77 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
/**
 | 
						|
 * webpack config
 | 
						|
 */
 | 
						|
 | 
						|
import * as webpack from 'webpack';
 | 
						|
const StringReplacePlugin = require('string-replace-webpack-plugin');
 | 
						|
const constants = require('./src/const.json');
 | 
						|
 | 
						|
const env = process.env.NODE_ENV;
 | 
						|
const isProduction = env === 'production';
 | 
						|
 | 
						|
const pack: webpack.Configuration = {
 | 
						|
	entry: {
 | 
						|
		'desktop': './src/web/app/desktop/script.js',
 | 
						|
		'mobile': './src/web/app/mobile/script.js',
 | 
						|
		'dev': './src/web/app/dev/script.js',
 | 
						|
		'auth': './src/web/app/auth/script.js'
 | 
						|
	},
 | 
						|
	module: {
 | 
						|
		rules: [
 | 
						|
			{
 | 
						|
				enforce: 'pre',
 | 
						|
				test: /\.tag$/,
 | 
						|
				exclude: /node_modules/,
 | 
						|
				loader: StringReplacePlugin.replace({
 | 
						|
					replacements: [
 | 
						|
						{ pattern: /\$theme\-color\-foreground/g, replacement: () => constants.themeColorForeground },
 | 
						|
						{ pattern: /\$theme\-color/g, replacement: () => constants.themeColor },
 | 
						|
					]
 | 
						|
				})
 | 
						|
			},
 | 
						|
			{
 | 
						|
				test: /\.tag$/,
 | 
						|
				exclude: /node_modules/,
 | 
						|
				loader: 'riot-tag-loader',
 | 
						|
				query: {
 | 
						|
					hot: false,
 | 
						|
					style: 'stylus',
 | 
						|
					expr: false,
 | 
						|
					compact: true,
 | 
						|
					parserOptions: {
 | 
						|
						style: {
 | 
						|
							compress: true
 | 
						|
						}
 | 
						|
					}
 | 
						|
				}
 | 
						|
			},
 | 
						|
			{
 | 
						|
				test: /\.styl$/,
 | 
						|
				exclude: /node_modules/,
 | 
						|
				use: [
 | 
						|
					{ loader: 'style-loader' },
 | 
						|
					{ loader: 'css-loader' },
 | 
						|
					{ loader: 'stylus-loader' }
 | 
						|
				]
 | 
						|
			}
 | 
						|
		]
 | 
						|
	},
 | 
						|
	plugins: [
 | 
						|
		new webpack.DefinePlugin({
 | 
						|
			CONFIG: {
 | 
						|
				themeColor: JSON.stringify(constants.themeColor)
 | 
						|
			}
 | 
						|
		}),
 | 
						|
		new StringReplacePlugin()
 | 
						|
	],
 | 
						|
	output: {
 | 
						|
		filename: '[name]/script.js'
 | 
						|
	}
 | 
						|
};
 | 
						|
 | 
						|
if (isProduction) {
 | 
						|
	pack.plugins.push(new webpack.optimize.UglifyJsPlugin());
 | 
						|
}
 | 
						|
 | 
						|
module.exports = pack;
 |