'use strict' const localBase = './water.css/' const fileSizes = { dark: 2.57, light: 2.55, auto: 3.27 } const themeForm = document.getElementById('theme-form') const stylesheet = document.getElementById('js-stylesheet') const startupStylesheet = document.getElementById('js-startup-stylesheet') const productHunt = document.querySelector('#product-hunt > img') const linkSnippets = [...document.querySelectorAll('#link-snippet-container > pre')] const table = { fileName: document.getElementById('table-file-name'), fileSize: document.getElementById('table-file-size'), theme: document.getElementById('table-theme'), npm: document.getElementById('table-npm') } const prefersColorScheme = window.matchMedia('(prefers-color-scheme: light)') const updateProductHunt = (theme) => { if (!productHunt) return theme = theme || (prefersColorScheme.matches ? 'light' : 'dark') productHunt.src = `https://api.producthunt.com/widgets/embed-image/v1/top-post-badge.svg?post_id=150490&theme=${theme}&period=daily` } const updateTheme = () => { const theme = document.querySelector('input[name="theme"]:checked').value localStorage.setItem('theme', theme) const fileName = `${theme === 'auto' ? 'water' : theme}.min.css` const localUrl = `${localBase}${fileName}` stylesheet.href = localUrl for (const snippet of linkSnippets) { snippet.hidden = snippet.id.indexOf(theme) === -1 } if (table.theme) { table.fileName.innerText = fileName table.fileSize.innerText = `${fileSizes[theme].toFixed(2)} kb` if (theme === 'auto') { updateProductHunt() table.theme.innerHTML = ` Respects user-defined theme settings using prefers-color-scheme.
Light in browsers where the theme settings can't be detected. ` } else { updateProductHunt(theme) table.theme.innerText = `Theme is forced to ${theme}.` } table.npm.innerHTML = ` Install with npm i water.css or yarn add water.css.

In JavaScript, where CSS imports are supported:
import 'water.css/out/${fileName}'

Usage from CSS depends on your bundler and dependency management setup, but in some cases may be as simple as a @import. ` } } const storedTheme = localStorage.getItem('theme') if (storedTheme) { themeForm.querySelector(`input[name="theme"][value="${storedTheme}"]`).checked = true } updateTheme() themeForm.addEventListener('change', updateTheme) startupStylesheet.parentElement.removeChild(startupStylesheet) prefersColorScheme.addListener(() => { if (themeForm.theme.value !== 'auto') return updateProductHunt() })