generated from dimfeld/svelte-storybook-tailwind
/
rollup.config.js
115 lines (105 loc) · 3.49 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
import * as fs from 'fs';
import { template } from 'lodash';
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 postcss from 'rollup-plugin-postcss';
import babel from 'rollup-plugin-babel';
import html, { makeHtmlAttributes } from '@rollup/plugin-html';
import copy from 'rollup-plugin-copy';
import json from '@rollup/plugin-json';
const production = process.env.NODE_ENV !== 'development';
const babelConfig = {
extensions: ['.js', '.mjs', '.html', '.svelte', '.ts'],
exclude: ['node_modules/@babel/**', 'static/**', 'build/**', 'public/**'],
presets: [
['@babel/preset-env', { targets: { esmodules: true } }],
'@babel/preset-typescript',
],
plugins: [
'@babel/plugin-syntax-dynamic-import',
'@babel/proposal-class-properties',
'@babel/plugin-proposal-object-rest-spread',
'@babel/plugin-proposal-nullish-coalescing-operator',
'@babel/plugin-proposal-optional-chaining',
],
};
export default {
input: 'src/main.js',
output: {
dir: 'public',
entryFileNames: '[name].[hash].js',
chunkFileNames: '[name].[hash].js',
assetFileNames: '[name].[hash][extname]',
sourcemap: production ? true : 'inline',
format: 'esm',
},
plugins: [
svelte({
preprocess: require('./svelte.config').preprocess,
// enable run-time checks when not in production
dev: !production,
// extract any component CSS out into
// a separate file — better for performance
// css: css => {
// css.write('public/bundle.css');
// },
// Instead, emit CSS as a file for processing through rollup
emitCss: true,
}),
postcss({
extract: true,
}),
resolve({
mainFields: ['module', 'browser', 'main'],
extensions: ['.mjs', '.js', '.json', '.ts', '.svelte'],
dedupe: (importee) =>
importee === 'svelte' || importee.startsWith('svelte/'),
}),
copy({
targets: [{ src: 'static/**/*', dest: 'public/' }],
}),
commonjs(),
json(),
babel(babelConfig),
// Watch the `public` directory and refresh the
// browser on changes when not in production
!production && livereload('public'),
// If we're building for production (npm run build
// instead of npm run dev), minify
production && terser(),
html({
title: 'Fund the Rebuild',
template: ({ attributes, files, publicPath, title }) => {
let templateFile = fs.readFileSync('src/index.html');
// This is adapted from the default template function in the HTML plugin.
const scripts = (files.js || [])
.map(({ fileName }) => {
const attrs = makeHtmlAttributes(attributes.script);
return `<script src="${publicPath}${fileName}"${attrs}></script>`;
})
.join('\n');
const links = (files.css || [])
.map(({ fileName }) => {
const attrs = makeHtmlAttributes(attributes.link);
return `<link href="${publicPath}${fileName}" rel="stylesheet"${attrs}>`;
})
.join('\n');
let exec = template(templateFile.toString());
return exec({
attributes,
title,
scripts,
links,
prod: production,
htmlAttributes: makeHtmlAttributes(attributes.html),
});
},
}),
],
watch: {
clearScreen: false,
},
};