@tamagui/static 2.0.0-rc.9 → 2.0.0

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 (186) hide show
  1. package/dist/check-dep-versions.cjs +201 -96
  2. package/dist/checkDeps.cjs +250 -46
  3. package/dist/constants.cjs +32 -30
  4. package/dist/exports.cjs +20 -13
  5. package/dist/extractor/accessSafe.cjs +25 -23
  6. package/dist/extractor/babelParse.cjs +30 -28
  7. package/dist/extractor/buildClassName.cjs +59 -35
  8. package/dist/extractor/bundle.cjs +187 -101
  9. package/dist/extractor/bundleConfig.cjs +568 -168
  10. package/dist/extractor/concatClassName.cjs +73 -32
  11. package/dist/extractor/createEvaluator.cjs +54 -41
  12. package/dist/extractor/createExtractor.cjs +1405 -574
  13. package/dist/extractor/createLogger.cjs +30 -25
  14. package/dist/extractor/detectModuleFormat.cjs +55 -0
  15. package/dist/extractor/ensureImportingConcat.cjs +31 -25
  16. package/dist/extractor/errors.cjs +12 -10
  17. package/dist/extractor/esbuildAliasPlugin.cjs +28 -16
  18. package/dist/extractor/esbuildTsconfigPaths.cjs +60 -36
  19. package/dist/extractor/evaluateAstNode.cjs +104 -59
  20. package/dist/extractor/extractHelpers.cjs +130 -67
  21. package/dist/extractor/extractMediaStyle.cjs +110 -69
  22. package/dist/extractor/extractToClassNames.cjs +337 -229
  23. package/dist/extractor/extractToNative.cjs +248 -152
  24. package/dist/extractor/findTopmostFunction.cjs +22 -13
  25. package/dist/extractor/generatedUid.cjs +39 -28
  26. package/dist/extractor/getPrefixLogs.cjs +12 -10
  27. package/dist/extractor/getPropValueFromAttributes.cjs +52 -34
  28. package/dist/extractor/getSourceModule.cjs +73 -37
  29. package/dist/extractor/getStaticBindingsForScope.cjs +131 -68
  30. package/dist/extractor/getTamaguiConfigPathFromOptionsConfig.cjs +20 -14
  31. package/dist/extractor/hasTopLevelAwait.cjs +62 -0
  32. package/dist/extractor/hoistClassNames.cjs +46 -32
  33. package/dist/extractor/literalToAst.cjs +67 -42
  34. package/dist/extractor/loadFile.cjs +9 -3
  35. package/dist/extractor/loadTamagui.cjs +151 -105
  36. package/dist/extractor/logLines.cjs +27 -19
  37. package/dist/extractor/normalizeTernaries.cjs +66 -44
  38. package/dist/extractor/propsToFontFamilyCache.cjs +15 -11
  39. package/dist/extractor/regenerateConfig.cjs +109 -81
  40. package/dist/extractor/removeUnusedHooks.cjs +73 -41
  41. package/dist/extractor/timer.cjs +23 -14
  42. package/dist/extractor/validHTMLAttributes.cjs +61 -59
  43. package/dist/extractor/watchTamaguiConfig.cjs +35 -23
  44. package/dist/getPragmaOptions.cjs +34 -19
  45. package/dist/helpers/memoize.cjs +24 -16
  46. package/dist/helpers/requireTamaguiCore.cjs +22 -15
  47. package/dist/index.cjs +26 -24
  48. package/dist/registerRequire.cjs +168 -65
  49. package/dist/server.cjs +35 -28
  50. package/dist/types.cjs +7 -5
  51. package/dist/worker.cjs +62 -40
  52. package/package.json +27 -24
  53. package/src/checkDeps.ts +305 -68
  54. package/src/exports.ts +2 -0
  55. package/src/extractor/babelParse.ts +1 -0
  56. package/src/extractor/bundle.ts +172 -40
  57. package/src/extractor/bundleConfig.ts +459 -65
  58. package/src/extractor/concatClassName.ts +37 -20
  59. package/src/extractor/createExtractor.ts +300 -30
  60. package/src/extractor/detectModuleFormat.ts +42 -0
  61. package/src/extractor/esbuildTsconfigPaths.ts +6 -1
  62. package/src/extractor/extractToClassNames.ts +15 -9
  63. package/src/extractor/extractToNative.ts +65 -32
  64. package/src/extractor/hasTopLevelAwait.ts +28 -0
  65. package/src/extractor/loadTamagui.ts +5 -4
  66. package/src/registerRequire.ts +102 -9
  67. package/types/checkDeps.d.ts.map +1 -1
  68. package/types/exports.d.ts +2 -0
  69. package/types/exports.d.ts.map +1 -1
  70. package/types/extractor/babelParse.d.ts.map +1 -1
  71. package/types/extractor/bundle.d.ts +83 -1
  72. package/types/extractor/bundle.d.ts.map +1 -1
  73. package/types/extractor/bundleConfig.d.ts +15 -2
  74. package/types/extractor/bundleConfig.d.ts.map +1 -1
  75. package/types/extractor/createExtractor.d.ts.map +1 -1
  76. package/types/extractor/detectModuleFormat.d.ts +5 -0
  77. package/types/extractor/detectModuleFormat.d.ts.map +1 -0
  78. package/types/extractor/esbuildTsconfigPaths.d.ts +8 -0
  79. package/types/extractor/esbuildTsconfigPaths.d.ts.map +1 -1
  80. package/types/extractor/extractToClassNames.d.ts.map +1 -1
  81. package/types/extractor/extractToNative.d.ts.map +1 -1
  82. package/types/extractor/hasTopLevelAwait.d.ts +2 -0
  83. package/types/extractor/hasTopLevelAwait.d.ts.map +1 -0
  84. package/types/extractor/loadTamagui.d.ts +1 -1
  85. package/types/extractor/loadTamagui.d.ts.map +1 -1
  86. package/types/registerRequire.d.ts.map +1 -1
  87. package/dist/check-dep-versions.js +0 -389
  88. package/dist/check-dep-versions.js.map +0 -6
  89. package/dist/checkDeps.js +0 -60
  90. package/dist/checkDeps.js.map +0 -6
  91. package/dist/constants.js +0 -34
  92. package/dist/constants.js.map +0 -6
  93. package/dist/exports.js +0 -34
  94. package/dist/exports.js.map +0 -6
  95. package/dist/extractor/accessSafe.js +0 -47
  96. package/dist/extractor/accessSafe.js.map +0 -6
  97. package/dist/extractor/babelParse.js +0 -59
  98. package/dist/extractor/babelParse.js.map +0 -6
  99. package/dist/extractor/buildClassName.js +0 -72
  100. package/dist/extractor/buildClassName.js.map +0 -6
  101. package/dist/extractor/bundle.js +0 -135
  102. package/dist/extractor/bundle.js.map +0 -6
  103. package/dist/extractor/bundleConfig.js +0 -352
  104. package/dist/extractor/bundleConfig.js.map +0 -6
  105. package/dist/extractor/concatClassName.js +0 -69
  106. package/dist/extractor/concatClassName.js.map +0 -6
  107. package/dist/extractor/createEvaluator.js +0 -66
  108. package/dist/extractor/createEvaluator.js.map +0 -6
  109. package/dist/extractor/createExtractor.js +0 -1212
  110. package/dist/extractor/createExtractor.js.map +0 -6
  111. package/dist/extractor/createLogger.js +0 -32
  112. package/dist/extractor/createLogger.js.map +0 -6
  113. package/dist/extractor/ensureImportingConcat.js +0 -50
  114. package/dist/extractor/ensureImportingConcat.js.map +0 -6
  115. package/dist/extractor/errors.js +0 -22
  116. package/dist/extractor/errors.js.map +0 -6
  117. package/dist/extractor/esbuildAliasPlugin.js +0 -36
  118. package/dist/extractor/esbuildAliasPlugin.js.map +0 -6
  119. package/dist/extractor/esbuildTsconfigPaths.js +0 -79
  120. package/dist/extractor/esbuildTsconfigPaths.js.map +0 -6
  121. package/dist/extractor/evaluateAstNode.js +0 -99
  122. package/dist/extractor/evaluateAstNode.js.map +0 -6
  123. package/dist/extractor/extractHelpers.js +0 -108
  124. package/dist/extractor/extractHelpers.js.map +0 -6
  125. package/dist/extractor/extractMediaStyle.js +0 -123
  126. package/dist/extractor/extractMediaStyle.js.map +0 -6
  127. package/dist/extractor/extractToClassNames.js +0 -351
  128. package/dist/extractor/extractToClassNames.js.map +0 -6
  129. package/dist/extractor/extractToNative.js +0 -286
  130. package/dist/extractor/extractToNative.js.map +0 -6
  131. package/dist/extractor/findTopmostFunction.js +0 -32
  132. package/dist/extractor/findTopmostFunction.js.map +0 -6
  133. package/dist/extractor/generatedUid.js +0 -42
  134. package/dist/extractor/generatedUid.js.map +0 -6
  135. package/dist/extractor/getPrefixLogs.js +0 -24
  136. package/dist/extractor/getPrefixLogs.js.map +0 -6
  137. package/dist/extractor/getPropValueFromAttributes.js +0 -65
  138. package/dist/extractor/getPropValueFromAttributes.js.map +0 -6
  139. package/dist/extractor/getSourceModule.js +0 -62
  140. package/dist/extractor/getSourceModule.js.map +0 -6
  141. package/dist/extractor/getStaticBindingsForScope.js +0 -145
  142. package/dist/extractor/getStaticBindingsForScope.js.map +0 -6
  143. package/dist/extractor/getTamaguiConfigPathFromOptionsConfig.js +0 -32
  144. package/dist/extractor/getTamaguiConfigPathFromOptionsConfig.js.map +0 -6
  145. package/dist/extractor/hoistClassNames.js +0 -63
  146. package/dist/extractor/hoistClassNames.js.map +0 -6
  147. package/dist/extractor/literalToAst.js +0 -90
  148. package/dist/extractor/literalToAst.js.map +0 -6
  149. package/dist/extractor/loadFile.js +0 -14
  150. package/dist/extractor/loadFile.js.map +0 -6
  151. package/dist/extractor/loadTamagui.js +0 -306
  152. package/dist/extractor/loadTamagui.js.map +0 -6
  153. package/dist/extractor/logLines.js +0 -30
  154. package/dist/extractor/logLines.js.map +0 -6
  155. package/dist/extractor/normalizeTernaries.js +0 -61
  156. package/dist/extractor/normalizeTernaries.js.map +0 -6
  157. package/dist/extractor/propsToFontFamilyCache.js +0 -33
  158. package/dist/extractor/propsToFontFamilyCache.js.map +0 -6
  159. package/dist/extractor/regenerateConfig.js +0 -123
  160. package/dist/extractor/regenerateConfig.js.map +0 -6
  161. package/dist/extractor/removeUnusedHooks.js +0 -72
  162. package/dist/extractor/removeUnusedHooks.js.map +0 -6
  163. package/dist/extractor/timer.js +0 -38
  164. package/dist/extractor/timer.js.map +0 -6
  165. package/dist/extractor/validHTMLAttributes.js +0 -72
  166. package/dist/extractor/validHTMLAttributes.js.map +0 -6
  167. package/dist/extractor/watchTamaguiConfig.js +0 -57
  168. package/dist/extractor/watchTamaguiConfig.js.map +0 -6
  169. package/dist/getPragmaOptions.js +0 -50
  170. package/dist/getPragmaOptions.js.map +0 -6
  171. package/dist/helpers/memoize.js +0 -33
  172. package/dist/helpers/memoize.js.map +0 -6
  173. package/dist/helpers/requireTamaguiCore.js +0 -30
  174. package/dist/helpers/requireTamaguiCore.js.map +0 -6
  175. package/dist/index.js +0 -30
  176. package/dist/index.js.map +0 -6
  177. package/dist/registerRequire.js +0 -100
  178. package/dist/registerRequire.js.map +0 -6
  179. package/dist/server.js +0 -58
  180. package/dist/server.js.map +0 -6
  181. package/dist/setup.js +0 -1
  182. package/dist/setup.js.map +0 -6
  183. package/dist/types.js +0 -14
  184. package/dist/types.js.map +0 -6
  185. package/dist/worker.js +0 -72
  186. package/dist/worker.js.map +0 -6
@@ -2,103 +2,262 @@ var __create = Object.create;
2
2
  var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf,
6
- __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
7
  var __export = (target, all) => {
8
- for (var name in all) __defProp(target, name, {
9
- get: all[name],
10
- enumerable: !0
11
- });
12
- },
13
- __copyProps = (to, from, except, desc) => {
14
- if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
8
+ for (var name in all) __defProp(target, name, {
9
+ get: all[name],
10
+ enumerable: true
11
+ });
12
+ };
13
+ var __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from === "object" || typeof from === "function") {
15
+ for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
15
16
  get: () => from[key],
16
17
  enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
17
18
  });
18
- return to;
19
- };
19
+ }
20
+ return to;
21
+ };
20
22
  var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
26
- value: mod,
27
- enumerable: !0
28
- }) : target, mod)),
29
- __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
30
- value: !0
31
- }), mod);
23
+ // If the importer is in node compatibility mode or this is not an ESM
24
+ // file that has been converted to a CommonJS file using a Babel-
25
+ // compatible transform (i.e. "__esModule" has not been set), then set
26
+ // "default" to the CommonJS "module.exports" for node compatibility.
27
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
28
+ value: mod,
29
+ enumerable: true
30
+ }) : target, mod));
31
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
32
+ value: true
33
+ }), mod);
32
34
  var bundleConfig_exports = {};
33
35
  __export(bundleConfig_exports, {
34
36
  bundleConfig: () => bundleConfig,
35
37
  esbuildOptions: () => esbuildOptions,
38
+ esbuildOptionsWithPlugins: () => esbuildOptionsWithPlugins,
36
39
  getBundledConfig: () => getBundledConfig,
37
40
  getLoadedConfig: () => getLoadedConfig,
38
41
  hasBundledConfigChanged: () => hasBundledConfigChanged,
39
42
  loadComponents: () => loadComponents,
40
43
  loadComponentsInner: () => loadComponentsInner,
44
+ loadComponentsInnerSync: () => loadComponentsInnerSync,
45
+ loadComponentsSync: () => loadComponentsSync,
41
46
  writeTamaguiCSS: () => writeTamaguiCSS
42
47
  });
43
48
  module.exports = __toCommonJS(bundleConfig_exports);
44
- var import_generator = __toESM(require("@babel/generator")),
45
- import_traverse = __toESM(require("@babel/traverse")),
46
- t = __toESM(require("@babel/types")),
47
- import_node_fs = require("node:fs"),
48
- import_node_path = require("node:path"),
49
- import_cli_color = require("@tamagui/cli-color"),
50
- import_esbuild = __toESM(require("esbuild")),
51
- FS = __toESM(require("fs-extra")),
52
- import_promises = require("node:fs/promises"),
53
- import_registerRequire = require("../registerRequire.cjs"),
54
- import_babelParse = require("./babelParse.cjs"),
55
- import_bundle = require("./bundle.cjs"),
56
- import_getTamaguiConfigPathFromOptionsConfig = require("./getTamaguiConfigPathFromOptionsConfig.cjs"),
57
- import_requireTamaguiCore = require("../helpers/requireTamaguiCore.cjs");
58
- const external = ["@tamagui/core", "@tamagui/web", "react", "react-dom", "react-native-svg"],
59
- esbuildExtraOptions = {
60
- define: {
61
- __DEV__: `${process.env.NODE_ENV === "development"}`
62
- }
63
- },
64
- esbuildOptions = {
65
- target: "es2018",
66
- format: "cjs",
67
- jsx: "automatic",
68
- platform: "node",
69
- ...esbuildExtraOptions
70
- };
71
- let currentBundle = null,
72
- isBundling = !1,
73
- lastBundle = null;
49
+ var import_generator = __toESM(require("@babel/generator"));
50
+ var import_traverse = __toESM(require("@babel/traverse"));
51
+ var t = __toESM(require("@babel/types"));
52
+ var import_node_crypto = require("node:crypto");
53
+ var import_node_fs = require("node:fs");
54
+ var import_node_path = require("node:path");
55
+ var import_node_url = require("node:url");
56
+ var import_cli_color = require("@tamagui/cli-color");
57
+ var import_esbuild = __toESM(require("esbuild"));
58
+ var FS = __toESM(require("fs-extra"));
59
+ var import_promises = require("node:fs/promises");
60
+ var import_registerRequire = require("../registerRequire.cjs");
61
+ var import_babelParse = require("./babelParse.cjs");
62
+ var import_bundle = require("./bundle.cjs");
63
+ var import_getTamaguiConfigPathFromOptionsConfig = require("./getTamaguiConfigPathFromOptionsConfig.cjs");
64
+ var import_hasTopLevelAwait = require("./hasTopLevelAwait.cjs");
65
+ var import_requireTamaguiCore = require("../helpers/requireTamaguiCore.cjs");
66
+ var import_detectModuleFormat = require("./detectModuleFormat.cjs");
67
+ const activeTempFiles = /* @__PURE__ */new Set();
68
+ function getDynamicEvalOutfile(name, format, contents) {
69
+ const ext = format === "esm" ? "mjs" : "cjs";
70
+ const hash = (0, import_node_crypto.createHash)("sha1").update(name).update("\0").update(format).update("\0").update(contents).digest("hex").slice(0, 10);
71
+ return (0, import_node_path.join)(process.cwd(), ".tamagui", `dynamic-eval-${hash}-${(0, import_node_path.basename)(name)}.${ext}`);
72
+ }
73
+ function getEsbuildStdinLoader(filePath) {
74
+ if (filePath.endsWith(".tsx")) return "tsx";
75
+ if (filePath.endsWith(".ts")) return "ts";
76
+ if (filePath.endsWith(".jsx")) return "jsx";
77
+ return "js";
78
+ }
79
+ function resolvePackageEntry(packageName, format) {
80
+ if (format === "cjs") {
81
+ return require.resolve(packageName);
82
+ }
83
+ const packageJsonPath = require.resolve(`${packageName}/package.json`);
84
+ const packageJson = JSON.parse((0, import_node_fs.readFileSync)(packageJsonPath, "utf-8"));
85
+ const packageRoot = (0, import_node_path.dirname)(packageJsonPath);
86
+ const exportEntry = packageJson.exports?.["."];
87
+ const esmEntry = exportEntry?.import || exportEntry?.module || exportEntry?.browser || packageJson.module;
88
+ if (typeof esmEntry === "string") {
89
+ return (0, import_node_path.join)(packageRoot, esmEntry);
90
+ }
91
+ return require.resolve(packageName);
92
+ }
93
+ function cleanupTempFiles() {
94
+ for (const f of activeTempFiles) {
95
+ try {
96
+ (0, import_node_fs.unlinkSync)(f);
97
+ } catch {}
98
+ }
99
+ activeTempFiles.clear();
100
+ }
101
+ process.on("exit", cleanupTempFiles);
102
+ process.on("SIGINT", () => {
103
+ cleanupTempFiles();
104
+ process.exit();
105
+ });
106
+ process.on("SIGTERM", () => {
107
+ cleanupTempFiles();
108
+ process.exit();
109
+ });
110
+ const external = ["@tamagui/core", "@tamagui/web", "react", "react-dom", "react-native-svg"];
111
+ const esbuildExtraOptions = {
112
+ define: {
113
+ __DEV__: `${process.env.NODE_ENV === "development"}`
114
+ }
115
+ };
116
+ const handleEsmFeaturesPlugin = {
117
+ name: "handle-esm-features",
118
+ setup(build) {
119
+ const isCjs = build.initialOptions.format === "cjs" || !build.initialOptions.format;
120
+ build.onLoad({
121
+ filter: /\.(ts|tsx|js|jsx|mjs)$/
122
+ }, args => {
123
+ if (!isCjs) {
124
+ return null;
125
+ }
126
+ if (args.path.includes("node_modules") && !args.path.includes("@tamagui")) {
127
+ return null;
128
+ }
129
+ let contents = (0, import_node_fs.readFileSync)(args.path, "utf8");
130
+ let modified = false;
131
+ if (contents.includes("import.meta.env")) {
132
+ contents = contents.replace(/import\.meta\.env/g, "process.env");
133
+ modified = true;
134
+ }
135
+ if (contents.includes("import.meta.url")) {
136
+ contents = contents.replace(/import\.meta\.url/g, '""');
137
+ modified = true;
138
+ }
139
+ if (contents.includes("import.meta.main")) {
140
+ contents = contents.replace(/import\.meta\.main/g, "false");
141
+ modified = true;
142
+ }
143
+ if ((0, import_hasTopLevelAwait.hasTopLevelAwait)(contents, args.path)) {
144
+ if (process.env.DEBUG?.startsWith("tamagui")) {
145
+ console.info(`[tamagui] stubbing file with top-level await: ${args.path}`);
146
+ }
147
+ return {
148
+ // Keep this as an ESM-shaped stub so esbuild doesn't inline a top-level
149
+ // `module.exports = {}` into the parent bundle and wipe its exports.
150
+ contents: `// stubbed - contains top-level await
151
+ export default {}`,
152
+ loader: "js"
153
+ };
154
+ }
155
+ if (modified) {
156
+ return {
157
+ contents,
158
+ loader: args.path.endsWith(".tsx") ? "tsx" : args.path.endsWith(".ts") ? "ts" : args.path.endsWith(".jsx") ? "jsx" : "js"
159
+ };
160
+ }
161
+ return null;
162
+ });
163
+ }
164
+ };
165
+ const esbuildTransformOptions = {
166
+ target: "es2022",
167
+ format: "cjs",
168
+ jsx: "automatic",
169
+ platform: "node",
170
+ ...esbuildExtraOptions
171
+ };
172
+ const esbuildOptions = {
173
+ ...esbuildTransformOptions
174
+ };
175
+ const esbuildOptionsWithPlugins = {
176
+ ...esbuildTransformOptions,
177
+ plugins: [handleEsmFeaturesPlugin]
178
+ };
179
+ let currentBundle = null;
180
+ let currentBundleKey = "";
181
+ let isBundling = false;
182
+ let lastBundle = null;
74
183
  const waitForBundle = /* @__PURE__ */new Set();
75
184
  function hasBundledConfigChanged() {
76
- return lastBundle === currentBundle ? !1 : (lastBundle = currentBundle, !0);
185
+ if (lastBundle === currentBundle) {
186
+ return false;
187
+ }
188
+ lastBundle = currentBundle;
189
+ return true;
77
190
  }
78
191
  let loadedConfig = null;
79
192
  const getLoadedConfig = () => loadedConfig;
80
- async function getBundledConfig(props, rebuild = !1) {
81
- if (isBundling) await new Promise(res => {
82
- waitForBundle.add(res);
83
- });else if (!currentBundle || rebuild) return await bundleConfig(props);
193
+ function getBundleKey(props) {
194
+ return JSON.stringify({
195
+ components: props.components,
196
+ config: props.config,
197
+ platform: props.platform
198
+ });
199
+ }
200
+ async function getBundledConfig(props, rebuild = false) {
201
+ const bundleKey = getBundleKey(props);
202
+ if (isBundling) {
203
+ await new Promise(res => {
204
+ waitForBundle.add(res);
205
+ });
206
+ }
207
+ if (!currentBundle || currentBundleKey !== bundleKey || rebuild) {
208
+ return await bundleConfig(props);
209
+ }
84
210
  return currentBundle;
85
211
  }
86
212
  global.tamaguiLastLoaded ||= 0;
87
- function updateLastLoaded(config) {
88
- global.tamaguiLastLoaded = Date.now(), global.tamaguiLastBundledConfig = config;
213
+ function updateLastLoaded(config, bundleKey) {
214
+ global.tamaguiLastLoaded = Date.now();
215
+ global.tamaguiLastBundledConfig = config;
216
+ global.tamaguiLastBundledConfigKey = bundleKey;
89
217
  }
90
- let hasBundledOnce = !1,
91
- hasLoggedBuild = !1;
218
+ let hasBundledOnce = false;
219
+ let hasLoggedBuild = false;
92
220
  async function bundleConfig(props) {
93
- if (global.tamaguiLastBundledConfig && Date.now() - global.tamaguiLastLoaded < 3e3) return global.tamaguiLastBundledConfig;
221
+ const bundleKey = getBundleKey(props);
222
+ if (global.tamaguiLastBundledConfig && global.tamaguiLastBundledConfigKey === bundleKey && Date.now() - global.tamaguiLastLoaded < 3e3) {
223
+ return global.tamaguiLastBundledConfig;
224
+ }
94
225
  try {
95
- isBundling = !0;
96
- const configEntry = props.config ? (0, import_getTamaguiConfigPathFromOptionsConfig.getTamaguiConfigPathFromOptionsConfig)(props.config) : "",
97
- tmpDir = (0, import_node_path.join)(process.cwd(), ".tamagui"),
98
- configOutPath = (0, import_node_path.join)(tmpDir, "tamagui.config.cjs"),
99
- baseComponents = (props.components || []).filter(x => x !== "@tamagui/core"),
100
- componentOutPaths = baseComponents.map(componentModule => (0, import_node_path.join)(tmpDir, `${componentModule.split(import_node_path.sep).join("-").replace(/[^a-z0-9]+/gi, "")}-components.config.cjs`));
101
- if (process.env.NODE_ENV === "development" && process.env.DEBUG?.startsWith("tamagui") && console.info("Building config entry", configEntry), !props.disableInitialBuild) {
226
+ isBundling = true;
227
+ const configEntry = props.config ? (0, import_getTamaguiConfigPathFromOptionsConfig.getTamaguiConfigPathFromOptionsConfig)(props.config) : "";
228
+ const tmpDir = (0, import_node_path.join)(process.cwd(), ".tamagui");
229
+ const configFormat = configEntry ? (0, import_detectModuleFormat.detectModuleFormat)(configEntry) : "cjs";
230
+ const configExt = configFormat === "esm" ? ".mjs" : ".cjs";
231
+ const configOutPath = (0, import_node_path.join)(tmpDir, `tamagui.config${configExt}`);
232
+ const baseComponents = (props.components || []).filter(x => x !== "@tamagui/core");
233
+ const componentFormats = baseComponents.map(mod => {
234
+ try {
235
+ const pkgJson = require.resolve(mod + "/package.json");
236
+ const pkg = JSON.parse((0, import_node_fs.readFileSync)(pkgJson, "utf-8"));
237
+ return pkg.type === "module" ? "esm" : "cjs";
238
+ } catch {
239
+ return "cjs";
240
+ }
241
+ });
242
+ const componentOutPaths = baseComponents.map((componentModule, i) => {
243
+ const ext = componentFormats[i] === "esm" ? ".mjs" : ".cjs";
244
+ return (0, import_node_path.join)(tmpDir, `${componentModule.split(import_node_path.sep).join("-").replace(/[^a-z0-9]+/gi, "")}-components.config${ext}`);
245
+ });
246
+ if (process.env.NODE_ENV === "development" && process.env.DEBUG?.startsWith("tamagui")) {
247
+ console.info(`Building config entry`, configEntry);
248
+ }
249
+ let shouldBuild = !props.disableInitialBuild;
250
+ if (shouldBuild && props.config) {
251
+ const allOutFiles = [configOutPath, ...componentOutPaths];
252
+ try {
253
+ const stats = await Promise.all(allOutFiles.map(f => FS.stat(f).catch(() => null)));
254
+ const allExistAndRecent = stats.every(s => s !== null && Date.now() - s.mtimeMs < 3e3);
255
+ if (allExistAndRecent) {
256
+ shouldBuild = false;
257
+ }
258
+ } catch {}
259
+ }
260
+ if (shouldBuild) {
102
261
  try {
103
262
  await FS.ensureDir(tmpDir);
104
263
  } catch {}
@@ -107,92 +266,278 @@ async function bundleConfig(props) {
107
266
  entryPoints: [configEntry],
108
267
  external,
109
268
  outfile: configOutPath,
110
- target: "node20",
269
+ target: "node24",
270
+ format: configFormat,
111
271
  ...esbuildExtraOptions
112
- }, props.platform || "web") : null, ...baseComponents.map((componentModule, i) => (0, import_bundle.esbundleTamaguiConfig)({
113
- entryPoints: [componentModule],
114
- resolvePlatformSpecificEntries: !0,
115
- external,
116
- outfile: componentOutPaths[i],
117
- target: "node20",
118
- ...esbuildExtraOptions
119
- }, props.platform || "web"))]), !hasLoggedBuild && !props._skipBuildLog && (hasLoggedBuild = !0, (0, import_cli_color.colorLog)(import_cli_color.Color.FgYellow, `
120
- \u27A1 [tamagui] built config, components, prompt (${Date.now() - start}ms)`), process.env.DEBUG?.startsWith("tamagui") && (0, import_cli_color.colorLog)(import_cli_color.Color.Dim, `
272
+ }, props.platform || "web") : null, ...baseComponents.map((componentModule, i) => {
273
+ return (0, import_bundle.esbundleTamaguiConfig)({
274
+ entryPoints: [componentModule],
275
+ resolvePlatformSpecificEntries: true,
276
+ external,
277
+ outfile: componentOutPaths[i],
278
+ target: "node24",
279
+ format: componentFormats[i],
280
+ ...esbuildExtraOptions
281
+ }, props.platform || "web");
282
+ })]);
283
+ if (!hasLoggedBuild && !props["_skipBuildLog"]) {
284
+ hasLoggedBuild = true;
285
+ (0, import_cli_color.colorLog)(import_cli_color.Color.FgYellow, `
286
+ \u27A1 [tamagui] built config, components, prompt (${Date.now() - start}ms)`);
287
+ if (process.env.DEBUG?.startsWith("tamagui")) {
288
+ (0, import_cli_color.colorLog)(import_cli_color.Color.Dim, `
121
289
  Config .${import_node_path.sep}${(0, import_node_path.relative)(process.cwd(), configOutPath)}
122
- Components ${componentOutPaths.map(p => `.${import_node_path.sep}${(0, import_node_path.relative)(process.cwd(), p)}`).join(`
123
- `)}
124
- `));
290
+ Components ${componentOutPaths.map(p => `.${import_node_path.sep}${(0, import_node_path.relative)(process.cwd(), p)}`).join("\n ")}
291
+ `);
292
+ }
293
+ }
294
+ }
295
+ if (hasBundledOnce) {
296
+ try {
297
+ delete require.cache[require.resolve(configOutPath)];
298
+ } catch {}
299
+ for (const p of componentOutPaths) {
300
+ try {
301
+ delete require.cache[require.resolve(p)];
302
+ } catch {}
303
+ }
304
+ } else {
305
+ hasBundledOnce = true;
125
306
  }
126
307
  let out;
127
- const {
128
- unregister
129
- } = (0, import_registerRequire.registerRequire)(props.platform || "web");
130
- try {
131
- if (hasBundledOnce) for (const key in require.cache) /(core|web)[/\\]dist/.test(key) || delete require.cache[key];else hasBundledOnce = !0;
308
+ if (configFormat === "esm") {
309
+ out = await import((0, import_node_url.pathToFileURL)(configOutPath).href);
310
+ } else {
132
311
  out = require(configOutPath);
133
- } finally {
134
- unregister();
135
312
  }
136
313
  let config = out.default || out || out.config;
137
- if (config && config.config && !config.tokens && (config = config.config), !config) throw new Error(`No config: ${config}`);
138
- if (loadedConfig = config, !config.parsed) {
314
+ if (config && config.config && !config.tokens) {
315
+ config = config.config;
316
+ }
317
+ if (!config) {
318
+ throw new Error(`No config: ${config}`);
319
+ }
320
+ if (config._isProxyWorm) {
321
+ throw new Error(`Got a proxied config - likely a module loading error. Set DEBUG=tamagui for details.`);
322
+ }
323
+ loadedConfig = config;
324
+ if (!config.parsed) {
139
325
  const {
140
326
  createTamagui
141
327
  } = (0, import_requireTamaguiCore.requireTamaguiCore)(props.platform || "web");
142
328
  config = createTamagui(config);
143
329
  }
144
- props.outputCSS && (await writeTamaguiCSS(props.outputCSS, config));
145
- let components = loadComponents({
330
+ if (props.outputCSS) {
331
+ await writeTamaguiCSS(props.outputCSS, config);
332
+ }
333
+ let components = await loadComponents({
146
334
  ...props,
147
335
  components: componentOutPaths
148
336
  });
149
- if (!components) throw new Error(`No components found: ${componentOutPaths.join(", ")}`);
150
- for (const component of components) component.moduleName = baseComponents[componentOutPaths.indexOf(component.moduleName)] || component.moduleName, component.moduleName || (process.env.DEBUG?.includes("tamagui") || process.env.IS_TAMAGUI_DEV) && console.warn(`\u26A0\uFE0F no module name found: ${component.moduleName} ${JSON.stringify(baseComponents)} in ${JSON.stringify(componentOutPaths)}`);
151
- process.env.NODE_ENV === "development" && process.env.DEBUG?.startsWith("tamagui") && console.info("Loaded components", components);
337
+ if (!components) {
338
+ throw new Error(`No components found: ${componentOutPaths.join(", ")}`);
339
+ }
340
+ for (const component of components) {
341
+ component.moduleName = baseComponents[componentOutPaths.indexOf(component.moduleName)] || component.moduleName;
342
+ if (!component.moduleName) {
343
+ if (process.env.DEBUG?.includes("tamagui") || process.env.IS_TAMAGUI_DEV) {
344
+ console.warn(`\u26A0\uFE0F no module name found: ${component.moduleName} ${JSON.stringify(baseComponents)} in ${JSON.stringify(componentOutPaths)}`);
345
+ }
346
+ }
347
+ }
348
+ if (process.env.NODE_ENV === "development" && process.env.DEBUG?.startsWith("tamagui")) {
349
+ console.info("Loaded components", components);
350
+ }
152
351
  const res = {
153
352
  components,
154
353
  nameToPaths: {},
155
354
  tamaguiConfig: config
156
355
  };
157
- return currentBundle = res, updateLastLoaded(res), res;
356
+ currentBundle = res;
357
+ currentBundleKey = bundleKey;
358
+ updateLastLoaded(res, bundleKey);
359
+ return res;
158
360
  } catch (err) {
159
- console.error(`Error bundling tamagui config: ${err?.message} (run with DEBUG=tamagui to see stack)`), process.env.DEBUG?.includes("tamagui") && console.error(err.stack);
361
+ console.error(`Error bundling tamagui config: ${err?.message} (run with DEBUG=tamagui to see stack)`);
362
+ if (process.env.DEBUG?.includes("tamagui")) {
363
+ console.error(err.stack);
364
+ }
160
365
  } finally {
161
- isBundling = !1, waitForBundle.forEach(cb => cb()), waitForBundle.clear();
366
+ isBundling = false;
367
+ waitForBundle.forEach(cb => cb());
368
+ waitForBundle.clear();
162
369
  }
163
370
  }
164
371
  async function writeTamaguiCSS(outputCSS, config) {
165
372
  const flush = async () => {
166
- (0, import_cli_color.colorLog)(import_cli_color.Color.FgYellow, ` \u27A1 [tamagui] output css: ${outputCSS}`), await FS.writeFile(outputCSS, css);
167
- },
168
- css = config.getCSS();
169
- if (typeof css != "string") throw new Error(`Invalid CSS: ${typeof css} ${css}`);
373
+ (0, import_cli_color.colorLog)(import_cli_color.Color.FgYellow, ` \u27A1 [tamagui] output css: ${outputCSS}`);
374
+ await FS.writeFile(outputCSS, css);
375
+ };
376
+ const css = config.getCSS();
377
+ if (typeof css !== "string") {
378
+ throw new Error(`Invalid CSS: ${typeof css} ${css}`);
379
+ }
170
380
  try {
171
- (0, import_node_fs.existsSync)(outputCSS) && (await (0, import_promises.readFile)(outputCSS, "utf8")) === css || (await flush());
381
+ if ((0, import_node_fs.existsSync)(outputCSS) && (await (0, import_promises.readFile)(outputCSS, "utf8")) === css) {} else {
382
+ await flush();
383
+ }
172
384
  } catch (err) {
173
385
  console.info("Error writing themes", err);
174
386
  }
175
387
  }
176
- function loadComponents(props, forceExports = !1) {
177
- const coreComponents = getCoreComponents(props),
178
- otherComponents = loadComponentsInner(props, forceExports);
388
+ async function loadComponents(props, forceExports = false) {
389
+ const coreComponents = getCoreComponentsSync(props);
390
+ const otherComponents = await loadComponentsInner(props, forceExports);
179
391
  return [...coreComponents, ...(otherComponents || [])];
180
392
  }
181
- function getCoreComponents(props) {
182
- const loaded = loadComponentsInner({
393
+ function loadComponentsSync(props, forceExports = false) {
394
+ const coreComponents = getCoreComponentsSync(props);
395
+ const otherComponents = loadComponentsInnerSync(props, forceExports);
396
+ return [...coreComponents, ...(otherComponents || [])];
397
+ }
398
+ function getCoreComponentsSync(props) {
399
+ const loaded = loadComponentsInnerSync({
183
400
  ...props,
184
401
  components: ["@tamagui/core"]
185
402
  });
186
- if (!loaded) throw new Error("Core should always load");
403
+ if (!loaded) {
404
+ throw new Error(`Core should always load`);
405
+ }
187
406
  return [{
188
407
  ...loaded[0],
189
408
  moduleName: "@tamagui/core"
190
409
  }];
191
410
  }
192
- function loadComponentsInner(props, forceExports = !1) {
193
- const componentsModules = props.components || [],
194
- key = componentsModules.join("");
195
- if (!forceExports && cacheComponents[key]) return cacheComponents[key];
411
+ async function loadComponentsInner(props, forceExports = false) {
412
+ const componentsModules = props.components || [];
413
+ const key = componentsModules.join("\0");
414
+ if (!forceExports && cacheComponents[key]) {
415
+ return cacheComponents[key];
416
+ }
417
+ const {
418
+ unregister
419
+ } = (0, import_registerRequire.registerRequire)(props.platform || "web", {
420
+ proxyWormImports: forceExports
421
+ });
422
+ try {
423
+ const results = [];
424
+ for (const name of componentsModules) {
425
+ const extension = (0, import_node_path.extname)(name);
426
+ const isLocal = Boolean(extension);
427
+ const isDynamic = isLocal && forceExports;
428
+ const format = isLocal ? (0, import_detectModuleFormat.detectModuleFormat)(name) : "cjs";
429
+ const fileContents = isDynamic ? (0, import_node_fs.readFileSync)(name, "utf-8") : "";
430
+ let loadModule = name;
431
+ let writtenContents = fileContents;
432
+ let didBabel = false;
433
+ const attemptLoad = async ({
434
+ forceExports: forceExports2 = false
435
+ } = {}) => {
436
+ if (isDynamic) {
437
+ writtenContents = forceExports2 ? transformAddExports((0, import_babelParse.babelParse)(esbuildit(fileContents, "modern"), name)) : fileContents;
438
+ loadModule = getDynamicEvalOutfile(name, format, writtenContents);
439
+ FS.ensureDirSync((0, import_node_path.dirname)(loadModule));
440
+ activeTempFiles.add(loadModule);
441
+ await import_esbuild.default.build({
442
+ ...esbuildOptionsWithPlugins,
443
+ format,
444
+ outfile: loadModule,
445
+ stdin: {
446
+ contents: writtenContents,
447
+ resolveDir: (0, import_node_path.dirname)(name),
448
+ sourcefile: name,
449
+ loader: getEsbuildStdinLoader(name)
450
+ },
451
+ alias: {
452
+ "react-native": resolvePackageEntry("@tamagui/react-native-web-lite", format),
453
+ "@tamagui/react-native-web-lite": resolvePackageEntry("@tamagui/react-native-web-lite", format),
454
+ "@tamagui/react-native-web-internals": resolvePackageEntry("@tamagui/react-native-web-internals", format)
455
+ },
456
+ bundle: true,
457
+ packages: "external",
458
+ allowOverwrite: true,
459
+ sourcemap: false,
460
+ loader: import_bundle.esbuildLoaderConfig
461
+ });
462
+ }
463
+ if (process.env.DEBUG === "tamagui") {
464
+ console.info(`loadModule`, loadModule, format);
465
+ }
466
+ let moduleResult;
467
+ if (format === "esm") {
468
+ moduleResult = await import((0, import_node_url.pathToFileURL)(loadModule).href);
469
+ } else {
470
+ moduleResult = require(loadModule);
471
+ }
472
+ if (!forceExports2) {
473
+ (0, import_registerRequire.setRequireResult)(name, moduleResult);
474
+ }
475
+ const nameToInfo = getComponentStaticConfigByName(name, interopDefaultExport(moduleResult));
476
+ return {
477
+ moduleName: name,
478
+ nameToInfo
479
+ };
480
+ };
481
+ const dispose = () => {
482
+ if (isDynamic) {
483
+ FS.removeSync(loadModule);
484
+ activeTempFiles.delete(loadModule);
485
+ }
486
+ };
487
+ let loaded;
488
+ try {
489
+ loaded = await attemptLoad({
490
+ forceExports: true
491
+ });
492
+ didBabel = true;
493
+ } catch (err) {
494
+ console.info("babel err", err, writtenContents);
495
+ writtenContents = fileContents;
496
+ if (process.env.DEBUG?.startsWith("tamagui")) {
497
+ console.info(`Error parsing babel likely`, err);
498
+ }
499
+ try {
500
+ loaded = await attemptLoad({
501
+ forceExports: false
502
+ });
503
+ } catch (err2) {
504
+ if (process.env.TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD) {
505
+ console.info(`
506
+ Tamagui attempted but failed to dynamically optimize components in:
507
+ ${name}
508
+ `);
509
+ console.info(err2);
510
+ console.info(`At: ${loadModule}`, `
511
+ didBabel: ${didBabel}`, `
512
+ In:`, writtenContents, `
513
+ isDynamic: `, isDynamic);
514
+ }
515
+ loaded = [];
516
+ }
517
+ } finally {
518
+ dispose();
519
+ }
520
+ if (Array.isArray(loaded)) {
521
+ results.push(...loaded);
522
+ } else if (loaded) {
523
+ results.push(loaded);
524
+ }
525
+ }
526
+ cacheComponents[key] = results;
527
+ return results;
528
+ } catch (err) {
529
+ console.info(`Tamagui error bundling components`, err.message, err.stack);
530
+ return null;
531
+ } finally {
532
+ unregister();
533
+ }
534
+ }
535
+ function loadComponentsInnerSync(props, forceExports = false) {
536
+ const componentsModules = props.components || [];
537
+ const key = componentsModules.join("\0");
538
+ if (!forceExports && cacheComponents[key]) {
539
+ return cacheComponents[key];
540
+ }
196
541
  const {
197
542
  unregister
198
543
  } = (0, import_registerRequire.registerRequire)(props.platform || "web", {
@@ -200,30 +545,49 @@ function loadComponentsInner(props, forceExports = !1) {
200
545
  });
201
546
  try {
202
547
  const info = componentsModules.flatMap(name => {
203
- const isDynamic = !!(0, import_node_path.extname)(name) && forceExports,
204
- fileContents = isDynamic ? (0, import_node_fs.readFileSync)(name, "utf-8") : "",
205
- loadModule = isDynamic ? (0, import_node_path.join)((0, import_node_path.dirname)(name), `.tamagui-dynamic-eval-${(0, import_node_path.basename)(name)}.tsx`) : name;
206
- let writtenContents = fileContents,
207
- didBabel = !1;
548
+ const extension = (0, import_node_path.extname)(name);
549
+ const isLocal = Boolean(extension);
550
+ const isDynamic = isLocal && forceExports;
551
+ const fileContents = isDynamic ? (0, import_node_fs.readFileSync)(name, "utf-8") : "";
552
+ let loadModule = name;
553
+ let writtenContents = fileContents;
554
+ let didBabel = false;
208
555
  function attemptLoad({
209
- forceExports: forceExports2 = !1
556
+ forceExports: forceExports2 = false
210
557
  } = {}) {
211
- isDynamic && (writtenContents = forceExports2 ? transformAddExports((0, import_babelParse.babelParse)(esbuildit(fileContents, "modern"), name)) : fileContents, FS.writeFileSync(loadModule, writtenContents), import_esbuild.default.buildSync({
212
- ...esbuildOptions,
213
- entryPoints: [loadModule],
214
- outfile: loadModule,
215
- alias: {
216
- "react-native": require.resolve("@tamagui/react-native-web-lite")
217
- },
218
- bundle: !0,
219
- packages: "external",
220
- allowOverwrite: !0,
221
- // logLevel: 'silent',
222
- sourcemap: !1,
223
- loader: import_bundle.esbuildLoaderConfig
224
- })), process.env.DEBUG === "tamagui" && console.info("loadModule", loadModule, require.resolve(loadModule));
558
+ if (isDynamic) {
559
+ writtenContents = forceExports2 ? transformAddExports((0, import_babelParse.babelParse)(esbuildit(fileContents, "modern"), name)) : fileContents;
560
+ loadModule = getDynamicEvalOutfile(name, "cjs", writtenContents);
561
+ FS.ensureDirSync((0, import_node_path.dirname)(loadModule));
562
+ activeTempFiles.add(loadModule);
563
+ import_esbuild.default.buildSync({
564
+ ...esbuildOptions,
565
+ outfile: loadModule,
566
+ stdin: {
567
+ contents: writtenContents,
568
+ resolveDir: (0, import_node_path.dirname)(name),
569
+ sourcefile: name,
570
+ loader: getEsbuildStdinLoader(name)
571
+ },
572
+ alias: {
573
+ "react-native": resolvePackageEntry("@tamagui/react-native-web-lite", "esm"),
574
+ "@tamagui/react-native-web-lite": resolvePackageEntry("@tamagui/react-native-web-lite", "esm"),
575
+ "@tamagui/react-native-web-internals": resolvePackageEntry("@tamagui/react-native-web-internals", "esm")
576
+ },
577
+ bundle: true,
578
+ packages: "external",
579
+ allowOverwrite: true,
580
+ sourcemap: false,
581
+ loader: import_bundle.esbuildLoaderConfig
582
+ });
583
+ }
584
+ if (process.env.DEBUG === "tamagui") {
585
+ console.info(`loadModule`, loadModule, require.resolve(loadModule));
586
+ }
225
587
  const moduleResult = require(loadModule);
226
- forceExports2 || (0, import_registerRequire.setRequireResult)(name, moduleResult);
588
+ if (!forceExports2) {
589
+ (0, import_registerRequire.setRequireResult)(name, moduleResult);
590
+ }
227
591
  const nameToInfo = getComponentStaticConfigByName(name, interopDefaultExport(moduleResult));
228
592
  return {
229
593
  moduleName: name,
@@ -231,56 +595,74 @@ function loadComponentsInner(props, forceExports = !1) {
231
595
  };
232
596
  }
233
597
  const dispose = () => {
234
- isDynamic && FS.removeSync(loadModule);
598
+ if (isDynamic) {
599
+ FS.removeSync(loadModule);
600
+ activeTempFiles.delete(loadModule);
601
+ }
235
602
  };
236
603
  try {
237
604
  const res = attemptLoad({
238
- forceExports: !0
605
+ forceExports: true
239
606
  });
240
- return didBabel = !0, res;
607
+ didBabel = true;
608
+ return res;
241
609
  } catch (err) {
242
- console.info("babel err", err, writtenContents), writtenContents = fileContents, process.env.DEBUG?.startsWith("tamagui") && console.info("Error parsing babel likely", err);
610
+ console.info("babel err", err, writtenContents);
611
+ writtenContents = fileContents;
612
+ if (process.env.DEBUG?.startsWith("tamagui")) {
613
+ console.info(`Error parsing babel likely`, err);
614
+ }
243
615
  } finally {
244
616
  dispose();
245
617
  }
246
618
  try {
247
619
  return attemptLoad({
248
- forceExports: !1
620
+ forceExports: false
249
621
  });
250
622
  } catch (err) {
251
- return process.env.TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD && (console.info(`
252
-
623
+ if (process.env.TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD) {
624
+ console.info(`
253
625
  Tamagui attempted but failed to dynamically optimize components in:
254
626
  ${name}
255
- `), console.info(err), console.info(`At: ${loadModule}`, `
627
+ `);
628
+ console.info(err);
629
+ console.info(`At: ${loadModule}`, `
256
630
  didBabel: ${didBabel}`, `
257
631
  In:`, writtenContents, `
258
- isDynamic: `, isDynamic)), [];
632
+ isDynamic: `, isDynamic);
633
+ }
634
+ return [];
259
635
  } finally {
260
636
  dispose();
261
637
  }
262
638
  });
263
- return cacheComponents[key] = info, info;
639
+ cacheComponents[key] = info;
640
+ return info;
264
641
  } catch (err) {
265
- return console.info("Tamagui error bundling components", err.message, err.stack), null;
642
+ console.info(`Tamagui error bundling components`, err.message, err.stack);
643
+ return null;
266
644
  } finally {
267
645
  unregister();
268
646
  }
269
647
  }
270
- const esbuildit = (src, target) => import_esbuild.default.transformSync(src, {
271
- ...esbuildOptions,
272
- ...(target === "modern" && {
273
- target: "es2022",
274
- jsx: "automatic",
275
- loader: "tsx",
276
- platform: "neutral",
277
- format: "esm"
278
- })
279
- }).code;
648
+ const esbuildit = (src, target) => {
649
+ return import_esbuild.default.transformSync(src, {
650
+ ...esbuildTransformOptions,
651
+ ...(target === "modern" && {
652
+ target: "es2022",
653
+ jsx: "automatic",
654
+ loader: "tsx",
655
+ platform: "neutral",
656
+ format: "esm"
657
+ })
658
+ }).code;
659
+ };
280
660
  function getComponentStaticConfigByName(name, exported) {
281
661
  const components = {};
282
662
  try {
283
- if (!exported || typeof exported != "object" || Array.isArray(exported)) throw new Error(`Invalid export from package ${name}: ${typeof exported}`);
663
+ if (!exported || typeof exported !== "object" || Array.isArray(exported)) {
664
+ throw new Error(`Invalid export from package ${name}: ${typeof exported}`);
665
+ }
284
666
  for (const key in exported) {
285
667
  const found = getTamaguiComponent(key, exported[key]);
286
668
  if (found) {
@@ -294,13 +676,21 @@ function getComponentStaticConfigByName(name, exported) {
294
676
  }
295
677
  }
296
678
  } catch (err) {
297
- process.env.TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD && (console.error(`Tamagui failed getting components from ${name} (Disable error by setting environment variable TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD=1)`), console.error(err));
679
+ if (process.env.TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD) {
680
+ console.error(`Tamagui failed getting components from ${name} (Disable error by setting environment variable TAMAGUI_ENABLE_WARN_DYNAMIC_LOAD=1)`);
681
+ console.error(err);
682
+ }
298
683
  }
299
684
  return components;
300
685
  }
301
686
  function getTamaguiComponent(name, Component) {
302
- if (name[0].toUpperCase() !== name[0]) return;
303
- if (Component?.staticConfig) return Component;
687
+ if (name[0].toUpperCase() !== name[0]) {
688
+ return;
689
+ }
690
+ const staticConfig = Component?.staticConfig;
691
+ if (staticConfig) {
692
+ return Component;
693
+ }
304
694
  }
305
695
  function interopDefaultExport(mod) {
306
696
  return mod?.default ?? mod;
@@ -308,22 +698,32 @@ function interopDefaultExport(mod) {
308
698
  const cacheComponents = {};
309
699
  function transformAddExports(ast) {
310
700
  const usedNames = /* @__PURE__ */new Set();
311
- return (0, import_traverse.default)(ast, {
701
+ (0, import_traverse.default)(ast, {
312
702
  ExportNamedDeclaration(nodePath) {
313
- if (nodePath.node.specifiers) for (const spec of nodePath.node.specifiers) usedNames.add(t.isIdentifier(spec.exported) ? spec.exported.name : spec.exported.value);
703
+ if (nodePath.node.specifiers) {
704
+ for (const spec of nodePath.node.specifiers) {
705
+ usedNames.add(t.isIdentifier(spec.exported) ? spec.exported.name : spec.exported.value);
706
+ }
707
+ }
314
708
  }
315
- }), (0, import_traverse.default)(ast, {
709
+ });
710
+ (0, import_traverse.default)(ast, {
316
711
  VariableDeclaration(nodePath) {
317
712
  if (!t.isProgram(nodePath.parent)) return;
318
713
  const decs = nodePath.node.declarations;
319
714
  if (decs.length > 1) return;
320
715
  const [dec] = decs;
321
- t.isIdentifier(dec.id) && dec.init && (usedNames.has(dec.id.name) || (usedNames.add(dec.id.name), nodePath.replaceWith(t.exportNamedDeclaration(t.variableDeclaration("let", [dec]), [t.exportSpecifier(t.identifier(dec.id.name), t.identifier(dec.id.name))]))));
716
+ if (!t.isIdentifier(dec.id)) return;
717
+ if (!dec.init) return;
718
+ if (usedNames.has(dec.id.name)) return;
719
+ usedNames.add(dec.id.name);
720
+ nodePath.replaceWith(t.exportNamedDeclaration(t.variableDeclaration("let", [dec]), [t.exportSpecifier(t.identifier(dec.id.name), t.identifier(dec.id.name))]));
322
721
  }
323
- }), (0, import_generator.default)(ast, {
324
- concise: !1,
722
+ });
723
+ return (0, import_generator.default)(ast, {
724
+ concise: false,
325
725
  filename: "test.tsx",
326
- retainLines: !1,
327
- sourceMaps: !1
726
+ retainLines: false,
727
+ sourceMaps: false
328
728
  }).code;
329
729
  }