@anansi/generator-js
Version:
Generate Fast React Web Apps
83 lines • 13.5 kB
JavaScript
import { execa } from 'execa';
import { BetterGenerator } from '../utils.js';
export default class WebpackGenerator extends BetterGenerator {
props;
constructor(args, options, features) {
super(args, options, features);
this.config.set('webpack', true);
}
async prompting() {
const prompts = [
// TODO: actually do something with this
{
type: 'list',
name: 'style',
message: 'SCSS with CSS modules and Linaria can both be used for styling.\nWhich would you like in the generated example?',
default: 'linaria',
choices: [{
name: 'SASS/CSS modules',
value: 'sass'
}, {
name: 'Linaria (CSS-in-JS)',
value: 'linaria'
}],
store: true
}];
this.props = await this.prompt(prompts);
this.config.set('style', this?.props?.style);
await this.createCert();
}
async createCert() {
const cwd = this.destinationRoot();
try {
await execa(`mkcert localhost 127.0.0.1`, [], {
cwd,
shell: true
});
this.config.set('devssl', /*true*/false); //TODO: figure out how to make this actually work
} catch (e) {
this.config.set('devssl', false);
}
}
configuring() {
this.packageJson.merge(this.fs.readJSONTpl(this.templatePath('package.json.tpl')));
// TODO: Remove once https://github.com/facebook/create-react-app/issues/11773 is fixed
this.packageJson.merge({
resolutions: {
'react-error-overlay': '6.0.9'
}
});
}
async writingDependencies() {
await this.addDevDependencies(['webpack', 'webpack-cli', 'webpack-dev-server', '@anansi/webpack-config']);
if (!this.config.get('features').includes('SSR')) {
await this.addDevDependencies(['serve']);
}
if (this?.props?.style === 'linaria') {
await this.addDevDependencies(['@linaria/core', '@linaria/react']);
if (this.config.get('features')?.includes?.('testing')) {
await this.addDevDependencies(['@wyw-in-js/babel-preset']);
}
} else if (this?.props?.style === 'sass') {
await this.addDevDependencies(['sass']);
}
}
writing() {
if (this?.props?.style === 'sass') {
this.fs.copyTpl(this.templatePath('src/style/**'), this.destinationPath(this.config.get('rootPath'), 'style'), this.config.getAll(), {}, {
globOptions: {
dot: true
}
});
}
this.fs.copyTpl(this.templatePath('webpack.config.js'), this.destinationPath('webpack.config.js'), this.config.getAll());
this.fs.extendJSONTpl(this.templatePath('tsconfig.json'), this.destinationPath('tsconfig.json'));
this.fs.appendTpl(this.templatePath('README.md'), this.destinationPath('README.md'), this.config.getAll());
this.fs.copy(this.templatePath('index.ejs'), this.destinationPath('index.ejs'));
if (this?.props?.style === 'linaria') {
this.fs.copyTpl(this.templatePath('.babelrc.js'), this.destinationPath('.babelrc.js'), this.config.getAll());
this.fs.appendTpl(this.templatePath('.gitignore.tpl'), this.destinationPath('.gitignore'), this.config.getAll());
}
}
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["execa","BetterGenerator","WebpackGenerator","props","constructor","args","options","features","config","set","prompting","prompts","type","name","message","default","choices","value","store","prompt","style","createCert","cwd","destinationRoot","shell","e","configuring","packageJson","merge","fs","readJSONTpl","templatePath","resolutions","writingDependencies","addDevDependencies","get","includes","writing","copyTpl","destinationPath","getAll","globOptions","dot","extendJSONTpl","appendTpl","copy"],"sources":["../../src/webpack/index.ts"],"sourcesContent":["import { execa } from 'execa';\nimport { BaseFeatures, BaseOptions } from 'yeoman-generator';\n\nimport { BetterGenerator } from '../utils.js';\n\nexport default class WebpackGenerator extends BetterGenerator<WebpackOptions> {\n  props?: Record<string, any>;\n\n  constructor(\n    args: string | string[],\n    options: WebpackOptions,\n    features: BaseFeatures,\n  ) {\n    super(args, options, features);\n    this.config.set('webpack', true);\n  }\n\n  async prompting() {\n    const prompts = [\n      // TODO: actually do something with this\n      {\n        type: 'list',\n        name: 'style',\n        message:\n          'SCSS with CSS modules and Linaria can both be used for styling.\\nWhich would you like in the generated example?',\n        default: 'linaria',\n        choices: [\n          {\n            name: 'SASS/CSS modules',\n            value: 'sass',\n          },\n          {\n            name: 'Linaria (CSS-in-JS)',\n            value: 'linaria',\n          },\n        ],\n        store: true,\n      },\n    ];\n\n    this.props = await this.prompt(prompts);\n    this.config.set('style', this?.props?.style);\n\n    await this.createCert();\n  }\n\n  async createCert() {\n    const cwd = this.destinationRoot();\n    try {\n      await execa(`mkcert localhost 127.0.0.1`, [], {\n        cwd,\n        shell: true,\n      });\n      this.config.set('devssl', /*true*/ false); //TODO: figure out how to make this actually work\n    } catch (e) {\n      this.config.set('devssl', false);\n    }\n  }\n\n  configuring() {\n    this.packageJson.merge(\n      this.fs.readJSONTpl(this.templatePath('package.json.tpl')),\n    );\n    // TODO: Remove once https://github.com/facebook/create-react-app/issues/11773 is fixed\n    this.packageJson.merge({\n      resolutions: {\n        'react-error-overlay': '6.0.9',\n      },\n    });\n  }\n\n  async writingDependencies() {\n    await this.addDevDependencies([\n      'webpack',\n      'webpack-cli',\n      'webpack-dev-server',\n      '@anansi/webpack-config',\n    ]);\n    if (!this.config.get('features').includes('SSR')) {\n      await this.addDevDependencies(['serve']);\n    }\n    if (this?.props?.style === 'linaria') {\n      await this.addDevDependencies(['@linaria/core', '@linaria/react']);\n      if (this.config.get('features')?.includes?.('testing')) {\n        await this.addDevDependencies(['@wyw-in-js/babel-preset']);\n      }\n    } else if (this?.props?.style === 'sass') {\n      await this.addDevDependencies(['sass']);\n    }\n  }\n\n  writing() {\n    if (this?.props?.style === 'sass') {\n      this.fs.copyTpl(\n        this.templatePath('src/style/**'),\n        this.destinationPath(this.config.get('rootPath'), 'style'),\n        this.config.getAll(),\n        {},\n        { globOptions: { dot: true } },\n      );\n    }\n    this.fs.copyTpl(\n      this.templatePath('webpack.config.js'),\n      this.destinationPath('webpack.config.js'),\n      this.config.getAll(),\n    );\n    this.fs.extendJSONTpl(\n      this.templatePath('tsconfig.json'),\n      this.destinationPath('tsconfig.json'),\n    );\n    this.fs.appendTpl(\n      this.templatePath('README.md'),\n      this.destinationPath('README.md'),\n      this.config.getAll(),\n    );\n    this.fs.copy(\n      this.templatePath('index.ejs'),\n      this.destinationPath('index.ejs'),\n    );\n\n    if (this?.props?.style === 'linaria') {\n      this.fs.copyTpl(\n        this.templatePath('.babelrc.js'),\n        this.destinationPath('.babelrc.js'),\n        this.config.getAll(),\n      );\n      this.fs.appendTpl(\n        this.templatePath('.gitignore.tpl'),\n        this.destinationPath('.gitignore'),\n        this.config.getAll(),\n      );\n    }\n  }\n}\n\ntype WebpackOptions = BaseOptions;\n"],"mappings":"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","ignoreList":[]}