-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.js
106 lines (98 loc) · 3.01 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
import commonjs from '@rollup/plugin-commonjs';
import resolve from '@rollup/plugin-node-resolve';
import terser from '@rollup/plugin-terser';
import { importsResolve } from '@typhonjs-build-test/rollup-plugin-pkg-imports';
import autoprefixer from 'autoprefixer';
import cssnano from 'cssnano';
import postcssPresetEnv from 'postcss-preset-env';
import postcss from 'rollup-plugin-postcss';
import svelte from 'rollup-plugin-svelte';
import { sveltePreprocess } from 'svelte-preprocess';
const banner = `/**
* @module @typhonjs-typedoc/typedoc-theme-dmt
* @license MPL-2.0
* @see https://github.com/typhonjs-typedoc/typedoc-theme-dmt
*/
`;
/**
* @type {import('rollup').RollupOptions[]}
*/
export default [
{
input: 'src/plugin/index.js',
external: [
'cheerio',
'lunr',
'node:fs',
'node:path',
'node:url',
'typedoc'
],
output: {
banner,
file: 'dist/index.js',
format: 'es',
generatedCode: { constBindings: true },
sourcemap: false
},
plugins: [
commonjs(),
importsResolve(),
resolve()
]
},
{
input: 'src/frontend/index.js',
external: ['../dmt-component-data.js'],
output: {
banner,
file: 'dist/assets/dmt-components.js',
format: 'es',
generatedCode: { constBindings: true },
plugins: [terser()],
sourcemap: false
},
plugins: [
svelte({
preprocess: sveltePreprocess()
}),
postcss(postcssConfig({
extract: 'dmt-components.css',
compress: true,
sourceMap: false
})),
commonjs(),
importsResolve(),
resolve({
browser: true,
dedupe: ['svelte']
}),
]
}
];
/**
* Provides a function to return a new PostCSS configuration setting the extract parameter.
*
* @param {object} [opts] - Optional parameters.
*
* @param {string} [opts.extract] - Name of CSS file to extract to...
*
* @param {boolean} [opts.compress=false] - Compress CSS.
*
* @param {boolean} [opts.sourceMap=false] - Generate source maps.
*
* @returns {{extensions: string[], extract, sourceMap: boolean, plugins: (*)[], use: string[], inject: boolean}}
* PostCSS config
*/
export function postcssConfig({ extract, compress = false, sourceMap = false } = {})
{
const plugins = compress ? [autoprefixer, postcssPresetEnv, cssnano] : [autoprefixer, postcssPresetEnv];
return {
inject: false, // Don't inject CSS into <HEAD>
extract,
sourceMap,
extensions: ['.scss', '.sass', '.css'], // File extensions
plugins, // Postcss plugins to use
use: ['sass'] // Use sass / dart-sass
};
}