-
Notifications
You must be signed in to change notification settings - Fork 76
/
Copy pathrollup.config.js
121 lines (114 loc) · 3.35 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
110
111
112
113
114
115
116
117
118
119
120
121
import svelte from 'rollup-plugin-svelte';
import resolve from '@rollup/plugin-node-resolve';
import commonjs from '@rollup/plugin-commonjs';
import livereload from 'rollup-plugin-livereload';
import { terser } from 'rollup-plugin-terser';
import sveltePreprocess from 'svelte-preprocess';
import typescript from '@rollup/plugin-typescript';
import del from 'rollup-plugin-delete'
const production = !process.env.ROLLUP_WATCH;
function onwarn(warning, handler) {
if (warning.message === 'A11y: Avoid using autofocus') return // use responsibly
if (warning.message === 'A11y: avoid tabindex values above zero') return // remove if possible
if (warning.message === 'A11y: <a> element should have an href attribute') return
if (warning.message === 'A11y: A form label must be associated with a control') return
handler(warning)
}
const preprocess = sveltePreprocess({
preserve: ['systemjs-importmap'],
postcss: {
plugins: [
require('postcss-nested'),
require('tailwindcss')('./tailwind.config.js'),
],
},
})
const buildDirectory = 'public/'
export default [{
input: 'src/main.ts',
output: {
sourcemap: true,
format: 'es',
dir: buildDirectory+'build',
name: 'app',
},
plugins: [
del({ targets: buildDirectory+'build' }),
svelte({ preprocess, customElement: true, include: /\.wc\.svelte$/ }),
svelte({
customElement: false,
exclude: /\.wc\.svelte$/,
// enable run-time checks when not in production
dev: !production,
// we'll extract any component CSS out into
// a separate file - better for performance
css: css => {
css.write(buildDirectory+'/build/bundle.css');
},
preprocess,
}),
// If you have external dependencies installed from
// npm, you'll most likely need these plugins. In
// some cases you'll need additional configuration -
// consult the documentation for details:
// https://github.com/rollup/plugins/tree/master/packages/commonjs
resolve({
browser: true,
dedupe: ['svelte']
}),
commonjs(),
typescript({
sourceMap: !production,
inlineSources: !production
}),
typescript({ sourceMap: !production }),
// Watch the `public` directory and refresh the
// browser on changes when not in production
!production && livereload(buildDirectory),
// If we're building for production (npm run build
// instead of npm run dev), minify
production && terser()
],
watch: {
clearScreen: false
}
},
{
input: 'src/preview.ts',
output: {
// format: 'iife',
// file: buildDirectory+'preview/bundle.js',
sourcemap: true,
name: 'preview',
format: 'es',
dir: buildDirectory+'preview',
},
plugins: [
del({ targets: buildDirectory+'/preview' }),
svelte({
// enable run-time checks when not in production
dev: !production,
// we'll extract any component CSS out into
// a separate file - better for performance
css: css => {
css.write(buildDirectory+'/build/bundle.css');
},
preprocess,
}),
// If you have external dependencies installed from
// npm, you'll most likely need these plugins. In
// some cases you'll need additional configuration -
// consult the documentation for details:
// https://github.com/rollup/plugins/tree/master/packages/commonjs
resolve({
browser: true,
dedupe: ['svelte']
}),
commonjs(),
typescript({ sourceMap: !production }),
production && terser()
],
watch: {
clearScreen: false
}
}];