-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.mjs
50 lines (44 loc) · 1.37 KB
/
build.mjs
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
import { sassPlugin } from 'esbuild-sass-plugin';
import * as esbuild from 'esbuild';
import * as tsup from 'tsup';
async function build(path) {
const file = `${path}/src/datepicker/index.ts`;
const dist = `${path}/dist`;
const esbuildConfig = {
entryPoints: [file],
packages: 'external',
external: ['@radix-ui/*', 'framer-motion', 'classnames'],
bundle: true,
sourcemap: false,
format: 'cjs',
target: 'es2022',
outdir: dist,
plugins: [sassPlugin()],
};
await esbuild.build(esbuildConfig);
console.log(`Built ${path}/dist/index.js`);
await esbuild.build({
...esbuildConfig,
format: 'esm',
outExtension: { '.js': '.mjs' },
});
console.log(`Built ${path}/dist/index.mjs`);
// tsup is used to emit d.ts files only (esbuild can't do that).
//
// Notes:
// 1. Emitting d.ts files is super slow for whatever reason.
// 2. It could have fully replaced esbuild (as it uses that internally),
// but at the moment its esbuild version is somewhat outdated.
// It’s also harder to configure and esbuild docs are more thorough.
await tsup.build({
entry: [file],
format: ['cjs', 'esm'],
dts: { only: true },
outDir: dist,
silent: true,
external: [/@radix-ui\/.+/, 'classnames', 'framer-motion'],
});
console.log(`Built ${path}/dist/index.d.ts`);
}
const entryFile = '.';
await build(entryFile);