-
Notifications
You must be signed in to change notification settings - Fork 107
Expand file tree
/
Copy pathrollup.config.mjs
More file actions
96 lines (89 loc) · 2.83 KB
/
rollup.config.mjs
File metadata and controls
96 lines (89 loc) · 2.83 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
// official rollup plugins
import path from 'path';
import alias from '@rollup/plugin-alias';
import commonjs from '@rollup/plugin-commonjs';
import image from '@rollup/plugin-image';
import json from '@rollup/plugin-json';
import resolve from '@rollup/plugin-node-resolve';
import replace from '@rollup/plugin-replace';
import terser from '@rollup/plugin-terser';
import typescript from '@rollup/plugin-typescript';
import sass from 'rollup-plugin-sass';
// custom plugins
import { copyAndWatch } from './plugins/copy-and-watch.mjs';
// 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 BLUE_OUT = '\x1b[34m';
const BOLD_OUT = '\x1b[1m';
const REGULAR_OUT = '\x1b[22m';
const RESET_OUT = '\x1b[0m';
const title = [
'Building PlayCanvas Model Viewer',
`type ${BOLD_OUT}${BUILD_TYPE}${REGULAR_OUT}`,
`engine ${BOLD_OUT}${ENGINE_DIR}${REGULAR_OUT}`
].map(l => `${BLUE_OUT}${l}`).join('\n');
console.log(`${BLUE_OUT}${title}${RESET_OUT}\n`);
const TARGETS = [
{
src: 'src/index.html',
transform: (contents) => {
return contents.toString()
.replace('__BASE_HREF__', process.env.BASE_HREF || '')
.replace('__');
}
},
{ src: 'src/manifest.json' },
{ src: 'src/fonts.css' },
{ src: 'static/' }
];
export default {
input: 'src/index.tsx',
output: {
dir: 'dist',
format: 'esm',
sourcemap: true
},
treeshake: 'smallest',
onwarn(warning, warn) {
// Suppress "use client" directive warnings from react-intersection-observer
if (warning.code === 'MODULE_LEVEL_DIRECTIVE' && warning.message.includes('"use client"')) {
return;
}
warn(warning);
},
plugins: [
copyAndWatch(TARGETS),
replace({
values: {
// NOTE: this is required for react (??) - see https://github.com/rollup/rollup/issues/487#issuecomment-177596512
'process.env.NODE_ENV': JSON.stringify(BUILD_TYPE === 'release' ? 'production' : 'development')
},
preventAssignment: true
}),
sass({
insert: false,
output: 'dist/style.css',
outputStyle: 'compressed',
api: 'modern'
}),
image({ dom: true }),
alias({
entries: {
'playcanvas': ENGINE_DIR
}
}),
commonjs(),
resolve(),
typescript({
tsconfig: './tsconfig.json'
}),
json(),
(BUILD_TYPE !== 'debug') && terser({
mangle: {
// script classes can't be mangeled
reserved: ['CameraControls']
}
})
]
};