@tamagui/web 2.0.0-rc.9 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1383) hide show
  1. package/.turbo/turbo-build.log +2 -0
  2. package/.turbo/turbo-test$colon$web.log +15 -0
  3. package/dist/cjs/Tamagui.cjs +57 -53
  4. package/dist/cjs/Tamagui.native.js +95 -79
  5. package/dist/cjs/Tamagui.native.js.map +1 -1
  6. package/dist/cjs/_withStableStyle.cjs +56 -35
  7. package/dist/cjs/_withStableStyle.native.js +64 -46
  8. package/dist/cjs/_withStableStyle.native.js.map +1 -1
  9. package/dist/cjs/animationDriverTypes.test-d.cjs +39 -11
  10. package/dist/cjs/animationDriverTypes.test-d.native.js +39 -11
  11. package/dist/cjs/animationDriverTypes.test-d.native.js.map +1 -1
  12. package/dist/cjs/config.cjs +135 -75
  13. package/dist/cjs/config.native.js +158 -106
  14. package/dist/cjs/config.native.js.map +1 -1
  15. package/dist/cjs/constants/accessibilityDirectMap.cjs +17 -15
  16. package/dist/cjs/constants/accessibilityDirectMap.native.js +17 -15
  17. package/dist/cjs/constants/accessibilityDirectMap.native.js.map +1 -1
  18. package/dist/cjs/constants/constants.cjs +17 -29
  19. package/dist/cjs/constants/constants.native.js +18 -29
  20. package/dist/cjs/constants/constants.native.js.map +1 -1
  21. package/dist/cjs/constants/isDevTools.cjs +18 -14
  22. package/dist/cjs/constants/isDevTools.native.js +18 -14
  23. package/dist/cjs/constants/isDevTools.native.js.map +1 -1
  24. package/dist/cjs/contexts/ComponentContext.cjs +24 -20
  25. package/dist/cjs/contexts/ComponentContext.native.js +25 -23
  26. package/dist/cjs/contexts/ComponentContext.native.js.map +1 -1
  27. package/dist/cjs/contexts/GroupContext.cjs +12 -10
  28. package/dist/cjs/contexts/GroupContext.native.js +14 -12
  29. package/dist/cjs/contexts/GroupContext.native.js.map +1 -1
  30. package/dist/cjs/createComponent.cjs +916 -636
  31. package/dist/cjs/createComponent.native.js +917 -692
  32. package/dist/cjs/createComponent.native.js.map +1 -1
  33. package/dist/cjs/createFont.cjs +33 -27
  34. package/dist/cjs/createFont.native.js +35 -32
  35. package/dist/cjs/createFont.native.js.map +1 -1
  36. package/dist/cjs/createShorthands.cjs +12 -10
  37. package/dist/cjs/createShorthands.native.js +12 -10
  38. package/dist/cjs/createShorthands.native.js.map +1 -1
  39. package/dist/cjs/createTamagui.cjs +118 -97
  40. package/dist/cjs/createTamagui.native.js +155 -141
  41. package/dist/cjs/createTamagui.native.js.map +1 -1
  42. package/dist/cjs/createTokens.cjs +12 -10
  43. package/dist/cjs/createTokens.native.js +12 -10
  44. package/dist/cjs/createTokens.native.js.map +1 -1
  45. package/dist/cjs/createVariable.cjs +57 -31
  46. package/dist/cjs/createVariable.native.js +67 -42
  47. package/dist/cjs/createVariable.native.js.map +1 -1
  48. package/dist/cjs/createVariables.cjs +55 -49
  49. package/dist/cjs/createVariables.native.js +57 -51
  50. package/dist/cjs/createVariables.native.js.map +1 -1
  51. package/dist/cjs/defaultComponentState.cjs +29 -27
  52. package/dist/cjs/defaultComponentState.native.js +29 -27
  53. package/dist/cjs/defaultComponentState.native.js.map +1 -1
  54. package/dist/cjs/eventHandling.cjs +15 -13
  55. package/dist/cjs/eventHandling.native.js +198 -92
  56. package/dist/cjs/eventHandling.native.js.map +1 -1
  57. package/dist/cjs/helpers/consoleLog.native.js +14 -12
  58. package/dist/cjs/helpers/consoleLog.native.js.map +1 -1
  59. package/dist/cjs/helpers/createDesignSystem.cjs +84 -44
  60. package/dist/cjs/helpers/createDesignSystem.native.js +118 -88
  61. package/dist/cjs/helpers/createDesignSystem.native.js.map +1 -1
  62. package/dist/cjs/helpers/createMediaStyle.cjs +91 -61
  63. package/dist/cjs/helpers/createMediaStyle.native.js +97 -68
  64. package/dist/cjs/helpers/createMediaStyle.native.js.map +1 -1
  65. package/dist/cjs/helpers/createStyledContext.cjs +84 -61
  66. package/dist/cjs/helpers/createStyledContext.native.js +88 -68
  67. package/dist/cjs/helpers/createStyledContext.native.js.map +1 -1
  68. package/dist/cjs/helpers/defaultAnimationDriver.cjs +29 -28
  69. package/dist/cjs/helpers/defaultAnimationDriver.native.js +45 -42
  70. package/dist/cjs/helpers/defaultAnimationDriver.native.js.map +1 -1
  71. package/dist/cjs/helpers/defaultOffset.cjs +12 -10
  72. package/dist/cjs/helpers/defaultOffset.native.js +12 -10
  73. package/dist/cjs/helpers/defaultOffset.native.js.map +1 -1
  74. package/dist/cjs/helpers/expandStyle.cjs +54 -39
  75. package/dist/cjs/helpers/expandStyle.native.js +68 -77
  76. package/dist/cjs/helpers/expandStyle.native.js.map +1 -1
  77. package/dist/cjs/helpers/expandStyles.cjs +24 -23
  78. package/dist/cjs/helpers/expandStyles.native.js +27 -21
  79. package/dist/cjs/helpers/expandStyles.native.js.map +1 -1
  80. package/dist/cjs/helpers/getCSSStylesAtomic.cjs +110 -73
  81. package/dist/cjs/helpers/getCSSStylesAtomic.native.js +17 -15
  82. package/dist/cjs/helpers/getCSSStylesAtomic.native.js.map +1 -1
  83. package/dist/cjs/helpers/getDefaultProps.cjs +22 -23
  84. package/dist/cjs/helpers/getDefaultProps.native.js +27 -23
  85. package/dist/cjs/helpers/getDefaultProps.native.js.map +1 -1
  86. package/dist/cjs/helpers/getDynamicVal.cjs +32 -27
  87. package/dist/cjs/helpers/getDynamicVal.native.js +37 -32
  88. package/dist/cjs/helpers/getDynamicVal.native.js.map +1 -1
  89. package/dist/cjs/helpers/getExpandedShorthands.cjs +15 -11
  90. package/dist/cjs/helpers/getExpandedShorthands.native.js +17 -13
  91. package/dist/cjs/helpers/getExpandedShorthands.native.js.map +1 -1
  92. package/dist/cjs/helpers/getFontLanguage.cjs +12 -10
  93. package/dist/cjs/helpers/getFontLanguage.native.js +12 -10
  94. package/dist/cjs/helpers/getFontLanguage.native.js.map +1 -1
  95. package/dist/cjs/helpers/getGroupPropParts.cjs +27 -18
  96. package/dist/cjs/helpers/getGroupPropParts.native.js +28 -19
  97. package/dist/cjs/helpers/getGroupPropParts.native.js.map +1 -1
  98. package/dist/cjs/helpers/getShorthandValue.cjs +16 -11
  99. package/dist/cjs/helpers/getShorthandValue.native.js +19 -17
  100. package/dist/cjs/helpers/getShorthandValue.native.js.map +1 -1
  101. package/dist/cjs/helpers/getSplitStyles.cjs +638 -395
  102. package/dist/cjs/helpers/getSplitStyles.native.js +754 -598
  103. package/dist/cjs/helpers/getSplitStyles.native.js.map +1 -1
  104. package/dist/cjs/helpers/getThemeCSSRules.cjs +94 -88
  105. package/dist/cjs/helpers/getThemeCSSRules.native.js +12 -10
  106. package/dist/cjs/helpers/getThemeCSSRules.native.js.map +1 -1
  107. package/dist/cjs/helpers/getTokenForKey.cjs +174 -0
  108. package/dist/cjs/helpers/getTokenForKey.native.js +186 -0
  109. package/dist/cjs/helpers/getTokenForKey.native.js.map +1 -0
  110. package/dist/cjs/helpers/getVariantExtras.cjs +60 -44
  111. package/dist/cjs/helpers/getVariantExtras.native.js +60 -44
  112. package/dist/cjs/helpers/getVariantExtras.native.js.map +1 -1
  113. package/dist/cjs/helpers/insertStyleRule.cjs +109 -75
  114. package/dist/cjs/helpers/insertStyleRule.native.js +52 -263
  115. package/dist/cjs/helpers/insertStyleRule.native.js.map +1 -1
  116. package/dist/cjs/helpers/isActivePlatform.cjs +21 -17
  117. package/dist/cjs/helpers/isActivePlatform.native.js +21 -17
  118. package/dist/cjs/helpers/isActivePlatform.native.js.map +1 -1
  119. package/dist/cjs/helpers/isActiveTheme.cjs +14 -11
  120. package/dist/cjs/helpers/isActiveTheme.native.js +14 -11
  121. package/dist/cjs/helpers/isActiveTheme.native.js.map +1 -1
  122. package/dist/cjs/helpers/isObj.cjs +13 -11
  123. package/dist/cjs/helpers/isObj.native.js +14 -12
  124. package/dist/cjs/helpers/isObj.native.js.map +1 -1
  125. package/dist/cjs/helpers/isTamaguiComponent.cjs +14 -12
  126. package/dist/cjs/helpers/isTamaguiComponent.native.js +14 -12
  127. package/dist/cjs/helpers/isTamaguiComponent.native.js.map +1 -1
  128. package/dist/cjs/helpers/isTamaguiElement.cjs +29 -25
  129. package/dist/cjs/helpers/isTamaguiElement.native.js +29 -27
  130. package/dist/cjs/helpers/isTamaguiElement.native.js.map +1 -1
  131. package/dist/cjs/helpers/log.cjs +20 -19
  132. package/dist/cjs/helpers/log.native.js +20 -19
  133. package/dist/cjs/helpers/log.native.js.map +1 -1
  134. package/dist/cjs/helpers/mainThreadPressEvents.cjs +13 -11
  135. package/dist/cjs/helpers/mainThreadPressEvents.native.js +111 -26
  136. package/dist/cjs/helpers/mainThreadPressEvents.native.js.map +1 -1
  137. package/dist/cjs/helpers/matchMedia.cjs +15 -13
  138. package/dist/cjs/helpers/matchMedia.native.js +34 -19
  139. package/dist/cjs/helpers/matchMedia.native.js.map +1 -1
  140. package/dist/cjs/helpers/mediaObjectToString.cjs +30 -14
  141. package/dist/cjs/helpers/mediaObjectToString.native.js +28 -14
  142. package/dist/cjs/helpers/mediaObjectToString.native.js.map +1 -1
  143. package/dist/cjs/helpers/mediaState.cjs +21 -17
  144. package/dist/cjs/helpers/mediaState.native.js +30 -26
  145. package/dist/cjs/helpers/mediaState.native.js.map +1 -1
  146. package/dist/cjs/helpers/mergeProps.cjs +54 -30
  147. package/dist/cjs/helpers/mergeProps.native.js +55 -30
  148. package/dist/cjs/helpers/mergeProps.native.js.map +1 -1
  149. package/dist/cjs/helpers/mergeRenderElementProps.cjs +14 -11
  150. package/dist/cjs/helpers/mergeRenderElementProps.native.js +14 -11
  151. package/dist/cjs/helpers/mergeRenderElementProps.native.js.map +1 -1
  152. package/dist/cjs/helpers/mergeSlotStyleProps.cjs +31 -18
  153. package/dist/cjs/helpers/mergeSlotStyleProps.native.js +32 -19
  154. package/dist/cjs/helpers/mergeSlotStyleProps.native.js.map +1 -1
  155. package/dist/cjs/helpers/mergeVariants.cjs +28 -16
  156. package/dist/cjs/helpers/mergeVariants.native.js +30 -18
  157. package/dist/cjs/helpers/mergeVariants.native.js.map +1 -1
  158. package/dist/cjs/helpers/nativeOnlyProps.cjs +12 -10
  159. package/dist/cjs/helpers/nativeOnlyProps.native.js +12 -10
  160. package/dist/cjs/helpers/nativeOnlyProps.native.js.map +1 -1
  161. package/dist/cjs/helpers/normalizeColor.cjs +30 -13
  162. package/dist/cjs/helpers/normalizeColor.native.js +33 -30
  163. package/dist/cjs/helpers/normalizeColor.native.js.map +1 -1
  164. package/dist/cjs/helpers/normalizeShadow.cjs +12 -10
  165. package/dist/cjs/helpers/normalizeShadow.native.js +25 -23
  166. package/dist/cjs/helpers/normalizeShadow.native.js.map +1 -1
  167. package/dist/cjs/helpers/normalizeStyle.cjs +48 -20
  168. package/dist/cjs/helpers/normalizeStyle.native.js +73 -27
  169. package/dist/cjs/helpers/normalizeStyle.native.js.map +1 -1
  170. package/dist/cjs/helpers/normalizeStylePropKeys.cjs +12 -10
  171. package/dist/cjs/helpers/normalizeStylePropKeys.native.js +22 -20
  172. package/dist/cjs/helpers/normalizeStylePropKeys.native.js.map +1 -1
  173. package/dist/cjs/helpers/normalizeValueWithProperty.cjs +33 -17
  174. package/dist/cjs/helpers/normalizeValueWithProperty.native.js +34 -18
  175. package/dist/cjs/helpers/normalizeValueWithProperty.native.js.map +1 -1
  176. package/dist/cjs/helpers/objectIdentityKey.cjs +19 -12
  177. package/dist/cjs/helpers/objectIdentityKey.native.js +22 -15
  178. package/dist/cjs/helpers/objectIdentityKey.native.js.map +1 -1
  179. package/dist/cjs/helpers/parseBorderShorthand.cjs +15 -11
  180. package/dist/cjs/helpers/parseBorderShorthand.native.js +52 -24
  181. package/dist/cjs/helpers/parseBorderShorthand.native.js.map +1 -1
  182. package/dist/cjs/helpers/parseNativeStyle.cjs +84 -49
  183. package/dist/cjs/helpers/parseNativeStyle.native.js +130 -88
  184. package/dist/cjs/helpers/parseNativeStyle.native.js.map +1 -1
  185. package/dist/cjs/helpers/parseOutlineShorthand.cjs +15 -11
  186. package/dist/cjs/helpers/parseOutlineShorthand.native.js +46 -24
  187. package/dist/cjs/helpers/parseOutlineShorthand.native.js.map +1 -1
  188. package/dist/cjs/helpers/platformResolveValue.cjs +38 -0
  189. package/dist/cjs/helpers/platformResolveValue.native.js +74 -0
  190. package/dist/cjs/helpers/platformResolveValue.native.js.map +1 -0
  191. package/dist/cjs/helpers/pointerEvents.cjs +12 -10
  192. package/dist/cjs/helpers/pointerEvents.native.js +124 -89
  193. package/dist/cjs/helpers/pointerEvents.native.js.map +1 -1
  194. package/dist/cjs/helpers/propMapper.cjs +216 -211
  195. package/dist/cjs/helpers/propMapper.native.js +297 -339
  196. package/dist/cjs/helpers/propMapper.native.js.map +1 -1
  197. package/dist/cjs/helpers/proxyThemeToParents.cjs +33 -19
  198. package/dist/cjs/helpers/proxyThemeToParents.native.js +84 -55
  199. package/dist/cjs/helpers/proxyThemeToParents.native.js.map +1 -1
  200. package/dist/cjs/helpers/proxyThemeVariables.cjs +13 -11
  201. package/dist/cjs/helpers/proxyThemeVariables.native.js +13 -11
  202. package/dist/cjs/helpers/proxyThemeVariables.native.js.map +1 -1
  203. package/dist/cjs/helpers/pseudoDescriptors.cjs +60 -58
  204. package/dist/cjs/helpers/pseudoDescriptors.native.js +60 -58
  205. package/dist/cjs/helpers/pseudoDescriptors.native.js.map +1 -1
  206. package/dist/cjs/helpers/pseudoTransitions.cjs +83 -0
  207. package/dist/cjs/helpers/pseudoTransitions.native.js +88 -0
  208. package/dist/cjs/helpers/pseudoTransitions.native.js.map +1 -0
  209. package/dist/cjs/helpers/registerCSSVariable.cjs +55 -38
  210. package/dist/cjs/helpers/registerCSSVariable.native.js +60 -45
  211. package/dist/cjs/helpers/registerCSSVariable.native.js.map +1 -1
  212. package/dist/cjs/helpers/resolveAnimationDriver.cjs +37 -0
  213. package/dist/cjs/helpers/resolveAnimationDriver.native.js +41 -0
  214. package/dist/cjs/helpers/resolveAnimationDriver.native.js.map +1 -0
  215. package/dist/cjs/helpers/resolveCompoundTokens.cjs +41 -0
  216. package/dist/cjs/helpers/resolveCompoundTokens.native.js +44 -0
  217. package/dist/cjs/helpers/resolveCompoundTokens.native.js.map +1 -0
  218. package/dist/cjs/helpers/resolveRem.cjs +13 -11
  219. package/dist/cjs/helpers/resolveRem.native.js +31 -22
  220. package/dist/cjs/helpers/resolveRem.native.js.map +1 -1
  221. package/dist/cjs/helpers/resolveSafeArea.cjs +12 -10
  222. package/dist/cjs/helpers/resolveSafeArea.native.js +18 -14
  223. package/dist/cjs/helpers/resolveSafeArea.native.js.map +1 -1
  224. package/dist/cjs/helpers/setElementProps.cjs +12 -10
  225. package/dist/cjs/helpers/setElementProps.native.js +19 -13
  226. package/dist/cjs/helpers/setElementProps.native.js.map +1 -1
  227. package/dist/cjs/helpers/skipProps.cjs +16 -14
  228. package/dist/cjs/helpers/skipProps.native.js +30 -28
  229. package/dist/cjs/helpers/skipProps.native.js.map +1 -1
  230. package/dist/cjs/helpers/sortString.cjs +12 -10
  231. package/dist/cjs/helpers/sortString.native.js +12 -10
  232. package/dist/cjs/helpers/sortString.native.js.map +1 -1
  233. package/dist/cjs/helpers/styleOriginalValues.cjs +28 -0
  234. package/dist/cjs/helpers/styleOriginalValues.native.js +31 -0
  235. package/dist/cjs/helpers/styleOriginalValues.native.js.map +1 -0
  236. package/dist/cjs/helpers/subscribeToContextGroup.cjs +83 -55
  237. package/dist/cjs/helpers/subscribeToContextGroup.native.js +118 -92
  238. package/dist/cjs/helpers/subscribeToContextGroup.native.js.map +1 -1
  239. package/dist/cjs/helpers/themeable.cjs +77 -48
  240. package/dist/cjs/helpers/themeable.native.js +97 -69
  241. package/dist/cjs/helpers/themeable.native.js.map +1 -1
  242. package/dist/cjs/helpers/themes.cjs +27 -19
  243. package/dist/cjs/helpers/themes.native.js +27 -19
  244. package/dist/cjs/helpers/themes.native.js.map +1 -1
  245. package/dist/cjs/helpers/timer.cjs +13 -11
  246. package/dist/cjs/helpers/timer.native.js +13 -11
  247. package/dist/cjs/helpers/timer.native.js.map +1 -1
  248. package/dist/cjs/helpers/transformsToString.cjs +18 -13
  249. package/dist/cjs/helpers/transformsToString.native.js +18 -13
  250. package/dist/cjs/helpers/transformsToString.native.js.map +1 -1
  251. package/dist/cjs/helpers/useRenderElement.cjs +29 -24
  252. package/dist/cjs/helpers/useRenderElement.native.js +33 -25
  253. package/dist/cjs/helpers/useRenderElement.native.js.map +1 -1
  254. package/dist/cjs/helpers/webPropsToSkip.cjs +12 -10
  255. package/dist/cjs/helpers/webPropsToSkip.native.js +60 -58
  256. package/dist/cjs/helpers/webPropsToSkip.native.js.map +1 -1
  257. package/dist/cjs/helpers/wrapStyleTags.cjs +16 -15
  258. package/dist/cjs/helpers/wrapStyleTags.native.js +14 -12
  259. package/dist/cjs/helpers/wrapStyleTags.native.js.map +1 -1
  260. package/dist/cjs/hooks/doesRootSchemeMatchSystem.cjs +13 -11
  261. package/dist/cjs/hooks/doesRootSchemeMatchSystem.native.js +14 -12
  262. package/dist/cjs/hooks/doesRootSchemeMatchSystem.native.js.map +1 -1
  263. package/dist/cjs/hooks/getThemeProxied.cjs +45 -27
  264. package/dist/cjs/hooks/getThemeProxied.native.js +79 -65
  265. package/dist/cjs/hooks/getThemeProxied.native.js.map +1 -1
  266. package/dist/cjs/hooks/useComponentState.cjs +141 -86
  267. package/dist/cjs/hooks/useComponentState.native.js +145 -97
  268. package/dist/cjs/hooks/useComponentState.native.js.map +1 -1
  269. package/dist/cjs/hooks/useDisableSSR.cjs +12 -10
  270. package/dist/cjs/hooks/useDisableSSR.native.js +13 -11
  271. package/dist/cjs/hooks/useDisableSSR.native.js.map +1 -1
  272. package/dist/cjs/hooks/useIsTouchDevice.cjs +17 -13
  273. package/dist/cjs/hooks/useIsTouchDevice.native.js +17 -15
  274. package/dist/cjs/hooks/useIsTouchDevice.native.js.map +1 -1
  275. package/dist/cjs/hooks/useMedia.cjs +153 -93
  276. package/dist/cjs/hooks/useMedia.native.js +164 -108
  277. package/dist/cjs/hooks/useMedia.native.js.map +1 -1
  278. package/dist/cjs/hooks/useProps.cjs +83 -77
  279. package/dist/cjs/hooks/useProps.native.js +85 -79
  280. package/dist/cjs/hooks/useProps.native.js.map +1 -1
  281. package/dist/cjs/hooks/useTheme.cjs +40 -25
  282. package/dist/cjs/hooks/useTheme.native.js +40 -28
  283. package/dist/cjs/hooks/useTheme.native.js.map +1 -1
  284. package/dist/cjs/hooks/useThemeName.cjs +20 -18
  285. package/dist/cjs/hooks/useThemeName.native.js +24 -22
  286. package/dist/cjs/hooks/useThemeName.native.js.map +1 -1
  287. package/dist/cjs/hooks/useThemeState.cjs +248 -172
  288. package/dist/cjs/hooks/useThemeState.native.js +315 -248
  289. package/dist/cjs/hooks/useThemeState.native.js.map +1 -1
  290. package/dist/cjs/index.cjs +22 -18
  291. package/dist/cjs/index.native.js +22 -18
  292. package/dist/cjs/index.native.js.map +1 -1
  293. package/dist/cjs/inject-styles.cjs +27 -22
  294. package/dist/cjs/inject-styles.native.js +28 -23
  295. package/dist/cjs/inject-styles.native.js.map +1 -1
  296. package/dist/cjs/insertFont.cjs +37 -28
  297. package/dist/cjs/insertFont.native.js +35 -30
  298. package/dist/cjs/insertFont.native.js.map +1 -1
  299. package/dist/cjs/interfaces/CSSColorNames.cjs +7 -5
  300. package/dist/cjs/interfaces/CSSColorNames.native.js +7 -5
  301. package/dist/cjs/interfaces/CSSColorNames.native.js.map +1 -1
  302. package/dist/cjs/interfaces/GetRef.cjs +7 -5
  303. package/dist/cjs/interfaces/GetRef.native.js +7 -5
  304. package/dist/cjs/interfaces/GetRef.native.js.map +1 -1
  305. package/dist/cjs/interfaces/RNExclusiveTypes.cjs +7 -5
  306. package/dist/cjs/interfaces/RNExclusiveTypes.native.js +7 -5
  307. package/dist/cjs/interfaces/RNExclusiveTypes.native.js.map +1 -1
  308. package/dist/cjs/interfaces/TamaguiComponentEvents.cjs +7 -5
  309. package/dist/cjs/interfaces/TamaguiComponentEvents.native.js +7 -5
  310. package/dist/cjs/interfaces/TamaguiComponentEvents.native.js.map +1 -1
  311. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.cjs +7 -5
  312. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.native.js +7 -5
  313. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.native.js.map +1 -1
  314. package/dist/cjs/setupHooks.cjs +12 -10
  315. package/dist/cjs/setupHooks.native.js +12 -10
  316. package/dist/cjs/setupHooks.native.js.map +1 -1
  317. package/dist/cjs/setupReactNative.cjs +25 -18
  318. package/dist/cjs/setupReactNative.native.js +25 -21
  319. package/dist/cjs/setupReactNative.native.js.map +1 -1
  320. package/dist/cjs/styled.cjs +121 -77
  321. package/dist/cjs/styled.native.js +125 -87
  322. package/dist/cjs/styled.native.js.map +1 -1
  323. package/dist/cjs/styledHtml.test-d.cjs +58 -27
  324. package/dist/cjs/styledHtml.test-d.native.js +58 -27
  325. package/dist/cjs/styledHtml.test-d.native.js.map +1 -1
  326. package/dist/cjs/styledNonStyleProps.test-d.cjs +63 -0
  327. package/dist/cjs/styledNonStyleProps.test-d.native.js +66 -0
  328. package/dist/cjs/styledNonStyleProps.test-d.native.js.map +1 -0
  329. package/dist/cjs/type-utils.cjs +7 -5
  330. package/dist/cjs/type-utils.native.js +7 -5
  331. package/dist/cjs/type-utils.native.js.map +1 -1
  332. package/dist/cjs/types.cjs +7 -5
  333. package/dist/cjs/types.native.js +7 -5
  334. package/dist/cjs/types.native.js.map +1 -1
  335. package/dist/cjs/views/Configuration.cjs +28 -26
  336. package/dist/cjs/views/Configuration.native.js +39 -37
  337. package/dist/cjs/views/Configuration.native.js.map +1 -1
  338. package/dist/cjs/views/FontLanguage.cjs +22 -18
  339. package/dist/cjs/views/FontLanguage.native.js +34 -32
  340. package/dist/cjs/views/FontLanguage.native.js.map +1 -1
  341. package/dist/cjs/views/Slot.cjs +55 -37
  342. package/dist/cjs/views/Slot.native.js +57 -41
  343. package/dist/cjs/views/Slot.native.js.map +1 -1
  344. package/dist/cjs/views/TamaguiProvider.cjs +65 -53
  345. package/dist/cjs/views/TamaguiProvider.native.js +69 -55
  346. package/dist/cjs/views/TamaguiProvider.native.js.map +1 -1
  347. package/dist/cjs/views/TamaguiRoot.cjs +60 -42
  348. package/dist/cjs/views/TamaguiRoot.native.js +12 -10
  349. package/dist/cjs/views/TamaguiRoot.native.js.map +1 -1
  350. package/dist/cjs/views/Text.cjs +44 -48
  351. package/dist/cjs/views/Text.native.js +32 -32
  352. package/dist/cjs/views/Text.native.js.map +1 -1
  353. package/dist/cjs/views/Theme.cjs +139 -101
  354. package/dist/cjs/views/Theme.native.js +148 -113
  355. package/dist/cjs/views/Theme.native.js.map +1 -1
  356. package/dist/cjs/views/ThemeDebug.cjs +39 -18
  357. package/dist/cjs/views/ThemeDebug.native.js +13 -11
  358. package/dist/cjs/views/ThemeDebug.native.js.map +1 -1
  359. package/dist/cjs/views/ThemeProvider.cjs +25 -20
  360. package/dist/cjs/views/ThemeProvider.native.js +30 -28
  361. package/dist/cjs/views/ThemeProvider.native.js.map +1 -1
  362. package/dist/cjs/views/View.cjs +15 -15
  363. package/dist/cjs/views/View.native.js +18 -18
  364. package/dist/cjs/views/View.native.js.map +1 -1
  365. package/dist/esm/Tamagui.mjs +29 -27
  366. package/dist/esm/Tamagui.mjs.map +1 -1
  367. package/dist/esm/Tamagui.native.js +67 -53
  368. package/dist/esm/Tamagui.native.js.map +1 -1
  369. package/dist/esm/_withStableStyle.mjs +29 -10
  370. package/dist/esm/_withStableStyle.mjs.map +1 -1
  371. package/dist/esm/_withStableStyle.native.js +32 -16
  372. package/dist/esm/_withStableStyle.native.js.map +1 -1
  373. package/dist/esm/animationDriverTypes.test-d.mjs +39 -11
  374. package/dist/esm/animationDriverTypes.test-d.mjs.map +1 -1
  375. package/dist/esm/animationDriverTypes.test-d.native.js +39 -11
  376. package/dist/esm/animationDriverTypes.test-d.native.js.map +1 -1
  377. package/dist/esm/config.mjs +121 -64
  378. package/dist/esm/config.mjs.map +1 -1
  379. package/dist/esm/config.native.js +144 -95
  380. package/dist/esm/config.native.js.map +1 -1
  381. package/dist/esm/constants/accessibilityDirectMap.mjs +5 -5
  382. package/dist/esm/constants/accessibilityDirectMap.mjs.map +1 -1
  383. package/dist/esm/constants/accessibilityDirectMap.native.js +5 -5
  384. package/dist/esm/constants/accessibilityDirectMap.native.js.map +1 -1
  385. package/dist/esm/constants/constants.mjs +5 -17
  386. package/dist/esm/constants/constants.mjs.map +1 -1
  387. package/dist/esm/constants/constants.native.js +6 -17
  388. package/dist/esm/constants/constants.native.js.map +1 -1
  389. package/dist/esm/constants/isDevTools.mjs +6 -4
  390. package/dist/esm/constants/isDevTools.mjs.map +1 -1
  391. package/dist/esm/constants/isDevTools.native.js +6 -4
  392. package/dist/esm/constants/isDevTools.native.js.map +1 -1
  393. package/dist/esm/contexts/ComponentContext.mjs +10 -8
  394. package/dist/esm/contexts/ComponentContext.mjs.map +1 -1
  395. package/dist/esm/contexts/ComponentContext.native.js +10 -10
  396. package/dist/esm/contexts/ComponentContext.native.js.map +1 -1
  397. package/dist/esm/createComponent.mjs +861 -586
  398. package/dist/esm/createComponent.mjs.map +1 -1
  399. package/dist/esm/createComponent.native.js +864 -645
  400. package/dist/esm/createComponent.native.js.map +1 -1
  401. package/dist/esm/createFont.mjs +21 -17
  402. package/dist/esm/createFont.mjs.map +1 -1
  403. package/dist/esm/createFont.native.js +23 -22
  404. package/dist/esm/createFont.native.js.map +1 -1
  405. package/dist/esm/createTamagui.mjs +94 -77
  406. package/dist/esm/createTamagui.mjs.map +1 -1
  407. package/dist/esm/createTamagui.native.js +130 -121
  408. package/dist/esm/createTamagui.native.js.map +1 -1
  409. package/dist/esm/createVariable.mjs +42 -18
  410. package/dist/esm/createVariable.mjs.map +1 -1
  411. package/dist/esm/createVariable.native.js +52 -29
  412. package/dist/esm/createVariable.native.js.map +1 -1
  413. package/dist/esm/createVariables.mjs +40 -36
  414. package/dist/esm/createVariables.mjs.map +1 -1
  415. package/dist/esm/createVariables.native.js +42 -38
  416. package/dist/esm/createVariables.native.js.map +1 -1
  417. package/dist/esm/defaultComponentState.mjs +17 -17
  418. package/dist/esm/defaultComponentState.mjs.map +1 -1
  419. package/dist/esm/defaultComponentState.native.js +17 -17
  420. package/dist/esm/defaultComponentState.native.js.map +1 -1
  421. package/dist/esm/eventHandling.mjs +3 -3
  422. package/dist/esm/eventHandling.mjs.map +1 -1
  423. package/dist/esm/eventHandling.native.js +170 -66
  424. package/dist/esm/eventHandling.native.js.map +1 -1
  425. package/dist/esm/helpers/consoleLog.native.js +2 -2
  426. package/dist/esm/helpers/consoleLog.native.js.map +1 -1
  427. package/dist/esm/helpers/createDesignSystem.mjs +67 -30
  428. package/dist/esm/helpers/createDesignSystem.mjs.map +1 -1
  429. package/dist/esm/helpers/createDesignSystem.native.js +103 -76
  430. package/dist/esm/helpers/createDesignSystem.native.js.map +1 -1
  431. package/dist/esm/helpers/createMediaStyle.mjs +76 -48
  432. package/dist/esm/helpers/createMediaStyle.mjs.map +1 -1
  433. package/dist/esm/helpers/createMediaStyle.native.js +82 -55
  434. package/dist/esm/helpers/createMediaStyle.native.js.map +1 -1
  435. package/dist/esm/helpers/createStyledContext.mjs +57 -36
  436. package/dist/esm/helpers/createStyledContext.mjs.map +1 -1
  437. package/dist/esm/helpers/createStyledContext.native.js +61 -43
  438. package/dist/esm/helpers/createStyledContext.native.js.map +1 -1
  439. package/dist/esm/helpers/defaultAnimationDriver.mjs +17 -18
  440. package/dist/esm/helpers/defaultAnimationDriver.mjs.map +1 -1
  441. package/dist/esm/helpers/defaultAnimationDriver.native.js +33 -32
  442. package/dist/esm/helpers/defaultAnimationDriver.native.js.map +1 -1
  443. package/dist/esm/helpers/expandStyle.mjs +42 -29
  444. package/dist/esm/helpers/expandStyle.mjs.map +1 -1
  445. package/dist/esm/helpers/expandStyle.native.js +48 -59
  446. package/dist/esm/helpers/expandStyle.native.js.map +1 -1
  447. package/dist/esm/helpers/expandStyles.mjs +10 -11
  448. package/dist/esm/helpers/expandStyles.mjs.map +1 -1
  449. package/dist/esm/helpers/expandStyles.native.js +13 -9
  450. package/dist/esm/helpers/expandStyles.native.js.map +1 -1
  451. package/dist/esm/helpers/getCSSStylesAtomic.mjs +89 -54
  452. package/dist/esm/helpers/getCSSStylesAtomic.mjs.map +1 -1
  453. package/dist/esm/helpers/getCSSStylesAtomic.native.js +5 -5
  454. package/dist/esm/helpers/getCSSStylesAtomic.native.js.map +1 -1
  455. package/dist/esm/helpers/getDefaultProps.mjs +10 -13
  456. package/dist/esm/helpers/getDefaultProps.mjs.map +1 -1
  457. package/dist/esm/helpers/getDefaultProps.native.js +14 -12
  458. package/dist/esm/helpers/getDefaultProps.native.js.map +1 -1
  459. package/dist/esm/helpers/getDynamicVal.mjs +20 -17
  460. package/dist/esm/helpers/getDynamicVal.mjs.map +1 -1
  461. package/dist/esm/helpers/getDynamicVal.native.js +25 -22
  462. package/dist/esm/helpers/getDynamicVal.native.js.map +1 -1
  463. package/dist/esm/helpers/getExpandedShorthands.mjs +3 -1
  464. package/dist/esm/helpers/getExpandedShorthands.mjs.map +1 -1
  465. package/dist/esm/helpers/getExpandedShorthands.native.js +5 -3
  466. package/dist/esm/helpers/getExpandedShorthands.native.js.map +1 -1
  467. package/dist/esm/helpers/getGroupPropParts.mjs +13 -6
  468. package/dist/esm/helpers/getGroupPropParts.mjs.map +1 -1
  469. package/dist/esm/helpers/getGroupPropParts.native.js +14 -7
  470. package/dist/esm/helpers/getGroupPropParts.native.js.map +1 -1
  471. package/dist/esm/helpers/getShorthandValue.mjs +4 -1
  472. package/dist/esm/helpers/getShorthandValue.mjs.map +1 -1
  473. package/dist/esm/helpers/getShorthandValue.native.js +6 -6
  474. package/dist/esm/helpers/getShorthandValue.native.js.map +1 -1
  475. package/dist/esm/helpers/getSplitStyles.mjs +595 -355
  476. package/dist/esm/helpers/getSplitStyles.mjs.map +1 -1
  477. package/dist/esm/helpers/getSplitStyles.native.js +708 -556
  478. package/dist/esm/helpers/getSplitStyles.native.js.map +1 -1
  479. package/dist/esm/helpers/getThemeCSSRules.mjs +76 -72
  480. package/dist/esm/helpers/getThemeCSSRules.mjs.map +1 -1
  481. package/dist/esm/helpers/getTokenForKey.mjs +146 -0
  482. package/dist/esm/helpers/getTokenForKey.mjs.map +1 -0
  483. package/dist/esm/helpers/getTokenForKey.native.js +155 -0
  484. package/dist/esm/helpers/getTokenForKey.native.js.map +1 -0
  485. package/dist/esm/helpers/getVariantExtras.mjs +46 -32
  486. package/dist/esm/helpers/getVariantExtras.mjs.map +1 -1
  487. package/dist/esm/helpers/getVariantExtras.native.js +46 -32
  488. package/dist/esm/helpers/getVariantExtras.native.js.map +1 -1
  489. package/dist/esm/helpers/insertStyleRule.mjs +95 -63
  490. package/dist/esm/helpers/insertStyleRule.mjs.map +1 -1
  491. package/dist/esm/helpers/insertStyleRule.native.js +38 -251
  492. package/dist/esm/helpers/insertStyleRule.native.js.map +1 -1
  493. package/dist/esm/helpers/isActivePlatform.mjs +10 -9
  494. package/dist/esm/helpers/isActivePlatform.mjs.map +1 -1
  495. package/dist/esm/helpers/isActivePlatform.native.js +10 -9
  496. package/dist/esm/helpers/isActivePlatform.native.js.map +1 -1
  497. package/dist/esm/helpers/isActiveTheme.mjs +2 -1
  498. package/dist/esm/helpers/isActiveTheme.mjs.map +1 -1
  499. package/dist/esm/helpers/isActiveTheme.native.js +2 -1
  500. package/dist/esm/helpers/isActiveTheme.native.js.map +1 -1
  501. package/dist/esm/helpers/isObj.mjs +1 -1
  502. package/dist/esm/helpers/isObj.mjs.map +1 -1
  503. package/dist/esm/helpers/isObj.native.js +2 -2
  504. package/dist/esm/helpers/isTamaguiComponent.mjs +2 -2
  505. package/dist/esm/helpers/isTamaguiComponent.mjs.map +1 -1
  506. package/dist/esm/helpers/isTamaguiComponent.native.js +2 -2
  507. package/dist/esm/helpers/isTamaguiComponent.native.js.map +1 -1
  508. package/dist/esm/helpers/isTamaguiElement.mjs +3 -1
  509. package/dist/esm/helpers/isTamaguiElement.mjs.map +1 -1
  510. package/dist/esm/helpers/isTamaguiElement.native.js.map +1 -1
  511. package/dist/esm/helpers/log.mjs +8 -9
  512. package/dist/esm/helpers/log.mjs.map +1 -1
  513. package/dist/esm/helpers/log.native.js +8 -9
  514. package/dist/esm/helpers/log.native.js.map +1 -1
  515. package/dist/esm/helpers/mainThreadPressEvents.mjs +1 -1
  516. package/dist/esm/helpers/mainThreadPressEvents.mjs.map +1 -1
  517. package/dist/esm/helpers/mainThreadPressEvents.native.js +99 -16
  518. package/dist/esm/helpers/mainThreadPressEvents.native.js.map +1 -1
  519. package/dist/esm/helpers/matchMedia.mjs +3 -3
  520. package/dist/esm/helpers/matchMedia.mjs.map +1 -1
  521. package/dist/esm/helpers/matchMedia.native.js +22 -9
  522. package/dist/esm/helpers/matchMedia.native.js.map +1 -1
  523. package/dist/esm/helpers/mediaObjectToString.mjs +18 -4
  524. package/dist/esm/helpers/mediaObjectToString.mjs.map +1 -1
  525. package/dist/esm/helpers/mediaObjectToString.native.js +16 -4
  526. package/dist/esm/helpers/mediaObjectToString.native.js.map +1 -1
  527. package/dist/esm/helpers/mediaState.mjs +9 -7
  528. package/dist/esm/helpers/mediaState.mjs.map +1 -1
  529. package/dist/esm/helpers/mediaState.native.js +18 -16
  530. package/dist/esm/helpers/mediaState.native.js.map +1 -1
  531. package/dist/esm/helpers/mergeProps.mjs +42 -20
  532. package/dist/esm/helpers/mergeProps.mjs.map +1 -1
  533. package/dist/esm/helpers/mergeProps.native.js +43 -20
  534. package/dist/esm/helpers/mergeProps.native.js.map +1 -1
  535. package/dist/esm/helpers/mergeRenderElementProps.mjs +2 -1
  536. package/dist/esm/helpers/mergeRenderElementProps.mjs.map +1 -1
  537. package/dist/esm/helpers/mergeRenderElementProps.native.js +2 -1
  538. package/dist/esm/helpers/mergeRenderElementProps.native.js.map +1 -1
  539. package/dist/esm/helpers/mergeSlotStyleProps.mjs +17 -6
  540. package/dist/esm/helpers/mergeSlotStyleProps.mjs.map +1 -1
  541. package/dist/esm/helpers/mergeSlotStyleProps.native.js +17 -6
  542. package/dist/esm/helpers/mergeSlotStyleProps.native.js.map +1 -1
  543. package/dist/esm/helpers/mergeVariants.mjs +16 -6
  544. package/dist/esm/helpers/mergeVariants.mjs.map +1 -1
  545. package/dist/esm/helpers/mergeVariants.native.js +18 -8
  546. package/dist/esm/helpers/mergeVariants.native.js.map +1 -1
  547. package/dist/esm/helpers/normalizeColor.mjs +18 -3
  548. package/dist/esm/helpers/normalizeColor.mjs.map +1 -1
  549. package/dist/esm/helpers/normalizeColor.native.js +18 -17
  550. package/dist/esm/helpers/normalizeColor.native.js.map +1 -1
  551. package/dist/esm/helpers/normalizeShadow.native.js +11 -11
  552. package/dist/esm/helpers/normalizeShadow.native.js.map +1 -1
  553. package/dist/esm/helpers/normalizeStyle.mjs +31 -5
  554. package/dist/esm/helpers/normalizeStyle.mjs.map +1 -1
  555. package/dist/esm/helpers/normalizeStyle.native.js +56 -12
  556. package/dist/esm/helpers/normalizeStyle.native.js.map +1 -1
  557. package/dist/esm/helpers/normalizeStylePropKeys.native.js +10 -10
  558. package/dist/esm/helpers/normalizeValueWithProperty.mjs +19 -5
  559. package/dist/esm/helpers/normalizeValueWithProperty.mjs.map +1 -1
  560. package/dist/esm/helpers/normalizeValueWithProperty.native.js +20 -6
  561. package/dist/esm/helpers/normalizeValueWithProperty.native.js.map +1 -1
  562. package/dist/esm/helpers/objectIdentityKey.mjs +7 -2
  563. package/dist/esm/helpers/objectIdentityKey.mjs.map +1 -1
  564. package/dist/esm/helpers/objectIdentityKey.native.js +10 -5
  565. package/dist/esm/helpers/objectIdentityKey.native.js.map +1 -1
  566. package/dist/esm/helpers/parseBorderShorthand.mjs +3 -1
  567. package/dist/esm/helpers/parseBorderShorthand.mjs.map +1 -1
  568. package/dist/esm/helpers/parseBorderShorthand.native.js +40 -14
  569. package/dist/esm/helpers/parseBorderShorthand.native.js.map +1 -1
  570. package/dist/esm/helpers/parseNativeStyle.mjs +72 -39
  571. package/dist/esm/helpers/parseNativeStyle.mjs.map +1 -1
  572. package/dist/esm/helpers/parseNativeStyle.native.js +118 -78
  573. package/dist/esm/helpers/parseNativeStyle.native.js.map +1 -1
  574. package/dist/esm/helpers/parseOutlineShorthand.mjs +3 -1
  575. package/dist/esm/helpers/parseOutlineShorthand.mjs.map +1 -1
  576. package/dist/esm/helpers/parseOutlineShorthand.native.js +34 -14
  577. package/dist/esm/helpers/parseOutlineShorthand.native.js.map +1 -1
  578. package/dist/esm/helpers/platformResolveValue.mjs +13 -0
  579. package/dist/esm/helpers/platformResolveValue.mjs.map +1 -0
  580. package/dist/esm/helpers/platformResolveValue.native.js +46 -0
  581. package/dist/esm/helpers/platformResolveValue.native.js.map +1 -0
  582. package/dist/esm/helpers/pointerEvents.native.js +110 -77
  583. package/dist/esm/helpers/pointerEvents.native.js.map +1 -1
  584. package/dist/esm/helpers/propMapper.mjs +197 -194
  585. package/dist/esm/helpers/propMapper.mjs.map +1 -1
  586. package/dist/esm/helpers/propMapper.native.js +276 -320
  587. package/dist/esm/helpers/propMapper.native.js.map +1 -1
  588. package/dist/esm/helpers/proxyThemeToParents.mjs +21 -9
  589. package/dist/esm/helpers/proxyThemeToParents.mjs.map +1 -1
  590. package/dist/esm/helpers/proxyThemeToParents.native.js +72 -45
  591. package/dist/esm/helpers/proxyThemeToParents.native.js.map +1 -1
  592. package/dist/esm/helpers/proxyThemeVariables.mjs +1 -1
  593. package/dist/esm/helpers/proxyThemeVariables.mjs.map +1 -1
  594. package/dist/esm/helpers/proxyThemeVariables.native.js +1 -1
  595. package/dist/esm/helpers/pseudoDescriptors.mjs +48 -48
  596. package/dist/esm/helpers/pseudoDescriptors.mjs.map +1 -1
  597. package/dist/esm/helpers/pseudoDescriptors.native.js +48 -48
  598. package/dist/esm/helpers/pseudoDescriptors.native.js.map +1 -1
  599. package/dist/esm/helpers/pseudoTransitions.mjs +57 -0
  600. package/dist/esm/helpers/pseudoTransitions.mjs.map +1 -0
  601. package/dist/esm/helpers/pseudoTransitions.native.js +59 -0
  602. package/dist/esm/helpers/pseudoTransitions.native.js.map +1 -0
  603. package/dist/esm/helpers/registerCSSVariable.mjs +42 -27
  604. package/dist/esm/helpers/registerCSSVariable.mjs.map +1 -1
  605. package/dist/esm/helpers/registerCSSVariable.native.js +46 -33
  606. package/dist/esm/helpers/registerCSSVariable.native.js.map +1 -1
  607. package/dist/esm/helpers/resolveAnimationDriver.mjs +12 -0
  608. package/dist/esm/helpers/resolveAnimationDriver.mjs.map +1 -0
  609. package/dist/esm/helpers/resolveAnimationDriver.native.js +13 -0
  610. package/dist/esm/helpers/resolveAnimationDriver.native.js.map +1 -0
  611. package/dist/esm/helpers/resolveCompoundTokens.mjs +16 -0
  612. package/dist/esm/helpers/resolveCompoundTokens.mjs.map +1 -0
  613. package/dist/esm/helpers/resolveCompoundTokens.native.js +16 -0
  614. package/dist/esm/helpers/resolveCompoundTokens.native.js.map +1 -0
  615. package/dist/esm/helpers/resolveRem.mjs +1 -1
  616. package/dist/esm/helpers/resolveRem.mjs.map +1 -1
  617. package/dist/esm/helpers/resolveRem.native.js +16 -9
  618. package/dist/esm/helpers/resolveRem.native.js.map +1 -1
  619. package/dist/esm/helpers/resolveSafeArea.native.js +6 -4
  620. package/dist/esm/helpers/resolveSafeArea.native.js.map +1 -1
  621. package/dist/esm/helpers/setElementProps.native.js +7 -3
  622. package/dist/esm/helpers/setElementProps.native.js.map +1 -1
  623. package/dist/esm/helpers/skipProps.mjs +3 -3
  624. package/dist/esm/helpers/skipProps.mjs.map +1 -1
  625. package/dist/esm/helpers/skipProps.native.js +3 -3
  626. package/dist/esm/helpers/skipProps.native.js.map +1 -1
  627. package/dist/esm/helpers/styleOriginalValues.mjs +3 -0
  628. package/dist/esm/helpers/styleOriginalValues.mjs.map +1 -0
  629. package/dist/esm/helpers/styleOriginalValues.native.js +3 -0
  630. package/dist/esm/helpers/styleOriginalValues.native.js.map +1 -0
  631. package/dist/esm/helpers/subscribeToContextGroup.mjs +68 -42
  632. package/dist/esm/helpers/subscribeToContextGroup.mjs.map +1 -1
  633. package/dist/esm/helpers/subscribeToContextGroup.native.js +103 -79
  634. package/dist/esm/helpers/subscribeToContextGroup.native.js.map +1 -1
  635. package/dist/esm/helpers/themeable.mjs +47 -20
  636. package/dist/esm/helpers/themeable.mjs.map +1 -1
  637. package/dist/esm/helpers/themeable.native.js +69 -43
  638. package/dist/esm/helpers/themeable.native.js.map +1 -1
  639. package/dist/esm/helpers/themes.mjs +15 -9
  640. package/dist/esm/helpers/themes.mjs.map +1 -1
  641. package/dist/esm/helpers/themes.native.js +15 -9
  642. package/dist/esm/helpers/themes.native.js.map +1 -1
  643. package/dist/esm/helpers/timer.mjs +1 -1
  644. package/dist/esm/helpers/timer.native.js +1 -1
  645. package/dist/esm/helpers/transformsToString.mjs +6 -3
  646. package/dist/esm/helpers/transformsToString.mjs.map +1 -1
  647. package/dist/esm/helpers/transformsToString.native.js +6 -3
  648. package/dist/esm/helpers/transformsToString.native.js.map +1 -1
  649. package/dist/esm/helpers/useRenderElement.mjs +14 -13
  650. package/dist/esm/helpers/useRenderElement.mjs.map +1 -1
  651. package/dist/esm/helpers/useRenderElement.native.js +18 -13
  652. package/dist/esm/helpers/useRenderElement.native.js.map +1 -1
  653. package/dist/esm/helpers/webPropsToSkip.native.js +46 -46
  654. package/dist/esm/helpers/webPropsToSkip.native.js.map +1 -1
  655. package/dist/esm/helpers/wrapStyleTags.mjs +2 -3
  656. package/dist/esm/helpers/wrapStyleTags.mjs.map +1 -1
  657. package/dist/esm/helpers/wrapStyleTags.native.js +2 -2
  658. package/dist/esm/helpers/wrapStyleTags.native.js.map +1 -1
  659. package/dist/esm/hooks/doesRootSchemeMatchSystem.mjs +1 -1
  660. package/dist/esm/hooks/getThemeProxied.mjs +32 -16
  661. package/dist/esm/hooks/getThemeProxied.mjs.map +1 -1
  662. package/dist/esm/hooks/getThemeProxied.native.js +62 -50
  663. package/dist/esm/hooks/getThemeProxied.native.js.map +1 -1
  664. package/dist/esm/hooks/useComponentState.mjs +121 -68
  665. package/dist/esm/hooks/useComponentState.mjs.map +1 -1
  666. package/dist/esm/hooks/useComponentState.native.js +125 -79
  667. package/dist/esm/hooks/useComponentState.native.js.map +1 -1
  668. package/dist/esm/hooks/useDisableSSR.native.js +1 -1
  669. package/dist/esm/hooks/useDisableSSR.native.js.map +1 -1
  670. package/dist/esm/hooks/useIsTouchDevice.mjs +3 -1
  671. package/dist/esm/hooks/useIsTouchDevice.mjs.map +1 -1
  672. package/dist/esm/hooks/useIsTouchDevice.native.js +1 -1
  673. package/dist/esm/hooks/useIsTouchDevice.native.js.map +1 -1
  674. package/dist/esm/hooks/useMedia.mjs +133 -75
  675. package/dist/esm/hooks/useMedia.mjs.map +1 -1
  676. package/dist/esm/hooks/useMedia.native.js +144 -90
  677. package/dist/esm/hooks/useMedia.native.js.map +1 -1
  678. package/dist/esm/hooks/useProps.mjs +47 -43
  679. package/dist/esm/hooks/useProps.mjs.map +1 -1
  680. package/dist/esm/hooks/useProps.native.js +49 -45
  681. package/dist/esm/hooks/useProps.native.js.map +1 -1
  682. package/dist/esm/hooks/useTheme.mjs +25 -12
  683. package/dist/esm/hooks/useTheme.mjs.map +1 -1
  684. package/dist/esm/hooks/useTheme.native.js +25 -15
  685. package/dist/esm/hooks/useTheme.native.js.map +1 -1
  686. package/dist/esm/hooks/useThemeName.mjs +8 -8
  687. package/dist/esm/hooks/useThemeName.mjs.map +1 -1
  688. package/dist/esm/hooks/useThemeName.native.js +10 -10
  689. package/dist/esm/hooks/useThemeName.native.js.map +1 -1
  690. package/dist/esm/hooks/useThemeState.mjs +233 -159
  691. package/dist/esm/hooks/useThemeState.mjs.map +1 -1
  692. package/dist/esm/hooks/useThemeState.native.js +298 -233
  693. package/dist/esm/hooks/useThemeState.native.js.map +1 -1
  694. package/dist/esm/index.js +67 -106
  695. package/dist/esm/index.js.map +1 -6
  696. package/dist/esm/index.mjs +3 -2
  697. package/dist/esm/index.mjs.map +1 -1
  698. package/dist/esm/index.native.js +3 -2
  699. package/dist/esm/index.native.js.map +1 -1
  700. package/dist/esm/inject-styles.mjs +15 -12
  701. package/dist/esm/inject-styles.mjs.map +1 -1
  702. package/dist/esm/inject-styles.native.js +16 -13
  703. package/dist/esm/inject-styles.native.js.map +1 -1
  704. package/dist/esm/insertFont.mjs +19 -13
  705. package/dist/esm/insertFont.mjs.map +1 -1
  706. package/dist/esm/insertFont.native.js +18 -16
  707. package/dist/esm/insertFont.native.js.map +1 -1
  708. package/dist/esm/setupReactNative.mjs +13 -8
  709. package/dist/esm/setupReactNative.mjs.map +1 -1
  710. package/dist/esm/setupReactNative.native.js +13 -11
  711. package/dist/esm/setupReactNative.native.js.map +1 -1
  712. package/dist/esm/styled.mjs +106 -64
  713. package/dist/esm/styled.mjs.map +1 -1
  714. package/dist/esm/styled.native.js +109 -73
  715. package/dist/esm/styled.native.js.map +1 -1
  716. package/dist/esm/styledHtml.test-d.mjs +56 -25
  717. package/dist/esm/styledHtml.test-d.mjs.map +1 -1
  718. package/dist/esm/styledHtml.test-d.native.js +56 -25
  719. package/dist/esm/styledHtml.test-d.native.js.map +1 -1
  720. package/dist/esm/styledNonStyleProps.test-d.mjs +64 -0
  721. package/dist/esm/styledNonStyleProps.test-d.mjs.map +1 -0
  722. package/dist/esm/styledNonStyleProps.test-d.native.js +64 -0
  723. package/dist/esm/styledNonStyleProps.test-d.native.js.map +1 -0
  724. package/dist/esm/views/Configuration.native.js +2 -2
  725. package/dist/esm/views/Configuration.native.js.map +1 -1
  726. package/dist/esm/views/FontLanguage.mjs +10 -8
  727. package/dist/esm/views/FontLanguage.mjs.map +1 -1
  728. package/dist/esm/views/FontLanguage.native.js +7 -7
  729. package/dist/esm/views/FontLanguage.native.js.map +1 -1
  730. package/dist/esm/views/Slot.mjs +38 -22
  731. package/dist/esm/views/Slot.mjs.map +1 -1
  732. package/dist/esm/views/Slot.native.js +40 -26
  733. package/dist/esm/views/Slot.native.js.map +1 -1
  734. package/dist/esm/views/TamaguiProvider.mjs +30 -20
  735. package/dist/esm/views/TamaguiProvider.mjs.map +1 -1
  736. package/dist/esm/views/TamaguiProvider.native.js +35 -23
  737. package/dist/esm/views/TamaguiProvider.native.js.map +1 -1
  738. package/dist/esm/views/TamaguiRoot.mjs +33 -17
  739. package/dist/esm/views/TamaguiRoot.mjs.map +1 -1
  740. package/dist/esm/views/Text.mjs +30 -36
  741. package/dist/esm/views/Text.mjs.map +1 -1
  742. package/dist/esm/views/Text.native.js +19 -20
  743. package/dist/esm/views/Text.native.js.map +1 -1
  744. package/dist/esm/views/Theme.mjs +108 -72
  745. package/dist/esm/views/Theme.mjs.map +1 -1
  746. package/dist/esm/views/Theme.native.js +114 -81
  747. package/dist/esm/views/Theme.native.js.map +1 -1
  748. package/dist/esm/views/ThemeDebug.mjs +22 -3
  749. package/dist/esm/views/ThemeDebug.mjs.map +1 -1
  750. package/dist/esm/views/ThemeDebug.native.js +1 -1
  751. package/dist/esm/views/ThemeDebug.native.js.map +1 -1
  752. package/dist/esm/views/ThemeProvider.mjs +7 -4
  753. package/dist/esm/views/ThemeProvider.mjs.map +1 -1
  754. package/dist/esm/views/ThemeProvider.native.js +5 -5
  755. package/dist/esm/views/ThemeProvider.native.js.map +1 -1
  756. package/dist/esm/views/View.mjs +1 -3
  757. package/dist/esm/views/View.mjs.map +1 -1
  758. package/dist/esm/views/View.native.js +1 -3
  759. package/dist/esm/views/View.native.js.map +1 -1
  760. package/inject-styles/index.cjs +2 -0
  761. package/inject-styles/index.js +2 -0
  762. package/package.json +21 -25
  763. package/src/_withStableStyle.tsx +54 -19
  764. package/src/animationDriverTypes.test-d.ts +76 -0
  765. package/src/config.ts +12 -1
  766. package/src/constants/constants.ts +0 -17
  767. package/src/createComponent.tsx +287 -102
  768. package/src/createTamagui.ts +37 -20
  769. package/src/createVariable.ts +1 -1
  770. package/src/eventHandling.native.ts +219 -61
  771. package/src/eventHandling.ts +6 -2
  772. package/src/helpers/createDesignSystem.ts +79 -8
  773. package/src/helpers/createMediaStyle.ts +8 -2
  774. package/src/helpers/createStyledContext.tsx +27 -18
  775. package/src/helpers/defaultAnimationDriver.tsx +1 -2
  776. package/src/helpers/expandStyle.ts +56 -7
  777. package/src/helpers/getCSSStylesAtomic.ts +5 -10
  778. package/src/helpers/getDefaultProps.ts +4 -15
  779. package/src/helpers/getSplitStyles.tsx +302 -84
  780. package/src/helpers/getTokenForKey.ts +236 -0
  781. package/src/helpers/getVariantExtras.tsx +5 -4
  782. package/src/helpers/insertStyleRule.tsx +1 -1
  783. package/src/helpers/isActivePlatform.ts +33 -4
  784. package/src/helpers/mainThreadPressEvents.native.ts +122 -25
  785. package/src/helpers/mainThreadPressEvents.ts +2 -1
  786. package/src/helpers/normalizeColor.ts +12 -8
  787. package/src/helpers/normalizeStyle.ts +23 -1
  788. package/src/helpers/parseNativeStyle.ts +10 -11
  789. package/src/helpers/platformResolveValue.native.ts +72 -0
  790. package/src/helpers/platformResolveValue.ts +22 -0
  791. package/src/helpers/propMapper.ts +60 -258
  792. package/src/helpers/pseudoTransitions.ts +97 -0
  793. package/src/helpers/resolveAnimationDriver.ts +23 -0
  794. package/src/helpers/resolveCompoundTokens.ts +28 -0
  795. package/src/helpers/skipProps.ts +1 -0
  796. package/src/helpers/styleOriginalValues.ts +2 -0
  797. package/src/helpers/themeable.tsx +7 -5
  798. package/src/helpers/useRenderElement.tsx +7 -0
  799. package/src/hooks/useComponentState.ts +11 -8
  800. package/src/hooks/useMedia.tsx +2 -0
  801. package/src/hooks/useTheme.tsx +4 -0
  802. package/src/hooks/useThemeState.ts +44 -12
  803. package/src/index.ts +3 -0
  804. package/src/styled.tsx +2 -2
  805. package/src/styledNonStyleProps.test-d.ts +106 -0
  806. package/src/types.tsx +140 -59
  807. package/src/views/TamaguiProvider.tsx +32 -21
  808. package/src/views/TamaguiRoot.tsx +40 -14
  809. package/src/views/Text.tsx +3 -9
  810. package/src/views/Theme.tsx +2 -0
  811. package/src/views/ThemeProvider.tsx +2 -0
  812. package/src/views/View.tsx +0 -2
  813. package/tsconfig.json +44 -0
  814. package/tsconfig.test.json +9 -0
  815. package/types/_withStableStyle.d.ts +1 -2
  816. package/types/_withStableStyle.d.ts.map +1 -1
  817. package/types/config.d.ts +2 -0
  818. package/types/config.d.ts.map +1 -1
  819. package/types/constants/constants.d.ts +0 -3
  820. package/types/constants/constants.d.ts.map +1 -1
  821. package/types/createComponent.d.ts.map +1 -1
  822. package/types/createTamagui.d.ts.map +1 -1
  823. package/types/createVariable.d.ts +1 -1
  824. package/types/createVariable.d.ts.map +1 -1
  825. package/types/eventHandling.d.ts +2 -2
  826. package/types/eventHandling.d.ts.map +1 -1
  827. package/types/eventHandling.native.d.ts +3 -3
  828. package/types/eventHandling.native.d.ts.map +1 -1
  829. package/types/helpers/createDesignSystem.d.ts +5 -2
  830. package/types/helpers/createDesignSystem.d.ts.map +1 -1
  831. package/types/helpers/createMediaStyle.d.ts.map +1 -1
  832. package/types/helpers/createStyledContext.d.ts +1 -1
  833. package/types/helpers/createStyledContext.d.ts.map +1 -1
  834. package/types/helpers/defaultAnimationDriver.d.ts.map +1 -1
  835. package/types/helpers/expandStyle.d.ts +2 -1
  836. package/types/helpers/expandStyle.d.ts.map +1 -1
  837. package/types/helpers/getCSSStylesAtomic.d.ts.map +1 -1
  838. package/types/helpers/getDefaultProps.d.ts +1 -1
  839. package/types/helpers/getDefaultProps.d.ts.map +1 -1
  840. package/types/helpers/getSplitStyles.d.ts +4 -4
  841. package/types/helpers/getSplitStyles.d.ts.map +1 -1
  842. package/types/helpers/getTokenForKey.d.ts +6 -0
  843. package/types/helpers/getTokenForKey.d.ts.map +1 -0
  844. package/types/helpers/getVariantExtras.d.ts.map +1 -1
  845. package/types/helpers/isActivePlatform.d.ts +14 -0
  846. package/types/helpers/isActivePlatform.d.ts.map +1 -1
  847. package/types/helpers/mainThreadPressEvents.d.ts +1 -1
  848. package/types/helpers/mainThreadPressEvents.d.ts.map +1 -1
  849. package/types/helpers/mainThreadPressEvents.native.d.ts +5 -6
  850. package/types/helpers/mainThreadPressEvents.native.d.ts.map +1 -1
  851. package/types/helpers/normalizeColor.d.ts +1 -1
  852. package/types/helpers/normalizeColor.d.ts.map +1 -1
  853. package/types/helpers/normalizeStyle.d.ts.map +1 -1
  854. package/types/helpers/platformResolveValue.d.ts +6 -0
  855. package/types/helpers/platformResolveValue.d.ts.map +1 -0
  856. package/types/helpers/platformResolveValue.native.d.ts +7 -0
  857. package/types/helpers/platformResolveValue.native.d.ts.map +1 -0
  858. package/types/helpers/propMapper.d.ts +2 -2
  859. package/types/helpers/propMapper.d.ts.map +1 -1
  860. package/types/helpers/pseudoTransitions.d.ts +29 -0
  861. package/types/helpers/pseudoTransitions.d.ts.map +1 -0
  862. package/types/helpers/resolveAnimationDriver.d.ts +7 -0
  863. package/types/helpers/resolveAnimationDriver.d.ts.map +1 -0
  864. package/types/helpers/resolveCompoundTokens.d.ts +9 -0
  865. package/types/helpers/resolveCompoundTokens.d.ts.map +1 -0
  866. package/types/helpers/skipProps.d.ts +1 -0
  867. package/types/helpers/skipProps.d.ts.map +1 -1
  868. package/types/helpers/styleOriginalValues.d.ts +2 -0
  869. package/types/helpers/styleOriginalValues.d.ts.map +1 -0
  870. package/types/helpers/themeable.d.ts.map +1 -1
  871. package/types/helpers/useRenderElement.d.ts.map +1 -1
  872. package/types/helpers/webPropsToSkip.native.d.ts +20 -20
  873. package/types/hooks/useComponentState.d.ts +2 -1
  874. package/types/hooks/useComponentState.d.ts.map +1 -1
  875. package/types/hooks/useMedia.d.ts.map +1 -1
  876. package/types/hooks/useTheme.d.ts.map +1 -1
  877. package/types/hooks/useThemeState.d.ts.map +1 -1
  878. package/types/index.d.ts +2 -1
  879. package/types/index.d.ts.map +1 -1
  880. package/types/styled.d.ts +2 -2
  881. package/types/styled.d.ts.map +1 -1
  882. package/types/types.d.ts +68 -34
  883. package/types/types.d.ts.map +1 -1
  884. package/types/views/TamaguiProvider.d.ts +1 -4
  885. package/types/views/TamaguiProvider.d.ts.map +1 -1
  886. package/types/views/TamaguiRoot.d.ts +5 -2
  887. package/types/views/TamaguiRoot.d.ts.map +1 -1
  888. package/types/views/Text.d.ts.map +1 -1
  889. package/types/views/Theme.d.ts.map +1 -1
  890. package/types/views/ThemeProvider.d.ts.map +1 -1
  891. package/types/views/View.d.ts.map +1 -1
  892. package/vitest.config.d.ts +3 -0
  893. package/vitest.config.d.ts.map +1 -0
  894. package/vitest.config.ts +14 -0
  895. package/dist/cjs/Tamagui.js +0 -56
  896. package/dist/cjs/Tamagui.js.map +0 -6
  897. package/dist/cjs/_withStableStyle.js +0 -33
  898. package/dist/cjs/_withStableStyle.js.map +0 -6
  899. package/dist/cjs/animationDriverTypes.test-d.js +0 -51
  900. package/dist/cjs/animationDriverTypes.test-d.js.map +0 -6
  901. package/dist/cjs/config.js +0 -109
  902. package/dist/cjs/config.js.map +0 -6
  903. package/dist/cjs/constants/accessibilityDirectMap.js +0 -25
  904. package/dist/cjs/constants/accessibilityDirectMap.js.map +0 -6
  905. package/dist/cjs/constants/constants.js +0 -43
  906. package/dist/cjs/constants/constants.js.map +0 -6
  907. package/dist/cjs/constants/isDevTools.js +0 -28
  908. package/dist/cjs/constants/isDevTools.js.map +0 -6
  909. package/dist/cjs/constants/webToNativeProps.cjs +0 -28
  910. package/dist/cjs/constants/webToNativeProps.js +0 -22
  911. package/dist/cjs/constants/webToNativeProps.js.map +0 -6
  912. package/dist/cjs/constants/webToNativeProps.native.js +0 -115
  913. package/dist/cjs/constants/webToNativeProps.native.js.map +0 -1
  914. package/dist/cjs/contexts/ComponentContext.js +0 -30
  915. package/dist/cjs/contexts/ComponentContext.js.map +0 -6
  916. package/dist/cjs/contexts/GroupContext.js +0 -22
  917. package/dist/cjs/contexts/GroupContext.js.map +0 -6
  918. package/dist/cjs/createComponent.js +0 -697
  919. package/dist/cjs/createComponent.js.map +0 -6
  920. package/dist/cjs/createFont.js +0 -53
  921. package/dist/cjs/createFont.js.map +0 -6
  922. package/dist/cjs/createShorthands.js +0 -23
  923. package/dist/cjs/createShorthands.js.map +0 -6
  924. package/dist/cjs/createTamagui.js +0 -190
  925. package/dist/cjs/createTamagui.js.map +0 -6
  926. package/dist/cjs/createTheme.cjs +0 -26
  927. package/dist/cjs/createTheme.js +0 -21
  928. package/dist/cjs/createTheme.js.map +0 -6
  929. package/dist/cjs/createTheme.native.js +0 -31
  930. package/dist/cjs/createTheme.native.js.map +0 -1
  931. package/dist/cjs/createTokens.js +0 -24
  932. package/dist/cjs/createTokens.js.map +0 -6
  933. package/dist/cjs/createVariable.js +0 -89
  934. package/dist/cjs/createVariable.js.map +0 -6
  935. package/dist/cjs/createVariables.js +0 -56
  936. package/dist/cjs/createVariables.js.map +0 -6
  937. package/dist/cjs/defaultComponentState.js +0 -38
  938. package/dist/cjs/defaultComponentState.js.map +0 -6
  939. package/dist/cjs/eventHandling.js +0 -41
  940. package/dist/cjs/eventHandling.js.map +0 -6
  941. package/dist/cjs/helpers/createDesignSystem.js +0 -120
  942. package/dist/cjs/helpers/createDesignSystem.js.map +0 -6
  943. package/dist/cjs/helpers/createMediaStyle.js +0 -74
  944. package/dist/cjs/helpers/createMediaStyle.js.map +0 -6
  945. package/dist/cjs/helpers/createStyledContext.js +0 -52
  946. package/dist/cjs/helpers/createStyledContext.js.map +0 -6
  947. package/dist/cjs/helpers/defaultAnimationDriver.js +0 -39
  948. package/dist/cjs/helpers/defaultAnimationDriver.js.map +0 -6
  949. package/dist/cjs/helpers/defaultOffset.js +0 -21
  950. package/dist/cjs/helpers/defaultOffset.js.map +0 -6
  951. package/dist/cjs/helpers/expandStyle.js +0 -73
  952. package/dist/cjs/helpers/expandStyle.js.map +0 -6
  953. package/dist/cjs/helpers/expandStyles.js +0 -34
  954. package/dist/cjs/helpers/expandStyles.js.map +0 -6
  955. package/dist/cjs/helpers/getCSSStylesAtomic.js +0 -156
  956. package/dist/cjs/helpers/getCSSStylesAtomic.js.map +0 -6
  957. package/dist/cjs/helpers/getDefaultProps.js +0 -31
  958. package/dist/cjs/helpers/getDefaultProps.js.map +0 -6
  959. package/dist/cjs/helpers/getDynamicVal.js +0 -62
  960. package/dist/cjs/helpers/getDynamicVal.js.map +0 -6
  961. package/dist/cjs/helpers/getExpandedShorthands.js +0 -34
  962. package/dist/cjs/helpers/getExpandedShorthands.js.map +0 -6
  963. package/dist/cjs/helpers/getFontLanguage.js +0 -21
  964. package/dist/cjs/helpers/getFontLanguage.js.map +0 -6
  965. package/dist/cjs/helpers/getGroupPropParts.js +0 -34
  966. package/dist/cjs/helpers/getGroupPropParts.js.map +0 -6
  967. package/dist/cjs/helpers/getShorthandValue.js +0 -23
  968. package/dist/cjs/helpers/getShorthandValue.js.map +0 -6
  969. package/dist/cjs/helpers/getSplitStyles.js +0 -630
  970. package/dist/cjs/helpers/getSplitStyles.js.map +0 -6
  971. package/dist/cjs/helpers/getThemeCSSRules.js +0 -98
  972. package/dist/cjs/helpers/getThemeCSSRules.js.map +0 -6
  973. package/dist/cjs/helpers/getVariantExtras.js +0 -59
  974. package/dist/cjs/helpers/getVariantExtras.js.map +0 -6
  975. package/dist/cjs/helpers/insertStyleRule.js +0 -196
  976. package/dist/cjs/helpers/insertStyleRule.js.map +0 -6
  977. package/dist/cjs/helpers/isActivePlatform.js +0 -31
  978. package/dist/cjs/helpers/isActivePlatform.js.map +0 -6
  979. package/dist/cjs/helpers/isActiveTheme.js +0 -24
  980. package/dist/cjs/helpers/isActiveTheme.js.map +0 -6
  981. package/dist/cjs/helpers/isObj.js +0 -21
  982. package/dist/cjs/helpers/isObj.js.map +0 -6
  983. package/dist/cjs/helpers/isTamaguiComponent.js +0 -24
  984. package/dist/cjs/helpers/isTamaguiComponent.js.map +0 -6
  985. package/dist/cjs/helpers/isTamaguiElement.js +0 -30
  986. package/dist/cjs/helpers/isTamaguiElement.js.map +0 -6
  987. package/dist/cjs/helpers/log.js +0 -33
  988. package/dist/cjs/helpers/log.js.map +0 -6
  989. package/dist/cjs/helpers/mainThreadPressEvents.js +0 -22
  990. package/dist/cjs/helpers/mainThreadPressEvents.js.map +0 -6
  991. package/dist/cjs/helpers/matchMedia.js +0 -34
  992. package/dist/cjs/helpers/matchMedia.js.map +0 -6
  993. package/dist/cjs/helpers/mediaObjectToString.js +0 -32
  994. package/dist/cjs/helpers/mediaObjectToString.js.map +0 -6
  995. package/dist/cjs/helpers/mediaState.js +0 -41
  996. package/dist/cjs/helpers/mediaState.js.map +0 -6
  997. package/dist/cjs/helpers/mergeProps.js +0 -55
  998. package/dist/cjs/helpers/mergeProps.js.map +0 -6
  999. package/dist/cjs/helpers/mergeRenderElementProps.js +0 -25
  1000. package/dist/cjs/helpers/mergeRenderElementProps.js.map +0 -6
  1001. package/dist/cjs/helpers/mergeSlotStyleProps.js +0 -29
  1002. package/dist/cjs/helpers/mergeSlotStyleProps.js.map +0 -6
  1003. package/dist/cjs/helpers/mergeVariants.js +0 -38
  1004. package/dist/cjs/helpers/mergeVariants.js.map +0 -6
  1005. package/dist/cjs/helpers/nativeOnlyProps.js +0 -55
  1006. package/dist/cjs/helpers/nativeOnlyProps.js.map +0 -6
  1007. package/dist/cjs/helpers/normalizeColor.js +0 -26
  1008. package/dist/cjs/helpers/normalizeColor.js.map +0 -6
  1009. package/dist/cjs/helpers/normalizeShadow.js +0 -40
  1010. package/dist/cjs/helpers/normalizeShadow.js.map +0 -6
  1011. package/dist/cjs/helpers/normalizeStyle.js +0 -36
  1012. package/dist/cjs/helpers/normalizeStyle.js.map +0 -6
  1013. package/dist/cjs/helpers/normalizeStylePropKeys.js +0 -21
  1014. package/dist/cjs/helpers/normalizeStylePropKeys.js.map +0 -6
  1015. package/dist/cjs/helpers/normalizeValueWithProperty.js +0 -37
  1016. package/dist/cjs/helpers/normalizeValueWithProperty.js.map +0 -6
  1017. package/dist/cjs/helpers/objectIdentityKey.js +0 -38
  1018. package/dist/cjs/helpers/objectIdentityKey.js.map +0 -6
  1019. package/dist/cjs/helpers/parseBorderShorthand.js +0 -22
  1020. package/dist/cjs/helpers/parseBorderShorthand.js.map +0 -6
  1021. package/dist/cjs/helpers/parseNativeStyle.js +0 -116
  1022. package/dist/cjs/helpers/parseNativeStyle.js.map +0 -6
  1023. package/dist/cjs/helpers/parseOutlineShorthand.js +0 -22
  1024. package/dist/cjs/helpers/parseOutlineShorthand.js.map +0 -6
  1025. package/dist/cjs/helpers/pointerEvents.js +0 -22
  1026. package/dist/cjs/helpers/pointerEvents.js.map +0 -6
  1027. package/dist/cjs/helpers/propMapper.js +0 -257
  1028. package/dist/cjs/helpers/propMapper.js.map +0 -6
  1029. package/dist/cjs/helpers/proxyThemeToParents.js +0 -40
  1030. package/dist/cjs/helpers/proxyThemeToParents.js.map +0 -6
  1031. package/dist/cjs/helpers/proxyThemeVariables.js +0 -31
  1032. package/dist/cjs/helpers/proxyThemeVariables.js.map +0 -6
  1033. package/dist/cjs/helpers/pseudoDescriptors.js +0 -72
  1034. package/dist/cjs/helpers/pseudoDescriptors.js.map +0 -6
  1035. package/dist/cjs/helpers/registerCSSVariable.js +0 -47
  1036. package/dist/cjs/helpers/registerCSSVariable.js.map +0 -6
  1037. package/dist/cjs/helpers/resolveRem.js +0 -27
  1038. package/dist/cjs/helpers/resolveRem.js.map +0 -6
  1039. package/dist/cjs/helpers/resolveSafeArea.js +0 -29
  1040. package/dist/cjs/helpers/resolveSafeArea.js.map +0 -6
  1041. package/dist/cjs/helpers/setElementProps.js +0 -24
  1042. package/dist/cjs/helpers/setElementProps.js.map +0 -6
  1043. package/dist/cjs/helpers/skipProps.js +0 -38
  1044. package/dist/cjs/helpers/skipProps.js.map +0 -6
  1045. package/dist/cjs/helpers/sortString.js +0 -21
  1046. package/dist/cjs/helpers/sortString.js.map +0 -6
  1047. package/dist/cjs/helpers/subscribeToContextGroup.js +0 -74
  1048. package/dist/cjs/helpers/subscribeToContextGroup.js.map +0 -6
  1049. package/dist/cjs/helpers/themeable.js +0 -56
  1050. package/dist/cjs/helpers/themeable.js.map +0 -6
  1051. package/dist/cjs/helpers/themes.js +0 -33
  1052. package/dist/cjs/helpers/themes.js.map +0 -6
  1053. package/dist/cjs/helpers/timer.js +0 -27
  1054. package/dist/cjs/helpers/timer.js.map +0 -6
  1055. package/dist/cjs/helpers/transformsToString.js +0 -33
  1056. package/dist/cjs/helpers/transformsToString.js.map +0 -6
  1057. package/dist/cjs/helpers/useRenderElement.js +0 -42
  1058. package/dist/cjs/helpers/useRenderElement.js.map +0 -6
  1059. package/dist/cjs/helpers/webPropsToSkip.js +0 -21
  1060. package/dist/cjs/helpers/webPropsToSkip.js.map +0 -6
  1061. package/dist/cjs/helpers/wrapStyleTags.js +0 -38
  1062. package/dist/cjs/helpers/wrapStyleTags.js.map +0 -6
  1063. package/dist/cjs/hooks/doesRootSchemeMatchSystem.js +0 -23
  1064. package/dist/cjs/hooks/doesRootSchemeMatchSystem.js.map +0 -6
  1065. package/dist/cjs/hooks/getThemeProxied.js +0 -56
  1066. package/dist/cjs/hooks/getThemeProxied.js.map +0 -6
  1067. package/dist/cjs/hooks/useComponentState.js +0 -96
  1068. package/dist/cjs/hooks/useComponentState.js.map +0 -6
  1069. package/dist/cjs/hooks/useDisableSSR.js +0 -24
  1070. package/dist/cjs/hooks/useDisableSSR.js.map +0 -6
  1071. package/dist/cjs/hooks/useIsTouchDevice.js +0 -22
  1072. package/dist/cjs/hooks/useIsTouchDevice.js.map +0 -6
  1073. package/dist/cjs/hooks/useMedia.js +0 -153
  1074. package/dist/cjs/hooks/useMedia.js.map +0 -6
  1075. package/dist/cjs/hooks/useProps.js +0 -106
  1076. package/dist/cjs/hooks/useProps.js.map +0 -6
  1077. package/dist/cjs/hooks/useTheme.js +0 -35
  1078. package/dist/cjs/hooks/useTheme.js.map +0 -6
  1079. package/dist/cjs/hooks/useThemeName.js +0 -25
  1080. package/dist/cjs/hooks/useThemeName.js.map +0 -6
  1081. package/dist/cjs/hooks/useThemeState.js +0 -226
  1082. package/dist/cjs/hooks/useThemeState.js.map +0 -6
  1083. package/dist/cjs/index.js +0 -109
  1084. package/dist/cjs/index.js.map +0 -6
  1085. package/dist/cjs/inject-styles.js +0 -28
  1086. package/dist/cjs/inject-styles.js.map +0 -6
  1087. package/dist/cjs/insertFont.js +0 -68
  1088. package/dist/cjs/insertFont.js.map +0 -6
  1089. package/dist/cjs/interfaces/CSSColorNames.js +0 -14
  1090. package/dist/cjs/interfaces/CSSColorNames.js.map +0 -6
  1091. package/dist/cjs/interfaces/GetRef.js +0 -14
  1092. package/dist/cjs/interfaces/GetRef.js.map +0 -6
  1093. package/dist/cjs/interfaces/RNExclusiveTypes.js +0 -14
  1094. package/dist/cjs/interfaces/RNExclusiveTypes.js.map +0 -6
  1095. package/dist/cjs/interfaces/TamaguiComponentEvents.js +0 -14
  1096. package/dist/cjs/interfaces/TamaguiComponentEvents.js.map +0 -6
  1097. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.js +0 -14
  1098. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.js.map +0 -6
  1099. package/dist/cjs/setupHooks.js +0 -25
  1100. package/dist/cjs/setupHooks.js.map +0 -6
  1101. package/dist/cjs/setupReactNative.js +0 -43
  1102. package/dist/cjs/setupReactNative.js.map +0 -6
  1103. package/dist/cjs/styled.js +0 -116
  1104. package/dist/cjs/styled.js.map +0 -6
  1105. package/dist/cjs/styledHtml.test-d.js +0 -136
  1106. package/dist/cjs/styledHtml.test-d.js.map +0 -6
  1107. package/dist/cjs/type-utils.js +0 -14
  1108. package/dist/cjs/type-utils.js.map +0 -6
  1109. package/dist/cjs/types.js +0 -14
  1110. package/dist/cjs/types.js.map +0 -6
  1111. package/dist/cjs/views/Configuration.js +0 -33
  1112. package/dist/cjs/views/Configuration.js.map +0 -6
  1113. package/dist/cjs/views/FontLanguage.js +0 -32
  1114. package/dist/cjs/views/FontLanguage.js.map +0 -6
  1115. package/dist/cjs/views/Slot.js +0 -55
  1116. package/dist/cjs/views/Slot.js.map +0 -6
  1117. package/dist/cjs/views/Stack.cjs +0 -34
  1118. package/dist/cjs/views/Stack.js +0 -27
  1119. package/dist/cjs/views/Stack.js.map +0 -6
  1120. package/dist/cjs/views/Stack.native.js +0 -37
  1121. package/dist/cjs/views/Stack.native.js.map +0 -1
  1122. package/dist/cjs/views/TamaguiProvider.js +0 -73
  1123. package/dist/cjs/views/TamaguiProvider.js.map +0 -6
  1124. package/dist/cjs/views/TamaguiRoot.js +0 -40
  1125. package/dist/cjs/views/TamaguiRoot.js.map +0 -6
  1126. package/dist/cjs/views/Text.js +0 -59
  1127. package/dist/cjs/views/Text.js.map +0 -6
  1128. package/dist/cjs/views/Theme.js +0 -124
  1129. package/dist/cjs/views/Theme.js.map +0 -6
  1130. package/dist/cjs/views/ThemeDebug.js +0 -81
  1131. package/dist/cjs/views/ThemeDebug.js.map +0 -6
  1132. package/dist/cjs/views/ThemeProvider.js +0 -42
  1133. package/dist/cjs/views/ThemeProvider.js.map +0 -6
  1134. package/dist/cjs/views/View.js +0 -26
  1135. package/dist/cjs/views/View.js.map +0 -6
  1136. package/dist/esm/Tamagui.js +0 -35
  1137. package/dist/esm/Tamagui.js.map +0 -6
  1138. package/dist/esm/_withStableStyle.js +0 -12
  1139. package/dist/esm/_withStableStyle.js.map +0 -6
  1140. package/dist/esm/animationDriverTypes.test-d.js +0 -51
  1141. package/dist/esm/animationDriverTypes.test-d.js.map +0 -6
  1142. package/dist/esm/config.js +0 -94
  1143. package/dist/esm/config.js.map +0 -6
  1144. package/dist/esm/constants/accessibilityDirectMap.js +0 -9
  1145. package/dist/esm/constants/accessibilityDirectMap.js.map +0 -6
  1146. package/dist/esm/constants/constants.js +0 -27
  1147. package/dist/esm/constants/constants.js.map +0 -6
  1148. package/dist/esm/constants/isDevTools.js +0 -12
  1149. package/dist/esm/constants/isDevTools.js.map +0 -6
  1150. package/dist/esm/constants/webToNativeProps.js +0 -6
  1151. package/dist/esm/constants/webToNativeProps.js.map +0 -6
  1152. package/dist/esm/constants/webToNativeProps.mjs +0 -4
  1153. package/dist/esm/constants/webToNativeProps.mjs.map +0 -1
  1154. package/dist/esm/constants/webToNativeProps.native.js +0 -88
  1155. package/dist/esm/constants/webToNativeProps.native.js.map +0 -1
  1156. package/dist/esm/contexts/ComponentContext.js +0 -15
  1157. package/dist/esm/contexts/ComponentContext.js.map +0 -6
  1158. package/dist/esm/contexts/GroupContext.js +0 -6
  1159. package/dist/esm/contexts/GroupContext.js.map +0 -6
  1160. package/dist/esm/createComponent.js +0 -702
  1161. package/dist/esm/createComponent.js.map +0 -6
  1162. package/dist/esm/createFont.js +0 -37
  1163. package/dist/esm/createFont.js.map +0 -6
  1164. package/dist/esm/createShorthands.js +0 -7
  1165. package/dist/esm/createShorthands.js.map +0 -6
  1166. package/dist/esm/createTamagui.js +0 -189
  1167. package/dist/esm/createTamagui.js.map +0 -6
  1168. package/dist/esm/createTheme.js +0 -5
  1169. package/dist/esm/createTheme.js.map +0 -6
  1170. package/dist/esm/createTheme.mjs +0 -3
  1171. package/dist/esm/createTheme.mjs.map +0 -1
  1172. package/dist/esm/createTheme.native.js +0 -5
  1173. package/dist/esm/createTheme.native.js.map +0 -1
  1174. package/dist/esm/createTokens.js +0 -8
  1175. package/dist/esm/createTokens.js.map +0 -6
  1176. package/dist/esm/createVariable.js +0 -75
  1177. package/dist/esm/createVariable.js.map +0 -6
  1178. package/dist/esm/createVariables.js +0 -42
  1179. package/dist/esm/createVariables.js.map +0 -6
  1180. package/dist/esm/defaultComponentState.js +0 -22
  1181. package/dist/esm/defaultComponentState.js.map +0 -6
  1182. package/dist/esm/eventHandling.js +0 -25
  1183. package/dist/esm/eventHandling.js.map +0 -6
  1184. package/dist/esm/helpers/createDesignSystem.js +0 -107
  1185. package/dist/esm/helpers/createDesignSystem.js.map +0 -6
  1186. package/dist/esm/helpers/createMediaStyle.js +0 -60
  1187. package/dist/esm/helpers/createMediaStyle.js.map +0 -6
  1188. package/dist/esm/helpers/createStyledContext.js +0 -31
  1189. package/dist/esm/helpers/createStyledContext.js.map +0 -6
  1190. package/dist/esm/helpers/defaultAnimationDriver.js +0 -23
  1191. package/dist/esm/helpers/defaultAnimationDriver.js.map +0 -6
  1192. package/dist/esm/helpers/defaultOffset.js +0 -5
  1193. package/dist/esm/helpers/defaultOffset.js.map +0 -6
  1194. package/dist/esm/helpers/expandStyle.js +0 -60
  1195. package/dist/esm/helpers/expandStyle.js.map +0 -6
  1196. package/dist/esm/helpers/expandStyles.js +0 -19
  1197. package/dist/esm/helpers/expandStyles.js.map +0 -6
  1198. package/dist/esm/helpers/getCSSStylesAtomic.js +0 -147
  1199. package/dist/esm/helpers/getCSSStylesAtomic.js.map +0 -6
  1200. package/dist/esm/helpers/getDefaultProps.js +0 -15
  1201. package/dist/esm/helpers/getDefaultProps.js.map +0 -6
  1202. package/dist/esm/helpers/getDynamicVal.js +0 -46
  1203. package/dist/esm/helpers/getDynamicVal.js.map +0 -6
  1204. package/dist/esm/helpers/getExpandedShorthands.js +0 -18
  1205. package/dist/esm/helpers/getExpandedShorthands.js.map +0 -6
  1206. package/dist/esm/helpers/getFontLanguage.js +0 -5
  1207. package/dist/esm/helpers/getFontLanguage.js.map +0 -6
  1208. package/dist/esm/helpers/getGroupPropParts.js +0 -19
  1209. package/dist/esm/helpers/getGroupPropParts.js.map +0 -6
  1210. package/dist/esm/helpers/getShorthandValue.js +0 -7
  1211. package/dist/esm/helpers/getShorthandValue.js.map +0 -6
  1212. package/dist/esm/helpers/getSplitStyles.js +0 -649
  1213. package/dist/esm/helpers/getSplitStyles.js.map +0 -6
  1214. package/dist/esm/helpers/getThemeCSSRules.js +0 -87
  1215. package/dist/esm/helpers/getThemeCSSRules.js.map +0 -6
  1216. package/dist/esm/helpers/getVariantExtras.js +0 -44
  1217. package/dist/esm/helpers/getVariantExtras.js.map +0 -6
  1218. package/dist/esm/helpers/insertStyleRule.js +0 -181
  1219. package/dist/esm/helpers/insertStyleRule.js.map +0 -6
  1220. package/dist/esm/helpers/isActivePlatform.js +0 -15
  1221. package/dist/esm/helpers/isActivePlatform.js.map +0 -6
  1222. package/dist/esm/helpers/isActiveTheme.js +0 -8
  1223. package/dist/esm/helpers/isActiveTheme.js.map +0 -6
  1224. package/dist/esm/helpers/isObj.js +0 -5
  1225. package/dist/esm/helpers/isObj.js.map +0 -6
  1226. package/dist/esm/helpers/isTamaguiComponent.js +0 -8
  1227. package/dist/esm/helpers/isTamaguiComponent.js.map +0 -6
  1228. package/dist/esm/helpers/isTamaguiElement.js +0 -7
  1229. package/dist/esm/helpers/isTamaguiElement.js.map +0 -6
  1230. package/dist/esm/helpers/log.js +0 -17
  1231. package/dist/esm/helpers/log.js.map +0 -6
  1232. package/dist/esm/helpers/mainThreadPressEvents.js +0 -6
  1233. package/dist/esm/helpers/mainThreadPressEvents.js.map +0 -6
  1234. package/dist/esm/helpers/matchMedia.js +0 -18
  1235. package/dist/esm/helpers/matchMedia.js.map +0 -6
  1236. package/dist/esm/helpers/mediaObjectToString.js +0 -16
  1237. package/dist/esm/helpers/mediaObjectToString.js.map +0 -6
  1238. package/dist/esm/helpers/mediaState.js +0 -25
  1239. package/dist/esm/helpers/mediaState.js.map +0 -6
  1240. package/dist/esm/helpers/mergeProps.js +0 -39
  1241. package/dist/esm/helpers/mergeProps.js.map +0 -6
  1242. package/dist/esm/helpers/mergeRenderElementProps.js +0 -9
  1243. package/dist/esm/helpers/mergeRenderElementProps.js.map +0 -6
  1244. package/dist/esm/helpers/mergeSlotStyleProps.js +0 -14
  1245. package/dist/esm/helpers/mergeSlotStyleProps.js.map +0 -6
  1246. package/dist/esm/helpers/mergeVariants.js +0 -22
  1247. package/dist/esm/helpers/mergeVariants.js.map +0 -6
  1248. package/dist/esm/helpers/nativeOnlyProps.js +0 -39
  1249. package/dist/esm/helpers/nativeOnlyProps.js.map +0 -6
  1250. package/dist/esm/helpers/normalizeColor.js +0 -10
  1251. package/dist/esm/helpers/normalizeColor.js.map +0 -6
  1252. package/dist/esm/helpers/normalizeShadow.js +0 -24
  1253. package/dist/esm/helpers/normalizeShadow.js.map +0 -6
  1254. package/dist/esm/helpers/normalizeStyle.js +0 -24
  1255. package/dist/esm/helpers/normalizeStyle.js.map +0 -6
  1256. package/dist/esm/helpers/normalizeStylePropKeys.js +0 -5
  1257. package/dist/esm/helpers/normalizeStylePropKeys.js.map +0 -6
  1258. package/dist/esm/helpers/normalizeValueWithProperty.js +0 -22
  1259. package/dist/esm/helpers/normalizeValueWithProperty.js.map +0 -6
  1260. package/dist/esm/helpers/objectIdentityKey.js +0 -22
  1261. package/dist/esm/helpers/objectIdentityKey.js.map +0 -6
  1262. package/dist/esm/helpers/parseBorderShorthand.js +0 -6
  1263. package/dist/esm/helpers/parseBorderShorthand.js.map +0 -6
  1264. package/dist/esm/helpers/parseNativeStyle.js +0 -100
  1265. package/dist/esm/helpers/parseNativeStyle.js.map +0 -6
  1266. package/dist/esm/helpers/parseOutlineShorthand.js +0 -6
  1267. package/dist/esm/helpers/parseOutlineShorthand.js.map +0 -6
  1268. package/dist/esm/helpers/pointerEvents.js +0 -6
  1269. package/dist/esm/helpers/pointerEvents.js.map +0 -6
  1270. package/dist/esm/helpers/propMapper.js +0 -252
  1271. package/dist/esm/helpers/propMapper.js.map +0 -6
  1272. package/dist/esm/helpers/proxyThemeToParents.js +0 -24
  1273. package/dist/esm/helpers/proxyThemeToParents.js.map +0 -6
  1274. package/dist/esm/helpers/proxyThemeVariables.js +0 -15
  1275. package/dist/esm/helpers/proxyThemeVariables.js.map +0 -6
  1276. package/dist/esm/helpers/pseudoDescriptors.js +0 -56
  1277. package/dist/esm/helpers/pseudoDescriptors.js.map +0 -6
  1278. package/dist/esm/helpers/registerCSSVariable.js +0 -31
  1279. package/dist/esm/helpers/registerCSSVariable.js.map +0 -6
  1280. package/dist/esm/helpers/resolveRem.js +0 -11
  1281. package/dist/esm/helpers/resolveRem.js.map +0 -6
  1282. package/dist/esm/helpers/resolveSafeArea.js +0 -13
  1283. package/dist/esm/helpers/resolveSafeArea.js.map +0 -6
  1284. package/dist/esm/helpers/setElementProps.js +0 -8
  1285. package/dist/esm/helpers/setElementProps.js.map +0 -6
  1286. package/dist/esm/helpers/skipProps.js +0 -23
  1287. package/dist/esm/helpers/skipProps.js.map +0 -6
  1288. package/dist/esm/helpers/sortString.js +0 -5
  1289. package/dist/esm/helpers/sortString.js.map +0 -6
  1290. package/dist/esm/helpers/subscribeToContextGroup.js +0 -59
  1291. package/dist/esm/helpers/subscribeToContextGroup.js.map +0 -6
  1292. package/dist/esm/helpers/themeable.js +0 -35
  1293. package/dist/esm/helpers/themeable.js.map +0 -6
  1294. package/dist/esm/helpers/themes.js +0 -17
  1295. package/dist/esm/helpers/themes.js.map +0 -6
  1296. package/dist/esm/helpers/timer.js +0 -11
  1297. package/dist/esm/helpers/timer.js.map +0 -6
  1298. package/dist/esm/helpers/transformsToString.js +0 -17
  1299. package/dist/esm/helpers/transformsToString.js.map +0 -6
  1300. package/dist/esm/helpers/useRenderElement.js +0 -28
  1301. package/dist/esm/helpers/useRenderElement.js.map +0 -6
  1302. package/dist/esm/helpers/webPropsToSkip.js +0 -5
  1303. package/dist/esm/helpers/webPropsToSkip.js.map +0 -6
  1304. package/dist/esm/helpers/wrapStyleTags.js +0 -23
  1305. package/dist/esm/helpers/wrapStyleTags.js.map +0 -6
  1306. package/dist/esm/hooks/doesRootSchemeMatchSystem.js +0 -7
  1307. package/dist/esm/hooks/doesRootSchemeMatchSystem.js.map +0 -6
  1308. package/dist/esm/hooks/getThemeProxied.js +0 -44
  1309. package/dist/esm/hooks/getThemeProxied.js.map +0 -6
  1310. package/dist/esm/hooks/useComponentState.js +0 -91
  1311. package/dist/esm/hooks/useComponentState.js.map +0 -6
  1312. package/dist/esm/hooks/useDisableSSR.js +0 -8
  1313. package/dist/esm/hooks/useDisableSSR.js.map +0 -6
  1314. package/dist/esm/hooks/useIsTouchDevice.js +0 -7
  1315. package/dist/esm/hooks/useIsTouchDevice.js.map +0 -6
  1316. package/dist/esm/hooks/useMedia.js +0 -149
  1317. package/dist/esm/hooks/useMedia.js.map +0 -6
  1318. package/dist/esm/hooks/useProps.js +0 -93
  1319. package/dist/esm/hooks/useProps.js.map +0 -6
  1320. package/dist/esm/hooks/useTheme.js +0 -21
  1321. package/dist/esm/hooks/useTheme.js.map +0 -6
  1322. package/dist/esm/hooks/useThemeName.js +0 -9
  1323. package/dist/esm/hooks/useThemeName.js.map +0 -6
  1324. package/dist/esm/hooks/useThemeState.js +0 -220
  1325. package/dist/esm/hooks/useThemeState.js.map +0 -6
  1326. package/dist/esm/inject-styles.js +0 -12
  1327. package/dist/esm/inject-styles.js.map +0 -6
  1328. package/dist/esm/insertFont.js +0 -56
  1329. package/dist/esm/insertFont.js.map +0 -6
  1330. package/dist/esm/interfaces/CSSColorNames.js +0 -1
  1331. package/dist/esm/interfaces/CSSColorNames.js.map +0 -6
  1332. package/dist/esm/interfaces/GetRef.js +0 -1
  1333. package/dist/esm/interfaces/GetRef.js.map +0 -6
  1334. package/dist/esm/interfaces/RNExclusiveTypes.js +0 -1
  1335. package/dist/esm/interfaces/RNExclusiveTypes.js.map +0 -6
  1336. package/dist/esm/interfaces/TamaguiComponentEvents.js +0 -1
  1337. package/dist/esm/interfaces/TamaguiComponentEvents.js.map +0 -6
  1338. package/dist/esm/interfaces/TamaguiComponentPropsBaseBase.js +0 -1
  1339. package/dist/esm/interfaces/TamaguiComponentPropsBaseBase.js.map +0 -6
  1340. package/dist/esm/setupHooks.js +0 -9
  1341. package/dist/esm/setupHooks.js.map +0 -6
  1342. package/dist/esm/setupReactNative.js +0 -27
  1343. package/dist/esm/setupReactNative.js.map +0 -6
  1344. package/dist/esm/styled.js +0 -102
  1345. package/dist/esm/styled.js.map +0 -6
  1346. package/dist/esm/styledHtml.test-d.js +0 -137
  1347. package/dist/esm/styledHtml.test-d.js.map +0 -6
  1348. package/dist/esm/type-utils.js +0 -1
  1349. package/dist/esm/type-utils.js.map +0 -6
  1350. package/dist/esm/types.js +0 -1
  1351. package/dist/esm/types.js.map +0 -6
  1352. package/dist/esm/views/Configuration.js +0 -12
  1353. package/dist/esm/views/Configuration.js.map +0 -6
  1354. package/dist/esm/views/FontLanguage.js +0 -16
  1355. package/dist/esm/views/FontLanguage.js.map +0 -6
  1356. package/dist/esm/views/Slot.js +0 -43
  1357. package/dist/esm/views/Slot.js.map +0 -6
  1358. package/dist/esm/views/Stack.js +0 -13
  1359. package/dist/esm/views/Stack.js.map +0 -6
  1360. package/dist/esm/views/Stack.mjs +0 -11
  1361. package/dist/esm/views/Stack.mjs.map +0 -1
  1362. package/dist/esm/views/Stack.native.js +0 -11
  1363. package/dist/esm/views/Stack.native.js.map +0 -1
  1364. package/dist/esm/views/TamaguiProvider.js +0 -58
  1365. package/dist/esm/views/TamaguiProvider.js.map +0 -6
  1366. package/dist/esm/views/TamaguiRoot.js +0 -18
  1367. package/dist/esm/views/TamaguiRoot.js.map +0 -6
  1368. package/dist/esm/views/Text.js +0 -44
  1369. package/dist/esm/views/Text.js.map +0 -6
  1370. package/dist/esm/views/Theme.js +0 -110
  1371. package/dist/esm/views/Theme.js.map +0 -6
  1372. package/dist/esm/views/ThemeDebug.js +0 -69
  1373. package/dist/esm/views/ThemeDebug.js.map +0 -6
  1374. package/dist/esm/views/ThemeProvider.js +0 -31
  1375. package/dist/esm/views/ThemeProvider.js.map +0 -6
  1376. package/dist/esm/views/View.js +0 -12
  1377. package/dist/esm/views/View.js.map +0 -6
  1378. package/types/constants/webToNativeProps.d.ts.map +0 -1
  1379. package/types/constants/webToNativeProps.native.d.ts.map +0 -1
  1380. package/types/createTheme.d.ts.map +0 -1
  1381. package/types/helpers/expandStyle.native.d.ts.map +0 -1
  1382. package/types/helpers/propMapper.native.d.ts.map +0 -1
  1383. package/types/views/Stack.d.ts.map +0 -1
@@ -1,5 +1,6 @@
1
1
  import { composeRefs } from "@tamagui/compose-refs";
2
2
  import { isClient, isServer, isWeb, useIsomorphicLayoutEffect } from "@tamagui/constants";
3
+ import { NativeMenuContext } from "@tamagui/native";
3
4
  import { composeEventHandlers } from "@tamagui/helpers";
4
5
  import { isEqualShallow } from "@tamagui/is-equal-shallow";
5
6
  import React, { useMemo } from "react";
@@ -9,14 +10,16 @@ import { ComponentContext } from "./contexts/ComponentContext.mjs";
9
10
  import { GroupContext } from "./contexts/GroupContext.mjs";
10
11
  import { didGetVariableValue, setDidGetVariableValue } from "./createVariable.mjs";
11
12
  import { defaultComponentStateMounted } from "./defaultComponentState.mjs";
12
- import { getWebEvents } from "./eventHandling.mjs";
13
+ import { getWebEvents, useEvents, wrapWithGestureDetector } from "./eventHandling.mjs";
13
14
  import { getDefaultProps } from "./helpers/getDefaultProps.mjs";
15
+ import { resolveAnimationDriver } from "./helpers/resolveAnimationDriver.mjs";
14
16
  import { getSplitStyles, useSplitStyles } from "./helpers/getSplitStyles.mjs";
15
17
  import { log } from "./helpers/log.mjs";
16
- import { usePointerEvents } from "./helpers/pointerEvents.mjs";
17
18
  import { mergeComponentProps } from "./helpers/mergeProps.mjs";
18
19
  import { mergeRenderElementProps } from "./helpers/mergeRenderElementProps.mjs";
19
20
  import { objectIdentityKey } from "./helpers/objectIdentityKey.mjs";
21
+ import { usePointerEvents } from "./helpers/pointerEvents.mjs";
22
+ import { extractPseudoState, resolveEffectivePseudoTransition } from "./helpers/pseudoTransitions.mjs";
20
23
  import { setElementProps } from "./helpers/setElementProps.mjs";
21
24
  import { subscribeToContextGroup } from "./helpers/subscribeToContextGroup.mjs";
22
25
  import { themeable } from "./helpers/themeable.mjs";
@@ -28,644 +31,876 @@ import { hooks } from "./setupHooks.mjs";
28
31
  import { Slot } from "./views/Slot.mjs";
29
32
  import { getThemedChildren } from "./views/Theme.mjs";
30
33
  import { Fragment, jsx, jsxs } from "react/jsx-runtime";
31
- let time, debugKeyListeners, startVisualizer;
32
- const componentSetStates = /* @__PURE__ */new Set(),
33
- avoidReRenderKeys = /* @__PURE__ */new Set(["hover", "press", "pressIn", "group", "focus", "focusWithin", "media", "group"]);
34
- if (typeof window < "u") {
34
+ let time;
35
+ let debugKeyListeners;
36
+ let startVisualizer;
37
+ const componentSetStates = /* @__PURE__ */new Set();
38
+ const avoidReRenderKeys = /* @__PURE__ */new Set(["hover", "press", "pressIn", "group", "focus", "focusWithin", "media", "group"]);
39
+ if (typeof window !== "undefined") {
35
40
  const cancelPresses = () => {
36
- componentSetStates.forEach(setState => setState(prev => prev.press || prev.pressIn ? {
41
+ componentSetStates.forEach(setState => setState(prev => {
42
+ if (prev.press || prev.pressIn) return {
37
43
  ...prev,
38
- press: !1,
39
- pressIn: !1
40
- } : prev)), componentSetStates.clear();
41
- },
42
- cancelTouches = () => {
43
- componentSetStates.forEach(setState => setState(prev => prev.press || prev.pressIn || prev.hover ? {
44
+ press: false,
45
+ pressIn: false
46
+ };
47
+ return prev;
48
+ }));
49
+ componentSetStates.clear();
50
+ };
51
+ const cancelTouches = () => {
52
+ componentSetStates.forEach(setState => setState(prev => {
53
+ if (prev.press || prev.pressIn || prev.hover) return {
44
54
  ...prev,
45
- press: !1,
46
- pressIn: !1,
47
- hover: !1
48
- } : prev)), componentSetStates.clear();
49
- };
50
- addEventListener("mouseup", cancelPresses), addEventListener("touchend", cancelTouches), addEventListener("touchcancel", cancelTouches), process.env.NODE_ENV === "development" && (startVisualizer = () => {
55
+ press: false,
56
+ pressIn: false,
57
+ hover: false
58
+ };
59
+ return prev;
60
+ }));
61
+ componentSetStates.clear();
62
+ };
63
+ addEventListener("mouseup", cancelPresses);
64
+ addEventListener("touchend", cancelTouches);
65
+ addEventListener("touchcancel", cancelTouches);
66
+ if (process.env.NODE_ENV === "development") startVisualizer = () => {
51
67
  const devVisualizerConfig = devConfig?.visualizer;
52
68
  if (devVisualizerConfig && !globalThis.__tamaguiDevVisualizer) {
53
69
  let show = function (val) {
54
- clearTimeout(tm), isShowing = val, debugKeyListeners?.forEach(l => l(val)), !val && resizeListener && (window.removeEventListener("resize", resizeListener), resizeListener = null);
70
+ clearTimeout(tm);
71
+ isShowing = val;
72
+ debugKeyListeners?.forEach(l => l(val));
73
+ if (!val && resizeListener) {
74
+ window.removeEventListener("resize", resizeListener);
75
+ resizeListener = null;
76
+ }
55
77
  },
56
78
  cancelShow = function () {
57
- clearTimeout(tm), resizeListener && (window.removeEventListener("resize", resizeListener), resizeListener = null);
79
+ clearTimeout(tm);
80
+ if (resizeListener) {
81
+ window.removeEventListener("resize", resizeListener);
82
+ resizeListener = null;
83
+ }
58
84
  };
59
- globalThis.__tamaguiDevVisualizer = !0, debugKeyListeners = /* @__PURE__ */new Set();
60
- let tm,
61
- isShowing = !1,
62
- resizeListener = null;
85
+ globalThis.__tamaguiDevVisualizer = true;
86
+ debugKeyListeners = /* @__PURE__ */new Set();
87
+ let tm;
88
+ let isShowing = false;
89
+ let resizeListener = null;
63
90
  const options = {
64
91
  key: "Alt",
65
92
  delay: 800,
66
- ...(typeof devVisualizerConfig == "object" ? devVisualizerConfig : {})
93
+ ...(typeof devVisualizerConfig === "object" ? devVisualizerConfig : {})
67
94
  };
68
95
  window.addEventListener("blur", () => {
69
- show(!1);
70
- }), window.addEventListener("keydown", ({
96
+ show(false);
97
+ });
98
+ window.addEventListener("keydown", ({
71
99
  key,
72
100
  metaKey,
73
101
  defaultPrevented
74
102
  }) => {
75
- clearTimeout(tm), !defaultPrevented && (metaKey || key === options.key && (resizeListener || (resizeListener = () => cancelShow(), window.addEventListener("resize", resizeListener)), tm = setTimeout(() => {
76
- show(!0);
77
- }, options.delay)));
78
- }), window.addEventListener("keyup", ({
103
+ clearTimeout(tm);
104
+ if (defaultPrevented) return;
105
+ if (metaKey) return;
106
+ if (key === options.key) {
107
+ if (!resizeListener) {
108
+ resizeListener = () => cancelShow();
109
+ window.addEventListener("resize", resizeListener);
110
+ }
111
+ tm = setTimeout(() => {
112
+ show(true);
113
+ }, options.delay);
114
+ }
115
+ });
116
+ window.addEventListener("keyup", ({
79
117
  defaultPrevented
80
118
  }) => {
81
- defaultPrevented || (cancelShow(), isShowing && show(!1));
119
+ if (defaultPrevented) return;
120
+ cancelShow();
121
+ if (isShowing) show(false);
82
122
  });
83
123
  }
84
- });
124
+ };
85
125
  }
86
- let BaseText, BaseView;
87
126
  const lastInteractionWasKeyboard = {
88
- value: !1
89
- },
90
- lastInteractionWasTouch = {
91
- value: !1
92
- };
93
- isWeb && typeof document < "u" && (document.addEventListener("keydown", () => {
94
- lastInteractionWasKeyboard.value || (lastInteractionWasKeyboard.value = !0);
95
- }), document.addEventListener("mousedown", () => {
96
- lastInteractionWasKeyboard.value && (lastInteractionWasKeyboard.value = !1);
97
- }), document.addEventListener("mousemove", () => {
98
- lastInteractionWasKeyboard.value && (lastInteractionWasKeyboard.value = !1), lastInteractionWasTouch.value = !1;
99
- }), document.addEventListener("touchstart", () => {
100
- lastInteractionWasTouch.value = !0;
101
- }));
127
+ value: false
128
+ };
129
+ const lastInteractionWasTouch = {
130
+ value: false
131
+ };
132
+ if (isWeb && typeof document !== "undefined") {
133
+ document.addEventListener("keydown", () => {
134
+ if (!lastInteractionWasKeyboard.value) lastInteractionWasKeyboard.value = true;
135
+ });
136
+ document.addEventListener("mousedown", () => {
137
+ if (lastInteractionWasKeyboard.value) lastInteractionWasKeyboard.value = false;
138
+ });
139
+ document.addEventListener("mousemove", () => {
140
+ if (lastInteractionWasKeyboard.value) lastInteractionWasKeyboard.value = false;
141
+ lastInteractionWasTouch.value = false;
142
+ });
143
+ document.addEventListener("touchstart", () => {
144
+ lastInteractionWasTouch.value = true;
145
+ });
146
+ }
102
147
  function createComponent(staticConfig) {
103
148
  let config = null;
104
149
  const {
105
- Component,
106
- isText,
107
- isHOC
108
- } = staticConfig,
109
- component = React.forwardRef((propsIn, forwardedRef) => {
110
- config ||= getConfig();
111
- const internalID = process.env.NODE_ENV === "development" ? React.useId() : "";
112
- process.env.NODE_ENV === "development" && startVisualizer && (startVisualizer(), startVisualizer = void 0), process.env.NODE_ENV === "test" && propsIn["data-test-renders"] && (propsIn["data-test-renders"].current ??= 0, propsIn["data-test-renders"].current += 1);
113
- const {
114
- context,
115
- isReactNative
116
- } = staticConfig,
117
- debugProp = propsIn.debug,
118
- styledContextValue = context ? React.useContext(context) : void 0;
119
- let overriddenContextProps = null;
120
- const componentContext = React.useContext(ComponentContext),
121
- hasTextAncestor = !!(isWeb && isText && componentContext.inText);
122
- !process.env.TAMAGUI_IS_CORE_NODE && process.env.NODE_ENV === "development" && debugProp === "profile" && !time && (time = require("@tamagui/timer").timer().start(), globalThis.time = time), process.env.NODE_ENV === "development" && time && time`non-tamagui time (ignore)`;
123
- let props = propsIn;
124
- const componentName = props.componentName || staticConfig.componentName,
125
- defaultProps = getDefaultProps(staticConfig, props.componentName, isText && hasTextAncestor),
126
- [nextProps, overrides] = mergeComponentProps(defaultProps, styledContextValue, propsIn);
127
- props = nextProps, overriddenContextProps = overrides, process.env.NODE_ENV === "development" && isClient && React.useEffect(() => {
128
- let node,
150
+ Component,
151
+ isText,
152
+ isHOC
153
+ } = staticConfig;
154
+ const component = React.forwardRef((propsIn, forwardedRef) => {
155
+ "use no memo";
156
+
157
+ config = config || getConfig();
158
+ const internalID = process.env.NODE_ENV === "development" ? React.useId() : "";
159
+ if (process.env.NODE_ENV === "development") {
160
+ if (startVisualizer) {
161
+ startVisualizer();
162
+ startVisualizer = void 0;
163
+ }
164
+ }
165
+ if (process.env.NODE_ENV === "test") {
166
+ if (propsIn["data-test-renders"]) {
167
+ propsIn["data-test-renders"]["current"] = propsIn["data-test-renders"]["current"] ?? 0;
168
+ propsIn["data-test-renders"]["current"] += 1;
169
+ }
170
+ }
171
+ const {
172
+ context,
173
+ isReactNative
174
+ } = staticConfig;
175
+ const debugProp = propsIn["debug"];
176
+ const styledContextValue = context ? React.useContext(context) : void 0;
177
+ let overriddenContextProps = null;
178
+ const componentContext = React.useContext(ComponentContext);
179
+ const hasTextAncestor = !!(isWeb && isText ? componentContext.inText : false);
180
+ if (!process.env.TAMAGUI_IS_CORE_NODE && process.env.NODE_ENV === "development" && debugProp === "profile" && !time) {
181
+ time = require("@tamagui/timer").timer().start();
182
+ globalThis["time"] = time;
183
+ }
184
+ if (process.env.NODE_ENV === "development" && !time && globalThis.time) time = globalThis.time;
185
+ if (process.env.NODE_ENV === "development" && time) time`non-tamagui time (ignore)`;
186
+ let props = propsIn;
187
+ const componentName = props.componentName || staticConfig.componentName;
188
+ const [nextProps, overrides] = mergeComponentProps(getDefaultProps(staticConfig, props.componentName), styledContextValue, propsIn);
189
+ props = nextProps;
190
+ overriddenContextProps = overrides;
191
+ if (process.env.NODE_ENV === "development" && isClient) React.useEffect(() => {
192
+ let node;
193
+ let overlay = null;
194
+ const remove = () => {
195
+ if (overlay) try {
196
+ overlay.parentNode?.removeChild(overlay);
129
197
  overlay = null;
130
- const remove = () => {
131
- if (overlay) try {
132
- overlay.parentNode?.removeChild(overlay), overlay = null;
133
- } catch {}
134
- },
135
- debugVisualizerHandler = (show = !1) => {
136
- if (node = stateRef.current.host, !!node) if (show) {
137
- overlay || (overlay = document.createElement("span"), overlay.style.inset = "0px", overlay.style.zIndex = "1000000", overlay.style.position = "absolute", overlay.style.borderColor = "red", overlay.style.borderWidth = "1px", overlay.style.borderStyle = "dotted");
138
- const dataAt = node.getAttribute("data-at") || "",
139
- dataIn = node.getAttribute("data-in") || "",
140
- tooltip = document.createElement("span");
141
- tooltip.style.position = "absolute", tooltip.style.top = "0px", tooltip.style.left = "0px", tooltip.style.padding = "3px", tooltip.style.background = "rgba(0,0,0,0.75)", tooltip.style.color = "rgba(255,255,255,1)", tooltip.style.fontSize = "12px", tooltip.style.lineHeight = "12px", tooltip.style.fontFamily = "monospace", tooltip.innerText = `${componentName || ""} ${dataAt} ${dataIn}`.trim(), overlay.appendChild(tooltip), node.appendChild(overlay);
142
- } else remove();
143
- };
144
- return debugKeyListeners ||= /* @__PURE__ */new Set(), debugKeyListeners.add(debugVisualizerHandler), () => {
145
- remove(), debugKeyListeners?.delete(debugVisualizerHandler);
146
- };
147
- }, [componentName]);
148
- const groupContextParent = React.useContext(GroupContext),
149
- animationDriver = (() => {
150
- if (props.animatedBy && config?.animations) {
151
- const animations = config.animations;
152
- return "default" in animations ? animations[props.animatedBy] ?? animations.default : props.animatedBy === "default" ? animations : null;
198
+ } catch {}
199
+ };
200
+ const debugVisualizerHandler = (show = false) => {
201
+ node = stateRef.current.host;
202
+ if (!node) return;
203
+ if (show) {
204
+ if (!overlay) {
205
+ overlay = document.createElement("span");
206
+ overlay.style.inset = "0px";
207
+ overlay.style.zIndex = "1000000";
208
+ overlay.style.position = "absolute";
209
+ overlay.style.borderColor = "red";
210
+ overlay.style.borderWidth = "1px";
211
+ overlay.style.borderStyle = "dotted";
153
212
  }
154
- return componentContext.animationDriver;
155
- })(),
156
- useAnimations = animationDriver?.useAnimations,
157
- componentState = useComponentState(props, animationDriver?.isStub ? null : animationDriver, staticConfig, config),
158
- {
159
- disabled,
160
- groupName,
161
- hasAnimationProp,
162
- hasEnterStyle,
163
- isAnimated,
164
- isExiting,
165
- isHydrated,
166
- presence,
167
- presenceState,
168
- setState,
169
- noClass,
170
- state,
171
- stateRef,
172
- supportsCSS,
173
- willBeAnimated,
174
- willBeAnimatedClient,
175
- startedUnhydrated
176
- } = componentState;
177
- hasAnimationProp && animationDriver?.avoidReRenders && useIsomorphicLayoutEffect(() => {
178
- const pendingState = stateRef.current.nextState;
179
- pendingState && (stateRef.current.nextState = void 0, componentState.setStateShallow(pendingState));
180
- });
181
- const allGroupContexts = useMemo(() => {
182
- if (!groupName || props.passThrough) return groupContextParent;
183
- const listeners = /* @__PURE__ */new Set();
184
- return stateRef.current.group?.listeners?.clear(), stateRef.current.group = {
185
- listeners,
186
- emit(state2) {
187
- listeners.forEach(l => l(state2));
213
+ const dataAt = node.getAttribute("data-at") || "";
214
+ const dataIn = node.getAttribute("data-in") || "";
215
+ const tooltip = document.createElement("span");
216
+ tooltip.style.position = "absolute";
217
+ tooltip.style.top = "0px";
218
+ tooltip.style.left = "0px";
219
+ tooltip.style.padding = "3px";
220
+ tooltip.style.background = "rgba(0,0,0,0.75)";
221
+ tooltip.style.color = "rgba(255,255,255,1)";
222
+ tooltip.style.fontSize = "12px";
223
+ tooltip.style.lineHeight = "12px";
224
+ tooltip.style.fontFamily = "monospace";
225
+ tooltip.innerText = `${componentName || ""} ${dataAt} ${dataIn}`.trim();
226
+ overlay.appendChild(tooltip);
227
+ node.appendChild(overlay);
228
+ } else remove();
229
+ };
230
+ debugKeyListeners = debugKeyListeners || /* @__PURE__ */new Set();
231
+ debugKeyListeners.add(debugVisualizerHandler);
232
+ return () => {
233
+ remove();
234
+ debugKeyListeners?.delete(debugVisualizerHandler);
235
+ };
236
+ }, [componentName]);
237
+ const groupContextParent = React.useContext(GroupContext);
238
+ const animationDriver = (() => {
239
+ if (props.animatedBy && config) {
240
+ if (config.animationDrivers) return config.animationDrivers[props.animatedBy] ?? config.animations;
241
+ return props.animatedBy === "default" ? config.animations : null;
242
+ }
243
+ return resolveAnimationDriver(componentContext.animationDriver) ?? resolveAnimationDriver(config?.animations) ?? null;
244
+ })();
245
+ const useAnimations = animationDriver?.useAnimations;
246
+ const componentState = useComponentState(props, animationDriver?.isStub ? null : animationDriver, staticConfig, config);
247
+ const {
248
+ disabled,
249
+ groupName,
250
+ hasAnimationProp,
251
+ hasEnterStyle,
252
+ isAnimated,
253
+ isExiting,
254
+ isHydrated,
255
+ presence,
256
+ presenceState,
257
+ setState,
258
+ noClass,
259
+ state,
260
+ stateRef,
261
+ inputStyle,
262
+ outputStyle,
263
+ willBeAnimated,
264
+ willBeAnimatedClient,
265
+ startedUnhydrated
266
+ } = componentState;
267
+ if (animationDriver?.avoidReRenders) useIsomorphicLayoutEffect(() => {
268
+ const pendingState = stateRef.current.nextState;
269
+ if (!pendingState) return;
270
+ stateRef.current.nextState = void 0;
271
+ if (!isEqualShallow(state, pendingState)) componentState.setStateShallow(pendingState);
272
+ });
273
+ const allGroupContexts = useMemo(() => {
274
+ if (!groupName || props.passThrough) return groupContextParent;
275
+ const listeners = /* @__PURE__ */new Set();
276
+ stateRef.current.group?.listeners?.clear();
277
+ stateRef.current.group = {
278
+ listeners,
279
+ emit(state2) {
280
+ listeners.forEach(l => l(state2));
281
+ },
282
+ subscribe(cb) {
283
+ listeners.add(cb);
284
+ if (listeners.size === 1) setStateShallow({
285
+ hasDynGroupChildren: true
286
+ });
287
+ return () => {
288
+ listeners.delete(cb);
289
+ if (listeners.size === 0) setStateShallow({
290
+ hasDynGroupChildren: false
291
+ });
292
+ };
293
+ }
294
+ };
295
+ return {
296
+ ...groupContextParent,
297
+ [groupName]: {
298
+ state: {
299
+ pseudo: defaultComponentStateMounted
188
300
  },
189
- subscribe(cb) {
190
- return listeners.add(cb), listeners.size === 1 && setStateShallow({
191
- hasDynGroupChildren: !0
192
- }), () => {
193
- listeners.delete(cb), listeners.size === 0 && setStateShallow({
194
- hasDynGroupChildren: !1
195
- });
301
+ subscribe: listener => {
302
+ const dispose = stateRef.current.group?.subscribe(listener);
303
+ return () => {
304
+ dispose?.();
196
305
  };
197
306
  }
198
- }, {
199
- ...groupContextParent,
200
- [groupName]: {
201
- state: {
202
- pseudo: defaultComponentStateMounted
203
- },
204
- subscribe: listener => {
205
- const dispose = stateRef.current.group?.subscribe(listener);
206
- return () => {
207
- dispose?.();
208
- };
209
- }
210
- }
211
- };
212
- }, [stateRef, groupName, groupContextParent]);
213
- let setStateShallow = componentState.setStateShallow;
214
- process.env.NODE_ENV === "development" && time && time`use-state`;
215
- const isTaggable = !Component || typeof Component == "string",
216
- renderProp = props.render,
217
- element = isWeb && isTaggable && renderProp || Component,
218
- BaseTextComponent = BaseText || element || "span",
219
- BaseViewComponent = BaseView || element || (hasTextAncestor ? "span" : "div");
220
- let elementType = isText ? BaseTextComponent : BaseViewComponent;
221
- animationDriver && isAnimated &&
222
- // this should really be behind another prop as it's not really related to
223
- // "needsWebStyles" basically with motion we just animate a plain div, but
224
- // we still have animated.View/Text for Sheet which wants to control
225
- // things declaratively
226
- !animationDriver.needsWebStyles && (elementType = animationDriver[isText ? "Text" : "View"] || elementType);
227
- const disableTheme = props["data-disable-theme"] || isHOC;
228
- process.env.NODE_ENV === "development" && time && time`theme-props`;
229
- const themeStateProps = {
230
- componentName,
231
- disable: disableTheme,
232
- shallow: props.themeShallow,
233
- debug: debugProp,
234
- unstyled: props.unstyled
307
+ }
235
308
  };
236
- if ("theme" in props && (themeStateProps.name = props.theme), themeStateProps.needsUpdate = () => !!stateRef.current.isListeningToTheme, process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile") {
237
- const name = `${componentName || Component?.displayName || Component?.name || "[Unnamed Component]"}`,
238
- type = (hasEnterStyle ? "(hasEnter)" : " ") + (isAnimated ? "(animated)" : " ") + (isReactNative ? "(rnw)" : " ") + (noClass ? "(noClass)" : " ") + (state.press || state.pressIn ? "(PRESSED)" : " ") + (state.hover ? "(HOVERED)" : " ") + (state.focus ? "(FOCUSED)" : " ") + (state.focusWithin ? "(WITHIN FOCUSED)" : " ") + (presenceState?.isPresent === !1 ? "(EXIT)" : ""),
239
- dataIs = propsIn["data-is"] || "",
240
- banner = `<${name} /> ${internalID} ${dataIs ? ` ${dataIs}` : ""} ${type.trim()} (hydrated: ${isHydrated}) (unmounted: ${state.unmounted})`,
241
- ch = propsIn.children;
242
- let childLog = typeof ch == "string" ? ch.length > 4 ? ch.slice(0, 4) + "..." : ch : "";
243
- childLog.length && (childLog = `(children: ${childLog})`), isWeb ? (console.info(`%c ${banner}`, "background: green; color: white;"), isServer ? log({
244
- noClass,
245
- isAnimated,
246
- isWeb,
247
- supportsCSS
248
- }) : (console.groupEnd(), console.groupCollapsed(`${childLog} [inspect props, state, context \u{1F447}]`), log("props in:", propsIn), log("final props:", props, Object.keys(props)), log({
249
- state,
250
- staticConfig,
251
- elementType,
252
- themeStateProps
253
- }), log({
254
- context,
255
- overriddenContextProps,
256
- componentContext
257
- }), log({
258
- presence,
259
- isAnimated,
260
- isHOC,
261
- hasAnimationProp,
262
- useAnimations
263
- }), console.groupEnd())) : (console.info(`
309
+ }, [stateRef, groupName, groupContextParent]);
310
+ let setStateShallow = componentState.setStateShallow;
311
+ if (process.env.NODE_ENV === "development" && time) time`use-state`;
312
+ const renderProp = props.render;
313
+ const element = isWeb ? !Component || typeof Component === "string" ? renderProp || Component : Component : Component;
314
+ const BaseComponent = isText ? element || "span" : element || (hasTextAncestor ? "span" : "div");
315
+ let elementType = BaseComponent;
316
+ if (animationDriver && isAnimated && animationDriver.needsCustomComponent) elementType = animationDriver[isText ? "Text" : "View"] || elementType;
317
+ const disableTheme = props["data-disable-theme"] || isHOC;
318
+ if (process.env.NODE_ENV === "development" && time) time`theme-props`;
319
+ const themeStateProps = {
320
+ componentName,
321
+ disable: disableTheme,
322
+ shallow: props.themeShallow,
323
+ debug: debugProp,
324
+ unstyled: props.unstyled
325
+ };
326
+ if ("theme" in props) themeStateProps.name = props.theme;
327
+ themeStateProps.needsUpdate = () => !!stateRef.current.isListeningToTheme;
328
+ if (process.env.NODE_ENV === "development") {
329
+ if (debugProp && debugProp !== "profile") {
330
+ const name = `${componentName || Component?.displayName || Component?.name || "[Unnamed Component]"}`;
331
+ const type = (hasEnterStyle ? "(hasEnter)" : " ") + (isAnimated ? "(animated)" : " ") + (isReactNative ? "(rnw)" : " ") + (noClass ? "(noClass)" : " ") + (state.press || state.pressIn ? "(PRESSED)" : " ") + (state.hover ? "(HOVERED)" : " ") + (state.focus ? "(FOCUSED)" : " ") + (state.focusWithin ? "(WITHIN FOCUSED)" : " ") + (presenceState?.isPresent === false ? "(EXIT)" : "");
332
+ const dataIs = propsIn["data-is"] || "";
333
+ const banner = `<${name} /> ${internalID} ${dataIs ? ` ${dataIs}` : ""} ${type.trim()} (hydrated: ${isHydrated}) (unmounted: ${state.unmounted})`;
334
+ const ch = propsIn.children;
335
+ let childLog = typeof ch === "string" ? ch.length > 4 ? ch.slice(0, 4) + "..." : ch : "";
336
+ if (childLog.length) childLog = `(children: ${childLog})`;
337
+ if (isWeb) {
338
+ console.info(`%c ${banner}`, "background: green; color: white;");
339
+ if (isServer) log({
340
+ noClass,
341
+ isAnimated,
342
+ isWeb,
343
+ inputStyle
344
+ });else {
345
+ console.groupEnd();
346
+ console.groupCollapsed(`${childLog} [inspect props, state, context \u{1F447}]`);
347
+ log("props in:", propsIn);
348
+ log("final props:", props, Object.keys(props));
349
+ log({
350
+ state,
351
+ staticConfig,
352
+ elementType,
353
+ themeStateProps
354
+ });
355
+ log({
356
+ context,
357
+ overriddenContextProps,
358
+ componentContext
359
+ });
360
+ log({
361
+ presence,
362
+ isAnimated,
363
+ isHOC,
364
+ hasAnimationProp,
365
+ useAnimations
366
+ });
367
+ console.groupEnd();
368
+ }
369
+ } else {
370
+ console.info(`
264
371
 
265
372
  ------------------------------
266
373
  ${banner}
267
374
  ------------------------------
268
- `), log("children:", props.children), log({
269
- overriddenContextProps,
270
- styledContextValue
271
- }), log({
272
- noClass,
273
- isAnimated,
274
- isWeb,
275
- supportsCSS
276
- }));
375
+ `);
376
+ log(`children:`, props.children);
377
+ log({
378
+ overriddenContextProps,
379
+ styledContextValue
380
+ });
381
+ log({
382
+ noClass,
383
+ isAnimated,
384
+ isWeb,
385
+ inputStyle
386
+ });
387
+ }
277
388
  }
278
- process.env.NODE_ENV === "development" && time && time`pre-theme-media`;
279
- const [theme, themeState] = useThemeWithState(themeStateProps);
280
- process.env.NODE_ENV === "development" && time && time`theme`, elementType = element || elementType;
281
- const isStringElement = typeof elementType == "string",
282
- mediaState = useMedia(componentContext, debugProp);
283
- setDidGetVariableValue(!1), process.env.NODE_ENV === "development" && time && time`media`;
284
- const resolveValues =
285
- // if HOC + mounted + has animation prop, resolve as value so it passes non-variable to child
286
- isAnimated && !supportsCSS || isHOC && state.unmounted == !1 && hasAnimationProp ? "value" : "auto",
287
- styleProps = {
288
- mediaState,
289
- noClass,
290
- resolveValues,
291
- isExiting,
292
- isAnimated,
293
- willBeAnimated,
294
- styledContext: styledContextValue
295
- },
296
- themeName = themeState?.name || "";
297
- process.env.NODE_ENV === "development" && time && time`split-styles-prepare`;
298
- const splitStyles = useSplitStyles(props, staticConfig, theme, themeName, state, styleProps, null, componentContext, allGroupContexts, elementType, startedUnhydrated, debugProp),
299
- isPassthrough = !splitStyles;
300
- let contextForOverride = staticConfig.context;
301
- if (splitStyles?.overriddenContextProps) {
302
- const contextForProps = staticConfig.context || staticConfig.parentStaticConfig?.context;
303
- if (contextForProps) {
304
- for (const key in splitStyles.overriddenContextProps) overriddenContextProps ||= {}, overriddenContextProps[key] = splitStyles.overriddenContextProps[key];
305
- staticConfig.context || (contextForOverride = contextForProps);
389
+ }
390
+ if (process.env.NODE_ENV === "development" && time) time`pre-theme-media`;
391
+ const [theme, themeState] = useThemeWithState(themeStateProps);
392
+ if (process.env.NODE_ENV === "development" && time) time`theme`;
393
+ elementType = element || elementType;
394
+ const isStringElement = typeof elementType === "string";
395
+ const mediaState = useMedia(componentContext, debugProp);
396
+ setDidGetVariableValue(false);
397
+ if (process.env.NODE_ENV === "development" && time) time`media`;
398
+ const styleProps = {
399
+ mediaState,
400
+ noClass,
401
+ resolveValues: isAnimated && inputStyle !== "css" || isHOC && state.unmounted == false && hasAnimationProp ? "value" : "auto",
402
+ isExiting,
403
+ isAnimated,
404
+ willBeAnimated,
405
+ styledContext: styledContextValue
406
+ };
407
+ const themeName = themeState?.name || "";
408
+ if (process.env.NODE_ENV === "development" && time) time`split-styles-prepare`;
409
+ const splitStyles = useSplitStyles(props, staticConfig, theme, themeName, state, styleProps, null, componentContext, allGroupContexts, elementType, startedUnhydrated, debugProp, animationDriver);
410
+ const isPassthrough = !splitStyles;
411
+ let contextForOverride = staticConfig.context;
412
+ if (splitStyles?.overriddenContextProps) {
413
+ const contextForProps = staticConfig.context || staticConfig.parentStaticConfig?.context;
414
+ if (contextForProps) {
415
+ for (const key in splitStyles.overriddenContextProps) {
416
+ overriddenContextProps = overriddenContextProps || {};
417
+ overriddenContextProps[key] = splitStyles.overriddenContextProps[key];
306
418
  }
419
+ if (!staticConfig.context) contextForOverride = contextForProps;
307
420
  }
308
- const groupContext = groupName && allGroupContexts?.[groupName] || null;
309
- if (!isPassthrough && groupContext &&
310
- // avoids onLayout if we don't need it
311
- props.containerType !== "normal") {
312
- const groupState = groupContext?.state;
313
- groupState && groupState.layout === void 0 && (splitStyles.style?.width || splitStyles.style?.height) && (groupState.layout = {
421
+ }
422
+ const groupContext = groupName ? allGroupContexts?.[groupName] || null : null;
423
+ if (!isPassthrough && groupContext && props.containerType !== "normal") {
424
+ const groupState = groupContext?.state;
425
+ if (groupState && groupState.layout === void 0) {
426
+ if (splitStyles.style?.width || splitStyles.style?.height) groupState.layout = {
314
427
  width: fromPx(splitStyles.style.width),
315
428
  height: fromPx(splitStyles.style.height)
316
- });
429
+ };
317
430
  }
318
- if (!isPassthrough && (hasAnimationProp || groupName) && animationDriver?.avoidReRenders) {
319
- let updateGroupListeners = function () {
320
- const updatedState = stateRef.current.nextState;
321
- if (groupContext) {
322
- const {
323
- group,
324
- hasDynGroupChildren,
325
- unmounted,
326
- transition,
327
- ...childrenGroupState
328
- } = updatedState;
329
- notifyGroupSubscribers(groupContext, stateRef.current.group || null, childrenGroupState);
330
- }
431
+ }
432
+ const hasEnterExitTransition = props.transition && typeof props.transition === "object" && !Array.isArray(props.transition) && ("enter" in props.transition || "exit" in props.transition);
433
+ if (!isPassthrough && (hasAnimationProp || groupName) && animationDriver?.avoidReRenders && !hasEnterExitTransition) {
434
+ let updateGroupListeners = function () {
435
+ const updatedState = stateRef.current.nextState;
436
+ if (groupContext) {
437
+ const {
438
+ group,
439
+ hasDynGroupChildren,
440
+ unmounted,
441
+ transition,
442
+ ...childrenGroupState
443
+ } = updatedState;
444
+ notifyGroupSubscribers(groupContext, stateRef.current.group || null, childrenGroupState);
445
+ }
446
+ };
447
+ const ogSetStateShallow = setStateShallow;
448
+ stateRef.current.updateStyleListener = () => {
449
+ const useStyleListener = stateRef.current.useStyleListener;
450
+ if (!useStyleListener) {
451
+ const pendingState = stateRef.current.nextState;
452
+ if (pendingState) ogSetStateShallow(pendingState);
453
+ return;
454
+ }
455
+ const updatedState = stateRef.current.nextState || state;
456
+ const mediaState2 = stateRef.current.nextMedia;
457
+ const nextStyles = getSplitStyles(props, staticConfig, theme, themeName, updatedState, mediaState2 ? {
458
+ ...styleProps,
459
+ mediaState: mediaState2
460
+ } : styleProps, null, componentContext, allGroupContexts, elementType, startedUnhydrated, debugProp, animationDriver);
461
+ const effectiveTransition = resolveEffectivePseudoTransition(stateRef.current.prevPseudoState, updatedState, nextStyles?.pseudoTransitions, props.transition);
462
+ stateRef.current.prevPseudoState = extractPseudoState(updatedState);
463
+ useStyleListener(nextStyles?.style || {}, effectiveTransition);
464
+ };
465
+ componentContext.mediaEmitListeners = componentContext.mediaEmitListeners || /* @__PURE__ */new Set();
466
+ if (!stateRef.current.mediaEmitCleanup) {
467
+ const updateListener = next => {
468
+ stateRef.current.nextMedia = next;
469
+ stateRef.current.updateStyleListener?.();
470
+ };
471
+ componentContext.mediaEmitListeners.add(updateListener);
472
+ stateRef.current.mediaEmitCleanup = () => {
473
+ componentContext.mediaEmitListeners?.delete(updateListener);
331
474
  };
332
- const ogSetStateShallow = setStateShallow;
333
- if (stateRef.current.updateStyleListener = () => {
334
- const useStyleListener = stateRef.current.useStyleListener;
335
- if (!useStyleListener) {
336
- const pendingState = stateRef.current.nextState;
337
- pendingState && (stateRef.current.nextState = void 0, ogSetStateShallow(pendingState));
338
- return;
475
+ }
476
+ componentContext.mediaEmit = componentContext.mediaEmit || (next => {
477
+ for (const listener of componentContext.mediaEmitListeners) listener(next);
478
+ });
479
+ stateRef.current.setStateShallow = nextOrGetNext => {
480
+ const prev = stateRef.current.nextState || state;
481
+ const next = typeof nextOrGetNext === "function" ? nextOrGetNext(prev) : nextOrGetNext;
482
+ if (next === prev || isEqualShallow(prev, next)) return;
483
+ const canAvoidReRender = Object.keys(next).every(key => avoidReRenderKeys.has(key));
484
+ const updatedState = {
485
+ ...prev,
486
+ ...next
487
+ };
488
+ stateRef.current.nextState = updatedState;
489
+ if (canAvoidReRender) {
490
+ if (process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile") {
491
+ console.groupCollapsed(`[\u26A1\uFE0F] avoid setState`, componentName, next, {
492
+ updatedState,
493
+ props
494
+ });
495
+ console.info(stateRef.current.host);
496
+ console.groupEnd();
339
497
  }
340
- const updatedState = stateRef.current.nextState || state,
341
- mediaState2 = stateRef.current.nextMedia,
342
- nextStyles = getSplitStyles(props, staticConfig, theme, themeName, updatedState, mediaState2 ? {
343
- ...styleProps,
344
- mediaState: mediaState2
345
- } : styleProps, null, componentContext, allGroupContexts, elementType, startedUnhydrated, debugProp);
346
- useStyleListener(nextStyles?.style || {});
347
- }, componentContext.mediaEmitListeners ||= /* @__PURE__ */new Set(), !stateRef.current.mediaEmitCleanup) {
348
- const updateListener = next => {
349
- stateRef.current.nextMedia = next, stateRef.current.updateStyleListener?.();
350
- };
351
- componentContext.mediaEmitListeners.add(updateListener), stateRef.current.mediaEmitCleanup = () => {
352
- componentContext.mediaEmitListeners?.delete(updateListener);
353
- };
354
- }
355
- componentContext.mediaEmit ||= next => {
356
- for (const listener of componentContext.mediaEmitListeners) listener(next);
357
- }, stateRef.current.setStateShallow = nextOrGetNext => {
358
- const prev = stateRef.current.nextState || state,
359
- next = typeof nextOrGetNext == "function" ? nextOrGetNext(prev) : nextOrGetNext;
360
- if (next === prev || isEqualShallow(prev, next)) return;
361
- const canAvoidReRender = Object.keys(next).every(key => avoidReRenderKeys.has(key)),
362
- updatedState = {
363
- ...prev,
364
- ...next
365
- };
366
- stateRef.current.nextState = updatedState, canAvoidReRender ? (process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile" && (console.groupCollapsed("[\u26A1\uFE0F] avoid setState", componentName, next, {
367
- updatedState,
368
- props
369
- }), console.info(stateRef.current.host), console.groupEnd()), updateGroupListeners(), stateRef.current.updateStyleListener?.()) : (process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile" && console.info("[\u{1F40C}] re-render", {
498
+ updateGroupListeners();
499
+ stateRef.current.updateStyleListener?.();
500
+ } else {
501
+ if (process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile") console.info(`[\u{1F40C}] re-render`, {
370
502
  canAvoidReRender,
371
503
  next
372
- }), ogSetStateShallow(next));
373
- }, setStateShallow = state2 => {
374
- stateRef.current.setStateShallow?.(state2);
375
- };
376
- }
377
- process.env.NODE_ENV === "development" && time && time`split-styles`, splitStyles && (props.group && props.untilMeasured === "hide" && !stateRef.current.hasMeasured && (splitStyles.style ||= {}, splitStyles.style.opacity = 0), splitStyles.dynamicThemeAccess != null && (stateRef.current.isListeningToTheme = splitStyles.dynamicThemeAccess));
378
- const hasRuntimeMediaKeys = splitStyles?.hasMedia && splitStyles.hasMedia !== !0,
379
- shouldListenForMedia = didGetVariableValue() || hasRuntimeMediaKeys || noClass && splitStyles?.hasMedia === !0,
380
- mediaListeningKeys = hasRuntimeMediaKeys ? splitStyles.hasMedia : null;
381
- process.env.NODE_ENV === "development" && debugProp === "verbose" && console.info("useMedia() createComponent", shouldListenForMedia, mediaListeningKeys), setMediaShouldUpdate(componentContext, shouldListenForMedia, mediaListeningKeys);
382
- const {
383
- viewProps: viewPropsIn,
384
- pseudos,
385
- style: splitStylesStyle,
386
- classNames,
387
- pseudoGroups,
388
- mediaGroups
389
- } = splitStyles || {},
390
- propsWithAnimation = props,
391
- {
392
- asChild,
393
- children,
394
- themeShallow,
395
- spaceDirection: _spaceDirection,
396
- onPress,
397
- onLongPress,
398
- onPressIn,
399
- onPressOut,
400
- onHoverIn,
401
- onHoverOut,
402
- onMouseUp,
403
- onMouseDown,
404
- onMouseEnter,
405
- onMouseLeave,
406
- onFocus,
407
- onBlur,
408
- separator,
409
- // ignore from here on out
410
- passThrough,
411
- forceStyle: _forceStyle,
412
- // @ts-ignore for next/link compat etc
413
- onClick,
414
- theme: _themeProp,
415
- ...nonTamaguiProps
416
- } = viewPropsIn || {};
417
- let viewProps = nonTamaguiProps;
418
- !isTaggable && props.forceStyle && (viewProps.forceStyle = props.forceStyle), isHOC && (typeof _themeProp < "u" && (viewProps.theme = _themeProp), typeof passThrough < "u" && (viewProps.passThrough = passThrough)), renderProp && elementType.acceptTagProp && (viewProps.render = renderProp);
419
- let animationStyles;
420
- const shouldUseAnimation =
421
- // if it supports css vars we run it on server too to get matching initial style
422
- (supportsCSS ? willBeAnimatedClient : willBeAnimated) && useAnimations && !isHOC;
423
- let animatedRef;
424
- if (shouldUseAnimation) {
425
- const useStyleEmitter = animationDriver?.avoidReRenders ? listener => {
426
- stateRef.current.useStyleListener = listener;
427
- } : void 0,
428
- animations = useAnimations({
429
- props: propsWithAnimation,
430
- // if hydrating, send empty style
431
- style: splitStylesStyle || {},
432
- // @ts-ignore
433
- styleState: splitStyles,
434
- useStyleEmitter,
435
- presence,
436
- componentState: state,
437
- styleProps,
438
- theme,
439
- themeName,
440
- pseudos: pseudos || null,
441
- staticConfig,
442
- stateRef
443
504
  });
444
- animations && (animations.ref && (animatedRef = animations.ref), isHydrated && animations && (animationStyles = animations.style, viewProps.style = animationStyles, animations.className && (viewProps.className = `${state.unmounted === "should-enter" ? "t_unmounted " : ""}${viewProps.className || ""} ${animations.className}`))), process.env.NODE_ENV === "development" && time && time`animations`;
505
+ ogSetStateShallow(next);
506
+ }
507
+ };
508
+ setStateShallow = state2 => {
509
+ stateRef.current.setStateShallow?.(state2);
510
+ };
511
+ }
512
+ if (process.env.NODE_ENV === "development" && time) time`split-styles`;
513
+ if (splitStyles) {
514
+ if (props.group && props.untilMeasured === "hide" && !stateRef.current.hasMeasured) {
515
+ splitStyles.style = splitStyles.style || {};
516
+ splitStyles.style.opacity = 0;
517
+ }
518
+ if (splitStyles.dynamicThemeAccess != null) stateRef.current.isListeningToTheme = splitStyles.dynamicThemeAccess;
519
+ }
520
+ const hasRuntimeMediaKeys = splitStyles?.hasMedia && splitStyles.hasMedia !== true;
521
+ const shouldListenForMedia = didGetVariableValue() || hasRuntimeMediaKeys || noClass && splitStyles?.hasMedia === true;
522
+ const mediaListeningKeys = hasRuntimeMediaKeys ? splitStyles.hasMedia : null;
523
+ if (process.env.NODE_ENV === "development" && debugProp === "verbose") console.info(`useMedia() createComponent`, shouldListenForMedia, mediaListeningKeys);
524
+ setMediaShouldUpdate(componentContext, shouldListenForMedia, mediaListeningKeys);
525
+ const {
526
+ viewProps: viewPropsIn,
527
+ pseudos,
528
+ style: splitStylesStyle,
529
+ classNames,
530
+ pseudoGroups,
531
+ mediaGroups
532
+ } = splitStyles || {};
533
+ const propsWithAnimation = props;
534
+ const {
535
+ asChild,
536
+ children,
537
+ themeShallow,
538
+ spaceDirection: _spaceDirection,
539
+ onPress,
540
+ onLongPress,
541
+ onPressIn,
542
+ onPressOut,
543
+ onHoverIn,
544
+ onHoverOut,
545
+ onMouseUp,
546
+ onMouseDown,
547
+ onMouseEnter,
548
+ onMouseLeave,
549
+ onFocus,
550
+ onBlur,
551
+ separator,
552
+ passThrough,
553
+ forceStyle: _forceStyle,
554
+ onClick,
555
+ theme: _themeProp,
556
+ ...nonTamaguiProps
557
+ } = viewPropsIn || {};
558
+ let viewProps = nonTamaguiProps;
559
+ if (props.forceStyle) viewProps.forceStyle = props.forceStyle;
560
+ if (isHOC) {
561
+ if (typeof _themeProp !== "undefined") viewProps.theme = _themeProp;
562
+ if (typeof passThrough !== "undefined") viewProps.passThrough = passThrough;
563
+ }
564
+ let animationStyles;
565
+ const shouldUseAnimation = (inputStyle === "css" ? willBeAnimatedClient : willBeAnimated) && useAnimations && !isHOC;
566
+ let animatedRef;
567
+ if (shouldUseAnimation) {
568
+ const useStyleEmitter = animationDriver?.avoidReRenders ? listener => {
569
+ stateRef.current.useStyleListener = listener;
570
+ } : void 0;
571
+ const effectiveTransition = resolveEffectivePseudoTransition(stateRef.current.prevPseudoState, state, splitStyles?.pseudoTransitions, props.transition);
572
+ if (splitStyles) splitStyles.effectiveTransition = effectiveTransition;
573
+ stateRef.current.prevPseudoState = extractPseudoState(state);
574
+ const animations = useAnimations({
575
+ props: propsWithAnimation,
576
+ style: isHydrated ? splitStylesStyle || {} : {
577
+ ...splitStylesStyle
578
+ },
579
+ styleState: splitStyles,
580
+ useStyleEmitter,
581
+ presence,
582
+ componentState: state,
583
+ styleProps,
584
+ theme,
585
+ themeName,
586
+ pseudos: pseudos || null,
587
+ staticConfig,
588
+ stateRef
589
+ });
590
+ if (animations) {
591
+ if (animations.ref) animatedRef = animations.ref;
592
+ if (isHydrated && animations) {
593
+ animationStyles = animations.style;
594
+ viewProps.style = animationStyles;
595
+ if (animations.className) viewProps.className = `${state.unmounted === "should-enter" ? "t_unmounted " : ""}${viewProps.className || ""} ${animations.className}`;
596
+ }
445
597
  }
446
- process.env.NODE_ENV === "development" && props.untilMeasured && !props.group && console.warn(`You set the untilMeasured prop without setting group. This doesn't work, be sure to set untilMeasured on the parent that sets group, not the children that use the $group- prop.
598
+ if (process.env.NODE_ENV === "development" && time) time`animations`;
599
+ }
600
+ if (process.env.NODE_ENV === "development" && props.untilMeasured && !props.group) console.warn(`You set the untilMeasured prop without setting group. This doesn't work, be sure to set untilMeasured on the parent that sets group, not the children that use the $group- prop.
447
601
 
448
- If you meant to do this, you can disable this warning - either change untilMeasured and group at the same time, or do group={conditional ? 'name' : undefined}`), process.env.NODE_ENV === "development" && time && time`destructure`, !isPassthrough && groupContext &&
449
- // avoids onLayout if we don't need it
450
- props.containerType !== "normal" && (nonTamaguiProps.onLayout = composeEventHandlers(nonTamaguiProps.onLayout, e => {
451
- const layout = e.nativeEvent.layout;
452
- groupContext.state.layout = layout, stateRef.current.group?.emit({
453
- layout
454
- }), !stateRef.current.hasMeasured && props.untilMeasured === "hide" && setState(prev => ({
455
- ...prev
456
- })), stateRef.current.hasMeasured = !0;
457
- })), viewProps = hooks.usePropsTransform?.(elementType, nonTamaguiProps, stateRef, stateRef.current.willHydrate) || nonTamaguiProps, stateRef.current.composedRef || (stateRef.current.composedRef = composeRefs(x => stateRef.current.host = x, forwardedRef, setElementProps, animatedRef)), viewProps.ref = stateRef.current.composedRef, usePointerEvents(props, viewProps), process.env.NODE_ENV === "development" && !isReactNative && !isText && isWeb && !isHOC && React.Children.toArray(props.children).forEach(item => {
458
- typeof item == "string" && item !== `
459
- ` && console.error(`Unexpected text node: ${item}. A text node cannot be a child of a <${staticConfig.componentName || propsIn.tag || "View"}>.`, props);
460
- }), process.env.NODE_ENV === "development" && time && time`events-hooks`;
461
- const unPress = () => {
602
+ If you meant to do this, you can disable this warning - either change untilMeasured and group at the same time, or do group={conditional ? 'name' : undefined}`);
603
+ if (process.env.NODE_ENV === "development" && time) time`destructure`;
604
+ if (!isPassthrough && groupContext && props.containerType !== "normal") nonTamaguiProps.onLayout = composeEventHandlers(nonTamaguiProps.onLayout, e => {
605
+ const layout = e.nativeEvent.layout;
606
+ groupContext.state.layout = layout;
607
+ stateRef.current.group?.emit({
608
+ layout
609
+ });
610
+ if (!stateRef.current.hasMeasured && props.untilMeasured === "hide") setState(prev => ({
611
+ ...prev
612
+ }));
613
+ stateRef.current.hasMeasured = true;
614
+ });
615
+ viewProps = hooks.usePropsTransform?.(elementType, nonTamaguiProps, stateRef, stateRef.current.willHydrate) || nonTamaguiProps;
616
+ if (!stateRef.current.composedRef) stateRef.current.composedRef = composeRefs(x => stateRef.current.host = x, forwardedRef, setElementProps, animatedRef);
617
+ viewProps.ref = stateRef.current.composedRef;
618
+ usePointerEvents(props, viewProps);
619
+ if (process.env.NODE_ENV === "development") {
620
+ if (!isReactNative && !isText && isWeb && !isHOC) React.Children.toArray(props.children).forEach(item => {
621
+ if (typeof item === "string" && item !== "\n") console.error(`Unexpected text node: ${item}. A text node cannot be a child of a <${staticConfig.componentName || propsIn.tag || "View"}>.`, props);
622
+ });
623
+ }
624
+ if (process.env.NODE_ENV === "development" && time) time`events-hooks`;
625
+ const unPress = () => {
626
+ setStateShallow({
627
+ press: false,
628
+ pressIn: false
629
+ });
630
+ };
631
+ if (process.env.NODE_ENV === "development" && isWeb) useIsomorphicLayoutEffect(() => {
632
+ if (debugProp === "verbose") {
633
+ let cssStyleDeclarationToObject = function (style) {
634
+ const styleObject = {};
635
+ for (let i = 0; i < style.length; i++) {
636
+ let prop = style[i];
637
+ styleObject[prop] = style.getPropertyValue(prop);
638
+ }
639
+ return styleObject;
640
+ };
641
+ const computed = stateRef.current.host ? cssStyleDeclarationToObject(getComputedStyle(stateRef.current.host)) : {};
642
+ console.groupCollapsed(`Rendered > (opacity: ${computed.opacity})`);
643
+ console.warn(stateRef.current.host);
644
+ console.warn(computed);
645
+ console.groupEnd();
646
+ }
647
+ });
648
+ useIsomorphicLayoutEffect(() => {
649
+ if (state.unmounted === true && hasEnterStyle) {
462
650
  setStateShallow({
463
- press: !1,
464
- pressIn: !1
651
+ unmounted: "should-enter"
465
652
  });
466
- };
467
- process.env.NODE_ENV === "development" && isWeb && useIsomorphicLayoutEffect(() => {
468
- if (debugProp === "verbose") {
469
- let cssStyleDeclarationToObject = function (style) {
470
- const styleObject = {};
471
- for (let i = 0; i < style.length; i++) {
472
- let prop = style[i];
473
- styleObject[prop] = style.getPropertyValue(prop);
474
- }
475
- return styleObject;
476
- };
477
- const computed = stateRef.current.host ? cssStyleDeclarationToObject(getComputedStyle(stateRef.current.host)) : {};
478
- console.groupCollapsed(`Rendered > (opacity: ${computed.opacity})`), console.warn(stateRef.current.host), console.warn(computed), console.groupEnd();
479
- }
480
- }), useIsomorphicLayoutEffect(() => {
481
- if (state.unmounted === !0 && hasEnterStyle) {
482
- setStateShallow({
483
- unmounted: "should-enter"
484
- });
485
- return;
486
- }
487
- if (state.unmounted) {
488
- if (supportsCSS) {
489
- let cancelled = !1;
490
- return requestAnimationFrame(() => {
491
- cancelled || requestAnimationFrame(() => {
492
- cancelled || setStateShallow({
493
- unmounted: !1
494
- });
653
+ return;
654
+ }
655
+ if (state.unmounted) {
656
+ if (inputStyle === "css") {
657
+ let cancelled = false;
658
+ requestAnimationFrame(() => {
659
+ if (cancelled) return;
660
+ requestAnimationFrame(() => {
661
+ if (cancelled) return;
662
+ setStateShallow({
663
+ unmounted: false
495
664
  });
496
- }), () => {
497
- cancelled = !0;
498
- };
499
- }
500
- setStateShallow({
501
- unmounted: !1
665
+ });
502
666
  });
667
+ return () => {
668
+ cancelled = true;
669
+ };
503
670
  }
504
- return () => {
505
- componentSetStates.delete(setState), stateRef.current.mediaEmitCleanup?.();
506
- };
507
- }, [state.unmounted, supportsCSS]), useIsomorphicLayoutEffect(() => {
508
- if (!disabled && !(!pseudoGroups && !mediaGroups) && allGroupContexts) return subscribeToContextGroup({
509
- groupContext: allGroupContexts,
510
- setStateShallow,
511
- mediaGroups,
512
- pseudoGroups
671
+ setStateShallow({
672
+ unmounted: false
513
673
  });
514
- }, [allGroupContexts, disabled, pseudoGroups ? objectIdentityKey(pseudoGroups) : 0, mediaGroups ? objectIdentityKey(mediaGroups) : 0]);
515
- const groupEmitter = stateRef.current.group;
516
- useIsomorphicLayoutEffect(() => {
517
- !groupContext || !groupEmitter || notifyGroupSubscribers(groupContext, groupEmitter, state);
518
- }, [groupContext, groupEmitter, state]);
519
- const runtimePressStyle = !disabled && noClass && pseudos?.pressStyle,
520
- runtimeFocusStyle = !disabled && noClass && pseudos?.focusStyle,
521
- runtimeFocusVisibleStyle = !disabled && noClass && pseudos?.focusVisibleStyle,
522
- attachFocus = !!(runtimePressStyle || runtimeFocusStyle || runtimeFocusVisibleStyle || onFocus || onBlur || componentContext.setParentFocusState),
523
- hasDynamicGroupChildren = !!(groupName && state.hasDynGroupChildren),
524
- attachPress = !!(hasDynamicGroupChildren || runtimePressStyle || onPress || onPressOut || onPressIn || onMouseDown || onMouseUp || onLongPress || onClick || pseudos?.focusVisibleStyle),
525
- runtimeHoverStyle = !disabled && noClass && pseudos?.hoverStyle,
526
- needsHoverState = !!(hasDynamicGroupChildren || runtimeHoverStyle),
527
- attachHover = isWeb && !!(hasDynamicGroupChildren || needsHoverState || onMouseEnter || onMouseLeave),
528
- shouldAttach = !disabled && !props.asChild && !!(attachFocus || attachPress || attachHover || runtimePressStyle || runtimeHoverStyle || runtimeFocusStyle),
529
- needsPressState = !!(hasDynamicGroupChildren || runtimePressStyle);
530
- process.env.NODE_ENV === "development" && time && time`events-setup`, process.env.NODE_ENV === "development" && debugProp === "verbose" && log("\u{1FAA9} events()", {
531
- runtimeFocusStyle,
532
- runtimePressStyle,
533
- runtimeHoverStyle,
534
- runtimeFocusVisibleStyle,
535
- attachPress,
536
- attachFocus,
537
- attachHover,
538
- shouldAttach,
539
- needsHoverState,
540
- pseudos
674
+ }
675
+ return () => {
676
+ componentSetStates.delete(setState);
677
+ stateRef.current.mediaEmitCleanup?.();
678
+ };
679
+ }, [state.unmounted, inputStyle]);
680
+ useIsomorphicLayoutEffect(() => {
681
+ if (disabled) return;
682
+ if (!pseudoGroups && !mediaGroups) return;
683
+ if (!allGroupContexts) return;
684
+ return subscribeToContextGroup({
685
+ groupContext: allGroupContexts,
686
+ setStateShallow,
687
+ mediaGroups,
688
+ pseudoGroups
541
689
  });
542
- const events = shouldAttach ? {
543
- onPressOut: attachPress ? e => {
544
- unPress(), onPressOut?.(e), onMouseUp?.(e);
545
- } : void 0,
546
- ...((attachHover || attachPress) && {
547
- onMouseEnter: e => {
548
- const next = {};
549
- needsHoverState && !lastInteractionWasTouch.value && (next.hover = !0), needsPressState && state.pressIn && (next.press = !0), setStateShallow(next), onHoverIn?.(e), onMouseEnter?.(e);
550
- },
551
- onMouseLeave: e => {
552
- const next = {};
553
- needsHoverState && (next.hover = !1), needsPressState && (next.press = !1, next.pressIn = !1), setStateShallow(next), onHoverOut?.(e), onMouseLeave?.(e);
690
+ }, [allGroupContexts, disabled, pseudoGroups ? objectIdentityKey(pseudoGroups) : 0, mediaGroups ? objectIdentityKey(mediaGroups) : 0]);
691
+ const groupEmitter = stateRef.current.group;
692
+ useIsomorphicLayoutEffect(() => {
693
+ if (!groupContext || !groupEmitter) return;
694
+ notifyGroupSubscribers(groupContext, groupEmitter, state);
695
+ }, [groupContext, groupEmitter, state]);
696
+ const runtimePressStyle = !disabled && noClass && pseudos?.pressStyle;
697
+ const runtimeFocusStyle = !disabled && noClass && pseudos?.focusStyle;
698
+ const runtimeFocusVisibleStyle = !disabled && noClass && pseudos?.focusVisibleStyle;
699
+ const attachFocus = Boolean(runtimePressStyle || runtimeFocusStyle || runtimeFocusVisibleStyle || onFocus || onBlur || !!componentContext.setParentFocusState);
700
+ const hasDynamicGroupChildren = Boolean(groupName && state.hasDynGroupChildren);
701
+ const attachPress = Boolean(hasDynamicGroupChildren || runtimePressStyle || onPress || onPressOut || onPressIn || onMouseDown || onMouseUp || onLongPress || onClick || pseudos?.focusVisibleStyle);
702
+ const runtimeHoverStyle = !disabled && noClass && pseudos?.hoverStyle;
703
+ const needsHoverState = Boolean(hasDynamicGroupChildren || runtimeHoverStyle);
704
+ const attachHover = isWeb && !!(hasDynamicGroupChildren || needsHoverState || onMouseEnter || onMouseLeave);
705
+ const shouldAttach = !disabled && !props.asChild && Boolean(attachFocus || attachPress || attachHover || runtimePressStyle || runtimeHoverStyle || runtimeFocusStyle);
706
+ const needsPressState = Boolean(hasDynamicGroupChildren || runtimePressStyle);
707
+ if (process.env.NODE_ENV === "development" && time) time`events-setup`;
708
+ if (process.env.NODE_ENV === "development" && debugProp === "verbose") log(`\u{1FAA9} events()`, {
709
+ runtimeFocusStyle,
710
+ runtimePressStyle,
711
+ runtimeHoverStyle,
712
+ runtimeFocusVisibleStyle,
713
+ attachPress,
714
+ attachFocus,
715
+ attachHover,
716
+ shouldAttach,
717
+ needsHoverState,
718
+ pseudos
719
+ });
720
+ const events = shouldAttach ? {
721
+ onPressOut: attachPress ? e => {
722
+ unPress();
723
+ onPressOut?.(e);
724
+ onMouseUp?.(e);
725
+ } : void 0,
726
+ ...((attachHover || attachPress) && {
727
+ onMouseEnter: e => {
728
+ const next = {};
729
+ if (needsHoverState && !lastInteractionWasTouch.value) next.hover = true;
730
+ if (needsPressState) {
731
+ if (state.pressIn) next.press = true;
554
732
  }
555
- }),
556
- onPressIn: attachPress ? e => {
557
- needsPressState && setStateShallow({
558
- press: !0,
559
- pressIn: !0
560
- }), onPressIn?.(e), onMouseDown?.(e), isWeb && componentSetStates.add(setState);
561
- } : void 0,
562
- onPress: attachPress ? e => {
563
- unPress(), isWeb && onClick?.(e), onPress?.(e), onLongPress?.(e);
564
- } : void 0,
565
- ...(attachFocus && {
566
- onFocus: e => {
567
- const next = {};
568
- componentContext.setParentFocusState && (next.focusWithin = !0), pseudos?.focusVisibleStyle && lastInteractionWasKeyboard.value ? next.focusVisible = !0 : next.focus = !0, setStateShallow(next), onFocus?.(e);
569
- },
570
- onBlur: e => {
571
- componentContext.setParentFocusState && componentContext.setParentFocusState({
572
- focusWithin: !1
573
- }), setStateShallow({
574
- focus: !1,
575
- focusVisible: !1,
576
- focusWithin: !1
577
- }), onBlur?.(e);
733
+ setStateShallow(next);
734
+ onHoverIn?.(e);
735
+ onMouseEnter?.(e);
736
+ },
737
+ onMouseLeave: e => {
738
+ const next = {};
739
+ if (needsHoverState) next.hover = false;
740
+ if (needsPressState) {
741
+ next.press = false;
742
+ next.pressIn = false;
578
743
  }
579
- })
580
- } : null;
581
- events && !isReactNative && Object.assign(viewProps, getWebEvents(events)), process.env.NODE_ENV === "development" && time && time`events`, process.env.NODE_ENV === "development" && debugProp === "verbose" && log("events", {
582
- events,
583
- attachHover,
584
- attachPress
585
- });
586
- const pressGesture = null;
587
- process.env.NODE_ENV === "development" && time && time`hooks`;
588
- let content = children;
589
- if (asChild) {
590
- elementType = Slot;
591
- {
592
- const passEvents = getWebEvents({
593
- onPress,
594
- onLongPress,
595
- onPressIn,
596
- onPressOut,
597
- onMouseUp,
598
- onMouseDown,
599
- onMouseEnter,
600
- onMouseLeave
601
- }, asChild === "web" || asChild === "except-style-web");
602
- Object.assign(viewProps, passEvents);
744
+ setStateShallow(next);
745
+ onHoverOut?.(e);
746
+ onMouseLeave?.(e);
747
+ }
748
+ }),
749
+ onPressIn: attachPress ? e => {
750
+ if (needsPressState) setStateShallow({
751
+ press: true,
752
+ pressIn: true
753
+ });
754
+ onPressIn?.(e);
755
+ onMouseDown?.(e);
756
+ if (isWeb) componentSetStates.add(setState);
757
+ } : void 0,
758
+ onPress: attachPress ? e => {
759
+ unPress();
760
+ onClick?.(e);
761
+ if (onPress || onClick) e.stopPropagation();
762
+ onPress?.(e);
763
+ onLongPress?.(e);
764
+ } : void 0,
765
+ ...(attachFocus && {
766
+ onFocus: e => {
767
+ const next = {};
768
+ if (componentContext.setParentFocusState) {
769
+ componentContext.setParentFocusState({
770
+ focusWithin: true
771
+ });
772
+ next.focusWithin = true;
773
+ }
774
+ if (pseudos?.focusVisibleStyle) {
775
+ if (lastInteractionWasKeyboard.value) next.focusVisible = true;else next.focus = true;
776
+ } else next.focus = true;
777
+ setStateShallow(next);
778
+ onFocus?.(e);
779
+ },
780
+ onBlur: e => {
781
+ if (componentContext.setParentFocusState) componentContext.setParentFocusState({
782
+ focusWithin: false
783
+ });
784
+ setStateShallow({
785
+ focus: false,
786
+ focusVisible: false,
787
+ focusWithin: false
788
+ });
789
+ onBlur?.(e);
603
790
  }
791
+ })
792
+ } : null;
793
+ if (events && !isReactNative) Object.assign(viewProps, getWebEvents(events));
794
+ if (process.env.NODE_ENV === "development" && time) time`events`;
795
+ if (process.env.NODE_ENV === "development" && debugProp === "verbose") log(`events`, {
796
+ events,
797
+ attachHover,
798
+ attachPress
799
+ });
800
+ const propsWithHref = props;
801
+ const propsInWithHref = propsIn;
802
+ [componentName, props.testID ?? propsIn.testID ?? props.accessibilityLabel ?? propsIn.accessibilityLabel ?? (typeof propsWithHref.href === "string" ? propsWithHref.href : null) ?? (typeof propsInWithHref.href === "string" ? propsInWithHref.href : null)].filter(Boolean).join(":");
803
+ if (process.env.NODE_ENV === "development" && time) time`hooks`;
804
+ if (asChild) {
805
+ elementType = Slot;
806
+ {
807
+ const passEvents = getWebEvents({
808
+ onPress,
809
+ onLongPress,
810
+ onPressIn,
811
+ onPressOut,
812
+ onMouseUp,
813
+ onMouseDown,
814
+ onMouseEnter,
815
+ onMouseLeave
816
+ }, asChild === "web" || asChild === "except-style-web");
817
+ Object.assign(viewProps, passEvents);
604
818
  }
605
- process.env.NODE_ENV === "development" && time && time`spaced-as-child`, isPassthrough && (content = propsIn.children, elementType = BaseViewComponent, viewProps = {
606
- style: {
607
- display: "contents"
819
+ }
820
+ if (process.env.NODE_ENV === "development" && time) time`spaced-as-child`;
821
+ let content;
822
+ if (isPassthrough) content = React.createElement(BaseComponent, {
823
+ style: {
824
+ display: "contents"
825
+ }
826
+ }, propsIn.children);else {
827
+ if (hooks.useChildren) content = hooks.useChildren(elementType, content || children, viewProps);
828
+ const isRenderPropString = typeof renderProp === "string";
829
+ if (renderProp && !isRenderPropString) {
830
+ const out = getCustomRender(renderProp, content || children, viewProps, componentState);
831
+ if (out) {
832
+ viewProps = out.viewProps;
833
+ elementType = out.elementType;
608
834
  }
609
- });
610
- let useChildrenResult;
611
- if (hooks.useChildren && (useChildrenResult = hooks.useChildren(elementType, content, viewProps)), process.env.NODE_ENV === "development" && time && time`use-children`, useChildrenResult) content = useChildrenResult;else if (typeof renderProp == "function") {
612
- const renderProps = {
613
- ...viewProps,
614
- children: content
615
- };
616
- content = renderProp(renderProps, state);
617
- } else if (renderProp && typeof renderProp == "object" && React.isValidElement(renderProp)) {
618
- const elementProps = renderProp.props || {},
619
- mergedProps = mergeRenderElementProps(elementProps, viewProps, content);
620
- content = React.cloneElement(renderProp, mergedProps);
621
- } else content = React.createElement(elementType, viewProps, content);
622
- const ResetPresence = animationDriver?.ResetPresence,
623
- needsReset = !!(
624
- // not when passing down to child
625
- !asChild &&
626
- // not when passThrough
627
- splitStyles &&
628
- // not when HOC
629
- !isHOC && ResetPresence && willBeAnimated && (hasEnterStyle || presenceState)),
630
- hasEverReset = stateRef.current.hasEverResetPresence;
631
- if (needsReset && !hasEverReset && (stateRef.current.hasEverResetPresence = !0), (needsReset || hasEverReset) && ResetPresence && (content = /* @__PURE__ */jsx(ResetPresence, {
632
- disabled: !needsReset,
633
- children: content
634
- })), process.env.NODE_ENV === "development" && time && time`create-element`, "focusWithinStyle" in propsIn && (content = /* @__PURE__ */jsx(ComponentContext.Provider, {
635
- ...componentContext,
636
- setParentFocusState: setStateShallow,
637
- children: content
638
- })), "group" in props && (content = /* @__PURE__ */jsx(GroupContext.Provider, {
639
- value: allGroupContexts,
640
- children: content
641
- })), !asChild && isText && !hasTextAncestor && (content = /* @__PURE__ */jsx(ComponentContext.Provider, {
642
- ...componentContext,
643
- inText: !0,
644
- children: content
645
- })), process.env.NODE_ENV === "development" && time && time`group-context`, content = disableTheme || !splitStyles ? content : getThemedChildren(themeState, content, themeStateProps, !1, stateRef), process.env.NODE_ENV === "development" && time && time`themed-children`, isReactNative && !asChild && (content = /* @__PURE__ */jsx("span", {
646
- className: "_dsp_contents",
647
- ...(!isPassthrough && isHydrated && events && getWebEvents(events)),
648
- children: content
649
- })), overriddenContextProps && contextForOverride) {
650
- const Provider = contextForOverride.Provider;
651
- for (const key in styledContextValue) key in overriddenContextProps || (overriddenContextProps[key] = styledContextValue[key]);
652
- content = /* @__PURE__ */jsx(Provider, {
653
- __disableMergeDefaultValues: !0,
654
- ...overriddenContextProps,
655
- children: content
656
- });
657
835
  }
658
- if (process.env.NODE_ENV === "development" && time && time`context-override`, startedUnhydrated && splitStyles && (content = /* @__PURE__ */jsxs(Fragment, {
659
- children: [content, isHydrated ? null : getStyleTags(Object.values(splitStyles.rulesToInsert))]
660
- })), process.env.NODE_ENV === "development" && time && time`style-tags`, process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile") {
661
- const title = `render <${typeof elementType == "string" ? elementType : "Component"} /> (${internalID}) with props`;
836
+ if (!content) {
837
+ if (isRenderPropString) viewProps.render;
838
+ content = React.createElement(elementType, viewProps, content || children);
839
+ }
840
+ if (process.env.NODE_ENV === "development" && time) time`use-children`;
841
+ }
842
+ const ResetPresence = animationDriver?.ResetPresence;
843
+ const needsReset = Boolean(
844
+ // not when passing down to child
845
+ !asChild && splitStyles && !isHOC && ResetPresence && willBeAnimated && (hasEnterStyle || presenceState));
846
+ const hasEverReset = stateRef.current.hasEverResetPresence;
847
+ if (needsReset && !hasEverReset) stateRef.current.hasEverResetPresence = true;
848
+ if ((needsReset || hasEverReset) && ResetPresence) content = /* @__PURE__ */jsx(ResetPresence, {
849
+ disabled: !needsReset,
850
+ children: content
851
+ });
852
+ if (process.env.NODE_ENV === "development" && time) time`create-element`;
853
+ if ("focusWithinStyle" in propsIn || pseudos?.focusWithinStyle) content = /* @__PURE__ */jsx(ComponentContext.Provider, {
854
+ ...componentContext,
855
+ setParentFocusState: setStateShallow,
856
+ children: content
857
+ });
858
+ if ("group" in props) content = /* @__PURE__ */jsx(GroupContext.Provider, {
859
+ value: allGroupContexts,
860
+ children: content
861
+ });
862
+ if (!asChild && isText && !hasTextAncestor) content = /* @__PURE__ */jsx(ComponentContext.Provider, {
863
+ ...componentContext,
864
+ inText: true,
865
+ children: content
866
+ });
867
+ if (process.env.NODE_ENV === "development" && time) time`group-context`;
868
+ content = disableTheme || !splitStyles ? content : getThemedChildren(themeState, content, themeStateProps, false, stateRef);
869
+ if (process.env.NODE_ENV === "development" && time) time`themed-children`;
870
+ if (isReactNative && !asChild) content = /* @__PURE__ */jsx("span", {
871
+ className: "_dsp_contents",
872
+ ...(!isPassthrough && isHydrated && events && getWebEvents(events)),
873
+ children: content
874
+ });
875
+ if (overriddenContextProps && contextForOverride) {
876
+ const Provider = contextForOverride.Provider;
877
+ for (const key in styledContextValue) if (!(key in overriddenContextProps)) overriddenContextProps[key] = styledContextValue[key];
878
+ content = /* @__PURE__ */jsx(Provider, {
879
+ __disableMergeDefaultValues: true,
880
+ ...overriddenContextProps,
881
+ children: content
882
+ });
883
+ }
884
+ if (process.env.NODE_ENV === "development" && time) time`context-override`;
885
+ if (startedUnhydrated && splitStyles) content = /* @__PURE__ */jsxs(Fragment, {
886
+ children: [content, !isHydrated ? getStyleTags(Object.values(splitStyles.rulesToInsert)) : null]
887
+ });
888
+ if (process.env.NODE_ENV === "development" && time) time`style-tags`;
889
+ if (process.env.NODE_ENV === "development") {
890
+ if (debugProp && debugProp !== "profile") {
891
+ const title = `render <${typeof elementType === "string" ? elementType : "Component"} /> (${internalID}) with props`;
662
892
  if (!isWeb || !isClient) {
663
- log(title), log("state: ", state), isDevTools && log("viewProps", viewProps), log("final styles:");
893
+ log(title);
894
+ log(`state: `, state);
895
+ if (isDevTools) log("viewProps", viewProps);
896
+ log(`final styles:`);
664
897
  for (const key in splitStylesStyle) log(key, splitStylesStyle[key]);
665
898
  } else {
666
899
  console.groupCollapsed(title);
667
900
  try {
668
- log("viewProps", viewProps), log("children", content), typeof window < "u" && log({
901
+ log("viewProps", viewProps);
902
+ log("children", content);
903
+ if (typeof window !== "undefined") log({
669
904
  propsIn,
670
905
  props,
671
906
  attachPress,
@@ -697,38 +932,78 @@ If you meant to do this, you can disable this warning - either change untilMeasu
697
932
  console.groupEnd();
698
933
  }
699
934
  }
935
+ if (debugProp === "break") {}
700
936
  }
701
- return process.env.NODE_ENV === "development" && time && (time`rest`, globalThis.willPrint || (globalThis.willPrint = !0, setTimeout(() => {
702
- delete globalThis.willPrint, time.print(), time = null;
703
- }, 50))), content;
704
- });
937
+ }
938
+ if (process.env.NODE_ENV === "development" && time) {
939
+ time`rest`;
940
+ if (!globalThis["willPrint"]) {
941
+ globalThis["willPrint"] = true;
942
+ setTimeout(() => {
943
+ delete globalThis["willPrint"];
944
+ time.print();
945
+ time = null;
946
+ }, 50);
947
+ }
948
+ }
949
+ return content;
950
+ });
705
951
  function notifyGroupSubscribers(groupContext, groupEmitter, pseudo) {
706
952
  if (!groupContext || !groupEmitter) return;
707
953
  const nextState = {
708
954
  ...groupContext.state,
709
955
  pseudo
710
956
  };
711
- groupEmitter.emit(nextState), groupContext.state = nextState;
957
+ groupEmitter.emit(nextState);
958
+ groupContext.state = nextState;
712
959
  }
713
- staticConfig.componentName && (component.displayName = staticConfig.componentName);
960
+ if (staticConfig.componentName) component.displayName = staticConfig.componentName;
714
961
  let res = component;
715
- res = React.memo(res), res.staticConfig = staticConfig;
962
+ res = React.memo(res);
963
+ res.staticConfig = staticConfig;
716
964
  function extendStyledConfig(extended) {
717
965
  return {
718
966
  ...staticConfig,
719
967
  ...extended,
720
- neverFlatten: !0,
721
- isHOC: !0,
722
- isStyledHOC: !1
968
+ neverFlatten: true,
969
+ isHOC: true,
970
+ isStyledHOC: false
723
971
  };
724
972
  }
725
973
  function styleable(Component2, options) {
726
- let out = typeof Component2 == "function" && Component2.length === 1 ? Component2 : React.forwardRef(Component2);
974
+ let out = typeof Component2 === "function" && Component2.length === 1 ? Component2 : React.forwardRef(Component2);
727
975
  const extendedConfig = extendStyledConfig(options?.staticConfig);
728
- return out = options?.disableTheme ? out : themeable(out, extendedConfig, !0), (extendedConfig.memo || process.env.TAMAGUI_MEMOIZE_STYLEABLE) && (out = React.memo(out)), out.staticConfig = extendedConfig, out.styleable = styleable, out;
976
+ out = options?.disableTheme ? out : themeable(out, extendedConfig, true);
977
+ if (extendedConfig.memo || process.env.TAMAGUI_MEMOIZE_STYLEABLE) out = React.memo(out);
978
+ out.staticConfig = extendedConfig;
979
+ out.styleable = styleable;
980
+ return out;
981
+ }
982
+ res.styleable = styleable;
983
+ return res;
984
+ }
985
+ const fromPx = val => {
986
+ if (typeof val === "number") return val;
987
+ if (typeof val === "string") return +val.replace("px", "");
988
+ return 0;
989
+ };
990
+ const getCustomRender = (renderProp, content, viewProps, state) => {
991
+ if (typeof renderProp === "function") renderProp = getRenderElementForPlatform(renderProp(viewProps, state));
992
+ if (renderProp) {
993
+ if (typeof renderProp === "object" && React.isValidElement(renderProp)) {
994
+ if (getRenderElementForPlatform(renderProp)) {
995
+ const elementProps = renderProp.props;
996
+ const mergedProps = elementProps ? mergeRenderElementProps(elementProps, viewProps, content) : viewProps;
997
+ return {
998
+ elementType: renderProp.type,
999
+ viewProps: mergedProps
1000
+ };
1001
+ }
1002
+ }
729
1003
  }
730
- return res.styleable = styleable, res;
1004
+ };
1005
+ function getRenderElementForPlatform(potential) {
1006
+ return potential;
731
1007
  }
732
- const fromPx = val => typeof val == "number" ? val : typeof val == "string" ? +val.replace("px", "") : 0;
733
1008
  export { componentSetStates, createComponent };
734
1009
  //# sourceMappingURL=createComponent.mjs.map