vsc-material-theme/scripts/generator/index.ts
Alessio Occhipinti bf9a2bb6ed Feat/generator 1 iteration (#397)
* chore: added editor config and fix vscode settings

* fix: eslint and typescript

* chore: cleanup folders (gulp)

* feat: cleanup and working generator
2019-12-23 15:54:32 +01:00

33 lines
1,012 B
TypeScript

import * as fs from 'fs-extra';
import * as path from 'path';
import {generateTheme} from '@moxer/vscode-theme-generator';
import {ThemeSetting} from './types';
import {getColorSet} from './color-set';
import {BUILD_FOLDER_PATH} from '../../env';
const THEME_BUILD_PATH = path.join(BUILD_FOLDER_PATH, 'themes');
const themes = ['default', 'darker', 'lighter', 'ocean', 'palenight'];
const withHC = themes.reduce((acc, src) => {
acc = acc.concat(`${src}-hc`);
return acc;
}, themes);
const themeModules = withHC.map(async theme => import(`./settings/specific/${theme}`).then(res => res.default));
const generate = async (): Promise<void> => {
await fs.mkdirp(THEME_BUILD_PATH);
const modules = await Promise.all(themeModules) as ThemeSetting[];
modules.forEach(theme => {
const colorSet = getColorSet(theme);
generateTheme(theme.name, colorSet, path.join(THEME_BUILD_PATH, `${theme.name}.json`));
});
};
try {
generate();
} catch (error) {
console.error(error);
process.exit(1);
}