-
Notifications
You must be signed in to change notification settings - Fork 41
/
vue.config.js
107 lines (104 loc) · 3.03 KB
/
vue.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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
require('dotenv').config()
const { DefinePlugin } = require('webpack')
const { defineConfig } = require('@vue/cli-service')
const NodePolyfillPlugin = require('node-polyfill-webpack-plugin')
const path = require('path')
const __IS_WEB_APP = process.env.VUE_APP_WEB === 'true'
module.exports = defineConfig({
publicPath: './',
runtimeCompiler: true,
transpileDependencies: true,
productionSourceMap: false,
pluginOptions: {
cordovaPath: 'cordova',
electronBuilder: {
nodeIntegration: true,
outputDir: path.resolve(__dirname, 'dist'),
chainWebpackMainProcess: config => {
config.module
.rule('node')
.test(/\.node$/)
.use('node-loader')
.loader('node-loader')
.end()
},
chainWebpackRendererProcess: config => {
config.module
.rule('node')
.test(/\.node$/)
.use('node-loader')
.loader('node-loader')
.end()
},
builderOptions: {
icon: path.resolve(__dirname, 'build/icons/icon.png'),
productName: 'MyVPN',
appId: 'com.myvpn.app',
linux: {
target: ['deb', 'tar.bz2', 'AppImage'],
category: 'Network',
publish: ['github'],
},
mac: {
target: ['dmg'],
category: 'public.app-category.utilities',
publish: ['github'],
},
win: {
target: ['nsis', 'portable'],
publish: ['github'],
},
},
},
},
css: {
loaderOptions: {
sass: {
sassOptions: {
includePaths: [path.resolve(__dirname, 'node_modules')],
},
additionalData: `
@import "@/assets/css/variables.scss";
@import "@/assets/element-ui/theme-myvpn/index.scss";
@import "@/assets/css/app.scss";
`,
},
},
},
configureWebpack: config => ({
plugins: [
new NodePolyfillPlugin(
__IS_WEB_APP
? { includeAliases: ['process', 'Buffer'] }
: { excludeAliases: ['process'] },
),
new DefinePlugin({ __IS_WEB_APP }),
],
resolve: {
fallback: {
fs: false,
dns: false,
tls: false,
path: false,
zlib: false,
child_process: false,
net: false,
process: require.resolve('process'),
http: require.resolve('stream-http'),
https: require.resolve('https-browserify'),
crypto: require.resolve('crypto-browserify'),
stream: require.resolve('stream-browserify'),
os: require.resolve('os-browserify/browser'),
url: require.resolve('url'),
assert: require.resolve('assert'),
'crypto-browserify': require.resolve('crypto-browserify'), //if you want to use this module also don't forget npm i crypto-browserify
},
extensions: ['.ts', '.js', '.json', '.node'],
alias: {
'@': path.resolve(__dirname, 'src/'),
'sass-mixins': path.resolve(__dirname, 'src/assets/css/mixins'),
vue$: 'vue/dist/vue.esm.js',
},
},
}),
})