diff --git a/.gitignore b/.gitignore index ec19f842..1bab51eb 100644 --- a/.gitignore +++ b/.gitignore @@ -25,6 +25,8 @@ libs/ [Jj]ni[Ll]ibs/ .vs/ *.js +!postcss.config.js +!webpack.config.js .codelite/ .build-*/ *.tlog diff --git a/src/client/postcss.config.js b/src/client/postcss.config.js new file mode 100644 index 00000000..a0995453 --- /dev/null +++ b/src/client/postcss.config.js @@ -0,0 +1 @@ +module.exports = {}; \ No newline at end of file diff --git a/src/client/webpack.config.js b/src/client/webpack.config.js new file mode 100644 index 00000000..ba4912eb --- /dev/null +++ b/src/client/webpack.config.js @@ -0,0 +1,395 @@ +const path = require('path'); +const webpack = require('webpack'); +const ProgressPlugin = require('webpack/lib/ProgressPlugin'); +const HtmlWebpackPlugin = require('html-webpack-plugin'); +const ExtractTextPlugin = require('extract-text-webpack-plugin'); +const autoprefixer = require('autoprefixer'); +const postcssUrl = require('postcss-url'); +const ConcatPlugin = require('webpack-concat-plugin'); + +const { NoEmitOnErrorsPlugin, LoaderOptionsPlugin, DefinePlugin, HashedModuleIdsPlugin } = require('webpack'); +const { GlobCopyWebpackPlugin, BaseHrefWebpackPlugin, InsertConcatAssetsWebpackPlugin } = require('@angular/cli/plugins/webpack'); +const { CommonsChunkPlugin, UglifyJsPlugin } = require('webpack').optimize; +const { AotPlugin } = require('@ngtools/webpack'); + +const nodeModules = path.join(process.cwd(), 'node_modules'); +const entryPoints = ["inline", "polyfills", "sw-register", "styles", "vendor", "main"]; +const baseHref = ""; +const deployUrl = ""; + +const isProd = (process.env.NODE_ENV === 'production'); + +//add all external css to be added in our index.html--> like as if it's .angular-cli.json +const styles = [ + "./src/styles.scss" +]; + +//we add all our external scripts we want to load externally, like inserting in our index.html --> like as if it's .angular-cli.json +const scripts = [ +]; + +//create file path for each , so we use for our excludes and includes where needed +let style_paths = styles.map(style_src => path.join(process.cwd(), style_src)); + +function getPlugins() { + var plugins = []; + + // Always expose NODE_ENV to webpack, you can now use `process.env.NODE_ENV` + // inside your code for any environment checks; UglifyJS will automatically + // drop any unreachable code. + plugins.push(new DefinePlugin({ + "process.env.NODE_ENV": "\"production\"" + })); + + plugins.push(new NoEmitOnErrorsPlugin()); + +if(scripts.length > 0){ + plugins.push(new ConcatPlugin({ + "uglify": false, + "sourceMap": true, + "name": "scripts", + "fileName": "[name].bundle.js", + "filesToConcat": scripts + })); + plugins.push(new InsertConcatAssetsWebpackPlugin([ + "scripts" + ])); +} + + plugins.push(new GlobCopyWebpackPlugin({ + "patterns": [ + "assets", + "favicon.ico" + ], + "globOptions": { + "cwd": process.cwd() + "/src", + "dot": true, + "ignore": "**/.gitkeep" + } + })); + + plugins.push(new ProgressPlugin()); + + plugins.push(new HtmlWebpackPlugin({ + "template": "./src/index.html", + "filename": "./index.html", + "hash": false, + "inject": true, + "compile": true, + "favicon": false, + "minify": false, + "cache": true, + "showErrors": true, + "chunks": "all", + "excludeChunks": [], + "title": "Webpack App", + "xhtml": true, + "chunksSortMode": function sort(left, right) { + let leftIndex = entryPoints.indexOf(left.names[0]); + let rightindex = entryPoints.indexOf(right.names[0]); + if (leftIndex > rightindex) { + return 1; + } + else if (leftIndex < rightindex) { + return -1; + } + else { + return 0; + } + } + })); + + plugins.push(new BaseHrefWebpackPlugin({})); + + plugins.push(new CommonsChunkPlugin({ + "name": "inline", + "minChunks": null + })); + + plugins.push(new CommonsChunkPlugin({ + "name": "vendor", + "minChunks": (module) => module.resource && module.resource.startsWith(nodeModules), + "chunks": [ + "main" + ] + })); + + plugins.push(new ExtractTextPlugin({ + "filename": "[name].bundle.css", + "disable": true + })); + + plugins.push(new LoaderOptionsPlugin({ + "sourceMap": false, + "options": { + "postcss": [ + autoprefixer(), + postcssUrl({ + "url": (obj) => { + // Only convert root relative URLs, which CSS-Loader won't process into require(). + if (!obj.url.startsWith('/') || obj.url.startsWith('//')) { + return obj.url; + } + if (deployUrl.match(/:\/\//)) { + // If deployUrl contains a scheme, ignore baseHref use deployUrl as is. + return `${deployUrl.replace(/\/$/, '')}${obj.url}`; + } + else if (baseHref.match(/:\/\//)) { + // If baseHref contains a scheme, include it as is. + return baseHref.replace(/\/$/, '') + + `/${deployUrl}/${obj.url}`.replace(/\/\/+/g, '/'); + } + else { + // Join together base-href, deploy-url and the original URL. + // Also dedupe multiple slashes into single ones. + return `/${baseHref}/${deployUrl}/${obj.url}`.replace(/\/\/+/g, '/'); + } + } + }) + ], + "sassLoader": { + "sourceMap": false, + "includePaths": [] + }, + "lessLoader": { + "sourceMap": false + }, + "context": "" + } + })); + + if (isProd) { + plugins.push(new HashedModuleIdsPlugin({ + "hashFunction": "md5", + "hashDigest": "base64", + "hashDigestLength": 4 + })); + + plugins.push(new AotPlugin({ + "mainPath": "main.ts", + "hostReplacementPaths": { + "environments/environment.ts": "environments/environment.prod.ts" + }, + "exclude": [], + "tsConfigPath": "src/tsconfig.app.json" + })); + + plugins.push(new UglifyJsPlugin({ + "mangle": { + "screw_ie8": true + }, + "compress": { + "screw_ie8": true, + "warnings": false + }, + "sourceMap": false + })); + + } else { + plugins.push(new AotPlugin({ + "mainPath": "main.ts", + "hostReplacementPaths": { + "environments/environment.ts": "environments/environment.ts" + }, + "exclude": [], + "tsConfigPath": "src/tsconfig.app.json", + "skipCodeGeneration": true + })); + } + + return plugins; +} + +module.exports = { + "devtool": "source-map", + "externals": { + "electron": "require('electron')", + "buffer": "require('buffer')", + "child_process": "require('child_process')", + "crypto": "require('crypto')", + "events": "require('events')", + "fs": "require('fs')", + "http": "require('http')", + "https": "require('https')", + "assert": "require('assert')", + "dns": "require('dns')", + "net": "require('net')", + "os": "require('os')", + "path": "require('path')", + "querystring": "require('querystring')", + "readline": "require('readline')", + "repl": "require('repl')", + "stream": "require('stream')", + "string_decoder": "require('string_decoder')", + "url": "require('url')", + "util": "require('util')", + "zlib": "require('zlib')" + }, + "resolve": { + "extensions": [ + ".ts", + ".js", + ".scss", + ".json" + ], + "aliasFields": [], + "alias": { // WORKAROUND See. angular-cli/issues/5433 + "environments": isProd ? path.resolve(__dirname, 'src/environments/environment.prod.ts') : path.resolve(__dirname, 'src/environments/environment.ts') + }, + "modules": [ + "./node_modules" + ] + }, + "resolveLoader": { + "modules": [ + "./node_modules" + ] + }, + "entry": { + "main": [ + "./src/main.ts" + ], + "polyfills": [ + "./src/polyfills.ts" + ], + "styles": styles + }, + "output": { + "path": path.join(process.cwd(), "dist"), + "filename": "[name].bundle.js", + "chunkFilename": "[id].chunk.js" + }, + "module": { + "rules": [ + { + "enforce": "pre", + "test": /\.(js|ts)$/, + "loader": "source-map-loader", + "exclude": [ + /\/node_modules\//, + path.join(__dirname, 'node_modules', '@angular/compiler') + ] + }, + { + "test": /\.html$/, + "loader": "html-loader" + }, + { + "test": /\.(eot|svg)$/, + "loader": "file-loader?name=[name].[hash:20].[ext]" + }, + { + "test": /\.(jpg|png|gif|otf|ttf|woff|woff2|cur|ani)$/, + "loader": "url-loader?name=[name].[hash:20].[ext]&limit=10000" + }, + { + "exclude": style_paths, + "test": /\.css$/, + "loaders": [ + "exports-loader?module.exports.toString()", + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader" + ] + }, + { + "exclude": style_paths, + "test": /\.scss$|\.sass$/, + "loaders": [ + "exports-loader?module.exports.toString()", + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader", + "sass-loader" + ] + }, + { + "exclude": style_paths, + "test": /\.less$/, + "loaders": [ + "exports-loader?module.exports.toString()", + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader", + "less-loader" + ] + }, + { + "exclude": style_paths, + "test": /\.styl$/, + "loaders": [ + "exports-loader?module.exports.toString()", + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader", + "stylus-loader?{\"sourceMap\":false,\"paths\":[]}" + ] + }, + { + "include": style_paths, + "test": /\.css$/, + "loaders": ExtractTextPlugin.extract({ + "use": [ + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader" + ], + "fallback": "style-loader", + "publicPath": "" + }) + }, + { + "include": style_paths, + "test": /\.scss$|\.sass$/, + "loaders": ExtractTextPlugin.extract({ + "use": [ + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader", + "sass-loader" + ], + "fallback": "style-loader", + "publicPath": "" + }) + }, + { + "include":style_paths, + "test": /\.less$/, + "loaders": ExtractTextPlugin.extract({ + "use": [ + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader", + "less-loader" + ], + "fallback": "style-loader", + "publicPath": "" + }) + }, + { + "include": style_paths, + "test": /\.styl$/, + "loaders": ExtractTextPlugin.extract({ + "use": [ + "css-loader?{\"sourceMap\":false,\"importLoaders\":1}", + "postcss-loader", + "stylus-loader?{\"sourceMap\":false,\"paths\":[]}" + ], + "fallback": "style-loader", + "publicPath": "" + }) + }, + { + "test": /\.ts$/, + "loader": "@ngtools/webpack" + } + ] + }, + "plugins": getPlugins(), + "node": { + fs: "empty", + global: true, + crypto: "empty", + tls: "empty", + net: "empty", + process: true, + module: false, + clearImmediate: false, + setImmediate: false, + __dirname: false, + __filename: false + } +}; \ No newline at end of file