-
Notifications
You must be signed in to change notification settings - Fork 156
/
Copy pathwebpack.config.js
90 lines (87 loc) · 2.49 KB
/
webpack.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/**
* @license
* Copyright 2018 Google Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const webpack = require('webpack')
const fs = require('fs')
const { argv } = require('yargs')
const { resolve } = require('path')
const { version } = require('./package.json')
const { ModuleFilenameHelpers } = require('webpack')
function getDefinitions(env, width = 100, height = 100) {
return new webpack.DefinePlugin({
PRODUCTION: JSON.stringify(Boolean(env.production)),
// ANIMATE : JSON.stringify(Boolean(env.animate)),
ANIMATE: JSON.stringify(false),
INDEX_FILE: JSON.stringify('index.html'),
ABOUT_FILE: JSON.stringify('about.html'),
WIDTH: JSON.stringify(width),
HEIGHT: JSON.stringify(height),
VERSION: JSON.stringify(require("./package.json").version),
})
}
module.exports = (env = {}) => {
const templateParameters = { version }
const definitions = getDefinitions(env)
const PRODUCTION = env.production;
return {
mode: PRODUCTION ? 'production' : 'development',
devtool: PRODUCTION ? undefined : 'eval-cheap-module-source-map',
entry: {
Renderer: [path.resolve(__dirname, 'client/index.js')],
components: [path.resolve(__dirname, 'client/components/index.js')]
},
output: {
path: path.resolve(__dirname, 'magenta4live.amxd/code/public'),
filename: '[name].js',
publicPath: '/'
},
resolve: {
modules: [
'node_modules',
path.resolve(__dirname, '.'),
],
fallback: {
"buffer": require.resolve("buffer")
}
},
plugins: [
definitions,
new HtmlWebpackPlugin({
title: 'Main',
filename: 'index.html',
template: path.resolve(__dirname, 'template.html'),
templateParameters
})],
module: {
rules: [
{
test: /\.scss$/,
use: ['style-loader', 'css-loader', 'sass-loader']
},
{
test: /\.(png|jpe?g|gif|svg)$/i,
use: [
{
loader: 'file-loader',
},
],
},
]
}
}
}