Skip to content

OpenSourceTreasure/No-Distraction-Dark-Mode-HTML-Webpage

Repository files navigation

No-Distraction-Dark-Mode-HTML-Webpage

Sometimes you just need a blank webpage to look at so you can think and chill out in between projects. The HTML page, Title and Favicon are all in dark mode. There are two parts to this:

✅ HTML Webpage

✅ Favicon

The HTML Webpage uses simple code to create a "dark mode" page. It points to a black colored Favicon, so the tab will be in dark mode as well. The HTML title, which appears on the browser tab, is also blank, with the following code:

<title>&#65279;</title>

How to setup:

1️⃣ Decide where you will store the two files (HTML and Favicon). I recommend My Documents.

2️⃣ Change the below code in the HTML file to reflect the directory where you will store the Favicon:

<link rel="shortcut icon" type="image/x-icon" href="/Users/name/Documents/favicon.ico">

3️⃣ Put the HTML file in the same directory as the Favicon.

4️⃣ Rename the HTML file as you wish.

5️⃣ In your browser, set the Homepage to the HTML file that you renamed.

6️⃣ Make sure your browser is set to display the homepage icon.

7️⃣ Click the homepage icon and enjoy a few moments of quiet thinking..

screenshot

Here is the HTML if you want to copy and paste it:

<html>
<link rel="shortcut icon" type="image/x-icon" href="/Users/name/Documents/favicon.ico">
<head><title>&#65279;</title></head>
<body bgcolor="black">
</body>
</html>

🌟 In this version, the favicon image is embedded in the HTML via Base64. The filename is No Distraction Webpage - Base64 Favicon.html. The code is below:

<html>
<head>
    <link rel="shortcut icon" href="">
    <title>&#65279;</title>
</head>
<body bgcolor="black">
</body>
</html>

Relaxing Countdown Timer

In this version, you decide how long you want to see the blank page and relax. End the session by clicking stop on the bottom. Below is the code. The filename is "Home Time.html".

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>&#65279;</title>
    <style>
        @import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400&display=swap');

        body {
            background-color: black;
            color: white;
            font-family: 'Lato', sans-serif;
            text-align: center;
            position: relative;
            height: 100vh;
            margin: 0;
            transition: all 0.3s ease-in-out;
        }

        #header {
            font-size: 24px;
            margin-top: 1em;
        }

        #customTime {
            font-family: 'Lato', sans-serif;
            padding: 10px;
            border: 1px solid white;
            background-color: transparent;
            color: white;
            margin-top: 1em;
        }

        #startButton, #stopButton {
            background-color: transparent;
            color: white;
            border: none;
            cursor: pointer;
            padding: 10px 20px;
            font-size: 16px;
        }

        #inputSection {
            display: block;
            margin-top: 1em;
        }

        #countdownSection, #stopButton {
            display: none; /* Hide by default */
        }

        #stopButton {
            position: absolute;
            right: 20px;
            bottom: 20px;
        }

        #feedback {
            color: red;
            margin-top: 10px;
            display: none; /* Hide by default, shown on invalid input */
        }
    </style>
    <link rel="shortcut icon" type="image/x-icon" href="/Users/name/Documents/favicon.ico">
</head>
<body>
    <div id="header">It's time to relax...</div>
    <br> <!-- Line break added here -->
    <div id="inputSection">
        <input type="number" id="customTime" placeholder="Enter relaxation time">
        <button id="startButton" onclick="startCountdown()">Start</button>
        <div id="feedback"></div>
    </div>
    <div id="countdownSection">
        <!-- Countdown display goes here -->
    </div>
    <button id="stopButton" onclick="stopCountdown()">Stop</button>

    <script>
        const countdownSection = document.getElementById("countdownSection");
        const customTimeInput = document.getElementById("customTime");
        const inputSection = document.getElementById("inputSection");
        const stopButton = document.getElementById("stopButton");
        const feedback = document.getElementById('feedback');
        let intervalId = null;

        function startCountdown() {
            const relaxationTimeMinutes = parseInt(customTimeInput.value, 10);
            if (isNaN(relaxationTimeMinutes) || relaxationTimeMinutes <= 0) {
                feedback.textContent = "Please enter a valid time in minutes.";
                feedback.style.display = 'block';
                return;
            } else {
                feedback.style.display = 'none';
            }

            inputSection.style.display = 'none';
            countdownSection.style.display = 'block';
            stopButton.style.display = 'block';

            const endTime = Date.now() + relaxationTimeMinutes * 60 * 1000;

            function updateCountdown() {
                const currentTime = Date.now();
                const remainingTime = endTime - currentTime;

                if (remainingTime <= 0) {
                    countdownSection.textContent = "Time's up!";
                    clearInterval(intervalId);
                    stopCountdown();
                    return;
                }

                const minutes = Math.floor(remainingTime / 60000);
                const seconds = Math.floor((remainingTime % 60000) / 1000);

                countdownSection.textContent = `Time remaining: ${minutes} min ${seconds} sec`;
            }

            updateCountdown();
            intervalId = setInterval(updateCountdown, 1000);
        }

        function stopCountdown() {
            clearInterval(intervalId);
            countdownSection.style.display = 'none';
            stopButton.style.display = 'none';
            inputSection.style.display = 'block';
            customTimeInput.value = '';
        }
    </script>
</body>
</html>

⭐ Bonus Section ⭐

1️⃣ Redirect to HTML pages based on time of day

Someone may want two sets of links - one for day (work related) and one for night. In the below, you create two additional webpages - index-day.html and index-night.html. The code is currently set to redirect to index-day.html between 6am and 7pm (the 6 and 19 variables). No special code needed for the day and night index pages. Change the links as you wish (perhaps to even non-HTML links). A downloadable HTML file of the below is available.

<html lang="en">
<head>
<meta charset="UTF-8" />

<title>Links</title>

</head>
<body>
<script type="text/javascript">
// var SpecialRedirectURL = ['night.html','morning.html','day.html','eve.html'];
var SpecialRedirectURL = [
   'index-night.html',
   'index-day.html'
];

function specRedirect() {
  var currentTime = new Date();
  var currentHour = currentTime.getHours();
  var Hour = 0;
  if ( (currentHour >= 6) && (currentHour < 19) ) { Hour = 1; }
//  alert(Hour+' goes to: '+SpecialRedirectURL[Hour]);
  window.location.href = SpecialRedirectURL[Hour];
}  

window.onload = function() {
  specRedirect(); 
}

</script>
</body>
</html>

2️⃣ A dark mode wallpaper image for your smartphone

Skip the busy wallpaper photo that your apps are covering and go for simplicity! I created an image that is what I believe to be the largest commonly used resolution for smartphones - 3200 x 1440. It should resize perfectly for any smaller resolution as there are no pixels in it - just dark mode black. The below image can be downloaded as well. Rotate it if you need.

screenshot

Ideas for forks..

💡 Change the colors

💡 Add minimalist content like the weather

💡 Have the "time of day" webpage load applications based on time and even if-then statements

💡 Whatever else you can think of

Enjoy!

Releases

No releases published

Packages

No packages published

Languages