UNPKG

xm-roadhog

Version:

The xm-roadhog base on roadhog.

268 lines (207 loc) 7.97 kB
'use strict'; var _detectPort = require('detect-port'); var _detectPort2 = _interopRequireDefault(_detectPort); var _clearConsole = require('react-dev-utils/clearConsole'); var _clearConsole2 = _interopRequireDefault(_clearConsole); var _getProcessForPort = require('react-dev-utils/getProcessForPort'); var _getProcessForPort2 = _interopRequireDefault(_getProcessForPort); var _formatWebpackMessages = require('react-dev-utils/formatWebpackMessages'); var _formatWebpackMessages2 = _interopRequireDefault(_formatWebpackMessages); var _openBrowser = require('react-dev-utils/openBrowser'); var _openBrowser2 = _interopRequireDefault(_openBrowser); var _prompt = require('react-dev-utils/prompt'); var _prompt2 = _interopRequireDefault(_prompt); var _webpack = require('webpack'); var _webpack2 = _interopRequireDefault(_webpack); var _connectHistoryApiFallback = require('connect-history-api-fallback'); var _connectHistoryApiFallback2 = _interopRequireDefault(_connectHistoryApiFallback); var _webpackDevServer = require('webpack-dev-server'); var _webpackDevServer2 = _interopRequireDefault(_webpackDevServer); var _chalk = require('chalk'); var _chalk2 = _interopRequireDefault(_chalk); var _chokidar = require('chokidar'); var _chokidar2 = _interopRequireDefault(_chokidar); var _paths = require('./config/paths'); var _paths2 = _interopRequireDefault(_paths); var _getConfig = require('./utils/getConfig'); var _getConfig2 = _interopRequireDefault(_getConfig); var _applyWebpackConfig = require('./utils/applyWebpackConfig'); var _applyWebpackConfig2 = _interopRequireDefault(_applyWebpackConfig); var _mock = require('./utils/mock'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } process.env.NODE_ENV = 'development'; var DEFAULT_PORT = process.env.PORT ? parseInt(process.env.PORT, 10) : 8000; var isInteractive = process.stdout.isTTY; var cwd = process.cwd(); var paths = (0, _paths2.default)(cwd); var compiler = void 0; var argv = require('yargs').usage('Usage: roadhog server [options]').option('open', { type: 'boolean', describe: 'Open url in browser after started', default: true }).help('h').argv; var rcConfig = void 0; var config = void 0; function clearConsoleWrapped() { if (process.env.CLEAR_CONSOLE !== 'NONE') { (0, _clearConsole2.default)(); } } function readRcConfig() { try { rcConfig = (0, _getConfig2.default)(process.env.NODE_ENV, cwd); } catch (e) { console.log(_chalk2.default.red('Failed to parse .roadhogrc config.')); console.log(); console.log(e.message); process.exit(1); } } function readWebpackConfig() { config = (0, _applyWebpackConfig2.default)(require('./config/webpack.config.dev')(rcConfig, cwd), process.env.NODE_ENV); } function setupCompiler(host, port, protocol) { compiler = (0, _webpack2.default)(config); compiler.plugin('invalid', function () { if (isInteractive) { clearConsoleWrapped(); } console.log('Compiling...'); }); var isFirstCompile = true; compiler.plugin('done', function (stats) { if (isInteractive) { clearConsoleWrapped(); } var messages = (0, _formatWebpackMessages2.default)(stats.toJson({}, true)); var isSuccessful = !messages.errors.length && !messages.warnings.length; var showInstructions = isSuccessful && (isInteractive || isFirstCompile); (0, _applyWebpackConfig.warnIfExists)(); if (isSuccessful) { console.log(_chalk2.default.green('Compiled successfully!')); } if (showInstructions) { console.log(); console.log('The app is running at:'); console.log(); console.log(' ' + _chalk2.default.cyan(protocol + '://' + host + ':' + port + '/')); console.log(); console.log('Note that the development build is not optimized.'); console.log('To create a production build, use ' + _chalk2.default.cyan('npm run build') + '.'); console.log(); isFirstCompile = false; } // If errors exist, only show errors. if (messages.errors.length) { console.log(_chalk2.default.red('Failed to compile.')); console.log(); messages.errors.forEach(function (message) { console.log(message); console.log(); }); // Show warnings if no errors were found. } else if (messages.warnings.length) { console.log(_chalk2.default.yellow('Compiled with warnings.')); console.log(); messages.warnings.forEach(function (message) { console.log(message); console.log(); }); // Teach some ESLint tricks. console.log('You may use special comments to disable some warnings.'); console.log('Use ' + _chalk2.default.yellow('// eslint-disable-next-line') + ' to ignore the next line.'); console.log('Use ' + _chalk2.default.yellow('/* eslint-disable */') + ' to ignore all warnings in a file.'); console.log(); } if (isInteractive) { (0, _mock.outputError)(); } }); } function addMiddleware(devServer) { var proxy = require(paths.appPackageJson).proxy; // eslint-disable-line devServer.use((0, _connectHistoryApiFallback2.default)({ disableDotRule: true, htmlAcceptHeaders: proxy ? ['text/html'] : ['text/html', '*/*'] })); // TODO: proxy index.html, ... devServer.use(devServer.middleware); } function runDevServer(host, port, protocol) { var devServer = new _webpackDevServer2.default(compiler, { compress: true, clientLogLevel: 'none', contentBase: paths.appPublic, hot: true, publicPath: config.output.publicPath, quiet: true, watchOptions: { ignored: /node_modules/ }, https: protocol === 'https', host: host, proxy: rcConfig.proxy }); addMiddleware(devServer); (0, _mock.applyMock)(devServer); devServer.listen(port, function (err) { if (err) { return console.log(err); } process.send('READY'); if (isInteractive) { clearConsoleWrapped(); } console.log(_chalk2.default.cyan('Starting the development server...')); console.log(); if (isInteractive) { (0, _mock.outputError)(); } if (argv.open) { (0, _openBrowser2.default)(protocol + '://' + host + ':' + port + '/'); } }); setupWatch(devServer, port); } function setupWatch(devServer) { var files = [paths.resolveApp('.roadhogrc'), paths.resolveApp('.roadhogrc.js'), paths.resolveApp('webpack.config.js')].concat(typeof rcConfig.theme === 'string' ? paths.resolveApp(rcConfig.theme) : []); var watcher = _chokidar2.default.watch(files, { ignored: /node_modules/, persistent: true }); watcher.on('change', function (path) { console.log(_chalk2.default.green('File ' + path.replace(paths.appDirectory, '.') + ' changed, try to restart server')); watcher.close(); devServer.close(); process.send('RESTART'); }); } function run(port) { var protocol = process.env.HTTPS === 'true' ? 'https' : 'http'; var host = process.env.HOST || 'localhost'; setupCompiler(host, port, protocol); runDevServer(host, port, protocol); } function init() { readRcConfig(); readWebpackConfig(); (0, _detectPort2.default)(DEFAULT_PORT).then(function (port) { if (port === DEFAULT_PORT) { run(port); return; } if (isInteractive) { clearConsoleWrapped(); var existingProcess = (0, _getProcessForPort2.default)(DEFAULT_PORT); var question = _chalk2.default.yellow('Something is already running on port ' + DEFAULT_PORT + '.' + (existingProcess ? ' Probably:\n ' + existingProcess : '') + '\n\nWould you like to run the app on another port instead?'); (0, _prompt2.default)(question, true).then(function (shouldChangePort) { if (shouldChangePort) { run(port); } }); } else { console.log(_chalk2.default.red('Something is already running on port ' + DEFAULT_PORT + '.')); } }); } init();