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

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