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