@tamagui/static 1.0.1-beta.99 → 1.0.1-rc.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.
- package/dist/{cjs/constants.js → constants.js} +9 -4
- package/dist/constants.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/accessSafe.js +14 -2
- package/dist/{esm/extractor → extractor}/accessSafe.js.map +2 -2
- package/dist/{cjs/extractor → extractor}/babelParse.js +5 -1
- package/dist/extractor/babelParse.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/buildClassName.js +40 -9
- package/dist/extractor/buildClassName.js.map +7 -0
- package/dist/extractor/bundle.js +117 -0
- package/dist/extractor/bundle.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/createEvaluator.js +11 -8
- package/dist/extractor/createEvaluator.js.map +7 -0
- package/dist/extractor/createExtractor.js +1623 -0
- package/dist/extractor/createExtractor.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/ensureImportingConcat.js +18 -6
- package/dist/extractor/ensureImportingConcat.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/evaluateAstNode.js +14 -4
- package/dist/extractor/evaluateAstNode.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/extractHelpers.js +83 -12
- package/dist/extractor/extractHelpers.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/extractMediaStyle.js +46 -42
- package/dist/extractor/extractMediaStyle.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/extractToClassNames.js +144 -73
- package/dist/extractor/extractToClassNames.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/findTopmostFunction.js +1 -0
- package/dist/{cjs/extractor → extractor}/findTopmostFunction.js.map +2 -2
- package/dist/{cjs/extractor → extractor}/generatedUid.js +9 -2
- package/dist/{cjs/extractor → extractor}/generatedUid.js.map +3 -3
- package/dist/{cjs/extractor → extractor}/getPrefixLogs.js +1 -0
- package/dist/extractor/getPrefixLogs.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/getPropValueFromAttributes.js +24 -13
- package/dist/extractor/getPropValueFromAttributes.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/getSourceModule.js +5 -1
- package/dist/{esm/extractor → extractor}/getSourceModule.js.map +3 -3
- package/dist/{cjs/extractor → extractor}/getStaticBindingsForScope.js +89 -35
- package/dist/extractor/getStaticBindingsForScope.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/hoistClassNames.js +5 -1
- package/dist/{jsx/extractor → extractor}/hoistClassNames.js.map +3 -3
- package/dist/{cjs/extractor → extractor}/literalToAst.js +26 -30
- package/dist/{jsx/extractor → extractor}/literalToAst.js.map +2 -2
- package/dist/extractor/loadFile.js +21 -0
- package/dist/extractor/loadFile.js.map +7 -0
- package/dist/extractor/loadTamagui.js +427 -0
- package/dist/extractor/loadTamagui.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/logLines.js +2 -1
- package/dist/extractor/logLines.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/normalizeTernaries.js +13 -34
- package/dist/extractor/normalizeTernaries.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/removeUnusedHooks.js +5 -1
- package/dist/extractor/removeUnusedHooks.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/timer.js +9 -1
- package/dist/extractor/timer.js.map +7 -0
- package/dist/{cjs/extractor → extractor}/validHTMLAttributes.js +1 -0
- package/dist/{jsx/extractor → extractor}/validHTMLAttributes.js.map +2 -2
- package/dist/getPragmaOptions.js +68 -0
- package/dist/getPragmaOptions.js.map +7 -0
- package/dist/helpers/memoize.js +46 -0
- package/dist/helpers/memoize.js.map +7 -0
- package/dist/{cjs/index.js → index.js} +10 -8
- package/dist/index.js.map +7 -0
- package/dist/require.js +86 -0
- package/dist/require.js.map +7 -0
- package/dist/{cjs/types.js → types.js} +1 -0
- package/dist/types.js.map +7 -0
- package/dist/webpackPlugin.js +35 -0
- package/dist/webpackPlugin.js.map +7 -0
- package/package.json +40 -36
- package/src/constants.ts +2 -1
- package/src/extractor/babelParse.ts +3 -2
- package/src/extractor/buildClassName.ts +21 -5
- package/src/extractor/bundle.ts +110 -0
- package/src/extractor/createEvaluator.ts +10 -12
- package/src/extractor/createExtractor.ts +1702 -1523
- package/src/extractor/ensureImportingConcat.ts +4 -11
- package/src/extractor/evaluateAstNode.ts +1 -1
- package/src/extractor/extractHelpers.ts +93 -10
- package/src/extractor/extractMediaStyle.ts +18 -11
- package/src/extractor/extractToClassNames.ts +104 -47
- package/src/extractor/getPrefixLogs.ts +1 -1
- package/src/extractor/getPropValueFromAttributes.ts +4 -3
- package/src/extractor/getSourceModule.ts +2 -0
- package/src/extractor/getStaticBindingsForScope.ts +90 -46
- package/src/extractor/loadFile.ts +17 -0
- package/src/extractor/loadTamagui.ts +448 -103
- package/src/extractor/logLines.ts +1 -1
- package/src/extractor/normalizeTernaries.ts +2 -2
- package/src/extractor/removeUnusedHooks.ts +2 -0
- package/src/extractor/timer.ts +12 -1
- package/src/getPragmaOptions.ts +53 -0
- package/src/helpers/memoize.ts +21 -0
- package/src/index.ts +9 -8
- package/src/require.ts +103 -0
- package/src/types.ts +33 -31
- package/src/webpackPlugin.ts +9 -0
- package/tamagui.tsconfig.json +5 -0
- package/types/constants.d.ts +6 -0
- package/types/extractor/accessSafe.d.ts +3 -0
- package/types/extractor/babelParse.d.ts +6 -0
- package/types/extractor/buildClassName.d.ts +5 -2
- package/types/extractor/bundle.d.ts +13 -0
- package/types/extractor/createEvaluator.d.ts +3 -3
- package/types/extractor/createExtractor.d.ts +25 -9
- package/types/extractor/ensureImportingConcat.d.ts +4 -0
- package/types/extractor/evaluateAstNode.d.ts +3 -0
- package/types/extractor/extractHelpers.d.ts +15 -3
- package/types/extractor/extractMediaStyle.d.ts +3 -3
- package/types/extractor/extractToClassNames.d.ts +5 -4
- package/types/extractor/findTopmostFunction.d.ts +4 -0
- package/types/extractor/generatedUid.d.ts +5 -0
- package/types/extractor/getPrefixLogs.d.ts +1 -1
- package/types/extractor/getPropValueFromAttributes.d.ts +19 -0
- package/types/extractor/getSourceModule.d.ts +16 -0
- package/types/extractor/getStaticBindingsForScope.d.ts +5 -0
- package/types/extractor/hoistClassNames.d.ts +6 -0
- package/types/extractor/literalToAst.d.ts +4 -0
- package/types/extractor/loadFile.d.ts +1 -0
- package/types/extractor/loadTamagui.d.ts +15 -5
- package/types/extractor/logLines.d.ts +2 -0
- package/types/extractor/normalizeTernaries.d.ts +1 -1
- package/types/extractor/removeUnusedHooks.d.ts +3 -0
- package/types/extractor/timer.d.ts +5 -0
- package/types/extractor/validHTMLAttributes.d.ts +98 -0
- package/types/getPragmaOptions.d.ts +9 -0
- package/types/helpers/memoize.d.ts +8 -0
- package/types/index.d.ts +9 -8
- package/types/require.d.ts +4 -0
- package/types/types.d.ts +28 -27
- package/types/webpackPlugin.d.ts +4 -0
- package/dist/cjs/constants.js.map +0 -7
- package/dist/cjs/extractor/accessSafe.js.map +0 -7
- package/dist/cjs/extractor/babelParse.js.map +0 -7
- package/dist/cjs/extractor/buildClassName.js.map +0 -7
- package/dist/cjs/extractor/createEvaluator.js.map +0 -7
- package/dist/cjs/extractor/createExtractor.js +0 -1394
- package/dist/cjs/extractor/createExtractor.js.map +0 -7
- package/dist/cjs/extractor/ensureImportingConcat.js.map +0 -7
- package/dist/cjs/extractor/evaluateAstNode.js.map +0 -7
- package/dist/cjs/extractor/extractHelpers.js.map +0 -7
- package/dist/cjs/extractor/extractMediaStyle.js.map +0 -7
- package/dist/cjs/extractor/extractToClassNames.js.map +0 -7
- package/dist/cjs/extractor/getPrefixLogs.js.map +0 -7
- package/dist/cjs/extractor/getPropValueFromAttributes.js.map +0 -7
- package/dist/cjs/extractor/getSourceModule.js.map +0 -7
- package/dist/cjs/extractor/getStaticBindingsForScope.js.map +0 -7
- package/dist/cjs/extractor/hoistClassNames.js.map +0 -7
- package/dist/cjs/extractor/literalToAst.js.map +0 -7
- package/dist/cjs/extractor/loadTamagui.js +0 -139
- package/dist/cjs/extractor/loadTamagui.js.map +0 -7
- package/dist/cjs/extractor/logLines.js.map +0 -7
- package/dist/cjs/extractor/normalizeTernaries.js.map +0 -7
- package/dist/cjs/extractor/removeUnusedHooks.js.map +0 -7
- package/dist/cjs/extractor/timer.js.map +0 -7
- package/dist/cjs/extractor/validHTMLAttributes.js.map +0 -7
- package/dist/cjs/index.js.map +0 -7
- package/dist/cjs/types.js.map +0 -7
- package/dist/esm/constants.js +0 -14
- package/dist/esm/constants.js.map +0 -7
- package/dist/esm/extractor/accessSafe.js +0 -8
- package/dist/esm/extractor/babelParse.js +0 -28
- package/dist/esm/extractor/babelParse.js.map +0 -7
- package/dist/esm/extractor/buildClassName.js +0 -37
- package/dist/esm/extractor/buildClassName.js.map +0 -7
- package/dist/esm/extractor/createEvaluator.js +0 -53
- package/dist/esm/extractor/createEvaluator.js.map +0 -7
- package/dist/esm/extractor/createExtractor.js +0 -1379
- package/dist/esm/extractor/createExtractor.js.map +0 -7
- package/dist/esm/extractor/ensureImportingConcat.js +0 -21
- package/dist/esm/extractor/ensureImportingConcat.js.map +0 -7
- package/dist/esm/extractor/evaluateAstNode.js +0 -91
- package/dist/esm/extractor/evaluateAstNode.js.map +0 -7
- package/dist/esm/extractor/extractHelpers.js +0 -97
- package/dist/esm/extractor/extractHelpers.js.map +0 -7
- package/dist/esm/extractor/extractMediaStyle.js +0 -161
- package/dist/esm/extractor/extractMediaStyle.js.map +0 -7
- package/dist/esm/extractor/extractToClassNames.js +0 -294
- package/dist/esm/extractor/extractToClassNames.js.map +0 -7
- package/dist/esm/extractor/findTopmostFunction.js +0 -20
- package/dist/esm/extractor/findTopmostFunction.js.map +0 -7
- package/dist/esm/extractor/generatedUid.js +0 -25
- package/dist/esm/extractor/generatedUid.js.map +0 -7
- package/dist/esm/extractor/getPrefixLogs.js +0 -8
- package/dist/esm/extractor/getPrefixLogs.js.map +0 -7
- package/dist/esm/extractor/getPropValueFromAttributes.js +0 -46
- package/dist/esm/extractor/getPropValueFromAttributes.js.map +0 -7
- package/dist/esm/extractor/getSourceModule.js +0 -66
- package/dist/esm/extractor/getStaticBindingsForScope.js +0 -132
- package/dist/esm/extractor/getStaticBindingsForScope.js.map +0 -7
- package/dist/esm/extractor/hoistClassNames.js +0 -40
- package/dist/esm/extractor/hoistClassNames.js.map +0 -7
- package/dist/esm/extractor/literalToAst.js +0 -90
- package/dist/esm/extractor/literalToAst.js.map +0 -7
- package/dist/esm/extractor/loadTamagui.js +0 -117
- package/dist/esm/extractor/loadTamagui.js.map +0 -7
- package/dist/esm/extractor/logLines.js +0 -20
- package/dist/esm/extractor/logLines.js.map +0 -7
- package/dist/esm/extractor/normalizeTernaries.js +0 -79
- package/dist/esm/extractor/normalizeTernaries.js.map +0 -7
- package/dist/esm/extractor/removeUnusedHooks.js +0 -76
- package/dist/esm/extractor/removeUnusedHooks.js.map +0 -7
- package/dist/esm/extractor/timer.js +0 -22
- package/dist/esm/extractor/timer.js.map +0 -7
- package/dist/esm/extractor/validHTMLAttributes.js +0 -102
- package/dist/esm/extractor/validHTMLAttributes.js.map +0 -7
- package/dist/esm/index.js +0 -15
- package/dist/esm/index.js.map +0 -7
- package/dist/esm/types.js +0 -1
- package/dist/esm/types.js.map +0 -7
- package/dist/jsx/constants.js +0 -14
- package/dist/jsx/constants.js.map +0 -7
- package/dist/jsx/extractor/accessSafe.js +0 -8
- package/dist/jsx/extractor/accessSafe.js.map +0 -7
- package/dist/jsx/extractor/babelParse.js +0 -28
- package/dist/jsx/extractor/babelParse.js.map +0 -7
- package/dist/jsx/extractor/buildClassName.js +0 -37
- package/dist/jsx/extractor/buildClassName.js.map +0 -7
- package/dist/jsx/extractor/createEvaluator.js +0 -53
- package/dist/jsx/extractor/createEvaluator.js.map +0 -7
- package/dist/jsx/extractor/createExtractor.js +0 -1343
- package/dist/jsx/extractor/createExtractor.js.map +0 -7
- package/dist/jsx/extractor/ensureImportingConcat.js +0 -21
- package/dist/jsx/extractor/ensureImportingConcat.js.map +0 -7
- package/dist/jsx/extractor/evaluateAstNode.js +0 -91
- package/dist/jsx/extractor/evaluateAstNode.js.map +0 -7
- package/dist/jsx/extractor/extractHelpers.js +0 -97
- package/dist/jsx/extractor/extractHelpers.js.map +0 -7
- package/dist/jsx/extractor/extractMediaStyle.js +0 -146
- package/dist/jsx/extractor/extractMediaStyle.js.map +0 -7
- package/dist/jsx/extractor/extractToClassNames.js +0 -280
- package/dist/jsx/extractor/extractToClassNames.js.map +0 -7
- package/dist/jsx/extractor/findTopmostFunction.js +0 -20
- package/dist/jsx/extractor/findTopmostFunction.js.map +0 -7
- package/dist/jsx/extractor/generatedUid.js +0 -25
- package/dist/jsx/extractor/generatedUid.js.map +0 -7
- package/dist/jsx/extractor/getPrefixLogs.js +0 -9
- package/dist/jsx/extractor/getPrefixLogs.js.map +0 -7
- package/dist/jsx/extractor/getPropValueFromAttributes.js +0 -46
- package/dist/jsx/extractor/getPropValueFromAttributes.js.map +0 -7
- package/dist/jsx/extractor/getSourceModule.js +0 -66
- package/dist/jsx/extractor/getSourceModule.js.map +0 -7
- package/dist/jsx/extractor/getStaticBindingsForScope.js +0 -132
- package/dist/jsx/extractor/getStaticBindingsForScope.js.map +0 -7
- package/dist/jsx/extractor/hoistClassNames.js +0 -40
- package/dist/jsx/extractor/literalToAst.js +0 -75
- package/dist/jsx/extractor/loadTamagui.js +0 -102
- package/dist/jsx/extractor/loadTamagui.js.map +0 -7
- package/dist/jsx/extractor/logLines.js +0 -20
- package/dist/jsx/extractor/logLines.js.map +0 -7
- package/dist/jsx/extractor/normalizeTernaries.js +0 -50
- package/dist/jsx/extractor/normalizeTernaries.js.map +0 -7
- package/dist/jsx/extractor/removeUnusedHooks.js +0 -77
- package/dist/jsx/extractor/removeUnusedHooks.js.map +0 -7
- package/dist/jsx/extractor/timer.js +0 -22
- package/dist/jsx/extractor/timer.js.map +0 -7
- package/dist/jsx/extractor/validHTMLAttributes.js +0 -102
- package/dist/jsx/index.js +0 -15
- package/dist/jsx/index.js.map +0 -7
- package/dist/jsx/types.js +0 -1
- package/dist/jsx/types.js.map +0 -7
- package/types/extractor/buildClassName.d.ts.map +0 -1
- package/types/extractor/createEvaluator.d.ts.map +0 -1
- package/types/extractor/createExtractor.d.ts.map +0 -1
- package/types/extractor/extractHelpers.d.ts.map +0 -1
- package/types/extractor/extractMediaStyle.d.ts.map +0 -1
- package/types/extractor/extractToClassNames.d.ts.map +0 -1
- package/types/extractor/getPrefixLogs.d.ts.map +0 -1
- package/types/extractor/loadTamagui.d.ts.map +0 -1
- package/types/extractor/normalizeTernaries.d.ts.map +0 -1
- package/types/index.d.ts.map +0 -1
- package/types/types.d.ts.map +0 -1
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { basename, dirname, join } from 'path'
|
|
2
|
+
|
|
3
|
+
import esbuild from 'esbuild'
|
|
4
|
+
import { pathExists, stat, writeFile } from 'fs-extra'
|
|
5
|
+
|
|
6
|
+
import { resolveWebOrNativeSpecificEntry } from './loadTamagui'
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* For internal loading of new files
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
type Props = Omit<Partial<esbuild.BuildOptions>, 'entryPoints'> & {
|
|
13
|
+
outfile: string
|
|
14
|
+
entryPoints: string[]
|
|
15
|
+
resolvePlatformSpecificEntries?: boolean
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function getESBuildConfig(
|
|
19
|
+
{ entryPoints, resolvePlatformSpecificEntries, ...options }: Props,
|
|
20
|
+
aliases?: Record<string, string>
|
|
21
|
+
) {
|
|
22
|
+
const alias = require('@tamagui/core-node').aliasPlugin
|
|
23
|
+
if (process.env.DEBUG?.startsWith('tamagui')) {
|
|
24
|
+
// eslint-disable-next-line no-console
|
|
25
|
+
console.log(`Building`, entryPoints)
|
|
26
|
+
}
|
|
27
|
+
const tsconfig = join(__dirname, '..', '..', 'tamagui.tsconfig.json')
|
|
28
|
+
|
|
29
|
+
const resolvedEntryPoints = !resolvePlatformSpecificEntries
|
|
30
|
+
? entryPoints
|
|
31
|
+
: entryPoints.map(resolveWebOrNativeSpecificEntry)
|
|
32
|
+
|
|
33
|
+
const res: esbuild.BuildOptions = {
|
|
34
|
+
bundle: true,
|
|
35
|
+
entryPoints: resolvedEntryPoints,
|
|
36
|
+
format: 'cjs',
|
|
37
|
+
target: 'node18',
|
|
38
|
+
jsx: 'transform',
|
|
39
|
+
jsxFactory: 'react',
|
|
40
|
+
allowOverwrite: true,
|
|
41
|
+
keepNames: true,
|
|
42
|
+
platform: 'node',
|
|
43
|
+
tsconfig,
|
|
44
|
+
loader: {
|
|
45
|
+
'.js': 'jsx',
|
|
46
|
+
},
|
|
47
|
+
logLevel: 'warning',
|
|
48
|
+
plugins: [
|
|
49
|
+
{
|
|
50
|
+
name: 'external',
|
|
51
|
+
setup(build) {
|
|
52
|
+
build.onResolve({ filter: /@tamagui\/core/ }, (args) => {
|
|
53
|
+
return {
|
|
54
|
+
path: '@tamagui/core-node',
|
|
55
|
+
external: true,
|
|
56
|
+
}
|
|
57
|
+
})
|
|
58
|
+
|
|
59
|
+
build.onResolve({ filter: /^(react-native|react-native\/.*)$/ }, (args) => {
|
|
60
|
+
return {
|
|
61
|
+
path: 'react-native-web-lite',
|
|
62
|
+
external: true,
|
|
63
|
+
}
|
|
64
|
+
})
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
alias({
|
|
68
|
+
...aliases,
|
|
69
|
+
}),
|
|
70
|
+
],
|
|
71
|
+
...options,
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
return res
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export async function bundle(props: Props, aliases?: Record<string, string>) {
|
|
78
|
+
await asyncLock(props)
|
|
79
|
+
return esbuild.build(getESBuildConfig(props, aliases))
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export function bundleSync(props: Props, aliases?: Record<string, string>) {
|
|
83
|
+
return esbuild.buildSync(getESBuildConfig(props, aliases))
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// until i do fancier things w plugins:
|
|
87
|
+
async function asyncLock(props: Props) {
|
|
88
|
+
const lockFile = join(dirname(props.outfile), basename(props.outfile, '.lock'))
|
|
89
|
+
const lockStat = await stat(lockFile).catch(() => {
|
|
90
|
+
/* ok */
|
|
91
|
+
})
|
|
92
|
+
const lockedMsAgo = !lockStat
|
|
93
|
+
? Infinity
|
|
94
|
+
: new Date().getTime() - new Date(lockStat.mtime).getTime()
|
|
95
|
+
if (lockedMsAgo < 500) {
|
|
96
|
+
if (process.env.DEBUG?.startsWith('tamagui')) {
|
|
97
|
+
// eslint-disable-next-line no-console
|
|
98
|
+
console.log(`Waiting for existing build`, props.entryPoints)
|
|
99
|
+
}
|
|
100
|
+
let tries = 5
|
|
101
|
+
while (tries--) {
|
|
102
|
+
if (await pathExists(props.outfile)) {
|
|
103
|
+
return
|
|
104
|
+
} else {
|
|
105
|
+
await new Promise((res) => setTimeout(res, 50))
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
void writeFile(lockFile, '')
|
|
110
|
+
}
|
|
@@ -3,22 +3,22 @@ import vm from 'vm'
|
|
|
3
3
|
import generate from '@babel/generator'
|
|
4
4
|
import { NodePath } from '@babel/traverse'
|
|
5
5
|
import * as t from '@babel/types'
|
|
6
|
-
import type { TamaguiConfig } from '@tamagui/core'
|
|
7
6
|
import { createCSSVariable } from '@tamagui/core-node'
|
|
8
7
|
import esbuild from 'esbuild'
|
|
9
8
|
|
|
10
|
-
import { FAILED_EVAL } from '../constants'
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
9
|
+
import { FAILED_EVAL } from '../constants.js'
|
|
10
|
+
import { TamaguiOptionsWithFileInfo } from '../types.js'
|
|
11
|
+
import { evaluateAstNode } from './evaluateAstNode.js'
|
|
12
|
+
import { isValidThemeHook } from './extractHelpers.js'
|
|
13
13
|
|
|
14
14
|
export function createEvaluator({
|
|
15
|
-
|
|
15
|
+
props,
|
|
16
16
|
staticNamespace,
|
|
17
17
|
sourcePath,
|
|
18
18
|
traversePath,
|
|
19
19
|
shouldPrintDebug,
|
|
20
20
|
}: {
|
|
21
|
-
|
|
21
|
+
props: TamaguiOptionsWithFileInfo
|
|
22
22
|
staticNamespace: Record<string, any>
|
|
23
23
|
sourcePath: string
|
|
24
24
|
traversePath?: NodePath<t.JSXElement>
|
|
@@ -31,20 +31,17 @@ export function createEvaluator({
|
|
|
31
31
|
t.isMemberExpression(n) &&
|
|
32
32
|
t.isIdentifier(n.property) &&
|
|
33
33
|
traversePath &&
|
|
34
|
-
isValidThemeHook(traversePath, n, sourcePath)
|
|
34
|
+
isValidThemeHook(props, traversePath, n, sourcePath)
|
|
35
35
|
) {
|
|
36
36
|
const key = n.property.name
|
|
37
37
|
if (shouldPrintDebug) {
|
|
38
|
+
// eslint-disable-next-line no-console
|
|
38
39
|
console.log(' > found theme prop', key)
|
|
39
40
|
}
|
|
40
|
-
console.log('SHOULD FIND THEME (NESTED NOW)', key) // tamaguiConfig.themes)
|
|
41
|
-
// if (!themeKeys.has(key)) {
|
|
42
|
-
// throw new Error(` > accessing non-existent theme key: ${key}`)
|
|
43
|
-
// }
|
|
44
41
|
return createCSSVariable(key)
|
|
45
42
|
}
|
|
46
43
|
// variable
|
|
47
|
-
if (t.isIdentifier(n) && staticNamespace
|
|
44
|
+
if (t.isIdentifier(n) && typeof staticNamespace[n.name] !== 'undefined') {
|
|
48
45
|
return staticNamespace[n.name]
|
|
49
46
|
}
|
|
50
47
|
const evalContext = vm.createContext(staticNamespace)
|
|
@@ -54,6 +51,7 @@ export function createEvaluator({
|
|
|
54
51
|
.code.replace(/;\n$/, '')
|
|
55
52
|
|
|
56
53
|
if (shouldPrintDebug) {
|
|
54
|
+
// eslint-disable-next-line no-console
|
|
57
55
|
console.log('evaluating', code)
|
|
58
56
|
}
|
|
59
57
|
return vm.runInContext(code, evalContext)
|