WIP - Webpack 2 building
This commit is contained in:
		
							parent
							
								
									a534949b2d
								
							
						
					
					
						commit
						8392090861
					
				| @ -1,5 +1,9 @@ | |||||||
| { | { | ||||||
|   "presets": ["es2017", "es2016", "es2015", "stage-0", "react"], |   "presets": [ | ||||||
|  |     "es2017", "es2016", | ||||||
|  |     [ "es2015", { "modules": false } ], | ||||||
|  |     "stage-0", "react" | ||||||
|  |   ], | ||||||
|   "plugins": [ |   "plugins": [ | ||||||
|     "transform-runtime", |     "transform-runtime", | ||||||
|     "transform-decorators-legacy", |     "transform-decorators-legacy", | ||||||
|  | |||||||
| @ -100,10 +100,11 @@ | |||||||
|     "mock-local-storage": "1.0.2", |     "mock-local-storage": "1.0.2", | ||||||
|     "mock-socket": "~3.0.1", |     "mock-socket": "~3.0.1", | ||||||
|     "nock": "~8.0.0", |     "nock": "~8.0.0", | ||||||
|     "postcss-import": "~8.1.2", |     "postcss-import": "8.1.0", | ||||||
|     "postcss-loader": "~1.1.1", |     "postcss-loader": "~1.1.1", | ||||||
|     "postcss-nested": "~1.0.0", |     "postcss-nested": "~1.0.0", | ||||||
|     "postcss-simple-vars": "~3.0.0", |     "postcss-simple-vars": "~3.0.0", | ||||||
|  |     "progress": "^1.1.8", | ||||||
|     "raw-loader": "~0.5.1", |     "raw-loader": "~0.5.1", | ||||||
|     "react-addons-perf": "~15.3.2", |     "react-addons-perf": "~15.3.2", | ||||||
|     "react-addons-test-utils": "~15.3.2", |     "react-addons-test-utils": "~15.3.2", | ||||||
|  | |||||||
| @ -19,7 +19,7 @@ import Registry from './registry'; | |||||||
| import SignatureReg from './signaturereg'; | import SignatureReg from './signaturereg'; | ||||||
| import TokenReg from './tokenreg'; | import TokenReg from './tokenreg'; | ||||||
| import GithubHint from './githubhint'; | import GithubHint from './githubhint'; | ||||||
| import smsVerification from './sms-verification'; | import * as smsVerification from './sms-verification'; | ||||||
| 
 | 
 | ||||||
| let instance = null; | let instance = null; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -24,17 +24,17 @@ const SNIPPETS = { | |||||||
|   snippet0: { |   snippet0: { | ||||||
|     name: 'Token.sol', |     name: 'Token.sol', | ||||||
|     description: 'Standard ERP20 Token Contract', |     description: 'Standard ERP20 Token Contract', | ||||||
|     id: 'snippet0', sourcecode: require('raw!../../contracts/snippets/token.sol') |     id: 'snippet0', sourcecode: require('raw-loader!../../contracts/snippets/token.sol') | ||||||
|   }, |   }, | ||||||
|   snippet1: { |   snippet1: { | ||||||
|     name: 'StandardToken.sol', |     name: 'StandardToken.sol', | ||||||
|     description: 'Implementation of ERP20 Token Contract', |     description: 'Implementation of ERP20 Token Contract', | ||||||
|     id: 'snippet1', sourcecode: require('raw!../../contracts/snippets/standard-token.sol') |     id: 'snippet1', sourcecode: require('raw-loader!../../contracts/snippets/standard-token.sol') | ||||||
|   }, |   }, | ||||||
|   snippet2: { |   snippet2: { | ||||||
|     name: 'HumanStandardToken.sol', |     name: 'HumanStandardToken.sol', | ||||||
|     description: 'Implementation of the Human Token Contract', |     description: 'Implementation of the Human Token Contract', | ||||||
|     id: 'snippet2', sourcecode: require('raw!../../contracts/snippets/human-standard-token.sol') |     id: 'snippet2', sourcecode: require('raw-loader!../../contracts/snippets/human-standard-token.sol') | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -31,7 +31,6 @@ const ENV = process.env.NODE_ENV || 'development'; | |||||||
| const isProd = ENV === 'production'; | const isProd = ENV === 'production'; | ||||||
| 
 | 
 | ||||||
| module.exports = { | module.exports = { | ||||||
|   debug: !isProd, |  | ||||||
|   cache: !isProd, |   cache: !isProd, | ||||||
|   devtool: isProd ? '#eval' : '#cheap-module-eval-source-map', |   devtool: isProd ? '#eval' : '#cheap-module-eval-source-map', | ||||||
| 
 | 
 | ||||||
| @ -46,43 +45,61 @@ module.exports = { | |||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   module: { |   module: { | ||||||
|     loaders: [ |     rules: [ | ||||||
|       { |       { | ||||||
|         test: /\.js$/, |         test: /\.js$/, | ||||||
|         exclude: /node_modules/, |         exclude: /node_modules/, | ||||||
|         loaders: [ 'happypack/loader?id=js' ] |         // use: [ 'happypack/loader?id=js' ]
 | ||||||
|  |         use: isProd ? ['babel-loader'] : [ | ||||||
|  |           // 'react-hot-loader',
 | ||||||
|  |           'babel-loader?cacheDirectory=true' | ||||||
|  |         ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.js$/, |         test: /\.js$/, | ||||||
|         include: /node_modules\/material-ui-chip-input/, |         include: /node_modules\/material-ui-chip-input/, | ||||||
|         loader: 'babel' |         use: [ 'babel-loader' ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.json$/, |         test: /\.json$/, | ||||||
|         loaders: ['json'] |         use: [ 'json-loader' ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.html$/, |         test: /\.html$/, | ||||||
|         loader: 'file?name=[name].[ext]!extract-loader!html-loader' |         use: [ | ||||||
|  |           'file-loader?name=[name].[ext]!extract-loader', | ||||||
|  |           { | ||||||
|  |             loader: 'html-loader', | ||||||
|  |             options: { | ||||||
|  |               root: path.resolve(__dirname, '../assets/images'), | ||||||
|  |               attrs: ['img:src', 'link:href'] | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|       }, |       }, | ||||||
| 
 | 
 | ||||||
|       { |       { | ||||||
|         test: /\.css$/, |         test: /\.css$/, | ||||||
|         include: [ /src/ ], |         include: [ /src/ ], | ||||||
|         loaders: [ 'happypack/loader?id=css' ] |         // use: [ 'happypack/loader?id=css' ]
 | ||||||
|  |         use: [ | ||||||
|  |           'style-loader', | ||||||
|  |           'css-loader?modules&sourceMap&importLoaders=1&localIdentName=[name]__[local]___[hash:base64:5]', | ||||||
|  |           'postcss-loader' | ||||||
|  |         ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.css$/, |         test: /\.css$/, | ||||||
|         exclude: [ /src/ ], |         exclude: [ /src/ ], | ||||||
|         loader: 'style!css' |         use: [ 'style-loader', 'css-loader' ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.(png|jpg)$/, |         test: /\.(png|jpg)$/, | ||||||
|         loader: 'file-loader?name=[name].[hash].[ext]' |         use: [ 'file-loader?name=[name].[hash].[ext]' ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.(woff(2)|ttf|eot|svg|otf)(\?v=[0-9]\.[0-9]\.[0-9])?$/, |         test: /\.(woff(2)|ttf|eot|svg|otf)(\?v=[0-9]\.[0-9]\.[0-9])?$/, | ||||||
|         loader: 'file-loader' |         use: [ 'file-loader' ] | ||||||
|       } |       } | ||||||
|     ], |     ], | ||||||
|     noParse: [ |     noParse: [ | ||||||
| @ -91,22 +108,12 @@ module.exports = { | |||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   resolve: { |   resolve: { | ||||||
|     root: path.join(__dirname, '../node_modules'), |     modules: [ | ||||||
|     fallback: path.join(__dirname, '../node_modules'), |       path.join(__dirname, '../node_modules') | ||||||
|     extensions: ['', '.js', '.jsx'], |     ], | ||||||
|  |     extensions: ['.json', '.js', '.jsx'], | ||||||
|     unsafeCache: true |     unsafeCache: true | ||||||
|   }, |   }, | ||||||
|   resolveLoaders: { |  | ||||||
|     root: path.join(__dirname, '../node_modules'), |  | ||||||
|     fallback: path.join(__dirname, '../node_modules') |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   htmlLoader: { |  | ||||||
|     root: path.resolve(__dirname, '../assets/images'), |  | ||||||
|     attrs: ['img:src', 'link:href'] |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   postcss: Shared.postcss, |  | ||||||
| 
 | 
 | ||||||
|   plugins: (function () { |   plugins: (function () { | ||||||
|     const plugins = Shared.getPlugins().concat([ |     const plugins = Shared.getPlugins().concat([ | ||||||
|  | |||||||
| @ -20,11 +20,13 @@ const webpackHotMiddleware = require('webpack-hot-middleware'); | |||||||
| 
 | 
 | ||||||
| const http = require('http'); | const http = require('http'); | ||||||
| const express = require('express'); | const express = require('express'); | ||||||
|  | const ProgressBar = require('progress'); | ||||||
| 
 | 
 | ||||||
| const webpackConfig = require('./config'); | const webpackConfig = require('./config'); | ||||||
| const Shared = require('./shared'); | const Shared = require('./shared'); | ||||||
| 
 | 
 | ||||||
| const hotMiddlewareScript = 'webpack-hot-middleware/client'; | const hotMiddlewareScript = 'webpack-hot-middleware/client'; | ||||||
|  | let progressBar = { update: () => {} }; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Add webpack hot middleware to each entry in the config |  * Add webpack hot middleware to each entry in the config | ||||||
| @ -39,6 +41,9 @@ const hotMiddlewareScript = 'webpack-hot-middleware/client'; | |||||||
| 
 | 
 | ||||||
|   webpackConfig.plugins.push(new webpack.HotModuleReplacementPlugin()); |   webpackConfig.plugins.push(new webpack.HotModuleReplacementPlugin()); | ||||||
|   webpackConfig.plugins.push(new webpack.NoErrorsPlugin()); |   webpackConfig.plugins.push(new webpack.NoErrorsPlugin()); | ||||||
|  |   webpackConfig.plugins.push(new webpack.ProgressPlugin( | ||||||
|  |     (percentage) => progressBar.update(percentage) | ||||||
|  |   )); | ||||||
| })(); | })(); | ||||||
| 
 | 
 | ||||||
| const app = express(); | const app = express(); | ||||||
| @ -47,6 +52,7 @@ const compiler = webpack(webpackConfig); | |||||||
| app.use(webpackDevMiddleware(compiler, { | app.use(webpackDevMiddleware(compiler, { | ||||||
|   noInfo: false, |   noInfo: false, | ||||||
|   quiet: false, |   quiet: false, | ||||||
|  |   progress: true, | ||||||
|   publicPath: webpackConfig.output.publicPath, |   publicPath: webpackConfig.output.publicPath, | ||||||
|   stats: { |   stats: { | ||||||
|     colors: true |     colors: true | ||||||
| @ -65,4 +71,5 @@ Shared.addProxies(app); | |||||||
| const server = http.createServer(app); | const server = http.createServer(app); | ||||||
| server.listen(process.env.PORT || 3000, function () { | server.listen(process.env.PORT || 3000, function () { | ||||||
|   console.log('Listening on port', server.address().port); |   console.log('Listening on port', server.address().port); | ||||||
|  |   progressBar = new ProgressBar('[:bar] :percent :etas', { total: 50 }); | ||||||
| }); | }); | ||||||
|  | |||||||
| @ -21,6 +21,8 @@ const path = require('path'); | |||||||
| const Shared = require('./shared'); | const Shared = require('./shared'); | ||||||
| 
 | 
 | ||||||
| const DEST = process.env.BUILD_DEST || '.build'; | const DEST = process.env.BUILD_DEST || '.build'; | ||||||
|  | const ENV = process.env.NODE_ENV || 'development'; | ||||||
|  | const isProd = ENV === 'production'; | ||||||
| 
 | 
 | ||||||
| module.exports = { | module.exports = { | ||||||
|   context: path.join(__dirname, '../src'), |   context: path.join(__dirname, '../src'), | ||||||
| @ -37,19 +39,23 @@ module.exports = { | |||||||
|     libraryTarget: 'umd' |     libraryTarget: 'umd' | ||||||
|   }, |   }, | ||||||
|   module: { |   module: { | ||||||
|     loaders: [ |     rules: [ | ||||||
|       { |       { | ||||||
|         test: /\.js$/, |         test: /\.js$/, | ||||||
|         exclude: /node_modules/, |         exclude: /node_modules/, | ||||||
|         loader: 'happypack/loader?id=js' |         // use: [ 'happypack/loader?id=js' ]
 | ||||||
|  |         use: isProd ? ['babel-loader'] : [ | ||||||
|  |           // 'react-hot-loader',
 | ||||||
|  |           'babel-loader?cacheDirectory=true' | ||||||
|  |         ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.json$/, |         test: /\.json$/, | ||||||
|         loaders: ['json'] |         use: [ 'json-loader' ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.html$/, |         test: /\.html$/, | ||||||
|         loader: 'file?name=[name].[ext]' |         use: [ 'file-loader?name=[name].[ext]' ] | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|  | |||||||
| @ -15,7 +15,6 @@ | |||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| const path = require('path'); | const path = require('path'); | ||||||
| const webpack = require('webpack'); |  | ||||||
| const CopyWebpackPlugin = require('copy-webpack-plugin'); | const CopyWebpackPlugin = require('copy-webpack-plugin'); | ||||||
| const packageJson = require('../package.json'); | const packageJson = require('../package.json'); | ||||||
| 
 | 
 | ||||||
| @ -43,18 +42,27 @@ module.exports = { | |||||||
|     noParse: [ |     noParse: [ | ||||||
|       /babel-polyfill/ |       /babel-polyfill/ | ||||||
|     ], |     ], | ||||||
|     loaders: [ |     rules: [ | ||||||
|       { |       { | ||||||
|         test: /(\.jsx|\.js)$/, |         test: /(\.jsx|\.js)$/, | ||||||
|         loaders: [ 'happypack/loader?id=js' ], |         // use: [ 'happypack/loader?id=js' ],
 | ||||||
|  |         use: isProd ? ['babel-loader'] : [ | ||||||
|  |           // 'react-hot-loader',
 | ||||||
|  |           'babel-loader?cacheDirectory=true' | ||||||
|  |         ], | ||||||
|         exclude: /node_modules/ |         exclude: /node_modules/ | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|  | 
 | ||||||
|   resolve: { |   resolve: { | ||||||
|     root: path.resolve('./src'), |     modules: [ | ||||||
|     extensions: ['', '.js'] |       path.resolve('./src'), | ||||||
|  |       path.join(__dirname, '../node_modules') | ||||||
|  |     ], | ||||||
|  |     extensions: ['.json', '.js', '.jsx'] | ||||||
|   }, |   }, | ||||||
|  | 
 | ||||||
|   plugins: Shared.getPlugins().concat([ |   plugins: Shared.getPlugins().concat([ | ||||||
|     new CopyWebpackPlugin([ |     new CopyWebpackPlugin([ | ||||||
|       { |       { | ||||||
|  | |||||||
| @ -15,7 +15,8 @@ | |||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| const webpack = require('webpack'); | const webpack = require('webpack'); | ||||||
| const HappyPack = require('happypack'); | const path = require('path'); | ||||||
|  | // const HappyPack = require('happypack');
 | ||||||
| 
 | 
 | ||||||
| const postcssImport = require('postcss-import'); | const postcssImport = require('postcss-import'); | ||||||
| const postcssNested = require('postcss-nested'); | const postcssNested = require('postcss-nested'); | ||||||
| @ -26,31 +27,46 @@ const ENV = process.env.NODE_ENV || 'development'; | |||||||
| const isProd = ENV === 'production'; | const isProd = ENV === 'production'; | ||||||
| 
 | 
 | ||||||
| function getPlugins (_isProd = isProd) { | function getPlugins (_isProd = isProd) { | ||||||
|  |   const postcss = [ | ||||||
|  |     postcssImport({ | ||||||
|  |       addDependencyTo: webpack | ||||||
|  |     }), | ||||||
|  |     postcssNested({}), | ||||||
|  |     postcssVars({ | ||||||
|  |       unknown: function (node, name, result) { | ||||||
|  |         node.warn(result, `Unknown variable ${name}`); | ||||||
|  |       } | ||||||
|  |     }), | ||||||
|  |     rucksack({ | ||||||
|  |       autoprefixer: true | ||||||
|  |     }) | ||||||
|  |   ]; | ||||||
|  | 
 | ||||||
|   const plugins = [ |   const plugins = [ | ||||||
|     new HappyPack({ |     // new HappyPack({
 | ||||||
|       id: 'css', |     //   id: 'css',
 | ||||||
|       threads: 4, |     //   threads: 4,
 | ||||||
|       loaders: [ |     //   loaders: [
 | ||||||
|         'style', |     //     'style-loader',
 | ||||||
|         'css?modules&sourceMap&importLoaders=1&localIdentName=[name]__[local]___[hash:base64:5]', |     //     'css-loader?modules&sourceMap&importLoaders=1&localIdentName=[name]__[local]___[hash:base64:5]',
 | ||||||
|         'postcss' |     //     'postcss-loader'
 | ||||||
|       ] |     //   ]
 | ||||||
|     }), |     // }),
 | ||||||
| 
 | 
 | ||||||
|     new HappyPack({ |     // new HappyPack({
 | ||||||
|       id: 'js', |     //   id: 'js',
 | ||||||
|       threads: 4, |     //   threads: 4,
 | ||||||
|       loaders: _isProd ? ['babel'] : [ |     //   loaders: _isProd ? ['babel'] : [
 | ||||||
|         'react-hot', |     //     'react-hot-loader',
 | ||||||
|         'babel?cacheDirectory=true' |     //     'babel-loader?cacheDirectory=true'
 | ||||||
|       ] |     //   ]
 | ||||||
|     }), |     // }),
 | ||||||
| 
 | 
 | ||||||
|     new HappyPack({ |     // new HappyPack({
 | ||||||
|       id: 'babel', |     //   id: 'babel',
 | ||||||
|       threads: 4, |     //   threads: 4,
 | ||||||
|       loaders: ['babel'] |     //   loaders: ['babel-loader']
 | ||||||
|     }), |     // }),
 | ||||||
| 
 | 
 | ||||||
|     new webpack.DefinePlugin({ |     new webpack.DefinePlugin({ | ||||||
|       'process.env': { |       'process.env': { | ||||||
| @ -62,11 +78,19 @@ function getPlugins (_isProd = isProd) { | |||||||
|       } |       } | ||||||
|     }), |     }), | ||||||
| 
 | 
 | ||||||
|  |     new webpack.LoaderOptionsPlugin({ | ||||||
|  |       minimize: isProd, | ||||||
|  |       debug: !isProd, | ||||||
|  |       options: { | ||||||
|  |         context: path.join(__dirname, '../src'), | ||||||
|  |         postcss: postcss | ||||||
|  |       } | ||||||
|  |     }), | ||||||
|  | 
 | ||||||
|     new webpack.optimize.OccurrenceOrderPlugin(!_isProd) |     new webpack.optimize.OccurrenceOrderPlugin(!_isProd) | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|   if (_isProd) { |   if (_isProd) { | ||||||
|     plugins.push(new webpack.optimize.DedupePlugin()); |  | ||||||
|     plugins.push(new webpack.optimize.UglifyJsPlugin({ |     plugins.push(new webpack.optimize.UglifyJsPlugin({ | ||||||
|       screwIe8: true, |       screwIe8: true, | ||||||
|       compress: { |       compress: { | ||||||
| @ -90,21 +114,6 @@ function getDappsEntry () { | |||||||
|   }, {}); |   }, {}); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const postcss = [ |  | ||||||
|   postcssImport({ |  | ||||||
|     addDependencyTo: webpack |  | ||||||
|   }), |  | ||||||
|   postcssNested({}), |  | ||||||
|   postcssVars({ |  | ||||||
|     unknown: function (node, name, result) { |  | ||||||
|       node.warn(result, `Unknown variable ${name}`); |  | ||||||
|     } |  | ||||||
|   }), |  | ||||||
|   rucksack({ |  | ||||||
|     autoprefixer: true |  | ||||||
|   }) |  | ||||||
| ]; |  | ||||||
| 
 |  | ||||||
| function addProxies (app) { | function addProxies (app) { | ||||||
|   const proxy = require('http-proxy-middleware'); |   const proxy = require('http-proxy-middleware'); | ||||||
| 
 | 
 | ||||||
| @ -147,6 +156,5 @@ function addProxies (app) { | |||||||
| module.exports = { | module.exports = { | ||||||
|   getPlugins: getPlugins, |   getPlugins: getPlugins, | ||||||
|   dappsEntry: getDappsEntry(), |   dappsEntry: getDappsEntry(), | ||||||
|   addProxies: addProxies, |   addProxies: addProxies | ||||||
|   postcss: postcss |  | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -51,15 +51,15 @@ module.exports = { | |||||||
|     vendor: modules |     vendor: modules | ||||||
|   }, |   }, | ||||||
|   module: { |   module: { | ||||||
|     loaders: [ |     rules: [ | ||||||
|       { |       { | ||||||
|         test: /\.json$/, |         test: /\.json$/, | ||||||
|         loaders: ['json'] |         use: [ 'json-loader' ] | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         test: /\.js$/, |         test: /\.js$/, | ||||||
|         include: /(ethereumjs-tx)/, |         include: /(ethereumjs-tx)/, | ||||||
|         loaders: [ 'happypack/loader?id=babel' ] |         use: [ 'babel-loader' ] | ||||||
|       } |       } | ||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user