@tamagui/static 1.0.10 → 1.0.12
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/extractor/createExtractor.js +1 -46
- package/dist/extractor/createExtractor.js.map +2 -2
- package/dist/extractor/ensureImportingConcat.js +3 -1
- package/dist/extractor/ensureImportingConcat.js.map +2 -2
- package/dist/extractor/extractToClassNames.js +19 -2
- package/dist/extractor/extractToClassNames.js.map +2 -2
- package/dist/extractor/getStaticBindingsForScope.js +3 -5
- package/dist/extractor/getStaticBindingsForScope.js.map +2 -2
- package/package.json +13 -13
- package/src/extractor/createExtractor.ts +2 -59
- package/src/extractor/ensureImportingConcat.ts +36 -0
- package/src/extractor/extractToClassNames.ts +23 -2
- package/src/extractor/getStaticBindingsForScope.ts +3 -5
- package/dist/cjs/constants.js +0 -49
- package/dist/cjs/constants.js.map +0 -7
- package/dist/cjs/extractor/accessSafe.js +0 -35
- package/dist/cjs/extractor/accessSafe.js.map +0 -7
- package/dist/cjs/extractor/babelParse.js +0 -56
- package/dist/cjs/extractor/babelParse.js.map +0 -7
- package/dist/cjs/extractor/buildClassName.js +0 -64
- package/dist/cjs/extractor/buildClassName.js.map +0 -7
- package/dist/cjs/extractor/bundle.js +0 -137
- package/dist/cjs/extractor/bundle.js.map +0 -7
- package/dist/cjs/extractor/createEvaluator.js +0 -81
- package/dist/cjs/extractor/createEvaluator.js.map +0 -7
- package/dist/cjs/extractor/createExtractor.js +0 -1330
- package/dist/cjs/extractor/createExtractor.js.map +0 -7
- package/dist/cjs/extractor/defaultTamaguiConfig.js +0 -167
- package/dist/cjs/extractor/defaultTamaguiConfig.js.map +0 -7
- package/dist/cjs/extractor/ensureImportingConcat.js +0 -48
- package/dist/cjs/extractor/ensureImportingConcat.js.map +0 -7
- package/dist/cjs/extractor/evaluateAstNode.js +0 -118
- package/dist/cjs/extractor/evaluateAstNode.js.map +0 -7
- package/dist/cjs/extractor/extractHelpers.js +0 -131
- package/dist/cjs/extractor/extractHelpers.js.map +0 -7
- package/dist/cjs/extractor/extractMediaStyle.js +0 -174
- package/dist/cjs/extractor/extractMediaStyle.js.map +0 -7
- package/dist/cjs/extractor/extractToClassNames.js +0 -305
- package/dist/cjs/extractor/extractToClassNames.js.map +0 -7
- package/dist/cjs/extractor/findTopmostFunction.js +0 -44
- package/dist/cjs/extractor/findTopmostFunction.js.map +0 -7
- package/dist/cjs/extractor/generatedUid.js +0 -52
- package/dist/cjs/extractor/generatedUid.js.map +0 -7
- package/dist/cjs/extractor/getPrefixLogs.js +0 -32
- package/dist/cjs/extractor/getPrefixLogs.js.map +0 -7
- package/dist/cjs/extractor/getPropValueFromAttributes.js +0 -73
- package/dist/cjs/extractor/getPropValueFromAttributes.js.map +0 -7
- package/dist/cjs/extractor/getSourceModule.js +0 -93
- package/dist/cjs/extractor/getSourceModule.js.map +0 -7
- package/dist/cjs/extractor/getStaticBindingsForScope.js +0 -184
- package/dist/cjs/extractor/getStaticBindingsForScope.js.map +0 -7
- package/dist/cjs/extractor/hoistClassNames.js +0 -67
- package/dist/cjs/extractor/hoistClassNames.js.map +0 -7
- package/dist/cjs/extractor/literalToAst.js +0 -103
- package/dist/cjs/extractor/literalToAst.js.map +0 -7
- package/dist/cjs/extractor/loadFile.js +0 -21
- package/dist/cjs/extractor/loadFile.js.map +0 -7
- package/dist/cjs/extractor/loadTamagui.js +0 -105
- package/dist/cjs/extractor/loadTamagui.js.map +0 -7
- package/dist/cjs/extractor/logLines.js +0 -44
- package/dist/cjs/extractor/logLines.js.map +0 -7
- package/dist/cjs/extractor/normalizeTernaries.js +0 -76
- package/dist/cjs/extractor/normalizeTernaries.js.map +0 -7
- package/dist/cjs/extractor/removeUnusedHooks.js +0 -103
- package/dist/cjs/extractor/removeUnusedHooks.js.map +0 -7
- package/dist/cjs/extractor/timer.js +0 -46
- package/dist/cjs/extractor/timer.js.map +0 -7
- package/dist/cjs/extractor/validHTMLAttributes.js +0 -127
- package/dist/cjs/extractor/validHTMLAttributes.js.map +0 -7
- package/dist/cjs/getPragmaOptions.js +0 -67
- package/dist/cjs/getPragmaOptions.js.map +0 -7
- package/dist/cjs/helpers/memoize.js +0 -45
- package/dist/cjs/helpers/memoize.js.map +0 -7
- package/dist/cjs/index.js +0 -43
- package/dist/cjs/index.js.map +0 -7
- package/dist/cjs/require.js +0 -104
- package/dist/cjs/require.js.map +0 -7
- package/dist/cjs/types.js +0 -17
- package/dist/cjs/types.js.map +0 -7
- package/dist/cjs/webpackPlugin.js +0 -34
- package/dist/cjs/webpackPlugin.js.map +0 -7
- package/dist/esm/constants.js +0 -17
- package/dist/esm/constants.js.map +0 -7
- package/dist/esm/extractor/accessSafe.js +0 -8
- package/dist/esm/extractor/accessSafe.js.map +0 -7
- 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/bundle.js +0 -112
- package/dist/esm/extractor/bundle.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 -1311
- package/dist/esm/extractor/createExtractor.js.map +0 -7
- package/dist/esm/extractor/defaultTamaguiConfig.js +0 -143
- package/dist/esm/extractor/defaultTamaguiConfig.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 -146
- package/dist/esm/extractor/extractMediaStyle.js.map +0 -7
- package/dist/esm/extractor/extractToClassNames.js +0 -278
- 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/getSourceModule.js.map +0 -7
- package/dist/esm/extractor/getStaticBindingsForScope.js +0 -157
- 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 -75
- package/dist/esm/extractor/literalToAst.js.map +0 -7
- package/dist/esm/extractor/loadFile.js +0 -20
- package/dist/esm/extractor/loadFile.js.map +0 -7
- package/dist/esm/extractor/loadTamagui.js +0 -81
- 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 -49
- 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/getPragmaOptions.js +0 -44
- package/dist/esm/getPragmaOptions.js.map +0 -7
- package/dist/esm/helpers/memoize.js +0 -22
- package/dist/esm/helpers/memoize.js.map +0 -7
- package/dist/esm/index.js +0 -16
- package/dist/esm/index.js.map +0 -7
- package/dist/esm/require.js +0 -78
- package/dist/esm/require.js.map +0 -7
- package/dist/esm/types.js +0 -1
- package/dist/esm/types.js.map +0 -7
- package/dist/esm/webpackPlugin.js +0 -11
- package/dist/esm/webpackPlugin.js.map +0 -7
- package/dist/jsx/constants.js +0 -17
- 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/bundle.js +0 -86
- package/dist/jsx/extractor/bundle.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 -1311
- package/dist/jsx/extractor/createExtractor.js.map +0 -7
- package/dist/jsx/extractor/defaultTamaguiConfig.js +0 -143
- package/dist/jsx/extractor/defaultTamaguiConfig.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 -157
- package/dist/jsx/extractor/getStaticBindingsForScope.js.map +0 -7
- package/dist/jsx/extractor/hoistClassNames.js +0 -40
- package/dist/jsx/extractor/hoistClassNames.js.map +0 -7
- package/dist/jsx/extractor/literalToAst.js +0 -75
- package/dist/jsx/extractor/literalToAst.js.map +0 -7
- package/dist/jsx/extractor/loadFile.js +0 -20
- package/dist/jsx/extractor/loadFile.js.map +0 -7
- package/dist/jsx/extractor/loadTamagui.js +0 -81
- 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/extractor/validHTMLAttributes.js.map +0 -7
- package/dist/jsx/getPragmaOptions.js +0 -44
- package/dist/jsx/getPragmaOptions.js.map +0 -7
- package/dist/jsx/helpers/memoize.js +0 -22
- package/dist/jsx/helpers/memoize.js.map +0 -7
- package/dist/jsx/index.js +0 -16
- package/dist/jsx/index.js.map +0 -7
- package/dist/jsx/require.js +0 -78
- package/dist/jsx/require.js.map +0 -7
- package/dist/jsx/types.js +0 -1
- package/dist/jsx/types.js.map +0 -7
- package/dist/jsx/webpackPlugin.js +0 -11
- package/dist/jsx/webpackPlugin.js.map +0 -7
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
21
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
22
|
-
var extractHelpers_exports = {};
|
|
23
|
-
__export(extractHelpers_exports, {
|
|
24
|
-
attrStr: () => attrStr,
|
|
25
|
-
findComponentName: () => findComponentName,
|
|
26
|
-
isInsideTamagui: () => isInsideTamagui,
|
|
27
|
-
isPresent: () => isPresent,
|
|
28
|
-
isSimpleSpread: () => isSimpleSpread,
|
|
29
|
-
isValidThemeHook: () => isValidThemeHook,
|
|
30
|
-
objToStr: () => objToStr,
|
|
31
|
-
ternaryStr: () => ternaryStr
|
|
32
|
-
});
|
|
33
|
-
module.exports = __toCommonJS(extractHelpers_exports);
|
|
34
|
-
var import_generator = __toESM(require("@babel/generator"));
|
|
35
|
-
var t = __toESM(require("@babel/types"));
|
|
36
|
-
function isPresent(input) {
|
|
37
|
-
return input != null;
|
|
38
|
-
}
|
|
39
|
-
function isSimpleSpread(node) {
|
|
40
|
-
return t.isIdentifier(node.argument) || t.isMemberExpression(node.argument);
|
|
41
|
-
}
|
|
42
|
-
const attrStr = (attr) => {
|
|
43
|
-
return !attr ? "" : attr.type === "attr" ? getNameAttr(attr.value) : attr.type === "ternary" ? `...${ternaryStr(attr.value)}` : `${attr.type}(${objToStr(attr.value)})`;
|
|
44
|
-
};
|
|
45
|
-
const objToStr = (obj, spacer = ", ") => {
|
|
46
|
-
if (!obj) {
|
|
47
|
-
return `${obj}`;
|
|
48
|
-
}
|
|
49
|
-
return `{${Object.entries(obj).map(([k, v]) => `${k}:${Array.isArray(v) ? `[...]` : v && typeof v === "object" ? `${objToStr(v, ",")}` : JSON.stringify(v)}`).join(spacer)}}`;
|
|
50
|
-
};
|
|
51
|
-
const getNameAttr = (attr) => {
|
|
52
|
-
if (t.isJSXSpreadAttribute(attr)) {
|
|
53
|
-
return `...${attr.argument["name"]}`;
|
|
54
|
-
}
|
|
55
|
-
return "name" in attr ? attr.name.name : `unknown-${attr["type"]}`;
|
|
56
|
-
};
|
|
57
|
-
const ternaryStr = (x) => {
|
|
58
|
-
const conditional = t.isIdentifier(x.test) ? x.test.name : t.isMemberExpression(x.test) ? [x.test.object["name"], x.test.property["name"]] : (0, import_generator.default)(x.test).code;
|
|
59
|
-
return [
|
|
60
|
-
"ternary(",
|
|
61
|
-
conditional,
|
|
62
|
-
isFilledObj(x.consequent) ? ` ? ${objToStr(x.consequent)}` : " ? \u{1F6AB}",
|
|
63
|
-
isFilledObj(x.alternate) ? ` : ${objToStr(x.alternate)}` : " : \u{1F6AB}",
|
|
64
|
-
")"
|
|
65
|
-
].flat().join("");
|
|
66
|
-
};
|
|
67
|
-
const isFilledObj = (obj) => obj && Object.keys(obj).length;
|
|
68
|
-
function findComponentName(scope) {
|
|
69
|
-
var _a;
|
|
70
|
-
let componentName = "";
|
|
71
|
-
let cur = scope.path;
|
|
72
|
-
while (cur.parentPath && !t.isProgram(cur.parentPath.parent)) {
|
|
73
|
-
cur = cur.parentPath;
|
|
74
|
-
}
|
|
75
|
-
let node = cur.parent;
|
|
76
|
-
if (t.isExportNamedDeclaration(node)) {
|
|
77
|
-
node = node.declaration;
|
|
78
|
-
}
|
|
79
|
-
if (t.isVariableDeclaration(node)) {
|
|
80
|
-
const [dec] = node.declarations;
|
|
81
|
-
if (t.isVariableDeclarator(dec) && t.isIdentifier(dec.id)) {
|
|
82
|
-
return dec.id.name;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
if (t.isFunctionDeclaration(node)) {
|
|
86
|
-
return (_a = node.id) == null ? void 0 : _a.name;
|
|
87
|
-
}
|
|
88
|
-
return componentName;
|
|
89
|
-
}
|
|
90
|
-
function isValidThemeHook(jsxPath, n, sourcePath) {
|
|
91
|
-
var _a;
|
|
92
|
-
if (!t.isIdentifier(n.object) || !t.isIdentifier(n.property))
|
|
93
|
-
return false;
|
|
94
|
-
const bindings = jsxPath.scope.getAllBindings();
|
|
95
|
-
const binding = bindings[n.object.name];
|
|
96
|
-
if (!(binding == null ? void 0 : binding.path))
|
|
97
|
-
return false;
|
|
98
|
-
if (!binding.path.isVariableDeclarator())
|
|
99
|
-
return false;
|
|
100
|
-
const init = binding.path.node.init;
|
|
101
|
-
if (!t.isCallExpression(init))
|
|
102
|
-
return false;
|
|
103
|
-
if (!t.isIdentifier(init.callee))
|
|
104
|
-
return false;
|
|
105
|
-
if (init.callee.name !== "useTheme")
|
|
106
|
-
return false;
|
|
107
|
-
const importNode = (_a = binding.scope.getBinding("useTheme")) == null ? void 0 : _a.path.parent;
|
|
108
|
-
if (!t.isImportDeclaration(importNode))
|
|
109
|
-
return false;
|
|
110
|
-
if (importNode.source.value !== "tamagui") {
|
|
111
|
-
if (!isInsideTamagui(sourcePath)) {
|
|
112
|
-
return false;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
return true;
|
|
116
|
-
}
|
|
117
|
-
const isInsideTamagui = (srcName) => {
|
|
118
|
-
return srcName.includes("/dist/jsx") || srcName.includes("/core/src");
|
|
119
|
-
};
|
|
120
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
121
|
-
0 && (module.exports = {
|
|
122
|
-
attrStr,
|
|
123
|
-
findComponentName,
|
|
124
|
-
isInsideTamagui,
|
|
125
|
-
isPresent,
|
|
126
|
-
isSimpleSpread,
|
|
127
|
-
isValidThemeHook,
|
|
128
|
-
objToStr,
|
|
129
|
-
ternaryStr
|
|
130
|
-
});
|
|
131
|
-
//# sourceMappingURL=extractHelpers.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/extractor/extractHelpers.ts"],
|
|
4
|
-
"sourcesContent": ["import generate from '@babel/generator'\nimport type { NodePath } from '@babel/traverse'\nimport * as t from '@babel/types'\n\nimport { ExtractedAttr, Ternary } from '../types'\nimport { astToLiteral } from './literalToAst'\n\nexport function isPresent<T extends Object>(input: null | void | undefined | T): input is T {\n return input != null\n}\n\nexport function isSimpleSpread(node: t.JSXSpreadAttribute) {\n return t.isIdentifier(node.argument) || t.isMemberExpression(node.argument)\n}\n\nexport const attrStr = (attr?: ExtractedAttr) => {\n return !attr\n ? ''\n : attr.type === 'attr'\n ? getNameAttr(attr.value)\n : attr.type === 'ternary'\n ? `...${ternaryStr(attr.value)}`\n : `${attr.type}(${objToStr(attr.value)})`\n}\n\nexport const objToStr = (obj: any, spacer = ', ') => {\n if (!obj) {\n return `${obj}`\n }\n return `{${Object.entries(obj)\n .map(\n ([k, v]) =>\n `${k}:${\n Array.isArray(v)\n ? `[...]`\n : v && typeof v === 'object'\n ? `${objToStr(v, ',')}`\n : JSON.stringify(v)\n }`\n )\n .join(spacer)}}`\n}\n\nconst getNameAttr = (attr: t.JSXAttribute | t.JSXSpreadAttribute) => {\n if (t.isJSXSpreadAttribute(attr)) {\n return `...${attr.argument['name']}`\n }\n return 'name' in attr ? attr.name.name : `unknown-${attr['type']}`\n}\n\nexport const ternaryStr = (x: Ternary) => {\n const conditional = t.isIdentifier(x.test)\n ? x.test.name\n : t.isMemberExpression(x.test)\n ? [x.test.object['name'], x.test.property['name']]\n : generate(x.test).code\n return [\n 'ternary(',\n conditional,\n isFilledObj(x.consequent) ? ` ? ${objToStr(x.consequent)}` : ' ? \uD83D\uDEAB',\n isFilledObj(x.alternate) ? ` : ${objToStr(x.alternate)}` : ' : \uD83D\uDEAB',\n ')',\n ]\n .flat()\n .join('')\n}\n\nconst isFilledObj = (obj: any) => obj && Object.keys(obj).length\n\nexport function findComponentName(scope) {\n let componentName = ''\n let cur = scope.path\n while (cur.parentPath && !t.isProgram(cur.parentPath.parent)) {\n cur = cur.parentPath\n }\n let node = cur.parent\n if (t.isExportNamedDeclaration(node)) {\n node = node.declaration\n }\n if (t.isVariableDeclaration(node)) {\n const [dec] = node.declarations\n if (t.isVariableDeclarator(dec) && t.isIdentifier(dec.id)) {\n return dec.id.name\n }\n }\n if (t.isFunctionDeclaration(node)) {\n return node.id?.name\n }\n return componentName\n}\n\nexport function isValidThemeHook(\n jsxPath: NodePath<t.JSXElement>,\n n: t.MemberExpression,\n sourcePath: string\n) {\n if (!t.isIdentifier(n.object) || !t.isIdentifier(n.property)) return false\n const bindings = jsxPath.scope.getAllBindings()\n const binding = bindings[n.object.name]\n if (!binding?.path) return false\n if (!binding.path.isVariableDeclarator()) return false\n const init = binding.path.node.init\n if (!t.isCallExpression(init)) return false\n if (!t.isIdentifier(init.callee)) return false\n // TODO could support renaming useTheme by looking up import first\n if (init.callee.name !== 'useTheme') return false\n const importNode = binding.scope.getBinding('useTheme')?.path.parent\n if (!t.isImportDeclaration(importNode)) return false\n if (importNode.source.value !== 'tamagui') {\n if (!isInsideTamagui(sourcePath)) {\n return false\n }\n }\n return true\n}\n\nexport const isInsideTamagui = (srcName: string) => {\n return srcName.includes('/dist/jsx') || srcName.includes('/core/src')\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,174 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
21
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
22
|
-
var extractMediaStyle_exports = {};
|
|
23
|
-
__export(extractMediaStyle_exports, {
|
|
24
|
-
extractMediaStyle: () => extractMediaStyle,
|
|
25
|
-
isValidMediaCall: () => isValidMediaCall
|
|
26
|
-
});
|
|
27
|
-
module.exports = __toCommonJS(extractMediaStyle_exports);
|
|
28
|
-
var t = __toESM(require("@babel/types"));
|
|
29
|
-
var import_core_node = require("@tamagui/core-node");
|
|
30
|
-
var import_constants = require("../constants");
|
|
31
|
-
var import_extractHelpers = require("./extractHelpers");
|
|
32
|
-
function extractMediaStyle(ternary, jsxPath, tamaguiConfig, sourcePath, importance = 0, shouldPrintDebug = false) {
|
|
33
|
-
const mt = getMediaQueryTernary(ternary, jsxPath, sourcePath);
|
|
34
|
-
if (!mt) {
|
|
35
|
-
return null;
|
|
36
|
-
}
|
|
37
|
-
const { key } = mt;
|
|
38
|
-
const mq = tamaguiConfig.media[key];
|
|
39
|
-
if (!mq) {
|
|
40
|
-
console.error(`Media query "${key}" not found: ${Object.keys(tamaguiConfig.media)}`);
|
|
41
|
-
return null;
|
|
42
|
-
}
|
|
43
|
-
const getStyleObj = (styleObj, negate = false) => {
|
|
44
|
-
return styleObj ? { styleObj, negate } : null;
|
|
45
|
-
};
|
|
46
|
-
const styleOpts = [
|
|
47
|
-
getStyleObj(ternary.consequent, false),
|
|
48
|
-
getStyleObj(ternary.alternate, true)
|
|
49
|
-
].filter(import_extractHelpers.isPresent);
|
|
50
|
-
if (shouldPrintDebug && !styleOpts.length) {
|
|
51
|
-
console.log(" media query, no styles?");
|
|
52
|
-
return null;
|
|
53
|
-
}
|
|
54
|
-
const mediaKeys = Object.keys(tamaguiConfig.media);
|
|
55
|
-
const mediaKeyPrecendence = mediaKeys.reduce((acc, cur, i) => {
|
|
56
|
-
acc[cur] = new Array(importance + 1).fill(":root").join("");
|
|
57
|
-
return acc;
|
|
58
|
-
}, {});
|
|
59
|
-
let mediaStyles = [];
|
|
60
|
-
for (const { styleObj, negate } of styleOpts) {
|
|
61
|
-
const styles = (0, import_core_node.getStylesAtomic)(styleObj);
|
|
62
|
-
const singleMediaStyles = styles.map((style) => {
|
|
63
|
-
const negKey = negate ? "0" : "";
|
|
64
|
-
const ogPrefix = style.identifier.slice(0, style.identifier.indexOf("-") + 1);
|
|
65
|
-
const identifier = `${style.identifier.replace(ogPrefix, `${ogPrefix}${import_constants.MEDIA_SEP}${key}${negKey}${import_constants.MEDIA_SEP}`)}`;
|
|
66
|
-
const className = `.${identifier}`;
|
|
67
|
-
const mediaSelector = (0, import_core_node.mediaObjectToString)(tamaguiConfig.media[key]);
|
|
68
|
-
const screenStr = negate ? "not all" : "screen";
|
|
69
|
-
const mediaQuery = `${screenStr} and ${mediaSelector}`;
|
|
70
|
-
const precendencePrefix = mediaKeyPrecendence[key];
|
|
71
|
-
const styleInner = style.rules.map((rule) => rule.replace(style.identifier, identifier)).join(";");
|
|
72
|
-
let styleRule = "";
|
|
73
|
-
if (styleInner.includes("@media")) {
|
|
74
|
-
styleRule = styleInner.replace("{", ` and ${mediaQuery} {`);
|
|
75
|
-
} else {
|
|
76
|
-
styleRule = `@media ${mediaQuery} { ${precendencePrefix} ${styleInner} }`;
|
|
77
|
-
}
|
|
78
|
-
return {
|
|
79
|
-
...style,
|
|
80
|
-
identifier,
|
|
81
|
-
className,
|
|
82
|
-
rules: [styleRule]
|
|
83
|
-
};
|
|
84
|
-
});
|
|
85
|
-
if (shouldPrintDebug === "verbose") {
|
|
86
|
-
console.log(" media styles:", importance, styleObj, singleMediaStyles.map((x) => x.identifier).join(", "));
|
|
87
|
-
}
|
|
88
|
-
mediaStyles = [...mediaStyles, ...singleMediaStyles];
|
|
89
|
-
}
|
|
90
|
-
ternary.remove();
|
|
91
|
-
return { mediaStyles, ternaryWithoutMedia: mt.ternaryWithoutMedia };
|
|
92
|
-
}
|
|
93
|
-
function getMediaQueryTernary(ternary, jsxPath, sourcePath) {
|
|
94
|
-
if (t.isLogicalExpression(ternary.test) && ternary.test.operator === "&&") {
|
|
95
|
-
const mediaLeft = getMediaInfoFromExpression(ternary.test.left, jsxPath, sourcePath, ternary.inlineMediaQuery);
|
|
96
|
-
if (mediaLeft) {
|
|
97
|
-
return {
|
|
98
|
-
...mediaLeft,
|
|
99
|
-
ternaryWithoutMedia: {
|
|
100
|
-
...ternary,
|
|
101
|
-
test: ternary.test.right
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
const result = getMediaInfoFromExpression(ternary.test, jsxPath, sourcePath, ternary.inlineMediaQuery);
|
|
107
|
-
if (result) {
|
|
108
|
-
return {
|
|
109
|
-
...result,
|
|
110
|
-
ternaryWithoutMedia: null
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
return null;
|
|
114
|
-
}
|
|
115
|
-
function getMediaInfoFromExpression(test, jsxPath, sourcePath, inlineMediaQuery) {
|
|
116
|
-
var _a, _b, _c;
|
|
117
|
-
if (inlineMediaQuery) {
|
|
118
|
-
return {
|
|
119
|
-
key: inlineMediaQuery,
|
|
120
|
-
bindingName: inlineMediaQuery
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
if (t.isMemberExpression(test) && t.isIdentifier(test.object) && t.isIdentifier(test.property)) {
|
|
124
|
-
const name = test.object["name"];
|
|
125
|
-
const key = test.property["name"];
|
|
126
|
-
const bindings = jsxPath.scope.getAllBindings();
|
|
127
|
-
const binding = bindings[name];
|
|
128
|
-
if (!binding)
|
|
129
|
-
return false;
|
|
130
|
-
const bindingNode = (_a = binding.path) == null ? void 0 : _a.node;
|
|
131
|
-
if (!t.isVariableDeclarator(bindingNode) || !bindingNode.init)
|
|
132
|
-
return false;
|
|
133
|
-
if (!isValidMediaCall(jsxPath, bindingNode.init, sourcePath))
|
|
134
|
-
return false;
|
|
135
|
-
return { key, bindingName: name };
|
|
136
|
-
}
|
|
137
|
-
if (t.isIdentifier(test)) {
|
|
138
|
-
const key = test.name;
|
|
139
|
-
const node = (_c = (_b = jsxPath.scope.getBinding(test.name)) == null ? void 0 : _b.path) == null ? void 0 : _c.node;
|
|
140
|
-
if (!t.isVariableDeclarator(node))
|
|
141
|
-
return false;
|
|
142
|
-
if (!node.init || !isValidMediaCall(jsxPath, node.init, sourcePath))
|
|
143
|
-
return false;
|
|
144
|
-
return { key, bindingName: key };
|
|
145
|
-
}
|
|
146
|
-
return null;
|
|
147
|
-
}
|
|
148
|
-
function isValidMediaCall(jsxPath, init, sourcePath) {
|
|
149
|
-
if (!t.isCallExpression(init))
|
|
150
|
-
return false;
|
|
151
|
-
if (!t.isIdentifier(init.callee))
|
|
152
|
-
return false;
|
|
153
|
-
if (init.callee.name !== "useMedia")
|
|
154
|
-
return false;
|
|
155
|
-
const bindings = jsxPath.scope.getAllBindings();
|
|
156
|
-
const mediaBinding = bindings["useMedia"];
|
|
157
|
-
if (!mediaBinding)
|
|
158
|
-
return false;
|
|
159
|
-
const useMediaImport = mediaBinding.path.parent;
|
|
160
|
-
if (!t.isImportDeclaration(useMediaImport))
|
|
161
|
-
return false;
|
|
162
|
-
if (useMediaImport.source.value !== "tamagui") {
|
|
163
|
-
if (!(0, import_extractHelpers.isInsideTamagui)(sourcePath)) {
|
|
164
|
-
return false;
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
return true;
|
|
168
|
-
}
|
|
169
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
170
|
-
0 && (module.exports = {
|
|
171
|
-
extractMediaStyle,
|
|
172
|
-
isValidMediaCall
|
|
173
|
-
});
|
|
174
|
-
//# sourceMappingURL=extractMediaStyle.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/extractor/extractMediaStyle.ts"],
|
|
4
|
-
"sourcesContent": ["import { NodePath } from '@babel/traverse'\nimport * as t from '@babel/types'\nimport { TamaguiInternalConfig, getStylesAtomic, mediaObjectToString } from '@tamagui/core-node'\nimport { ViewStyle } from 'react-native'\n\nimport { MEDIA_SEP } from '../constants'\nimport { StyleObject, Ternary } from '../types'\nimport { isInsideTamagui, isPresent } from './extractHelpers'\n\nexport function extractMediaStyle(\n ternary: Ternary,\n jsxPath: NodePath<t.JSXElement>,\n tamaguiConfig: TamaguiInternalConfig,\n sourcePath: string,\n importance = 0,\n shouldPrintDebug: boolean | 'verbose' = false\n) {\n const mt = getMediaQueryTernary(ternary, jsxPath, sourcePath)\n if (!mt) {\n return null\n }\n const { key } = mt\n const mq = tamaguiConfig.media[key]\n if (!mq) {\n console.error(`Media query \"${key}\" not found: ${Object.keys(tamaguiConfig.media)}`)\n return null\n }\n const getStyleObj = (styleObj: ViewStyle | null, negate = false) => {\n return styleObj ? { styleObj, negate } : null\n }\n const styleOpts = [\n getStyleObj(ternary.consequent, false),\n getStyleObj(ternary.alternate, true),\n ].filter(isPresent)\n if (shouldPrintDebug && !styleOpts.length) {\n console.log(' media query, no styles?')\n return null\n }\n // for now order first strongest\n const mediaKeys = Object.keys(tamaguiConfig.media)\n const mediaKeyPrecendence = mediaKeys.reduce((acc, cur, i) => {\n acc[cur] = new Array(importance + 1).fill(':root').join('')\n return acc\n }, {})\n let mediaStyles: StyleObject[] = []\n for (const { styleObj, negate } of styleOpts) {\n const styles = getStylesAtomic(styleObj)\n const singleMediaStyles = styles.map((style) => {\n const negKey = negate ? '0' : ''\n const ogPrefix = style.identifier.slice(0, style.identifier.indexOf('-') + 1)\n // adds an extra separator before and after to detect later in concatClassName\n // so it goes from: \"_f-[hash]\"\n // to: \"_f-_sm0_[hash]\" or \"_f-_sm_[hash]\"\n const identifier = `${style.identifier.replace(\n ogPrefix,\n `${ogPrefix}${MEDIA_SEP}${key}${negKey}${MEDIA_SEP}`\n )}`\n const className = `.${identifier}`\n const mediaSelector = mediaObjectToString(tamaguiConfig.media[key])\n const screenStr = negate ? 'not all' : 'screen'\n const mediaQuery = `${screenStr} and ${mediaSelector}`\n const precendencePrefix = mediaKeyPrecendence[key]\n const styleInner = style.rules\n .map((rule) => rule.replace(style.identifier, identifier))\n .join(';')\n // combines media queries if they already exist\n let styleRule = ''\n if (styleInner.includes('@media')) {\n // combine\n styleRule = styleInner.replace('{', ` and ${mediaQuery} {`)\n } else {\n styleRule = `@media ${mediaQuery} { ${precendencePrefix} ${styleInner} }`\n }\n return {\n ...style,\n identifier,\n className,\n rules: [styleRule],\n }\n })\n if (shouldPrintDebug === 'verbose') {\n // prettier-ignore\n console.log(' media styles:', importance, styleObj, singleMediaStyles.map(x => x.identifier).join(', '))\n }\n // add to output\n mediaStyles = [...mediaStyles, ...singleMediaStyles]\n }\n // filter out\n ternary.remove()\n return { mediaStyles, ternaryWithoutMedia: mt.ternaryWithoutMedia }\n}\n\nfunction getMediaQueryTernary(\n ternary: Ternary,\n jsxPath: NodePath<t.JSXElement>,\n sourcePath: string\n): null | {\n key: string\n bindingName: string\n ternaryWithoutMedia: Ternary | null\n} {\n // this handles unwrapping logical && media query ternarys\n // first, unwrap if it has media logicalExpression\n if (t.isLogicalExpression(ternary.test) && ternary.test.operator === '&&') {\n // *should* be normalized to always be on left side\n const mediaLeft = getMediaInfoFromExpression(\n ternary.test.left,\n jsxPath,\n sourcePath,\n ternary.inlineMediaQuery\n )\n if (mediaLeft) {\n return {\n ...mediaLeft,\n ternaryWithoutMedia: {\n ...ternary,\n test: ternary.test.right,\n },\n }\n }\n }\n // const media = useMedia()\n // ... media.sm\n const result = getMediaInfoFromExpression(\n ternary.test,\n jsxPath,\n sourcePath,\n ternary.inlineMediaQuery\n )\n if (result) {\n return {\n ...result,\n ternaryWithoutMedia: null,\n }\n }\n return null\n}\n\nfunction getMediaInfoFromExpression(\n test: t.Expression,\n jsxPath: NodePath<t.JSXElement>,\n sourcePath: string,\n inlineMediaQuery?: string\n) {\n if (inlineMediaQuery) {\n return {\n key: inlineMediaQuery,\n bindingName: inlineMediaQuery,\n }\n }\n if (t.isMemberExpression(test) && t.isIdentifier(test.object) && t.isIdentifier(test.property)) {\n const name = test.object['name']\n const key = test.property['name']\n const bindings = jsxPath.scope.getAllBindings()\n const binding = bindings[name]\n if (!binding) return false\n const bindingNode = binding.path?.node\n if (!t.isVariableDeclarator(bindingNode) || !bindingNode.init) return false\n if (!isValidMediaCall(jsxPath, bindingNode.init, sourcePath)) return false\n return { key, bindingName: name }\n }\n if (t.isIdentifier(test)) {\n const key = test.name\n const node = jsxPath.scope.getBinding(test.name)?.path?.node\n if (!t.isVariableDeclarator(node)) return false\n if (!node.init || !isValidMediaCall(jsxPath, node.init, sourcePath)) return false\n return { key, bindingName: key }\n }\n return null\n}\n\nexport function isValidMediaCall(\n jsxPath: NodePath<t.JSXElement>,\n init: t.Expression,\n sourcePath: string\n) {\n if (!t.isCallExpression(init)) return false\n if (!t.isIdentifier(init.callee)) return false\n // TODO could support renaming useMedia by looking up import first\n if (init.callee.name !== 'useMedia') return false\n const bindings = jsxPath.scope.getAllBindings()\n const mediaBinding = bindings['useMedia']\n if (!mediaBinding) return false\n const useMediaImport = mediaBinding.path.parent\n if (!t.isImportDeclaration(useMediaImport)) return false\n if (useMediaImport.source.value !== 'tamagui') {\n if (!isInsideTamagui(sourcePath)) {\n return false\n }\n }\n return true\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,305 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
21
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
22
|
-
var extractToClassNames_exports = {};
|
|
23
|
-
__export(extractToClassNames_exports, {
|
|
24
|
-
extractToClassNames: () => extractToClassNames
|
|
25
|
-
});
|
|
26
|
-
module.exports = __toCommonJS(extractToClassNames_exports);
|
|
27
|
-
var path = __toESM(require("path"));
|
|
28
|
-
var import_path = require("path");
|
|
29
|
-
var util = __toESM(require("util"));
|
|
30
|
-
var import_generator = __toESM(require("@babel/generator"));
|
|
31
|
-
var t = __toESM(require("@babel/types"));
|
|
32
|
-
var import_core_node = require("@tamagui/core-node");
|
|
33
|
-
var import_helpers = require("@tamagui/helpers");
|
|
34
|
-
var import_invariant = __toESM(require("invariant"));
|
|
35
|
-
var import_constants = require("../constants");
|
|
36
|
-
var import_babelParse = require("./babelParse");
|
|
37
|
-
var import_buildClassName = require("./buildClassName");
|
|
38
|
-
var import_ensureImportingConcat = require("./ensureImportingConcat");
|
|
39
|
-
var import_extractHelpers = require("./extractHelpers");
|
|
40
|
-
var import_extractMediaStyle = require("./extractMediaStyle");
|
|
41
|
-
var import_getPrefixLogs = require("./getPrefixLogs");
|
|
42
|
-
var import_hoistClassNames = require("./hoistClassNames");
|
|
43
|
-
var import_logLines = require("./logLines");
|
|
44
|
-
var import_timer = require("./timer");
|
|
45
|
-
const mergeStyleGroups = {
|
|
46
|
-
shadowOpacity: true,
|
|
47
|
-
shadowRadius: true,
|
|
48
|
-
shadowColor: true,
|
|
49
|
-
shadowOffset: true
|
|
50
|
-
};
|
|
51
|
-
function extractToClassNames({
|
|
52
|
-
extractor,
|
|
53
|
-
source,
|
|
54
|
-
sourcePath,
|
|
55
|
-
options,
|
|
56
|
-
shouldPrintDebug
|
|
57
|
-
}) {
|
|
58
|
-
const tm = (0, import_timer.timer)();
|
|
59
|
-
if (typeof source !== "string") {
|
|
60
|
-
throw new Error("`source` must be a string of javascript");
|
|
61
|
-
}
|
|
62
|
-
(0, import_invariant.default)(typeof sourcePath === "string" && path.isAbsolute(sourcePath), "`sourcePath` must be an absolute path to a .js file");
|
|
63
|
-
const shouldLogTiming = options.logTimings ?? true;
|
|
64
|
-
const start = Date.now();
|
|
65
|
-
const mem = shouldLogTiming ? process.memoryUsage() : null;
|
|
66
|
-
let ast;
|
|
67
|
-
try {
|
|
68
|
-
ast = (0, import_babelParse.babelParse)(source);
|
|
69
|
-
} catch (err) {
|
|
70
|
-
console.error("babel parse error:", sourcePath);
|
|
71
|
-
throw err;
|
|
72
|
-
}
|
|
73
|
-
tm.mark(`babel-parse`, shouldPrintDebug === "verbose");
|
|
74
|
-
const cssMap = /* @__PURE__ */ new Map();
|
|
75
|
-
const existingHoists = {};
|
|
76
|
-
let hasFlattened = false;
|
|
77
|
-
const res = extractor.parse(ast, {
|
|
78
|
-
sourcePath,
|
|
79
|
-
shouldPrintDebug,
|
|
80
|
-
...options,
|
|
81
|
-
target: "html",
|
|
82
|
-
extractStyledDefinitions: true,
|
|
83
|
-
onStyleRule(identifier, rules) {
|
|
84
|
-
cssMap.set(`.${identifier}`, { css: rules.join(";"), commentTexts: [] });
|
|
85
|
-
},
|
|
86
|
-
getFlattenedNode: ({ tag }) => {
|
|
87
|
-
hasFlattened = true;
|
|
88
|
-
return tag;
|
|
89
|
-
},
|
|
90
|
-
onExtractTag: ({
|
|
91
|
-
attrs,
|
|
92
|
-
node,
|
|
93
|
-
attemptEval,
|
|
94
|
-
jsxPath,
|
|
95
|
-
originalNodeName,
|
|
96
|
-
filePath,
|
|
97
|
-
lineNumbers,
|
|
98
|
-
programPath,
|
|
99
|
-
isFlattened
|
|
100
|
-
}) => {
|
|
101
|
-
var _a;
|
|
102
|
-
const didFlattenThisTag = hasFlattened;
|
|
103
|
-
hasFlattened = false;
|
|
104
|
-
let finalClassNames = [];
|
|
105
|
-
let finalAttrs = [];
|
|
106
|
-
let finalStyles = [];
|
|
107
|
-
let viewStyles = {};
|
|
108
|
-
for (const attr of attrs) {
|
|
109
|
-
if (attr.type === "style") {
|
|
110
|
-
viewStyles = {
|
|
111
|
-
...viewStyles,
|
|
112
|
-
...attr.value
|
|
113
|
-
};
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
const ensureNeededPrevStyle = (style) => {
|
|
117
|
-
const keys = Object.keys(style);
|
|
118
|
-
if (!keys.some((key) => mergeStyleGroups[key])) {
|
|
119
|
-
return style;
|
|
120
|
-
}
|
|
121
|
-
for (const k in mergeStyleGroups) {
|
|
122
|
-
if (k in viewStyles) {
|
|
123
|
-
style[k] = style[k] ?? viewStyles[k];
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
return style;
|
|
127
|
-
};
|
|
128
|
-
const addStyles = (style) => {
|
|
129
|
-
if (!style)
|
|
130
|
-
return [];
|
|
131
|
-
const styleWithPrev = ensureNeededPrevStyle(style);
|
|
132
|
-
const res2 = (0, import_core_node.getStylesAtomic)(styleWithPrev);
|
|
133
|
-
if (res2.length) {
|
|
134
|
-
finalStyles = [...finalStyles, ...res2];
|
|
135
|
-
}
|
|
136
|
-
return res2;
|
|
137
|
-
};
|
|
138
|
-
let lastMediaImportance = 1;
|
|
139
|
-
for (const attr of attrs) {
|
|
140
|
-
switch (attr.type) {
|
|
141
|
-
case "style":
|
|
142
|
-
if (!isFlattened) {
|
|
143
|
-
const styles2 = (0, import_core_node.getStylesAtomic)(attr.value);
|
|
144
|
-
finalStyles = [...finalStyles, ...styles2];
|
|
145
|
-
for (const style of styles2) {
|
|
146
|
-
const prop = style.pseudo ? `${style.property}-${style.pseudo}` : style.property;
|
|
147
|
-
finalAttrs.push(t.jsxAttribute(t.jsxIdentifier(prop), t.stringLiteral(style.identifier)));
|
|
148
|
-
}
|
|
149
|
-
} else {
|
|
150
|
-
const styles2 = addStyles(attr.value);
|
|
151
|
-
const newClassNames = (0, import_helpers.concatClassName)(styles2.map((x) => x.identifier).join(" "));
|
|
152
|
-
const existing = finalClassNames.find((x) => x.type == "StringLiteral");
|
|
153
|
-
if (existing) {
|
|
154
|
-
existing.value = `${existing.value} ${newClassNames}`;
|
|
155
|
-
} else {
|
|
156
|
-
finalClassNames = [...finalClassNames, t.stringLiteral(newClassNames)];
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
break;
|
|
160
|
-
case "attr":
|
|
161
|
-
const val = attr.value;
|
|
162
|
-
if (t.isJSXSpreadAttribute(val)) {
|
|
163
|
-
if ((0, import_extractHelpers.isSimpleSpread)(val)) {
|
|
164
|
-
finalClassNames.push(t.logicalExpression("&&", val.argument, t.memberExpression(val.argument, t.identifier("className"))));
|
|
165
|
-
}
|
|
166
|
-
} else if (val.name.name === "className") {
|
|
167
|
-
const value = val.value;
|
|
168
|
-
if (value) {
|
|
169
|
-
try {
|
|
170
|
-
const evaluatedValue = attemptEval(value);
|
|
171
|
-
finalClassNames.push(t.stringLiteral(evaluatedValue));
|
|
172
|
-
} catch (e) {
|
|
173
|
-
finalClassNames.push(value["expression"]);
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
continue;
|
|
177
|
-
}
|
|
178
|
-
finalAttrs.push(val);
|
|
179
|
-
break;
|
|
180
|
-
case "ternary":
|
|
181
|
-
const mediaExtraction = (0, import_extractMediaStyle.extractMediaStyle)(attr.value, jsxPath, extractor.getTamagui(), sourcePath, lastMediaImportance, shouldPrintDebug);
|
|
182
|
-
if (shouldPrintDebug) {
|
|
183
|
-
if (mediaExtraction) {
|
|
184
|
-
console.log("ternary (mediaStyles)", ((_a = mediaExtraction.ternaryWithoutMedia) == null ? void 0 : _a.inlineMediaQuery) ?? "", mediaExtraction.mediaStyles.map((x) => x.identifier).join("."));
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
if (!mediaExtraction) {
|
|
188
|
-
addTernaryStyle(attr.value, addStyles(attr.value.consequent), addStyles(attr.value.alternate));
|
|
189
|
-
continue;
|
|
190
|
-
}
|
|
191
|
-
lastMediaImportance++;
|
|
192
|
-
if (mediaExtraction.mediaStyles) {
|
|
193
|
-
finalStyles = [...finalStyles, ...mediaExtraction.mediaStyles];
|
|
194
|
-
}
|
|
195
|
-
if (mediaExtraction.ternaryWithoutMedia) {
|
|
196
|
-
addTernaryStyle(mediaExtraction.ternaryWithoutMedia, mediaExtraction.mediaStyles, []);
|
|
197
|
-
} else {
|
|
198
|
-
finalClassNames = [
|
|
199
|
-
...finalClassNames,
|
|
200
|
-
...mediaExtraction.mediaStyles.map((x) => t.stringLiteral(x.identifier))
|
|
201
|
-
];
|
|
202
|
-
}
|
|
203
|
-
break;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
function addTernaryStyle(ternary, a, b) {
|
|
207
|
-
const cCN = a.map((x) => x.identifier).join(" ");
|
|
208
|
-
const aCN = b.map((x) => x.identifier).join(" ");
|
|
209
|
-
if (a.length && b.length) {
|
|
210
|
-
finalClassNames.push(t.conditionalExpression(ternary.test, t.stringLiteral(cCN), t.stringLiteral(aCN)));
|
|
211
|
-
} else {
|
|
212
|
-
finalClassNames.push(t.conditionalExpression(ternary.test, t.stringLiteral(" " + cCN), t.stringLiteral(" " + aCN)));
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
if (shouldPrintDebug) {
|
|
216
|
-
console.log(" finalClassNames\n", (0, import_logLines.logLines)(finalClassNames.map((x) => x["value"]).join(" ")));
|
|
217
|
-
}
|
|
218
|
-
node.attributes = finalAttrs;
|
|
219
|
-
if (finalClassNames.length) {
|
|
220
|
-
let names = (0, import_buildClassName.buildClassName)(finalClassNames);
|
|
221
|
-
if (t.isStringLiteral(names)) {
|
|
222
|
-
names.value = (0, import_helpers.concatClassName)(names.value);
|
|
223
|
-
}
|
|
224
|
-
const nameExpr = names ? (0, import_hoistClassNames.hoistClassNames)(jsxPath, existingHoists, names) : null;
|
|
225
|
-
let expr = nameExpr;
|
|
226
|
-
if (nameExpr && !t.isIdentifier(nameExpr)) {
|
|
227
|
-
if (!didFlattenThisTag) {
|
|
228
|
-
} else {
|
|
229
|
-
(0, import_ensureImportingConcat.ensureImportingConcat)(programPath);
|
|
230
|
-
const simpleSpreads = attrs.filter((x) => t.isJSXSpreadAttribute(x.value) && (0, import_extractHelpers.isSimpleSpread)(x.value));
|
|
231
|
-
expr = t.callExpression(t.identifier(import_constants.CONCAT_CLASSNAME_IMPORT), [
|
|
232
|
-
expr,
|
|
233
|
-
...simpleSpreads.map((val) => val.value["argument"])
|
|
234
|
-
]);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
node.attributes.push(t.jsxAttribute(t.jsxIdentifier("className"), t.jsxExpressionContainer(expr)));
|
|
238
|
-
}
|
|
239
|
-
const comment = util.format("/* %s:%s (%s) */", filePath, lineNumbers, originalNodeName);
|
|
240
|
-
for (const { identifier, rules } of finalStyles) {
|
|
241
|
-
const className = `.${identifier}`;
|
|
242
|
-
if (cssMap.has(className)) {
|
|
243
|
-
if (comment) {
|
|
244
|
-
const val = cssMap.get(className);
|
|
245
|
-
val.commentTexts.push(comment);
|
|
246
|
-
cssMap.set(className, val);
|
|
247
|
-
}
|
|
248
|
-
} else if (rules.length) {
|
|
249
|
-
if (rules.length > 1) {
|
|
250
|
-
console.log(" rules error", { rules });
|
|
251
|
-
throw new Error(`Shouldn't have more than one rule`);
|
|
252
|
-
}
|
|
253
|
-
cssMap.set(className, {
|
|
254
|
-
css: rules[0],
|
|
255
|
-
commentTexts: [comment]
|
|
256
|
-
});
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
}
|
|
260
|
-
});
|
|
261
|
-
if (!res || !res.modified && !res.optimized && !res.flattened && !res.styled) {
|
|
262
|
-
if (shouldPrintDebug) {
|
|
263
|
-
console.log("no res or none modified", res);
|
|
264
|
-
}
|
|
265
|
-
return null;
|
|
266
|
-
}
|
|
267
|
-
const styles = Array.from(cssMap.values()).map((x) => x.css).join("\n").trim();
|
|
268
|
-
const result = (0, import_generator.default)(ast, {
|
|
269
|
-
concise: false,
|
|
270
|
-
filename: sourcePath,
|
|
271
|
-
retainLines: false,
|
|
272
|
-
sourceFileName: sourcePath,
|
|
273
|
-
sourceMaps: true
|
|
274
|
-
}, source);
|
|
275
|
-
if (shouldPrintDebug) {
|
|
276
|
-
console.log("\n -------- output code ------- \n\n", result.code.split("\n").filter((x) => !x.startsWith("//")).join("\n"));
|
|
277
|
-
console.log("\n -------- output style -------- \n\n", styles);
|
|
278
|
-
}
|
|
279
|
-
if (shouldLogTiming) {
|
|
280
|
-
const memUsed = mem ? Math.round((process.memoryUsage().heapUsed - mem.heapUsed) / 1024 / 1204 * 10) / 10 : 0;
|
|
281
|
-
const path2 = (0, import_path.basename)(sourcePath).replace(/\.[jt]sx?$/, "").slice(0, 22).trim().padStart(24);
|
|
282
|
-
const numStyled = `${res.styled}`.padStart(3);
|
|
283
|
-
const numOptimized = `${res.optimized}`.padStart(3);
|
|
284
|
-
const numFound = `${res.found}`.padStart(3);
|
|
285
|
-
const numFlattened = `${res.flattened}`.padStart(3);
|
|
286
|
-
const memory = process.env.DEBUG && memUsed > 10 ? ` ${memUsed}MB` : "";
|
|
287
|
-
const timing = Date.now() - start;
|
|
288
|
-
const timingWarning = timing > 150 ? "\u26A0\uFE0F" : timing > 150 ? "\u2622\uFE0F" : "";
|
|
289
|
-
const timingStr = `${timing}ms ${timingWarning}`.padStart(6);
|
|
290
|
-
const pre = (0, import_getPrefixLogs.getPrefixLogs)(options);
|
|
291
|
-
const memStr = memory ? `(${memory})` : "";
|
|
292
|
-
console.log(`${pre} ${path2} ${numFound} \xB7 ${numOptimized} \xB7 ${numFlattened} \xB7 ${numStyled} ${timingStr} ${memStr}`);
|
|
293
|
-
}
|
|
294
|
-
return {
|
|
295
|
-
ast,
|
|
296
|
-
styles,
|
|
297
|
-
js: result.code,
|
|
298
|
-
map: result.map
|
|
299
|
-
};
|
|
300
|
-
}
|
|
301
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
302
|
-
0 && (module.exports = {
|
|
303
|
-
extractToClassNames
|
|
304
|
-
});
|
|
305
|
-
//# sourceMappingURL=extractToClassNames.js.map
|