@workleap/swc-configs 2.2.3 → 2.2.4

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.
Files changed (49) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/applyTransformers.d.ts +4 -7
  3. package/dist/applyTransformers.js +51 -4
  4. package/dist/applyTransformers.js.map +1 -0
  5. package/dist/applyTransformers.mjs +9 -1
  6. package/dist/applyTransformers.mjs.map +1 -0
  7. package/dist/browserslistToSwc.d.ts +4 -7
  8. package/dist/browserslistToSwc.js +194 -67
  9. package/dist/browserslistToSwc.js.map +1 -0
  10. package/dist/browserslistToSwc.mjs +140 -1
  11. package/dist/browserslistToSwc.mjs.map +1 -0
  12. package/dist/build.d.ts +6 -9
  13. package/dist/build.js +98 -53
  14. package/dist/build.js.map +1 -0
  15. package/dist/build.mjs +54 -2
  16. package/dist/build.mjs.map +1 -0
  17. package/dist/dev.d.ts +6 -9
  18. package/dist/dev.js +96 -52
  19. package/dist/dev.js.map +1 -0
  20. package/dist/dev.mjs +52 -2
  21. package/dist/dev.mjs.map +1 -0
  22. package/dist/index.d.ts +7 -7
  23. package/dist/index.js +127 -222
  24. package/dist/index.js.map +1 -0
  25. package/dist/index.mjs +13 -5
  26. package/dist/index.mjs.map +1 -0
  27. package/dist/jest.d.ts +6 -9
  28. package/dist/jest.js +88 -44
  29. package/dist/jest.js.map +1 -0
  30. package/dist/jest.mjs +44 -2
  31. package/dist/jest.mjs.map +1 -0
  32. package/package.json +24 -22
  33. package/src/applyTransformers.ts +11 -0
  34. package/src/browserslistToSwc.ts +155 -0
  35. package/src/build.ts +64 -0
  36. package/src/dev.ts +64 -0
  37. package/src/index.ts +9 -0
  38. package/src/jest.ts +58 -0
  39. package/dist/applyTransformers.d.mts +0 -9
  40. package/dist/browserslistToSwc.d.mts +0 -9
  41. package/dist/build.d.mts +0 -12
  42. package/dist/chunk-3UBBOKDF.mjs +0 -6
  43. package/dist/chunk-G3VHSALI.mjs +0 -53
  44. package/dist/chunk-JXCM6TQ3.mjs +0 -45
  45. package/dist/chunk-MGMFB3UY.mjs +0 -73
  46. package/dist/chunk-OLWWFWTT.mjs +0 -54
  47. package/dist/dev.d.mts +0 -13
  48. package/dist/index.d.mts +0 -7
  49. package/dist/jest.d.mts +0 -13
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # @workleap/swc-configs
2
2
 
3
+ ## 2.2.4
4
+
5
+ ### Patch Changes
6
+
7
+ - [#230](https://github.com/gsoft-inc/wl-web-configs/pull/230) [`0a4279c`](https://github.com/gsoft-inc/wl-web-configs/commit/0a4279c40b7c2ea76c7e1884a8e2fd744ca9b7c1) Thanks [@patricklafrance](https://github.com/patricklafrance)! - Packages now includes the source codes and sourcemap.
8
+
3
9
  ## 2.2.3
4
10
 
5
11
  ### Patch Changes
@@ -1,9 +1,6 @@
1
- import { Config } from '@swc/core';
2
-
3
- interface SwcConfigTransformerContext {
1
+ import type { Config as SwcConfig } from "@swc/core";
2
+ export interface SwcConfigTransformerContext {
4
3
  environment: "dev" | "build" | "jest";
5
4
  }
6
- type SwcConfigTransformer = (config: Config, context: SwcConfigTransformerContext) => Config;
7
- declare function applyTransformers(config: Config, transformers: SwcConfigTransformer[], context: SwcConfigTransformerContext): Config;
8
-
9
- export { type SwcConfigTransformer, type SwcConfigTransformerContext, applyTransformers };
5
+ export type SwcConfigTransformer = (config: SwcConfig, context: SwcConfigTransformerContext) => SwcConfig;
6
+ export declare function applyTransformers(config: SwcConfig, transformers: SwcConfigTransformer[], context: SwcConfigTransformerContext): SwcConfig;
@@ -1,8 +1,55 @@
1
- 'use strict';
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
- // src/applyTransformers.ts
12
+ /************************************************************************/
13
+ // webpack/runtime/define_property_getters
14
+ (() => {
15
+ __webpack_require__.d = function(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 = function (obj, prop) {
26
+ return Object.prototype.hasOwnProperty.call(obj, prop);
27
+ };
28
+
29
+ })();
30
+ // webpack/runtime/make_namespace_object
31
+ (() => {
32
+ // define __esModule on exports
33
+ __webpack_require__.r = function(exports) {
34
+ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
35
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
36
+ }
37
+ Object.defineProperty(exports, '__esModule', { value: true });
38
+ };
39
+
40
+ })();
41
+ /************************************************************************/
42
+ var __webpack_exports__ = {};
43
+ __webpack_require__.r(__webpack_exports__);
44
+ __webpack_require__.d(__webpack_exports__, {
45
+ applyTransformers: function() { return applyTransformers; }
46
+ });
4
47
  function applyTransformers(config, transformers, context) {
5
- return transformers.reduce((acc, transformer) => transformer(acc, context), config);
48
+ return transformers.reduce((acc, transformer)=>transformer(acc, context), config);
6
49
  }
7
50
 
8
- exports.applyTransformers = applyTransformers;
51
+ var __webpack_export_target__ = exports;
52
+ for(var __webpack_i__ in __webpack_exports__) __webpack_export_target__[__webpack_i__] = __webpack_exports__[__webpack_i__];
53
+ if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, '__esModule', { value: true });
54
+
55
+ //# sourceMappingURL=applyTransformers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"applyTransformers.js","sources":["webpack://@workleap/swc-configs/./src/applyTransformers.ts"],"sourcesContent":["import type { Config as SwcConfig } from \"@swc/core\";\n\nexport interface SwcConfigTransformerContext {\n environment: \"dev\" | \"build\" | \"jest\";\n}\n\nexport type SwcConfigTransformer = (config: SwcConfig, context: SwcConfigTransformerContext) => SwcConfig;\n\nexport function applyTransformers(config: SwcConfig, transformers: SwcConfigTransformer[], context: SwcConfigTransformerContext) {\n return transformers.reduce((acc, transformer) => transformer(acc, context), config);\n}\n"],"names":["applyTransformers","config","transformers","context","acc","transformer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQO,SAASA,kBAAkBC,MAAiB,EAAEC,YAAoC,EAAEC,OAAoC;IAC3H,OAAOD,aAAa,MAAM,CAAC,CAACE,KAAKC,cAAgBA,YAAYD,KAAKD,UAAUF;AAChF"}
@@ -1 +1,9 @@
1
- export { applyTransformers } from './chunk-3UBBOKDF.mjs';
1
+
2
+ ;// CONCATENATED MODULE: ./src/applyTransformers.ts?__rslib_entry__
3
+ function applyTransformers(config, transformers, context) {
4
+ return transformers.reduce((acc, transformer)=>transformer(acc, context), config);
5
+ }
6
+
7
+ export { applyTransformers };
8
+
9
+ //# sourceMappingURL=applyTransformers.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"applyTransformers.mjs","sources":["webpack://@workleap/swc-configs/./src/applyTransformers.ts"],"sourcesContent":["import type { Config as SwcConfig } from \"@swc/core\";\n\nexport interface SwcConfigTransformerContext {\n environment: \"dev\" | \"build\" | \"jest\";\n}\n\nexport type SwcConfigTransformer = (config: SwcConfig, context: SwcConfigTransformerContext) => SwcConfig;\n\nexport function applyTransformers(config: SwcConfig, transformers: SwcConfigTransformer[], context: SwcConfigTransformerContext) {\n return transformers.reduce((acc, transformer) => transformer(acc, context), config);\n}\n"],"names":["applyTransformers","config","transformers","context","acc","transformer"],"mappings":";;AAQO,SAASA,kBAAkBC,MAAiB,EAAEC,YAAoC,EAAEC,OAAoC;IAC3H,OAAOD,aAAa,MAAM,CAAC,CAACE,KAAKC,cAAgBA,YAAYD,KAAKD,UAAUF;AAChF"}
@@ -1,9 +1,6 @@
1
- import browserslist from 'browserslist';
2
-
3
- declare function createSwcTargetsFromBrowserslistEntries(entries: string[]): Record<keyof readonly ["ie", "edge", "firefox", "chrome", "safari", "opera", "ios", "android", "op_mob", "and_chr", "and_ff", "ie_mob", "samsung"], string>;
4
- interface BrowserslistToSwcOptions extends Omit<browserslist.Options, "path"> {
1
+ import browserslist from "browserslist";
2
+ export declare function createSwcTargetsFromBrowserslistEntries(entries: string[]): Record<keyof readonly ["ie", "edge", "firefox", "chrome", "safari", "opera", "ios", "android", "op_mob", "and_chr", "and_ff", "ie_mob", "samsung"], string>;
3
+ export interface BrowserslistToSwcOptions extends Omit<browserslist.Options, "path"> {
5
4
  queries?: string | string[];
6
5
  }
7
- declare function browserslistToSwc(options?: BrowserslistToSwcOptions): Record<keyof readonly ["ie", "edge", "firefox", "chrome", "safari", "opera", "ios", "android", "op_mob", "and_chr", "and_ff", "ie_mob", "samsung"], string>;
8
-
9
- export { type BrowserslistToSwcOptions, browserslistToSwc, createSwcTargetsFromBrowserslistEntries };
6
+ export declare function browserslistToSwc(options?: BrowserslistToSwcOptions): Record<keyof readonly ["ie", "edge", "firefox", "chrome", "safari", "opera", "ios", "android", "op_mob", "and_chr", "and_ff", "ie_mob", "samsung"], string>;
@@ -1,80 +1,207 @@
1
- 'use strict';
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__ = {};
11
+
12
+ /************************************************************************/
13
+ // webpack/runtime/compat_get_default_export
14
+ (() => {
15
+ // getDefaultExport function for compatibility with non-ESM modules
16
+ __webpack_require__.n = function (module) {
17
+ var getter = module && module.__esModule ?
18
+ function () { return module['default']; } :
19
+ function () { return module; };
20
+ __webpack_require__.d(getter, { a: getter });
21
+ return getter;
22
+ };
23
+
2
24
 
3
- var browserslist = require('browserslist');
4
25
 
5
- function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
6
26
 
7
- var browserslist__default = /*#__PURE__*/_interopDefault(browserslist);
27
+ })();
28
+ // webpack/runtime/define_property_getters
29
+ (() => {
30
+ __webpack_require__.d = function(exports, definition) {
31
+ for(var key in definition) {
32
+ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
33
+ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
34
+ }
35
+ }
36
+ };
37
+ })();
38
+ // webpack/runtime/has_own_property
39
+ (() => {
40
+ __webpack_require__.o = function (obj, prop) {
41
+ return Object.prototype.hasOwnProperty.call(obj, prop);
42
+ };
43
+
44
+ })();
45
+ // webpack/runtime/make_namespace_object
46
+ (() => {
47
+ // define __esModule on exports
48
+ __webpack_require__.r = function(exports) {
49
+ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
50
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
51
+ }
52
+ Object.defineProperty(exports, '__esModule', { value: true });
53
+ };
54
+
55
+ })();
56
+ /************************************************************************/
57
+ var __webpack_exports__ = {};
58
+ // ESM COMPAT FLAG
59
+ __webpack_require__.r(__webpack_exports__);
8
60
 
9
- // src/browserslistToSwc.ts
10
- var SwcSupportedBrowsers = [
11
- "ie",
12
- "edge",
13
- "firefox",
14
- "chrome",
15
- "safari",
16
- "opera",
17
- "ios",
18
- "android",
19
- "op_mob",
20
- "and_chr",
21
- "and_ff",
22
- "ie_mob",
23
- "samsung"
61
+ // EXPORTS
62
+ __webpack_require__.d(__webpack_exports__, {
63
+ browserslistToSwc: () => (/* binding */ browserslistToSwc),
64
+ createSwcTargetsFromBrowserslistEntries: () => (/* binding */ createSwcTargetsFromBrowserslistEntries)
65
+ });
66
+
67
+ ;// CONCATENATED MODULE: external "browserslist"
68
+ const external_browserslist_namespaceObject = require("browserslist");
69
+ var external_browserslist_default = /*#__PURE__*/__webpack_require__.n(external_browserslist_namespaceObject);
70
+ ;// CONCATENATED MODULE: ./src/browserslistToSwc.ts?__rslib_entry__
71
+ // Inspired by https://github.com/marcofugaro/browserslist-to-esbuild/blob/main/src/index.js.
72
+ //
73
+ // 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.
74
+ // Therefore, we must parse ourself the ".browserslistrc" file to extract the browser entries and transform them into valid SWC "env.targets".
75
+ //
76
+ // The function will convert an array of browserslist entries from:
77
+ //
78
+ // ['and_chr 115', 'and_ff 115', 'and_qq 13.1',
79
+ // 'and_uc 15.5', 'android 115', 'baidu 13.18',
80
+ // 'bb 10', 'bb 7', 'chrome 116',
81
+ // 'chrome 115', 'chrome 114', 'chrome 113',
82
+ // 'chrome 112', 'chrome 111', 'chrome 110',
83
+ // 'chrome 109', 'chrome 108', 'chrome 107',
84
+ // 'edge 115', 'edge 114', 'edge 113',
85
+ // 'edge 112', 'edge 111', 'edge 110',
86
+ // 'edge 109', 'edge 108', 'edge 107',
87
+ // 'edge 106', 'firefox 116', 'firefox 115',
88
+ // 'firefox 114', 'firefox 113', 'firefox 112',
89
+ // 'firefox 111', 'firefox 110', 'firefox 109',
90
+ // 'firefox 108', 'firefox 107', 'ie 11',
91
+ // 'ie 10', 'ie 9', 'ie 8',
92
+ // 'ie 7', 'ie 6', 'ie 5.5',
93
+ // 'ie_mob 11', 'ie_mob 10', 'ios_saf 16.5',
94
+ // 'ios_saf 16.4', 'ios_saf 16.3', 'ios_saf 16.2',
95
+ // 'ios_saf 16.1', 'ios_saf 16.0', 'ios_saf 15.6-15.7',
96
+ // 'ios_saf 15.5', 'ios_saf 15.4', 'ios_saf 15.2-15.3',
97
+ // 'kaios 3.0-3.1', 'kaios 2.5', 'op_mini all',
98
+ // 'op_mob 73', 'opera 101', 'opera 100',
99
+ // 'opera 99', 'opera 98', 'opera 97',
100
+ // 'opera 96', 'opera 95', 'opera 94',
101
+ // 'opera 93', 'opera 92', 'safari 16.5',
102
+ // 'safari 16.4', 'safari 16.3', 'safari 16.2',
103
+ // 'safari 16.1', 'safari 16.0', 'safari 15.6',
104
+ // 'safari 15.5', 'safari 15.4', 'safari 15.2-15.3',
105
+ // 'samsung 21', 'samsung 20', 'samsung 19.0',
106
+ // 'samsung 18.0', 'samsung 17.0', 'samsung 16.0',
107
+ // 'samsung 15.0', 'samsung 14.0', 'samsung 13.0',
108
+ // 'samsung 12.0']
109
+ //
110
+ // To an object literal of SWC "env.targets":
111
+ //
112
+ // {
113
+ // chrome: '107',
114
+ // firefox: '107',
115
+ // android: '115',
116
+ // edge: '106',
117
+ // ie: '5.5',
118
+ // opera: '73',
119
+ // safari: '15.2',
120
+ // samsung: '12'
121
+ // }
122
+
123
+ // Original browserslist-rs supported browsers (https://github.com/browserslist/browserslist-rs/blob/99a3244fc8c0e631a80a9cae5c41dca6c5a2aae5/build.rs#L10)
124
+ // minus the browsers that are discarted by SWC (https://github.com/swc-project/swc/blob/main/crates/preset_env_base/src/lib.rs#L105).
125
+ const SwcSupportedBrowsers = [
126
+ "ie",
127
+ "edge",
128
+ "firefox",
129
+ "chrome",
130
+ "safari",
131
+ "opera",
132
+ "ios",
133
+ "android",
134
+ "op_mob",
135
+ "and_chr",
136
+ "and_ff",
137
+ "ie_mob",
138
+ "samsung"
24
139
  ];
25
- var SwcMobileBrowserAliases = {
26
- "and_chr": "chrome",
27
- "and_ff": "firefox",
28
- "ie_mob": "ie",
29
- "ios_saf": "ios",
30
- "op_mob": "opera"
140
+ // SWC browsers aliases (https://github.com/swc-project/swc/blob/main/crates/preset_env_base/src/lib.rs#L90).
141
+ const SwcMobileBrowserAliases = {
142
+ "and_chr": "chrome",
143
+ "and_ff": "firefox",
144
+ "ie_mob": "ie",
145
+ "ios_saf": "ios",
146
+ "op_mob": "opera"
31
147
  };
32
148
  function parseBrowserslistEntry(entry) {
33
- const values = entry.split(" ");
34
- let browser = values[0];
35
- let version = values[1];
36
- if (SwcMobileBrowserAliases[browser]) {
37
- browser = SwcMobileBrowserAliases[browser];
38
- }
39
- if (version.includes("-")) {
40
- version = version.slice(0, version.indexOf("-"));
41
- }
42
- if (version.endsWith(".0")) {
43
- version = version.slice(0, -2);
44
- }
45
- return {
46
- browser,
47
- version
48
- };
49
- }
50
- function createSwcTargetsFromBrowserslistEntries(entries) {
51
- return entries.reduce((acc, x) => {
52
- const { browser, version } = parseBrowserslistEntry(x);
53
- if (SwcSupportedBrowsers.indexOf(browser) === -1) {
54
- return acc;
149
+ // "chrome 11" --> ["chrome", "11"]
150
+ const values = entry.split(" ");
151
+ let browser = values[0];
152
+ let version = values[1];
153
+ // "and_chr" --> "chrome"
154
+ if (SwcMobileBrowserAliases[browser]) {
155
+ browser = SwcMobileBrowserAliases[browser];
55
156
  }
56
- const _browser = browser;
57
- if (acc[_browser]) {
58
- if (parseFloat(acc[_browser]) > parseFloat(version)) {
59
- acc[_browser] = version;
60
- }
61
- } else {
62
- acc[_browser] = version;
157
+ // "11.0-12.0" --> "11.0"
158
+ if (version.includes("-")) {
159
+ version = version.slice(0, version.indexOf("-"));
63
160
  }
64
- return acc;
65
- }, {});
161
+ // "11.0" --> "11"
162
+ if (version.endsWith(".0")) {
163
+ version = version.slice(0, -2);
164
+ }
165
+ return {
166
+ browser,
167
+ version
168
+ };
169
+ }
170
+ function createSwcTargetsFromBrowserslistEntries(entries) {
171
+ return entries.reduce((acc, x)=>{
172
+ const { browser, version } = parseBrowserslistEntry(x);
173
+ // Exclude browsers that are not supported by SWC.
174
+ if (SwcSupportedBrowsers.indexOf(browser) === -1) {
175
+ return acc;
176
+ }
177
+ // Let's make TS happy as we are now certain that the browser is part
178
+ // of the supported browsers list.
179
+ const _browser = browser;
180
+ // SWC "env.targets" only support a single entry per target (browser).
181
+ // Therefore, we loop through the browser versions to keep only the oldest one.
182
+ if (acc[_browser]) {
183
+ if (parseFloat(acc[_browser]) > parseFloat(version)) {
184
+ acc[_browser] = version;
185
+ }
186
+ } else {
187
+ acc[_browser] = version;
188
+ }
189
+ return acc;
190
+ }, {});
66
191
  }
67
192
  function browserslistToSwc(options = {}) {
68
- const {
69
- queries,
70
- ...browserlistsOptions
71
- } = options;
72
- const entries = browserslist__default.default(queries, {
73
- path: "./browserslistrc",
74
- ...browserlistsOptions
75
- });
76
- return createSwcTargetsFromBrowserslistEntries(entries);
193
+ const { queries, ...browserlistsOptions } = options;
194
+ // Will return the entries matching the "queries" prop when provided, otherwise,
195
+ // the function will load the closest ".browserslistrc" file.
196
+ const entries = external_browserslist_default()(queries, {
197
+ path: "./browserslistrc",
198
+ ...browserlistsOptions
199
+ });
200
+ return createSwcTargetsFromBrowserslistEntries(entries);
77
201
  }
78
202
 
79
- exports.browserslistToSwc = browserslistToSwc;
80
- exports.createSwcTargetsFromBrowserslistEntries = createSwcTargetsFromBrowserslistEntries;
203
+ var __webpack_export_target__ = exports;
204
+ for(var __webpack_i__ in __webpack_exports__) __webpack_export_target__[__webpack_i__] = __webpack_exports__[__webpack_i__];
205
+ if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, '__esModule', { value: true });
206
+
207
+ //# sourceMappingURL=browserslistToSwc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"browserslistToSwc.js","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":"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"}
@@ -1 +1,140 @@
1
- export { browserslistToSwc, createSwcTargetsFromBrowserslistEntries } from './chunk-MGMFB3UY.mjs';
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 '@swc/core';
2
- import { SwcConfigTransformer } from './applyTransformers.js';
3
-
4
- interface DefineBuildConfigOptions {
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<Config["jsc"]>["paths"];
6
+ paths?: NonNullable<SwcConfig["jsc"]>["paths"];
8
7
  transformers?: SwcConfigTransformer[];
9
8
  }
10
- declare function defineBuildConfig(targets: Record<string, string>, options?: DefineBuildConfigOptions): Config;
11
-
12
- export { type DefineBuildConfigOptions, defineBuildConfig };
9
+ export declare function defineBuildConfig(targets: Record<string, string>, options?: DefineBuildConfigOptions): SwcConfig;