* Added a Nix Flake and support for running from the Nix Store * Removed variable imports since they're brough in at the top level. * Removed redundan imports and remove unused files (moved to temp). --------- Co-authored-by: Jas Singh <jaskiratpal.singh@outlook.com>
74 lines
2.1 KiB
TypeScript
74 lines
2.1 KiB
TypeScript
/* eslint-disable max-len */
|
|
import { type Opt } from "lib/option"
|
|
import options from "options"
|
|
import { bash, dependencies } from "lib/utils"
|
|
|
|
const deps = [
|
|
"font",
|
|
"theme",
|
|
"bar.flatButtons",
|
|
"bar.position",
|
|
"bar.battery.charging",
|
|
"bar.battery.blocks",
|
|
]
|
|
|
|
const $ = (name: string, value: string | Opt<any>) => `$${name}: ${value};`
|
|
|
|
function extractVariables(theme: any, prefix: string = ""): string[] {
|
|
let result: string[] = [];
|
|
for (let key in theme) {
|
|
if (theme.hasOwnProperty(key)) {
|
|
const value = theme[key];
|
|
const newPrefix = prefix ? `${prefix}-${key}` : key;
|
|
|
|
if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
|
|
// Check if the object contains an Opt value or is a nested object
|
|
if (typeof value.value !== 'undefined') {
|
|
result.push($(`${newPrefix}`, `${value.value}`));
|
|
} else {
|
|
result = result.concat(extractVariables(value, newPrefix));
|
|
}
|
|
} else if (typeof value === 'function' && value.name === 'opt') {
|
|
result.push($(`${newPrefix}`, value));
|
|
}
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
|
|
const variables = () => [
|
|
...extractVariables(options.theme),
|
|
];
|
|
|
|
async function resetCss() {
|
|
if (!dependencies("sass"))
|
|
return
|
|
|
|
try {
|
|
const vars = `${TMP}/variables.scss`
|
|
const css = `${TMP}/main.css`
|
|
const scss = `${TMP}/entry.scss`
|
|
const localScss = `${App.configDir}/scss/main.scss`;
|
|
|
|
await Utils.writeFile(variables().join("\n"), vars)
|
|
const imports = [vars].map(f => `@import '${f}';`)
|
|
|
|
let mainScss = Utils.readFile(localScss);
|
|
mainScss = `${imports}\n${mainScss}`;
|
|
|
|
await Utils.writeFile(mainScss, scss)
|
|
|
|
await bash(`sass --load-path=${App.configDir}/scss/ ${scss} ${css}`);
|
|
|
|
App.applyCss(css, true);
|
|
} catch (error) {
|
|
error instanceof Error
|
|
? logError(error)
|
|
: console.error(error)
|
|
}
|
|
}
|
|
|
|
Utils.monitorFile(`${App.configDir}/scss/style`, resetCss)
|
|
options.handler(deps, resetCss)
|
|
await resetCss()
|