mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-08 03:11:49 +08:00
116 lines
4.2 KiB
JavaScript
116 lines
4.2 KiB
JavaScript
#!/usr/bin/env node
|
|
'use strict';
|
|
|
|
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 _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]', 'Path to the addon database JSON file').option('--enable-db', 'Enable the (experimental) addon database service on dev-server').parse(process.argv);
|
|
|
|
// 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: 'STORYBOOK_STATIC_DIR',
|
|
outputDir: 'STORYBOOK_OUTPUT_DIR',
|
|
configDir: 'STORYBOOK_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);
|
|
|
|
// The addon database service is disabled by default for now
|
|
// It should be enabled with the --enable-db for dev server
|
|
if (_commander2.default.enableDb) {
|
|
// NOTE enables database on client
|
|
process.env.STORYBOOK_ENABLE_DB = 1;
|
|
var dbPath = _commander2.default.dbPath || _path2.default.resolve(configDir, 'addon-db.json');
|
|
// create addon-db.json file if it's missing to avoid the 404 error
|
|
if (!_fs2.default.existsSync(dbPath)) {
|
|
_fs2.default.writeFileSync(dbPath, '{}');
|
|
}
|
|
_shelljs2.default.cp(dbPath, 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);
|
|
});
|
|
}
|
|
|
|
// Write both the storybook UI and IFRAME HTML files to destination path.
|
|
var headHtml = (0, _utils.getHeadHtml)(configDir);
|
|
var publicPath = config.output.publicPath;
|
|
_fs2.default.writeFileSync(_path2.default.resolve(outputDir, 'index.html'), (0, _index2.default)(publicPath));
|
|
_fs2.default.writeFileSync(_path2.default.resolve(outputDir, 'iframe.html'), (0, _iframe2.default)(headHtml, publicPath));
|
|
|
|
// compile all resources with webpack and write them to the disk.
|
|
logger.log('Building storybook ...');
|
|
(0, _webpack2.default)(config).run(function (err) {
|
|
if (err) {
|
|
logger.error('Failed to build the storybook');
|
|
logger.error(err.message);
|
|
process.exit(1);
|
|
}
|
|
}); |