const path = require("path"); const configs = require("./src/config"); const CompressionPlugin = require("compression-webpack-plugin"); const resolve = (dir) => path.join(__dirname, dir); const enableProduction = process.env.NODE_ENV === "production"; module.exports = { outputDir: "dist", assetsDir: "static", css: { sourceMap: false, loaderOptions: { less: { lessOptions: { javascriptEnabled: true, }, }, scss: { sassOptions: { silenceDeprecations: ["legacy-js-api", "import"], }, }, sass: { sassOptions: { silenceDeprecations: ["legacy-js-api", "import"], }, }, }, }, devServer: { port: configs.port, }, productionSourceMap: false, configureWebpack: { plugins: enableProduction ? [ new CompressionPlugin({ test: /\.js$|\.html$|\.css/, threshold: 10240, }), ] : [], optimization: { runtimeChunk: "single", splitChunks: { chunks: "all", maxInitialRequests: Infinity, minSize: 20000, cacheGroups: { vendor: { test: /[\\/]node_modules[\\/]/, name(module) { const match = module.context && module.context.match(/[\\/]node_modules[\\/](.*?)([\\/]|$)/); const packageName = match ? match[1] : "vendor"; return `npm.${packageName.replace("@", "")}`; }, }, }, }, }, }, chainWebpack(config) { config.resolve.alias .set("@", resolve("src")) .set("@/components/lili", resolve("src/views/my-components/lili")) .set("@/components/map", resolve("src/views/my-components/map")) .set("@/components/lili-dialog", resolve("src/views/lili-dialog")) .set("@/components/hotzone", resolve("src/views/shop/hotzone")); config.plugin("html").tap((args) => { args[0].cdn = { css: [], js: [] }; return args; }); }, pluginOptions: { "style-resources-loader": { preProcessor: "scss", patterns: [path.resolve(__dirname, "./src/styles/common.scss")], }, }, };