UNPKG

string-to-react-component

Version:

Dynamically create and render React components from strings at runtime, converting strings to React components for flexible UI generation.

53 lines (52 loc) 1.72 kB
const pkg = require('./package.json'); const terser = require('@rollup/plugin-terser'); const commonjs = require('@rollup/plugin-commonjs'); const nodeResolve = require('@rollup/plugin-node-resolve'); const name = pkg.name .split('-') .map((s) => s.charAt(0).toUpperCase() + s.slice(1)) .join(''); const Config = ({en, inputPath = '', outputFile = 'stringToReactComponent', pf = false}) => { var pfName = pf ? '.including-polyfills' : ''; return { input: `lib/${pf ? 'esm-including-polyfills' : 'esm'}/${inputPath}index.js`, output: { file: `dist/${outputFile}${pfName}.umd${en === 'dev' ? '' : '.min'}.js`, format: 'umd', name, banner: '' + `/** * ${pkg.name} - ${pkg.description} * * @version v${pkg.version} * @homepage ${pkg.homepage} * @author ${pkg.author.name} ${pkg.author.email} * @license ${pkg.license} */`, globals: { 'react-dom': 'ReactDOM', react: 'React', '@babel/standalone': 'Babel', }, sourcemap: true, }, plugins: (function () { const _plugins = [nodeResolve({preferBuiltins: false}), commonjs()]; if (en === 'prod') { _plugins.push(terser()); } return _plugins; })(), external: function (id) { return /prop-types$|react$|\@babel\/standalone$|react-dom$|.test.js$|.js.snap$|.css$/g.test(id); }, }; }, ConfigFactory = (op) => [ Config({en: 'dev', ...op}), Config({en: 'prod', ...op}), Config({en: 'dev', pf: true, ...op}), Config({en: 'prod', pf: true, ...op}), ]; module.exports = ConfigFactory();