@workleap/swc-configs 2.2.3 → 2.2.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +22 -10
- package/README.md +2 -2
- package/dist/applyTransformers.d.ts +4 -7
- package/dist/applyTransformers.js +47 -4
- package/dist/applyTransformers.js.map +1 -0
- package/dist/applyTransformers.mjs +9 -1
- package/dist/applyTransformers.mjs.map +1 -0
- package/dist/browserslistToSwc.d.ts +4 -7
- package/dist/browserslistToSwc.js +187 -67
- package/dist/browserslistToSwc.js.map +1 -0
- package/dist/browserslistToSwc.mjs +140 -1
- package/dist/browserslistToSwc.mjs.map +1 -0
- package/dist/build.d.ts +6 -9
- package/dist/build.js +94 -53
- package/dist/build.js.map +1 -0
- package/dist/build.mjs +54 -2
- package/dist/build.mjs.map +1 -0
- package/dist/dev.d.ts +6 -9
- package/dist/dev.js +92 -52
- package/dist/dev.js.map +1 -0
- package/dist/dev.mjs +52 -2
- package/dist/dev.mjs.map +1 -0
- package/dist/index.d.ts +7 -7
- package/dist/index.js +120 -222
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +13 -5
- package/dist/index.mjs.map +1 -0
- package/dist/jest.d.ts +6 -9
- package/dist/jest.js +84 -44
- package/dist/jest.js.map +1 -0
- package/dist/jest.mjs +44 -2
- package/dist/jest.mjs.map +1 -0
- package/package.json +24 -24
- package/src/applyTransformers.ts +11 -0
- package/src/browserslistToSwc.ts +155 -0
- package/src/build.ts +64 -0
- package/src/dev.ts +64 -0
- package/src/index.ts +9 -0
- package/src/jest.ts +58 -0
- package/dist/applyTransformers.d.mts +0 -9
- package/dist/browserslistToSwc.d.mts +0 -9
- package/dist/build.d.mts +0 -12
- package/dist/chunk-3UBBOKDF.mjs +0 -6
- package/dist/chunk-G3VHSALI.mjs +0 -53
- package/dist/chunk-JXCM6TQ3.mjs +0 -45
- package/dist/chunk-MGMFB3UY.mjs +0 -73
- package/dist/chunk-OLWWFWTT.mjs +0 -54
- package/dist/dev.d.mts +0 -13
- package/dist/index.d.mts +0 -7
- package/dist/jest.d.mts +0 -13
|
@@ -1 +1,140 @@
|
|
|
1
|
-
|
|
1
|
+
import * as __WEBPACK_EXTERNAL_MODULE_browserslist__ from "browserslist";
|
|
2
|
+
|
|
3
|
+
;// CONCATENATED MODULE: external "browserslist"
|
|
4
|
+
|
|
5
|
+
;// CONCATENATED MODULE: ./src/browserslistToSwc.ts?__rslib_entry__
|
|
6
|
+
// Inspired by https://github.com/marcofugaro/browserslist-to-esbuild/blob/main/src/index.js.
|
|
7
|
+
//
|
|
8
|
+
// This function exist because browserslist-rs (which is used under the hood by SWC) doesn't support browserslist "extends" syntax: https://github.com/browserslist/browserslist-rs#limitations.
|
|
9
|
+
// Therefore, we must parse ourself the ".browserslistrc" file to extract the browser entries and transform them into valid SWC "env.targets".
|
|
10
|
+
//
|
|
11
|
+
// The function will convert an array of browserslist entries from:
|
|
12
|
+
//
|
|
13
|
+
// ['and_chr 115', 'and_ff 115', 'and_qq 13.1',
|
|
14
|
+
// 'and_uc 15.5', 'android 115', 'baidu 13.18',
|
|
15
|
+
// 'bb 10', 'bb 7', 'chrome 116',
|
|
16
|
+
// 'chrome 115', 'chrome 114', 'chrome 113',
|
|
17
|
+
// 'chrome 112', 'chrome 111', 'chrome 110',
|
|
18
|
+
// 'chrome 109', 'chrome 108', 'chrome 107',
|
|
19
|
+
// 'edge 115', 'edge 114', 'edge 113',
|
|
20
|
+
// 'edge 112', 'edge 111', 'edge 110',
|
|
21
|
+
// 'edge 109', 'edge 108', 'edge 107',
|
|
22
|
+
// 'edge 106', 'firefox 116', 'firefox 115',
|
|
23
|
+
// 'firefox 114', 'firefox 113', 'firefox 112',
|
|
24
|
+
// 'firefox 111', 'firefox 110', 'firefox 109',
|
|
25
|
+
// 'firefox 108', 'firefox 107', 'ie 11',
|
|
26
|
+
// 'ie 10', 'ie 9', 'ie 8',
|
|
27
|
+
// 'ie 7', 'ie 6', 'ie 5.5',
|
|
28
|
+
// 'ie_mob 11', 'ie_mob 10', 'ios_saf 16.5',
|
|
29
|
+
// 'ios_saf 16.4', 'ios_saf 16.3', 'ios_saf 16.2',
|
|
30
|
+
// 'ios_saf 16.1', 'ios_saf 16.0', 'ios_saf 15.6-15.7',
|
|
31
|
+
// 'ios_saf 15.5', 'ios_saf 15.4', 'ios_saf 15.2-15.3',
|
|
32
|
+
// 'kaios 3.0-3.1', 'kaios 2.5', 'op_mini all',
|
|
33
|
+
// 'op_mob 73', 'opera 101', 'opera 100',
|
|
34
|
+
// 'opera 99', 'opera 98', 'opera 97',
|
|
35
|
+
// 'opera 96', 'opera 95', 'opera 94',
|
|
36
|
+
// 'opera 93', 'opera 92', 'safari 16.5',
|
|
37
|
+
// 'safari 16.4', 'safari 16.3', 'safari 16.2',
|
|
38
|
+
// 'safari 16.1', 'safari 16.0', 'safari 15.6',
|
|
39
|
+
// 'safari 15.5', 'safari 15.4', 'safari 15.2-15.3',
|
|
40
|
+
// 'samsung 21', 'samsung 20', 'samsung 19.0',
|
|
41
|
+
// 'samsung 18.0', 'samsung 17.0', 'samsung 16.0',
|
|
42
|
+
// 'samsung 15.0', 'samsung 14.0', 'samsung 13.0',
|
|
43
|
+
// 'samsung 12.0']
|
|
44
|
+
//
|
|
45
|
+
// To an object literal of SWC "env.targets":
|
|
46
|
+
//
|
|
47
|
+
// {
|
|
48
|
+
// chrome: '107',
|
|
49
|
+
// firefox: '107',
|
|
50
|
+
// android: '115',
|
|
51
|
+
// edge: '106',
|
|
52
|
+
// ie: '5.5',
|
|
53
|
+
// opera: '73',
|
|
54
|
+
// safari: '15.2',
|
|
55
|
+
// samsung: '12'
|
|
56
|
+
// }
|
|
57
|
+
|
|
58
|
+
// Original browserslist-rs supported browsers (https://github.com/browserslist/browserslist-rs/blob/99a3244fc8c0e631a80a9cae5c41dca6c5a2aae5/build.rs#L10)
|
|
59
|
+
// minus the browsers that are discarted by SWC (https://github.com/swc-project/swc/blob/main/crates/preset_env_base/src/lib.rs#L105).
|
|
60
|
+
const SwcSupportedBrowsers = [
|
|
61
|
+
"ie",
|
|
62
|
+
"edge",
|
|
63
|
+
"firefox",
|
|
64
|
+
"chrome",
|
|
65
|
+
"safari",
|
|
66
|
+
"opera",
|
|
67
|
+
"ios",
|
|
68
|
+
"android",
|
|
69
|
+
"op_mob",
|
|
70
|
+
"and_chr",
|
|
71
|
+
"and_ff",
|
|
72
|
+
"ie_mob",
|
|
73
|
+
"samsung"
|
|
74
|
+
];
|
|
75
|
+
// SWC browsers aliases (https://github.com/swc-project/swc/blob/main/crates/preset_env_base/src/lib.rs#L90).
|
|
76
|
+
const SwcMobileBrowserAliases = {
|
|
77
|
+
"and_chr": "chrome",
|
|
78
|
+
"and_ff": "firefox",
|
|
79
|
+
"ie_mob": "ie",
|
|
80
|
+
"ios_saf": "ios",
|
|
81
|
+
"op_mob": "opera"
|
|
82
|
+
};
|
|
83
|
+
function parseBrowserslistEntry(entry) {
|
|
84
|
+
// "chrome 11" --> ["chrome", "11"]
|
|
85
|
+
const values = entry.split(" ");
|
|
86
|
+
let browser = values[0];
|
|
87
|
+
let version = values[1];
|
|
88
|
+
// "and_chr" --> "chrome"
|
|
89
|
+
if (SwcMobileBrowserAliases[browser]) {
|
|
90
|
+
browser = SwcMobileBrowserAliases[browser];
|
|
91
|
+
}
|
|
92
|
+
// "11.0-12.0" --> "11.0"
|
|
93
|
+
if (version.includes("-")) {
|
|
94
|
+
version = version.slice(0, version.indexOf("-"));
|
|
95
|
+
}
|
|
96
|
+
// "11.0" --> "11"
|
|
97
|
+
if (version.endsWith(".0")) {
|
|
98
|
+
version = version.slice(0, -2);
|
|
99
|
+
}
|
|
100
|
+
return {
|
|
101
|
+
browser,
|
|
102
|
+
version
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
function createSwcTargetsFromBrowserslistEntries(entries) {
|
|
106
|
+
return entries.reduce((acc, x)=>{
|
|
107
|
+
const { browser, version } = parseBrowserslistEntry(x);
|
|
108
|
+
// Exclude browsers that are not supported by SWC.
|
|
109
|
+
if (SwcSupportedBrowsers.indexOf(browser) === -1) {
|
|
110
|
+
return acc;
|
|
111
|
+
}
|
|
112
|
+
// Let's make TS happy as we are now certain that the browser is part
|
|
113
|
+
// of the supported browsers list.
|
|
114
|
+
const _browser = browser;
|
|
115
|
+
// SWC "env.targets" only support a single entry per target (browser).
|
|
116
|
+
// Therefore, we loop through the browser versions to keep only the oldest one.
|
|
117
|
+
if (acc[_browser]) {
|
|
118
|
+
if (parseFloat(acc[_browser]) > parseFloat(version)) {
|
|
119
|
+
acc[_browser] = version;
|
|
120
|
+
}
|
|
121
|
+
} else {
|
|
122
|
+
acc[_browser] = version;
|
|
123
|
+
}
|
|
124
|
+
return acc;
|
|
125
|
+
}, {});
|
|
126
|
+
}
|
|
127
|
+
function browserslistToSwc(options = {}) {
|
|
128
|
+
const { queries, ...browserlistsOptions } = options;
|
|
129
|
+
// Will return the entries matching the "queries" prop when provided, otherwise,
|
|
130
|
+
// the function will load the closest ".browserslistrc" file.
|
|
131
|
+
const entries = (0,__WEBPACK_EXTERNAL_MODULE_browserslist__["default"])(queries, {
|
|
132
|
+
path: "./browserslistrc",
|
|
133
|
+
...browserlistsOptions
|
|
134
|
+
});
|
|
135
|
+
return createSwcTargetsFromBrowserslistEntries(entries);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
export { browserslistToSwc, createSwcTargetsFromBrowserslistEntries };
|
|
139
|
+
|
|
140
|
+
//# sourceMappingURL=browserslistToSwc.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"browserslistToSwc.mjs","sources":["webpack://@workleap/swc-configs/./src/browserslistToSwc.ts"],"sourcesContent":["// Inspired by https://github.com/marcofugaro/browserslist-to-esbuild/blob/main/src/index.js.\n//\n// This function exist because browserslist-rs (which is used under the hood by SWC) doesn't support browserslist \"extends\" syntax: https://github.com/browserslist/browserslist-rs#limitations.\n// Therefore, we must parse ourself the \".browserslistrc\" file to extract the browser entries and transform them into valid SWC \"env.targets\".\n//\n// The function will convert an array of browserslist entries from:\n//\n// ['and_chr 115', 'and_ff 115', 'and_qq 13.1',\n// 'and_uc 15.5', 'android 115', 'baidu 13.18',\n// 'bb 10', 'bb 7', 'chrome 116',\n// 'chrome 115', 'chrome 114', 'chrome 113',\n// 'chrome 112', 'chrome 111', 'chrome 110',\n// 'chrome 109', 'chrome 108', 'chrome 107',\n// 'edge 115', 'edge 114', 'edge 113',\n// 'edge 112', 'edge 111', 'edge 110',\n// 'edge 109', 'edge 108', 'edge 107',\n// 'edge 106', 'firefox 116', 'firefox 115',\n// 'firefox 114', 'firefox 113', 'firefox 112',\n// 'firefox 111', 'firefox 110', 'firefox 109',\n// 'firefox 108', 'firefox 107', 'ie 11',\n// 'ie 10', 'ie 9', 'ie 8',\n// 'ie 7', 'ie 6', 'ie 5.5',\n// 'ie_mob 11', 'ie_mob 10', 'ios_saf 16.5',\n// 'ios_saf 16.4', 'ios_saf 16.3', 'ios_saf 16.2',\n// 'ios_saf 16.1', 'ios_saf 16.0', 'ios_saf 15.6-15.7',\n// 'ios_saf 15.5', 'ios_saf 15.4', 'ios_saf 15.2-15.3',\n// 'kaios 3.0-3.1', 'kaios 2.5', 'op_mini all',\n// 'op_mob 73', 'opera 101', 'opera 100',\n// 'opera 99', 'opera 98', 'opera 97',\n// 'opera 96', 'opera 95', 'opera 94',\n// 'opera 93', 'opera 92', 'safari 16.5',\n// 'safari 16.4', 'safari 16.3', 'safari 16.2',\n// 'safari 16.1', 'safari 16.0', 'safari 15.6',\n// 'safari 15.5', 'safari 15.4', 'safari 15.2-15.3',\n// 'samsung 21', 'samsung 20', 'samsung 19.0',\n// 'samsung 18.0', 'samsung 17.0', 'samsung 16.0',\n// 'samsung 15.0', 'samsung 14.0', 'samsung 13.0',\n// 'samsung 12.0']\n//\n// To an object literal of SWC \"env.targets\":\n//\n// {\n// chrome: '107',\n// firefox: '107',\n// android: '115',\n// edge: '106',\n// ie: '5.5',\n// opera: '73',\n// safari: '15.2',\n// samsung: '12'\n// }\n\nimport browserslist from \"browserslist\";\n\n// Original browserslist-rs supported browsers (https://github.com/browserslist/browserslist-rs/blob/99a3244fc8c0e631a80a9cae5c41dca6c5a2aae5/build.rs#L10)\n// minus the browsers that are discarted by SWC (https://github.com/swc-project/swc/blob/main/crates/preset_env_base/src/lib.rs#L105).\nconst SwcSupportedBrowsers = [\n \"ie\",\n \"edge\",\n \"firefox\",\n \"chrome\",\n \"safari\",\n \"opera\",\n \"ios\",\n \"android\",\n \"op_mob\",\n \"and_chr\",\n \"and_ff\",\n \"ie_mob\",\n \"samsung\"\n] as const;\n\n// SWC browsers aliases (https://github.com/swc-project/swc/blob/main/crates/preset_env_base/src/lib.rs#L90).\nconst SwcMobileBrowserAliases: Record<string, string> = {\n \"and_chr\": \"chrome\",\n \"and_ff\": \"firefox\",\n \"ie_mob\": \"ie\",\n \"ios_saf\": \"ios\",\n \"op_mob\": \"opera\"\n};\n\nfunction parseBrowserslistEntry(entry: string) {\n // \"chrome 11\" --> [\"chrome\", \"11\"]\n const values = entry.split(\" \");\n\n let browser = values[0];\n let version = values[1];\n\n // \"and_chr\" --> \"chrome\"\n if (SwcMobileBrowserAliases[browser]) {\n browser = SwcMobileBrowserAliases[browser];\n }\n\n // \"11.0-12.0\" --> \"11.0\"\n if (version.includes(\"-\")) {\n version = version.slice(0, version.indexOf(\"-\"));\n }\n\n // \"11.0\" --> \"11\"\n if (version.endsWith(\".0\")) {\n version = version.slice(0, -2);\n }\n\n return {\n browser,\n version\n };\n}\n\nexport function createSwcTargetsFromBrowserslistEntries(entries: string[]) {\n return entries.reduce((acc, x: string) => {\n const { browser, version } = parseBrowserslistEntry(x);\n\n // Exclude browsers that are not supported by SWC.\n if (((SwcSupportedBrowsers as unknown) as string[]).indexOf(browser) === -1) {\n return acc;\n }\n\n // Let's make TS happy as we are now certain that the browser is part\n // of the supported browsers list.\n const _browser = browser as keyof typeof SwcSupportedBrowsers;\n\n // SWC \"env.targets\" only support a single entry per target (browser).\n // Therefore, we loop through the browser versions to keep only the oldest one.\n if (acc[_browser]) {\n if (parseFloat(acc[_browser]) > parseFloat(version)) {\n acc[_browser] = version;\n }\n } else {\n acc[_browser] = version;\n }\n\n return acc;\n }, {} as Record<keyof typeof SwcSupportedBrowsers, string>);\n}\n\nexport interface BrowserslistToSwcOptions extends Omit<browserslist.Options, \"path\"> {\n queries?: string | string[];\n}\n\nexport function browserslistToSwc(options: BrowserslistToSwcOptions = {}) {\n const {\n queries,\n ...browserlistsOptions\n } = options;\n\n // Will return the entries matching the \"queries\" prop when provided, otherwise,\n // the function will load the closest \".browserslistrc\" file.\n const entries = browserslist(queries, {\n path: \"./browserslistrc\",\n ...browserlistsOptions\n });\n\n return createSwcTargetsFromBrowserslistEntries(entries);\n}\n"],"names":["browserslist","SwcSupportedBrowsers","SwcMobileBrowserAliases","parseBrowserslistEntry","entry","values","browser","version","createSwcTargetsFromBrowserslistEntries","entries","acc","x","_browser","parseFloat","browserslistToSwc","options","queries","browserlistsOptions"],"mappings":";;;;;AAAA,6FAA6F;AAC7F,EAAE;AACF,gMAAgM;AAChM,8IAA8I;AAC9I,EAAE;AACF,mEAAmE;AACnE,EAAE;AACF,mDAAmD;AACnD,kDAAkD;AAClD,iDAAiD;AACjD,iDAAiD;AACjD,iDAAiD;AACjD,iDAAiD;AACjD,+CAA+C;AAC/C,+CAA+C;AAC/C,+CAA+C;AAC/C,kDAAkD;AAClD,kDAAkD;AAClD,kDAAkD;AAClD,4CAA4C;AAC5C,2CAA2C;AAC3C,6CAA6C;AAC7C,mDAAmD;AACnD,mDAAmD;AACnD,wDAAwD;AACxD,wDAAwD;AACxD,kDAAkD;AAClD,gDAAgD;AAChD,+CAA+C;AAC/C,+CAA+C;AAC/C,kDAAkD;AAClD,kDAAkD;AAClD,kDAAkD;AAClD,uDAAuD;AACvD,mDAAmD;AACnD,mDAAmD;AACnD,mDAAmD;AACnD,kBAAkB;AAClB,EAAE;AACF,6CAA6C;AAC7C,EAAE;AACF,IAAI;AACJ,kBAAkB;AAClB,mBAAmB;AACnB,mBAAmB;AACnB,gBAAgB;AAChB,cAAc;AACd,gBAAgB;AAChB,mBAAmB;AACnB,iBAAiB;AACjB,IAAI;AAEoC;AAExC,2JAA2J;AAC3J,sIAAsI;AACtI,MAAMC,uBAAuB;IACzB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACH;AAED,6GAA6G;AAC7G,MAAMC,0BAAkD;IACpD,WAAW;IACX,UAAU;IACV,UAAU;IACV,WAAW;IACX,UAAU;AACd;AAEA,SAASC,uBAAuBC,KAAa;IACzC,mCAAmC;IACnC,MAAMC,SAASD,MAAM,KAAK,CAAC;IAE3B,IAAIE,UAAUD,MAAM,CAAC,EAAE;IACvB,IAAIE,UAAUF,MAAM,CAAC,EAAE;IAEvB,yBAAyB;IACzB,IAAIH,uBAAuB,CAACI,QAAQ,EAAE;QAClCA,UAAUJ,uBAAuB,CAACI,QAAQ;IAC9C;IAEA,yBAAyB;IACzB,IAAIC,QAAQ,QAAQ,CAAC,MAAM;QACvBA,UAAUA,QAAQ,KAAK,CAAC,GAAGA,QAAQ,OAAO,CAAC;IAC/C;IAEA,kBAAkB;IAClB,IAAIA,QAAQ,QAAQ,CAAC,OAAO;QACxBA,UAAUA,QAAQ,KAAK,CAAC,GAAG,CAAC;IAChC;IAEA,OAAO;QACHD;QACAC;IACJ;AACJ;AAEO,SAASC,wCAAwCC,OAAiB;IACrE,OAAOA,QAAQ,MAAM,CAAC,CAACC,KAAKC;QACxB,MAAM,EAAEL,OAAO,EAAEC,OAAO,EAAE,GAAGJ,uBAAuBQ;QAEpD,kDAAkD;QAClD,IAAMV,qBAA8C,OAAO,CAACK,aAAa,CAAC,GAAG;YACzE,OAAOI;QACX;QAEA,qEAAqE;QACrE,kCAAkC;QAClC,MAAME,WAAWN;QAEjB,sEAAsE;QACtE,+EAA+E;QAC/E,IAAII,GAAG,CAACE,SAAS,EAAE;YACf,IAAIC,WAAWH,GAAG,CAACE,SAAS,IAAIC,WAAWN,UAAU;gBACjDG,GAAG,CAACE,SAAS,GAAGL;YACpB;QACJ,OAAO;YACHG,GAAG,CAACE,SAAS,GAAGL;QACpB;QAEA,OAAOG;IACX,GAAG,CAAC;AACR;AAMO,SAASI,kBAAkBC,UAAoC,CAAC,CAAC;IACpE,MAAM,EACFC,OAAO,EACP,GAAGC,qBACN,GAAGF;IAEJ,gFAAgF;IAChF,6DAA6D;IAC7D,MAAMN,UAAUT,uDAAYA,CAACgB,SAAS;QAClC,MAAM;QACN,GAAGC,mBAAmB;IAC1B;IAEA,OAAOT,wCAAwCC;AACnD"}
|
package/dist/build.d.ts
CHANGED
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
import { Config } from
|
|
2
|
-
import { SwcConfigTransformer } from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
baseUrl?: NonNullable<Config["jsc"]>["baseUrl"];
|
|
1
|
+
import type { Config as SwcConfig } from "@swc/core";
|
|
2
|
+
import { type SwcConfigTransformer } from "./applyTransformers.ts";
|
|
3
|
+
export interface DefineBuildConfigOptions {
|
|
4
|
+
baseUrl?: NonNullable<SwcConfig["jsc"]>["baseUrl"];
|
|
6
5
|
parser?: "ecmascript" | "typescript";
|
|
7
|
-
paths?: NonNullable<
|
|
6
|
+
paths?: NonNullable<SwcConfig["jsc"]>["paths"];
|
|
8
7
|
transformers?: SwcConfigTransformer[];
|
|
9
8
|
}
|
|
10
|
-
declare function defineBuildConfig(targets: Record<string, string>, options?: DefineBuildConfigOptions):
|
|
11
|
-
|
|
12
|
-
export { type DefineBuildConfigOptions, defineBuildConfig };
|
|
9
|
+
export declare function defineBuildConfig(targets: Record<string, string>, options?: DefineBuildConfigOptions): SwcConfig;
|
package/dist/build.js
CHANGED
|
@@ -1,59 +1,100 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
const __rslib_import_meta_url__ = /*#__PURE__*/ (function () {
|
|
3
|
+
return typeof document === 'undefined'
|
|
4
|
+
? new (require('url'.replace('', '')).URL)('file:' + __filename).href
|
|
5
|
+
: (document.currentScript && document.currentScript.src) ||
|
|
6
|
+
new URL('main.js', document.baseURI).href;
|
|
7
|
+
})();
|
|
8
|
+
;
|
|
9
|
+
// The require scope
|
|
10
|
+
var __webpack_require__ = {};
|
|
2
11
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
12
|
+
/************************************************************************/
|
|
13
|
+
// webpack/runtime/define_property_getters
|
|
14
|
+
(() => {
|
|
15
|
+
__webpack_require__.d = (exports, definition) => {
|
|
16
|
+
for(var key in definition) {
|
|
17
|
+
if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
18
|
+
Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
})();
|
|
23
|
+
// webpack/runtime/has_own_property
|
|
24
|
+
(() => {
|
|
25
|
+
__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
26
|
+
})();
|
|
27
|
+
// webpack/runtime/make_namespace_object
|
|
28
|
+
(() => {
|
|
29
|
+
// define __esModule on exports
|
|
30
|
+
__webpack_require__.r = (exports) => {
|
|
31
|
+
if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
32
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
33
|
+
}
|
|
34
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
35
|
+
};
|
|
36
|
+
})();
|
|
37
|
+
/************************************************************************/
|
|
38
|
+
var __webpack_exports__ = {};
|
|
39
|
+
// ESM COMPAT FLAG
|
|
40
|
+
__webpack_require__.r(__webpack_exports__);
|
|
41
|
+
|
|
42
|
+
// EXPORTS
|
|
43
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
44
|
+
defineBuildConfig: () => (/* binding */ defineBuildConfig)
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
;// CONCATENATED MODULE: external "./applyTransformers.js"
|
|
48
|
+
const external_applyTransformers_js_namespaceObject = require("./applyTransformers.js");
|
|
49
|
+
;// CONCATENATED MODULE: ./src/build.ts?__rslib_entry__
|
|
7
50
|
|
|
8
|
-
// src/build.ts
|
|
9
51
|
function defineBuildConfig(targets, options = {}) {
|
|
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
|
-
|
|
52
|
+
const { baseUrl, parser = "typescript", paths, transformers = [] } = options;
|
|
53
|
+
const config = {
|
|
54
|
+
jsc: {
|
|
55
|
+
baseUrl,
|
|
56
|
+
paths,
|
|
57
|
+
parser: parser === "ecmascript" ? {
|
|
58
|
+
syntax: "ecmascript",
|
|
59
|
+
jsx: true
|
|
60
|
+
} : {
|
|
61
|
+
syntax: "typescript",
|
|
62
|
+
tsx: true
|
|
63
|
+
},
|
|
64
|
+
// View https://swc.rs/docs/configuration/minification for options.
|
|
65
|
+
minify: {
|
|
66
|
+
compress: true,
|
|
67
|
+
mangle: true
|
|
68
|
+
},
|
|
69
|
+
transform: {
|
|
70
|
+
react: {
|
|
71
|
+
// Use "react/jsx-runtime".
|
|
72
|
+
runtime: "automatic",
|
|
73
|
+
// Use the native "Object.assign()" instead of "_extends".
|
|
74
|
+
useBuiltins: true
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
// Import shims from an external module rather than inlining them in bundle files to greatly reduce the bundles size.
|
|
78
|
+
// Requires to add "@swc/helpers" as a project dependency.
|
|
79
|
+
externalHelpers: true
|
|
80
|
+
},
|
|
81
|
+
module: {
|
|
82
|
+
// The output module resolution system that the code will be compiled for.
|
|
83
|
+
type: "es6"
|
|
84
|
+
},
|
|
85
|
+
env: {
|
|
86
|
+
// jsc.target is not provided because the provided targets takes precedence.
|
|
87
|
+
targets
|
|
38
88
|
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
module: {
|
|
45
|
-
// The output module resolution system that the code will be compiled for.
|
|
46
|
-
type: "es6"
|
|
47
|
-
},
|
|
48
|
-
env: {
|
|
49
|
-
// jsc.target is not provided because the provided targets takes precedence.
|
|
50
|
-
targets
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
const transformedConfig = applyTransformers(config, transformers, {
|
|
54
|
-
environment: "build"
|
|
55
|
-
});
|
|
56
|
-
return transformedConfig;
|
|
89
|
+
};
|
|
90
|
+
const transformedConfig = (0,external_applyTransformers_js_namespaceObject.applyTransformers)(config, transformers, {
|
|
91
|
+
environment: "build"
|
|
92
|
+
});
|
|
93
|
+
return transformedConfig;
|
|
57
94
|
}
|
|
58
95
|
|
|
59
|
-
|
|
96
|
+
var __webpack_export_target__ = exports;
|
|
97
|
+
for(var __webpack_i__ in __webpack_exports__) __webpack_export_target__[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
98
|
+
if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, '__esModule', { value: true });
|
|
99
|
+
|
|
100
|
+
//# sourceMappingURL=build.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.js","sources":["webpack://@workleap/swc-configs/./src/build.ts"],"sourcesContent":["import type { Config as SwcConfig } from \"@swc/core\";\nimport { applyTransformers, type SwcConfigTransformer } from \"./applyTransformers.ts\";\n\nexport interface DefineBuildConfigOptions {\n baseUrl?: NonNullable<SwcConfig[\"jsc\"]>[\"baseUrl\"];\n parser?: \"ecmascript\" | \"typescript\";\n paths?: NonNullable<SwcConfig[\"jsc\"]>[\"paths\"];\n transformers?: SwcConfigTransformer[];\n}\n\nexport function defineBuildConfig(targets: Record<string, string>, options: DefineBuildConfigOptions = {}) {\n const {\n baseUrl,\n parser = \"typescript\",\n paths,\n transformers = []\n } = options;\n\n const config: SwcConfig = {\n jsc: {\n baseUrl,\n paths,\n parser: parser === \"ecmascript\"\n ? {\n syntax: \"ecmascript\",\n jsx: true\n }\n : {\n syntax: \"typescript\",\n tsx: true\n },\n // View https://swc.rs/docs/configuration/minification for options.\n minify: {\n compress: true,\n mangle: true\n },\n transform: {\n react: {\n // Use \"react/jsx-runtime\".\n runtime: \"automatic\",\n // Use the native \"Object.assign()\" instead of \"_extends\".\n useBuiltins: true\n }\n },\n // Import shims from an external module rather than inlining them in bundle files to greatly reduce the bundles size.\n // Requires to add \"@swc/helpers\" as a project dependency.\n externalHelpers: true\n },\n module: {\n // The output module resolution system that the code will be compiled for.\n type: \"es6\"\n },\n env: {\n // jsc.target is not provided because the provided targets takes precedence.\n targets\n }\n };\n\n const transformedConfig = applyTransformers(config, transformers, {\n environment: \"build\"\n });\n\n return transformedConfig;\n}\n"],"names":["applyTransformers","defineBuildConfig","targets","options","baseUrl","parser","paths","transformers","config","transformedConfig"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACsF;AAS/E,SAASC,kBAAkBC,OAA+B,EAAEC,UAAoC,CAAC,CAAC;IACrG,MAAM,EACFC,OAAO,EACPC,SAAS,YAAY,EACrBC,KAAK,EACLC,eAAe,EAAE,EACpB,GAAGJ;IAEJ,MAAMK,SAAoB;QACtB,KAAK;YACDJ;YACAE;YACA,QAAQD,WAAW,eACb;gBACE,QAAQ;gBACR,KAAK;YACT,IACE;gBACE,QAAQ;gBACR,KAAK;YACT;YACJ,mEAAmE;YACnE,QAAQ;gBACJ,UAAU;gBACV,QAAQ;YACZ;YACA,WAAW;gBACP,OAAO;oBACH,2BAA2B;oBAC3B,SAAS;oBACT,0DAA0D;oBAC1D,aAAa;gBACjB;YACJ;YACA,qHAAqH;YACrH,0DAA0D;YAC1D,iBAAiB;QACrB;QACA,QAAQ;YACJ,0EAA0E;YAC1E,MAAM;QACV;QACA,KAAK;YACD,4EAA4E;YAC5EH;QACJ;IACJ;IAEA,MAAMO,oBAAoBT,mEAAiBA,CAACQ,QAAQD,cAAc;QAC9D,aAAa;IACjB;IAEA,OAAOE;AACX"}
|
package/dist/build.mjs
CHANGED
|
@@ -1,2 +1,54 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import * as __WEBPACK_EXTERNAL_MODULE__applyTransformers_mjs_b5d980dd__ from "./applyTransformers.mjs";
|
|
2
|
+
|
|
3
|
+
;// CONCATENATED MODULE: external "./applyTransformers.mjs"
|
|
4
|
+
|
|
5
|
+
;// CONCATENATED MODULE: ./src/build.ts?__rslib_entry__
|
|
6
|
+
|
|
7
|
+
function defineBuildConfig(targets, options = {}) {
|
|
8
|
+
const { baseUrl, parser = "typescript", paths, transformers = [] } = options;
|
|
9
|
+
const config = {
|
|
10
|
+
jsc: {
|
|
11
|
+
baseUrl,
|
|
12
|
+
paths,
|
|
13
|
+
parser: parser === "ecmascript" ? {
|
|
14
|
+
syntax: "ecmascript",
|
|
15
|
+
jsx: true
|
|
16
|
+
} : {
|
|
17
|
+
syntax: "typescript",
|
|
18
|
+
tsx: true
|
|
19
|
+
},
|
|
20
|
+
// View https://swc.rs/docs/configuration/minification for options.
|
|
21
|
+
minify: {
|
|
22
|
+
compress: true,
|
|
23
|
+
mangle: true
|
|
24
|
+
},
|
|
25
|
+
transform: {
|
|
26
|
+
react: {
|
|
27
|
+
// Use "react/jsx-runtime".
|
|
28
|
+
runtime: "automatic",
|
|
29
|
+
// Use the native "Object.assign()" instead of "_extends".
|
|
30
|
+
useBuiltins: true
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
// Import shims from an external module rather than inlining them in bundle files to greatly reduce the bundles size.
|
|
34
|
+
// Requires to add "@swc/helpers" as a project dependency.
|
|
35
|
+
externalHelpers: true
|
|
36
|
+
},
|
|
37
|
+
module: {
|
|
38
|
+
// The output module resolution system that the code will be compiled for.
|
|
39
|
+
type: "es6"
|
|
40
|
+
},
|
|
41
|
+
env: {
|
|
42
|
+
// jsc.target is not provided because the provided targets takes precedence.
|
|
43
|
+
targets
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
const transformedConfig = (0,__WEBPACK_EXTERNAL_MODULE__applyTransformers_mjs_b5d980dd__.applyTransformers)(config, transformers, {
|
|
47
|
+
environment: "build"
|
|
48
|
+
});
|
|
49
|
+
return transformedConfig;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export { defineBuildConfig };
|
|
53
|
+
|
|
54
|
+
//# sourceMappingURL=build.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.mjs","sources":["webpack://@workleap/swc-configs/./src/build.ts"],"sourcesContent":["import type { Config as SwcConfig } from \"@swc/core\";\nimport { applyTransformers, type SwcConfigTransformer } from \"./applyTransformers.ts\";\n\nexport interface DefineBuildConfigOptions {\n baseUrl?: NonNullable<SwcConfig[\"jsc\"]>[\"baseUrl\"];\n parser?: \"ecmascript\" | \"typescript\";\n paths?: NonNullable<SwcConfig[\"jsc\"]>[\"paths\"];\n transformers?: SwcConfigTransformer[];\n}\n\nexport function defineBuildConfig(targets: Record<string, string>, options: DefineBuildConfigOptions = {}) {\n const {\n baseUrl,\n parser = \"typescript\",\n paths,\n transformers = []\n } = options;\n\n const config: SwcConfig = {\n jsc: {\n baseUrl,\n paths,\n parser: parser === \"ecmascript\"\n ? {\n syntax: \"ecmascript\",\n jsx: true\n }\n : {\n syntax: \"typescript\",\n tsx: true\n },\n // View https://swc.rs/docs/configuration/minification for options.\n minify: {\n compress: true,\n mangle: true\n },\n transform: {\n react: {\n // Use \"react/jsx-runtime\".\n runtime: \"automatic\",\n // Use the native \"Object.assign()\" instead of \"_extends\".\n useBuiltins: true\n }\n },\n // Import shims from an external module rather than inlining them in bundle files to greatly reduce the bundles size.\n // Requires to add \"@swc/helpers\" as a project dependency.\n externalHelpers: true\n },\n module: {\n // The output module resolution system that the code will be compiled for.\n type: \"es6\"\n },\n env: {\n // jsc.target is not provided because the provided targets takes precedence.\n targets\n }\n };\n\n const transformedConfig = applyTransformers(config, transformers, {\n environment: \"build\"\n });\n\n return transformedConfig;\n}\n"],"names":["applyTransformers","defineBuildConfig","targets","options","baseUrl","parser","paths","transformers","config","transformedConfig"],"mappings":";;;;;AACsF;AAS/E,SAASC,kBAAkBC,OAA+B,EAAEC,UAAoC,CAAC,CAAC;IACrG,MAAM,EACFC,OAAO,EACPC,SAAS,YAAY,EACrBC,KAAK,EACLC,eAAe,EAAE,EACpB,GAAGJ;IAEJ,MAAMK,SAAoB;QACtB,KAAK;YACDJ;YACAE;YACA,QAAQD,WAAW,eACb;gBACE,QAAQ;gBACR,KAAK;YACT,IACE;gBACE,QAAQ;gBACR,KAAK;YACT;YACJ,mEAAmE;YACnE,QAAQ;gBACJ,UAAU;gBACV,QAAQ;YACZ;YACA,WAAW;gBACP,OAAO;oBACH,2BAA2B;oBAC3B,SAAS;oBACT,0DAA0D;oBAC1D,aAAa;gBACjB;YACJ;YACA,qHAAqH;YACrH,0DAA0D;YAC1D,iBAAiB;QACrB;QACA,QAAQ;YACJ,0EAA0E;YAC1E,MAAM;QACV;QACA,KAAK;YACD,4EAA4E;YAC5EH;QACJ;IACJ;IAEA,MAAMO,oBAAoBT,iFAAiBA,CAACQ,QAAQD,cAAc;QAC9D,aAAa;IACjB;IAEA,OAAOE;AACX"}
|
package/dist/dev.d.ts
CHANGED
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import { Config } from
|
|
2
|
-
import { SwcConfigTransformer } from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
baseUrl?: NonNullable<Config["jsc"]>["baseUrl"];
|
|
1
|
+
import type { Config as SwcConfig } from "@swc/core";
|
|
2
|
+
import { type SwcConfigTransformer } from "./applyTransformers.ts";
|
|
3
|
+
export interface DefineDevConfigOptions {
|
|
4
|
+
baseUrl?: NonNullable<SwcConfig["jsc"]>["baseUrl"];
|
|
6
5
|
fastRefresh?: boolean;
|
|
7
6
|
parser?: "ecmascript" | "typescript";
|
|
8
|
-
paths?: NonNullable<
|
|
7
|
+
paths?: NonNullable<SwcConfig["jsc"]>["paths"];
|
|
9
8
|
transformers?: SwcConfigTransformer[];
|
|
10
9
|
}
|
|
11
|
-
declare function defineDevConfig(targets: Record<string, string>, options?: DefineDevConfigOptions):
|
|
12
|
-
|
|
13
|
-
export { type DefineDevConfigOptions, defineDevConfig };
|
|
10
|
+
export declare function defineDevConfig(targets: Record<string, string>, options?: DefineDevConfigOptions): SwcConfig;
|
package/dist/dev.js
CHANGED
|
@@ -1,58 +1,98 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
const __rslib_import_meta_url__ = /*#__PURE__*/ (function () {
|
|
3
|
+
return typeof document === 'undefined'
|
|
4
|
+
? new (require('url'.replace('', '')).URL)('file:' + __filename).href
|
|
5
|
+
: (document.currentScript && document.currentScript.src) ||
|
|
6
|
+
new URL('main.js', document.baseURI).href;
|
|
7
|
+
})();
|
|
8
|
+
;
|
|
9
|
+
// The require scope
|
|
10
|
+
var __webpack_require__ = {};
|
|
2
11
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
12
|
+
/************************************************************************/
|
|
13
|
+
// webpack/runtime/define_property_getters
|
|
14
|
+
(() => {
|
|
15
|
+
__webpack_require__.d = (exports, definition) => {
|
|
16
|
+
for(var key in definition) {
|
|
17
|
+
if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|
18
|
+
Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
})();
|
|
23
|
+
// webpack/runtime/has_own_property
|
|
24
|
+
(() => {
|
|
25
|
+
__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|
26
|
+
})();
|
|
27
|
+
// webpack/runtime/make_namespace_object
|
|
28
|
+
(() => {
|
|
29
|
+
// define __esModule on exports
|
|
30
|
+
__webpack_require__.r = (exports) => {
|
|
31
|
+
if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
32
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
33
|
+
}
|
|
34
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
35
|
+
};
|
|
36
|
+
})();
|
|
37
|
+
/************************************************************************/
|
|
38
|
+
var __webpack_exports__ = {};
|
|
39
|
+
// ESM COMPAT FLAG
|
|
40
|
+
__webpack_require__.r(__webpack_exports__);
|
|
41
|
+
|
|
42
|
+
// EXPORTS
|
|
43
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
44
|
+
defineDevConfig: () => (/* binding */ defineDevConfig)
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
;// CONCATENATED MODULE: external "./applyTransformers.js"
|
|
48
|
+
const external_applyTransformers_js_namespaceObject = require("./applyTransformers.js");
|
|
49
|
+
;// CONCATENATED MODULE: ./src/dev.ts?__rslib_entry__
|
|
7
50
|
|
|
8
|
-
// src/dev.ts
|
|
9
51
|
function defineDevConfig(targets, options = {}) {
|
|
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
|
-
|
|
52
|
+
const { baseUrl, fastRefresh = true, parser = "typescript", paths, transformers = [] } = options;
|
|
53
|
+
const config = {
|
|
54
|
+
jsc: {
|
|
55
|
+
baseUrl,
|
|
56
|
+
paths,
|
|
57
|
+
parser: parser === "ecmascript" ? {
|
|
58
|
+
syntax: "ecmascript",
|
|
59
|
+
jsx: true
|
|
60
|
+
} : {
|
|
61
|
+
syntax: "typescript",
|
|
62
|
+
tsx: true
|
|
63
|
+
},
|
|
64
|
+
transform: {
|
|
65
|
+
react: {
|
|
66
|
+
// Use "react/jsx-runtime".
|
|
67
|
+
runtime: "automatic",
|
|
68
|
+
// Use the native "Object.assign()" instead of "_extends".
|
|
69
|
+
useBuiltins: true,
|
|
70
|
+
// Enable React experimental "fast-refresh" feature.
|
|
71
|
+
// Also need to install @pmmmwh/react-refresh-webpack-plugin.
|
|
72
|
+
refresh: fastRefresh
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
// Import shims from an external module rather than inlining them in bundle files to greatly reduce the bundles size.
|
|
76
|
+
// Requires to add "@swc/helpers" as a project dependency.
|
|
77
|
+
externalHelpers: true
|
|
78
|
+
},
|
|
79
|
+
module: {
|
|
80
|
+
// The output module resolution system that the code will be compiled for.
|
|
81
|
+
type: "es6"
|
|
82
|
+
},
|
|
83
|
+
env: {
|
|
84
|
+
// jsc.target is not provided because the provided targets takes precedence.
|
|
85
|
+
targets
|
|
37
86
|
}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
module: {
|
|
44
|
-
// The output module resolution system that the code will be compiled for.
|
|
45
|
-
type: "es6"
|
|
46
|
-
},
|
|
47
|
-
env: {
|
|
48
|
-
// jsc.target is not provided because the provided targets takes precedence.
|
|
49
|
-
targets
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
const transformedConfig = applyTransformers(config, transformers, {
|
|
53
|
-
environment: "dev"
|
|
54
|
-
});
|
|
55
|
-
return transformedConfig;
|
|
87
|
+
};
|
|
88
|
+
const transformedConfig = (0,external_applyTransformers_js_namespaceObject.applyTransformers)(config, transformers, {
|
|
89
|
+
environment: "dev"
|
|
90
|
+
});
|
|
91
|
+
return transformedConfig;
|
|
56
92
|
}
|
|
57
93
|
|
|
58
|
-
|
|
94
|
+
var __webpack_export_target__ = exports;
|
|
95
|
+
for(var __webpack_i__ in __webpack_exports__) __webpack_export_target__[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
96
|
+
if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, '__esModule', { value: true });
|
|
97
|
+
|
|
98
|
+
//# sourceMappingURL=dev.js.map
|
package/dist/dev.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dev.js","sources":["webpack://@workleap/swc-configs/./src/dev.ts"],"sourcesContent":["import type { Config as SwcConfig } from \"@swc/core\";\nimport { applyTransformers, type SwcConfigTransformer } from \"./applyTransformers.ts\";\n\nexport interface DefineDevConfigOptions {\n baseUrl?: NonNullable<SwcConfig[\"jsc\"]>[\"baseUrl\"];\n fastRefresh?: boolean;\n parser?: \"ecmascript\" | \"typescript\";\n paths?: NonNullable<SwcConfig[\"jsc\"]>[\"paths\"];\n transformers?: SwcConfigTransformer[];\n}\n\nexport function defineDevConfig(targets: Record<string, string>, options: DefineDevConfigOptions = {}) {\n const {\n baseUrl,\n fastRefresh = true,\n parser = \"typescript\",\n paths,\n transformers = []\n } = options;\n\n const config: SwcConfig = {\n jsc: {\n baseUrl,\n paths,\n parser: parser === \"ecmascript\"\n ? {\n syntax: \"ecmascript\",\n jsx: true\n }\n : {\n syntax: \"typescript\",\n tsx: true\n },\n transform: {\n react: {\n // Use \"react/jsx-runtime\".\n runtime: \"automatic\",\n // Use the native \"Object.assign()\" instead of \"_extends\".\n useBuiltins: true,\n // Enable React experimental \"fast-refresh\" feature.\n // Also need to install @pmmmwh/react-refresh-webpack-plugin.\n refresh: fastRefresh\n }\n },\n // Import shims from an external module rather than inlining them in bundle files to greatly reduce the bundles size.\n // Requires to add \"@swc/helpers\" as a project dependency.\n externalHelpers: true\n },\n module: {\n // The output module resolution system that the code will be compiled for.\n type: \"es6\"\n },\n env: {\n // jsc.target is not provided because the provided targets takes precedence.\n targets\n }\n };\n\n const transformedConfig = applyTransformers(config, transformers, {\n environment: \"dev\"\n });\n\n return transformedConfig;\n}\n"],"names":["applyTransformers","defineDevConfig","targets","options","baseUrl","fastRefresh","parser","paths","transformers","config","transformedConfig"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACsF;AAU/E,SAASC,gBAAgBC,OAA+B,EAAEC,UAAkC,CAAC,CAAC;IACjG,MAAM,EACFC,OAAO,EACPC,cAAc,IAAI,EAClBC,SAAS,YAAY,EACrBC,KAAK,EACLC,eAAe,EAAE,EACpB,GAAGL;IAEJ,MAAMM,SAAoB;QACtB,KAAK;YACDL;YACAG;YACA,QAAQD,WAAW,eACb;gBACE,QAAQ;gBACR,KAAK;YACT,IACE;gBACE,QAAQ;gBACR,KAAK;YACT;YACJ,WAAW;gBACP,OAAO;oBACH,2BAA2B;oBAC3B,SAAS;oBACT,0DAA0D;oBAC1D,aAAa;oBACb,oDAAoD;oBACpD,6DAA6D;oBAC7D,SAASD;gBACb;YACJ;YACA,qHAAqH;YACrH,0DAA0D;YAC1D,iBAAiB;QACrB;QACA,QAAQ;YACJ,0EAA0E;YAC1E,MAAM;QACV;QACA,KAAK;YACD,4EAA4E;YAC5EH;QACJ;IACJ;IAEA,MAAMQ,oBAAoBV,mEAAiBA,CAACS,QAAQD,cAAc;QAC9D,aAAa;IACjB;IAEA,OAAOE;AACX"}
|