Migrate to webpack 5
This commit is contained in:
parent
a584ca6653
commit
9a552762b9
38386
package-lock.json
generated
38386
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
86
package.json
86
package.json
@ -20,64 +20,62 @@
|
|||||||
"author": "",
|
"author": "",
|
||||||
"license": "GPL-3.0-only",
|
"license": "GPL-3.0-only",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/crypto-js": "^4.1.1",
|
"webpack-dev-server": "^4.7.4"
|
||||||
"crypto-js": "^4.1.1",
|
|
||||||
"webpack-dev-server": "^3.11.2"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/cli": "^7.13.16",
|
"@babel/cli": "^7.17.6",
|
||||||
"@babel/core": "^7.14.2",
|
"@babel/core": "^7.17.8",
|
||||||
"@babel/plugin-proposal-class-properties": "^7.13.0",
|
"@babel/plugin-proposal-class-properties": "^7.16.7",
|
||||||
"@babel/plugin-transform-typescript": "^7.13.0",
|
"@babel/plugin-transform-typescript": "^7.16.8",
|
||||||
"@babel/polyfill": "^7.12.1",
|
"@babel/polyfill": "^7.12.1",
|
||||||
"@babel/preset-env": "^7.14.2",
|
"@babel/preset-env": "^7.16.11",
|
||||||
"@babel/preset-es2015": "^7.0.0-beta.53",
|
"@babel/preset-es2015": "^7.0.0-beta.53",
|
||||||
"@babel/preset-typescript": "^7.13.0",
|
"@babel/preset-typescript": "^7.16.7",
|
||||||
"@cryptography/aes": "^0.1.1",
|
"@cryptography/aes": "^0.1.1",
|
||||||
"@cryptography/sha1": "^0.2.0",
|
"@cryptography/sha1": "^0.2.0",
|
||||||
"@cryptography/sha256": "^0.2.0",
|
"@cryptography/sha256": "^0.2.0",
|
||||||
"@peculiar/webcrypto": "^1.1.7",
|
"@peculiar/webcrypto": "^1.3.2",
|
||||||
"@types/big-integer": "^0.0.31",
|
"@types/big-integer": "^0.0.31",
|
||||||
"@types/chrome": "0.0.139",
|
"@types/chrome": "0.0.180",
|
||||||
"@types/jest": "^26.0.23",
|
"@types/jest": "^27.4.1",
|
||||||
"@types/serviceworker-webpack-plugin": "^1.0.2",
|
"@types/serviceworker-webpack-plugin": "^1.0.3",
|
||||||
"autoprefixer": "^9.8.6",
|
"autoprefixer": "^10.4.4",
|
||||||
"babel-jest": "^26.6.3",
|
"babel-jest": "^27.5.1",
|
||||||
"babel-loader": "^8.2.2",
|
"babel-loader": "^8.2.4",
|
||||||
"babel-preset-es2015": "^6.24.1",
|
"babel-preset-es2015": "^6.24.1",
|
||||||
"big-integer": "^1.6.51",
|
"big-integer": "^1.6.51",
|
||||||
"compression": "^1.7.4",
|
"compression": "^1.7.4",
|
||||||
"css-loader": "^3.6.0",
|
"css-loader": "^6.7.1",
|
||||||
"dotenv-webpack": "^7.0.3",
|
"cssnano": "^5.1.5",
|
||||||
"express": "^4.17.1",
|
"dotenv-webpack": "^7.1.0",
|
||||||
"fast-png": "^5.0.4",
|
"express": "^4.17.3",
|
||||||
|
"fast-png": "^6.1.0",
|
||||||
"handlebars": "^4.7.7",
|
"handlebars": "^4.7.7",
|
||||||
"handlebars-loader": "^1.7.1",
|
"handlebars-loader": "^1.7.1",
|
||||||
"html-webpack-plugin": "^4.5.2",
|
"html-webpack-plugin": "^5.5.0",
|
||||||
"ifdef-loader": "^2.3.0",
|
"ifdef-loader": "^2.3.2",
|
||||||
"jest": "^26.6.3",
|
"jest": "^27.5.1",
|
||||||
"media-query-plugin": "^1.4.0",
|
"media-query-plugin": "^1.5.0",
|
||||||
"mini-css-extract-plugin": "^0.9.0",
|
"mini-css-extract-plugin": "^2.6.0",
|
||||||
"npm": "^7.12.1",
|
"npm": "^8.5.5",
|
||||||
"on-build-webpack": "^0.1.0",
|
"optimize-css-assets-webpack-plugin": "^6.0.1",
|
||||||
"optimize-css-assets-webpack-plugin": "^5.0.4",
|
"pako": "^2.0.4",
|
||||||
"pako": "^2.0.3",
|
"postcss-import": "^14.1.0",
|
||||||
"postcss": "^8.2.10",
|
"postcss-loader": "^6.2.1",
|
||||||
"postcss-loader": "^3.0.0",
|
"postcss-preset-env": "^7.4.3",
|
||||||
"postcss-preset-env": "^6.7.0",
|
"qr-code-styling": "^1.5.0",
|
||||||
"qr-code-styling": "^1.3.4",
|
"sass": "^1.49.9",
|
||||||
"sass": "^1.32.13",
|
"sass-loader": "^12.6.0",
|
||||||
"sass-loader": "^8.0.2",
|
"style-loader": "^3.3.1",
|
||||||
"serviceworker-webpack-plugin": "^1.0.1",
|
|
||||||
"style-loader": "^1.3.0",
|
|
||||||
"text-encoding": "^0.7.0",
|
"text-encoding": "^0.7.0",
|
||||||
"ts-jest": "^26.5.6",
|
"ts-jest": "^27.1.4",
|
||||||
"ts-loader": "^8.2.0",
|
"ts-loader": "^9.2.8",
|
||||||
"typescript": "^4.4.3",
|
"typescript": "^4.6.3",
|
||||||
"webpack": "^4.46.0",
|
"webpack": "^5.70.0",
|
||||||
"webpack-cli": "^3.3.12",
|
"webpack-bundle-analyzer": "^4.5.0",
|
||||||
"webpack-merge": "^4.2.2",
|
"webpack-cli": "^4.9.2",
|
||||||
"webpack-retry-chunk-load-plugin": "^1.5.0",
|
"webpack-merge": "^5.8.0",
|
||||||
|
"webpack-retry-chunk-load-plugin": "^3.0.0",
|
||||||
"worker-loader": "^3.0.8"
|
"worker-loader": "^3.0.8"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
parser: 'sugarss',
|
// parser: 'sugarss',
|
||||||
plugins: {
|
plugins: {
|
||||||
'postcss-import': {},
|
'postcss-import': {},
|
||||||
'postcss-preset-env': {},
|
'postcss-preset-env': {},
|
||||||
'cssnano': {}
|
'cssnano': {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ export default class QueryableWorker extends EventListenerBase<{
|
|||||||
this.worker.postMessage({
|
this.worker.postMessage({
|
||||||
queryMethod: queryMethod,
|
queryMethod: queryMethod,
|
||||||
queryMethodArguments: args
|
queryMethodArguments: args
|
||||||
}, transfer as PostMessageOptions);
|
}, transfer as Transferable[]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,14 @@
|
|||||||
* https://github.com/morethanwords/tweb/blob/master/LICENSE
|
* https://github.com/morethanwords/tweb/blob/master/LICENSE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@use "sass:math";
|
||||||
|
|
||||||
$btn-send-margin: .5rem;
|
$btn-send-margin: .5rem;
|
||||||
$chat-helper-size: 45px;
|
$chat-helper-size: 45px;
|
||||||
$chat-input-box-shadow: 0px 1px 8px 1px rgb(0 0 0 / 18%);
|
$chat-input-box-shadow: 0px 1px 8px 1px rgb(0 0 0 / 18%);
|
||||||
|
|
||||||
$input-transition-time: .2s;
|
$input-transition-time: .2s;
|
||||||
$input-half-transition-time: #{$input-transition-time / 2};
|
$input-half-transition-time: math.div($input-transition-time, 2);
|
||||||
$background-transition-time: 0.05s;
|
$background-transition-time: 0.05s;
|
||||||
$background-transition-total-time: #{$input-transition-time - $background-transition-time};
|
$background-transition-total-time: #{$input-transition-time - $background-transition-time};
|
||||||
|
|
||||||
|
@ -4,6 +4,8 @@
|
|||||||
* https://github.com/morethanwords/tweb/blob/master/LICENSE
|
* https://github.com/morethanwords/tweb/blob/master/LICENSE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@use "sass:math";
|
||||||
|
|
||||||
$bubble-margin: .25rem;
|
$bubble-margin: .25rem;
|
||||||
$bubble-beside-button-width: 38px;
|
$bubble-beside-button-width: 38px;
|
||||||
|
|
||||||
@ -103,8 +105,8 @@ $bubble-beside-button-width: 38px;
|
|||||||
left: -50%;
|
left: -50%;
|
||||||
/* top: 0;
|
/* top: 0;
|
||||||
bottom: 0; */
|
bottom: 0; */
|
||||||
top: -#{$bubble-margin / 2};
|
top: -#{math.div($bubble-margin, 2)};
|
||||||
bottom: -#{$bubble-margin / 2};
|
bottom: -#{math.div($bubble-margin, 2)};
|
||||||
content: " ";
|
content: " ";
|
||||||
z-index: -1;
|
z-index: -1;
|
||||||
}
|
}
|
||||||
@ -112,13 +114,13 @@ $bubble-beside-button-width: 38px;
|
|||||||
|
|
||||||
/* &.is-highlighted, &.is-selected {
|
/* &.is-highlighted, &.is-selected {
|
||||||
&:not(.is-group-last):after {
|
&:not(.is-group-last):after {
|
||||||
height: calc(100% + #{$bubble-margin / 2}) !important;
|
height: calc(100% + #{math.div($bubble-margin, 2)}) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
& + &:not(.is-group-last) {
|
& + &:not(.is-group-last) {
|
||||||
&:after {
|
&:after {
|
||||||
top: .125rem !important;
|
top: .125rem !important;
|
||||||
height: calc(100% - #{$bubble-margin / 2}) !important;
|
height: calc(100% - #{math.div($bubble-margin, 2)}) !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} */
|
} */
|
||||||
@ -126,7 +128,7 @@ $bubble-beside-button-width: 38px;
|
|||||||
// ! if turn this on, there will be an empty space
|
// ! if turn this on, there will be an empty space
|
||||||
/* &.is-highlighted, &.is-selected {
|
/* &.is-highlighted, &.is-selected {
|
||||||
&.is-group-last:after {
|
&.is-group-last:after {
|
||||||
bottom: #{$bubble-margin / 2} !important;
|
bottom: #{math.div($bubble-margin, 2)} !important;
|
||||||
}
|
}
|
||||||
} */
|
} */
|
||||||
|
|
||||||
@ -162,7 +164,7 @@ $bubble-beside-button-width: 38px;
|
|||||||
|
|
||||||
&.is-highlighted, &.is-selected {
|
&.is-highlighted, &.is-selected {
|
||||||
&:after {
|
&:after {
|
||||||
top: calc(#{$bubble-margin / 2} + 30px);
|
top: calc(#{math.div($bubble-margin, 2)} + 30px);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1547,7 +1549,7 @@ $bubble-beside-button-width: 38px;
|
|||||||
|
|
||||||
&:first-of-type {
|
&:first-of-type {
|
||||||
.document-selection {
|
.document-selection {
|
||||||
top: -#{$bubble-margin / 2}; // * padding inner + half padding outer
|
top: -#{math.div($bubble-margin, 2)}; // * padding inner + half padding outer
|
||||||
}
|
}
|
||||||
|
|
||||||
.document-wrapper {
|
.document-wrapper {
|
||||||
@ -1559,7 +1561,7 @@ $bubble-beside-button-width: 38px;
|
|||||||
|
|
||||||
&:last-of-type {
|
&:last-of-type {
|
||||||
.document-selection {
|
.document-selection {
|
||||||
bottom: -#{$bubble-margin / 2};
|
bottom: -#{math.div($bubble-margin, 2)};
|
||||||
}
|
}
|
||||||
|
|
||||||
.document-wrapper {
|
.document-wrapper {
|
||||||
|
@ -4,6 +4,8 @@
|
|||||||
* https://github.com/morethanwords/tweb/blob/master/LICENSE
|
* https://github.com/morethanwords/tweb/blob/master/LICENSE
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@use "sass:math";
|
||||||
|
|
||||||
.peer-typing {
|
.peer-typing {
|
||||||
//display: flex;
|
//display: flex;
|
||||||
margin-right: 4px;
|
margin-right: 4px;
|
||||||
@ -135,7 +137,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
$scale-max: 1;
|
$scale-max: 1;
|
||||||
$scale-step: 1 / 6;
|
$scale-step: math.div(1, 6);
|
||||||
$scale-mid: $scale-max - $scale-step;
|
$scale-mid: $scale-max - $scale-step;
|
||||||
$scale-min: $scale-max - ($scale-step * 2);
|
$scale-min: $scale-max - ($scale-step * 2);
|
||||||
$opacity-max: 1;
|
$opacity-max: 1;
|
||||||
|
@ -3,10 +3,10 @@ const HtmlWebpackPlugin = require('html-webpack-plugin');
|
|||||||
const MediaQueryPlugin = require('media-query-plugin');
|
const MediaQueryPlugin = require('media-query-plugin');
|
||||||
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
|
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
|
||||||
const postcssPresetEnv = require('postcss-preset-env');
|
const postcssPresetEnv = require('postcss-preset-env');
|
||||||
const ServiceWorkerWebpackPlugin = require('serviceworker-webpack-plugin');
|
|
||||||
const { RetryChunkLoadPlugin } = require('webpack-retry-chunk-load-plugin');
|
const { RetryChunkLoadPlugin } = require('webpack-retry-chunk-load-plugin');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const Dotenv = require('dotenv-webpack');
|
const Dotenv = require('dotenv-webpack');
|
||||||
|
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
|
||||||
|
|
||||||
const allowedIPs = ['127.0.0.1'];
|
const allowedIPs = ['127.0.0.1'];
|
||||||
const devMode = process.env.NODE_ENV !== 'production';
|
const devMode = process.env.NODE_ENV !== 'production';
|
||||||
@ -51,15 +51,21 @@ module.exports = {
|
|||||||
reloadAll: true,
|
reloadAll: true,
|
||||||
}
|
}
|
||||||
}, */
|
}, */
|
||||||
'css-loader?url=false',
|
{
|
||||||
|
loader: 'css-loader',
|
||||||
|
options: {
|
||||||
|
url: false
|
||||||
|
}
|
||||||
|
},
|
||||||
devMode ? undefined : MediaQueryPlugin.loader,
|
devMode ? undefined : MediaQueryPlugin.loader,
|
||||||
{
|
{
|
||||||
loader: 'postcss-loader',
|
loader: 'postcss-loader',
|
||||||
options: {
|
options: {
|
||||||
ident: 'postcss',
|
postcssOptions: {
|
||||||
plugins: [
|
plugins: [
|
||||||
postcssPresetEnv(),
|
postcssPresetEnv(),
|
||||||
]
|
]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -92,7 +98,10 @@ module.exports = {
|
|||||||
extensions: ['.ts', '.js'],
|
extensions: ['.ts', '.js'],
|
||||||
},
|
},
|
||||||
|
|
||||||
entry: './src/index.ts',
|
entry: {
|
||||||
|
index: './src/index.ts',
|
||||||
|
sw: {import: './src/lib/serviceWorker/index.service.ts', filename: 'sw.js'}
|
||||||
|
},
|
||||||
/* entry: {
|
/* entry: {
|
||||||
index: './src/index.ts',
|
index: './src/index.ts',
|
||||||
pluralPolyfill: './src/lib/pluralPolyfill.ts'
|
pluralPolyfill: './src/lib/pluralPolyfill.ts'
|
||||||
@ -103,12 +112,28 @@ module.exports = {
|
|||||||
globalObject: 'this',
|
globalObject: 'this',
|
||||||
path: path.resolve(__dirname, 'public'),
|
path: path.resolve(__dirname, 'public'),
|
||||||
filename: '[name].[chunkhash].bundle.js',
|
filename: '[name].[chunkhash].bundle.js',
|
||||||
chunkFilename: '[name].[chunkhash].chunk.js'
|
chunkFilename: '[name].[chunkhash].chunk.js',
|
||||||
|
clean: {
|
||||||
|
keep(asset) {
|
||||||
|
if(asset.includes('.xml')
|
||||||
|
|| asset.includes('version')
|
||||||
|
|| asset.includes('assets/')
|
||||||
|
|| asset.includes('changelogs/')
|
||||||
|
|| asset.includes('.webmanifest')
|
||||||
|
|| asset.includes('.wasm')
|
||||||
|
|| asset.includes('rlottie-wasm')
|
||||||
|
|| asset.includes('Worker.min.js')
|
||||||
|
|| asset.includes('recorder.min.js')
|
||||||
|
|| asset.includes('.hbs')) return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
devServer: {
|
devServer: {
|
||||||
contentBase: path.join(__dirname, 'public'),
|
// static: {
|
||||||
watchContentBase: true,
|
// directory: path.join(__dirname, 'public')
|
||||||
|
// },
|
||||||
compress: true,
|
compress: true,
|
||||||
http2: useLocalNotLocal ? true : (useLocal ? undefined : true),
|
http2: useLocalNotLocal ? true : (useLocal ? undefined : true),
|
||||||
https: useLocal ? undefined : {
|
https: useLocal ? undefined : {
|
||||||
@ -119,12 +144,14 @@ module.exports = {
|
|||||||
domain
|
domain
|
||||||
],
|
],
|
||||||
host: useLocalNotLocal ? localIp : (useLocal ? undefined : '0.0.0.0'),
|
host: useLocalNotLocal ? localIp : (useLocal ? undefined : '0.0.0.0'),
|
||||||
public: useLocal ? undefined : domain,
|
|
||||||
//host: domain, // '0.0.0.0'
|
//host: domain, // '0.0.0.0'
|
||||||
port: useLocal ? undefined : 443,
|
port: useLocal ? undefined : 443,
|
||||||
overlay: true,
|
client: {
|
||||||
before: useLocal ? undefined : function(app, server, compiler) {
|
overlay: true,
|
||||||
app.use((req, res, next) => {
|
progress: true
|
||||||
|
},
|
||||||
|
setupMiddlewares: useLocal ? undefined : (middlewares, devServer) => {
|
||||||
|
middlewares.push((req, res) => {
|
||||||
let IP = '';
|
let IP = '';
|
||||||
if(req.headers['cf-connecting-ip']) {
|
if(req.headers['cf-connecting-ip']) {
|
||||||
IP = req.headers['cf-connecting-ip'];
|
IP = req.headers['cf-connecting-ip'];
|
||||||
@ -143,33 +170,16 @@ module.exports = {
|
|||||||
next();
|
next();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
return middlewares;
|
||||||
},
|
},
|
||||||
sockHost: useLocal ? undefined : domain,
|
/* public: useLocal ? undefined : domain,
|
||||||
|
sockHost: useLocal ? undefined : domain, */
|
||||||
},
|
},
|
||||||
|
|
||||||
plugins: [
|
plugins: [
|
||||||
new Dotenv(),
|
new Dotenv(),
|
||||||
|
|
||||||
new ServiceWorkerWebpackPlugin({
|
|
||||||
entry: path.join(__dirname, 'src/lib/serviceWorker/index.service.ts'),
|
|
||||||
filename: 'sw.js',
|
|
||||||
//excludes: ['**/*'],
|
|
||||||
includes: [
|
|
||||||
'**/*.js',
|
|
||||||
'**/*.css',
|
|
||||||
'**/*.json',
|
|
||||||
'**/*.wasm',
|
|
||||||
'**/*.mp3',
|
|
||||||
'**/*.svg',
|
|
||||||
'**/*.tgs',
|
|
||||||
'**/*.ico',
|
|
||||||
'**/*.woff',
|
|
||||||
'**/*.woff2',
|
|
||||||
'**/*.ttf',
|
|
||||||
'**/*.webmanifest'
|
|
||||||
],
|
|
||||||
}),
|
|
||||||
|
|
||||||
new HtmlWebpackPlugin({
|
new HtmlWebpackPlugin({
|
||||||
filename: `index.html`,
|
filename: `index.html`,
|
||||||
//template: 'public/index_template.html',
|
//template: 'public/index_template.html',
|
||||||
@ -225,5 +235,11 @@ module.exports = {
|
|||||||
// if not set - nothing will happen and error will be returned to the chunk loader.
|
// if not set - nothing will happen and error will be returned to the chunk loader.
|
||||||
//lastResortScript: "window.location.href='/500.html';",
|
//lastResortScript: "window.location.href='/500.html';",
|
||||||
}),
|
}),
|
||||||
],
|
|
||||||
|
devMode ? undefined : new BundleAnalyzerPlugin({
|
||||||
|
analyzerMode: 'static',
|
||||||
|
openAnalyzer: true,
|
||||||
|
generateStatsFile: true
|
||||||
|
}),
|
||||||
|
].filter(Boolean),
|
||||||
};
|
};
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
process.env.NODE_ENV = 'development';
|
process.env.NODE_ENV = 'development';
|
||||||
|
|
||||||
const webpack = require('webpack');
|
const webpack = require('webpack');
|
||||||
const merge = require('webpack-merge');
|
const {merge} = require('webpack-merge');
|
||||||
const common = require('./webpack.common.js');
|
const common = require('./webpack.common.js');
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,16 +1,11 @@
|
|||||||
process.env.NODE_ENV = 'production';
|
process.env.NODE_ENV = 'production';
|
||||||
|
|
||||||
const path = require('path');
|
const {merge} = require('webpack-merge');
|
||||||
const merge = require('webpack-merge');
|
|
||||||
const common = require('./webpack.common.js');
|
const common = require('./webpack.common.js');
|
||||||
|
|
||||||
//const CompressionPlugin = require("compression-webpack-plugin");
|
//const CompressionPlugin = require("compression-webpack-plugin");
|
||||||
const WebpackOnBuildPlugin = require('on-build-webpack');
|
|
||||||
//const TerserJSPlugin = require('terser-webpack-plugin');
|
//const TerserJSPlugin = require('terser-webpack-plugin');
|
||||||
//const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
|
//const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
|
||||||
const fs = require('fs');
|
|
||||||
|
|
||||||
const buildDir = __dirname + '/public/';
|
|
||||||
|
|
||||||
module.exports = merge(common, {
|
module.exports = merge(common, {
|
||||||
mode: 'production',
|
mode: 'production',
|
||||||
@ -57,37 +52,5 @@ module.exports = merge(common, {
|
|||||||
minRatio: 0.8,
|
minRatio: 0.8,
|
||||||
deleteOriginalAssets: false,
|
deleteOriginalAssets: false,
|
||||||
}), */
|
}), */
|
||||||
|
|
||||||
new WebpackOnBuildPlugin(function(stats) {
|
|
||||||
const newlyCreatedAssets = stats.compilation.assets;
|
|
||||||
|
|
||||||
const unlinked = [];
|
|
||||||
fs.readdir(path.resolve(buildDir), (err, files) => {
|
|
||||||
files.forEach(file => {
|
|
||||||
//console.log('to unlink 1:', file);
|
|
||||||
|
|
||||||
if(file.includes('.xml')
|
|
||||||
|| file.includes('.webmanifest')
|
|
||||||
|| file.includes('.wasm')
|
|
||||||
|| file.includes('rlottie-wasm')
|
|
||||||
|| file.includes('Worker.min.js')
|
|
||||||
|| file.includes('recorder.min.js')
|
|
||||||
|| file.includes('.hbs')) return;
|
|
||||||
|
|
||||||
let p = path.resolve(buildDir + file);
|
|
||||||
if(!newlyCreatedAssets[file] && ['.gz', '.js', '.ts', '.map', '.css', '.txt'].find(ext => file.endsWith(ext)) !== undefined) {
|
|
||||||
|
|
||||||
//console.log('to unlink 2:', file);
|
|
||||||
|
|
||||||
fs.unlinkSync(p);
|
|
||||||
unlinked.push(file);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if(unlinked.length > 0) {
|
|
||||||
console.log('Removed old assets: ', unlinked);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
})
|
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user