xm-roadhog
Version:
The xm-roadhog base on roadhog.
268 lines (207 loc) • 7.97 kB
JavaScript
;
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();