-
Notifications
You must be signed in to change notification settings - Fork 1
/
vue.config.js
86 lines (79 loc) · 2.61 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
/*
* @Author: iRuxu
* @Date: 2022-07-04 10:42:02
* @LastEditTime: 2022-07-08 19:27:07
* @Description:config
*/
const path = require("path");
const pkg = require("./package.json");
module.exports = {
//❤️ Multiple pages ~
pages: {
article: {
title: "Home",
entry: "demo/A.js",
template: "public/article.html",
filename: "index.html",
},
tinymce: {
title: "Tinymce编辑器",
entry: "demo/T.js",
template: "public/tinymce.html",
filename: "tinymce/index.html",
},
lightTinymce: {
title: "轻量级Tinymce编辑器",
entry: "demo/L.js",
template: "public/tinymce.html",
filename: "lightTinymce/index.html",
},
},
//⚛️ Proxy ~
devServer: {
proxy: {
"/api/cms": {
target:
process.env["DEV_SERVER"] == "true"
? "http://localhost:4100"
: "https://api.gatesstsuperlaser.com/",
},
},
},
//❤️ define path for static files ~
publicPath: process.env.NODE_ENV === "development" ? "/" : `${process.env.STATIC_PATH}${pkg.name}/`,
//❤️ Webpack configuration
chainWebpack: (config) => {
//💘 html-webpack-plugin ~
// Multiple pages disable the block below
// config.plugin("html").tap((args) => {
// args[0].meta = {
// //------设置SEO信息
// Keywords: project.keys,
// Description: project.desc,
// };
// args[0].title = project.title; //------自动添加标题后缀
// return args;
// });
//💝 in-line small imgs ~
config.module.rule("images").set("parser", {
dataUrlCondition: {
maxSize: 4 * 1024, // 4KiB
},
});
//💝 in-line svg imgs ~
config.module.rule("vue").use("vue-svg-inline-loader").loader("vue-svg-inline-loader");
//💖 import common less var * mixin ~
const types = ["vue-modules", "vue", "normal-modules", "normal"];
types.forEach((type) => addStyleResource(config.module.rule("less").oneOf(type)));
},
};
function addStyleResource(rule) {
var preload_styles = [];
preload_styles.push(
path.resolve(__dirname, "./node_modules/csslab/base.less"),
path.resolve(__dirname, "./assets/css/var.less")
);
rule.use("style-resource").loader("style-resources-loader").options({
patterns: preload_styles,
});
}