/** * Check if the less compiler is done rendering Less stylesheets into CSS. * * @returns {boolean} `true` if the rendering is complete, `false` otherwise. */ function isLessDone() { const lessSheets = document.querySelectorAll('link[rel="stylesheet/less"]') const cssSheets = document.querySelectorAll('style') return lessSheets.length === cssSheets.length } /** * Pause an async function until {@link isLessDone Less is done}. * * @returns {Promise<void>} Awaitable that waits until {@link isLessDone Less is done}. */ async function sleepUntilLessIsDone() { while(!isLessDone()) { await new Promise(resolve => setTimeout(resolve, 100)) } } const enabledByDefault = [ "less:bluelib-dist-base:root", "less:bluelib-dist-classic:root", "less:bluelib-dist-glass:root", "less:bluelib-dist-colors-royalblue:root", "less:bluelib-dist-fonts-fira-ghpages:root", ] let lessStyles = undefined let lessColors = undefined let lessFonts = undefined async function enableChanges() { await sleepUntilLessIsDone() lessStyles = [...document.styleSheets].filter( (s) => s.ownerNode.id.startsWith("less:bluelib-dist") ).map( (s) => ({[s.ownerNode.id]: s}) ).reduce( (p, c) => ({...p, ...c}), {} ) console.debug("Found Less stylesheets:", lessStyles) lessColors = [...document.styleSheets].filter( (s) => s.ownerNode.id.startsWith("less:bluelib-dist-colors") ).map( (s) => ({[s.ownerNode.id]: s}) ).reduce( (p, c) => ({...p, ...c}), {} ) console.debug("Found Less colors:", lessColors) lessFonts = [...document.styleSheets].filter( (s) => s.ownerNode.id.startsWith("less:bluelib-dist-fonts") ).map( (s) => ({[s.ownerNode.id]: s}) ).reduce( (p, c) => ({...p, ...c}), {} ) console.debug("Found Less fonts:", lessFonts) for(const [k, v] of Object.entries(lessStyles)) { v.disabled = !enabledByDefault.includes(k) } for(const input of document.querySelectorAll(".ruleset-toggle")) { input.disabled = false input.parentElement.classList.remove("fade") } } function toggleStyle(name) { if(lessStyles === undefined) { console.error("Less stylesheets are not yet available.") return } const style = lessStyles[name] if(style === undefined) { console.error("No such Less stylesheet.") return } style.disabled = !style.disabled } function selectColor(name) { if(lessColors === undefined) { console.error("Less stylesheets are not yet available.") return } const style = lessStyles[name] if(style === undefined) { console.error("No such Less stylesheet.") return } for(const c of Object.values(lessColors)) { c.disabled = true } style.disabled = false } enableChanges()