-
Notifications
You must be signed in to change notification settings - Fork 142
/
tsup.config.ts
100 lines (94 loc) · 3.39 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
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
import { defineConfig } from "tsup";
import packageJson from "./package.json" assert { type: "json" };
import swc, { JscConfig } from "@swc/core";
import path from "node:path";
import tsConfig from "./tsconfig.json" assert { type: "json" };
import { JscTarget } from "@swc/types";
export default defineConfig({
entry: ["src/**/*.{ts,js}", "!src/**/*.test.ts"],
tsconfig: "./tsconfig.json",
sourcemap: true,
dts: true,
format: ["esm", "cjs"],
plugins: [
{
name: "fix-cjs-imports",
renderChunk(code) {
if (this.format === "cjs") {
const regexCjs = /require\((?<quote>['"])(?<import>\.[^'"]+)\.js['"]\)/g;
const regexEsm = /from(?<space>[\s]*)(?<quote>['"])(?<import>\.[^'"]+)\.js['"]/g;
return {
code: code
.replace(regexCjs, "require($<quote>$<import>.cjs$<quote>)")
.replace(regexEsm, "from$<space>$<quote>$<import>.cjs$<quote>"),
};
}
},
},
{
name: "override-swc",
esbuildOptions: (options) => {
const plugin = options.plugins?.find((p) => p.name === "swc");
if (plugin) {
// Original Source: https://github.com/egoist/tsup/blob/49c11c3073ce977a01c84e7848fc070d5de0a652/src/esbuild/swc.ts#L14-L67
// Reason: tsup does not provide a way to modify 'jsc' config
plugin.setup = (build) => {
// Force esbuild to keep class names as well
build.initialOptions.keepNames = true;
build.onLoad({ filter: /\.[jt]sx?$/ }, async (args: any) => {
const isTs = /\.tsx?$/.test(args.path);
const jsc: JscConfig = {
parser: {
syntax: isTs ? "typescript" : "ecmascript",
decorators: true,
},
transform: {
legacyDecorator: true,
decoratorMetadata: true,
},
baseUrl: path.resolve(__dirname, tsConfig.compilerOptions.baseUrl || "."),
paths: tsConfig.compilerOptions.paths,
keepClassNames: true,
preserveAllComments: true,
target: (tsConfig.compilerOptions.target || "es2022").toLowerCase() as JscTarget,
};
const result = await swc.transformFile(args.path, {
jsc,
sourceMaps: true,
configFile: false,
swcrc: false,
});
let code = result.code;
if (result.map) {
const map: { sources: string[] } = JSON.parse(result.map);
// Make sure sources are relative path
map.sources = map.sources.map((source) => {
return path.isAbsolute(source)
? path.relative(path.dirname(args.path), source)
: source;
});
code += `//# sourceMappingURL=data:application/json;base64,${Buffer.from(
JSON.stringify(map),
).toString("base64")}`;
}
return {
contents: code,
};
});
};
}
},
},
],
treeshake: true,
shims: true,
skipNodeModulesBundle: true,
legacyOutput: false,
bundle: false,
splitting: false,
silent: false,
clean: true,
define: {
__LIBRARY_VERSION: JSON.stringify(packageJson.version),
},
});