This repository has been archived by the owner on May 31, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 23
/
rollup.config.js
109 lines (101 loc) · 2.82 KB
/
rollup.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/**
* Copyright (c) IBM, Corp. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import { createSpaConfig } from '@open-wc/building-rollup';
import replace from '@rollup/plugin-replace';
import typescript from '@rollup/plugin-typescript';
import { copy } from '@web/rollup-plugin-copy';
import merge from 'deepmerge';
import { black, blue, bgWhite } from 'picocolors';
const NODE_ENV = process.env.NODE_ENV || 'development';
const DIST_PATH = 'server/dist/';
const GENERATE_SERVICE_WORKER = false;
const absoluteBaseUrl =
NODE_ENV === 'production'
? 'https://pwa-lit-template.mybluemix.net'
: 'http://localhost:8000';
const workboxConfig = {
sourcemap: false,
runtimeCaching: [
{
urlPattern: /images\/.*$/,
handler: 'CacheFirst',
options: {
cacheName: 'images',
expiration: {
maxEntries: 60,
maxAgeSeconds: 30 * 24 * 60 * 60, // 30 Days
},
},
},
],
skipWaiting: false,
clientsClaim: false,
};
const config = merge(
createSpaConfig({
outputDir: DIST_PATH,
html: {
absoluteBaseUrl,
extractAssets: false,
},
legacyBuild: true,
polyfillsLoader: {
polyfills: {
custom: [
{
name: 'lit-polyfill-support',
path: 'node_modules/lit/polyfill-support.js',
test: "!('attachShadow' in Element.prototype)",
module: false,
},
],
},
},
developmentMode: process.env.ROLLUP_WATCH === 'true',
workbox: GENERATE_SERVICE_WORKER && workboxConfig,
injectServiceWorker: GENERATE_SERVICE_WORKER,
}),
{
input: 'index.html',
plugins: [
typescript({
declaration: false,
sourceMap: false,
inlineSources: false,
}),
replace({
preventAssignment: true,
values: {
'process.env.NODE_ENV': JSON.stringify('production'),
},
}),
...(NODE_ENV !== 'development'
? [
replace({
preventAssignment: true,
include: 'src/**/*.ts',
exclude: 'src/config.*.ts',
delimiters: ['', ''],
values: {
'./config.js': `./config.${NODE_ENV}.js`,
},
}),
]
: []),
copy({
// Copy all the static files
patterns: ['images/**/*', 'manifest.webmanifest', 'robots.txt'],
}),
],
}
);
console.log(`${bgWhite(black(' Build information'.padEnd(60, ' ')))}
${blue('Name')} ${process.env.npm_package_name}
${blue('Environment')} ${NODE_ENV}
${blue('Service Worker')} ${GENERATE_SERVICE_WORKER}
${blue('Version')} v${process.env.npm_package_version}`);
export default config;