@tamagui/web 2.0.0-rc.4 → 2.0.0-rc.40

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