2022-01-25 22:09:53 +00:00
|
|
|
//
|
|
|
|
// This script bakes and copies themes, then generates a corresponding Lit stylesheet in dist/themes
|
|
|
|
//
|
|
|
|
import chalk from 'chalk';
|
|
|
|
import commandLineArgs from 'command-line-args';
|
|
|
|
import fs from 'fs';
|
|
|
|
import { mkdirSync } from 'fs';
|
|
|
|
import { globbySync } from 'globby';
|
|
|
|
import path from 'path';
|
|
|
|
import prettier from 'prettier';
|
|
|
|
import stripComments from 'strip-css-comments';
|
|
|
|
|
|
|
|
const { outdir } = commandLineArgs({ name: 'outdir', type: String });
|
|
|
|
const files = globbySync('./src/themes/**/[!_]*.css');
|
|
|
|
const filesToEmbed = globbySync('./src/themes/**/_*.css');
|
|
|
|
const themesDir = path.join(outdir, 'themes');
|
|
|
|
const embeds = {};
|
|
|
|
|
|
|
|
mkdirSync(themesDir, { recursive: true });
|
|
|
|
|
2023-06-07 20:14:25 +00:00
|
|
|
// Gather an object containing the source of all files named "_filename.css" so we can embed them later
|
|
|
|
filesToEmbed.forEach(file => {
|
|
|
|
embeds[path.basename(file)] = fs.readFileSync(file, 'utf8');
|
|
|
|
});
|
|
|
|
|
|
|
|
// Loop through each theme file, copying the .css and generating a .js version for Lit users
|
2023-10-12 17:56:11 +00:00
|
|
|
files.forEach(async file => {
|
2023-06-07 20:14:25 +00:00
|
|
|
let source = fs.readFileSync(file, 'utf8');
|
|
|
|
|
|
|
|
// If the source has "/* _filename.css */" in it, replace it with the embedded styles
|
|
|
|
Object.keys(embeds).forEach(key => {
|
|
|
|
source = source.replace(`/* ${key} */`, embeds[key]);
|
2022-01-25 22:09:53 +00:00
|
|
|
});
|
|
|
|
|
2023-10-12 17:56:11 +00:00
|
|
|
const css = await prettier.format(stripComments(source), {
|
2023-06-07 20:14:25 +00:00
|
|
|
parser: 'css'
|
|
|
|
});
|
2022-01-25 22:09:53 +00:00
|
|
|
|
2023-10-12 17:56:11 +00:00
|
|
|
let js = await prettier.format(
|
2023-06-07 20:14:25 +00:00
|
|
|
`
|
|
|
|
import { css } from 'lit';
|
2022-01-25 22:09:53 +00:00
|
|
|
|
2023-06-07 20:14:25 +00:00
|
|
|
export default css\`
|
|
|
|
${css}
|
|
|
|
\`;
|
|
|
|
`,
|
|
|
|
{ parser: 'babel-ts' }
|
|
|
|
);
|
2022-01-25 22:09:53 +00:00
|
|
|
|
2023-12-06 21:23:39 +00:00
|
|
|
let dTs = await prettier.format(
|
2023-12-06 21:16:52 +00:00
|
|
|
`
|
|
|
|
declare const _default: import("lit").CSSResult;
|
|
|
|
export default _default;
|
|
|
|
`,
|
|
|
|
{ parser: 'babel-ts' }
|
|
|
|
);
|
|
|
|
|
2023-06-07 20:14:25 +00:00
|
|
|
const cssFile = path.join(themesDir, path.basename(file));
|
|
|
|
const jsFile = path.join(themesDir, path.basename(file).replace('.css', '.styles.js'));
|
2023-12-06 21:16:52 +00:00
|
|
|
const dTsFile = path.join(themesDir, path.basename(file).replace('.css', '.styles.d.ts'));
|
2022-01-25 22:09:53 +00:00
|
|
|
|
2023-06-07 20:14:25 +00:00
|
|
|
fs.writeFileSync(cssFile, css, 'utf8');
|
|
|
|
fs.writeFileSync(jsFile, js, 'utf8');
|
2023-12-06 21:16:52 +00:00
|
|
|
fs.writeFileSync(dTsFile, dTs, 'utf8');
|
2023-06-07 20:14:25 +00:00
|
|
|
});
|