aaiCss: dist + '/css',
saCss: dist + '/editAttributes/css',
war: [dist + '**/*.html', dist + '**/*.js', dist + '**/*.{css,png,svg,eot,ttf,woff,woff2,otf}', dist + '**/*.json', 'webapp/**'],
+ bundleSrc:[dist + '**/*.map'],
wardest: dist
};
taskMaker.defineTask('clean', {taskName: 'clean', src: path.output});
taskMaker.defineTask('copy', {taskName: 'copy-aai-index.html', src: path.aaiIndex, dest: path.output, rename: 'index.html'});
taskMaker.defineTask('copy', {taskName: 'copy-sa-index.html', src: path.saIndex, dest: path.saOutput, rename: 'index.html'});
+taskMaker.defineTask('copy', {taskName: 'copy-sa-index.html', src: path.saIndex, dest: path.saOutput, rename: 'index.html'});
+taskMaker.defineTask('copy', {taskName: 'copy-map-file', src: path.bundleSrc, dest: path.output, rename: 'mappingFile'});
+taskMaker.defineTask('clean', {taskName: 'clean-map-file', src: path.bundleSrc});
/** Uncomment the loine below to generate a .war file with a local build */
// taskMaker.defineTask('compress', {taskName: 'compress-war', src: path.war, filename: appName + '.war', dest: path.wardest})
// Production build
gulp.task('build', callback => {
- return runSequence('clean', ['copy-stuff'], 'prod', callback);
+ return runSequence('clean', ['copy-stuff'], 'prod', 'copy-map-file', 'clean-map-file', callback);
/** Uncomment the loine below to generate a .war file with a local build */
//return runSequence('clean', ['copy-stuff'], 'prod', 'compress-war', callback);
});
return new Promise((resolve, reject)=> {
// configure webpack for production
- let webpackProductionConfig = Object.create(webpackConfig);
-
- for (let name in webpackProductionConfig.entry) {
- webpackProductionConfig.entry[name] = webpackProductionConfig.entry[name].filter(path => !path.startsWith('webpack'));
- }
-
- webpackProductionConfig.cache = true;
- webpackProductionConfig.output = {
- path: localPath.join(__dirname, 'dist'),
- publicPath: '',
- filename: '[name].js'
- };
- webpackProductionConfig.resolveLoader = {
- root: [localPath.resolve('.')],
- alias: {
- 'config-json-loader': 'tools/webpack/config-json-loader/index.js'
- }
- };
-
- // remove source maps
- webpackProductionConfig.devtool = undefined;
- webpackProductionConfig.module.preLoaders = webpackProductionConfig.module.preLoaders.filter(preLoader => preLoader.loader != 'source-map-loader');
- webpackProductionConfig.module.loaders.forEach(loader => {
- if (loader.loaders && loader.loaders[0] === 'style') {
- loader.loaders = loader.loaders.map(loaderName => loaderName.replace('?sourceMap', ''));
- }
- });
-
- webpackProductionConfig.module.loaders.push({test: /config.json$/, loaders: ['config-json-loader']});
- webpackProductionConfig.eslint = {
- configFile: './.eslintrc',
- failOnError: true
- };
- webpackProductionConfig.plugins = [
- new webpack.DefinePlugin({
- 'process.env.NODE_ENV': JSON.stringify('production')
- }),
- new webpack.optimize.DedupePlugin(),
- new webpack.optimize.UglifyJsPlugin()
- ];
-
- // run production build
+ let webpackProductionConfig = webpackConfig;
webpack(webpackProductionConfig, function (err, stats) {
console.log('[webpack:build]', stats.toString());
if (err || stats.hasErrors()) {
});
-
gulp.task('webpack-dev-server', () => {
let myConfig = Object.create(devWebpackConfig);
*/
'use strict';
-var path = require('path');
var webpack = require('webpack');
-var devPort = process.env.PORT || 8001;
+var path = require('path');
module.exports = {
- devtool: 'eval-source-map',
+ devtool: 'source-map',
+ cache: 'true',
entry: {
bundle: [
'app/main.app.jsx',
output: {
path: path.join(__dirname, 'dist'),
publicPath: ``,
- filename: '[name].js'
+ filename: '[name].js',
+ sourceMapFilename: '[name].js.map'
},
resolve: {
root: [path.resolve('.')],
},
extensions: ["", ".webpack.js", ".web.js", ".js", ".json", ".jsx"]
},
- devServer: {
- port: devPort,
- historyApiFallback: true,
- publicPath: `http://localhost:${devPort}/`,
- contentBase: path.join(__dirname, 'dist'),
- hot: true,
- progress: true,
- inline: true,
- debug: true,
- stats: {
- colors: true
- }
+ resolveLoader: {
+ root: [path.resolve('.')],
+ alias: {
+ 'config-json-loader': 'tools/webpack/config-json-loader/index.js'
+ }
},
module: {
- preLoaders: [{
- test: /\.(js|jsx)$/,
- loader: 'source-map-loader'
- }],
loaders: [
- {test: /\.(js|jsx)$/, loaders: ['babel-loader', 'eslint-loader', 'source-map-loader'], exclude: /node_modules/},
+ {test: /\.(js|jsx)$/, loaders: ['babel-loader', 'eslint-loader'], exclude: /node_modules/},
{test: /\.(css|scss)$/, loaders: ['style', 'css?sourceMap', 'sass?sourceMap']},
// required for font icons
{test: /\.(woff|woff2|ttf|eot|otf)(\?.*)?$/, loader: 'url-loader?limit=163840&mimetype=application/font-woff&name=[name].[ext]'},
{test: /\.(png|jpg|svg)(\?.*)?$/, loader: 'url-loader?limit=163840'},
{test: /\.json$/, loaders: ['json']},
- { test: /\.xml$/, loader: 'xml-loader' }
+ { test: /\.xml$/, loader: 'xml-loader' }
]
},
eslint: {
configFile: './.eslintrc',
+ failOnError: true,
emitError: true,
emitWarning: true
},
plugins: [
new webpack.DefinePlugin({
- DEBUG: true
- }),
-
- new webpack.HotModuleReplacementPlugin()
+ 'process.env.NODE_ENV': JSON.stringify('production')
+ }),
+ new webpack.optimize.DedupePlugin(),
+ new webpack.optimize.UglifyJsPlugin({ sourceMap: true })
]
};
var path = require('path');
var webpack = require('webpack');
var devPort = process.env.PORT || 8001;
+var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
module.exports = {
- devtool: 'eval-source-map',
+ devtool: 'source-map',
entry: {
bundle: [
'app/main.app.jsx',
output: {
path: path.join(__dirname, 'dist'),
publicPath: ``,
- filename: '[name].js'
+ filename: '[name].js',
+ sourceMapFilename: '[name].js.map'
},
resolve: {
root: [path.resolve('.')],
}
},
module: {
- preLoaders: [
- {test: /\.(js|jsx)$/, loader: 'source-map-loader'}
- ],
loaders: [
{test: /\.(js|jsx)$/, loaders: ['babel-loader', 'eslint-loader'], exclude: /node_modules/},
{test: /\.(css|scss)$/, loaders: ['style-loader', 'css-loader', 'sass-loader']},
emitWarning: true
},
plugins: [
+ //new BundleAnalyzerPlugin(),
new webpack.DefinePlugin({
DEBUG: true
}),