summaryrefslogtreecommitdiff
path: root/webpack/module/rules
diff options
context:
space:
mode:
Diffstat (limited to 'webpack/module/rules')
-rw-r--r--webpack/module/rules/base64.ts2
-rw-r--r--webpack/module/rules/collapse-spaces.ts20
-rw-r--r--webpack/module/rules/index.ts2
3 files changed, 23 insertions, 1 deletions
diff --git a/webpack/module/rules/base64.ts b/webpack/module/rules/base64.ts
index 529816bd20..6d7eaddeba 100644
--- a/webpack/module/rules/base64.ts
+++ b/webpack/module/rules/base64.ts
@@ -7,7 +7,7 @@ const StringReplacePlugin = require('string-replace-webpack-plugin');
export default () => ({
enforce: 'pre',
- test: /\.(tag|js)$/,
+ test: /\.(vue|js)$/,
exclude: /node_modules/,
loader: StringReplacePlugin.replace({
replacements: [{
diff --git a/webpack/module/rules/collapse-spaces.ts b/webpack/module/rules/collapse-spaces.ts
new file mode 100644
index 0000000000..48fd57f017
--- /dev/null
+++ b/webpack/module/rules/collapse-spaces.ts
@@ -0,0 +1,20 @@
+import * as fs from 'fs';
+const minify = require('html-minifier').minify;
+const StringReplacePlugin = require('string-replace-webpack-plugin');
+
+export default () => ({
+ enforce: 'pre',
+ test: /\.vue$/,
+ exclude: /node_modules/,
+ loader: StringReplacePlugin.replace({
+ replacements: [{
+ pattern: /^<template>([\s\S]+?)\r?\n<\/template>/, replacement: html => {
+ return minify(html, {
+ collapseWhitespace: true,
+ collapseInlineTagWhitespace: true,
+ keepClosingSlash: true
+ });
+ }
+ }]
+ })
+});
diff --git a/webpack/module/rules/index.ts b/webpack/module/rules/index.ts
index 093f07330b..c63da7112d 100644
--- a/webpack/module/rules/index.ts
+++ b/webpack/module/rules/index.ts
@@ -6,8 +6,10 @@ import themeColor from './theme-color';
import vue from './vue';
import stylus from './stylus';
import typescript from './typescript';
+import collapseSpaces from './collapse-spaces';
export default lang => [
+ collapseSpaces(),
i18n(lang),
license(),
fa(),