@tamagui/web 2.0.0-rc.3 → 2.0.0-rc.31

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 (930) hide show
  1. package/.turbo/turbo-build.log +2 -0
  2. package/.turbo/turbo-test$colon$web.log +15 -0
  3. package/dist/cjs/Tamagui.cjs +2 -2
  4. package/dist/cjs/Tamagui.native.js +2 -2
  5. package/dist/cjs/Tamagui.native.js.map +1 -1
  6. package/dist/cjs/_withStableStyle.cjs +17 -6
  7. package/dist/cjs/_withStableStyle.native.js +18 -5
  8. package/dist/cjs/_withStableStyle.native.js.map +1 -1
  9. package/dist/cjs/animationDriverTypes.test-d.cjs +11 -0
  10. package/dist/cjs/animationDriverTypes.test-d.native.js +11 -0
  11. package/dist/cjs/animationDriverTypes.test-d.native.js.map +1 -1
  12. package/dist/cjs/config.cjs +5 -1
  13. package/dist/cjs/config.native.js +5 -1
  14. package/dist/cjs/config.native.js.map +1 -1
  15. package/dist/cjs/constants/constants.cjs +2 -16
  16. package/dist/cjs/constants/constants.native.js +1 -14
  17. package/dist/cjs/constants/constants.native.js.map +1 -1
  18. package/dist/cjs/createComponent.cjs +92 -79
  19. package/dist/cjs/createComponent.native.js +112 -88
  20. package/dist/cjs/createComponent.native.js.map +1 -1
  21. package/dist/cjs/createTamagui.cjs +38 -37
  22. package/dist/cjs/createTamagui.native.js +41 -37
  23. package/dist/cjs/createTamagui.native.js.map +1 -1
  24. package/dist/cjs/createVariable.native.js.map +1 -1
  25. package/dist/cjs/eventHandling.cjs +1 -1
  26. package/dist/cjs/eventHandling.native.js +84 -57
  27. package/dist/cjs/eventHandling.native.js.map +1 -1
  28. package/dist/cjs/helpers/createDesignSystem.cjs +44 -7
  29. package/dist/cjs/helpers/createDesignSystem.native.js +36 -6
  30. package/dist/cjs/helpers/createDesignSystem.native.js.map +1 -1
  31. package/dist/cjs/helpers/createMediaStyle.cjs +8 -5
  32. package/dist/cjs/helpers/createMediaStyle.native.js +10 -7
  33. package/dist/cjs/helpers/createMediaStyle.native.js.map +1 -1
  34. package/dist/cjs/helpers/createStyledContext.cjs +11 -7
  35. package/dist/cjs/helpers/createStyledContext.native.js +50 -46
  36. package/dist/cjs/helpers/createStyledContext.native.js.map +1 -1
  37. package/dist/cjs/helpers/defaultAnimationDriver.cjs +0 -2
  38. package/dist/cjs/helpers/defaultAnimationDriver.native.js +0 -2
  39. package/dist/cjs/helpers/defaultAnimationDriver.native.js.map +1 -1
  40. package/dist/cjs/helpers/expandStyle.cjs +2 -1
  41. package/dist/cjs/helpers/expandStyle.native.js +9 -0
  42. package/dist/cjs/helpers/expandStyle.native.js.map +1 -1
  43. package/dist/cjs/helpers/getCSSStylesAtomic.cjs +8 -8
  44. package/dist/cjs/helpers/getDefaultProps.cjs +3 -9
  45. package/dist/cjs/helpers/getDefaultProps.native.js +3 -4
  46. package/dist/cjs/helpers/getDefaultProps.native.js.map +1 -1
  47. package/dist/cjs/helpers/getGroupPropParts.cjs +2 -2
  48. package/dist/cjs/helpers/getGroupPropParts.native.js +2 -2
  49. package/dist/cjs/helpers/getGroupPropParts.native.js.map +1 -1
  50. package/dist/cjs/helpers/getSplitStyles.cjs +59 -28
  51. package/dist/cjs/helpers/getSplitStyles.native.js +114 -77
  52. package/dist/cjs/helpers/getSplitStyles.native.js.map +1 -1
  53. package/dist/cjs/helpers/getThemeCSSRules.cjs +17 -9
  54. package/dist/cjs/helpers/getTokenForKey.cjs +127 -0
  55. package/dist/cjs/helpers/getTokenForKey.native.js +145 -0
  56. package/dist/cjs/helpers/getTokenForKey.native.js.map +1 -0
  57. package/dist/cjs/helpers/insertStyleRule.cjs +1 -1
  58. package/dist/cjs/helpers/insertStyleRule.native.js +1 -1
  59. package/dist/cjs/helpers/mainThreadPressEvents.native.js +63 -16
  60. package/dist/cjs/helpers/mainThreadPressEvents.native.js.map +1 -1
  61. package/dist/cjs/helpers/mediaObjectToString.cjs +35 -0
  62. package/dist/cjs/helpers/mediaObjectToString.native.js +43 -0
  63. package/dist/cjs/helpers/mediaObjectToString.native.js.map +1 -0
  64. package/dist/cjs/helpers/mediaState.cjs +45 -0
  65. package/dist/cjs/helpers/mediaState.native.js +50 -0
  66. package/dist/cjs/helpers/mediaState.native.js.map +1 -0
  67. package/dist/cjs/helpers/normalizeColor.cjs +6 -1
  68. package/dist/cjs/helpers/normalizeValueWithProperty.cjs +2 -1
  69. package/dist/cjs/helpers/normalizeValueWithProperty.native.js +2 -1
  70. package/dist/cjs/helpers/normalizeValueWithProperty.native.js.map +1 -1
  71. package/dist/cjs/helpers/parseNativeStyle.cjs +133 -0
  72. package/dist/cjs/helpers/parseNativeStyle.native.js +151 -0
  73. package/dist/cjs/helpers/parseNativeStyle.native.js.map +1 -0
  74. package/dist/cjs/{createTheme.cjs → helpers/parseOutlineShorthand.cjs} +5 -5
  75. package/dist/cjs/helpers/parseOutlineShorthand.native.js +58 -0
  76. package/dist/cjs/helpers/parseOutlineShorthand.native.js.map +1 -0
  77. package/dist/cjs/helpers/platformResolveValue.cjs +33 -0
  78. package/dist/cjs/helpers/platformResolveValue.native.js +62 -0
  79. package/dist/cjs/helpers/platformResolveValue.native.js.map +1 -0
  80. package/dist/cjs/helpers/propMapper.cjs +26 -96
  81. package/dist/cjs/helpers/propMapper.native.js +61 -108
  82. package/dist/cjs/helpers/propMapper.native.js.map +1 -1
  83. package/dist/cjs/helpers/pseudoTransitions.cjs +65 -0
  84. package/dist/cjs/helpers/pseudoTransitions.native.js +72 -0
  85. package/dist/cjs/helpers/pseudoTransitions.native.js.map +1 -0
  86. package/dist/cjs/{constants/webToNativeProps.cjs → helpers/resolveAnimationDriver.cjs} +7 -7
  87. package/dist/cjs/{views/Stack.native.js → helpers/resolveAnimationDriver.native.js} +9 -14
  88. package/dist/cjs/helpers/resolveAnimationDriver.native.js.map +1 -0
  89. package/dist/cjs/{views/Stack.cjs → helpers/resolveCompoundTokens.cjs} +16 -13
  90. package/dist/cjs/helpers/resolveCompoundTokens.native.js +40 -0
  91. package/dist/cjs/helpers/resolveCompoundTokens.native.js.map +1 -0
  92. package/dist/cjs/helpers/skipProps.cjs +1 -0
  93. package/dist/cjs/helpers/skipProps.native.js +1 -0
  94. package/dist/cjs/helpers/skipProps.native.js.map +1 -1
  95. package/dist/cjs/helpers/themeable.cjs +4 -2
  96. package/dist/cjs/helpers/themeable.native.js +4 -2
  97. package/dist/cjs/helpers/themeable.native.js.map +1 -1
  98. package/dist/cjs/helpers/useRenderElement.native.js +1 -1
  99. package/dist/cjs/helpers/useRenderElement.native.js.map +1 -1
  100. package/dist/cjs/hooks/useComponentState.cjs +9 -5
  101. package/dist/cjs/hooks/useComponentState.native.js +10 -6
  102. package/dist/cjs/hooks/useComponentState.native.js.map +1 -1
  103. package/dist/cjs/hooks/useMedia.cjs +25 -48
  104. package/dist/cjs/hooks/useMedia.native.js +25 -55
  105. package/dist/cjs/hooks/useMedia.native.js.map +1 -1
  106. package/dist/cjs/hooks/useProps.cjs +3 -2
  107. package/dist/cjs/hooks/useProps.native.js +3 -2
  108. package/dist/cjs/hooks/useProps.native.js.map +1 -1
  109. package/dist/cjs/hooks/useTheme.cjs +4 -0
  110. package/dist/cjs/hooks/useTheme.native.js +4 -0
  111. package/dist/cjs/hooks/useTheme.native.js.map +1 -1
  112. package/dist/cjs/hooks/useThemeState.cjs +30 -12
  113. package/dist/cjs/hooks/useThemeState.native.js +28 -12
  114. package/dist/cjs/hooks/useThemeState.native.js.map +1 -1
  115. package/dist/cjs/index.cjs +9 -5
  116. package/dist/cjs/index.native.js +9 -5
  117. package/dist/cjs/index.native.js.map +1 -1
  118. package/dist/cjs/styled.native.js.map +1 -1
  119. package/dist/cjs/views/TamaguiProvider.cjs +20 -33
  120. package/dist/cjs/views/TamaguiProvider.native.js +28 -39
  121. package/dist/cjs/views/TamaguiProvider.native.js.map +1 -1
  122. package/dist/cjs/views/TamaguiRoot.cjs +68 -0
  123. package/dist/cjs/{createTheme.native.js → views/TamaguiRoot.native.js} +8 -8
  124. package/dist/cjs/views/TamaguiRoot.native.js.map +1 -0
  125. package/dist/cjs/views/Text.cjs +2 -10
  126. package/dist/cjs/views/Text.native.js +0 -1
  127. package/dist/cjs/views/Text.native.js.map +1 -1
  128. package/dist/cjs/views/Theme.cjs +2 -0
  129. package/dist/cjs/views/Theme.native.js +2 -0
  130. package/dist/cjs/views/Theme.native.js.map +1 -1
  131. package/dist/cjs/views/ThemeProvider.cjs +3 -1
  132. package/dist/cjs/views/ThemeProvider.native.js +2 -0
  133. package/dist/cjs/views/ThemeProvider.native.js.map +1 -1
  134. package/dist/cjs/views/View.cjs +0 -2
  135. package/dist/cjs/views/View.native.js +0 -2
  136. package/dist/cjs/views/View.native.js.map +1 -1
  137. package/dist/esm/Tamagui.mjs +1 -1
  138. package/dist/esm/Tamagui.native.js +1 -1
  139. package/dist/esm/_withStableStyle.mjs +18 -7
  140. package/dist/esm/_withStableStyle.mjs.map +1 -1
  141. package/dist/esm/_withStableStyle.native.js +19 -6
  142. package/dist/esm/_withStableStyle.native.js.map +1 -1
  143. package/dist/esm/animationDriverTypes.test-d.mjs +11 -0
  144. package/dist/esm/animationDriverTypes.test-d.mjs.map +1 -1
  145. package/dist/esm/animationDriverTypes.test-d.native.js +11 -0
  146. package/dist/esm/animationDriverTypes.test-d.native.js.map +1 -1
  147. package/dist/esm/config.mjs +5 -1
  148. package/dist/esm/config.mjs.map +1 -1
  149. package/dist/esm/config.native.js +5 -1
  150. package/dist/esm/config.native.js.map +1 -1
  151. package/dist/esm/constants/constants.mjs +2 -14
  152. package/dist/esm/constants/constants.mjs.map +1 -1
  153. package/dist/esm/constants/constants.native.js +1 -12
  154. package/dist/esm/constants/constants.native.js.map +1 -1
  155. package/dist/esm/createComponent.mjs +91 -79
  156. package/dist/esm/createComponent.mjs.map +1 -1
  157. package/dist/esm/createComponent.native.js +112 -89
  158. package/dist/esm/createComponent.native.js.map +1 -1
  159. package/dist/esm/createTamagui.mjs +38 -37
  160. package/dist/esm/createTamagui.mjs.map +1 -1
  161. package/dist/esm/createTamagui.native.js +41 -37
  162. package/dist/esm/createTamagui.native.js.map +1 -1
  163. package/dist/esm/createVariable.mjs.map +1 -1
  164. package/dist/esm/eventHandling.mjs +1 -1
  165. package/dist/esm/eventHandling.mjs.map +1 -1
  166. package/dist/esm/eventHandling.native.js +84 -57
  167. package/dist/esm/eventHandling.native.js.map +1 -1
  168. package/dist/esm/helpers/createDesignSystem.mjs +43 -7
  169. package/dist/esm/helpers/createDesignSystem.mjs.map +1 -1
  170. package/dist/esm/helpers/createDesignSystem.native.js +35 -7
  171. package/dist/esm/helpers/createDesignSystem.native.js.map +1 -1
  172. package/dist/esm/helpers/createMediaStyle.mjs +7 -4
  173. package/dist/esm/helpers/createMediaStyle.mjs.map +1 -1
  174. package/dist/esm/helpers/createMediaStyle.native.js +9 -6
  175. package/dist/esm/helpers/createMediaStyle.native.js.map +1 -1
  176. package/dist/esm/helpers/createStyledContext.mjs +12 -8
  177. package/dist/esm/helpers/createStyledContext.mjs.map +1 -1
  178. package/dist/esm/helpers/createStyledContext.native.js +11 -7
  179. package/dist/esm/helpers/createStyledContext.native.js.map +1 -1
  180. package/dist/esm/helpers/defaultAnimationDriver.mjs +0 -2
  181. package/dist/esm/helpers/defaultAnimationDriver.mjs.map +1 -1
  182. package/dist/esm/helpers/defaultAnimationDriver.native.js +0 -2
  183. package/dist/esm/helpers/defaultAnimationDriver.native.js.map +1 -1
  184. package/dist/esm/helpers/expandStyle.mjs +0 -1
  185. package/dist/esm/helpers/expandStyle.mjs.map +1 -1
  186. package/dist/esm/helpers/expandStyle.native.js +9 -1
  187. package/dist/esm/helpers/expandStyle.native.js.map +1 -1
  188. package/dist/esm/helpers/getCSSStylesAtomic.mjs +8 -8
  189. package/dist/esm/helpers/getCSSStylesAtomic.mjs.map +1 -1
  190. package/dist/esm/helpers/getDefaultProps.mjs +3 -9
  191. package/dist/esm/helpers/getDefaultProps.mjs.map +1 -1
  192. package/dist/esm/helpers/getDefaultProps.native.js +3 -4
  193. package/dist/esm/helpers/getDefaultProps.native.js.map +1 -1
  194. package/dist/esm/helpers/getGroupPropParts.mjs +1 -1
  195. package/dist/esm/helpers/getGroupPropParts.native.js +1 -1
  196. package/dist/esm/helpers/getSplitStyles.mjs +59 -29
  197. package/dist/esm/helpers/getSplitStyles.mjs.map +1 -1
  198. package/dist/esm/helpers/getSplitStyles.native.js +113 -77
  199. package/dist/esm/helpers/getSplitStyles.native.js.map +1 -1
  200. package/dist/esm/helpers/getThemeCSSRules.mjs +17 -9
  201. package/dist/esm/helpers/getThemeCSSRules.mjs.map +1 -1
  202. package/dist/esm/helpers/getTokenForKey.mjs +101 -0
  203. package/dist/esm/helpers/getTokenForKey.mjs.map +1 -0
  204. package/dist/esm/helpers/getTokenForKey.native.js +116 -0
  205. package/dist/esm/helpers/getTokenForKey.native.js.map +1 -0
  206. package/dist/esm/helpers/insertStyleRule.mjs +1 -1
  207. package/dist/esm/helpers/insertStyleRule.native.js +1 -1
  208. package/dist/esm/helpers/mainThreadPressEvents.native.js +63 -16
  209. package/dist/esm/helpers/mainThreadPressEvents.native.js.map +1 -1
  210. package/dist/esm/helpers/mediaObjectToString.mjs +12 -0
  211. package/dist/esm/helpers/mediaObjectToString.mjs.map +1 -0
  212. package/dist/esm/helpers/mediaObjectToString.native.js +17 -0
  213. package/dist/esm/helpers/mediaObjectToString.native.js.map +1 -0
  214. package/dist/esm/helpers/mediaState.mjs +18 -0
  215. package/dist/esm/helpers/mediaState.mjs.map +1 -0
  216. package/dist/esm/helpers/mediaState.native.js +20 -0
  217. package/dist/esm/helpers/mediaState.native.js.map +1 -0
  218. package/dist/esm/helpers/normalizeColor.mjs +6 -1
  219. package/dist/esm/helpers/normalizeColor.mjs.map +1 -1
  220. package/dist/esm/helpers/normalizeValueWithProperty.mjs +2 -1
  221. package/dist/esm/helpers/normalizeValueWithProperty.mjs.map +1 -1
  222. package/dist/esm/helpers/normalizeValueWithProperty.native.js +2 -1
  223. package/dist/esm/helpers/normalizeValueWithProperty.native.js.map +1 -1
  224. package/dist/esm/helpers/parseNativeStyle.mjs +110 -0
  225. package/dist/esm/helpers/parseNativeStyle.mjs.map +1 -0
  226. package/dist/esm/helpers/parseNativeStyle.native.js +125 -0
  227. package/dist/esm/helpers/parseNativeStyle.native.js.map +1 -0
  228. package/dist/esm/helpers/parseOutlineShorthand.mjs +3 -0
  229. package/dist/esm/helpers/parseOutlineShorthand.mjs.map +1 -0
  230. package/dist/esm/helpers/parseOutlineShorthand.native.js +32 -0
  231. package/dist/esm/helpers/parseOutlineShorthand.native.js.map +1 -0
  232. package/dist/esm/helpers/platformResolveValue.mjs +10 -0
  233. package/dist/esm/helpers/platformResolveValue.mjs.map +1 -0
  234. package/dist/esm/helpers/platformResolveValue.native.js +36 -0
  235. package/dist/esm/helpers/platformResolveValue.native.js.map +1 -0
  236. package/dist/esm/helpers/propMapper.mjs +24 -96
  237. package/dist/esm/helpers/propMapper.mjs.map +1 -1
  238. package/dist/esm/helpers/propMapper.native.js +60 -107
  239. package/dist/esm/helpers/propMapper.native.js.map +1 -1
  240. package/dist/esm/helpers/pseudoTransitions.mjs +41 -0
  241. package/dist/esm/helpers/pseudoTransitions.mjs.map +1 -0
  242. package/dist/esm/helpers/pseudoTransitions.native.js +45 -0
  243. package/dist/esm/helpers/pseudoTransitions.native.js.map +1 -0
  244. package/dist/esm/helpers/resolveAnimationDriver.mjs +5 -0
  245. package/dist/esm/helpers/resolveAnimationDriver.mjs.map +1 -0
  246. package/dist/esm/helpers/resolveAnimationDriver.native.js +6 -0
  247. package/dist/esm/helpers/resolveAnimationDriver.native.js.map +1 -0
  248. package/dist/esm/helpers/resolveCompoundTokens.mjs +14 -0
  249. package/dist/esm/helpers/resolveCompoundTokens.mjs.map +1 -0
  250. package/dist/esm/helpers/resolveCompoundTokens.native.js +14 -0
  251. package/dist/esm/helpers/resolveCompoundTokens.native.js.map +1 -0
  252. package/dist/esm/helpers/skipProps.mjs +1 -1
  253. package/dist/esm/helpers/skipProps.mjs.map +1 -1
  254. package/dist/esm/helpers/skipProps.native.js +1 -1
  255. package/dist/esm/helpers/skipProps.native.js.map +1 -1
  256. package/dist/esm/helpers/themeable.mjs +4 -2
  257. package/dist/esm/helpers/themeable.mjs.map +1 -1
  258. package/dist/esm/helpers/themeable.native.js +4 -2
  259. package/dist/esm/helpers/themeable.native.js.map +1 -1
  260. package/dist/esm/helpers/useRenderElement.mjs.map +1 -1
  261. package/dist/esm/helpers/useRenderElement.native.js +1 -1
  262. package/dist/esm/helpers/useRenderElement.native.js.map +1 -1
  263. package/dist/esm/helpers/wrapStyleTags.native.js +0 -2
  264. package/dist/esm/helpers/wrapStyleTags.native.js.map +1 -1
  265. package/dist/esm/hooks/getThemeProxied.mjs +0 -3
  266. package/dist/esm/hooks/getThemeProxied.mjs.map +1 -1
  267. package/dist/esm/hooks/useComponentState.mjs +9 -5
  268. package/dist/esm/hooks/useComponentState.mjs.map +1 -1
  269. package/dist/esm/hooks/useComponentState.native.js +10 -6
  270. package/dist/esm/hooks/useComponentState.native.js.map +1 -1
  271. package/dist/esm/hooks/useMedia.mjs +21 -39
  272. package/dist/esm/hooks/useMedia.mjs.map +1 -1
  273. package/dist/esm/hooks/useMedia.native.js +22 -47
  274. package/dist/esm/hooks/useMedia.native.js.map +1 -1
  275. package/dist/esm/hooks/useProps.mjs +2 -1
  276. package/dist/esm/hooks/useProps.mjs.map +1 -1
  277. package/dist/esm/hooks/useProps.native.js +2 -1
  278. package/dist/esm/hooks/useProps.native.js.map +1 -1
  279. package/dist/esm/hooks/useTheme.mjs +4 -0
  280. package/dist/esm/hooks/useTheme.mjs.map +1 -1
  281. package/dist/esm/hooks/useTheme.native.js +4 -0
  282. package/dist/esm/hooks/useTheme.native.js.map +1 -1
  283. package/dist/esm/hooks/useThemeState.mjs +30 -13
  284. package/dist/esm/hooks/useThemeState.mjs.map +1 -1
  285. package/dist/esm/hooks/useThemeState.native.js +28 -12
  286. package/dist/esm/hooks/useThemeState.native.js.map +1 -1
  287. package/dist/esm/index.js +67 -107
  288. package/dist/esm/index.js.map +1 -6
  289. package/dist/esm/index.mjs +5 -1
  290. package/dist/esm/index.mjs.map +1 -1
  291. package/dist/esm/index.native.js +5 -1
  292. package/dist/esm/index.native.js.map +1 -1
  293. package/dist/esm/insertFont.native.js +0 -1
  294. package/dist/esm/insertFont.native.js.map +1 -1
  295. package/dist/esm/styled.mjs.map +1 -1
  296. package/dist/esm/styled.native.js.map +1 -1
  297. package/dist/esm/views/TamaguiProvider.mjs +21 -34
  298. package/dist/esm/views/TamaguiProvider.mjs.map +1 -1
  299. package/dist/esm/views/TamaguiProvider.native.js +28 -40
  300. package/dist/esm/views/TamaguiProvider.native.js.map +1 -1
  301. package/dist/esm/views/TamaguiRoot.mjs +34 -0
  302. package/dist/esm/views/TamaguiRoot.mjs.map +1 -0
  303. package/dist/esm/views/TamaguiRoot.native.js +5 -0
  304. package/dist/esm/views/TamaguiRoot.native.js.map +1 -0
  305. package/dist/esm/views/Text.mjs +1 -9
  306. package/dist/esm/views/Text.mjs.map +1 -1
  307. package/dist/esm/views/Text.native.js +0 -1
  308. package/dist/esm/views/Text.native.js.map +1 -1
  309. package/dist/esm/views/Theme.mjs +2 -0
  310. package/dist/esm/views/Theme.mjs.map +1 -1
  311. package/dist/esm/views/Theme.native.js +2 -0
  312. package/dist/esm/views/Theme.native.js.map +1 -1
  313. package/dist/esm/views/ThemeProvider.mjs +3 -1
  314. package/dist/esm/views/ThemeProvider.mjs.map +1 -1
  315. package/dist/esm/views/ThemeProvider.native.js +2 -2
  316. package/dist/esm/views/ThemeProvider.native.js.map +1 -1
  317. package/dist/esm/views/View.mjs +0 -2
  318. package/dist/esm/views/View.mjs.map +1 -1
  319. package/dist/esm/views/View.native.js +0 -2
  320. package/dist/esm/views/View.native.js.map +1 -1
  321. package/inject-styles/index.cjs +2 -0
  322. package/inject-styles/index.js +2 -0
  323. package/inject-styles.cjs +1 -0
  324. package/package.json +21 -27
  325. package/src/Tamagui.ts +1 -1
  326. package/src/_withStableStyle.tsx +44 -16
  327. package/src/animationDriverTypes.test-d.ts +76 -0
  328. package/src/config.ts +5 -1
  329. package/src/constants/constants.ts +0 -17
  330. package/src/createComponent.tsx +224 -93
  331. package/src/createTamagui.ts +20 -11
  332. package/src/createVariable.ts +1 -1
  333. package/src/eventHandling.native.ts +80 -53
  334. package/src/eventHandling.ts +2 -1
  335. package/src/helpers/createDesignSystem.ts +77 -6
  336. package/src/helpers/createMediaStyle.ts +12 -4
  337. package/src/helpers/createStyledContext.tsx +27 -18
  338. package/src/helpers/defaultAnimationDriver.tsx +0 -2
  339. package/src/helpers/expandStyle.ts +11 -0
  340. package/src/helpers/getCSSStylesAtomic.ts +13 -14
  341. package/src/helpers/getDefaultProps.ts +4 -15
  342. package/src/helpers/getGroupPropParts.ts +1 -1
  343. package/src/helpers/getSplitStyles.tsx +174 -40
  344. package/src/helpers/getThemeCSSRules.ts +16 -14
  345. package/src/helpers/getTokenForKey.ts +223 -0
  346. package/src/helpers/insertStyleRule.tsx +1 -1
  347. package/src/helpers/mainThreadPressEvents.native.ts +118 -25
  348. package/src/helpers/mediaObjectToString.ts +30 -0
  349. package/src/helpers/mediaState.ts +32 -0
  350. package/src/helpers/normalizeColor.ts +12 -8
  351. package/src/helpers/normalizeValueWithProperty.ts +8 -1
  352. package/src/helpers/parseNativeStyle.ts +193 -0
  353. package/src/helpers/parseOutlineShorthand.native.ts +62 -0
  354. package/src/helpers/parseOutlineShorthand.ts +6 -0
  355. package/src/helpers/platformResolveValue.native.ts +72 -0
  356. package/src/helpers/platformResolveValue.ts +22 -0
  357. package/src/helpers/propMapper.ts +65 -221
  358. package/src/helpers/pseudoTransitions.ts +97 -0
  359. package/src/helpers/resolveAnimationDriver.ts +23 -0
  360. package/src/helpers/resolveCompoundTokens.ts +28 -0
  361. package/src/helpers/skipProps.ts +1 -0
  362. package/src/helpers/themeable.tsx +7 -5
  363. package/src/helpers/useRenderElement.tsx +7 -0
  364. package/src/hooks/useComponentState.ts +11 -8
  365. package/src/hooks/useMedia.tsx +28 -75
  366. package/src/hooks/useProps.tsx +2 -1
  367. package/src/hooks/useTheme.tsx +4 -0
  368. package/src/hooks/useThemeState.ts +57 -14
  369. package/src/index.ts +4 -4
  370. package/src/styled.tsx +2 -2
  371. package/src/types.tsx +205 -57
  372. package/src/views/TamaguiProvider.tsx +35 -54
  373. package/src/views/TamaguiRoot.native.tsx +9 -0
  374. package/src/views/TamaguiRoot.tsx +64 -0
  375. package/src/views/Text.tsx +1 -9
  376. package/src/views/Theme.tsx +2 -0
  377. package/src/views/ThemeProvider.tsx +3 -1
  378. package/src/views/View.tsx +0 -2
  379. package/tsconfig.json +44 -0
  380. package/tsconfig.test.json +9 -0
  381. package/types/_withStableStyle.d.ts +1 -1
  382. package/types/_withStableStyle.d.ts.map +1 -1
  383. package/types/config.d.ts.map +1 -1
  384. package/types/constants/constants.d.ts +0 -3
  385. package/types/constants/constants.d.ts.map +1 -1
  386. package/types/createComponent.d.ts.map +1 -1
  387. package/types/createTamagui.d.ts.map +1 -1
  388. package/types/createVariable.d.ts +1 -1
  389. package/types/createVariable.d.ts.map +1 -1
  390. package/types/eventHandling.d.ts +1 -1
  391. package/types/eventHandling.d.ts.map +1 -1
  392. package/types/eventHandling.native.d.ts +2 -2
  393. package/types/eventHandling.native.d.ts.map +1 -1
  394. package/types/helpers/createDesignSystem.d.ts +5 -2
  395. package/types/helpers/createDesignSystem.d.ts.map +1 -1
  396. package/types/helpers/createMediaStyle.d.ts.map +1 -1
  397. package/types/helpers/createStyledContext.d.ts +1 -1
  398. package/types/helpers/createStyledContext.d.ts.map +1 -1
  399. package/types/helpers/defaultAnimationDriver.d.ts.map +1 -1
  400. package/types/helpers/expandStyle.d.ts.map +1 -1
  401. package/types/helpers/getCSSStylesAtomic.d.ts.map +1 -1
  402. package/types/helpers/getDefaultProps.d.ts +1 -1
  403. package/types/helpers/getDefaultProps.d.ts.map +1 -1
  404. package/types/helpers/getSplitStyles.d.ts +2 -2
  405. package/types/helpers/getSplitStyles.d.ts.map +1 -1
  406. package/types/helpers/getThemeCSSRules.d.ts.map +1 -1
  407. package/types/helpers/getTokenForKey.d.ts +6 -0
  408. package/types/helpers/getTokenForKey.d.ts.map +1 -0
  409. package/types/helpers/mainThreadPressEvents.native.d.ts +4 -5
  410. package/types/helpers/mainThreadPressEvents.native.d.ts.map +1 -1
  411. package/types/helpers/mediaObjectToString.d.ts +3 -0
  412. package/types/helpers/mediaObjectToString.d.ts.map +1 -0
  413. package/types/helpers/mediaState.d.ts +7 -0
  414. package/types/helpers/mediaState.d.ts.map +1 -0
  415. package/types/helpers/normalizeColor.d.ts +1 -1
  416. package/types/helpers/normalizeColor.d.ts.map +1 -1
  417. package/types/helpers/normalizeValueWithProperty.d.ts.map +1 -1
  418. package/types/helpers/parseNativeStyle.d.ts +14 -0
  419. package/types/helpers/parseNativeStyle.d.ts.map +1 -0
  420. package/types/helpers/parseOutlineShorthand.d.ts +3 -0
  421. package/types/helpers/parseOutlineShorthand.d.ts.map +1 -0
  422. package/types/helpers/parseOutlineShorthand.native.d.ts +3 -0
  423. package/types/helpers/parseOutlineShorthand.native.d.ts.map +1 -0
  424. package/types/helpers/platformResolveValue.d.ts +6 -0
  425. package/types/helpers/platformResolveValue.d.ts.map +1 -0
  426. package/types/helpers/platformResolveValue.native.d.ts +7 -0
  427. package/types/helpers/platformResolveValue.native.d.ts.map +1 -0
  428. package/types/helpers/propMapper.d.ts +2 -2
  429. package/types/helpers/propMapper.d.ts.map +1 -1
  430. package/types/helpers/pseudoTransitions.d.ts +29 -0
  431. package/types/helpers/pseudoTransitions.d.ts.map +1 -0
  432. package/types/helpers/resolveAnimationDriver.d.ts +7 -0
  433. package/types/helpers/resolveAnimationDriver.d.ts.map +1 -0
  434. package/types/helpers/resolveCompoundTokens.d.ts +9 -0
  435. package/types/helpers/resolveCompoundTokens.d.ts.map +1 -0
  436. package/types/helpers/skipProps.d.ts +1 -0
  437. package/types/helpers/skipProps.d.ts.map +1 -1
  438. package/types/helpers/themeable.d.ts.map +1 -1
  439. package/types/helpers/useRenderElement.d.ts.map +1 -1
  440. package/types/helpers/webPropsToSkip.native.d.ts +20 -20
  441. package/types/hooks/useComponentState.d.ts +2 -1
  442. package/types/hooks/useComponentState.d.ts.map +1 -1
  443. package/types/hooks/useMedia.d.ts +1 -6
  444. package/types/hooks/useMedia.d.ts.map +1 -1
  445. package/types/hooks/useProps.d.ts.map +1 -1
  446. package/types/hooks/useTheme.d.ts.map +1 -1
  447. package/types/hooks/useThemeState.d.ts.map +1 -1
  448. package/types/index.d.ts +5 -1
  449. package/types/index.d.ts.map +1 -1
  450. package/types/styled.d.ts +2 -2
  451. package/types/styled.d.ts.map +1 -1
  452. package/types/types.d.ts +105 -30
  453. package/types/types.d.ts.map +1 -1
  454. package/types/views/TamaguiProvider.d.ts +1 -4
  455. package/types/views/TamaguiProvider.d.ts.map +1 -1
  456. package/types/views/TamaguiRoot.d.ts +15 -0
  457. package/types/views/TamaguiRoot.d.ts.map +1 -0
  458. package/types/views/TamaguiRoot.native.d.ts +7 -0
  459. package/types/views/TamaguiRoot.native.d.ts.map +1 -0
  460. package/types/views/Text.d.ts.map +1 -1
  461. package/types/views/Theme.d.ts.map +1 -1
  462. package/types/views/ThemeProvider.d.ts.map +1 -1
  463. package/types/views/View.d.ts.map +1 -1
  464. package/vitest.config.d.ts +3 -0
  465. package/vitest.config.d.ts.map +1 -0
  466. package/vitest.config.ts +14 -0
  467. package/dist/cjs/Tamagui.js +0 -56
  468. package/dist/cjs/Tamagui.js.map +0 -6
  469. package/dist/cjs/_withStableStyle.js +0 -33
  470. package/dist/cjs/_withStableStyle.js.map +0 -6
  471. package/dist/cjs/animationDriverTypes.test-d.js +0 -51
  472. package/dist/cjs/animationDriverTypes.test-d.js.map +0 -6
  473. package/dist/cjs/config.js +0 -109
  474. package/dist/cjs/config.js.map +0 -6
  475. package/dist/cjs/constants/accessibilityDirectMap.js +0 -25
  476. package/dist/cjs/constants/accessibilityDirectMap.js.map +0 -6
  477. package/dist/cjs/constants/constants.js +0 -43
  478. package/dist/cjs/constants/constants.js.map +0 -6
  479. package/dist/cjs/constants/isDevTools.js +0 -28
  480. package/dist/cjs/constants/isDevTools.js.map +0 -6
  481. package/dist/cjs/constants/webToNativeProps.js +0 -22
  482. package/dist/cjs/constants/webToNativeProps.js.map +0 -6
  483. package/dist/cjs/constants/webToNativeProps.native.js +0 -115
  484. package/dist/cjs/constants/webToNativeProps.native.js.map +0 -1
  485. package/dist/cjs/contexts/ComponentContext.js +0 -30
  486. package/dist/cjs/contexts/ComponentContext.js.map +0 -6
  487. package/dist/cjs/contexts/GroupContext.js +0 -22
  488. package/dist/cjs/contexts/GroupContext.js.map +0 -6
  489. package/dist/cjs/createComponent.js +0 -697
  490. package/dist/cjs/createComponent.js.map +0 -6
  491. package/dist/cjs/createFont.js +0 -53
  492. package/dist/cjs/createFont.js.map +0 -6
  493. package/dist/cjs/createShorthands.js +0 -23
  494. package/dist/cjs/createShorthands.js.map +0 -6
  495. package/dist/cjs/createTamagui.js +0 -190
  496. package/dist/cjs/createTamagui.js.map +0 -6
  497. package/dist/cjs/createTheme.js +0 -21
  498. package/dist/cjs/createTheme.js.map +0 -6
  499. package/dist/cjs/createTheme.native.js.map +0 -1
  500. package/dist/cjs/createTokens.js +0 -24
  501. package/dist/cjs/createTokens.js.map +0 -6
  502. package/dist/cjs/createVariable.js +0 -89
  503. package/dist/cjs/createVariable.js.map +0 -6
  504. package/dist/cjs/createVariables.js +0 -56
  505. package/dist/cjs/createVariables.js.map +0 -6
  506. package/dist/cjs/defaultComponentState.js +0 -38
  507. package/dist/cjs/defaultComponentState.js.map +0 -6
  508. package/dist/cjs/eventHandling.js +0 -41
  509. package/dist/cjs/eventHandling.js.map +0 -6
  510. package/dist/cjs/helpers/createDesignSystem.js +0 -120
  511. package/dist/cjs/helpers/createDesignSystem.js.map +0 -6
  512. package/dist/cjs/helpers/createMediaStyle.js +0 -74
  513. package/dist/cjs/helpers/createMediaStyle.js.map +0 -6
  514. package/dist/cjs/helpers/createStyledContext.js +0 -52
  515. package/dist/cjs/helpers/createStyledContext.js.map +0 -6
  516. package/dist/cjs/helpers/defaultAnimationDriver.js +0 -39
  517. package/dist/cjs/helpers/defaultAnimationDriver.js.map +0 -6
  518. package/dist/cjs/helpers/defaultOffset.js +0 -21
  519. package/dist/cjs/helpers/defaultOffset.js.map +0 -6
  520. package/dist/cjs/helpers/expandStyle.js +0 -73
  521. package/dist/cjs/helpers/expandStyle.js.map +0 -6
  522. package/dist/cjs/helpers/expandStyles.js +0 -34
  523. package/dist/cjs/helpers/expandStyles.js.map +0 -6
  524. package/dist/cjs/helpers/getCSSStylesAtomic.js +0 -156
  525. package/dist/cjs/helpers/getCSSStylesAtomic.js.map +0 -6
  526. package/dist/cjs/helpers/getDefaultProps.js +0 -31
  527. package/dist/cjs/helpers/getDefaultProps.js.map +0 -6
  528. package/dist/cjs/helpers/getDynamicVal.js +0 -62
  529. package/dist/cjs/helpers/getDynamicVal.js.map +0 -6
  530. package/dist/cjs/helpers/getExpandedShorthands.js +0 -34
  531. package/dist/cjs/helpers/getExpandedShorthands.js.map +0 -6
  532. package/dist/cjs/helpers/getFontLanguage.js +0 -21
  533. package/dist/cjs/helpers/getFontLanguage.js.map +0 -6
  534. package/dist/cjs/helpers/getGroupPropParts.js +0 -34
  535. package/dist/cjs/helpers/getGroupPropParts.js.map +0 -6
  536. package/dist/cjs/helpers/getShorthandValue.js +0 -23
  537. package/dist/cjs/helpers/getShorthandValue.js.map +0 -6
  538. package/dist/cjs/helpers/getSplitStyles.js +0 -630
  539. package/dist/cjs/helpers/getSplitStyles.js.map +0 -6
  540. package/dist/cjs/helpers/getThemeCSSRules.js +0 -89
  541. package/dist/cjs/helpers/getThemeCSSRules.js.map +0 -6
  542. package/dist/cjs/helpers/getVariantExtras.js +0 -59
  543. package/dist/cjs/helpers/getVariantExtras.js.map +0 -6
  544. package/dist/cjs/helpers/insertStyleRule.js +0 -196
  545. package/dist/cjs/helpers/insertStyleRule.js.map +0 -6
  546. package/dist/cjs/helpers/isActivePlatform.js +0 -31
  547. package/dist/cjs/helpers/isActivePlatform.js.map +0 -6
  548. package/dist/cjs/helpers/isActiveTheme.js +0 -24
  549. package/dist/cjs/helpers/isActiveTheme.js.map +0 -6
  550. package/dist/cjs/helpers/isObj.js +0 -21
  551. package/dist/cjs/helpers/isObj.js.map +0 -6
  552. package/dist/cjs/helpers/isTamaguiComponent.js +0 -24
  553. package/dist/cjs/helpers/isTamaguiComponent.js.map +0 -6
  554. package/dist/cjs/helpers/isTamaguiElement.js +0 -30
  555. package/dist/cjs/helpers/isTamaguiElement.js.map +0 -6
  556. package/dist/cjs/helpers/log.js +0 -33
  557. package/dist/cjs/helpers/log.js.map +0 -6
  558. package/dist/cjs/helpers/mainThreadPressEvents.js +0 -22
  559. package/dist/cjs/helpers/mainThreadPressEvents.js.map +0 -6
  560. package/dist/cjs/helpers/matchMedia.js +0 -34
  561. package/dist/cjs/helpers/matchMedia.js.map +0 -6
  562. package/dist/cjs/helpers/mergeProps.js +0 -55
  563. package/dist/cjs/helpers/mergeProps.js.map +0 -6
  564. package/dist/cjs/helpers/mergeRenderElementProps.js +0 -25
  565. package/dist/cjs/helpers/mergeRenderElementProps.js.map +0 -6
  566. package/dist/cjs/helpers/mergeSlotStyleProps.js +0 -29
  567. package/dist/cjs/helpers/mergeSlotStyleProps.js.map +0 -6
  568. package/dist/cjs/helpers/mergeVariants.js +0 -38
  569. package/dist/cjs/helpers/mergeVariants.js.map +0 -6
  570. package/dist/cjs/helpers/nativeOnlyProps.js +0 -55
  571. package/dist/cjs/helpers/nativeOnlyProps.js.map +0 -6
  572. package/dist/cjs/helpers/normalizeColor.js +0 -26
  573. package/dist/cjs/helpers/normalizeColor.js.map +0 -6
  574. package/dist/cjs/helpers/normalizeShadow.js +0 -40
  575. package/dist/cjs/helpers/normalizeShadow.js.map +0 -6
  576. package/dist/cjs/helpers/normalizeStyle.js +0 -36
  577. package/dist/cjs/helpers/normalizeStyle.js.map +0 -6
  578. package/dist/cjs/helpers/normalizeStylePropKeys.js +0 -21
  579. package/dist/cjs/helpers/normalizeStylePropKeys.js.map +0 -6
  580. package/dist/cjs/helpers/normalizeValueWithProperty.js +0 -32
  581. package/dist/cjs/helpers/normalizeValueWithProperty.js.map +0 -6
  582. package/dist/cjs/helpers/objectIdentityKey.js +0 -38
  583. package/dist/cjs/helpers/objectIdentityKey.js.map +0 -6
  584. package/dist/cjs/helpers/parseBorderShorthand.js +0 -22
  585. package/dist/cjs/helpers/parseBorderShorthand.js.map +0 -6
  586. package/dist/cjs/helpers/pointerEvents.js +0 -22
  587. package/dist/cjs/helpers/pointerEvents.js.map +0 -6
  588. package/dist/cjs/helpers/propMapper.js +0 -257
  589. package/dist/cjs/helpers/propMapper.js.map +0 -6
  590. package/dist/cjs/helpers/proxyThemeToParents.js +0 -40
  591. package/dist/cjs/helpers/proxyThemeToParents.js.map +0 -6
  592. package/dist/cjs/helpers/proxyThemeVariables.js +0 -31
  593. package/dist/cjs/helpers/proxyThemeVariables.js.map +0 -6
  594. package/dist/cjs/helpers/pseudoDescriptors.js +0 -72
  595. package/dist/cjs/helpers/pseudoDescriptors.js.map +0 -6
  596. package/dist/cjs/helpers/registerCSSVariable.js +0 -47
  597. package/dist/cjs/helpers/registerCSSVariable.js.map +0 -6
  598. package/dist/cjs/helpers/resolveRem.js +0 -27
  599. package/dist/cjs/helpers/resolveRem.js.map +0 -6
  600. package/dist/cjs/helpers/resolveSafeArea.js +0 -29
  601. package/dist/cjs/helpers/resolveSafeArea.js.map +0 -6
  602. package/dist/cjs/helpers/setElementProps.js +0 -24
  603. package/dist/cjs/helpers/setElementProps.js.map +0 -6
  604. package/dist/cjs/helpers/skipProps.js +0 -38
  605. package/dist/cjs/helpers/skipProps.js.map +0 -6
  606. package/dist/cjs/helpers/sortString.js +0 -21
  607. package/dist/cjs/helpers/sortString.js.map +0 -6
  608. package/dist/cjs/helpers/subscribeToContextGroup.js +0 -74
  609. package/dist/cjs/helpers/subscribeToContextGroup.js.map +0 -6
  610. package/dist/cjs/helpers/themeable.js +0 -56
  611. package/dist/cjs/helpers/themeable.js.map +0 -6
  612. package/dist/cjs/helpers/themes.js +0 -33
  613. package/dist/cjs/helpers/themes.js.map +0 -6
  614. package/dist/cjs/helpers/timer.js +0 -27
  615. package/dist/cjs/helpers/timer.js.map +0 -6
  616. package/dist/cjs/helpers/transformsToString.js +0 -33
  617. package/dist/cjs/helpers/transformsToString.js.map +0 -6
  618. package/dist/cjs/helpers/useRenderElement.js +0 -42
  619. package/dist/cjs/helpers/useRenderElement.js.map +0 -6
  620. package/dist/cjs/helpers/webPropsToSkip.js +0 -21
  621. package/dist/cjs/helpers/webPropsToSkip.js.map +0 -6
  622. package/dist/cjs/helpers/wrapStyleTags.js +0 -38
  623. package/dist/cjs/helpers/wrapStyleTags.js.map +0 -6
  624. package/dist/cjs/hooks/doesRootSchemeMatchSystem.js +0 -23
  625. package/dist/cjs/hooks/doesRootSchemeMatchSystem.js.map +0 -6
  626. package/dist/cjs/hooks/getThemeProxied.js +0 -56
  627. package/dist/cjs/hooks/getThemeProxied.js.map +0 -6
  628. package/dist/cjs/hooks/useComponentState.js +0 -96
  629. package/dist/cjs/hooks/useComponentState.js.map +0 -6
  630. package/dist/cjs/hooks/useDisableSSR.js +0 -24
  631. package/dist/cjs/hooks/useDisableSSR.js.map +0 -6
  632. package/dist/cjs/hooks/useIsTouchDevice.js +0 -22
  633. package/dist/cjs/hooks/useIsTouchDevice.js.map +0 -6
  634. package/dist/cjs/hooks/useMedia.js +0 -183
  635. package/dist/cjs/hooks/useMedia.js.map +0 -6
  636. package/dist/cjs/hooks/useProps.js +0 -106
  637. package/dist/cjs/hooks/useProps.js.map +0 -6
  638. package/dist/cjs/hooks/useTheme.js +0 -35
  639. package/dist/cjs/hooks/useTheme.js.map +0 -6
  640. package/dist/cjs/hooks/useThemeName.js +0 -25
  641. package/dist/cjs/hooks/useThemeName.js.map +0 -6
  642. package/dist/cjs/hooks/useThemeState.js +0 -218
  643. package/dist/cjs/hooks/useThemeState.js.map +0 -6
  644. package/dist/cjs/index.js +0 -108
  645. package/dist/cjs/index.js.map +0 -6
  646. package/dist/cjs/inject-styles.js +0 -28
  647. package/dist/cjs/inject-styles.js.map +0 -6
  648. package/dist/cjs/insertFont.js +0 -68
  649. package/dist/cjs/insertFont.js.map +0 -6
  650. package/dist/cjs/interfaces/CSSColorNames.js +0 -14
  651. package/dist/cjs/interfaces/CSSColorNames.js.map +0 -6
  652. package/dist/cjs/interfaces/GetRef.js +0 -14
  653. package/dist/cjs/interfaces/GetRef.js.map +0 -6
  654. package/dist/cjs/interfaces/RNExclusiveTypes.js +0 -14
  655. package/dist/cjs/interfaces/RNExclusiveTypes.js.map +0 -6
  656. package/dist/cjs/interfaces/TamaguiComponentEvents.js +0 -14
  657. package/dist/cjs/interfaces/TamaguiComponentEvents.js.map +0 -6
  658. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.js +0 -14
  659. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.js.map +0 -6
  660. package/dist/cjs/setupHooks.js +0 -25
  661. package/dist/cjs/setupHooks.js.map +0 -6
  662. package/dist/cjs/setupReactNative.js +0 -43
  663. package/dist/cjs/setupReactNative.js.map +0 -6
  664. package/dist/cjs/styled.js +0 -116
  665. package/dist/cjs/styled.js.map +0 -6
  666. package/dist/cjs/styledHtml.test-d.js +0 -136
  667. package/dist/cjs/styledHtml.test-d.js.map +0 -6
  668. package/dist/cjs/type-utils.js +0 -14
  669. package/dist/cjs/type-utils.js.map +0 -6
  670. package/dist/cjs/types.js +0 -14
  671. package/dist/cjs/types.js.map +0 -6
  672. package/dist/cjs/views/Configuration.js +0 -33
  673. package/dist/cjs/views/Configuration.js.map +0 -6
  674. package/dist/cjs/views/FontLanguage.js +0 -32
  675. package/dist/cjs/views/FontLanguage.js.map +0 -6
  676. package/dist/cjs/views/Slot.js +0 -55
  677. package/dist/cjs/views/Slot.js.map +0 -6
  678. package/dist/cjs/views/Stack.js +0 -27
  679. package/dist/cjs/views/Stack.js.map +0 -6
  680. package/dist/cjs/views/Stack.native.js.map +0 -1
  681. package/dist/cjs/views/TamaguiProvider.js +0 -93
  682. package/dist/cjs/views/TamaguiProvider.js.map +0 -6
  683. package/dist/cjs/views/Text.js +0 -59
  684. package/dist/cjs/views/Text.js.map +0 -6
  685. package/dist/cjs/views/Theme.js +0 -124
  686. package/dist/cjs/views/Theme.js.map +0 -6
  687. package/dist/cjs/views/ThemeDebug.js +0 -81
  688. package/dist/cjs/views/ThemeDebug.js.map +0 -6
  689. package/dist/cjs/views/ThemeProvider.js +0 -42
  690. package/dist/cjs/views/ThemeProvider.js.map +0 -6
  691. package/dist/cjs/views/View.js +0 -26
  692. package/dist/cjs/views/View.js.map +0 -6
  693. package/dist/esm/Tamagui.js +0 -35
  694. package/dist/esm/Tamagui.js.map +0 -6
  695. package/dist/esm/_withStableStyle.js +0 -12
  696. package/dist/esm/_withStableStyle.js.map +0 -6
  697. package/dist/esm/animationDriverTypes.test-d.js +0 -51
  698. package/dist/esm/animationDriverTypes.test-d.js.map +0 -6
  699. package/dist/esm/config.js +0 -94
  700. package/dist/esm/config.js.map +0 -6
  701. package/dist/esm/constants/accessibilityDirectMap.js +0 -9
  702. package/dist/esm/constants/accessibilityDirectMap.js.map +0 -6
  703. package/dist/esm/constants/constants.js +0 -27
  704. package/dist/esm/constants/constants.js.map +0 -6
  705. package/dist/esm/constants/isDevTools.js +0 -12
  706. package/dist/esm/constants/isDevTools.js.map +0 -6
  707. package/dist/esm/constants/webToNativeProps.js +0 -6
  708. package/dist/esm/constants/webToNativeProps.js.map +0 -6
  709. package/dist/esm/constants/webToNativeProps.mjs +0 -4
  710. package/dist/esm/constants/webToNativeProps.mjs.map +0 -1
  711. package/dist/esm/constants/webToNativeProps.native.js +0 -88
  712. package/dist/esm/constants/webToNativeProps.native.js.map +0 -1
  713. package/dist/esm/contexts/ComponentContext.js +0 -15
  714. package/dist/esm/contexts/ComponentContext.js.map +0 -6
  715. package/dist/esm/contexts/GroupContext.js +0 -6
  716. package/dist/esm/contexts/GroupContext.js.map +0 -6
  717. package/dist/esm/createComponent.js +0 -702
  718. package/dist/esm/createComponent.js.map +0 -6
  719. package/dist/esm/createFont.js +0 -37
  720. package/dist/esm/createFont.js.map +0 -6
  721. package/dist/esm/createShorthands.js +0 -7
  722. package/dist/esm/createShorthands.js.map +0 -6
  723. package/dist/esm/createTamagui.js +0 -189
  724. package/dist/esm/createTamagui.js.map +0 -6
  725. package/dist/esm/createTheme.js +0 -5
  726. package/dist/esm/createTheme.js.map +0 -6
  727. package/dist/esm/createTheme.mjs +0 -3
  728. package/dist/esm/createTheme.mjs.map +0 -1
  729. package/dist/esm/createTheme.native.js +0 -5
  730. package/dist/esm/createTheme.native.js.map +0 -1
  731. package/dist/esm/createTokens.js +0 -8
  732. package/dist/esm/createTokens.js.map +0 -6
  733. package/dist/esm/createVariable.js +0 -75
  734. package/dist/esm/createVariable.js.map +0 -6
  735. package/dist/esm/createVariables.js +0 -42
  736. package/dist/esm/createVariables.js.map +0 -6
  737. package/dist/esm/defaultComponentState.js +0 -22
  738. package/dist/esm/defaultComponentState.js.map +0 -6
  739. package/dist/esm/eventHandling.js +0 -25
  740. package/dist/esm/eventHandling.js.map +0 -6
  741. package/dist/esm/helpers/createDesignSystem.js +0 -107
  742. package/dist/esm/helpers/createDesignSystem.js.map +0 -6
  743. package/dist/esm/helpers/createMediaStyle.js +0 -60
  744. package/dist/esm/helpers/createMediaStyle.js.map +0 -6
  745. package/dist/esm/helpers/createStyledContext.js +0 -31
  746. package/dist/esm/helpers/createStyledContext.js.map +0 -6
  747. package/dist/esm/helpers/defaultAnimationDriver.js +0 -23
  748. package/dist/esm/helpers/defaultAnimationDriver.js.map +0 -6
  749. package/dist/esm/helpers/defaultOffset.js +0 -5
  750. package/dist/esm/helpers/defaultOffset.js.map +0 -6
  751. package/dist/esm/helpers/expandStyle.js +0 -59
  752. package/dist/esm/helpers/expandStyle.js.map +0 -6
  753. package/dist/esm/helpers/expandStyles.js +0 -19
  754. package/dist/esm/helpers/expandStyles.js.map +0 -6
  755. package/dist/esm/helpers/getCSSStylesAtomic.js +0 -147
  756. package/dist/esm/helpers/getCSSStylesAtomic.js.map +0 -6
  757. package/dist/esm/helpers/getDefaultProps.js +0 -15
  758. package/dist/esm/helpers/getDefaultProps.js.map +0 -6
  759. package/dist/esm/helpers/getDynamicVal.js +0 -46
  760. package/dist/esm/helpers/getDynamicVal.js.map +0 -6
  761. package/dist/esm/helpers/getExpandedShorthands.js +0 -18
  762. package/dist/esm/helpers/getExpandedShorthands.js.map +0 -6
  763. package/dist/esm/helpers/getFontLanguage.js +0 -5
  764. package/dist/esm/helpers/getFontLanguage.js.map +0 -6
  765. package/dist/esm/helpers/getGroupPropParts.js +0 -19
  766. package/dist/esm/helpers/getGroupPropParts.js.map +0 -6
  767. package/dist/esm/helpers/getShorthandValue.js +0 -7
  768. package/dist/esm/helpers/getShorthandValue.js.map +0 -6
  769. package/dist/esm/helpers/getSplitStyles.js +0 -650
  770. package/dist/esm/helpers/getSplitStyles.js.map +0 -6
  771. package/dist/esm/helpers/getThemeCSSRules.js +0 -78
  772. package/dist/esm/helpers/getThemeCSSRules.js.map +0 -6
  773. package/dist/esm/helpers/getVariantExtras.js +0 -44
  774. package/dist/esm/helpers/getVariantExtras.js.map +0 -6
  775. package/dist/esm/helpers/insertStyleRule.js +0 -181
  776. package/dist/esm/helpers/insertStyleRule.js.map +0 -6
  777. package/dist/esm/helpers/isActivePlatform.js +0 -15
  778. package/dist/esm/helpers/isActivePlatform.js.map +0 -6
  779. package/dist/esm/helpers/isActiveTheme.js +0 -8
  780. package/dist/esm/helpers/isActiveTheme.js.map +0 -6
  781. package/dist/esm/helpers/isObj.js +0 -5
  782. package/dist/esm/helpers/isObj.js.map +0 -6
  783. package/dist/esm/helpers/isTamaguiComponent.js +0 -8
  784. package/dist/esm/helpers/isTamaguiComponent.js.map +0 -6
  785. package/dist/esm/helpers/isTamaguiElement.js +0 -7
  786. package/dist/esm/helpers/isTamaguiElement.js.map +0 -6
  787. package/dist/esm/helpers/log.js +0 -17
  788. package/dist/esm/helpers/log.js.map +0 -6
  789. package/dist/esm/helpers/mainThreadPressEvents.js +0 -6
  790. package/dist/esm/helpers/mainThreadPressEvents.js.map +0 -6
  791. package/dist/esm/helpers/matchMedia.js +0 -18
  792. package/dist/esm/helpers/matchMedia.js.map +0 -6
  793. package/dist/esm/helpers/mergeProps.js +0 -39
  794. package/dist/esm/helpers/mergeProps.js.map +0 -6
  795. package/dist/esm/helpers/mergeRenderElementProps.js +0 -9
  796. package/dist/esm/helpers/mergeRenderElementProps.js.map +0 -6
  797. package/dist/esm/helpers/mergeSlotStyleProps.js +0 -14
  798. package/dist/esm/helpers/mergeSlotStyleProps.js.map +0 -6
  799. package/dist/esm/helpers/mergeVariants.js +0 -22
  800. package/dist/esm/helpers/mergeVariants.js.map +0 -6
  801. package/dist/esm/helpers/nativeOnlyProps.js +0 -39
  802. package/dist/esm/helpers/nativeOnlyProps.js.map +0 -6
  803. package/dist/esm/helpers/normalizeColor.js +0 -10
  804. package/dist/esm/helpers/normalizeColor.js.map +0 -6
  805. package/dist/esm/helpers/normalizeShadow.js +0 -24
  806. package/dist/esm/helpers/normalizeShadow.js.map +0 -6
  807. package/dist/esm/helpers/normalizeStyle.js +0 -24
  808. package/dist/esm/helpers/normalizeStyle.js.map +0 -6
  809. package/dist/esm/helpers/normalizeStylePropKeys.js +0 -5
  810. package/dist/esm/helpers/normalizeStylePropKeys.js.map +0 -6
  811. package/dist/esm/helpers/normalizeValueWithProperty.js +0 -17
  812. package/dist/esm/helpers/normalizeValueWithProperty.js.map +0 -6
  813. package/dist/esm/helpers/objectIdentityKey.js +0 -22
  814. package/dist/esm/helpers/objectIdentityKey.js.map +0 -6
  815. package/dist/esm/helpers/parseBorderShorthand.js +0 -6
  816. package/dist/esm/helpers/parseBorderShorthand.js.map +0 -6
  817. package/dist/esm/helpers/pointerEvents.js +0 -6
  818. package/dist/esm/helpers/pointerEvents.js.map +0 -6
  819. package/dist/esm/helpers/propMapper.js +0 -251
  820. package/dist/esm/helpers/propMapper.js.map +0 -6
  821. package/dist/esm/helpers/proxyThemeToParents.js +0 -24
  822. package/dist/esm/helpers/proxyThemeToParents.js.map +0 -6
  823. package/dist/esm/helpers/proxyThemeVariables.js +0 -15
  824. package/dist/esm/helpers/proxyThemeVariables.js.map +0 -6
  825. package/dist/esm/helpers/pseudoDescriptors.js +0 -56
  826. package/dist/esm/helpers/pseudoDescriptors.js.map +0 -6
  827. package/dist/esm/helpers/registerCSSVariable.js +0 -31
  828. package/dist/esm/helpers/registerCSSVariable.js.map +0 -6
  829. package/dist/esm/helpers/resolveRem.js +0 -11
  830. package/dist/esm/helpers/resolveRem.js.map +0 -6
  831. package/dist/esm/helpers/resolveSafeArea.js +0 -13
  832. package/dist/esm/helpers/resolveSafeArea.js.map +0 -6
  833. package/dist/esm/helpers/setElementProps.js +0 -8
  834. package/dist/esm/helpers/setElementProps.js.map +0 -6
  835. package/dist/esm/helpers/skipProps.js +0 -23
  836. package/dist/esm/helpers/skipProps.js.map +0 -6
  837. package/dist/esm/helpers/sortString.js +0 -5
  838. package/dist/esm/helpers/sortString.js.map +0 -6
  839. package/dist/esm/helpers/subscribeToContextGroup.js +0 -59
  840. package/dist/esm/helpers/subscribeToContextGroup.js.map +0 -6
  841. package/dist/esm/helpers/themeable.js +0 -35
  842. package/dist/esm/helpers/themeable.js.map +0 -6
  843. package/dist/esm/helpers/themes.js +0 -17
  844. package/dist/esm/helpers/themes.js.map +0 -6
  845. package/dist/esm/helpers/timer.js +0 -11
  846. package/dist/esm/helpers/timer.js.map +0 -6
  847. package/dist/esm/helpers/transformsToString.js +0 -17
  848. package/dist/esm/helpers/transformsToString.js.map +0 -6
  849. package/dist/esm/helpers/useRenderElement.js +0 -28
  850. package/dist/esm/helpers/useRenderElement.js.map +0 -6
  851. package/dist/esm/helpers/webPropsToSkip.js +0 -5
  852. package/dist/esm/helpers/webPropsToSkip.js.map +0 -6
  853. package/dist/esm/helpers/wrapStyleTags.js +0 -23
  854. package/dist/esm/helpers/wrapStyleTags.js.map +0 -6
  855. package/dist/esm/hooks/doesRootSchemeMatchSystem.js +0 -7
  856. package/dist/esm/hooks/doesRootSchemeMatchSystem.js.map +0 -6
  857. package/dist/esm/hooks/getThemeProxied.js +0 -44
  858. package/dist/esm/hooks/getThemeProxied.js.map +0 -6
  859. package/dist/esm/hooks/useComponentState.js +0 -91
  860. package/dist/esm/hooks/useComponentState.js.map +0 -6
  861. package/dist/esm/hooks/useDisableSSR.js +0 -8
  862. package/dist/esm/hooks/useDisableSSR.js.map +0 -6
  863. package/dist/esm/hooks/useIsTouchDevice.js +0 -7
  864. package/dist/esm/hooks/useIsTouchDevice.js.map +0 -6
  865. package/dist/esm/hooks/useMedia.js +0 -172
  866. package/dist/esm/hooks/useMedia.js.map +0 -6
  867. package/dist/esm/hooks/useProps.js +0 -92
  868. package/dist/esm/hooks/useProps.js.map +0 -6
  869. package/dist/esm/hooks/useTheme.js +0 -21
  870. package/dist/esm/hooks/useTheme.js.map +0 -6
  871. package/dist/esm/hooks/useThemeName.js +0 -9
  872. package/dist/esm/hooks/useThemeName.js.map +0 -6
  873. package/dist/esm/hooks/useThemeState.js +0 -212
  874. package/dist/esm/hooks/useThemeState.js.map +0 -6
  875. package/dist/esm/inject-styles.js +0 -12
  876. package/dist/esm/inject-styles.js.map +0 -6
  877. package/dist/esm/insertFont.js +0 -56
  878. package/dist/esm/insertFont.js.map +0 -6
  879. package/dist/esm/interfaces/CSSColorNames.js +0 -1
  880. package/dist/esm/interfaces/CSSColorNames.js.map +0 -6
  881. package/dist/esm/interfaces/GetRef.js +0 -1
  882. package/dist/esm/interfaces/GetRef.js.map +0 -6
  883. package/dist/esm/interfaces/RNExclusiveTypes.js +0 -1
  884. package/dist/esm/interfaces/RNExclusiveTypes.js.map +0 -6
  885. package/dist/esm/interfaces/TamaguiComponentEvents.js +0 -1
  886. package/dist/esm/interfaces/TamaguiComponentEvents.js.map +0 -6
  887. package/dist/esm/interfaces/TamaguiComponentPropsBaseBase.js +0 -1
  888. package/dist/esm/interfaces/TamaguiComponentPropsBaseBase.js.map +0 -6
  889. package/dist/esm/setupHooks.js +0 -9
  890. package/dist/esm/setupHooks.js.map +0 -6
  891. package/dist/esm/setupReactNative.js +0 -27
  892. package/dist/esm/setupReactNative.js.map +0 -6
  893. package/dist/esm/styled.js +0 -102
  894. package/dist/esm/styled.js.map +0 -6
  895. package/dist/esm/styledHtml.test-d.js +0 -137
  896. package/dist/esm/styledHtml.test-d.js.map +0 -6
  897. package/dist/esm/type-utils.js +0 -1
  898. package/dist/esm/type-utils.js.map +0 -6
  899. package/dist/esm/types.js +0 -1
  900. package/dist/esm/types.js.map +0 -6
  901. package/dist/esm/views/Configuration.js +0 -12
  902. package/dist/esm/views/Configuration.js.map +0 -6
  903. package/dist/esm/views/FontLanguage.js +0 -16
  904. package/dist/esm/views/FontLanguage.js.map +0 -6
  905. package/dist/esm/views/Slot.js +0 -43
  906. package/dist/esm/views/Slot.js.map +0 -6
  907. package/dist/esm/views/Stack.js +0 -13
  908. package/dist/esm/views/Stack.js.map +0 -6
  909. package/dist/esm/views/Stack.mjs +0 -11
  910. package/dist/esm/views/Stack.mjs.map +0 -1
  911. package/dist/esm/views/Stack.native.js +0 -11
  912. package/dist/esm/views/Stack.native.js.map +0 -1
  913. package/dist/esm/views/TamaguiProvider.js +0 -77
  914. package/dist/esm/views/TamaguiProvider.js.map +0 -6
  915. package/dist/esm/views/Text.js +0 -44
  916. package/dist/esm/views/Text.js.map +0 -6
  917. package/dist/esm/views/Theme.js +0 -110
  918. package/dist/esm/views/Theme.js.map +0 -6
  919. package/dist/esm/views/ThemeDebug.js +0 -69
  920. package/dist/esm/views/ThemeDebug.js.map +0 -6
  921. package/dist/esm/views/ThemeProvider.js +0 -31
  922. package/dist/esm/views/ThemeProvider.js.map +0 -6
  923. package/dist/esm/views/View.js +0 -12
  924. package/dist/esm/views/View.js.map +0 -6
  925. package/types/constants/webToNativeProps.d.ts.map +0 -1
  926. package/types/constants/webToNativeProps.native.d.ts.map +0 -1
  927. package/types/createTheme.d.ts.map +0 -1
  928. package/types/helpers/expandStyle.native.d.ts.map +0 -1
  929. package/types/helpers/propMapper.native.d.ts.map +0 -1
  930. package/types/views/Stack.d.ts.map +0 -1
@@ -1,702 +0,0 @@
1
- import { composeRefs } from "@tamagui/compose-refs";
2
- import { isClient, isServer, isWeb, useIsomorphicLayoutEffect } from "@tamagui/constants";
3
- import { composeEventHandlers } from "@tamagui/helpers";
4
- import { isEqualShallow } from "@tamagui/is-equal-shallow";
5
- import React, { useMemo } from "react";
6
- import { devConfig, getConfig } from "./config";
7
- import { isDevTools } from "./constants/isDevTools";
8
- import { ComponentContext } from "./contexts/ComponentContext";
9
- import { GroupContext } from "./contexts/GroupContext";
10
- import { didGetVariableValue, setDidGetVariableValue } from "./createVariable";
11
- import { defaultComponentStateMounted } from "./defaultComponentState";
12
- import { getWebEvents } from "./eventHandling";
13
- import { getDefaultProps } from "./helpers/getDefaultProps";
14
- import { getSplitStyles, useSplitStyles } from "./helpers/getSplitStyles";
15
- import { log } from "./helpers/log";
16
- import { usePointerEvents } from "./helpers/pointerEvents";
17
- import { mergeComponentProps } from "./helpers/mergeProps";
18
- import { mergeRenderElementProps } from "./helpers/mergeRenderElementProps";
19
- import { objectIdentityKey } from "./helpers/objectIdentityKey";
20
- import { setElementProps } from "./helpers/setElementProps";
21
- import { subscribeToContextGroup } from "./helpers/subscribeToContextGroup";
22
- import { themeable } from "./helpers/themeable";
23
- import { getStyleTags } from "./helpers/wrapStyleTags";
24
- import { useComponentState } from "./hooks/useComponentState";
25
- import { setMediaShouldUpdate, useMedia } from "./hooks/useMedia";
26
- import { useThemeWithState } from "./hooks/useTheme";
27
- import { hooks } from "./setupHooks";
28
- import { Slot } from "./views/Slot";
29
- import { getThemedChildren } from "./views/Theme";
30
- import { Fragment, jsx, jsxs } from "react/jsx-runtime";
31
- let time, debugKeyListeners, startVisualizer;
32
- const componentSetStates = /* @__PURE__ */ new Set(), avoidReRenderKeys = /* @__PURE__ */ new Set([
33
- "hover",
34
- "press",
35
- "pressIn",
36
- "group",
37
- "focus",
38
- "focusWithin",
39
- "media",
40
- "group"
41
- ]);
42
- if (typeof window < "u") {
43
- const cancelPresses = () => {
44
- componentSetStates.forEach(
45
- (setState) => setState((prev) => prev.press || prev.pressIn ? {
46
- ...prev,
47
- press: !1,
48
- pressIn: !1
49
- } : prev)
50
- ), componentSetStates.clear();
51
- }, cancelTouches = () => {
52
- componentSetStates.forEach(
53
- (setState) => setState((prev) => prev.press || prev.pressIn || prev.hover ? {
54
- ...prev,
55
- press: !1,
56
- pressIn: !1,
57
- hover: !1
58
- } : prev)
59
- ), componentSetStates.clear();
60
- };
61
- addEventListener("mouseup", cancelPresses), addEventListener("touchend", cancelTouches), addEventListener("touchcancel", cancelTouches), process.env.NODE_ENV === "development" && (startVisualizer = () => {
62
- const devVisualizerConfig = devConfig?.visualizer;
63
- if (devVisualizerConfig && !globalThis.__tamaguiDevVisualizer) {
64
- let show = function(val) {
65
- clearTimeout(tm), isShowing = val, debugKeyListeners?.forEach((l) => l(val)), !val && resizeListener && (window.removeEventListener("resize", resizeListener), resizeListener = null);
66
- }, cancelShow = function() {
67
- clearTimeout(tm), resizeListener && (window.removeEventListener("resize", resizeListener), resizeListener = null);
68
- };
69
- globalThis.__tamaguiDevVisualizer = !0, debugKeyListeners = /* @__PURE__ */ new Set();
70
- let tm, isShowing = !1, resizeListener = null;
71
- const options = {
72
- key: "Alt",
73
- delay: 800,
74
- ...typeof devVisualizerConfig == "object" ? devVisualizerConfig : {}
75
- };
76
- window.addEventListener("blur", () => {
77
- show(!1);
78
- }), window.addEventListener("keydown", ({ key, metaKey, defaultPrevented }) => {
79
- clearTimeout(tm), !defaultPrevented && (metaKey || key === options.key && (resizeListener || (resizeListener = () => cancelShow(), window.addEventListener("resize", resizeListener)), tm = setTimeout(() => {
80
- show(!0);
81
- }, options.delay)));
82
- }), window.addEventListener("keyup", ({ defaultPrevented }) => {
83
- defaultPrevented || (cancelShow(), isShowing && show(!1));
84
- });
85
- }
86
- });
87
- }
88
- let BaseText, BaseView;
89
- const lastInteractionWasKeyboard = { value: !1 }, lastInteractionWasTouch = { value: !1 };
90
- isWeb && typeof document < "u" && (document.addEventListener("keydown", () => {
91
- lastInteractionWasKeyboard.value || (lastInteractionWasKeyboard.value = !0);
92
- }), document.addEventListener("mousedown", () => {
93
- lastInteractionWasKeyboard.value && (lastInteractionWasKeyboard.value = !1);
94
- }), document.addEventListener("mousemove", () => {
95
- lastInteractionWasKeyboard.value && (lastInteractionWasKeyboard.value = !1), lastInteractionWasTouch.value = !1;
96
- }), document.addEventListener("touchstart", () => {
97
- lastInteractionWasTouch.value = !0;
98
- }));
99
- function createComponent(staticConfig) {
100
- let config = null;
101
- const { Component, isText, isHOC } = staticConfig, component = React.forwardRef((propsIn, forwardedRef) => {
102
- config ||= getConfig();
103
- const internalID = process.env.NODE_ENV === "development" ? React.useId() : "";
104
- 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);
105
- const { context, isReactNative } = staticConfig, debugProp = propsIn.debug, styledContextValue = context ? React.useContext(context) : void 0;
106
- let overriddenContextProps = null;
107
- const componentContext = React.useContext(ComponentContext), hasTextAncestor = !!(isWeb && isText && componentContext.inText);
108
- !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)`;
109
- let props = propsIn;
110
- const componentName = props.componentName || staticConfig.componentName, defaultProps = getDefaultProps(
111
- staticConfig,
112
- props.componentName,
113
- isText && hasTextAncestor
114
- ), [nextProps, overrides] = mergeComponentProps(
115
- defaultProps,
116
- styledContextValue,
117
- propsIn
118
- );
119
- props = nextProps, overriddenContextProps = overrides, process.env.NODE_ENV === "development" && isClient && React.useEffect(() => {
120
- let node, overlay = null;
121
- const remove = () => {
122
- if (overlay)
123
- try {
124
- overlay.parentNode?.removeChild(overlay), overlay = null;
125
- } catch {
126
- }
127
- }, debugVisualizerHandler = (show = !1) => {
128
- if (node = stateRef.current.host, !!node)
129
- if (show) {
130
- 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");
131
- const dataAt = node.getAttribute("data-at") || "", dataIn = node.getAttribute("data-in") || "", tooltip = document.createElement("span");
132
- 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);
133
- } else
134
- remove();
135
- };
136
- return debugKeyListeners ||= /* @__PURE__ */ new Set(), debugKeyListeners.add(debugVisualizerHandler), () => {
137
- remove(), debugKeyListeners?.delete(debugVisualizerHandler);
138
- };
139
- }, [componentName]);
140
- const groupContextParent = React.useContext(GroupContext), animationDriver = (() => {
141
- if (props.animatedBy && config?.animations) {
142
- const animations = config.animations;
143
- return "default" in animations ? animations[props.animatedBy] ?? animations.default : props.animatedBy === "default" ? animations : null;
144
- }
145
- return componentContext.animationDriver;
146
- })(), useAnimations = animationDriver?.useAnimations, componentState = useComponentState(
147
- props,
148
- animationDriver?.isStub ? null : animationDriver,
149
- staticConfig,
150
- config
151
- ), {
152
- disabled,
153
- groupName,
154
- hasAnimationProp,
155
- hasEnterStyle,
156
- isAnimated,
157
- isExiting,
158
- isHydrated,
159
- presence,
160
- presenceState,
161
- setState,
162
- noClass,
163
- state,
164
- stateRef,
165
- supportsCSS,
166
- willBeAnimated,
167
- willBeAnimatedClient,
168
- startedUnhydrated
169
- } = componentState;
170
- hasAnimationProp && animationDriver?.avoidReRenders && useIsomorphicLayoutEffect(() => {
171
- const pendingState = stateRef.current.nextState;
172
- pendingState && (stateRef.current.nextState = void 0, componentState.setStateShallow(pendingState));
173
- });
174
- const allGroupContexts = useMemo(() => {
175
- if (!groupName || props.passThrough)
176
- return groupContextParent;
177
- const listeners = /* @__PURE__ */ new Set();
178
- return stateRef.current.group?.listeners?.clear(), stateRef.current.group = {
179
- listeners,
180
- emit(state2) {
181
- listeners.forEach((l) => l(state2));
182
- },
183
- subscribe(cb) {
184
- return listeners.add(cb), listeners.size === 1 && setStateShallow({ hasDynGroupChildren: !0 }), () => {
185
- listeners.delete(cb), listeners.size === 0 && setStateShallow({ hasDynGroupChildren: !1 });
186
- };
187
- }
188
- }, {
189
- ...groupContextParent,
190
- [groupName]: {
191
- state: {
192
- pseudo: defaultComponentStateMounted
193
- },
194
- subscribe: (listener) => {
195
- const dispose = stateRef.current.group?.subscribe(listener);
196
- return () => {
197
- dispose?.();
198
- };
199
- }
200
- }
201
- };
202
- }, [stateRef, groupName, groupContextParent]);
203
- let setStateShallow = componentState.setStateShallow;
204
- process.env.NODE_ENV === "development" && time && time`use-state`;
205
- const isTaggable = !Component || typeof Component == "string", renderProp = props.render, element = isWeb && isTaggable && renderProp || Component, BaseTextComponent = BaseText || element || "span", BaseViewComponent = BaseView || element || (hasTextAncestor ? "span" : "div");
206
- let elementType = isText ? BaseTextComponent : BaseViewComponent;
207
- animationDriver && isAnimated && // this should really be behind another prop as it's not really related to
208
- // "needsWebStyles" basically with motion we just animate a plain div, but
209
- // we still have animated.View/Text for Sheet which wants to control
210
- // things declaratively
211
- !animationDriver.needsWebStyles && (elementType = animationDriver[isText ? "Text" : "View"] || elementType);
212
- const disableTheme = props["data-disable-theme"] || isHOC;
213
- process.env.NODE_ENV === "development" && time && time`theme-props`;
214
- const themeStateProps = {
215
- componentName,
216
- disable: disableTheme,
217
- shallow: props.themeShallow,
218
- debug: debugProp,
219
- unstyled: props.unstyled
220
- };
221
- if ("theme" in props && (themeStateProps.name = props.theme), themeStateProps.needsUpdate = () => !!stateRef.current.isListeningToTheme, process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile") {
222
- const name = `${componentName || Component?.displayName || Component?.name || "[Unnamed Component]"}`, 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)" : ""), dataIs = propsIn["data-is"] || "", banner = `<${name} /> ${internalID} ${dataIs ? ` ${dataIs}` : ""} ${type.trim()} (hydrated: ${isHydrated}) (unmounted: ${state.unmounted})`, ch = propsIn.children;
223
- let childLog = typeof ch == "string" ? ch.length > 4 ? ch.slice(0, 4) + "..." : ch : "";
224
- childLog.length && (childLog = `(children: ${childLog})`), isWeb ? (console.info(`%c ${banner}`, "background: green; color: white;"), isServer ? log({ noClass, isAnimated, isWeb, supportsCSS }) : (console.groupEnd(), console.groupCollapsed(`${childLog} [inspect props, state, context \u{1F447}]`), log("props in:", propsIn), log("final props:", props, Object.keys(props)), log({ state, staticConfig, elementType, themeStateProps }), log({
225
- context,
226
- overriddenContextProps,
227
- componentContext
228
- }), log({ presence, isAnimated, isHOC, hasAnimationProp, useAnimations }), console.groupEnd())) : (console.info(
229
- `
230
-
231
- ------------------------------
232
- ${banner}
233
- ------------------------------
234
- `
235
- ), log("children:", props.children), log({ overriddenContextProps, styledContextValue }), log({ noClass, isAnimated, isWeb, supportsCSS }));
236
- }
237
- process.env.NODE_ENV === "development" && time && time`pre-theme-media`;
238
- const [theme, themeState] = useThemeWithState(themeStateProps);
239
- process.env.NODE_ENV === "development" && time && time`theme`, elementType = element || elementType;
240
- const isStringElement = typeof elementType == "string", mediaState = useMedia(componentContext, debugProp);
241
- setDidGetVariableValue(!1), process.env.NODE_ENV === "development" && time && time`media`;
242
- const resolveValues = (
243
- // if HOC + mounted + has animation prop, resolve as value so it passes non-variable to child
244
- isAnimated && !supportsCSS || isHOC && state.unmounted == !1 && hasAnimationProp ? "value" : "auto"
245
- ), styleProps = {
246
- mediaState,
247
- noClass,
248
- resolveValues,
249
- isExiting,
250
- isAnimated,
251
- willBeAnimated,
252
- styledContext: styledContextValue
253
- }, themeName = themeState?.name || "";
254
- process.env.NODE_ENV === "development" && time && time`split-styles-prepare`;
255
- const splitStyles = useSplitStyles(
256
- props,
257
- staticConfig,
258
- theme,
259
- themeName,
260
- state,
261
- styleProps,
262
- null,
263
- componentContext,
264
- allGroupContexts,
265
- elementType,
266
- startedUnhydrated,
267
- debugProp
268
- ), isPassthrough = !splitStyles;
269
- let contextForOverride = staticConfig.context;
270
- if (splitStyles?.overriddenContextProps) {
271
- const contextForProps = staticConfig.context || staticConfig.parentStaticConfig?.context;
272
- if (contextForProps) {
273
- for (const key in splitStyles.overriddenContextProps)
274
- overriddenContextProps ||= {}, overriddenContextProps[key] = splitStyles.overriddenContextProps[key];
275
- staticConfig.context || (contextForOverride = contextForProps);
276
- }
277
- }
278
- const groupContext = groupName && allGroupContexts?.[groupName] || null;
279
- if (!isPassthrough && groupContext && // avoids onLayout if we don't need it
280
- props.containerType !== "normal") {
281
- const groupState = groupContext?.state;
282
- groupState && groupState.layout === void 0 && (splitStyles.style?.width || splitStyles.style?.height) && (groupState.layout = {
283
- width: fromPx(splitStyles.style.width),
284
- height: fromPx(splitStyles.style.height)
285
- });
286
- }
287
- if (!isPassthrough && (hasAnimationProp || groupName) && animationDriver?.avoidReRenders) {
288
- let updateGroupListeners = function() {
289
- const updatedState = stateRef.current.nextState;
290
- if (groupContext) {
291
- const {
292
- group,
293
- hasDynGroupChildren,
294
- unmounted,
295
- transition,
296
- ...childrenGroupState
297
- } = updatedState;
298
- notifyGroupSubscribers(
299
- groupContext,
300
- stateRef.current.group || null,
301
- childrenGroupState
302
- );
303
- }
304
- };
305
- const ogSetStateShallow = setStateShallow;
306
- if (stateRef.current.updateStyleListener = () => {
307
- const useStyleListener = stateRef.current.useStyleListener;
308
- if (!useStyleListener) {
309
- const pendingState = stateRef.current.nextState;
310
- pendingState && (stateRef.current.nextState = void 0, ogSetStateShallow(pendingState));
311
- return;
312
- }
313
- const updatedState = stateRef.current.nextState || state, mediaState2 = stateRef.current.nextMedia, nextStyles = getSplitStyles(
314
- props,
315
- staticConfig,
316
- theme,
317
- themeName,
318
- updatedState,
319
- mediaState2 ? { ...styleProps, mediaState: mediaState2 } : styleProps,
320
- null,
321
- componentContext,
322
- allGroupContexts,
323
- elementType,
324
- startedUnhydrated,
325
- debugProp
326
- );
327
- useStyleListener(nextStyles?.style || {});
328
- }, componentContext.mediaEmitListeners ||= /* @__PURE__ */ new Set(), !stateRef.current.mediaEmitCleanup) {
329
- const updateListener = (next) => {
330
- stateRef.current.nextMedia = next, stateRef.current.updateStyleListener?.();
331
- };
332
- componentContext.mediaEmitListeners.add(updateListener), stateRef.current.mediaEmitCleanup = () => {
333
- componentContext.mediaEmitListeners?.delete(updateListener);
334
- };
335
- }
336
- componentContext.mediaEmit ||= (next) => {
337
- for (const listener of componentContext.mediaEmitListeners)
338
- listener(next);
339
- }, stateRef.current.setStateShallow = (nextOrGetNext) => {
340
- const prev = stateRef.current.nextState || state, next = typeof nextOrGetNext == "function" ? nextOrGetNext(prev) : nextOrGetNext;
341
- if (next === prev || isEqualShallow(prev, next))
342
- return;
343
- const canAvoidReRender = Object.keys(next).every(
344
- (key) => avoidReRenderKeys.has(key)
345
- ), updatedState = {
346
- ...prev,
347
- ...next
348
- };
349
- stateRef.current.nextState = updatedState, canAvoidReRender ? (process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile" && (console.groupCollapsed("[\u26A1\uFE0F] avoid setState", componentName, next, {
350
- updatedState,
351
- props
352
- }), 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", { canAvoidReRender, next }), ogSetStateShallow(next));
353
- }, setStateShallow = (state2) => {
354
- stateRef.current.setStateShallow?.(state2);
355
- };
356
- }
357
- 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));
358
- const hasRuntimeMediaKeys = splitStyles?.hasMedia && splitStyles.hasMedia !== !0, shouldListenForMedia = didGetVariableValue() || hasRuntimeMediaKeys || noClass && splitStyles?.hasMedia === !0, mediaListeningKeys = hasRuntimeMediaKeys ? splitStyles.hasMedia : null;
359
- process.env.NODE_ENV === "development" && debugProp === "verbose" && console.info("useMedia() createComponent", shouldListenForMedia, mediaListeningKeys), setMediaShouldUpdate(componentContext, shouldListenForMedia, mediaListeningKeys);
360
- const {
361
- viewProps: viewPropsIn,
362
- pseudos,
363
- style: splitStylesStyle,
364
- classNames,
365
- pseudoGroups,
366
- mediaGroups
367
- } = splitStyles || {}, propsWithAnimation = props, {
368
- asChild,
369
- children,
370
- themeShallow,
371
- spaceDirection: _spaceDirection,
372
- onPress,
373
- onLongPress,
374
- onPressIn,
375
- onPressOut,
376
- onHoverIn,
377
- onHoverOut,
378
- onMouseUp,
379
- onMouseDown,
380
- onMouseEnter,
381
- onMouseLeave,
382
- onFocus,
383
- onBlur,
384
- separator,
385
- // ignore from here on out
386
- passThrough,
387
- forceStyle: _forceStyle,
388
- // @ts-ignore for next/link compat etc
389
- onClick,
390
- theme: _themeProp,
391
- ...nonTamaguiProps
392
- } = viewPropsIn || {};
393
- let viewProps = nonTamaguiProps;
394
- !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);
395
- let animationStyles;
396
- const shouldUseAnimation = (
397
- // if it supports css vars we run it on server too to get matching initial style
398
- (supportsCSS ? willBeAnimatedClient : willBeAnimated) && useAnimations && !isHOC
399
- );
400
- let animatedRef;
401
- if (shouldUseAnimation) {
402
- const useStyleEmitter = animationDriver?.avoidReRenders ? (listener) => {
403
- stateRef.current.useStyleListener = listener;
404
- } : void 0, animations = useAnimations({
405
- props: propsWithAnimation,
406
- // if hydrating, send empty style
407
- style: splitStylesStyle || {},
408
- // @ts-ignore
409
- styleState: splitStyles,
410
- useStyleEmitter,
411
- presence,
412
- componentState: state,
413
- styleProps,
414
- theme,
415
- themeName,
416
- pseudos: pseudos || null,
417
- staticConfig,
418
- stateRef
419
- });
420
- 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`;
421
- }
422
- process.env.NODE_ENV === "development" && props.untilMeasured && !props.group && console.warn(
423
- `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.
424
-
425
- 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}`
426
- ), process.env.NODE_ENV === "development" && time && time`destructure`, !isPassthrough && groupContext && // avoids onLayout if we don't need it
427
- props.containerType !== "normal" && (nonTamaguiProps.onLayout = composeEventHandlers(
428
- nonTamaguiProps.onLayout,
429
- (e) => {
430
- const layout = e.nativeEvent.layout;
431
- groupContext.state.layout = layout, stateRef.current.group?.emit({
432
- layout
433
- }), !stateRef.current.hasMeasured && props.untilMeasured === "hide" && setState((prev) => ({ ...prev })), stateRef.current.hasMeasured = !0;
434
- }
435
- )), viewProps = hooks.usePropsTransform?.(
436
- elementType,
437
- nonTamaguiProps,
438
- stateRef,
439
- stateRef.current.willHydrate
440
- ) || nonTamaguiProps, stateRef.current.composedRef || (stateRef.current.composedRef = composeRefs(
441
- (x) => stateRef.current.host = x,
442
- forwardedRef,
443
- setElementProps,
444
- animatedRef
445
- )), viewProps.ref = stateRef.current.composedRef, usePointerEvents(props, viewProps), process.env.NODE_ENV === "development" && !isReactNative && !isText && isWeb && !isHOC && React.Children.toArray(props.children).forEach((item) => {
446
- typeof item == "string" && item !== `
447
- ` && console.error(
448
- `Unexpected text node: ${item}. A text node cannot be a child of a <${staticConfig.componentName || propsIn.tag || "View"}>.`,
449
- props
450
- );
451
- }), process.env.NODE_ENV === "development" && time && time`events-hooks`;
452
- const unPress = () => {
453
- setStateShallow({ press: !1, pressIn: !1 });
454
- };
455
- process.env.NODE_ENV === "development" && isWeb && useIsomorphicLayoutEffect(() => {
456
- if (debugProp === "verbose") {
457
- let cssStyleDeclarationToObject = function(style) {
458
- const styleObject = {};
459
- for (let i = 0; i < style.length; i++) {
460
- let prop = style[i];
461
- styleObject[prop] = style.getPropertyValue(prop);
462
- }
463
- return styleObject;
464
- };
465
- const computed = stateRef.current.host ? cssStyleDeclarationToObject(
466
- getComputedStyle(stateRef.current.host)
467
- ) : {};
468
- console.groupCollapsed(`Rendered > (opacity: ${computed.opacity})`), console.warn(stateRef.current.host), console.warn(computed), console.groupEnd();
469
- }
470
- }), useIsomorphicLayoutEffect(() => {
471
- if (state.unmounted === !0 && hasEnterStyle) {
472
- setStateShallow({ unmounted: "should-enter" });
473
- return;
474
- }
475
- if (state.unmounted) {
476
- if (supportsCSS) {
477
- let cancelled = !1;
478
- return requestAnimationFrame(() => {
479
- cancelled || requestAnimationFrame(() => {
480
- cancelled || setStateShallow({ unmounted: !1 });
481
- });
482
- }), () => {
483
- cancelled = !0;
484
- };
485
- }
486
- setStateShallow({ unmounted: !1 });
487
- }
488
- return () => {
489
- componentSetStates.delete(setState), stateRef.current.mediaEmitCleanup?.();
490
- };
491
- }, [state.unmounted, supportsCSS]), useIsomorphicLayoutEffect(() => {
492
- if (!disabled && !(!pseudoGroups && !mediaGroups) && allGroupContexts)
493
- return subscribeToContextGroup({
494
- groupContext: allGroupContexts,
495
- setStateShallow,
496
- mediaGroups,
497
- pseudoGroups
498
- });
499
- }, [
500
- allGroupContexts,
501
- disabled,
502
- pseudoGroups ? objectIdentityKey(pseudoGroups) : 0,
503
- mediaGroups ? objectIdentityKey(mediaGroups) : 0
504
- ]);
505
- const groupEmitter = stateRef.current.group;
506
- useIsomorphicLayoutEffect(() => {
507
- !groupContext || !groupEmitter || notifyGroupSubscribers(groupContext, groupEmitter, state);
508
- }, [groupContext, groupEmitter, state]);
509
- const runtimePressStyle = !disabled && noClass && pseudos?.pressStyle, runtimeFocusStyle = !disabled && noClass && pseudos?.focusStyle, runtimeFocusVisibleStyle = !disabled && noClass && pseudos?.focusVisibleStyle, attachFocus = !!(runtimePressStyle || runtimeFocusStyle || runtimeFocusVisibleStyle || onFocus || onBlur || componentContext.setParentFocusState), hasDynamicGroupChildren = !!(groupName && state.hasDynGroupChildren), attachPress = !!(hasDynamicGroupChildren || runtimePressStyle || onPress || onPressOut || onPressIn || onMouseDown || onMouseUp || onLongPress || onClick || pseudos?.focusVisibleStyle), runtimeHoverStyle = !disabled && noClass && pseudos?.hoverStyle, needsHoverState = !!(hasDynamicGroupChildren || runtimeHoverStyle), attachHover = isWeb && !!(hasDynamicGroupChildren || needsHoverState || onMouseEnter || onMouseLeave), shouldAttach = !disabled && !props.asChild && !!(attachFocus || attachPress || attachHover || runtimePressStyle || runtimeHoverStyle || runtimeFocusStyle), needsPressState = !!(hasDynamicGroupChildren || runtimePressStyle);
510
- process.env.NODE_ENV === "development" && time && time`events-setup`, process.env.NODE_ENV === "development" && debugProp === "verbose" && log("\u{1FAA9} events()", {
511
- runtimeFocusStyle,
512
- runtimePressStyle,
513
- runtimeHoverStyle,
514
- runtimeFocusVisibleStyle,
515
- attachPress,
516
- attachFocus,
517
- attachHover,
518
- shouldAttach,
519
- needsHoverState,
520
- pseudos
521
- });
522
- const events = shouldAttach ? {
523
- onPressOut: attachPress ? (e) => {
524
- unPress(), onPressOut?.(e), onMouseUp?.(e);
525
- } : void 0,
526
- ...(attachHover || attachPress) && {
527
- onMouseEnter: (e) => {
528
- const next = {};
529
- needsHoverState && !lastInteractionWasTouch.value && (next.hover = !0), needsPressState && state.pressIn && (next.press = !0), setStateShallow(next), onHoverIn?.(e), onMouseEnter?.(e);
530
- },
531
- onMouseLeave: (e) => {
532
- const next = {};
533
- needsHoverState && (next.hover = !1), needsPressState && (next.press = !1, next.pressIn = !1), setStateShallow(next), onHoverOut?.(e), onMouseLeave?.(e);
534
- }
535
- },
536
- onPressIn: attachPress ? (e) => {
537
- needsPressState && setStateShallow({
538
- press: !0,
539
- pressIn: !0
540
- }), onPressIn?.(e), onMouseDown?.(e), isWeb && componentSetStates.add(setState);
541
- } : void 0,
542
- onPress: attachPress ? (e) => {
543
- unPress(), isWeb && onClick?.(e), onPress?.(e), onLongPress?.(e);
544
- } : void 0,
545
- ...attachFocus && {
546
- onFocus: (e) => {
547
- const next = {};
548
- componentContext.setParentFocusState && (next.focusWithin = !0), pseudos?.focusVisibleStyle && lastInteractionWasKeyboard.value ? next.focusVisible = !0 : next.focus = !0, setStateShallow(next), onFocus?.(e);
549
- },
550
- onBlur: (e) => {
551
- componentContext.setParentFocusState && componentContext.setParentFocusState({ focusWithin: !1 }), setStateShallow({
552
- focus: !1,
553
- focusVisible: !1,
554
- focusWithin: !1
555
- }), onBlur?.(e);
556
- }
557
- }
558
- } : null;
559
- events && !isReactNative && Object.assign(viewProps, getWebEvents(events)), process.env.NODE_ENV === "development" && time && time`events`, process.env.NODE_ENV === "development" && debugProp === "verbose" && log("events", { events, attachHover, attachPress });
560
- const pressGesture = null;
561
- process.env.NODE_ENV === "development" && time && time`hooks`;
562
- let content = children;
563
- if (asChild) {
564
- elementType = Slot;
565
- {
566
- const passEvents = getWebEvents(
567
- {
568
- onPress,
569
- onLongPress,
570
- onPressIn,
571
- onPressOut,
572
- onMouseUp,
573
- onMouseDown,
574
- onMouseEnter,
575
- onMouseLeave
576
- },
577
- asChild === "web" || asChild === "except-style-web"
578
- );
579
- Object.assign(viewProps, passEvents);
580
- }
581
- }
582
- process.env.NODE_ENV === "development" && time && time`spaced-as-child`, isPassthrough && (content = propsIn.children, elementType = BaseViewComponent, viewProps = {
583
- style: {
584
- display: "contents"
585
- }
586
- });
587
- let useChildrenResult;
588
- if (hooks.useChildren && (useChildrenResult = hooks.useChildren(elementType, content, viewProps)), process.env.NODE_ENV === "development" && time && time`use-children`, useChildrenResult)
589
- content = useChildrenResult;
590
- else if (typeof renderProp == "function") {
591
- const renderProps = { ...viewProps, children: content };
592
- content = renderProp(renderProps, state);
593
- } else if (renderProp && typeof renderProp == "object" && React.isValidElement(renderProp)) {
594
- const elementProps = renderProp.props || {}, mergedProps = mergeRenderElementProps(elementProps, viewProps, content);
595
- content = React.cloneElement(renderProp, mergedProps);
596
- } else
597
- content = React.createElement(elementType, viewProps, content);
598
- const ResetPresence = animationDriver?.ResetPresence, needsReset = !!// not when passing down to child
599
- (!asChild && // not when passThrough
600
- splitStyles && // not when HOC
601
- !isHOC && ResetPresence && willBeAnimated && (hasEnterStyle || presenceState)), hasEverReset = stateRef.current.hasEverResetPresence;
602
- if (needsReset && !hasEverReset && (stateRef.current.hasEverResetPresence = !0), (needsReset || hasEverReset) && ResetPresence && (content = /* @__PURE__ */ jsx(ResetPresence, { disabled: !needsReset, children: content })), process.env.NODE_ENV === "development" && time && time`create-element`, "focusWithinStyle" in propsIn && (content = /* @__PURE__ */ jsx(
603
- ComponentContext.Provider,
604
- {
605
- ...componentContext,
606
- setParentFocusState: setStateShallow,
607
- children: content
608
- }
609
- )), "group" in props && (content = /* @__PURE__ */ jsx(GroupContext.Provider, { value: allGroupContexts, children: content })), !asChild && isText && !hasTextAncestor && (content = /* @__PURE__ */ jsx(ComponentContext.Provider, { ...componentContext, inText: !0, children: content })), 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(
610
- "span",
611
- {
612
- className: "_dsp_contents",
613
- ...!isPassthrough && isHydrated && events && getWebEvents(events),
614
- children: content
615
- }
616
- )), overriddenContextProps && contextForOverride) {
617
- const Provider = contextForOverride.Provider;
618
- for (const key in styledContextValue)
619
- key in overriddenContextProps || (overriddenContextProps[key] = styledContextValue[key]);
620
- content = /* @__PURE__ */ jsx(Provider, { __disableMergeDefaultValues: !0, ...overriddenContextProps, children: content });
621
- }
622
- if (process.env.NODE_ENV === "development" && time && time`context-override`, startedUnhydrated && splitStyles && (content = /* @__PURE__ */ jsxs(Fragment, { children: [
623
- content,
624
- isHydrated ? null : getStyleTags(Object.values(splitStyles.rulesToInsert))
625
- ] })), process.env.NODE_ENV === "development" && time && time`style-tags`, process.env.NODE_ENV === "development" && debugProp && debugProp !== "profile") {
626
- const title = `render <${typeof elementType == "string" ? elementType : "Component"} /> (${internalID}) with props`;
627
- if (!isWeb || !isClient) {
628
- log(title), log("state: ", state), isDevTools && log("viewProps", viewProps), log("final styles:");
629
- for (const key in splitStylesStyle)
630
- log(key, splitStylesStyle[key]);
631
- } else {
632
- console.groupCollapsed(title);
633
- try {
634
- log("viewProps", viewProps), log("children", content), typeof window < "u" && log({
635
- propsIn,
636
- props,
637
- attachPress,
638
- animationStyles,
639
- classNames,
640
- content,
641
- elementType,
642
- events,
643
- isAnimated,
644
- hasRuntimeMediaKeys,
645
- isStringElement,
646
- mediaListeningKeys,
647
- pseudos,
648
- shouldAttach,
649
- noClass,
650
- shouldListenForMedia,
651
- splitStyles,
652
- splitStylesStyle,
653
- state,
654
- stateRef,
655
- staticConfig,
656
- styleProps,
657
- themeState,
658
- viewProps,
659
- willBeAnimated,
660
- startedUnhydrated
661
- });
662
- } catch {
663
- } finally {
664
- console.groupEnd();
665
- }
666
- }
667
- }
668
- return process.env.NODE_ENV === "development" && time && (time`rest`, globalThis.willPrint || (globalThis.willPrint = !0, setTimeout(() => {
669
- delete globalThis.willPrint, time.print(), time = null;
670
- }, 50))), content;
671
- });
672
- function notifyGroupSubscribers(groupContext, groupEmitter, pseudo) {
673
- if (!groupContext || !groupEmitter)
674
- return;
675
- const nextState = { ...groupContext.state, pseudo };
676
- groupEmitter.emit(nextState), groupContext.state = nextState;
677
- }
678
- staticConfig.componentName && (component.displayName = staticConfig.componentName);
679
- let res = component;
680
- res = React.memo(res), res.staticConfig = staticConfig;
681
- function extendStyledConfig(extended) {
682
- return {
683
- ...staticConfig,
684
- ...extended,
685
- neverFlatten: !0,
686
- isHOC: !0,
687
- isStyledHOC: !1
688
- };
689
- }
690
- function styleable(Component2, options) {
691
- let out = typeof Component2 == "function" && Component2.length === 1 ? Component2 : React.forwardRef(Component2);
692
- const extendedConfig = extendStyledConfig(options?.staticConfig);
693
- 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;
694
- }
695
- return res.styleable = styleable, res;
696
- }
697
- const fromPx = (val) => typeof val == "number" ? val : typeof val == "string" ? +val.replace("px", "") : 0;
698
- export {
699
- componentSetStates,
700
- createComponent
701
- };
702
- //# sourceMappingURL=createComponent.js.map