-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathrollup.config.js
70 lines (67 loc) · 1.57 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
import commonjs from '@rollup/plugin-commonjs';
import json from '@rollup/plugin-json';
import resolve from '@rollup/plugin-node-resolve';
import typescript from '@rollup/plugin-typescript';
import path from 'path';
import dts from 'rollup-plugin-dts';
import peerDepsExternal from 'rollup-plugin-peer-deps-external';
import postcss from 'rollup-plugin-postcss';
import packageJson from './package.json';
const stylesPostCssPlugin = (config) =>
postcss({
config: {
path: path.resolve('postcss.config.js'),
},
plugins: [
require('tailwindcss'),
require('autoprefixer'),
require('postcss-add-root-selector')({
rootSelector: '.flair-component',
}),
],
...config,
});
// eslint-disable-next-line import/no-anonymous-default-export
export default [
{
input: './src/index.css',
output: [
{
file: 'dist/index.css',
},
],
plugins: [
stylesPostCssPlugin({
// Setting extract to generate a CSS file
inject: false,
extract: true,
}),
],
},
{
input: './src/index.ts',
output: {
file: packageJson.module,
format: 'esm',
sourcemap: true,
},
plugins: [
peerDepsExternal(),
resolve(),
json(),
commonjs(),
typescript(),
stylesPostCssPlugin({
// Un-setting extract to force exporting styles in the JS
inject: false,
extract: false,
}),
],
},
{
input: 'src/index.ts',
output: [{ file: 'dist/types.d.ts' }],
external: [/\.css$/u],
plugins: [dts({})],
},
];