forked from remeda/remeda
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtsup.config.ts
46 lines (37 loc) · 1.42 KB
/
tsup.config.ts
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
import ts from "node:fs/promises";
import path from "node:path";
import { defineConfig } from "tsup";
const SOURCE_DIRECTORY = "src";
export default defineConfig(async () => ({
entry: await getEntries(SOURCE_DIRECTORY),
format: ["esm", "cjs"],
clean: true,
// Add types to our bundle, typing is a part of our offering.
dts: true,
// We want to stay generic, not building for node or the browser.
platform: "neutral",
// Make CJS output more efficient by putting common CommonJS "infra" in chunks
// outside of the utility.
splitting: true,
// For CJS this reduces ~29% of the size of the output, for ESM it reduces
// ~40%!
minify: true,
}));
/**
* Scans the source directory and build the list of entry points we should build
* our library for. This allows the library to be tree-shaken so that bundlers
* can take just the utilities and functionality the user's project needs.
*
* TODO: We need this just because tsup doesn't support globs in the entry field. If tsup starts supporting it we can drop this and replace it with a regular glob.
*/
async function getEntries(sourceDirectory: string): Promise<Array<string>> {
const files = await ts.readdir(sourceDirectory);
return files
.filter(
(fileName) =>
fileName.endsWith(".ts") &&
!fileName.endsWith(".test.ts") &&
!fileName.endsWith(".test-d.ts"),
)
.map((fileName) => path.join(sourceDirectory, fileName));
}