-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.js
66 lines (57 loc) · 1.63 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
import svelte from 'rollup-plugin-svelte'
import commonjs from '@rollup/plugin-commonjs'
import resolve from '@rollup/plugin-node-resolve'
import livereload from 'rollup-plugin-livereload'
import { terser } from 'rollup-plugin-terser'
import sveltePreprocess from 'svelte-preprocess'
import babel from "@rollup/plugin-babel"
import css from 'rollup-plugin-css-only'
const writeFileSync = require('fs').writeFileSync
const prod = !process.env.ROLLUP_WATCH
const babelSettings = {
babelHelpers: 'runtime',
extensions: [ '.js', '.mjs', '.html', '.svelte' ],
plugins: ['@babel/plugin-external-helpers', '@babel/plugin-transform-runtime', '@babel/plugin-proposal-object-rest-spread']
}
export default {
input: 'src/main.js',
output: {
sourcemap: true,
format: 'iife',
name: 'app',
file: 'public/bundle.js'
},
plugins: [
svelte({
preprocess: sveltePreprocess(),
}),
css({
output: (styles)=> {
writeFileSync("public/appBundle.css", styles)
},
}),
babel(babelSettings),
// 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/rollup-plugin-commonjs
resolve({
browser: true,
dedupe: ['svelte']
}),
commonjs(),
prod && babel(babelSettings),
//Watch 'public' directory and refresh when not in production
!prod && livereload({
watch: "public/",
verbose: false
}),
// If we're building for production (npm run build
// instead of npm run dev), minify
prod && terser()
],
watch: {
clearScreen: false
}
};