X-Git-Url: https://gerrit.onap.org/r/gitweb?p=aai%2Fsparky-fe.git;a=blobdiff_plain;f=gulpfile.js;h=93670fc113708ff3fe45a795409e37b06269296b;hp=c74b23f812cdefce249d4972ea49331ab2e89d70;hb=refs%2Fheads%2Fmaster;hpb=ca007e933bcd9f63aa77801656ed9dd4142c432c diff --git a/gulpfile.js b/gulpfile.js index c74b23f..ea284b1 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -1,35 +1,28 @@ /* - * ============LICENSE_START=================================================== - * SPARKY (AAI UI service) - * ============================================================================ - * Copyright © 2017 AT&T Intellectual Property. - * Copyright © 2017 Amdocs - * All rights reserved. - * ============================================================================ + * ============LICENSE_START======================================================= + * org.onap.aai + * ================================================================================ + * Copyright © 2017-2018 AT&T Intellectual Property. All rights reserved. + * Copyright © 2017-2018 Amdocs + * ================================================================================ * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. - * ============LICENSE_END===================================================== - * - * ECOMP and OpenECOMP are trademarks - * and service marks of AT&T Intellectual Property. + * ============LICENSE_END========================================================= */ - 'use strict'; var localPath = require('path'); var gulp = require('gulp'); -var gulpHelpers = require('gulp-helpers'); -var taskMaker = gulpHelpers.taskMaker(gulp); -var runSequence = gulpHelpers.framework('run-sequence'); +const del = require('del'); var gulpCssUsage = require('gulp-css-usage').default; var webpack = require('webpack'); var WebpackDevServer = require('webpack-dev-server'); @@ -48,82 +41,45 @@ let path = { scss: './resources/scss/**/*.scss', aaiCss: dist + '/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'}); +gulp.task('clean', () => { + return del(path.output); +}) -gulp.task('copy-dev-stuff', callback => { - return runSequence(['copy-aai-index.html'], callback); +gulp.task('copy-aai-index.html', () => { + return gulp.src(path.aaiIndex) + .pipe(gulp.dest(path.output)); }); -gulp.task('copy-stuff', callback => { - return runSequence(['copy-aai-index.html'], callback); +gulp.task('copy-map-file', () => { + return gulp.src(path.bundleSrc) + .pipe(gulp.dest(path.output)); }); -gulp.task('dev', callback => { - return runSequence('clean', 'copy-dev-stuff', 'webpack-dev-server', callback); +gulp.task('clean-map-file', () => { + return del(path.bundleSrc); }); -// Production build -gulp.task('build', callback => { - return runSequence('clean', ['copy-stuff'], 'prod', callback); -}); +gulp.task('webpack-dev-server', () => { + let myConfig = Object.create(devWebpackConfig); -gulp.task('default', ['dev']); + // Start a webpack-dev-server + let server = new WebpackDevServer(webpack(myConfig), myConfig.devServer); + server.listen(myConfig.devServer.port, '0.0.0.0', err => { + if (err) { + throw new Error('webpack-dev-server' + err); + } + }); +}); gulp.task('prod', () => { 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: '/services/aai/webapp/', - 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': { - // This has effect on the react lib size - 'NODE_ENV': JSON.stringify('production') - }, - DEBUG: false, - DEV: false - }), - 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()) { @@ -139,14 +95,12 @@ gulp.task('prod', () => { }); -gulp.task('webpack-dev-server', () => { - let myConfig = Object.create(devWebpackConfig); +gulp.task('copy-dev-stuff', gulp.series('copy-aai-index.html')); - // Start a webpack-dev-server - let server = new WebpackDevServer(webpack(myConfig), myConfig.devServer); - server.listen(myConfig.devServer.port, '0.0.0.0', err => { - if (err) { - throw new Error('webpack-dev-server' + err); - } - }); -}); +gulp.task('copy-stuff', gulp.series('copy-aai-index.html')); + +gulp.task('dev', gulp.series('clean', 'copy-dev-stuff', 'webpack-dev-server')); + +gulp.task('build', gulp.series('clean', 'copy-stuff', 'prod', 'copy-map-file', 'clean-map-file')); + +gulp.task('default', gulp.series('dev'));