react-native-boost 0.5.3 → 0.5.5
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/plugin/esm/index.mjs +217 -161
- package/dist/plugin/esm/index.mjs.map +1 -1
- package/dist/plugin/index.js +217 -161
- package/dist/plugin/index.js.map +1 -1
- package/package.json +1 -1
- package/src/plugin/optimizers/text/index.ts +127 -155
- package/src/plugin/optimizers/view/index.ts +96 -50
- package/src/plugin/utils/common/attributes.ts +144 -0
- package/src/plugin/utils/common/base.ts +82 -0
- package/src/plugin/utils/common/index.ts +4 -0
- package/src/plugin/utils/common/node-types.ts +22 -0
- package/src/plugin/utils/common/validation.ts +181 -0
- package/src/plugin/utils/constants.ts +16 -0
- package/src/plugin/utils/common.ts +0 -296
package/dist/plugin/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../src/plugin/utils/plugin-error.ts","../../src/plugin/utils/helpers.ts","../../src/plugin/utils/common.ts","../../src/plugin/optimizers/text/index.ts","../../src/plugin/utils/logger.ts","../../src/plugin/optimizers/view/index.ts","../../src/plugin/index.ts"],"sourcesContent":["export default class PluginError extends Error {\n constructor(message: string) {\n super(`[react-native-boost] Babel plugin exception: ${message}`);\n this.name = 'PluginError';\n }\n}\n","export const ensureArray = <T>(value: T | T[]): T[] => {\n if (Array.isArray(value)) return value;\n return [value];\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { ensureArray } from './helpers';\nimport { FileImportOptions, HubFile } from '../types';\nimport { minimatch } from 'minimatch';\nimport path from 'node:path';\nimport PluginError from './plugin-error';\nimport { addDefault, addNamed } from '@babel/helper-module-imports';\n\n/**\n * Adds a hint to the file object to ensure that a specific import is added only once and cached on the file object.\n *\n * @param opts - Object containing the function arguments:\n * - file: The Babel file object (e.g. HubFile)\n * - nameHint: The name hint which also acts as the cache key to ensure the import is only added once (e.g. 'normalizeAccessibilityProps')\n * - path: The current Babel NodePath\n * - importName: The named import string (e.g. 'normalizeAccessibilityProps'), used when importType is 'named'\n * - moduleName: The module to import from (e.g. 'react-native-boost')\n * - importType: Either 'named' (default) or 'default' to determine the type of import to use.\n *\n * @returns The identifier returned by addNamed or addDefault.\n */\nexport function addFileImportHint({\n file,\n nameHint,\n path,\n importName,\n moduleName,\n importType = 'named',\n}: FileImportOptions): t.Identifier {\n if (!file.__hasImports?.[nameHint]) {\n file.__hasImports = file.__hasImports || {};\n file.__hasImports[nameHint] =\n importType === 'default'\n ? addDefault(path, moduleName, { nameHint })\n : addNamed(path, importName, moduleName, { nameHint });\n }\n return file.__hasImports[nameHint];\n}\n/**\n * Checks if the file is in the list of ignored files.\n *\n * @param p - The path to the JSXOpeningElement.\n * @param ignores - List of glob paths (absolute or relative to import.meta.dirname).\n * @returns true if the file matches any of the ignore patterns.\n */\nexport const isIgnoredFile = (p: NodePath<t.JSXOpeningElement>, ignores: string[]): boolean => {\n const hub = p.hub as unknown;\n const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;\n\n if (!file) {\n throw new PluginError('No file found in Babel hub');\n }\n\n const fileName = file.opts.filename;\n\n // Use the current working directory which typically corresponds to the user's project root.\n const baseDirectory = 'cwd' in file.opts ? (file.opts.cwd as string) : process.cwd();\n\n // Iterate through the ignore patterns.\n for (const pattern of ignores) {\n // If the pattern is not absolute, join it with the baseDir\n const absolutePattern = path.isAbsolute(pattern) ? pattern : path.join(baseDirectory, pattern);\n\n // Check if the file name matches the glob pattern.\n if (minimatch(fileName, absolutePattern, { dot: true })) {\n return true;\n }\n }\n\n return false;\n};\n\n/**\n * Checks if the JSX element should be ignored based on a preceding comment.\n *\n * The function looks up the JSXOpeningElement's own leading comments as well as\n * the parent element's comments before falling back to inspect siblings.\n *\n * @param path - The path to the JSXOpeningElement.\n * @returns true if the JSX element should be ignored.\n */\nexport const shouldIgnoreOptimization = (path: NodePath<t.JSXOpeningElement>): boolean => {\n // Check for @boost-ignore in the leading comments on the JSX opening element.\n if (path.node.leadingComments?.some((comment) => comment.value.includes('@boost-ignore'))) {\n return true;\n }\n\n // Check for @boost-ignore in the leading comments on the parent JSX element.\n const jsxElementPath = path.parentPath;\n if (jsxElementPath.node.leadingComments?.some((comment) => comment.value.includes('@boost-ignore'))) {\n return true;\n }\n\n // NEW: Check for @boost-ignore in the leading comments on the ObjectProperty (if it exists)\n // This handles cases where the JSX element is used as a value inside an object literal.\n const propertyPath = jsxElementPath.parentPath;\n if (\n propertyPath &&\n propertyPath.isObjectProperty() &&\n propertyPath.node.leadingComments?.some((comment) => comment.value.includes('@boost-ignore'))\n ) {\n return true;\n }\n\n if (!jsxElementPath.parentPath) return false;\n\n // Get the container that holds this element (for example, a JSX fragment or JSX element)\n const containerPath = jsxElementPath.parentPath;\n const siblings = ensureArray(containerPath.get('children'));\n const index = siblings.findIndex((sibling) => sibling.node === jsxElementPath.node);\n if (index === -1) return false;\n\n // Look backward from the current element for a non-empty node.\n for (let index_ = index - 1; index_ >= 0; index_--) {\n const sibling = siblings[index_];\n // Skip over any whitespace (only in JSXText nodes)\n if (sibling.isJSXText() && sibling.node.value.trim() === '') {\n continue;\n }\n // If the sibling is a JSX expression container, check its empty expression's comments.\n if (sibling.isJSXExpressionContainer()) {\n const expression = sibling.get('expression');\n if (expression && expression.node) {\n const comments = [\n ...(expression.node.leadingComments || []),\n ...(expression.node.trailingComments || []),\n ...(expression.node.innerComments || []),\n ].map((comment) => comment.value.trim());\n if (comments.some((comment) => comment.includes('@boost-ignore'))) {\n return true;\n }\n }\n }\n // Also check if the node itself carries a leadingComments property.\n if (\n sibling.node.leadingComments &&\n sibling.node.leadingComments.some((comment) => comment.value.includes('@boost-ignore'))\n ) {\n return true;\n }\n break; // if the immediate non-whitespace node is not our ignore marker, stop\n }\n return false;\n};\n\n/**\n * Checks if the JSX element has a blacklisted property.\n *\n * @param path - The path to the JSXOpeningElement.\n * @param blacklist - The set of blacklisted properties.\n * @returns true if the JSX element has a blacklisted property.\n */\nexport const hasBlacklistedProperty = (path: NodePath<t.JSXOpeningElement>, blacklist: Set<string>): boolean => {\n return path.node.attributes.some((attribute) => {\n // Check if we can resolve the spread attribute\n if (t.isJSXSpreadAttribute(attribute)) {\n if (t.isIdentifier(attribute.argument)) {\n const binding = path.scope.getBinding(attribute.argument.name);\n let objectExpression: t.ObjectExpression | undefined;\n if (binding) {\n // If the binding node is a VariableDeclarator, use its initializer\n if (t.isVariableDeclarator(binding.path.node)) {\n objectExpression = binding.path.node.init as t.ObjectExpression;\n } else if (t.isObjectExpression(binding.path.node)) {\n objectExpression = binding.path.node;\n }\n }\n if (objectExpression && t.isObjectExpression(objectExpression)) {\n return objectExpression.properties.some((property) => {\n if (t.isObjectProperty(property) && t.isIdentifier(property.key)) {\n return blacklist.has(property.key.name);\n }\n return false;\n });\n }\n }\n // Bail if we can't resolve the spread attribute\n return true;\n }\n\n // For other attribute types (e.g. namespaced), assume no blacklisting\n return false;\n });\n};\n\n/**\n * Helper that builds an Object.assign expression out of the existing JSX attributes.\n * It handles both plain JSXAttributes and spread attributes.\n *\n * @param attributes - The attributes to build the expression from.\n * @returns The Object.assign expression.\n */\nexport const buildPropertiesFromAttributes = (attributes: (t.JSXAttribute | t.JSXSpreadAttribute)[]): t.Expression => {\n const arguments_: t.Expression[] = [];\n for (const attribute of attributes) {\n if (t.isJSXSpreadAttribute(attribute)) {\n arguments_.push(attribute.argument);\n } else if (t.isJSXAttribute(attribute)) {\n const key = attribute.name.name;\n let value: t.Expression;\n if (!attribute.value) {\n value = t.booleanLiteral(true);\n } else if (t.isStringLiteral(attribute.value)) {\n value = attribute.value;\n } else if (t.isJSXExpressionContainer(attribute.value)) {\n value = t.isJSXEmptyExpression(attribute.value.expression)\n ? t.booleanLiteral(true)\n : attribute.value.expression;\n } else {\n value = t.nullLiteral();\n }\n // If the key is not a valid JavaScript identifier (e.g. \"aria-label\"), use a string literal.\n const validIdentifierRegex = /^[a-zA-Z_$][a-zA-Z0-9_$]*$/;\n const keyNode =\n typeof key === 'string' && validIdentifierRegex.test(key) ? t.identifier(key) : t.stringLiteral(key.toString());\n\n arguments_.push(t.objectExpression([t.objectProperty(keyNode, value)]));\n }\n }\n if (arguments_.length === 0) {\n return t.objectExpression([]);\n }\n return t.callExpression(t.memberExpression(t.identifier('Object'), t.identifier('assign')), [\n t.objectExpression([]),\n ...arguments_,\n ]);\n};\n\n/**\n * The set of accessibility properties that need to be normalized.\n */\nexport const accessibilityProperties = new Set([\n 'accessibilityLabel',\n 'aria-label',\n 'accessibilityState',\n 'aria-busy',\n 'aria-checked',\n 'aria-disabled',\n 'aria-expanded',\n 'aria-selected',\n 'accessible',\n]);\n\n/**\n * Checks if the JSX element has an accessibility property.\n *\n * @param path - The NodePath for the JSXOpeningElement, used for scope lookup.\n * @param attributes - The attributes to check.\n * @returns true if the JSX element has an accessibility property.\n */\nexport const hasAccessibilityProperty = (\n path: NodePath<t.JSXOpeningElement>,\n attributes: (t.JSXAttribute | t.JSXSpreadAttribute)[]\n): boolean => {\n for (const attribute of attributes) {\n if (t.isJSXAttribute(attribute)) {\n const key = attribute.name.name;\n if (typeof key === 'string' && accessibilityProperties.has(key)) {\n return true;\n }\n } else if (t.isJSXSpreadAttribute(attribute)) {\n if (t.isObjectExpression(attribute.argument)) {\n for (const property of attribute.argument.properties) {\n if (\n t.isObjectProperty(property) &&\n t.isIdentifier(property.key) &&\n accessibilityProperties.has(property.key.name)\n ) {\n return true;\n }\n }\n } else if (t.isIdentifier(attribute.argument)) {\n const binding = path.scope.getBinding(attribute.argument.name);\n if (binding && t.isVariableDeclarator(binding.path.node)) {\n const declarator = binding.path.node as t.VariableDeclarator;\n if (declarator.init && t.isObjectExpression(declarator.init)) {\n for (const property of declarator.init.properties) {\n if (\n t.isObjectProperty(property) &&\n t.isIdentifier(property.key) &&\n accessibilityProperties.has(property.key.name)\n ) {\n return true;\n }\n }\n continue;\n }\n }\n return true;\n } else {\n return true;\n }\n }\n }\n return false;\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { HubFile, Optimizer } from '../../types';\nimport PluginError from '../../utils/plugin-error';\nimport {\n addFileImportHint,\n buildPropertiesFromAttributes,\n hasAccessibilityProperty,\n hasBlacklistedProperty,\n shouldIgnoreOptimization,\n} from '../../utils/common';\n\nexport const textBlacklistedProperties = new Set([\n 'allowFontScaling',\n 'ellipsizeMode',\n 'id',\n 'nativeID',\n 'onLongPress',\n 'onPress',\n 'onPressIn',\n 'onPressOut',\n 'onResponderGrant',\n 'onResponderMove',\n 'onResponderRelease',\n 'onResponderTerminate',\n 'onResponderTerminationRequest',\n 'onStartShouldSetResponder',\n 'pressRetentionOffset',\n 'suppressHighlighting',\n 'selectable',\n 'selectionColor',\n]);\n\nexport const textOptimizer: Optimizer = (path, log = () => {}) => {\n // Ensure we're processing a JSX Text element\n if (!t.isJSXIdentifier(path.node.name)) return;\n\n const parent = path.parent;\n if (!t.isJSXElement(parent)) return;\n\n const elementName = path.node.name.name;\n if (elementName !== 'Text') return;\n\n // If the component is preceded by an ignore comment, do not optimize.\n if (shouldIgnoreOptimization(path)) {\n return;\n }\n\n // Ensure Text element comes from react-native\n const binding = path.scope.getBinding(elementName);\n if (!binding) return;\n if (binding.kind === 'module') {\n const parentNode = binding.path.parent;\n if (!t.isImportDeclaration(parentNode) || parentNode.source.value !== 'react-native') {\n return;\n }\n }\n\n // Bail if the element has any blacklisted properties or non-string children props\n if (hasBlacklistedProperty(path, textBlacklistedProperties)) return;\n if (hasInvalidChildren(path)) return;\n if (!hasOnlyStringChildren(path, parent)) return;\n\n // Extract the file from the Babel hub and add flags for logging & import caching\n const hub = path.hub as unknown;\n const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;\n\n if (!file) {\n throw new PluginError('No file found in Babel hub');\n }\n\n const filename = file.opts?.filename || 'unknown file';\n const lineNumber = path.node.loc?.start.line ?? 'unknown line';\n log(`Optimizing Text component in ${filename}:${lineNumber}`);\n\n // Optimize props\n fixNegativeNumberOfLines({ path, log });\n\n // Process style and accessibility props\n const originalAttributes = [...path.node.attributes];\n let styleAttribute, styleExpr;\n for (const attribute of originalAttributes) {\n if (t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' })) {\n styleAttribute = attribute;\n break;\n }\n }\n if (\n styleAttribute &&\n styleAttribute.value &&\n t.isJSXExpressionContainer(styleAttribute.value) &&\n !t.isJSXEmptyExpression(styleAttribute.value.expression)\n ) {\n styleExpr = styleAttribute.value.expression;\n }\n const hasA11y = hasAccessibilityProperty(path, originalAttributes);\n\n if (styleExpr && hasA11y) {\n // When both style and accessibility properties exist, we split them into two separate spread attributes\n\n // Filter out the style attribute for accessibility props\n const accessibilityAttributes = originalAttributes.filter((attribute) => {\n if (t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' })) {\n return false;\n }\n return true;\n });\n\n // Set up the accessibility import if needed\n const normalizeIdentifier = addFileImportHint({\n file,\n nameHint: 'normalizeAccessibilityProps',\n path,\n importName: 'normalizeAccessibilityProps',\n moduleName: 'react-native-boost',\n });\n const accessibilityObject = buildPropertiesFromAttributes(accessibilityAttributes);\n const accessibilityExpr = t.callExpression(t.identifier(normalizeIdentifier.name), [accessibilityObject]);\n\n // Set up the style import if needed.\n const flattenIdentifier = addFileImportHint({\n file,\n nameHint: 'flattenTextStyle',\n path,\n importName: 'flattenTextStyle',\n moduleName: 'react-native-boost',\n });\n const flattenedStyleExpr = t.callExpression(t.identifier(flattenIdentifier.name), [styleExpr]);\n\n // Use two separate JSX spread attributes so that accessibility and style props remain distinct.\n path.node.attributes = [t.jsxSpreadAttribute(accessibilityExpr), t.jsxSpreadAttribute(flattenedStyleExpr)];\n } else if (styleExpr) {\n // Only style attribute is present.\n const flattenIdentifier = addFileImportHint({\n file,\n nameHint: 'flattenTextStyle',\n path,\n importName: 'flattenTextStyle',\n moduleName: 'react-native-boost',\n });\n const flattened = t.callExpression(t.identifier(flattenIdentifier.name), [styleExpr]);\n path.node.attributes = [t.jsxSpreadAttribute(flattened)];\n } else if (hasA11y) {\n // Only accessibility properties are present.\n const normalizeIdentifier = addFileImportHint({\n file,\n nameHint: 'normalizeAccessibilityProps',\n path,\n importName: 'normalizeAccessibilityProps',\n moduleName: 'react-native-boost',\n });\n const propsObject = buildPropertiesFromAttributes(originalAttributes);\n const normalized = t.callExpression(t.identifier(normalizeIdentifier.name), [propsObject]);\n path.node.attributes = [t.jsxSpreadAttribute(normalized)];\n }\n\n // Add TextNativeComponent import (cached on file) so we only add it once per file.\n const nativeTextIdentifier = addFileImportHint({\n file,\n nameHint: 'NativeText',\n path,\n importName: 'NativeText',\n moduleName: 'react-native-boost',\n });\n path.node.name.name = nativeTextIdentifier.name;\n\n // If the element is not self-closing, update the closing element as well\n if (\n !path.node.selfClosing &&\n parent.closingElement &&\n t.isJSXIdentifier(parent.closingElement.name) &&\n parent.closingElement.name.name === 'Text'\n ) {\n parent.closingElement.name.name = nativeTextIdentifier.name;\n }\n};\n\nfunction hasOnlyStringChildren(path: NodePath<t.JSXOpeningElement>, node: t.JSXElement): boolean {\n return node.children.every((child) => isStringNode(path, child));\n}\n\nfunction isStringNode(path: NodePath<t.JSXOpeningElement>, child: t.Node): boolean {\n if (t.isJSXText(child) || t.isStringLiteral(child)) return true;\n\n // Check for JSX expressions\n if (t.isJSXExpressionContainer(child)) {\n const expression = child.expression;\n if (t.isIdentifier(expression)) {\n const binding = path.scope.getBinding(expression.name);\n if (binding && binding.path.node && t.isVariableDeclarator(binding.path.node)) {\n return !!binding.path.node.init && t.isStringLiteral(binding.path.node.init);\n }\n return false;\n }\n if (t.isStringLiteral(expression)) return true;\n }\n return false;\n}\n\nfunction fixNegativeNumberOfLines({\n path,\n log,\n}: {\n path: NodePath<t.JSXOpeningElement>;\n log: (message: string) => void;\n}) {\n for (const attribute of path.node.attributes) {\n if (\n t.isJSXAttribute(attribute) &&\n t.isJSXIdentifier(attribute.name, { name: 'numberOfLines' }) &&\n attribute.value &&\n t.isJSXExpressionContainer(attribute.value)\n ) {\n let originalValue: number | undefined;\n if (t.isNumericLiteral(attribute.value.expression)) {\n originalValue = attribute.value.expression.value;\n } else if (\n t.isUnaryExpression(attribute.value.expression) &&\n attribute.value.expression.operator === '-' &&\n t.isNumericLiteral(attribute.value.expression.argument)\n ) {\n originalValue = -attribute.value.expression.argument.value;\n }\n if (originalValue !== undefined && originalValue < 0) {\n log(\n `Warning: 'numberOfLines' in <Text> must be a non-negative number, received: ${originalValue}. The value will be set to 0.`\n );\n attribute.value.expression = t.numericLiteral(0);\n }\n }\n }\n}\n\nfunction hasInvalidChildren(path: NodePath<t.JSXOpeningElement>): boolean {\n for (const attribute of path.node.attributes) {\n if (t.isJSXSpreadAttribute(attribute)) continue; // Spread attributes are handled in hasBlacklistedProperty\n\n if (t.isJSXIdentifier(attribute.name) && attribute.value) {\n // For a \"children\" attribute, optimization is allowed only if it is a string\n if (attribute.name.name === 'children') {\n if (!isStringNode(path, attribute.value)) {\n return true;\n }\n } else if (textBlacklistedProperties.has(attribute.name.name)) {\n return true;\n }\n }\n }\n return false;\n}\n","export const log = (message: string) => {\n console.log(`[react-native-boost] ${message}`);\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { HubFile, Optimizer } from '../../types';\nimport PluginError from '../../utils/plugin-error';\nimport { addFileImportHint, hasBlacklistedProperty, shouldIgnoreOptimization } from '../../utils/common';\n\nexport const viewBlacklistedProperties = new Set([\n 'accessible',\n 'accessibilityLabel',\n 'accessibilityState',\n 'allowFontScaling',\n 'aria-busy',\n 'aria-checked',\n 'aria-disabled',\n 'aria-expanded',\n 'aria-label',\n 'aria-selected',\n 'ellipsizeMode',\n 'disabled',\n 'id',\n 'nativeID',\n 'numberOfLines',\n 'onLongPress',\n 'onPress',\n 'onPressIn',\n 'onPressOut',\n 'onResponderGrant',\n 'onResponderMove',\n 'onResponderRelease',\n 'onResponderTerminate',\n 'onResponderTerminationRequest',\n 'onStartShouldSetResponder',\n 'pressRetentionOffset',\n 'selectable',\n 'selectionColor',\n 'suppressHighlighting',\n 'style',\n]);\n\nexport const viewOptimizer: Optimizer = (path, log = () => {}) => {\n // Ensure we're processing a JSX element identifier.\n if (!t.isJSXIdentifier(path.node.name)) return;\n\n const parent = path.parent;\n if (!t.isJSXElement(parent)) return;\n\n const elementName = path.node.name.name;\n if (elementName !== 'View') return;\n\n // Respect comments that disable optimization.\n if (shouldIgnoreOptimization(path)) return;\n\n // Ensure the View element comes from react-native.\n const binding = path.scope.getBinding(elementName);\n if (!binding) return;\n if (binding.kind === 'module') {\n const parentNode = binding.path.parent;\n if (!t.isImportDeclaration(parentNode) || parentNode.source.value !== 'react-native') {\n return;\n }\n }\n\n // Bail if any blacklisted props are present.\n if (hasBlacklistedProperty(path, viewBlacklistedProperties)) return;\n\n // Bail if a <TextAncestor /> component exists as an ancestor.\n if (hasTextAncestor(path)) return;\n\n // Extract the file from the Babel hub and add flags for logging & import caching.\n const hub = path.hub as unknown;\n const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;\n\n if (!file) {\n throw new PluginError('No file found in Babel hub');\n }\n\n const filename = file.opts?.filename || 'unknown file';\n const lineNumber = path.node.loc?.start.line ?? 'unknown line';\n log(`Optimizing View component in ${filename}:${lineNumber}`);\n\n // Add ViewNativeComponent import (cached on the file) to prevent duplicate imports.\n const viewNativeIdentifier = addFileImportHint({\n file,\n path,\n importName: 'NativeView',\n moduleName: 'react-native-boost',\n importType: 'named',\n nameHint: 'NativeView',\n });\n\n // Replace the component with its native counterpart.\n path.node.name.name = viewNativeIdentifier.name;\n\n // If the element is not self-closing, update the closing element as well.\n if (\n !path.node.selfClosing &&\n parent.closingElement &&\n t.isJSXIdentifier(parent.closingElement.name) &&\n parent.closingElement.name.name === 'View'\n ) {\n parent.closingElement.name.name = viewNativeIdentifier.name;\n }\n};\n\n/**\n * Returns true if any ancestor element is a <Text />.\n * TODO: This is dangerous as we can't resolve custom components and check if they have a <Text /> ancestor in the tree\n */\nfunction hasTextAncestor(path: NodePath<t.JSXOpeningElement>): boolean {\n return !!path.findParent((parentPath) => {\n return t.isJSXElement(parentPath.node) && t.isJSXIdentifier(parentPath.node.openingElement.name, { name: 'Text' });\n });\n}\n","import { declare } from '@babel/helper-plugin-utils';\nimport { textOptimizer } from './optimizers/text';\nimport { PluginOptions } from './types';\nimport { log } from './utils/logger';\nimport { viewOptimizer } from './optimizers/view';\nimport { isIgnoredFile } from './utils/common';\n\nexport default declare((api) => {\n api.assertVersion(7);\n\n return {\n name: 'react-native-boost',\n visitor: {\n JSXOpeningElement(path, state) {\n const options = (state.opts ?? {}) as PluginOptions;\n const logger = options.verbose ? log : () => {};\n if (isIgnoredFile(path, options.ignores ?? [])) return;\n if (options.optimizations?.text !== false) textOptimizer(path, logger);\n if (options.optimizations?.view !== false) viewOptimizer(path, logger);\n },\n },\n };\n});\n"],"names":["path","addDefault","addNamed","minimatch","t","declare"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/plugin/utils/plugin-error.ts","../../src/plugin/utils/constants.ts","../../src/plugin/utils/common/base.ts","../../src/plugin/utils/helpers.ts","../../src/plugin/utils/common/validation.ts","../../src/plugin/utils/common/attributes.ts","../../src/plugin/utils/common/node-types.ts","../../src/plugin/optimizers/text/index.ts","../../src/plugin/utils/logger.ts","../../src/plugin/optimizers/view/index.ts","../../src/plugin/index.ts"],"sourcesContent":["export default class PluginError extends Error {\n constructor(message: string) {\n super(`[react-native-boost] Babel plugin exception: ${message}`);\n this.name = 'PluginError';\n }\n}\n","export const RUNTIME_MODULE_NAME = 'react-native-boost';\n\n/**\n * The set of accessibility properties that need to be normalized.\n */\nexport const ACCESSIBILITY_PROPERTIES = new Set([\n 'accessibilityLabel',\n 'aria-label',\n 'accessibilityState',\n 'aria-busy',\n 'aria-checked',\n 'aria-disabled',\n 'aria-expanded',\n 'aria-selected',\n 'accessible',\n]);\n","import { NodePath, types as t } from '@babel/core';\nimport { addDefault, addNamed } from '@babel/helper-module-imports';\nimport { FileImportOptions, HubFile } from '../../types';\nimport { RUNTIME_MODULE_NAME } from '../constants';\n\n/**\n * Adds a hint to the file object to ensure that a specific import is added only once and cached on the file object.\n *\n * @param opts - Object containing the function arguments:\n * - file: The Babel file object (e.g. HubFile)\n * - nameHint: The name hint which also acts as the cache key to ensure the import is only added once (e.g. 'normalizeAccessibilityProps')\n * - path: The current Babel NodePath\n * - importName: The named import string (e.g. 'normalizeAccessibilityProps'), used when importType is 'named'\n * - moduleName: The module to import from (e.g. 'react-native-boost')\n * - importType: Either 'named' (default) or 'default' to determine the type of import to use.\n *\n * @returns The identifier returned by addNamed or addDefault.\n */\nexport function addFileImportHint({\n file,\n nameHint,\n path,\n importName,\n moduleName,\n importType = 'named',\n}: FileImportOptions): t.Identifier {\n if (!file.__hasImports?.[nameHint]) {\n file.__hasImports = file.__hasImports || {};\n file.__hasImports[nameHint] =\n importType === 'default'\n ? addDefault(path, moduleName, { nameHint })\n : addNamed(path, importName, moduleName, { nameHint });\n }\n return file.__hasImports[nameHint];\n}\n\n/**\n * Replaces a component with its native counterpart.\n * This function handles both the opening and closing tags.\n *\n * @param path - The path to the JSXOpeningElement.\n * @param parent - The parent JSX element.\n * @param file - The Babel file object.\n * @param nativeComponentName - The name of the native component to import.\n * @param moduleName - The module to import the native component from.\n * @returns The identifier for the imported native component.\n */\nexport const replaceWithNativeComponent = (\n path: NodePath<t.JSXOpeningElement>,\n parent: t.JSXElement,\n file: HubFile,\n nativeComponentName: string\n): t.Identifier => {\n // Add native component import (cached on file) to prevent duplicate imports\n const nativeIdentifier = addFileImportHint({\n file,\n nameHint: nativeComponentName,\n path,\n importName: nativeComponentName,\n moduleName: RUNTIME_MODULE_NAME,\n importType: 'named',\n });\n\n // Get the current name of the component, which may be aliased (i.e. Text -> RNText)\n const currentName = (path.node.name as t.JSXIdentifier).name;\n\n // Replace the component with its native counterpart\n const jsxName = path.node.name as t.JSXIdentifier;\n jsxName.name = nativeIdentifier.name;\n\n // If the element is not self-closing, update the closing element as well\n if (\n !path.node.selfClosing &&\n parent.closingElement &&\n t.isJSXIdentifier(parent.closingElement.name) &&\n parent.closingElement.name.name === currentName\n ) {\n parent.closingElement.name.name = nativeIdentifier.name;\n }\n\n return nativeIdentifier;\n};\n","export const ensureArray = <T>(value: T | T[]): T[] => {\n if (Array.isArray(value)) return value;\n return [value];\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { ensureArray } from '../helpers';\nimport { HubFile } from '../../types';\nimport { minimatch } from 'minimatch';\nimport nodePath from 'node:path';\nimport PluginError from '../plugin-error';\n\n/**\n * Checks if the file is in the list of ignored files.\n *\n * @param path - The path to the JSXOpeningElement.\n * @param ignores - List of glob paths (absolute or relative to import.meta.dirname).\n * @returns true if the file matches any of the ignore patterns.\n */\nexport const isIgnoredFile = (path: NodePath<t.JSXOpeningElement>, ignores: string[]): boolean => {\n const hub = path.hub as unknown;\n const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;\n\n if (!file) {\n throw new PluginError('No file found in Babel hub');\n }\n\n const fileName = file.opts.filename;\n\n // Use the current working directory which typically corresponds to the user's project root.\n const baseDirectory = 'cwd' in file.opts ? (file.opts.cwd as string) : process.cwd();\n\n // Iterate through the ignore patterns.\n for (const pattern of ignores) {\n // If the pattern is not absolute, join it with the baseDir\n const absolutePattern = nodePath.isAbsolute(pattern) ? pattern : nodePath.join(baseDirectory, pattern);\n\n // Check if the file name matches the glob pattern.\n if (minimatch(fileName, absolutePattern, { dot: true })) {\n return true;\n }\n }\n\n return false;\n};\n\n/**\n * Checks if the JSX element should be ignored based on a preceding comment.\n *\n * The function looks up the JSXOpeningElement's own leading comments as well as\n * the parent element's comments before falling back to inspect siblings.\n *\n * @param path - The path to the JSXOpeningElement.\n * @returns true if the JSX element should be ignored.\n */\nexport const isIgnoredLine = (path: NodePath<t.JSXOpeningElement>): boolean => {\n // Check for @boost-ignore in the leading comments on the JSX opening element.\n if (path.node.leadingComments?.some((comment) => comment.value.includes('@boost-ignore'))) {\n return true;\n }\n\n // Check for @boost-ignore in the leading comments on the parent JSX element.\n const jsxElementPath = path.parentPath;\n if (jsxElementPath.node.leadingComments?.some((comment) => comment.value.includes('@boost-ignore'))) {\n return true;\n }\n\n // NEW: Check for @boost-ignore in the leading comments on the ObjectProperty (if it exists)\n // This handles cases where the JSX element is used as a value inside an object literal.\n const propertyPath = jsxElementPath.parentPath;\n if (\n propertyPath &&\n propertyPath.isObjectProperty() &&\n propertyPath.node.leadingComments?.some((comment) => comment.value.includes('@boost-ignore'))\n ) {\n return true;\n }\n\n if (!jsxElementPath.parentPath) return false;\n\n // Get the container that holds this element (for example, a JSX fragment or JSX element)\n const containerPath = jsxElementPath.parentPath;\n const siblings = ensureArray(containerPath.get('children'));\n const index = siblings.findIndex((sibling) => sibling.node === jsxElementPath.node);\n if (index === -1) return false;\n\n // Look backward from the current element for a non-empty node.\n for (let index_ = index - 1; index_ >= 0; index_--) {\n const sibling = siblings[index_];\n // Skip over any whitespace (only in JSXText nodes)\n if (sibling.isJSXText() && sibling.node.value.trim() === '') {\n continue;\n }\n // If the sibling is a JSX expression container, check its empty expression's comments.\n if (sibling.isJSXExpressionContainer()) {\n const expression = sibling.get('expression');\n if (expression && expression.node) {\n const comments = [\n ...(expression.node.leadingComments || []),\n ...(expression.node.trailingComments || []),\n ...(expression.node.innerComments || []),\n ].map((comment) => comment.value.trim());\n if (comments.some((comment) => comment.includes('@boost-ignore'))) {\n return true;\n }\n }\n }\n // Also check if the node itself carries a leadingComments property.\n if (\n sibling.node.leadingComments &&\n sibling.node.leadingComments.some((comment) => comment.value.includes('@boost-ignore'))\n ) {\n return true;\n }\n break; // if the immediate non-whitespace node is not our ignore marker, stop\n }\n return false;\n};\n\n/**\n * Checks if the path represents a valid JSX component with the specified name.\n *\n * @param path - The NodePath to check.\n * @param componentName - The name of the component to validate against.\n * @returns true if the path is a valid JSX component with the specified name.\n */\nexport const isValidJSXComponent = (path: NodePath<t.JSXOpeningElement>, componentName: string): boolean => {\n // Check if the node name is a JSX identifier\n if (!t.isJSXIdentifier(path.node.name)) return false;\n\n // Check if the parent is a JSX element\n const parent = path.parent;\n if (!t.isJSXElement(parent)) return false;\n\n // For aliasing, we check if the underlying imported name matches the expected name\n const componentIdentifier = path.node.name.name;\n const binding = path.scope.getBinding(componentIdentifier);\n if (!binding) return false;\n if (\n binding.kind === 'module' &&\n t.isImportDeclaration(binding.path.parent) &&\n t.isImportSpecifier(binding.path.node)\n ) {\n const imported = binding.path.node.imported;\n if (t.isIdentifier(imported)) {\n return imported.name === componentName;\n }\n }\n\n // Fallback to string match if binding is not available\n return path.node.name.name === componentName;\n};\n\n/**\n * Checks if the component is imported from 'react-native' and not from a custom module.\n *\n * @param path - The NodePath to check.\n * @param expectedImportedName - The expected import name of the component (we'll also check for aliased imports).\n * @returns true if the component is imported from 'react-native'\n */\nexport const isReactNativeImport = (path: NodePath<t.JSXOpeningElement>, expectedImportedName: string): boolean => {\n if (!t.isJSXIdentifier(path.node.name)) return false;\n const localName = path.node.name.name;\n const binding = path.scope.getBinding(localName);\n if (!binding) return false;\n if (binding.kind === 'module') {\n const importDeclaration = binding.path.parent;\n if (!t.isImportDeclaration(importDeclaration)) return false;\n // Verify it's imported from 'react-native'\n if (importDeclaration.source.value !== 'react-native') return false;\n\n // For named imports, check the imported name (not the alias)\n if (t.isImportSpecifier(binding.path.node)) {\n const imported = binding.path.node.imported;\n if (t.isIdentifier(imported)) {\n return imported.name === expectedImportedName;\n }\n }\n\n // For default imports, we just assume it's valid if imported from react-native.\n if (t.isImportDefaultSpecifier(binding.path.node)) {\n return true;\n }\n }\n return false;\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { ACCESSIBILITY_PROPERTIES } from '../constants';\n\n/**\n * Checks if the JSX element has a blacklisted property.\n *\n * @param path - The path to the JSXOpeningElement.\n * @param blacklist - The set of blacklisted properties.\n * @returns true if the JSX element has a blacklisted property.\n */\nexport const hasBlacklistedProperty = (path: NodePath<t.JSXOpeningElement>, blacklist: Set<string>): boolean => {\n return path.node.attributes.some((attribute) => {\n // Check direct attributes (e.g., onPress={handler})\n if (t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name) && blacklist.has(attribute.name.name)) {\n return true;\n }\n\n // Check spread attributes (e.g., {...props})\n if (t.isJSXSpreadAttribute(attribute)) {\n if (t.isIdentifier(attribute.argument)) {\n const binding = path.scope.getBinding(attribute.argument.name);\n let objectExpression: t.ObjectExpression | undefined;\n if (binding) {\n // If the binding node is a VariableDeclarator, use its initializer\n if (t.isVariableDeclarator(binding.path.node)) {\n objectExpression = binding.path.node.init as t.ObjectExpression;\n } else if (t.isObjectExpression(binding.path.node)) {\n objectExpression = binding.path.node;\n }\n }\n if (objectExpression && t.isObjectExpression(objectExpression)) {\n return objectExpression.properties.some((property) => {\n if (t.isObjectProperty(property) && t.isIdentifier(property.key)) {\n return blacklist.has(property.key.name);\n }\n return false;\n });\n }\n }\n // Bail if we can't resolve the spread attribute\n return true;\n }\n\n // For other attribute types, assume no blacklisting\n return false;\n });\n};\n\n/**\n * Helper that builds an Object.assign expression out of the existing JSX attributes.\n * It handles both plain JSXAttributes and spread attributes.\n *\n * @param attributes - The attributes to build the expression from.\n * @returns The Object.assign expression.\n */\nexport const buildPropertiesFromAttributes = (attributes: (t.JSXAttribute | t.JSXSpreadAttribute)[]): t.Expression => {\n const arguments_: t.Expression[] = [];\n for (const attribute of attributes) {\n if (t.isJSXSpreadAttribute(attribute)) {\n arguments_.push(attribute.argument);\n } else if (t.isJSXAttribute(attribute)) {\n const key = attribute.name.name;\n let value: t.Expression;\n if (!attribute.value) {\n value = t.booleanLiteral(true);\n } else if (t.isStringLiteral(attribute.value)) {\n value = attribute.value;\n } else if (t.isJSXExpressionContainer(attribute.value)) {\n value = t.isJSXEmptyExpression(attribute.value.expression)\n ? t.booleanLiteral(true)\n : attribute.value.expression;\n } else {\n value = t.nullLiteral();\n }\n // If the key is not a valid JavaScript identifier (e.g. \"aria-label\"), use a string literal.\n const validIdentifierRegex = /^[a-zA-Z_$][a-zA-Z0-9_$]*$/;\n const keyNode =\n typeof key === 'string' && validIdentifierRegex.test(key) ? t.identifier(key) : t.stringLiteral(key.toString());\n\n arguments_.push(t.objectExpression([t.objectProperty(keyNode, value)]));\n }\n }\n if (arguments_.length === 0) {\n return t.objectExpression([]);\n }\n return t.callExpression(t.memberExpression(t.identifier('Object'), t.identifier('assign')), [\n t.objectExpression([]),\n ...arguments_,\n ]);\n};\n\n/**\n * Checks if the JSX element has an accessibility property.\n *\n * @param path - The NodePath for the JSXOpeningElement, used for scope lookup.\n * @param attributes - The attributes to check.\n * @returns true if the JSX element has an accessibility property.\n */\nexport const hasAccessibilityProperty = (\n path: NodePath<t.JSXOpeningElement>,\n attributes: (t.JSXAttribute | t.JSXSpreadAttribute)[]\n): boolean => {\n for (const attribute of attributes) {\n if (t.isJSXAttribute(attribute)) {\n const key = attribute.name.name;\n if (typeof key === 'string' && ACCESSIBILITY_PROPERTIES.has(key)) {\n return true;\n }\n } else if (t.isJSXSpreadAttribute(attribute)) {\n if (t.isObjectExpression(attribute.argument)) {\n for (const property of attribute.argument.properties) {\n if (\n t.isObjectProperty(property) &&\n t.isIdentifier(property.key) &&\n ACCESSIBILITY_PROPERTIES.has(property.key.name)\n ) {\n return true;\n }\n }\n } else if (t.isIdentifier(attribute.argument)) {\n const binding = path.scope.getBinding(attribute.argument.name);\n if (binding && t.isVariableDeclarator(binding.path.node)) {\n const declarator = binding.path.node as t.VariableDeclarator;\n if (declarator.init && t.isObjectExpression(declarator.init)) {\n for (const property of declarator.init.properties) {\n if (\n t.isObjectProperty(property) &&\n t.isIdentifier(property.key) &&\n ACCESSIBILITY_PROPERTIES.has(property.key.name)\n ) {\n return true;\n }\n }\n continue;\n }\n }\n return true;\n } else {\n return true;\n }\n }\n }\n return false;\n};\n","import { NodePath, types as t } from '@babel/core';\n\n/**\n * Checks if a node represents a string value.\n */\nexport const isStringNode = (path: NodePath<t.JSXOpeningElement>, child: t.Node): boolean => {\n if (t.isJSXText(child) || t.isStringLiteral(child)) return true;\n\n // Check for JSX expressions\n if (t.isJSXExpressionContainer(child)) {\n const expression = child.expression;\n if (t.isIdentifier(expression)) {\n const binding = path.scope.getBinding(expression.name);\n if (binding && binding.path.node && t.isVariableDeclarator(binding.path.node)) {\n return !!binding.path.node.init && t.isStringLiteral(binding.path.node.init);\n }\n return false;\n }\n if (t.isStringLiteral(expression)) return true;\n }\n return false;\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { HubFile, Optimizer } from '../../types';\nimport PluginError from '../../utils/plugin-error';\nimport {\n addFileImportHint,\n buildPropertiesFromAttributes,\n hasAccessibilityProperty,\n hasBlacklistedProperty,\n isIgnoredLine,\n isValidJSXComponent,\n isReactNativeImport,\n replaceWithNativeComponent,\n isStringNode,\n} from '../../utils/common';\nimport { RUNTIME_MODULE_NAME } from '../../utils/constants';\n\nexport const textBlacklistedProperties = new Set([\n 'allowFontScaling',\n 'ellipsizeMode',\n 'id',\n 'nativeID',\n 'onLongPress',\n 'onPress',\n 'onPressIn',\n 'onPressOut',\n 'onResponderGrant',\n 'onResponderMove',\n 'onResponderRelease',\n 'onResponderTerminate',\n 'onResponderTerminationRequest',\n 'onStartShouldSetResponder',\n 'pressRetentionOffset',\n 'suppressHighlighting',\n 'selectable',\n 'selectionColor',\n]);\n\nexport const textOptimizer: Optimizer = (path, log = () => {}) => {\n if (isIgnoredLine(path)) return;\n if (!isValidJSXComponent(path, 'Text')) return;\n if (!isReactNativeImport(path, 'Text')) return;\n if (hasBlacklistedProperty(path, textBlacklistedProperties)) return;\n\n // Verify that the Text only has string children\n const parent = path.parent as t.JSXElement;\n if (hasInvalidChildren(path, parent)) return;\n\n const hub = path.hub as unknown;\n const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;\n\n if (!file) {\n throw new PluginError('No file found in Babel hub');\n }\n\n const filename = file.opts?.filename || 'unknown file';\n const lineNumber = path.node.loc?.start.line ?? 'unknown line';\n log(`Optimizing Text component in ${filename}:${lineNumber}`);\n\n // Process props\n const originalAttributes = [...path.node.attributes];\n fixNegativeNumberOfLines({ path, log });\n processProps(path, file, originalAttributes);\n\n // Replace the Text component with NativeText\n replaceWithNativeComponent(path, parent, file, 'NativeText');\n};\n\n/**\n * Checks if the Text component has any invalid children or blacklisted properties.\n * This function combines the checks for both attribute-based children and JSX children.\n *\n * @param path - The path to the JSXOpeningElement.\n * @param parent - The parent JSX element.\n * @returns true if the component has invalid children or blacklisted properties.\n */\nfunction hasInvalidChildren(path: NodePath<t.JSXOpeningElement>, parent: t.JSXElement): boolean {\n for (const attribute of path.node.attributes) {\n if (t.isJSXSpreadAttribute(attribute)) continue; // Spread attributes are handled in hasBlacklistedProperty\n\n if (\n t.isJSXIdentifier(attribute.name) &&\n attribute.value &&\n // For a \"children\" attribute, optimization is allowed only if it is a string\n attribute.name.name === 'children' &&\n !isStringNode(path, attribute.value)\n ) {\n return true;\n }\n }\n\n // Return true if any child is not a string node\n return !parent.children.every((child) => isStringNode(path, child));\n}\n\n/**\n * Fixes negative numberOfLines values by setting them to 0.\n */\nfunction fixNegativeNumberOfLines({\n path,\n log,\n}: {\n path: NodePath<t.JSXOpeningElement>;\n log: (message: string) => void;\n}) {\n for (const attribute of path.node.attributes) {\n if (\n t.isJSXAttribute(attribute) &&\n t.isJSXIdentifier(attribute.name, { name: 'numberOfLines' }) &&\n attribute.value &&\n t.isJSXExpressionContainer(attribute.value)\n ) {\n let originalValue: number | undefined;\n if (t.isNumericLiteral(attribute.value.expression)) {\n originalValue = attribute.value.expression.value;\n } else if (\n t.isUnaryExpression(attribute.value.expression) &&\n attribute.value.expression.operator === '-' &&\n t.isNumericLiteral(attribute.value.expression.argument)\n ) {\n originalValue = -attribute.value.expression.argument.value;\n }\n if (originalValue !== undefined && originalValue < 0) {\n log(\n `Warning: 'numberOfLines' in <Text> must be a non-negative number, received: ${originalValue}. The value will be set to 0.`\n );\n attribute.value.expression = t.numericLiteral(0);\n }\n }\n }\n}\n\n/**\n * Extracts the style attribute from JSX attributes.\n */\nfunction extractStyleAttribute(attributes: Array<t.JSXAttribute | t.JSXSpreadAttribute>): {\n styleAttribute?: t.JSXAttribute;\n styleExpr?: t.Expression;\n} {\n for (const attribute of attributes) {\n if (t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' })) {\n if (\n attribute.value &&\n t.isJSXExpressionContainer(attribute.value) &&\n !t.isJSXEmptyExpression(attribute.value.expression)\n ) {\n return {\n styleAttribute: attribute,\n styleExpr: attribute.value.expression,\n };\n }\n return { styleAttribute: attribute };\n }\n }\n return {};\n}\n\n/**\n * Processes style and accessibility attributes, replacing them with optimized versions.\n */\nfunction processProps(\n path: NodePath<t.JSXOpeningElement>,\n file: HubFile,\n originalAttributes: Array<t.JSXAttribute | t.JSXSpreadAttribute>\n) {\n const { styleExpr } = extractStyleAttribute(originalAttributes);\n const hasA11y = hasAccessibilityProperty(path, originalAttributes);\n\n if (styleExpr && hasA11y) {\n // When both style and accessibility properties exist, we split them into two separate spread attributes\n const accessibilityAttributes = originalAttributes.filter(\n (attribute) => !(t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' }))\n );\n\n // Set up the accessibility import\n const normalizeIdentifier = addFileImportHint({\n file,\n nameHint: 'normalizeAccessibilityProps',\n path,\n importName: 'normalizeAccessibilityProps',\n moduleName: RUNTIME_MODULE_NAME,\n });\n const accessibilityObject = buildPropertiesFromAttributes(accessibilityAttributes);\n const accessibilityExpr = t.callExpression(t.identifier(normalizeIdentifier.name), [accessibilityObject]);\n\n // Set up the style import\n const flattenIdentifier = addFileImportHint({\n file,\n nameHint: 'flattenTextStyle',\n path,\n importName: 'flattenTextStyle',\n moduleName: RUNTIME_MODULE_NAME,\n });\n const flattenedStyleExpr = t.callExpression(t.identifier(flattenIdentifier.name), [styleExpr]);\n\n // Use two separate JSX spread attributes\n path.node.attributes = [t.jsxSpreadAttribute(accessibilityExpr), t.jsxSpreadAttribute(flattenedStyleExpr)];\n } else if (styleExpr) {\n // Only style attribute is present\n const flattenIdentifier = addFileImportHint({\n file,\n nameHint: 'flattenTextStyle',\n path,\n importName: 'flattenTextStyle',\n moduleName: RUNTIME_MODULE_NAME,\n });\n const flattened = t.callExpression(t.identifier(flattenIdentifier.name), [styleExpr]);\n path.node.attributes = [t.jsxSpreadAttribute(flattened)];\n } else if (hasA11y) {\n // Only accessibility properties are present\n const normalizeIdentifier = addFileImportHint({\n file,\n nameHint: 'normalizeAccessibilityProps',\n path,\n importName: 'normalizeAccessibilityProps',\n moduleName: RUNTIME_MODULE_NAME,\n });\n const propsObject = buildPropertiesFromAttributes(originalAttributes);\n const normalized = t.callExpression(t.identifier(normalizeIdentifier.name), [propsObject]);\n path.node.attributes = [t.jsxSpreadAttribute(normalized)];\n }\n}\n","export const log = (message: string) => {\n console.log(`[react-native-boost] ${message}`);\n};\n","import { NodePath, types as t } from '@babel/core';\nimport { HubFile, Optimizer } from '../../types';\nimport PluginError from '../../utils/plugin-error';\nimport {\n hasBlacklistedProperty,\n isIgnoredLine,\n isValidJSXComponent,\n isReactNativeImport,\n replaceWithNativeComponent,\n} from '../../utils/common';\n\nexport const viewBlacklistedProperties = new Set([\n 'accessible',\n 'accessibilityLabel',\n 'accessibilityState',\n 'allowFontScaling',\n 'aria-busy',\n 'aria-checked',\n 'aria-disabled',\n 'aria-expanded',\n 'aria-label',\n 'aria-selected',\n 'ellipsizeMode',\n 'disabled',\n 'id',\n 'nativeID',\n 'numberOfLines',\n 'onLongPress',\n 'onPress',\n 'onPressIn',\n 'onPressOut',\n 'onResponderGrant',\n 'onResponderMove',\n 'onResponderRelease',\n 'onResponderTerminate',\n 'onResponderTerminationRequest',\n 'onStartShouldSetResponder',\n 'pressRetentionOffset',\n 'selectable',\n 'selectionColor',\n 'suppressHighlighting',\n 'style',\n]);\n\nexport const viewOptimizer: Optimizer = (path, log = () => {}) => {\n if (isIgnoredLine(path)) return;\n if (!isValidJSXComponent(path, 'View')) return;\n if (!isReactNativeImport(path, 'View')) return;\n if (hasBlacklistedProperty(path, viewBlacklistedProperties)) return;\n if (hasTextAncestor(path)) return;\n\n // Extract the file from the Babel hub and add flags for logging & import caching.\n const hub = path.hub as unknown;\n const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;\n\n if (!file) {\n throw new PluginError('No file found in Babel hub');\n }\n\n const filename = file.opts?.filename || 'unknown file';\n const lineNumber = path.node.loc?.start.line ?? 'unknown line';\n log(`Optimizing View component in ${filename}:${lineNumber}`);\n\n const parent = path.parent as t.JSXElement;\n\n // Replace the Text component with NativeText\n replaceWithNativeComponent(path, parent, file, 'NativeView');\n};\n\n/**\n * Returns true if any ancestor element is a <Text /> or contains a <Text />.\n * This function handles both direct Text ancestors and custom components that may contain Text.\n * TODO: We can't test across file boundaries within the Babel plugin\n */\nfunction hasTextAncestor(path: NodePath<t.JSXOpeningElement>): boolean {\n // Check for direct Text ancestors (no custom components)\n const directTextAncestor = path.findParent((parentPath) => {\n return t.isJSXElement(parentPath.node) && t.isJSXIdentifier(parentPath.node.openingElement.name, { name: 'Text' });\n });\n\n if (directTextAncestor) return true;\n\n // Check for indirect Text ancestors (custom components that contain Text)\n return !!path.findParent((parentPath) => {\n // Only check JSX elements\n if (!t.isJSXElement(parentPath.node)) return false;\n\n // Get the component name\n const openingElement = parentPath.node.openingElement;\n if (!t.isJSXIdentifier(openingElement.name)) return false;\n\n const componentName = openingElement.name.name;\n\n // Skip built-in components and already checked Text component\n if (\n componentName === 'Text' ||\n componentName === 'View' ||\n componentName === 'Fragment' ||\n componentName[0] === componentName[0].toLowerCase()\n ) {\n return false;\n }\n\n // Try to find the component definition through variable binding\n const binding = parentPath.scope.getBinding(componentName);\n if (!binding) return false;\n\n // Now check the component definition for Text elements\n if (t.isVariableDeclarator(binding.path.node)) {\n const init = binding.path.node.init;\n\n // Handle arrow functions or function expressions\n if (t.isArrowFunctionExpression(init) || t.isFunctionExpression(init)) {\n // Check the function body for Text elements\n return t.isBlockStatement(init.body) ? hasTextInReturnStatement(init.body) : hasTextInExpression(init.body);\n }\n } else if (t.isFunctionDeclaration(binding.path.node)) {\n // Handle function declarations\n return hasTextInReturnStatement(binding.path.node.body);\n }\n\n return false;\n });\n}\n\n/**\n * Check if a block statement contains a return statement with a Text element\n */\nfunction hasTextInReturnStatement(blockStatement: t.BlockStatement): boolean {\n for (const statement of blockStatement.body) {\n if (t.isReturnStatement(statement) && statement.argument && hasTextInExpression(statement.argument)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * Check if an expression contains a Text element\n */\nfunction hasTextInExpression(expression: t.Expression): boolean {\n // If directly returning a JSX element\n if (t.isJSXElement(expression)) {\n // Check if it's a Text element\n if (t.isJSXIdentifier(expression.openingElement.name, { name: 'Text' })) {\n return true;\n }\n\n // Check if any children are Text elements\n for (const child of expression.children) {\n if (t.isJSXElement(child) && t.isJSXIdentifier(child.openingElement.name, { name: 'Text' })) {\n return true;\n }\n }\n }\n\n return false;\n}\n","import { declare } from '@babel/helper-plugin-utils';\nimport { textOptimizer } from './optimizers/text';\nimport { PluginOptions } from './types';\nimport { log } from './utils/logger';\nimport { viewOptimizer } from './optimizers/view';\nimport { isIgnoredFile } from './utils/common';\n\nexport default declare((api) => {\n api.assertVersion(7);\n\n return {\n name: 'react-native-boost',\n visitor: {\n JSXOpeningElement(path, state) {\n const options = (state.opts ?? {}) as PluginOptions;\n const logger = options.verbose ? log : () => {};\n if (isIgnoredFile(path, options.ignores ?? [])) return;\n if (options.optimizations?.text !== false) textOptimizer(path, logger);\n if (options.optimizations?.view !== false) viewOptimizer(path, logger);\n },\n },\n };\n});\n"],"names":["addDefault","addNamed","t","minimatch","declare"],"mappings":";;;;;;;;AAAA,MAAqB,oBAAoB,KAAM,CAAA;AAAA,EAC7C,YAAY,OAAiB,EAAA;AAC3B,IAAM,KAAA,CAAA,CAAA,6CAAA,EAAgD,OAAO,CAAE,CAAA,CAAA;AAC/D,IAAA,IAAA,CAAK,IAAO,GAAA,aAAA;AAAA;AAEhB;;ACLO,MAAM,mBAAsB,GAAA,oBAAA;AAKtB,MAAA,wBAAA,uBAA+B,GAAI,CAAA;AAAA,EAC9C,oBAAA;AAAA,EACA,YAAA;AAAA,EACA,oBAAA;AAAA,EACA,WAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EACA,eAAA;AAAA,EACA,eAAA;AAAA,EACA;AACF,CAAC,CAAA;;ACGM,SAAS,iBAAkB,CAAA;AAAA,EAChC,IAAA;AAAA,EACA,QAAA;AAAA,EACA,IAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAa,GAAA;AACf,CAAoC,EAAA;AAzBpC,EAAA,IAAA,EAAA;AA0BE,EAAA,IAAI,EAAC,CAAA,EAAA,GAAA,IAAA,CAAK,YAAL,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAAoB,QAAW,CAAA,CAAA,EAAA;AAClC,IAAK,IAAA,CAAA,YAAA,GAAe,IAAK,CAAA,YAAA,IAAgB,EAAC;AAC1C,IAAA,IAAA,CAAK,aAAa,QAAQ,CAAA,GACxB,eAAe,SACX,GAAAA,8BAAA,CAAW,MAAM,UAAY,EAAA,EAAE,QAAS,EAAC,IACzCC,4BAAS,CAAA,IAAA,EAAM,YAAY,UAAY,EAAA,EAAE,UAAU,CAAA;AAAA;AAE3D,EAAO,OAAA,IAAA,CAAK,aAAa,QAAQ,CAAA;AACnC;AAaO,MAAM,0BAA6B,GAAA,CACxC,IACA,EAAA,MAAA,EACA,MACA,mBACiB,KAAA;AAEjB,EAAA,MAAM,mBAAmB,iBAAkB,CAAA;AAAA,IACzC,IAAA;AAAA,IACA,QAAU,EAAA,mBAAA;AAAA,IACV,IAAA;AAAA,IACA,UAAY,EAAA,mBAAA;AAAA,IACZ,UAAY,EAAA,mBAAA;AAAA,IACZ,UAAY,EAAA;AAAA,GACb,CAAA;AAGD,EAAM,MAAA,WAAA,GAAe,IAAK,CAAA,IAAA,CAAK,IAAyB,CAAA,IAAA;AAGxD,EAAM,MAAA,OAAA,GAAU,KAAK,IAAK,CAAA,IAAA;AAC1B,EAAA,OAAA,CAAQ,OAAO,gBAAiB,CAAA,IAAA;AAGhC,EAAA,IACE,CAAC,IAAK,CAAA,IAAA,CAAK,WACX,IAAA,MAAA,CAAO,kBACPC,UAAE,CAAA,eAAA,CAAgB,MAAO,CAAA,cAAA,CAAe,IAAI,CAC5C,IAAA,MAAA,CAAO,cAAe,CAAA,IAAA,CAAK,SAAS,WACpC,EAAA;AACA,IAAO,MAAA,CAAA,cAAA,CAAe,IAAK,CAAA,IAAA,GAAO,gBAAiB,CAAA,IAAA;AAAA;AAGrD,EAAO,OAAA,gBAAA;AACT,CAAA;;ACjFa,MAAA,WAAA,GAAc,CAAI,KAAwB,KAAA;AACrD,EAAA,IAAI,KAAM,CAAA,OAAA,CAAQ,KAAK,CAAA,EAAU,OAAA,KAAA;AACjC,EAAA,OAAO,CAAC,KAAK,CAAA;AACf,CAAA;;ACWa,MAAA,aAAA,GAAgB,CAAC,IAAA,EAAqC,OAA+B,KAAA;AAChG,EAAA,MAAM,MAAM,IAAK,CAAA,GAAA;AACjB,EAAM,MAAA,IAAA,GAAO,OAAO,GAAQ,KAAA,QAAA,IAAY,QAAQ,IAAQ,IAAA,MAAA,IAAU,GAAO,GAAA,GAAA,CAAI,IAAmB,GAAA,MAAA;AAEhG,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAM,MAAA,IAAI,YAAY,4BAA4B,CAAA;AAAA;AAGpD,EAAM,MAAA,QAAA,GAAW,KAAK,IAAK,CAAA,QAAA;AAG3B,EAAM,MAAA,aAAA,GAAgB,SAAS,IAAK,CAAA,IAAA,GAAQ,KAAK,IAAK,CAAA,GAAA,GAAiB,QAAQ,GAAI,EAAA;AAGnF,EAAA,KAAA,MAAW,WAAW,OAAS,EAAA;AAE7B,IAAM,MAAA,eAAA,GAAkB,SAAS,UAAW,CAAA,OAAO,IAAI,OAAU,GAAA,QAAA,CAAS,IAAK,CAAA,aAAA,EAAe,OAAO,CAAA;AAGrG,IAAA,IAAIC,oBAAU,QAAU,EAAA,eAAA,EAAiB,EAAE,GAAK,EAAA,IAAA,EAAM,CAAG,EAAA;AACvD,MAAO,OAAA,IAAA;AAAA;AACT;AAGF,EAAO,OAAA,KAAA;AACT,CAAA;AAWa,MAAA,aAAA,GAAgB,CAAC,IAAiD,KAAA;AAlD/E,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AAoDE,EAAI,IAAA,CAAA,EAAA,GAAA,IAAA,CAAK,IAAK,CAAA,eAAA,KAAV,IAA2B,GAAA,MAAA,GAAA,EAAA,CAAA,IAAA,CAAK,CAAC,OAAA,KAAY,OAAQ,CAAA,KAAA,CAAM,QAAS,CAAA,eAAe,CAAI,CAAA,EAAA;AACzF,IAAO,OAAA,IAAA;AAAA;AAIT,EAAA,MAAM,iBAAiB,IAAK,CAAA,UAAA;AAC5B,EAAI,IAAA,CAAA,EAAA,GAAA,cAAA,CAAe,IAAK,CAAA,eAAA,KAApB,IAAqC,GAAA,MAAA,GAAA,EAAA,CAAA,IAAA,CAAK,CAAC,OAAA,KAAY,OAAQ,CAAA,KAAA,CAAM,QAAS,CAAA,eAAe,CAAI,CAAA,EAAA;AACnG,IAAO,OAAA,IAAA;AAAA;AAKT,EAAA,MAAM,eAAe,cAAe,CAAA,UAAA;AACpC,EAAA,IACE,YACA,IAAA,YAAA,CAAa,gBAAiB,EAAA,KAAA,CAC9B,kBAAa,IAAK,CAAA,eAAA,KAAlB,IAAmC,GAAA,MAAA,GAAA,EAAA,CAAA,IAAA,CAAK,CAAC,OAAY,KAAA,OAAA,CAAQ,KAAM,CAAA,QAAA,CAAS,eAAe,CAC3F,CAAA,CAAA,EAAA;AACA,IAAO,OAAA,IAAA;AAAA;AAGT,EAAI,IAAA,CAAC,cAAe,CAAA,UAAA,EAAmB,OAAA,KAAA;AAGvC,EAAA,MAAM,gBAAgB,cAAe,CAAA,UAAA;AACrC,EAAA,MAAM,QAAW,GAAA,WAAA,CAAY,aAAc,CAAA,GAAA,CAAI,UAAU,CAAC,CAAA;AAC1D,EAAM,MAAA,KAAA,GAAQ,SAAS,SAAU,CAAA,CAAC,YAAY,OAAQ,CAAA,IAAA,KAAS,eAAe,IAAI,CAAA;AAClF,EAAI,IAAA,KAAA,KAAU,IAAW,OAAA,KAAA;AAGzB,EAAA,KAAA,IAAS,MAAS,GAAA,KAAA,GAAQ,CAAG,EAAA,MAAA,IAAU,GAAG,MAAU,EAAA,EAAA;AAClD,IAAM,MAAA,OAAA,GAAU,SAAS,MAAM,CAAA;AAE/B,IAAI,IAAA,OAAA,CAAQ,WAAe,IAAA,OAAA,CAAQ,KAAK,KAAM,CAAA,IAAA,OAAW,EAAI,EAAA;AAC3D,MAAA;AAAA;AAGF,IAAI,IAAA,OAAA,CAAQ,0BAA4B,EAAA;AACtC,MAAM,MAAA,UAAA,GAAa,OAAQ,CAAA,GAAA,CAAI,YAAY,CAAA;AAC3C,MAAI,IAAA,UAAA,IAAc,WAAW,IAAM,EAAA;AACjC,QAAA,MAAM,QAAW,GAAA;AAAA,UACf,GAAI,UAAA,CAAW,IAAK,CAAA,eAAA,IAAmB,EAAC;AAAA,UACxC,GAAI,UAAA,CAAW,IAAK,CAAA,gBAAA,IAAoB,EAAC;AAAA,UACzC,GAAI,UAAA,CAAW,IAAK,CAAA,aAAA,IAAiB;AAAC,UACtC,GAAI,CAAA,CAAC,YAAY,OAAQ,CAAA,KAAA,CAAM,MAAM,CAAA;AACvC,QAAI,IAAA,QAAA,CAAS,KAAK,CAAC,OAAA,KAAY,QAAQ,QAAS,CAAA,eAAe,CAAC,CAAG,EAAA;AACjE,UAAO,OAAA,IAAA;AAAA;AACT;AACF;AAGF,IAAA,IACE,OAAQ,CAAA,IAAA,CAAK,eACb,IAAA,OAAA,CAAQ,KAAK,eAAgB,CAAA,IAAA,CAAK,CAAC,OAAA,KAAY,OAAQ,CAAA,KAAA,CAAM,QAAS,CAAA,eAAe,CAAC,CACtF,EAAA;AACA,MAAO,OAAA,IAAA;AAAA;AAET,IAAA;AAAA;AAEF,EAAO,OAAA,KAAA;AACT,CAAA;AASa,MAAA,mBAAA,GAAsB,CAAC,IAAA,EAAqC,aAAmC,KAAA;AAE1G,EAAA,IAAI,CAACD,UAAE,CAAA,eAAA,CAAgB,KAAK,IAAK,CAAA,IAAI,GAAU,OAAA,KAAA;AAG/C,EAAA,MAAM,SAAS,IAAK,CAAA,MAAA;AACpB,EAAA,IAAI,CAACA,UAAA,CAAE,YAAa,CAAA,MAAM,GAAU,OAAA,KAAA;AAGpC,EAAM,MAAA,mBAAA,GAAsB,IAAK,CAAA,IAAA,CAAK,IAAK,CAAA,IAAA;AAC3C,EAAA,MAAM,OAAU,GAAA,IAAA,CAAK,KAAM,CAAA,UAAA,CAAW,mBAAmB,CAAA;AACzD,EAAI,IAAA,CAAC,SAAgB,OAAA,KAAA;AACrB,EAAA,IACE,OAAQ,CAAA,IAAA,KAAS,QACjB,IAAAA,UAAA,CAAE,oBAAoB,OAAQ,CAAA,IAAA,CAAK,MAAM,CAAA,IACzCA,UAAE,CAAA,iBAAA,CAAkB,OAAQ,CAAA,IAAA,CAAK,IAAI,CACrC,EAAA;AACA,IAAM,MAAA,QAAA,GAAW,OAAQ,CAAA,IAAA,CAAK,IAAK,CAAA,QAAA;AACnC,IAAI,IAAAA,UAAA,CAAE,YAAa,CAAA,QAAQ,CAAG,EAAA;AAC5B,MAAA,OAAO,SAAS,IAAS,KAAA,aAAA;AAAA;AAC3B;AAIF,EAAO,OAAA,IAAA,CAAK,IAAK,CAAA,IAAA,CAAK,IAAS,KAAA,aAAA;AACjC,CAAA;AASa,MAAA,mBAAA,GAAsB,CAAC,IAAA,EAAqC,oBAA0C,KAAA;AACjH,EAAA,IAAI,CAACA,UAAE,CAAA,eAAA,CAAgB,KAAK,IAAK,CAAA,IAAI,GAAU,OAAA,KAAA;AAC/C,EAAM,MAAA,SAAA,GAAY,IAAK,CAAA,IAAA,CAAK,IAAK,CAAA,IAAA;AACjC,EAAA,MAAM,OAAU,GAAA,IAAA,CAAK,KAAM,CAAA,UAAA,CAAW,SAAS,CAAA;AAC/C,EAAI,IAAA,CAAC,SAAgB,OAAA,KAAA;AACrB,EAAI,IAAA,OAAA,CAAQ,SAAS,QAAU,EAAA;AAC7B,IAAM,MAAA,iBAAA,GAAoB,QAAQ,IAAK,CAAA,MAAA;AACvC,IAAA,IAAI,CAACA,UAAA,CAAE,mBAAoB,CAAA,iBAAiB,GAAU,OAAA,KAAA;AAEtD,IAAA,IAAI,iBAAkB,CAAA,MAAA,CAAO,KAAU,KAAA,cAAA,EAAuB,OAAA,KAAA;AAG9D,IAAA,IAAIA,UAAE,CAAA,iBAAA,CAAkB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AAC1C,MAAM,MAAA,QAAA,GAAW,OAAQ,CAAA,IAAA,CAAK,IAAK,CAAA,QAAA;AACnC,MAAI,IAAAA,UAAA,CAAE,YAAa,CAAA,QAAQ,CAAG,EAAA;AAC5B,QAAA,OAAO,SAAS,IAAS,KAAA,oBAAA;AAAA;AAC3B;AAIF,IAAA,IAAIA,UAAE,CAAA,wBAAA,CAAyB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AACjD,MAAO,OAAA,IAAA;AAAA;AACT;AAEF,EAAO,OAAA,KAAA;AACT,CAAA;;AC1Ka,MAAA,sBAAA,GAAyB,CAAC,IAAA,EAAqC,SAAoC,KAAA;AAC9G,EAAA,OAAO,IAAK,CAAA,IAAA,CAAK,UAAW,CAAA,IAAA,CAAK,CAAC,SAAc,KAAA;AAE9C,IAAA,IAAIA,UAAE,CAAA,cAAA,CAAe,SAAS,CAAA,IAAKA,WAAE,eAAgB,CAAA,SAAA,CAAU,IAAI,CAAA,IAAK,SAAU,CAAA,GAAA,CAAI,SAAU,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AAC1G,MAAO,OAAA,IAAA;AAAA;AAIT,IAAI,IAAAA,UAAA,CAAE,oBAAqB,CAAA,SAAS,CAAG,EAAA;AACrC,MAAA,IAAIA,UAAE,CAAA,YAAA,CAAa,SAAU,CAAA,QAAQ,CAAG,EAAA;AACtC,QAAA,MAAM,UAAU,IAAK,CAAA,KAAA,CAAM,UAAW,CAAA,SAAA,CAAU,SAAS,IAAI,CAAA;AAC7D,QAAI,IAAA,gBAAA;AACJ,QAAA,IAAI,OAAS,EAAA;AAEX,UAAA,IAAIA,UAAE,CAAA,oBAAA,CAAqB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AAC7C,YAAmB,gBAAA,GAAA,OAAA,CAAQ,KAAK,IAAK,CAAA,IAAA;AAAA,qBAC5BA,UAAE,CAAA,kBAAA,CAAmB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AAClD,YAAA,gBAAA,GAAmB,QAAQ,IAAK,CAAA,IAAA;AAAA;AAClC;AAEF,QAAA,IAAI,gBAAoB,IAAAA,UAAA,CAAE,kBAAmB,CAAA,gBAAgB,CAAG,EAAA;AAC9D,UAAA,OAAO,gBAAiB,CAAA,UAAA,CAAW,IAAK,CAAA,CAAC,QAAa,KAAA;AACpD,YAAI,IAAAA,UAAA,CAAE,iBAAiB,QAAQ,CAAA,IAAKA,WAAE,YAAa,CAAA,QAAA,CAAS,GAAG,CAAG,EAAA;AAChE,cAAA,OAAO,SAAU,CAAA,GAAA,CAAI,QAAS,CAAA,GAAA,CAAI,IAAI,CAAA;AAAA;AAExC,YAAO,OAAA,KAAA;AAAA,WACR,CAAA;AAAA;AACH;AAGF,MAAO,OAAA,IAAA;AAAA;AAIT,IAAO,OAAA,KAAA;AAAA,GACR,CAAA;AACH,CAAA;AASa,MAAA,6BAAA,GAAgC,CAAC,UAAwE,KAAA;AACpH,EAAA,MAAM,aAA6B,EAAC;AACpC,EAAA,KAAA,MAAW,aAAa,UAAY,EAAA;AAClC,IAAI,IAAAA,UAAA,CAAE,oBAAqB,CAAA,SAAS,CAAG,EAAA;AACrC,MAAW,UAAA,CAAA,IAAA,CAAK,UAAU,QAAQ,CAAA;AAAA,KACzB,MAAA,IAAAA,UAAA,CAAE,cAAe,CAAA,SAAS,CAAG,EAAA;AACtC,MAAM,MAAA,GAAA,GAAM,UAAU,IAAK,CAAA,IAAA;AAC3B,MAAI,IAAA,KAAA;AACJ,MAAI,IAAA,CAAC,UAAU,KAAO,EAAA;AACpB,QAAQ,KAAA,GAAAA,UAAA,CAAE,eAAe,IAAI,CAAA;AAAA,OACpB,MAAA,IAAAA,UAAA,CAAE,eAAgB,CAAA,SAAA,CAAU,KAAK,CAAG,EAAA;AAC7C,QAAA,KAAA,GAAQ,SAAU,CAAA,KAAA;AAAA,OACT,MAAA,IAAAA,UAAA,CAAE,wBAAyB,CAAA,SAAA,CAAU,KAAK,CAAG,EAAA;AACtD,QAAQ,KAAA,GAAAA,UAAA,CAAE,oBAAqB,CAAA,SAAA,CAAU,KAAM,CAAA,UAAU,CACrD,GAAAA,UAAA,CAAE,cAAe,CAAA,IAAI,CACrB,GAAA,SAAA,CAAU,KAAM,CAAA,UAAA;AAAA,OACf,MAAA;AACL,QAAA,KAAA,GAAQA,WAAE,WAAY,EAAA;AAAA;AAGxB,MAAA,MAAM,oBAAuB,GAAA,4BAAA;AAC7B,MAAA,MAAM,UACJ,OAAO,GAAA,KAAQ,QAAY,IAAA,oBAAA,CAAqB,KAAK,GAAG,CAAA,GAAIA,UAAE,CAAA,UAAA,CAAW,GAAG,CAAI,GAAAA,UAAA,CAAE,aAAc,CAAA,GAAA,CAAI,UAAU,CAAA;AAEhH,MAAW,UAAA,CAAA,IAAA,CAAKA,UAAE,CAAA,gBAAA,CAAiB,CAACA,UAAA,CAAE,eAAe,OAAS,EAAA,KAAK,CAAC,CAAC,CAAC,CAAA;AAAA;AACxE;AAEF,EAAI,IAAA,UAAA,CAAW,WAAW,CAAG,EAAA;AAC3B,IAAO,OAAAA,UAAA,CAAE,gBAAiB,CAAA,EAAE,CAAA;AAAA;AAE9B,EAAA,OAAOA,UAAE,CAAA,cAAA,CAAeA,UAAE,CAAA,gBAAA,CAAiBA,UAAE,CAAA,UAAA,CAAW,QAAQ,CAAA,EAAGA,UAAE,CAAA,UAAA,CAAW,QAAQ,CAAC,CAAG,EAAA;AAAA,IAC1FA,UAAA,CAAE,gBAAiB,CAAA,EAAE,CAAA;AAAA,IACrB,GAAG;AAAA,GACJ,CAAA;AACH,CAAA;AASa,MAAA,wBAAA,GAA2B,CACtC,IAAA,EACA,UACY,KAAA;AACZ,EAAA,KAAA,MAAW,aAAa,UAAY,EAAA;AAClC,IAAI,IAAAA,UAAA,CAAE,cAAe,CAAA,SAAS,CAAG,EAAA;AAC/B,MAAM,MAAA,GAAA,GAAM,UAAU,IAAK,CAAA,IAAA;AAC3B,MAAA,IAAI,OAAO,GAAQ,KAAA,QAAA,IAAY,wBAAyB,CAAA,GAAA,CAAI,GAAG,CAAG,EAAA;AAChE,QAAO,OAAA,IAAA;AAAA;AACT,KACS,MAAA,IAAAA,UAAA,CAAE,oBAAqB,CAAA,SAAS,CAAG,EAAA;AAC5C,MAAA,IAAIA,UAAE,CAAA,kBAAA,CAAmB,SAAU,CAAA,QAAQ,CAAG,EAAA;AAC5C,QAAW,KAAA,MAAA,QAAA,IAAY,SAAU,CAAA,QAAA,CAAS,UAAY,EAAA;AACpD,UAAA,IACEA,UAAE,CAAA,gBAAA,CAAiB,QAAQ,CAAA,IAC3BA,WAAE,YAAa,CAAA,QAAA,CAAS,GAAG,CAAA,IAC3B,wBAAyB,CAAA,GAAA,CAAI,QAAS,CAAA,GAAA,CAAI,IAAI,CAC9C,EAAA;AACA,YAAO,OAAA,IAAA;AAAA;AACT;AACF,OACS,MAAA,IAAAA,UAAA,CAAE,YAAa,CAAA,SAAA,CAAU,QAAQ,CAAG,EAAA;AAC7C,QAAA,MAAM,UAAU,IAAK,CAAA,KAAA,CAAM,UAAW,CAAA,SAAA,CAAU,SAAS,IAAI,CAAA;AAC7D,QAAA,IAAI,WAAWA,UAAE,CAAA,oBAAA,CAAqB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AACxD,UAAM,MAAA,UAAA,GAAa,QAAQ,IAAK,CAAA,IAAA;AAChC,UAAA,IAAI,WAAW,IAAQ,IAAAA,UAAA,CAAE,kBAAmB,CAAA,UAAA,CAAW,IAAI,CAAG,EAAA;AAC5D,YAAW,KAAA,MAAA,QAAA,IAAY,UAAW,CAAA,IAAA,CAAK,UAAY,EAAA;AACjD,cAAA,IACEA,UAAE,CAAA,gBAAA,CAAiB,QAAQ,CAAA,IAC3BA,WAAE,YAAa,CAAA,QAAA,CAAS,GAAG,CAAA,IAC3B,wBAAyB,CAAA,GAAA,CAAI,QAAS,CAAA,GAAA,CAAI,IAAI,CAC9C,EAAA;AACA,gBAAO,OAAA,IAAA;AAAA;AACT;AAEF,YAAA;AAAA;AACF;AAEF,QAAO,OAAA,IAAA;AAAA,OACF,MAAA;AACL,QAAO,OAAA,IAAA;AAAA;AACT;AACF;AAEF,EAAO,OAAA,KAAA;AACT,CAAA;;AC1Ia,MAAA,YAAA,GAAe,CAAC,IAAA,EAAqC,KAA2B,KAAA;AAC3F,EAAI,IAAAA,UAAA,CAAE,UAAU,KAAK,CAAA,IAAKA,WAAE,eAAgB,CAAA,KAAK,GAAU,OAAA,IAAA;AAG3D,EAAI,IAAAA,UAAA,CAAE,wBAAyB,CAAA,KAAK,CAAG,EAAA;AACrC,IAAA,MAAM,aAAa,KAAM,CAAA,UAAA;AACzB,IAAI,IAAAA,UAAA,CAAE,YAAa,CAAA,UAAU,CAAG,EAAA;AAC9B,MAAA,MAAM,OAAU,GAAA,IAAA,CAAK,KAAM,CAAA,UAAA,CAAW,WAAW,IAAI,CAAA;AACrD,MAAI,IAAA,OAAA,IAAW,QAAQ,IAAK,CAAA,IAAA,IAAQA,WAAE,oBAAqB,CAAA,OAAA,CAAQ,IAAK,CAAA,IAAI,CAAG,EAAA;AAC7E,QAAO,OAAA,CAAC,CAAC,OAAA,CAAQ,IAAK,CAAA,IAAA,CAAK,IAAQ,IAAAA,UAAA,CAAE,eAAgB,CAAA,OAAA,CAAQ,IAAK,CAAA,IAAA,CAAK,IAAI,CAAA;AAAA;AAE7E,MAAO,OAAA,KAAA;AAAA;AAET,IAAA,IAAIA,UAAE,CAAA,eAAA,CAAgB,UAAU,CAAA,EAAU,OAAA,IAAA;AAAA;AAE5C,EAAO,OAAA,KAAA;AACT,CAAA;;ACLa,MAAA,yBAAA,uBAAgC,GAAI,CAAA;AAAA,EAC/C,kBAAA;AAAA,EACA,eAAA;AAAA,EACA,IAAA;AAAA,EACA,UAAA;AAAA,EACA,aAAA;AAAA,EACA,SAAA;AAAA,EACA,WAAA;AAAA,EACA,YAAA;AAAA,EACA,kBAAA;AAAA,EACA,iBAAA;AAAA,EACA,oBAAA;AAAA,EACA,sBAAA;AAAA,EACA,+BAAA;AAAA,EACA,2BAAA;AAAA,EACA,sBAAA;AAAA,EACA,sBAAA;AAAA,EACA,YAAA;AAAA,EACA;AACF,CAAC,CAAA;AAEM,MAAM,aAA2B,GAAA,CAAC,IAAM,EAAA,GAAA,GAAM,MAAM;AAAC,CAAM,KAAA;AArClE,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AAsCE,EAAI,IAAA,aAAA,CAAc,IAAI,CAAG,EAAA;AACzB,EAAA,IAAI,CAAC,mBAAA,CAAoB,IAAM,EAAA,MAAM,CAAG,EAAA;AACxC,EAAA,IAAI,CAAC,mBAAA,CAAoB,IAAM,EAAA,MAAM,CAAG,EAAA;AACxC,EAAI,IAAA,sBAAA,CAAuB,IAAM,EAAA,yBAAyB,CAAG,EAAA;AAG7D,EAAA,MAAM,SAAS,IAAK,CAAA,MAAA;AACpB,EAAI,IAAA,kBAAA,CAAmB,IAAM,EAAA,MAAM,CAAG,EAAA;AAEtC,EAAA,MAAM,MAAM,IAAK,CAAA,GAAA;AACjB,EAAM,MAAA,IAAA,GAAO,OAAO,GAAQ,KAAA,QAAA,IAAY,QAAQ,IAAQ,IAAA,MAAA,IAAU,GAAO,GAAA,GAAA,CAAI,IAAmB,GAAA,MAAA;AAEhG,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAM,MAAA,IAAI,YAAY,4BAA4B,CAAA;AAAA;AAGpD,EAAA,MAAM,QAAW,GAAA,CAAA,CAAA,EAAA,GAAA,IAAA,CAAK,IAAL,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAAW,QAAY,KAAA,cAAA;AACxC,EAAA,MAAM,cAAa,EAAK,GAAA,CAAA,EAAA,GAAA,IAAA,CAAA,IAAA,CAAK,QAAV,IAAe,GAAA,MAAA,GAAA,EAAA,CAAA,KAAA,CAAM,SAArB,IAA6B,GAAA,EAAA,GAAA,cAAA;AAChD,EAAA,GAAA,CAAI,CAAgC,6BAAA,EAAA,QAAQ,CAAI,CAAA,EAAA,UAAU,CAAE,CAAA,CAAA;AAG5D,EAAA,MAAM,kBAAqB,GAAA,CAAC,GAAG,IAAA,CAAK,KAAK,UAAU,CAAA;AACnD,EAAyB,wBAAA,CAAA,EAAE,IAAM,EAAA,GAAA,EAAK,CAAA;AACtC,EAAa,YAAA,CAAA,IAAA,EAAM,MAAM,kBAAkB,CAAA;AAG3C,EAA2B,0BAAA,CAAA,IAAA,EAAM,MAAQ,EAAA,IAAA,EAAM,YAAY,CAAA;AAC7D,CAAA;AAUA,SAAS,kBAAA,CAAmB,MAAqC,MAA+B,EAAA;AAC9F,EAAW,KAAA,MAAA,SAAA,IAAa,IAAK,CAAA,IAAA,CAAK,UAAY,EAAA;AAC5C,IAAI,IAAAA,UAAA,CAAE,oBAAqB,CAAA,SAAS,CAAG,EAAA;AAEvC,IAAA,IACEA,UAAE,CAAA,eAAA,CAAgB,SAAU,CAAA,IAAI,KAChC,SAAU,CAAA,KAAA;AAAA,IAEV,SAAA,CAAU,KAAK,IAAS,KAAA,UAAA,IACxB,CAAC,YAAa,CAAA,IAAA,EAAM,SAAU,CAAA,KAAK,CACnC,EAAA;AACA,MAAO,OAAA,IAAA;AAAA;AACT;AAIF,EAAO,OAAA,CAAC,OAAO,QAAS,CAAA,KAAA,CAAM,CAAC,KAAU,KAAA,YAAA,CAAa,IAAM,EAAA,KAAK,CAAC,CAAA;AACpE;AAKA,SAAS,wBAAyB,CAAA;AAAA,EAChC,IAAA;AAAA,EACA;AACF,CAGG,EAAA;AACD,EAAW,KAAA,MAAA,SAAA,IAAa,IAAK,CAAA,IAAA,CAAK,UAAY,EAAA;AAC5C,IAAA,IACEA,WAAE,cAAe,CAAA,SAAS,KAC1BA,UAAE,CAAA,eAAA,CAAgB,UAAU,IAAM,EAAA,EAAE,MAAM,eAAgB,EAAC,KAC3D,SAAU,CAAA,KAAA,IACVA,WAAE,wBAAyB,CAAA,SAAA,CAAU,KAAK,CAC1C,EAAA;AACA,MAAI,IAAA,aAAA;AACJ,MAAA,IAAIA,UAAE,CAAA,gBAAA,CAAiB,SAAU,CAAA,KAAA,CAAM,UAAU,CAAG,EAAA;AAClD,QAAgB,aAAA,GAAA,SAAA,CAAU,MAAM,UAAW,CAAA,KAAA;AAAA,iBAE3CA,UAAE,CAAA,iBAAA,CAAkB,UAAU,KAAM,CAAA,UAAU,KAC9C,SAAU,CAAA,KAAA,CAAM,UAAW,CAAA,QAAA,KAAa,OACxCA,UAAE,CAAA,gBAAA,CAAiB,UAAU,KAAM,CAAA,UAAA,CAAW,QAAQ,CACtD,EAAA;AACA,QAAA,aAAA,GAAgB,CAAC,SAAA,CAAU,KAAM,CAAA,UAAA,CAAW,QAAS,CAAA,KAAA;AAAA;AAEvD,MAAI,IAAA,aAAA,KAAkB,MAAa,IAAA,aAAA,GAAgB,CAAG,EAAA;AACpD,QAAA,GAAA;AAAA,UACE,+EAA+E,aAAa,CAAA,6BAAA;AAAA,SAC9F;AACA,QAAA,SAAA,CAAU,KAAM,CAAA,UAAA,GAAaA,UAAE,CAAA,cAAA,CAAe,CAAC,CAAA;AAAA;AACjD;AACF;AAEJ;AAKA,SAAS,sBAAsB,UAG7B,EAAA;AACA,EAAA,KAAA,MAAW,aAAa,UAAY,EAAA;AAClC,IAAA,IAAIA,UAAE,CAAA,cAAA,CAAe,SAAS,CAAA,IAAKA,UAAE,CAAA,eAAA,CAAgB,SAAU,CAAA,IAAA,EAAM,EAAE,IAAA,EAAM,OAAQ,EAAC,CAAG,EAAA;AACvF,MAAA,IACE,SAAU,CAAA,KAAA,IACVA,UAAE,CAAA,wBAAA,CAAyB,SAAU,CAAA,KAAK,CAC1C,IAAA,CAACA,UAAE,CAAA,oBAAA,CAAqB,SAAU,CAAA,KAAA,CAAM,UAAU,CAClD,EAAA;AACA,QAAO,OAAA;AAAA,UACL,cAAgB,EAAA,SAAA;AAAA,UAChB,SAAA,EAAW,UAAU,KAAM,CAAA;AAAA,SAC7B;AAAA;AAEF,MAAO,OAAA,EAAE,gBAAgB,SAAU,EAAA;AAAA;AACrC;AAEF,EAAA,OAAO,EAAC;AACV;AAKA,SAAS,YAAA,CACP,IACA,EAAA,IAAA,EACA,kBACA,EAAA;AACA,EAAA,MAAM,EAAE,SAAA,EAAc,GAAA,qBAAA,CAAsB,kBAAkB,CAAA;AAC9D,EAAM,MAAA,OAAA,GAAU,wBAAyB,CAAA,IAAA,EAAM,kBAAkB,CAAA;AAEjE,EAAA,IAAI,aAAa,OAAS,EAAA;AAExB,IAAA,MAAM,0BAA0B,kBAAmB,CAAA,MAAA;AAAA,MACjD,CAAC,SAAA,KAAc,EAAEA,UAAA,CAAE,eAAe,SAAS,CAAA,IAAKA,UAAE,CAAA,eAAA,CAAgB,SAAU,CAAA,IAAA,EAAM,EAAE,IAAA,EAAM,SAAS,CAAA;AAAA,KACrG;AAGA,IAAA,MAAM,sBAAsB,iBAAkB,CAAA;AAAA,MAC5C,IAAA;AAAA,MACA,QAAU,EAAA,6BAAA;AAAA,MACV,IAAA;AAAA,MACA,UAAY,EAAA,6BAAA;AAAA,MACZ,UAAY,EAAA;AAAA,KACb,CAAA;AACD,IAAM,MAAA,mBAAA,GAAsB,8BAA8B,uBAAuB,CAAA;AACjF,IAAM,MAAA,iBAAA,GAAoBA,UAAE,CAAA,cAAA,CAAeA,UAAE,CAAA,UAAA,CAAW,oBAAoB,IAAI,CAAA,EAAG,CAAC,mBAAmB,CAAC,CAAA;AAGxG,IAAA,MAAM,oBAAoB,iBAAkB,CAAA;AAAA,MAC1C,IAAA;AAAA,MACA,QAAU,EAAA,kBAAA;AAAA,MACV,IAAA;AAAA,MACA,UAAY,EAAA,kBAAA;AAAA,MACZ,UAAY,EAAA;AAAA,KACb,CAAA;AACD,IAAM,MAAA,kBAAA,GAAqBA,UAAE,CAAA,cAAA,CAAeA,UAAE,CAAA,UAAA,CAAW,kBAAkB,IAAI,CAAA,EAAG,CAAC,SAAS,CAAC,CAAA;AAG7F,IAAK,IAAA,CAAA,IAAA,CAAK,UAAa,GAAA,CAACA,UAAE,CAAA,kBAAA,CAAmB,iBAAiB,CAAG,EAAAA,UAAA,CAAE,kBAAmB,CAAA,kBAAkB,CAAC,CAAA;AAAA,aAChG,SAAW,EAAA;AAEpB,IAAA,MAAM,oBAAoB,iBAAkB,CAAA;AAAA,MAC1C,IAAA;AAAA,MACA,QAAU,EAAA,kBAAA;AAAA,MACV,IAAA;AAAA,MACA,UAAY,EAAA,kBAAA;AAAA,MACZ,UAAY,EAAA;AAAA,KACb,CAAA;AACD,IAAM,MAAA,SAAA,GAAYA,UAAE,CAAA,cAAA,CAAeA,UAAE,CAAA,UAAA,CAAW,kBAAkB,IAAI,CAAA,EAAG,CAAC,SAAS,CAAC,CAAA;AACpF,IAAA,IAAA,CAAK,KAAK,UAAa,GAAA,CAACA,UAAE,CAAA,kBAAA,CAAmB,SAAS,CAAC,CAAA;AAAA,aAC9C,OAAS,EAAA;AAElB,IAAA,MAAM,sBAAsB,iBAAkB,CAAA;AAAA,MAC5C,IAAA;AAAA,MACA,QAAU,EAAA,6BAAA;AAAA,MACV,IAAA;AAAA,MACA,UAAY,EAAA,6BAAA;AAAA,MACZ,UAAY,EAAA;AAAA,KACb,CAAA;AACD,IAAM,MAAA,WAAA,GAAc,8BAA8B,kBAAkB,CAAA;AACpE,IAAM,MAAA,UAAA,GAAaA,UAAE,CAAA,cAAA,CAAeA,UAAE,CAAA,UAAA,CAAW,oBAAoB,IAAI,CAAA,EAAG,CAAC,WAAW,CAAC,CAAA;AACzF,IAAA,IAAA,CAAK,KAAK,UAAa,GAAA,CAACA,UAAE,CAAA,kBAAA,CAAmB,UAAU,CAAC,CAAA;AAAA;AAE5D;;AC5Na,MAAA,GAAA,GAAM,CAAC,OAAoB,KAAA;AACtC,EAAQ,OAAA,CAAA,GAAA,CAAI,CAAwB,qBAAA,EAAA,OAAO,CAAE,CAAA,CAAA;AAC/C,CAAA;;ACSa,MAAA,yBAAA,uBAAgC,GAAI,CAAA;AAAA,EAC/C,YAAA;AAAA,EACA,oBAAA;AAAA,EACA,oBAAA;AAAA,EACA,kBAAA;AAAA,EACA,WAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EACA,eAAA;AAAA,EACA,YAAA;AAAA,EACA,eAAA;AAAA,EACA,eAAA;AAAA,EACA,UAAA;AAAA,EACA,IAAA;AAAA,EACA,UAAA;AAAA,EACA,eAAA;AAAA,EACA,aAAA;AAAA,EACA,SAAA;AAAA,EACA,WAAA;AAAA,EACA,YAAA;AAAA,EACA,kBAAA;AAAA,EACA,iBAAA;AAAA,EACA,oBAAA;AAAA,EACA,sBAAA;AAAA,EACA,+BAAA;AAAA,EACA,2BAAA;AAAA,EACA,sBAAA;AAAA,EACA,YAAA;AAAA,EACA,gBAAA;AAAA,EACA,sBAAA;AAAA,EACA;AACF,CAAC,CAAA;AAEM,MAAM,aAA2B,GAAA,CAAC,IAAM,EAAA,GAAA,GAAM,MAAM;AAAC,CAAM,KAAA;AA5ClE,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AA6CE,EAAI,IAAA,aAAA,CAAc,IAAI,CAAG,EAAA;AACzB,EAAA,IAAI,CAAC,mBAAA,CAAoB,IAAM,EAAA,MAAM,CAAG,EAAA;AACxC,EAAA,IAAI,CAAC,mBAAA,CAAoB,IAAM,EAAA,MAAM,CAAG,EAAA;AACxC,EAAI,IAAA,sBAAA,CAAuB,IAAM,EAAA,yBAAyB,CAAG,EAAA;AAC7D,EAAI,IAAA,eAAA,CAAgB,IAAI,CAAG,EAAA;AAG3B,EAAA,MAAM,MAAM,IAAK,CAAA,GAAA;AACjB,EAAM,MAAA,IAAA,GAAO,OAAO,GAAQ,KAAA,QAAA,IAAY,QAAQ,IAAQ,IAAA,MAAA,IAAU,GAAO,GAAA,GAAA,CAAI,IAAmB,GAAA,MAAA;AAEhG,EAAA,IAAI,CAAC,IAAM,EAAA;AACT,IAAM,MAAA,IAAI,YAAY,4BAA4B,CAAA;AAAA;AAGpD,EAAA,MAAM,QAAW,GAAA,CAAA,CAAA,EAAA,GAAA,IAAA,CAAK,IAAL,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAAW,QAAY,KAAA,cAAA;AACxC,EAAA,MAAM,cAAa,EAAK,GAAA,CAAA,EAAA,GAAA,IAAA,CAAA,IAAA,CAAK,QAAV,IAAe,GAAA,MAAA,GAAA,EAAA,CAAA,KAAA,CAAM,SAArB,IAA6B,GAAA,EAAA,GAAA,cAAA;AAChD,EAAA,GAAA,CAAI,CAAgC,6BAAA,EAAA,QAAQ,CAAI,CAAA,EAAA,UAAU,CAAE,CAAA,CAAA;AAE5D,EAAA,MAAM,SAAS,IAAK,CAAA,MAAA;AAGpB,EAA2B,0BAAA,CAAA,IAAA,EAAM,MAAQ,EAAA,IAAA,EAAM,YAAY,CAAA;AAC7D,CAAA;AAOA,SAAS,gBAAgB,IAA8C,EAAA;AAErE,EAAA,MAAM,kBAAqB,GAAA,IAAA,CAAK,UAAW,CAAA,CAAC,UAAe,KAAA;AACzD,IAAA,OAAOA,UAAE,CAAA,YAAA,CAAa,UAAW,CAAA,IAAI,KAAKA,UAAE,CAAA,eAAA,CAAgB,UAAW,CAAA,IAAA,CAAK,cAAe,CAAA,IAAA,EAAM,EAAE,IAAA,EAAM,QAAQ,CAAA;AAAA,GAClH,CAAA;AAED,EAAA,IAAI,oBAA2B,OAAA,IAAA;AAG/B,EAAA,OAAO,CAAC,CAAC,IAAK,CAAA,UAAA,CAAW,CAAC,UAAe,KAAA;AAEvC,IAAA,IAAI,CAACA,UAAE,CAAA,YAAA,CAAa,UAAW,CAAA,IAAI,GAAU,OAAA,KAAA;AAG7C,IAAM,MAAA,cAAA,GAAiB,WAAW,IAAK,CAAA,cAAA;AACvC,IAAA,IAAI,CAACA,UAAE,CAAA,eAAA,CAAgB,cAAe,CAAA,IAAI,GAAU,OAAA,KAAA;AAEpD,IAAM,MAAA,aAAA,GAAgB,eAAe,IAAK,CAAA,IAAA;AAG1C,IAAA,IACE,aAAkB,KAAA,MAAA,IAClB,aAAkB,KAAA,MAAA,IAClB,aAAkB,KAAA,UAAA,IAClB,aAAc,CAAA,CAAC,CAAM,KAAA,aAAA,CAAc,CAAC,CAAA,CAAE,aACtC,EAAA;AACA,MAAO,OAAA,KAAA;AAAA;AAIT,IAAA,MAAM,OAAU,GAAA,UAAA,CAAW,KAAM,CAAA,UAAA,CAAW,aAAa,CAAA;AACzD,IAAI,IAAA,CAAC,SAAgB,OAAA,KAAA;AAGrB,IAAA,IAAIA,UAAE,CAAA,oBAAA,CAAqB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AAC7C,MAAM,MAAA,IAAA,GAAO,OAAQ,CAAA,IAAA,CAAK,IAAK,CAAA,IAAA;AAG/B,MAAA,IAAIA,WAAE,yBAA0B,CAAA,IAAI,KAAKA,UAAE,CAAA,oBAAA,CAAqB,IAAI,CAAG,EAAA;AAErE,QAAO,OAAAA,UAAA,CAAE,gBAAiB,CAAA,IAAA,CAAK,IAAI,CAAA,GAAI,wBAAyB,CAAA,IAAA,CAAK,IAAI,CAAA,GAAI,mBAAoB,CAAA,IAAA,CAAK,IAAI,CAAA;AAAA;AAC5G,eACSA,UAAE,CAAA,qBAAA,CAAsB,OAAQ,CAAA,IAAA,CAAK,IAAI,CAAG,EAAA;AAErD,MAAA,OAAO,wBAAyB,CAAA,OAAA,CAAQ,IAAK,CAAA,IAAA,CAAK,IAAI,CAAA;AAAA;AAGxD,IAAO,OAAA,KAAA;AAAA,GACR,CAAA;AACH;AAKA,SAAS,yBAAyB,cAA2C,EAAA;AAC3E,EAAW,KAAA,MAAA,SAAA,IAAa,eAAe,IAAM,EAAA;AAC3C,IAAI,IAAAA,UAAA,CAAE,kBAAkB,SAAS,CAAA,IAAK,UAAU,QAAY,IAAA,mBAAA,CAAoB,SAAU,CAAA,QAAQ,CAAG,EAAA;AACnG,MAAO,OAAA,IAAA;AAAA;AACT;AAEF,EAAO,OAAA,KAAA;AACT;AAKA,SAAS,oBAAoB,UAAmC,EAAA;AAE9D,EAAI,IAAAA,UAAA,CAAE,YAAa,CAAA,UAAU,CAAG,EAAA;AAE9B,IAAI,IAAAA,UAAA,CAAE,gBAAgB,UAAW,CAAA,cAAA,CAAe,MAAM,EAAE,IAAA,EAAM,MAAO,EAAC,CAAG,EAAA;AACvE,MAAO,OAAA,IAAA;AAAA;AAIT,IAAW,KAAA,MAAA,KAAA,IAAS,WAAW,QAAU,EAAA;AACvC,MAAA,IAAIA,UAAE,CAAA,YAAA,CAAa,KAAK,CAAA,IAAKA,UAAE,CAAA,eAAA,CAAgB,KAAM,CAAA,cAAA,CAAe,IAAM,EAAA,EAAE,IAAM,EAAA,MAAA,EAAQ,CAAG,EAAA;AAC3F,QAAO,OAAA,IAAA;AAAA;AACT;AACF;AAGF,EAAO,OAAA,KAAA;AACT;;ACtJA,YAAeE,yBAAA,CAAQ,CAAC,GAAQ,KAAA;AAC9B,EAAA,GAAA,CAAI,cAAc,CAAC,CAAA;AAEnB,EAAO,OAAA;AAAA,IACL,IAAM,EAAA,oBAAA;AAAA,IACN,OAAS,EAAA;AAAA,MACP,iBAAA,CAAkB,MAAM,KAAO,EAAA;AAbrC,QAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AAcQ,QAAA,MAAM,OAAW,GAAA,CAAA,EAAA,GAAA,KAAA,CAAM,IAAN,KAAA,IAAA,GAAA,EAAA,GAAc,EAAC;AAChC,QAAA,MAAM,MAAS,GAAA,OAAA,CAAQ,OAAU,GAAA,GAAA,GAAM,MAAM;AAAA,SAAC;AAC9C,QAAA,IAAI,cAAc,IAAM,EAAA,CAAA,EAAA,GAAA,OAAA,CAAQ,YAAR,IAAmB,GAAA,EAAA,GAAA,EAAE,CAAG,EAAA;AAChD,QAAA,IAAA,CAAA,CAAI,aAAQ,aAAR,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAAuB,UAAS,KAAO,EAAA,aAAA,CAAc,MAAM,MAAM,CAAA;AACrE,QAAA,IAAA,CAAA,CAAI,aAAQ,aAAR,KAAA,IAAA,GAAA,MAAA,GAAA,EAAA,CAAuB,UAAS,KAAO,EAAA,aAAA,CAAc,MAAM,MAAM,CAAA;AAAA;AACvE;AACF,GACF;AACF,CAAC,CAAA;;;;"}
|
package/package.json
CHANGED
|
@@ -6,8 +6,13 @@ import {
|
|
|
6
6
|
buildPropertiesFromAttributes,
|
|
7
7
|
hasAccessibilityProperty,
|
|
8
8
|
hasBlacklistedProperty,
|
|
9
|
-
|
|
9
|
+
isIgnoredLine,
|
|
10
|
+
isValidJSXComponent,
|
|
11
|
+
isReactNativeImport,
|
|
12
|
+
replaceWithNativeComponent,
|
|
13
|
+
isStringNode,
|
|
10
14
|
} from '../../utils/common';
|
|
15
|
+
import { RUNTIME_MODULE_NAME } from '../../utils/constants';
|
|
11
16
|
|
|
12
17
|
export const textBlacklistedProperties = new Set([
|
|
13
18
|
'allowFontScaling',
|
|
@@ -31,36 +36,15 @@ export const textBlacklistedProperties = new Set([
|
|
|
31
36
|
]);
|
|
32
37
|
|
|
33
38
|
export const textOptimizer: Optimizer = (path, log = () => {}) => {
|
|
34
|
-
|
|
35
|
-
if (!
|
|
36
|
-
|
|
37
|
-
const parent = path.parent;
|
|
38
|
-
if (!t.isJSXElement(parent)) return;
|
|
39
|
-
|
|
40
|
-
const elementName = path.node.name.name;
|
|
41
|
-
if (elementName !== 'Text') return;
|
|
42
|
-
|
|
43
|
-
// If the component is preceded by an ignore comment, do not optimize.
|
|
44
|
-
if (shouldIgnoreOptimization(path)) {
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
// Ensure Text element comes from react-native
|
|
49
|
-
const binding = path.scope.getBinding(elementName);
|
|
50
|
-
if (!binding) return;
|
|
51
|
-
if (binding.kind === 'module') {
|
|
52
|
-
const parentNode = binding.path.parent;
|
|
53
|
-
if (!t.isImportDeclaration(parentNode) || parentNode.source.value !== 'react-native') {
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// Bail if the element has any blacklisted properties or non-string children props
|
|
39
|
+
if (isIgnoredLine(path)) return;
|
|
40
|
+
if (!isValidJSXComponent(path, 'Text')) return;
|
|
41
|
+
if (!isReactNativeImport(path, 'Text')) return;
|
|
59
42
|
if (hasBlacklistedProperty(path, textBlacklistedProperties)) return;
|
|
60
|
-
if (hasInvalidChildren(path)) return;
|
|
61
|
-
if (!hasOnlyStringChildren(path, parent)) return;
|
|
62
43
|
|
|
63
|
-
//
|
|
44
|
+
// Verify that the Text only has string children
|
|
45
|
+
const parent = path.parent as t.JSXElement;
|
|
46
|
+
if (hasInvalidChildren(path, parent)) return;
|
|
47
|
+
|
|
64
48
|
const hub = path.hub as unknown;
|
|
65
49
|
const file = typeof hub === 'object' && hub !== null && 'file' in hub ? (hub.file as HubFile) : undefined;
|
|
66
50
|
|
|
@@ -72,178 +56,166 @@ export const textOptimizer: Optimizer = (path, log = () => {}) => {
|
|
|
72
56
|
const lineNumber = path.node.loc?.start.line ?? 'unknown line';
|
|
73
57
|
log(`Optimizing Text component in ${filename}:${lineNumber}`);
|
|
74
58
|
|
|
75
|
-
//
|
|
59
|
+
// Process props
|
|
60
|
+
const originalAttributes = [...path.node.attributes];
|
|
76
61
|
fixNegativeNumberOfLines({ path, log });
|
|
62
|
+
processProps(path, file, originalAttributes);
|
|
77
63
|
|
|
78
|
-
//
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
64
|
+
// Replace the Text component with NativeText
|
|
65
|
+
replaceWithNativeComponent(path, parent, file, 'NativeText');
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Checks if the Text component has any invalid children or blacklisted properties.
|
|
70
|
+
* This function combines the checks for both attribute-based children and JSX children.
|
|
71
|
+
*
|
|
72
|
+
* @param path - The path to the JSXOpeningElement.
|
|
73
|
+
* @param parent - The parent JSX element.
|
|
74
|
+
* @returns true if the component has invalid children or blacklisted properties.
|
|
75
|
+
*/
|
|
76
|
+
function hasInvalidChildren(path: NodePath<t.JSXOpeningElement>, parent: t.JSXElement): boolean {
|
|
77
|
+
for (const attribute of path.node.attributes) {
|
|
78
|
+
if (t.isJSXSpreadAttribute(attribute)) continue; // Spread attributes are handled in hasBlacklistedProperty
|
|
79
|
+
|
|
80
|
+
if (
|
|
81
|
+
t.isJSXIdentifier(attribute.name) &&
|
|
82
|
+
attribute.value &&
|
|
83
|
+
// For a "children" attribute, optimization is allowed only if it is a string
|
|
84
|
+
attribute.name.name === 'children' &&
|
|
85
|
+
!isStringNode(path, attribute.value)
|
|
86
|
+
) {
|
|
87
|
+
return true;
|
|
85
88
|
}
|
|
86
89
|
}
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
90
|
+
|
|
91
|
+
// Return true if any child is not a string node
|
|
92
|
+
return !parent.children.every((child) => isStringNode(path, child));
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Fixes negative numberOfLines values by setting them to 0.
|
|
97
|
+
*/
|
|
98
|
+
function fixNegativeNumberOfLines({
|
|
99
|
+
path,
|
|
100
|
+
log,
|
|
101
|
+
}: {
|
|
102
|
+
path: NodePath<t.JSXOpeningElement>;
|
|
103
|
+
log: (message: string) => void;
|
|
104
|
+
}) {
|
|
105
|
+
for (const attribute of path.node.attributes) {
|
|
106
|
+
if (
|
|
107
|
+
t.isJSXAttribute(attribute) &&
|
|
108
|
+
t.isJSXIdentifier(attribute.name, { name: 'numberOfLines' }) &&
|
|
109
|
+
attribute.value &&
|
|
110
|
+
t.isJSXExpressionContainer(attribute.value)
|
|
111
|
+
) {
|
|
112
|
+
let originalValue: number | undefined;
|
|
113
|
+
if (t.isNumericLiteral(attribute.value.expression)) {
|
|
114
|
+
originalValue = attribute.value.expression.value;
|
|
115
|
+
} else if (
|
|
116
|
+
t.isUnaryExpression(attribute.value.expression) &&
|
|
117
|
+
attribute.value.expression.operator === '-' &&
|
|
118
|
+
t.isNumericLiteral(attribute.value.expression.argument)
|
|
119
|
+
) {
|
|
120
|
+
originalValue = -attribute.value.expression.argument.value;
|
|
121
|
+
}
|
|
122
|
+
if (originalValue !== undefined && originalValue < 0) {
|
|
123
|
+
log(
|
|
124
|
+
`Warning: 'numberOfLines' in <Text> must be a non-negative number, received: ${originalValue}. The value will be set to 0.`
|
|
125
|
+
);
|
|
126
|
+
attribute.value.expression = t.numericLiteral(0);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Extracts the style attribute from JSX attributes.
|
|
134
|
+
*/
|
|
135
|
+
function extractStyleAttribute(attributes: Array<t.JSXAttribute | t.JSXSpreadAttribute>): {
|
|
136
|
+
styleAttribute?: t.JSXAttribute;
|
|
137
|
+
styleExpr?: t.Expression;
|
|
138
|
+
} {
|
|
139
|
+
for (const attribute of attributes) {
|
|
140
|
+
if (t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' })) {
|
|
141
|
+
if (
|
|
142
|
+
attribute.value &&
|
|
143
|
+
t.isJSXExpressionContainer(attribute.value) &&
|
|
144
|
+
!t.isJSXEmptyExpression(attribute.value.expression)
|
|
145
|
+
) {
|
|
146
|
+
return {
|
|
147
|
+
styleAttribute: attribute,
|
|
148
|
+
styleExpr: attribute.value.expression,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
return { styleAttribute: attribute };
|
|
152
|
+
}
|
|
94
153
|
}
|
|
154
|
+
return {};
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* Processes style and accessibility attributes, replacing them with optimized versions.
|
|
159
|
+
*/
|
|
160
|
+
function processProps(
|
|
161
|
+
path: NodePath<t.JSXOpeningElement>,
|
|
162
|
+
file: HubFile,
|
|
163
|
+
originalAttributes: Array<t.JSXAttribute | t.JSXSpreadAttribute>
|
|
164
|
+
) {
|
|
165
|
+
const { styleExpr } = extractStyleAttribute(originalAttributes);
|
|
95
166
|
const hasA11y = hasAccessibilityProperty(path, originalAttributes);
|
|
96
167
|
|
|
97
168
|
if (styleExpr && hasA11y) {
|
|
98
169
|
// When both style and accessibility properties exist, we split them into two separate spread attributes
|
|
170
|
+
const accessibilityAttributes = originalAttributes.filter(
|
|
171
|
+
(attribute) => !(t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' }))
|
|
172
|
+
);
|
|
99
173
|
|
|
100
|
-
//
|
|
101
|
-
const accessibilityAttributes = originalAttributes.filter((attribute) => {
|
|
102
|
-
if (t.isJSXAttribute(attribute) && t.isJSXIdentifier(attribute.name, { name: 'style' })) {
|
|
103
|
-
return false;
|
|
104
|
-
}
|
|
105
|
-
return true;
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
// Set up the accessibility import if needed
|
|
174
|
+
// Set up the accessibility import
|
|
109
175
|
const normalizeIdentifier = addFileImportHint({
|
|
110
176
|
file,
|
|
111
177
|
nameHint: 'normalizeAccessibilityProps',
|
|
112
178
|
path,
|
|
113
179
|
importName: 'normalizeAccessibilityProps',
|
|
114
|
-
moduleName:
|
|
180
|
+
moduleName: RUNTIME_MODULE_NAME,
|
|
115
181
|
});
|
|
116
182
|
const accessibilityObject = buildPropertiesFromAttributes(accessibilityAttributes);
|
|
117
183
|
const accessibilityExpr = t.callExpression(t.identifier(normalizeIdentifier.name), [accessibilityObject]);
|
|
118
184
|
|
|
119
|
-
// Set up the style import
|
|
185
|
+
// Set up the style import
|
|
120
186
|
const flattenIdentifier = addFileImportHint({
|
|
121
187
|
file,
|
|
122
188
|
nameHint: 'flattenTextStyle',
|
|
123
189
|
path,
|
|
124
190
|
importName: 'flattenTextStyle',
|
|
125
|
-
moduleName:
|
|
191
|
+
moduleName: RUNTIME_MODULE_NAME,
|
|
126
192
|
});
|
|
127
193
|
const flattenedStyleExpr = t.callExpression(t.identifier(flattenIdentifier.name), [styleExpr]);
|
|
128
194
|
|
|
129
|
-
// Use two separate JSX spread attributes
|
|
195
|
+
// Use two separate JSX spread attributes
|
|
130
196
|
path.node.attributes = [t.jsxSpreadAttribute(accessibilityExpr), t.jsxSpreadAttribute(flattenedStyleExpr)];
|
|
131
197
|
} else if (styleExpr) {
|
|
132
|
-
// Only style attribute is present
|
|
198
|
+
// Only style attribute is present
|
|
133
199
|
const flattenIdentifier = addFileImportHint({
|
|
134
200
|
file,
|
|
135
201
|
nameHint: 'flattenTextStyle',
|
|
136
202
|
path,
|
|
137
203
|
importName: 'flattenTextStyle',
|
|
138
|
-
moduleName:
|
|
204
|
+
moduleName: RUNTIME_MODULE_NAME,
|
|
139
205
|
});
|
|
140
206
|
const flattened = t.callExpression(t.identifier(flattenIdentifier.name), [styleExpr]);
|
|
141
207
|
path.node.attributes = [t.jsxSpreadAttribute(flattened)];
|
|
142
208
|
} else if (hasA11y) {
|
|
143
|
-
// Only accessibility properties are present
|
|
209
|
+
// Only accessibility properties are present
|
|
144
210
|
const normalizeIdentifier = addFileImportHint({
|
|
145
211
|
file,
|
|
146
212
|
nameHint: 'normalizeAccessibilityProps',
|
|
147
213
|
path,
|
|
148
214
|
importName: 'normalizeAccessibilityProps',
|
|
149
|
-
moduleName:
|
|
215
|
+
moduleName: RUNTIME_MODULE_NAME,
|
|
150
216
|
});
|
|
151
217
|
const propsObject = buildPropertiesFromAttributes(originalAttributes);
|
|
152
218
|
const normalized = t.callExpression(t.identifier(normalizeIdentifier.name), [propsObject]);
|
|
153
219
|
path.node.attributes = [t.jsxSpreadAttribute(normalized)];
|
|
154
220
|
}
|
|
155
|
-
|
|
156
|
-
// Add TextNativeComponent import (cached on file) so we only add it once per file.
|
|
157
|
-
const nativeTextIdentifier = addFileImportHint({
|
|
158
|
-
file,
|
|
159
|
-
nameHint: 'NativeText',
|
|
160
|
-
path,
|
|
161
|
-
importName: 'NativeText',
|
|
162
|
-
moduleName: 'react-native-boost',
|
|
163
|
-
});
|
|
164
|
-
path.node.name.name = nativeTextIdentifier.name;
|
|
165
|
-
|
|
166
|
-
// If the element is not self-closing, update the closing element as well
|
|
167
|
-
if (
|
|
168
|
-
!path.node.selfClosing &&
|
|
169
|
-
parent.closingElement &&
|
|
170
|
-
t.isJSXIdentifier(parent.closingElement.name) &&
|
|
171
|
-
parent.closingElement.name.name === 'Text'
|
|
172
|
-
) {
|
|
173
|
-
parent.closingElement.name.name = nativeTextIdentifier.name;
|
|
174
|
-
}
|
|
175
|
-
};
|
|
176
|
-
|
|
177
|
-
function hasOnlyStringChildren(path: NodePath<t.JSXOpeningElement>, node: t.JSXElement): boolean {
|
|
178
|
-
return node.children.every((child) => isStringNode(path, child));
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
function isStringNode(path: NodePath<t.JSXOpeningElement>, child: t.Node): boolean {
|
|
182
|
-
if (t.isJSXText(child) || t.isStringLiteral(child)) return true;
|
|
183
|
-
|
|
184
|
-
// Check for JSX expressions
|
|
185
|
-
if (t.isJSXExpressionContainer(child)) {
|
|
186
|
-
const expression = child.expression;
|
|
187
|
-
if (t.isIdentifier(expression)) {
|
|
188
|
-
const binding = path.scope.getBinding(expression.name);
|
|
189
|
-
if (binding && binding.path.node && t.isVariableDeclarator(binding.path.node)) {
|
|
190
|
-
return !!binding.path.node.init && t.isStringLiteral(binding.path.node.init);
|
|
191
|
-
}
|
|
192
|
-
return false;
|
|
193
|
-
}
|
|
194
|
-
if (t.isStringLiteral(expression)) return true;
|
|
195
|
-
}
|
|
196
|
-
return false;
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
function fixNegativeNumberOfLines({
|
|
200
|
-
path,
|
|
201
|
-
log,
|
|
202
|
-
}: {
|
|
203
|
-
path: NodePath<t.JSXOpeningElement>;
|
|
204
|
-
log: (message: string) => void;
|
|
205
|
-
}) {
|
|
206
|
-
for (const attribute of path.node.attributes) {
|
|
207
|
-
if (
|
|
208
|
-
t.isJSXAttribute(attribute) &&
|
|
209
|
-
t.isJSXIdentifier(attribute.name, { name: 'numberOfLines' }) &&
|
|
210
|
-
attribute.value &&
|
|
211
|
-
t.isJSXExpressionContainer(attribute.value)
|
|
212
|
-
) {
|
|
213
|
-
let originalValue: number | undefined;
|
|
214
|
-
if (t.isNumericLiteral(attribute.value.expression)) {
|
|
215
|
-
originalValue = attribute.value.expression.value;
|
|
216
|
-
} else if (
|
|
217
|
-
t.isUnaryExpression(attribute.value.expression) &&
|
|
218
|
-
attribute.value.expression.operator === '-' &&
|
|
219
|
-
t.isNumericLiteral(attribute.value.expression.argument)
|
|
220
|
-
) {
|
|
221
|
-
originalValue = -attribute.value.expression.argument.value;
|
|
222
|
-
}
|
|
223
|
-
if (originalValue !== undefined && originalValue < 0) {
|
|
224
|
-
log(
|
|
225
|
-
`Warning: 'numberOfLines' in <Text> must be a non-negative number, received: ${originalValue}. The value will be set to 0.`
|
|
226
|
-
);
|
|
227
|
-
attribute.value.expression = t.numericLiteral(0);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
function hasInvalidChildren(path: NodePath<t.JSXOpeningElement>): boolean {
|
|
234
|
-
for (const attribute of path.node.attributes) {
|
|
235
|
-
if (t.isJSXSpreadAttribute(attribute)) continue; // Spread attributes are handled in hasBlacklistedProperty
|
|
236
|
-
|
|
237
|
-
if (t.isJSXIdentifier(attribute.name) && attribute.value) {
|
|
238
|
-
// For a "children" attribute, optimization is allowed only if it is a string
|
|
239
|
-
if (attribute.name.name === 'children') {
|
|
240
|
-
if (!isStringNode(path, attribute.value)) {
|
|
241
|
-
return true;
|
|
242
|
-
}
|
|
243
|
-
} else if (textBlacklistedProperties.has(attribute.name.name)) {
|
|
244
|
-
return true;
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
return false;
|
|
249
221
|
}
|