UNPKG

@kadira/storybook

Version:

React Storybook: Isolate React Component Development with Hot Reloading.

122 lines (83 loc) 4.37 kB
#!/usr/bin/env node 'use strict'; var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _webpack = require('webpack'); var _webpack2 = _interopRequireDefault(_webpack); var _commander = require('commander'); var _commander2 = _interopRequireDefault(_commander); var _path = require('path'); var _path2 = _interopRequireDefault(_path); var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs); var _chalk = require('chalk'); var _chalk2 = _interopRequireDefault(_chalk); var _shelljs = require('shelljs'); var _shelljs2 = _interopRequireDefault(_shelljs); var _package = require('../../package.json'); var _package2 = _interopRequireDefault(_package); var _webpackConfig = require('./config/webpack.config.prod'); var _webpackConfig2 = _interopRequireDefault(_webpackConfig); var _config = require('./config'); var _config2 = _interopRequireDefault(_config); var _index = require('./index.html'); var _index2 = _interopRequireDefault(_index); var _iframe = require('./iframe.html'); var _iframe2 = _interopRequireDefault(_iframe); var _utils = require('./utils'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } process.env.NODE_ENV = process.env.NODE_ENV || 'production'; // avoid ESLint errors var logger = console; _commander2.default.version(_package2.default.version).option('-s, --static-dir <dir-names>', 'Directory where to load static files from', _utils.parseList).option('-o, --output-dir [dir-name]', 'Directory where to store built files').option('-c, --config-dir [dir-name]', 'Directory where to load Storybook configurations from').option('-d, --db-path [db-file]', 'DEPRECATED!').option('--enable-db', 'DEPRECATED!').parse(process.argv); logger.info(_chalk2.default.bold(_package2.default.name + ' v' + _package2.default.version + '\n')); if (_commander2.default.enableDb || _commander2.default.dbPath) { logger.error(['Error: the experimental local database addon is no longer bundled with', 'react-storybook. Please remove these flags (-d,--db-path,--enable-db)', 'from the command or npm script and try again.'].join(' ')); process.exit(1); } // The key is the field created in `program` variable for // each command line argument. Value is the env variable. (0, _utils.getEnvConfig)(_commander2.default, { staticDir: 'SBCONFIG_STATIC_DIR', outputDir: 'SBCONFIG_OUTPUT_DIR', configDir: 'SBCONFIG_CONFIG_DIR' }); var configDir = _commander2.default.configDir || './.storybook'; var outputDir = _commander2.default.outputDir || './storybook-static'; // create output directory (and the static dir) if not exists _shelljs2.default.rm('-rf', outputDir); _shelljs2.default.mkdir('-p', _path2.default.resolve(outputDir)); _shelljs2.default.cp(_path2.default.resolve(__dirname, 'public/favicon.ico'), outputDir); // Build the webpack configuration using the `baseConfig` // custom `.babelrc` file and `webpack.config.js` files // NOTE changes to env should be done before calling `getBaseConfig` var config = (0, _config2.default)('PRODUCTION', (0, _webpackConfig2.default)(), configDir); config.output.path = outputDir; // copy all static files if (_commander2.default.staticDir) { _commander2.default.staticDir.forEach(function (dir) { if (!_fs2.default.existsSync(dir)) { logger.error('Error: no such directory to load static files: ' + dir); process.exit(-1); } logger.log('=> Copying static files from: ' + dir); _shelljs2.default.cp('-r', dir + '/*', outputDir); }); } // compile all resources with webpack and write them to the disk. logger.log('Building storybook ...'); (0, _webpack2.default)(config).run(function (err, stats) { if (err) { logger.error('Failed to build the storybook'); logger.error(err.message); process.exit(1); } var data = { publicPath: config.output.publicPath, assets: stats.toJson().assetsByChunkName }; var headHtml = (0, _utils.getHeadHtml)(configDir); // Write both the storybook UI and IFRAME HTML files to destination path. _fs2.default.writeFileSync(_path2.default.resolve(outputDir, 'index.html'), (0, _index2.default)(data)); _fs2.default.writeFileSync(_path2.default.resolve(outputDir, 'iframe.html'), (0, _iframe2.default)((0, _extends3.default)({}, data, { headHtml: headHtml }))); });