123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216 |
- // Copyright 2017-2019 @polkadot/apps authors & contributors
- // This software may be modified and distributed under the terms
- // of the Apache-2.0 license. See the LICENSE file for details.
- const fs = require('fs');
- const path = require('path');
- const webpack = require('webpack');
- const CopyWebpackPlugin = require('copy-webpack-plugin');
- const MiniCssExtractPlugin = require('mini-css-extract-plugin');
- const HtmlWebpackPlugin = require('html-webpack-plugin');
- const { WebpackPluginServe } = require('webpack-plugin-serve');
- const packages = [
- 'app-accounts',
- 'app-addresses',
- 'app-democracy',
- 'app-explorer',
- 'app-extrinsics',
- 'app-js',
- 'app-settings',
- 'app-staking',
- 'app-storage',
- 'app-123code',
- 'app-toolbox',
- 'app-transfer',
- 'ui-api',
- 'ui-app',
- 'ui-params',
- 'ui-reactive',
- 'ui-signer'
- ];
- const DEFAULT_THEME = process.env.TRAVIS_BRANCH === 'next'
- ? 'substrate'
- : 'polkadot';
- function createWebpack ({ alias = {}, context, name = 'index' }) {
- const pkgJson = require(path.join(context, 'package.json'));
- const ENV = process.env.NODE_ENV || 'development';
- const isProd = ENV === 'production';
- const hasPublic = fs.existsSync(path.join(context, 'public'));
- const plugins = hasPublic
- ? [new CopyWebpackPlugin([{ from: 'public' }])]
- : [];
- return {
- context,
- devtool: isProd ? 'source-map' : 'cheap-eval-source-map',
- entry: [
- `./src/${name}.tsx`,
- isProd
- ? null
- : 'webpack-plugin-serve/client'
- ].filter((entry) => entry),
- mode: ENV,
- output: {
- chunkFilename: `[name].[chunkhash:8].js`,
- filename: `[name].[hash:8].js`,
- globalObject: `(typeof self !== 'undefined' ? self : this)`,
- path: path.join(context, 'build')
- },
- resolve: {
- alias,
- extensions: ['.js', '.jsx', '.ts', '.tsx']
- },
- module: {
- rules: [
- {
- test: /\.css$/,
- exclude: /(node_modules)/,
- use: [
- isProd
- ? MiniCssExtractPlugin.loader
- : require.resolve('style-loader'),
- {
- loader: require.resolve('css-loader'),
- options: {
- importLoaders: 1
- }
- },
- {
- loader: require.resolve('postcss-loader'),
- options: {
- ident: 'postcss',
- plugins: () => [
- require('precss'),
- require('autoprefixer'),
- require('postcss-simple-vars'),
- require('postcss-nested'),
- require('postcss-import'),
- require('postcss-clean')(),
- require('postcss-flexbugs-fixes')
- ]
- }
- }
- ]
- },
- {
- test: /\.css$/,
- include: /node_modules/,
- use: [
- isProd
- ? MiniCssExtractPlugin.loader
- : require.resolve('style-loader'),
- require.resolve('css-loader')
- ]
- },
- {
- test: /\.(js|ts|tsx)$/,
- exclude: /(node_modules)/,
- use: [
- require.resolve('thread-loader'),
- {
- loader: require.resolve('babel-loader'),
- options: require('@polkadot/dev-react/config/babel')
- }
- ]
- },
- {
- test: [/\.bmp$/, /\.gif$/, /\.jpe?g$/, /\.png$/],
- use: [
- {
- loader: require.resolve('url-loader'),
- options: {
- limit: 10000,
- name: 'static/[name].[hash:8].[ext]'
- }
- }
- ]
- },
- {
- test: [/\.eot$/, /\.ttf$/, /\.svg$/, /\.woff$/, /\.woff2$/],
- use: [
- {
- loader: require.resolve('file-loader'),
- options: {
- name: 'static/[name].[hash:8].[ext]'
- }
- }
- ]
- }
- ]
- },
- node: {
- child_process: 'empty',
- dgram: 'empty',
- fs: 'empty',
- net: 'empty',
- tls: 'empty'
- },
- optimization: {
- runtimeChunk: 'single',
- splitChunks: {
- cacheGroups: {
- vendorOther: {
- chunks: 'initial',
- enforce: true,
- name: 'vendor',
- test: /node_modules\/(asn1|bn\.js|buffer|cuint|elliptic|lodash|moment|readable-stream|rxjs)/
- },
- vendorReact: {
- chunks: 'initial',
- enforce: true,
- name: 'react',
- test: /node_modules\/(chart|i18next|react|semantic-ui)/
- },
- vendorSodium: {
- chunks: 'initial',
- enforce: true,
- name: 'sodium',
- test: /node_modules\/(libsodium)/
- }
- }
- }
- },
- performance: {
- hints: false
- },
- plugins: plugins.concat([
- isProd
- ? null
- : new WebpackPluginServe({
- port: 3000,
- static: path.join(process.cwd(), '/build')
- }),
- new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/),
- new webpack.DefinePlugin({
- 'process.env': {
- NODE_ENV: JSON.stringify(ENV),
- VERSION: JSON.stringify(pkgJson.version),
- WS_URL: JSON.stringify(process.env.WS_URL)
- }
- }),
- new HtmlWebpackPlugin({
- inject: true,
- template: path.join(context, `${hasPublic ? 'public/' : ''}${name}.html`),
- PAGE_TITLE: 'Polkadot/Substrate Portal'
- }),
- new webpack.optimize.SplitChunksPlugin(),
- new MiniCssExtractPlugin({
- filename: `[name].[contenthash:8].css`
- })
- ]).filter((entry) => entry),
- watch: !isProd
- };
- }
- module.exports = createWebpack({
- context: __dirname,
- alias: packages.reduce((alias, pkg) => {
- alias[`@polkadot/${pkg}`] = path.resolve(__dirname, `../${pkg}/src`);
- return alias;
- }, {})
- });
|