memories/webpack.js

68 lines
2.0 KiB
JavaScript
Raw Permalink Normal View History

2022-08-14 20:54:18 +00:00
const webpackConfig = require('@nextcloud/webpack-vue-config')
2022-10-17 02:52:44 +00:00
const WorkboxPlugin = require('workbox-webpack-plugin')
2022-09-13 01:33:24 +00:00
const path = require('path')
2022-10-17 02:52:44 +00:00
const buildMode = process.env.NODE_ENV
const isDev = buildMode === 'development'
2022-09-13 01:33:24 +00:00
webpackConfig.module.rules.push({
test: /\.ts?$/,
loader: 'ts-loader',
exclude: /node_modules/,
options: {
appendTsSuffixTo: [/\.vue$/],
},
});
webpackConfig.resolve.extensions.push('.ts');
webpackConfig.resolve.alias = {
'vue$': 'vue/dist/vue.esm.js',
}
webpackConfig.entry.main = path.resolve(path.join('src', 'main'));
delete webpackConfig.optimization.splitChunks;
2022-08-14 20:54:18 +00:00
2022-10-15 19:21:53 +00:00
webpackConfig.watchOptions = {
ignored: /node_modules/,
aggregateTimeout: 300,
};
2022-10-17 02:52:44 +00:00
if (!isDev) {
webpackConfig.plugins.push(
new WorkboxPlugin.GenerateSW({
swDest: 'memories-service-worker.js',
clientsClaim: true,
skipWaiting: true,
exclude: [new RegExp('.*')], // don't do precaching
inlineWorkboxRuntime: true,
sourcemap: false,
// Define runtime caching rules.
runtimeCaching: [{
// Match any preview file request
urlPattern: /^.*\/core\/preview\?fileId=.*/,
handler: 'CacheFirst',
options: {
cacheName: 'images',
expiration: {
maxAgeSeconds: 3600 * 24 * 7, // one week
maxEntries: 20000, // 20k images
},
},
}, {
// Match page requests
urlPattern: /^.*\/.*$/,
handler: 'NetworkFirst',
options: {
cacheName: 'pages',
expiration: {
maxAgeSeconds: 3600 * 24 * 7, // one week
maxEntries: 2000, // assets
},
},
}],
})
);
}
2022-08-14 20:54:18 +00:00
module.exports = webpackConfig