@tamagui/static 1.14.9 → 1.15.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 (39) hide show
  1. package/dist/cjs/extractor/bundleConfig.js +343 -0
  2. package/dist/cjs/extractor/bundleConfig.js.map +7 -0
  3. package/dist/cjs/extractor/createExtractor.js.map +2 -2
  4. package/dist/cjs/extractor/generateTamaguiConfig.js +83 -0
  5. package/dist/cjs/extractor/generateTamaguiConfig.js.map +7 -0
  6. package/dist/cjs/extractor/loadTamagui.js +76 -292
  7. package/dist/cjs/extractor/loadTamagui.js.map +3 -3
  8. package/dist/cjs/types.js.map +1 -1
  9. package/dist/esm/extractor/bundleConfig.js +307 -0
  10. package/dist/esm/extractor/bundleConfig.js.map +7 -0
  11. package/dist/esm/extractor/bundleConfig.mjs +307 -0
  12. package/dist/esm/extractor/bundleConfig.mjs.map +7 -0
  13. package/dist/esm/extractor/createExtractor.js.map +2 -2
  14. package/dist/esm/extractor/createExtractor.mjs.map +2 -2
  15. package/dist/esm/extractor/generateTamaguiConfig.js +49 -0
  16. package/dist/esm/extractor/generateTamaguiConfig.js.map +7 -0
  17. package/dist/esm/extractor/generateTamaguiConfig.mjs +49 -0
  18. package/dist/esm/extractor/generateTamaguiConfig.mjs.map +7 -0
  19. package/dist/esm/extractor/loadTamagui.js +76 -290
  20. package/dist/esm/extractor/loadTamagui.js.map +2 -2
  21. package/dist/esm/extractor/loadTamagui.mjs +76 -290
  22. package/dist/esm/extractor/loadTamagui.mjs.map +2 -2
  23. package/package.json +16 -16
  24. package/src/extractor/bundleConfig.ts +389 -0
  25. package/src/extractor/createExtractor.ts +3 -3
  26. package/src/extractor/generateTamaguiConfig.ts +65 -0
  27. package/src/extractor/loadTamagui.ts +81 -370
  28. package/src/types.ts +2 -3
  29. package/types/extractor/bundleConfig.d.ts +35 -0
  30. package/types/extractor/bundleConfig.d.ts.map +1 -0
  31. package/types/extractor/createExtractor.d.ts +2 -2
  32. package/types/extractor/createExtractor.d.ts.map +1 -1
  33. package/types/extractor/extractHelpers.d.ts +2 -2
  34. package/types/extractor/generateTamaguiConfig.d.ts +3 -0
  35. package/types/extractor/generateTamaguiConfig.d.ts.map +1 -0
  36. package/types/extractor/loadTamagui.d.ts +6 -21
  37. package/types/extractor/loadTamagui.d.ts.map +1 -1
  38. package/types/types.d.ts +1 -1
  39. package/types/types.d.ts.map +1 -1
@@ -0,0 +1,307 @@
1
+ import { readFileSync } from "fs";
2
+ import path, { basename, dirname, extname, join, relative, sep } from "path";
3
+ import generate from "@babel/generator";
4
+ import traverse from "@babel/traverse";
5
+ import * as t from "@babel/types";
6
+ import { Color, colorLog } from "@tamagui/cli-color";
7
+ import esbuild from "esbuild";
8
+ import { ensureDir, removeSync, writeFileSync } from "fs-extra";
9
+ import { babelParse } from "./babelParse.js";
10
+ import { bundle } from "./bundle.js";
11
+ let loggedOutputInfo = false;
12
+ const external = [
13
+ "@tamagui/core",
14
+ "@tamagui/web",
15
+ "@tamagui/core-node",
16
+ "react",
17
+ "react-dom",
18
+ "react-native-svg"
19
+ ];
20
+ const esbuildOptions = {
21
+ loader: "tsx",
22
+ target: "es2018",
23
+ format: "cjs",
24
+ jsx: "transform",
25
+ platform: "node"
26
+ };
27
+ async function bundleConfig(props) {
28
+ var _a, _b;
29
+ const configEntry = props.config ? join(process.cwd(), props.config) : "";
30
+ const tmpDir = join(process.cwd(), ".tamagui");
31
+ const configOutPath = join(tmpDir, `tamagui.config.cjs`);
32
+ const baseComponents = props.components.filter((x) => x !== "@tamagui/core");
33
+ const componentOutPaths = baseComponents.map(
34
+ (componentModule) => join(
35
+ tmpDir,
36
+ `${componentModule.split(sep).join("-").replace(/[^a-z0-9]+/gi, "")}-components.config.cjs`
37
+ )
38
+ );
39
+ if (process.env.NODE_ENV === "development" && ((_a = process.env.DEBUG) == null ? void 0 : _a.startsWith("tamagui"))) {
40
+ console.log(`Building config entry`, configEntry);
41
+ }
42
+ try {
43
+ await ensureDir(tmpDir);
44
+ } catch {
45
+ }
46
+ if (!loggedOutputInfo) {
47
+ loggedOutputInfo = true;
48
+ colorLog(
49
+ Color.FgYellow,
50
+ `
51
+ Tamagui built config and components:`
52
+ );
53
+ colorLog(
54
+ Color.Dim,
55
+ `
56
+ Config .${sep}${relative(process.cwd(), configOutPath)}
57
+ Components ${[
58
+ ...componentOutPaths.map((p) => `.${sep}${relative(process.cwd(), p)}`)
59
+ ].join("\n ")}
60
+ `
61
+ );
62
+ }
63
+ await Promise.all([
64
+ props.config ? bundle({
65
+ entryPoints: [configEntry],
66
+ external,
67
+ outfile: configOutPath
68
+ }) : null,
69
+ ...baseComponents.map((componentModule, i) => {
70
+ return bundle({
71
+ entryPoints: [componentModule],
72
+ resolvePlatformSpecificEntries: true,
73
+ external,
74
+ outfile: componentOutPaths[i]
75
+ });
76
+ })
77
+ ]);
78
+ delete require.cache[path.resolve(configOutPath)];
79
+ const out = require(configOutPath);
80
+ const config = out.default || out;
81
+ if (!config) {
82
+ throw new Error(`No config: ${config}`);
83
+ }
84
+ let components = loadComponents({
85
+ ...props,
86
+ components: componentOutPaths
87
+ });
88
+ if (!components) {
89
+ throw new Error(`No components found: ${componentOutPaths.join(", ")}`);
90
+ }
91
+ for (const component of components) {
92
+ component.moduleName = baseComponents[componentOutPaths.indexOf(component.moduleName)];
93
+ }
94
+ const coreComponents = loadComponents({
95
+ ...props,
96
+ components: ["@tamagui/core-node"]
97
+ });
98
+ if (coreComponents) {
99
+ coreComponents[0].moduleName = "@tamagui/core";
100
+ components = [...components, ...coreComponents];
101
+ }
102
+ if (process.env.NODE_ENV === "development" && ((_b = process.env.DEBUG) == null ? void 0 : _b.startsWith("tamagui"))) {
103
+ console.log("Loaded components", components);
104
+ }
105
+ return {
106
+ components,
107
+ nameToPaths: {},
108
+ tamaguiConfig: config
109
+ };
110
+ }
111
+ function loadComponents(props) {
112
+ const componentsModules = props.components;
113
+ const key = componentsModules.join("");
114
+ if (cacheComponents[key]) {
115
+ return cacheComponents[key];
116
+ }
117
+ try {
118
+ const info = componentsModules.flatMap((name) => {
119
+ var _a;
120
+ const extension = extname(name);
121
+ const isLocal = Boolean(extension);
122
+ const isDynamic = isLocal && !props.config;
123
+ if (isDynamic && !process.env.TAMAGUI_ENABLE_DYNAMIC_LOAD) {
124
+ return [];
125
+ }
126
+ const fileContents = isDynamic ? readFileSync(name, "utf-8") : "";
127
+ const loadModule = isDynamic ? join(dirname(name), `.tamagui-dynamic-eval-${basename(name)}.tsx`) : name;
128
+ let writtenContents = fileContents;
129
+ let didBabel = false;
130
+ function attemptLoad({ forceExports = false } = {}) {
131
+ if (isDynamic) {
132
+ writtenContents = forceExports ? esbuildit(
133
+ transformAddExports(babelParse(esbuildit(fileContents, "modern")))
134
+ ) : esbuildit(fileContents);
135
+ writeFileSync(loadModule, writtenContents);
136
+ }
137
+ if (process.env.DEBUG === "tamagui") {
138
+ console.log(`loadModule`, loadModule, require.resolve(loadModule));
139
+ }
140
+ return {
141
+ moduleName: name,
142
+ nameToInfo: getComponentStaticConfigByName(
143
+ name,
144
+ interopDefaultExport(require(loadModule))
145
+ )
146
+ };
147
+ }
148
+ const dispose = () => {
149
+ isDynamic && removeSync(loadModule);
150
+ };
151
+ try {
152
+ const res = attemptLoad({
153
+ forceExports: true
154
+ });
155
+ didBabel = true;
156
+ return res;
157
+ } catch (err) {
158
+ console.log("babel err", err, writtenContents);
159
+ writtenContents = fileContents;
160
+ if ((_a = process.env.DEBUG) == null ? void 0 : _a.startsWith("tamagui")) {
161
+ console.log(`Error parsing babel likely`, err);
162
+ }
163
+ } finally {
164
+ dispose();
165
+ }
166
+ try {
167
+ return attemptLoad({
168
+ forceExports: false
169
+ });
170
+ } catch (err) {
171
+ if (!process.env.TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD) {
172
+ console.log(`
173
+
174
+ Tamagui attempted but failed to dynamically load components in:
175
+ ${name}
176
+
177
+ This will leave some styled() tags unoptimized.
178
+ Disable this file (or dynamic loading altogether):
179
+
180
+ disableExtractFoundComponents: ['${name}'] | true
181
+
182
+ Quiet this warning with environment variable:
183
+
184
+ TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD=1
185
+
186
+ `);
187
+ console.log(err);
188
+ console.log(
189
+ `At: ${loadModule}`,
190
+ `
191
+ didBabel: ${didBabel}`,
192
+ `
193
+ In:`,
194
+ writtenContents,
195
+ `
196
+ isDynamic: `,
197
+ isDynamic
198
+ );
199
+ }
200
+ return [];
201
+ } finally {
202
+ dispose();
203
+ }
204
+ });
205
+ cacheComponents[key] = info;
206
+ return info;
207
+ } catch (err) {
208
+ console.log(`Tamagui error bundling components`, err.message, err.stack);
209
+ return null;
210
+ }
211
+ }
212
+ const esbuildit = (src, target) => {
213
+ return esbuild.transformSync(src, {
214
+ ...esbuildOptions,
215
+ ...target === "modern" && {
216
+ target: "es2022",
217
+ jsx: "transform",
218
+ loader: "tsx",
219
+ platform: "neutral",
220
+ format: "esm"
221
+ }
222
+ }).code;
223
+ };
224
+ function getComponentStaticConfigByName(name, exported) {
225
+ const components = {};
226
+ try {
227
+ if (!exported || typeof exported !== "object" || Array.isArray(exported)) {
228
+ throw new Error(`Invalid export from package ${name}: ${typeof exported}`);
229
+ }
230
+ for (const key in exported) {
231
+ const found = getTamaguiComponent(key, exported[key]);
232
+ if (found) {
233
+ const { Component, ...sc } = found.staticConfig;
234
+ components[key] = { staticConfig: sc };
235
+ }
236
+ }
237
+ } catch (err) {
238
+ if (process.env.TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD !== "1") {
239
+ console.error(
240
+ `Tamagui failed getting from ${name} (Disable error by setting environment variable TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD=1)`
241
+ );
242
+ console.error(err);
243
+ }
244
+ }
245
+ return components;
246
+ }
247
+ function getTamaguiComponent(name, Component) {
248
+ if (name[0].toUpperCase() !== name[0]) {
249
+ return;
250
+ }
251
+ const staticConfig = Component == null ? void 0 : Component.staticConfig;
252
+ if (staticConfig) {
253
+ return Component;
254
+ }
255
+ }
256
+ function interopDefaultExport(mod) {
257
+ return (mod == null ? void 0 : mod.default) ?? mod;
258
+ }
259
+ const cacheComponents = {};
260
+ function transformAddExports(ast) {
261
+ const usedNames = /* @__PURE__ */ new Set();
262
+ traverse(ast, {
263
+ ExportNamedDeclaration(nodePath) {
264
+ if (nodePath.node.specifiers) {
265
+ for (const spec of nodePath.node.specifiers) {
266
+ usedNames.add(
267
+ t.isIdentifier(spec.exported) ? spec.exported.name : spec.exported.value
268
+ );
269
+ }
270
+ }
271
+ }
272
+ });
273
+ traverse(ast, {
274
+ VariableDeclaration(nodePath) {
275
+ if (!t.isProgram(nodePath.parent))
276
+ return;
277
+ const decs = nodePath.node.declarations;
278
+ if (decs.length > 1)
279
+ return;
280
+ const [dec] = decs;
281
+ if (!t.isIdentifier(dec.id))
282
+ return;
283
+ if (!dec.init)
284
+ return;
285
+ if (usedNames.has(dec.id.name))
286
+ return;
287
+ usedNames.add(dec.id.name);
288
+ nodePath.replaceWith(
289
+ t.exportNamedDeclaration(t.variableDeclaration("let", [dec]), [
290
+ t.exportSpecifier(t.identifier(dec.id.name), t.identifier(dec.id.name))
291
+ ])
292
+ );
293
+ }
294
+ });
295
+ return generate(ast, {
296
+ concise: false,
297
+ filename: "test.tsx",
298
+ retainLines: false,
299
+ sourceMaps: false
300
+ }).code;
301
+ }
302
+ export {
303
+ bundleConfig,
304
+ esbuildOptions,
305
+ loadComponents
306
+ };
307
+ //# sourceMappingURL=bundleConfig.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/extractor/bundleConfig.ts"],
4
+ "sourcesContent": ["import { readFileSync } from 'fs'\nimport path, { basename, dirname, extname, join, relative, sep } from 'path'\n\nimport generate from '@babel/generator'\nimport traverse from '@babel/traverse'\nimport * as t from '@babel/types'\nimport { Color, colorLog } from '@tamagui/cli-color'\nimport type { StaticConfigParsed, TamaguiInternalConfig } from '@tamagui/web'\nimport esbuild from 'esbuild'\nimport { ensureDir, removeSync, writeFileSync } from 'fs-extra'\n\nimport { babelParse } from './babelParse.js'\nimport { bundle } from './bundle.js'\n\nlet loggedOutputInfo = false\n\ntype NameToPaths = {\n [key: string]: Set<string>\n}\n\nexport type LoadedComponents = {\n moduleName: string\n nameToInfo: Record<\n string,\n {\n staticConfig: StaticConfigParsed\n }\n >\n}\n\nexport type TamaguiProjectInfo = {\n components: LoadedComponents[]\n tamaguiConfig: TamaguiInternalConfig\n nameToPaths: NameToPaths\n}\n\nexport type Props = {\n components: string[]\n config?: string\n forceExports?: boolean\n}\n\nconst external = [\n '@tamagui/core',\n '@tamagui/web',\n '@tamagui/core-node',\n 'react',\n 'react-dom',\n 'react-native-svg',\n]\n\nexport const esbuildOptions = {\n loader: 'tsx',\n target: 'es2018',\n format: 'cjs',\n jsx: 'transform',\n platform: 'node',\n} as const\n\nexport async function bundleConfig(props: Props) {\n const configEntry = props.config ? join(process.cwd(), props.config) : ''\n const tmpDir = join(process.cwd(), '.tamagui')\n const configOutPath = join(tmpDir, `tamagui.config.cjs`)\n const baseComponents = props.components.filter((x) => x !== '@tamagui/core')\n const componentOutPaths = baseComponents.map((componentModule) =>\n join(\n tmpDir,\n `${componentModule\n .split(sep)\n .join('-')\n .replace(/[^a-z0-9]+/gi, '')}-components.config.cjs`\n )\n )\n\n if (\n process.env.NODE_ENV === 'development' &&\n process.env.DEBUG?.startsWith('tamagui')\n ) {\n console.log(`Building config entry`, configEntry)\n }\n\n // build them to node-compat versions\n try {\n await ensureDir(tmpDir)\n } catch {\n //\n }\n\n if (!loggedOutputInfo) {\n loggedOutputInfo = true\n colorLog(\n Color.FgYellow,\n `\n Tamagui built config and components:`\n )\n colorLog(\n Color.Dim,\n `\n Config .${sep}${relative(process.cwd(), configOutPath)}\n Components ${[\n ...componentOutPaths.map((p) => `.${sep}${relative(process.cwd(), p)}`),\n ].join('\\n ')}\n `\n )\n }\n\n await Promise.all([\n props.config\n ? bundle({\n entryPoints: [configEntry],\n external,\n outfile: configOutPath,\n })\n : null,\n ...baseComponents.map((componentModule, i) => {\n return bundle({\n entryPoints: [componentModule],\n resolvePlatformSpecificEntries: true,\n external,\n outfile: componentOutPaths[i],\n })\n }),\n ])\n\n // get around node.js's module cache to get the new config...\n delete require.cache[path.resolve(configOutPath)]\n const out = require(configOutPath)\n const config = out.default || out\n if (!config) {\n throw new Error(`No config: ${config}`)\n }\n\n let components = loadComponents({\n ...props,\n components: componentOutPaths,\n })\n\n if (!components) {\n throw new Error(`No components found: ${componentOutPaths.join(', ')}`)\n }\n\n // map from built back to original module names\n for (const component of components) {\n component.moduleName = baseComponents[componentOutPaths.indexOf(component.moduleName)]\n\n // if (!component.moduleName) {\n // throw new Error(`Tamagui internal err`)\n // }\n }\n\n // always load core so we can optimize if directly importing\n const coreComponents = loadComponents({\n ...props,\n components: ['@tamagui/core-node'],\n })\n if (coreComponents) {\n coreComponents[0].moduleName = '@tamagui/core'\n components = [...components, ...coreComponents]\n }\n\n if (\n process.env.NODE_ENV === 'development' &&\n process.env.DEBUG?.startsWith('tamagui')\n ) {\n console.log('Loaded components', components)\n }\n return {\n components,\n nameToPaths: {},\n tamaguiConfig: config,\n }\n}\n\nexport function loadComponents(props: Props): null | LoadedComponents[] {\n const componentsModules = props.components\n const key = componentsModules.join('')\n if (cacheComponents[key]) {\n return cacheComponents[key]\n }\n try {\n const info: LoadedComponents[] = componentsModules.flatMap((name) => {\n const extension = extname(name)\n const isLocal = Boolean(extension)\n // during props.config pass we are passing in pre-bundled stuff\n const isDynamic = isLocal && !props.config\n\n if (isDynamic && !process.env.TAMAGUI_ENABLE_DYNAMIC_LOAD) {\n return []\n }\n\n const fileContents = isDynamic ? readFileSync(name, 'utf-8') : ''\n const loadModule = isDynamic\n ? join(dirname(name), `.tamagui-dynamic-eval-${basename(name)}.tsx`)\n : name\n let writtenContents = fileContents\n let didBabel = false\n\n function attemptLoad({ forceExports = false } = {}) {\n // need to write to tsx to enable reading it properly (:/ esbuild-register)\n if (isDynamic) {\n writtenContents = forceExports\n ? esbuildit(\n transformAddExports(babelParse(esbuildit(fileContents, 'modern')))\n )\n : esbuildit(fileContents)\n\n writeFileSync(loadModule, writtenContents)\n }\n\n if (process.env.DEBUG === 'tamagui') {\n console.log(`loadModule`, loadModule, require.resolve(loadModule))\n }\n\n return {\n moduleName: name,\n nameToInfo: getComponentStaticConfigByName(\n name,\n interopDefaultExport(require(loadModule))\n ),\n }\n }\n\n const dispose = () => {\n isDynamic && removeSync(loadModule)\n }\n\n try {\n const res = attemptLoad({\n forceExports: true,\n })\n didBabel = true\n return res\n } catch (err) {\n console.log('babel err', err, writtenContents)\n // ok\n writtenContents = fileContents\n if (process.env.DEBUG?.startsWith('tamagui')) {\n console.log(`Error parsing babel likely`, err)\n }\n } finally {\n dispose()\n }\n\n try {\n return attemptLoad({\n forceExports: false,\n })\n } catch (err) {\n if (!process.env.TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD) {\n console.log(`\n\nTamagui attempted but failed to dynamically load components in:\n ${name}\n\nThis will leave some styled() tags unoptimized.\nDisable this file (or dynamic loading altogether):\n\n disableExtractFoundComponents: ['${name}'] | true\n\nQuiet this warning with environment variable:\n \n TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD=1\n\n`)\n console.log(err)\n console.log(\n `At: ${loadModule}`,\n `\\ndidBabel: ${didBabel}`,\n `\\nIn:`,\n writtenContents,\n `\\nisDynamic: `,\n isDynamic\n )\n }\n return []\n } finally {\n dispose()\n }\n })\n cacheComponents[key] = info\n return info\n } catch (err: any) {\n console.log(`Tamagui error bundling components`, err.message, err.stack)\n return null\n }\n}\n\nconst esbuildit = (src: string, target?: 'modern') => {\n return esbuild.transformSync(src, {\n ...esbuildOptions,\n ...(target === 'modern' && {\n target: 'es2022',\n jsx: 'transform',\n loader: 'tsx',\n platform: 'neutral',\n format: 'esm',\n }),\n }).code\n}\n\nfunction getComponentStaticConfigByName(name: string, exported: any) {\n const components: Record<string, { staticConfig: StaticConfigParsed }> = {}\n try {\n if (!exported || typeof exported !== 'object' || Array.isArray(exported)) {\n throw new Error(`Invalid export from package ${name}: ${typeof exported}`)\n }\n for (const key in exported) {\n const found = getTamaguiComponent(key, exported[key])\n if (found) {\n // remove non-stringifyable\n const { Component, ...sc } = found.staticConfig\n components[key] = { staticConfig: sc }\n }\n }\n } catch (err) {\n if (process.env.TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD !== '1') {\n console.error(\n `Tamagui failed getting from ${name} (Disable error by setting environment variable TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD=1)`\n )\n console.error(err)\n }\n }\n return components\n}\n\nfunction getTamaguiComponent(\n name: string,\n Component: any\n): undefined | { staticConfig: StaticConfigParsed } {\n if (name[0].toUpperCase() !== name[0]) {\n return\n }\n const staticConfig = Component?.staticConfig as StaticConfigParsed | undefined\n if (staticConfig) {\n return Component\n }\n}\n\nfunction interopDefaultExport(mod: any) {\n return mod?.default ?? mod\n}\n\nconst cacheComponents: Record<string, LoadedComponents[]> = {}\n\nfunction transformAddExports(ast: t.File) {\n const usedNames = new Set<string>()\n\n // avoid clobbering\n // @ts-ignore\n traverse(ast, {\n ExportNamedDeclaration(nodePath) {\n if (nodePath.node.specifiers) {\n for (const spec of nodePath.node.specifiers) {\n usedNames.add(\n t.isIdentifier(spec.exported) ? spec.exported.name : spec.exported.value\n )\n }\n }\n },\n })\n\n // @ts-ignore\n traverse(ast, {\n VariableDeclaration(nodePath) {\n // top level only\n if (!t.isProgram(nodePath.parent)) return\n const decs = nodePath.node.declarations\n if (decs.length > 1) return\n const [dec] = decs\n if (!t.isIdentifier(dec.id)) return\n if (!dec.init) return\n if (usedNames.has(dec.id.name)) return\n usedNames.add(dec.id.name)\n nodePath.replaceWith(\n t.exportNamedDeclaration(t.variableDeclaration('let', [dec]), [\n t.exportSpecifier(t.identifier(dec.id.name), t.identifier(dec.id.name)),\n ])\n )\n },\n })\n\n // @ts-ignore\n return generate(ast as any, {\n concise: false,\n filename: 'test.tsx',\n retainLines: false,\n sourceMaps: false,\n }).code\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,307 @@
1
+ import { readFileSync } from "fs";
2
+ import path, { basename, dirname, extname, join, relative, sep } from "path";
3
+ import generate from "@babel/generator";
4
+ import traverse from "@babel/traverse";
5
+ import * as t from "@babel/types";
6
+ import { Color, colorLog } from "@tamagui/cli-color";
7
+ import esbuild from "esbuild";
8
+ import { ensureDir, removeSync, writeFileSync } from "fs-extra";
9
+ import { babelParse } from "./babelParse.js";
10
+ import { bundle } from "./bundle.js";
11
+ let loggedOutputInfo = false;
12
+ const external = [
13
+ "@tamagui/core",
14
+ "@tamagui/web",
15
+ "@tamagui/core-node",
16
+ "react",
17
+ "react-dom",
18
+ "react-native-svg"
19
+ ];
20
+ const esbuildOptions = {
21
+ loader: "tsx",
22
+ target: "es2018",
23
+ format: "cjs",
24
+ jsx: "transform",
25
+ platform: "node"
26
+ };
27
+ async function bundleConfig(props) {
28
+ var _a, _b;
29
+ const configEntry = props.config ? join(process.cwd(), props.config) : "";
30
+ const tmpDir = join(process.cwd(), ".tamagui");
31
+ const configOutPath = join(tmpDir, `tamagui.config.cjs`);
32
+ const baseComponents = props.components.filter((x) => x !== "@tamagui/core");
33
+ const componentOutPaths = baseComponents.map(
34
+ (componentModule) => join(
35
+ tmpDir,
36
+ `${componentModule.split(sep).join("-").replace(/[^a-z0-9]+/gi, "")}-components.config.cjs`
37
+ )
38
+ );
39
+ if (process.env.NODE_ENV === "development" && ((_a = process.env.DEBUG) == null ? void 0 : _a.startsWith("tamagui"))) {
40
+ console.log(`Building config entry`, configEntry);
41
+ }
42
+ try {
43
+ await ensureDir(tmpDir);
44
+ } catch {
45
+ }
46
+ if (!loggedOutputInfo) {
47
+ loggedOutputInfo = true;
48
+ colorLog(
49
+ Color.FgYellow,
50
+ `
51
+ Tamagui built config and components:`
52
+ );
53
+ colorLog(
54
+ Color.Dim,
55
+ `
56
+ Config .${sep}${relative(process.cwd(), configOutPath)}
57
+ Components ${[
58
+ ...componentOutPaths.map((p) => `.${sep}${relative(process.cwd(), p)}`)
59
+ ].join("\n ")}
60
+ `
61
+ );
62
+ }
63
+ await Promise.all([
64
+ props.config ? bundle({
65
+ entryPoints: [configEntry],
66
+ external,
67
+ outfile: configOutPath
68
+ }) : null,
69
+ ...baseComponents.map((componentModule, i) => {
70
+ return bundle({
71
+ entryPoints: [componentModule],
72
+ resolvePlatformSpecificEntries: true,
73
+ external,
74
+ outfile: componentOutPaths[i]
75
+ });
76
+ })
77
+ ]);
78
+ delete require.cache[path.resolve(configOutPath)];
79
+ const out = require(configOutPath);
80
+ const config = out.default || out;
81
+ if (!config) {
82
+ throw new Error(`No config: ${config}`);
83
+ }
84
+ let components = loadComponents({
85
+ ...props,
86
+ components: componentOutPaths
87
+ });
88
+ if (!components) {
89
+ throw new Error(`No components found: ${componentOutPaths.join(", ")}`);
90
+ }
91
+ for (const component of components) {
92
+ component.moduleName = baseComponents[componentOutPaths.indexOf(component.moduleName)];
93
+ }
94
+ const coreComponents = loadComponents({
95
+ ...props,
96
+ components: ["@tamagui/core-node"]
97
+ });
98
+ if (coreComponents) {
99
+ coreComponents[0].moduleName = "@tamagui/core";
100
+ components = [...components, ...coreComponents];
101
+ }
102
+ if (process.env.NODE_ENV === "development" && ((_b = process.env.DEBUG) == null ? void 0 : _b.startsWith("tamagui"))) {
103
+ console.log("Loaded components", components);
104
+ }
105
+ return {
106
+ components,
107
+ nameToPaths: {},
108
+ tamaguiConfig: config
109
+ };
110
+ }
111
+ function loadComponents(props) {
112
+ const componentsModules = props.components;
113
+ const key = componentsModules.join("");
114
+ if (cacheComponents[key]) {
115
+ return cacheComponents[key];
116
+ }
117
+ try {
118
+ const info = componentsModules.flatMap((name) => {
119
+ var _a;
120
+ const extension = extname(name);
121
+ const isLocal = Boolean(extension);
122
+ const isDynamic = isLocal && !props.config;
123
+ if (isDynamic && !process.env.TAMAGUI_ENABLE_DYNAMIC_LOAD) {
124
+ return [];
125
+ }
126
+ const fileContents = isDynamic ? readFileSync(name, "utf-8") : "";
127
+ const loadModule = isDynamic ? join(dirname(name), `.tamagui-dynamic-eval-${basename(name)}.tsx`) : name;
128
+ let writtenContents = fileContents;
129
+ let didBabel = false;
130
+ function attemptLoad({ forceExports = false } = {}) {
131
+ if (isDynamic) {
132
+ writtenContents = forceExports ? esbuildit(
133
+ transformAddExports(babelParse(esbuildit(fileContents, "modern")))
134
+ ) : esbuildit(fileContents);
135
+ writeFileSync(loadModule, writtenContents);
136
+ }
137
+ if (process.env.DEBUG === "tamagui") {
138
+ console.log(`loadModule`, loadModule, require.resolve(loadModule));
139
+ }
140
+ return {
141
+ moduleName: name,
142
+ nameToInfo: getComponentStaticConfigByName(
143
+ name,
144
+ interopDefaultExport(require(loadModule))
145
+ )
146
+ };
147
+ }
148
+ const dispose = () => {
149
+ isDynamic && removeSync(loadModule);
150
+ };
151
+ try {
152
+ const res = attemptLoad({
153
+ forceExports: true
154
+ });
155
+ didBabel = true;
156
+ return res;
157
+ } catch (err) {
158
+ console.log("babel err", err, writtenContents);
159
+ writtenContents = fileContents;
160
+ if ((_a = process.env.DEBUG) == null ? void 0 : _a.startsWith("tamagui")) {
161
+ console.log(`Error parsing babel likely`, err);
162
+ }
163
+ } finally {
164
+ dispose();
165
+ }
166
+ try {
167
+ return attemptLoad({
168
+ forceExports: false
169
+ });
170
+ } catch (err) {
171
+ if (!process.env.TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD) {
172
+ console.log(`
173
+
174
+ Tamagui attempted but failed to dynamically load components in:
175
+ ${name}
176
+
177
+ This will leave some styled() tags unoptimized.
178
+ Disable this file (or dynamic loading altogether):
179
+
180
+ disableExtractFoundComponents: ['${name}'] | true
181
+
182
+ Quiet this warning with environment variable:
183
+
184
+ TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD=1
185
+
186
+ `);
187
+ console.log(err);
188
+ console.log(
189
+ `At: ${loadModule}`,
190
+ `
191
+ didBabel: ${didBabel}`,
192
+ `
193
+ In:`,
194
+ writtenContents,
195
+ `
196
+ isDynamic: `,
197
+ isDynamic
198
+ );
199
+ }
200
+ return [];
201
+ } finally {
202
+ dispose();
203
+ }
204
+ });
205
+ cacheComponents[key] = info;
206
+ return info;
207
+ } catch (err) {
208
+ console.log(`Tamagui error bundling components`, err.message, err.stack);
209
+ return null;
210
+ }
211
+ }
212
+ const esbuildit = (src, target) => {
213
+ return esbuild.transformSync(src, {
214
+ ...esbuildOptions,
215
+ ...target === "modern" && {
216
+ target: "es2022",
217
+ jsx: "transform",
218
+ loader: "tsx",
219
+ platform: "neutral",
220
+ format: "esm"
221
+ }
222
+ }).code;
223
+ };
224
+ function getComponentStaticConfigByName(name, exported) {
225
+ const components = {};
226
+ try {
227
+ if (!exported || typeof exported !== "object" || Array.isArray(exported)) {
228
+ throw new Error(`Invalid export from package ${name}: ${typeof exported}`);
229
+ }
230
+ for (const key in exported) {
231
+ const found = getTamaguiComponent(key, exported[key]);
232
+ if (found) {
233
+ const { Component, ...sc } = found.staticConfig;
234
+ components[key] = { staticConfig: sc };
235
+ }
236
+ }
237
+ } catch (err) {
238
+ if (process.env.TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD !== "1") {
239
+ console.error(
240
+ `Tamagui failed getting from ${name} (Disable error by setting environment variable TAMAGUI_DISABLE_WARN_DYNAMIC_LOAD=1)`
241
+ );
242
+ console.error(err);
243
+ }
244
+ }
245
+ return components;
246
+ }
247
+ function getTamaguiComponent(name, Component) {
248
+ if (name[0].toUpperCase() !== name[0]) {
249
+ return;
250
+ }
251
+ const staticConfig = Component == null ? void 0 : Component.staticConfig;
252
+ if (staticConfig) {
253
+ return Component;
254
+ }
255
+ }
256
+ function interopDefaultExport(mod) {
257
+ return (mod == null ? void 0 : mod.default) ?? mod;
258
+ }
259
+ const cacheComponents = {};
260
+ function transformAddExports(ast) {
261
+ const usedNames = /* @__PURE__ */ new Set();
262
+ traverse(ast, {
263
+ ExportNamedDeclaration(nodePath) {
264
+ if (nodePath.node.specifiers) {
265
+ for (const spec of nodePath.node.specifiers) {
266
+ usedNames.add(
267
+ t.isIdentifier(spec.exported) ? spec.exported.name : spec.exported.value
268
+ );
269
+ }
270
+ }
271
+ }
272
+ });
273
+ traverse(ast, {
274
+ VariableDeclaration(nodePath) {
275
+ if (!t.isProgram(nodePath.parent))
276
+ return;
277
+ const decs = nodePath.node.declarations;
278
+ if (decs.length > 1)
279
+ return;
280
+ const [dec] = decs;
281
+ if (!t.isIdentifier(dec.id))
282
+ return;
283
+ if (!dec.init)
284
+ return;
285
+ if (usedNames.has(dec.id.name))
286
+ return;
287
+ usedNames.add(dec.id.name);
288
+ nodePath.replaceWith(
289
+ t.exportNamedDeclaration(t.variableDeclaration("let", [dec]), [
290
+ t.exportSpecifier(t.identifier(dec.id.name), t.identifier(dec.id.name))
291
+ ])
292
+ );
293
+ }
294
+ });
295
+ return generate(ast, {
296
+ concise: false,
297
+ filename: "test.tsx",
298
+ retainLines: false,
299
+ sourceMaps: false
300
+ }).code;
301
+ }
302
+ export {
303
+ bundleConfig,
304
+ esbuildOptions,
305
+ loadComponents
306
+ };
307
+ //# sourceMappingURL=bundleConfig.mjs.map