-
Notifications
You must be signed in to change notification settings - Fork 483
Expand file tree
/
Copy pathrollup.config.mjs
More file actions
121 lines (112 loc) · 3.37 KB
/
rollup.config.mjs
File metadata and controls
121 lines (112 loc) · 3.37 KB
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
110
111
112
113
114
115
116
117
118
119
120
121
import path from 'path';
import alias from '@rollup/plugin-alias';
import image from '@rollup/plugin-image';
import json from '@rollup/plugin-json';
import resolve from '@rollup/plugin-node-resolve';
import strip from '@rollup/plugin-strip';
import terser from '@rollup/plugin-terser';
import typescript from '@rollup/plugin-typescript';
import autoprefixer from 'autoprefixer';
import postcss from 'postcss';
import scss from 'rollup-plugin-scss';
import sass from 'sass';
import copyAndWatch from './copy-and-watch.mjs';
// prod is release build
if (process.env.BUILD_TYPE === 'prod') {
process.env.BUILD_TYPE = 'release';
}
// debug, profile, release
const BUILD_TYPE = process.env.BUILD_TYPE || 'release';
const ENGINE_DIR = path.resolve(`node_modules/playcanvas/build/playcanvas${BUILD_TYPE === 'debug' ? '.dbg' : ''}/src/index.js`);
const PCUI_DIR = path.resolve('node_modules/@playcanvas/pcui');
const HREF = process.env.BASE_HREF || '';
const outputHeader = () => {
const BLUE_OUT = '\x1b[34m';
const BOLD_OUT = '\x1b[1m';
const REGULAR_OUT = '\x1b[22m';
const RESET_OUT = '\x1b[0m';
const title = [
'Building SuperSplat',
`type ${BOLD_OUT}${BUILD_TYPE}${REGULAR_OUT}`
].map(l => `${BLUE_OUT}${l}`).join('\n');
console.log(`${BLUE_OUT}${title}${RESET_OUT}\n`);
};
outputHeader();
const application = {
input: 'src/index.ts',
output: {
dir: 'dist',
format: 'esm',
sourcemap: true
},
plugins: [
copyAndWatch({
targets: [
{
src: 'src/index.html',
transform: (contents, filename) => {
return contents.toString().replace('__BASE_HREF__', HREF);
}
},
{ src: 'src/manifest.json' },
{ src: 'static/images', dest: 'static' },
{ src: 'static/icons', dest: 'static' },
{ src: 'static/lib', dest: 'static' },
{ src: 'static/locales', dest: 'static' },
{ src: 'static/env/VertebraeHDRI_v1_512.png', dest: 'static/env' }
]
}),
alias({
entries: {
'playcanvas': ENGINE_DIR,
'@playcanvas/pcui': PCUI_DIR
}
}),
typescript({
tsconfig: './tsconfig.json'
}),
resolve(),
image({ dom: false }),
json(),
scss({
sourceMap: true,
runtime: sass,
processor: (css) => {
return postcss([autoprefixer])
.process(css, { from: undefined })
.then(result => result.css);
},
fileName: 'index.css',
includePaths: [`${PCUI_DIR}/dist`],
watch: 'src/ui/scss'
}),
BUILD_TYPE === 'release' &&
strip({
include: ['**/*.ts'],
functions: ['Debug.exec']
}),
BUILD_TYPE !== 'debug' && terser()
],
treeshake: 'smallest',
cache: false
};
const serviceWorker = {
input: 'src/sw.ts',
output: {
dir: 'dist',
format: 'esm',
sourcemap: true
},
plugins: [
resolve(),
json(),
typescript()
// BUILD_TYPE !== 'debug' && terser()
],
treeshake: 'smallest',
cache: false
};
export default [
application,
serviceWorker
];