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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (930) hide show
  1. package/.turbo/turbo-build.log +2 -0
  2. package/.turbo/turbo-test$colon$web.log +15 -0
  3. package/dist/cjs/Tamagui.cjs +2 -2
  4. package/dist/cjs/Tamagui.native.js +2 -2
  5. package/dist/cjs/Tamagui.native.js.map +1 -1
  6. package/dist/cjs/_withStableStyle.cjs +17 -6
  7. package/dist/cjs/_withStableStyle.native.js +18 -5
  8. package/dist/cjs/_withStableStyle.native.js.map +1 -1
  9. package/dist/cjs/animationDriverTypes.test-d.cjs +11 -0
  10. package/dist/cjs/animationDriverTypes.test-d.native.js +11 -0
  11. package/dist/cjs/animationDriverTypes.test-d.native.js.map +1 -1
  12. package/dist/cjs/config.cjs +5 -1
  13. package/dist/cjs/config.native.js +5 -1
  14. package/dist/cjs/config.native.js.map +1 -1
  15. package/dist/cjs/constants/constants.cjs +2 -16
  16. package/dist/cjs/constants/constants.native.js +1 -14
  17. package/dist/cjs/constants/constants.native.js.map +1 -1
  18. package/dist/cjs/createComponent.cjs +92 -79
  19. package/dist/cjs/createComponent.native.js +112 -88
  20. package/dist/cjs/createComponent.native.js.map +1 -1
  21. package/dist/cjs/createTamagui.cjs +38 -37
  22. package/dist/cjs/createTamagui.native.js +41 -37
  23. package/dist/cjs/createTamagui.native.js.map +1 -1
  24. package/dist/cjs/createVariable.native.js.map +1 -1
  25. package/dist/cjs/eventHandling.cjs +1 -1
  26. package/dist/cjs/eventHandling.native.js +84 -57
  27. package/dist/cjs/eventHandling.native.js.map +1 -1
  28. package/dist/cjs/helpers/createDesignSystem.cjs +44 -7
  29. package/dist/cjs/helpers/createDesignSystem.native.js +36 -6
  30. package/dist/cjs/helpers/createDesignSystem.native.js.map +1 -1
  31. package/dist/cjs/helpers/createMediaStyle.cjs +8 -5
  32. package/dist/cjs/helpers/createMediaStyle.native.js +10 -7
  33. package/dist/cjs/helpers/createMediaStyle.native.js.map +1 -1
  34. package/dist/cjs/helpers/createStyledContext.cjs +11 -7
  35. package/dist/cjs/helpers/createStyledContext.native.js +50 -46
  36. package/dist/cjs/helpers/createStyledContext.native.js.map +1 -1
  37. package/dist/cjs/helpers/defaultAnimationDriver.cjs +0 -2
  38. package/dist/cjs/helpers/defaultAnimationDriver.native.js +0 -2
  39. package/dist/cjs/helpers/defaultAnimationDriver.native.js.map +1 -1
  40. package/dist/cjs/helpers/expandStyle.cjs +2 -1
  41. package/dist/cjs/helpers/expandStyle.native.js +9 -0
  42. package/dist/cjs/helpers/expandStyle.native.js.map +1 -1
  43. package/dist/cjs/helpers/getCSSStylesAtomic.cjs +8 -8
  44. package/dist/cjs/helpers/getDefaultProps.cjs +3 -9
  45. package/dist/cjs/helpers/getDefaultProps.native.js +3 -4
  46. package/dist/cjs/helpers/getDefaultProps.native.js.map +1 -1
  47. package/dist/cjs/helpers/getGroupPropParts.cjs +2 -2
  48. package/dist/cjs/helpers/getGroupPropParts.native.js +2 -2
  49. package/dist/cjs/helpers/getGroupPropParts.native.js.map +1 -1
  50. package/dist/cjs/helpers/getSplitStyles.cjs +59 -28
  51. package/dist/cjs/helpers/getSplitStyles.native.js +114 -77
  52. package/dist/cjs/helpers/getSplitStyles.native.js.map +1 -1
  53. package/dist/cjs/helpers/getThemeCSSRules.cjs +17 -9
  54. package/dist/cjs/helpers/getTokenForKey.cjs +127 -0
  55. package/dist/cjs/helpers/getTokenForKey.native.js +145 -0
  56. package/dist/cjs/helpers/getTokenForKey.native.js.map +1 -0
  57. package/dist/cjs/helpers/insertStyleRule.cjs +1 -1
  58. package/dist/cjs/helpers/insertStyleRule.native.js +1 -1
  59. package/dist/cjs/helpers/mainThreadPressEvents.native.js +63 -16
  60. package/dist/cjs/helpers/mainThreadPressEvents.native.js.map +1 -1
  61. package/dist/cjs/helpers/mediaObjectToString.cjs +35 -0
  62. package/dist/cjs/helpers/mediaObjectToString.native.js +43 -0
  63. package/dist/cjs/helpers/mediaObjectToString.native.js.map +1 -0
  64. package/dist/cjs/helpers/mediaState.cjs +45 -0
  65. package/dist/cjs/helpers/mediaState.native.js +50 -0
  66. package/dist/cjs/helpers/mediaState.native.js.map +1 -0
  67. package/dist/cjs/helpers/normalizeColor.cjs +6 -1
  68. package/dist/cjs/helpers/normalizeValueWithProperty.cjs +2 -1
  69. package/dist/cjs/helpers/normalizeValueWithProperty.native.js +2 -1
  70. package/dist/cjs/helpers/normalizeValueWithProperty.native.js.map +1 -1
  71. package/dist/cjs/helpers/parseNativeStyle.cjs +133 -0
  72. package/dist/cjs/helpers/parseNativeStyle.native.js +151 -0
  73. package/dist/cjs/helpers/parseNativeStyle.native.js.map +1 -0
  74. package/dist/cjs/{createTheme.cjs → helpers/parseOutlineShorthand.cjs} +5 -5
  75. package/dist/cjs/helpers/parseOutlineShorthand.native.js +58 -0
  76. package/dist/cjs/helpers/parseOutlineShorthand.native.js.map +1 -0
  77. package/dist/cjs/helpers/platformResolveValue.cjs +33 -0
  78. package/dist/cjs/helpers/platformResolveValue.native.js +62 -0
  79. package/dist/cjs/helpers/platformResolveValue.native.js.map +1 -0
  80. package/dist/cjs/helpers/propMapper.cjs +26 -96
  81. package/dist/cjs/helpers/propMapper.native.js +61 -108
  82. package/dist/cjs/helpers/propMapper.native.js.map +1 -1
  83. package/dist/cjs/helpers/pseudoTransitions.cjs +65 -0
  84. package/dist/cjs/helpers/pseudoTransitions.native.js +72 -0
  85. package/dist/cjs/helpers/pseudoTransitions.native.js.map +1 -0
  86. package/dist/cjs/{constants/webToNativeProps.cjs → helpers/resolveAnimationDriver.cjs} +7 -7
  87. package/dist/cjs/{views/Stack.native.js → helpers/resolveAnimationDriver.native.js} +9 -14
  88. package/dist/cjs/helpers/resolveAnimationDriver.native.js.map +1 -0
  89. package/dist/cjs/{views/Stack.cjs → helpers/resolveCompoundTokens.cjs} +16 -13
  90. package/dist/cjs/helpers/resolveCompoundTokens.native.js +40 -0
  91. package/dist/cjs/helpers/resolveCompoundTokens.native.js.map +1 -0
  92. package/dist/cjs/helpers/skipProps.cjs +1 -0
  93. package/dist/cjs/helpers/skipProps.native.js +1 -0
  94. package/dist/cjs/helpers/skipProps.native.js.map +1 -1
  95. package/dist/cjs/helpers/themeable.cjs +4 -2
  96. package/dist/cjs/helpers/themeable.native.js +4 -2
  97. package/dist/cjs/helpers/themeable.native.js.map +1 -1
  98. package/dist/cjs/helpers/useRenderElement.native.js +1 -1
  99. package/dist/cjs/helpers/useRenderElement.native.js.map +1 -1
  100. package/dist/cjs/hooks/useComponentState.cjs +9 -5
  101. package/dist/cjs/hooks/useComponentState.native.js +10 -6
  102. package/dist/cjs/hooks/useComponentState.native.js.map +1 -1
  103. package/dist/cjs/hooks/useMedia.cjs +25 -48
  104. package/dist/cjs/hooks/useMedia.native.js +25 -55
  105. package/dist/cjs/hooks/useMedia.native.js.map +1 -1
  106. package/dist/cjs/hooks/useProps.cjs +3 -2
  107. package/dist/cjs/hooks/useProps.native.js +3 -2
  108. package/dist/cjs/hooks/useProps.native.js.map +1 -1
  109. package/dist/cjs/hooks/useTheme.cjs +4 -0
  110. package/dist/cjs/hooks/useTheme.native.js +4 -0
  111. package/dist/cjs/hooks/useTheme.native.js.map +1 -1
  112. package/dist/cjs/hooks/useThemeState.cjs +30 -12
  113. package/dist/cjs/hooks/useThemeState.native.js +28 -12
  114. package/dist/cjs/hooks/useThemeState.native.js.map +1 -1
  115. package/dist/cjs/index.cjs +9 -5
  116. package/dist/cjs/index.native.js +9 -5
  117. package/dist/cjs/index.native.js.map +1 -1
  118. package/dist/cjs/styled.native.js.map +1 -1
  119. package/dist/cjs/views/TamaguiProvider.cjs +20 -33
  120. package/dist/cjs/views/TamaguiProvider.native.js +28 -39
  121. package/dist/cjs/views/TamaguiProvider.native.js.map +1 -1
  122. package/dist/cjs/views/TamaguiRoot.cjs +68 -0
  123. package/dist/cjs/{createTheme.native.js → views/TamaguiRoot.native.js} +8 -8
  124. package/dist/cjs/views/TamaguiRoot.native.js.map +1 -0
  125. package/dist/cjs/views/Text.cjs +2 -10
  126. package/dist/cjs/views/Text.native.js +0 -1
  127. package/dist/cjs/views/Text.native.js.map +1 -1
  128. package/dist/cjs/views/Theme.cjs +2 -0
  129. package/dist/cjs/views/Theme.native.js +2 -0
  130. package/dist/cjs/views/Theme.native.js.map +1 -1
  131. package/dist/cjs/views/ThemeProvider.cjs +3 -1
  132. package/dist/cjs/views/ThemeProvider.native.js +2 -0
  133. package/dist/cjs/views/ThemeProvider.native.js.map +1 -1
  134. package/dist/cjs/views/View.cjs +0 -2
  135. package/dist/cjs/views/View.native.js +0 -2
  136. package/dist/cjs/views/View.native.js.map +1 -1
  137. package/dist/esm/Tamagui.mjs +1 -1
  138. package/dist/esm/Tamagui.native.js +1 -1
  139. package/dist/esm/_withStableStyle.mjs +18 -7
  140. package/dist/esm/_withStableStyle.mjs.map +1 -1
  141. package/dist/esm/_withStableStyle.native.js +19 -6
  142. package/dist/esm/_withStableStyle.native.js.map +1 -1
  143. package/dist/esm/animationDriverTypes.test-d.mjs +11 -0
  144. package/dist/esm/animationDriverTypes.test-d.mjs.map +1 -1
  145. package/dist/esm/animationDriverTypes.test-d.native.js +11 -0
  146. package/dist/esm/animationDriverTypes.test-d.native.js.map +1 -1
  147. package/dist/esm/config.mjs +5 -1
  148. package/dist/esm/config.mjs.map +1 -1
  149. package/dist/esm/config.native.js +5 -1
  150. package/dist/esm/config.native.js.map +1 -1
  151. package/dist/esm/constants/constants.mjs +2 -14
  152. package/dist/esm/constants/constants.mjs.map +1 -1
  153. package/dist/esm/constants/constants.native.js +1 -12
  154. package/dist/esm/constants/constants.native.js.map +1 -1
  155. package/dist/esm/createComponent.mjs +91 -79
  156. package/dist/esm/createComponent.mjs.map +1 -1
  157. package/dist/esm/createComponent.native.js +112 -89
  158. package/dist/esm/createComponent.native.js.map +1 -1
  159. package/dist/esm/createTamagui.mjs +38 -37
  160. package/dist/esm/createTamagui.mjs.map +1 -1
  161. package/dist/esm/createTamagui.native.js +41 -37
  162. package/dist/esm/createTamagui.native.js.map +1 -1
  163. package/dist/esm/createVariable.mjs.map +1 -1
  164. package/dist/esm/eventHandling.mjs +1 -1
  165. package/dist/esm/eventHandling.mjs.map +1 -1
  166. package/dist/esm/eventHandling.native.js +84 -57
  167. package/dist/esm/eventHandling.native.js.map +1 -1
  168. package/dist/esm/helpers/createDesignSystem.mjs +43 -7
  169. package/dist/esm/helpers/createDesignSystem.mjs.map +1 -1
  170. package/dist/esm/helpers/createDesignSystem.native.js +35 -7
  171. package/dist/esm/helpers/createDesignSystem.native.js.map +1 -1
  172. package/dist/esm/helpers/createMediaStyle.mjs +7 -4
  173. package/dist/esm/helpers/createMediaStyle.mjs.map +1 -1
  174. package/dist/esm/helpers/createMediaStyle.native.js +9 -6
  175. package/dist/esm/helpers/createMediaStyle.native.js.map +1 -1
  176. package/dist/esm/helpers/createStyledContext.mjs +12 -8
  177. package/dist/esm/helpers/createStyledContext.mjs.map +1 -1
  178. package/dist/esm/helpers/createStyledContext.native.js +11 -7
  179. package/dist/esm/helpers/createStyledContext.native.js.map +1 -1
  180. package/dist/esm/helpers/defaultAnimationDriver.mjs +0 -2
  181. package/dist/esm/helpers/defaultAnimationDriver.mjs.map +1 -1
  182. package/dist/esm/helpers/defaultAnimationDriver.native.js +0 -2
  183. package/dist/esm/helpers/defaultAnimationDriver.native.js.map +1 -1
  184. package/dist/esm/helpers/expandStyle.mjs +0 -1
  185. package/dist/esm/helpers/expandStyle.mjs.map +1 -1
  186. package/dist/esm/helpers/expandStyle.native.js +9 -1
  187. package/dist/esm/helpers/expandStyle.native.js.map +1 -1
  188. package/dist/esm/helpers/getCSSStylesAtomic.mjs +8 -8
  189. package/dist/esm/helpers/getCSSStylesAtomic.mjs.map +1 -1
  190. package/dist/esm/helpers/getDefaultProps.mjs +3 -9
  191. package/dist/esm/helpers/getDefaultProps.mjs.map +1 -1
  192. package/dist/esm/helpers/getDefaultProps.native.js +3 -4
  193. package/dist/esm/helpers/getDefaultProps.native.js.map +1 -1
  194. package/dist/esm/helpers/getGroupPropParts.mjs +1 -1
  195. package/dist/esm/helpers/getGroupPropParts.native.js +1 -1
  196. package/dist/esm/helpers/getSplitStyles.mjs +59 -29
  197. package/dist/esm/helpers/getSplitStyles.mjs.map +1 -1
  198. package/dist/esm/helpers/getSplitStyles.native.js +113 -77
  199. package/dist/esm/helpers/getSplitStyles.native.js.map +1 -1
  200. package/dist/esm/helpers/getThemeCSSRules.mjs +17 -9
  201. package/dist/esm/helpers/getThemeCSSRules.mjs.map +1 -1
  202. package/dist/esm/helpers/getTokenForKey.mjs +101 -0
  203. package/dist/esm/helpers/getTokenForKey.mjs.map +1 -0
  204. package/dist/esm/helpers/getTokenForKey.native.js +116 -0
  205. package/dist/esm/helpers/getTokenForKey.native.js.map +1 -0
  206. package/dist/esm/helpers/insertStyleRule.mjs +1 -1
  207. package/dist/esm/helpers/insertStyleRule.native.js +1 -1
  208. package/dist/esm/helpers/mainThreadPressEvents.native.js +63 -16
  209. package/dist/esm/helpers/mainThreadPressEvents.native.js.map +1 -1
  210. package/dist/esm/helpers/mediaObjectToString.mjs +12 -0
  211. package/dist/esm/helpers/mediaObjectToString.mjs.map +1 -0
  212. package/dist/esm/helpers/mediaObjectToString.native.js +17 -0
  213. package/dist/esm/helpers/mediaObjectToString.native.js.map +1 -0
  214. package/dist/esm/helpers/mediaState.mjs +18 -0
  215. package/dist/esm/helpers/mediaState.mjs.map +1 -0
  216. package/dist/esm/helpers/mediaState.native.js +20 -0
  217. package/dist/esm/helpers/mediaState.native.js.map +1 -0
  218. package/dist/esm/helpers/normalizeColor.mjs +6 -1
  219. package/dist/esm/helpers/normalizeColor.mjs.map +1 -1
  220. package/dist/esm/helpers/normalizeValueWithProperty.mjs +2 -1
  221. package/dist/esm/helpers/normalizeValueWithProperty.mjs.map +1 -1
  222. package/dist/esm/helpers/normalizeValueWithProperty.native.js +2 -1
  223. package/dist/esm/helpers/normalizeValueWithProperty.native.js.map +1 -1
  224. package/dist/esm/helpers/parseNativeStyle.mjs +110 -0
  225. package/dist/esm/helpers/parseNativeStyle.mjs.map +1 -0
  226. package/dist/esm/helpers/parseNativeStyle.native.js +125 -0
  227. package/dist/esm/helpers/parseNativeStyle.native.js.map +1 -0
  228. package/dist/esm/helpers/parseOutlineShorthand.mjs +3 -0
  229. package/dist/esm/helpers/parseOutlineShorthand.mjs.map +1 -0
  230. package/dist/esm/helpers/parseOutlineShorthand.native.js +32 -0
  231. package/dist/esm/helpers/parseOutlineShorthand.native.js.map +1 -0
  232. package/dist/esm/helpers/platformResolveValue.mjs +10 -0
  233. package/dist/esm/helpers/platformResolveValue.mjs.map +1 -0
  234. package/dist/esm/helpers/platformResolveValue.native.js +36 -0
  235. package/dist/esm/helpers/platformResolveValue.native.js.map +1 -0
  236. package/dist/esm/helpers/propMapper.mjs +24 -96
  237. package/dist/esm/helpers/propMapper.mjs.map +1 -1
  238. package/dist/esm/helpers/propMapper.native.js +60 -107
  239. package/dist/esm/helpers/propMapper.native.js.map +1 -1
  240. package/dist/esm/helpers/pseudoTransitions.mjs +41 -0
  241. package/dist/esm/helpers/pseudoTransitions.mjs.map +1 -0
  242. package/dist/esm/helpers/pseudoTransitions.native.js +45 -0
  243. package/dist/esm/helpers/pseudoTransitions.native.js.map +1 -0
  244. package/dist/esm/helpers/resolveAnimationDriver.mjs +5 -0
  245. package/dist/esm/helpers/resolveAnimationDriver.mjs.map +1 -0
  246. package/dist/esm/helpers/resolveAnimationDriver.native.js +6 -0
  247. package/dist/esm/helpers/resolveAnimationDriver.native.js.map +1 -0
  248. package/dist/esm/helpers/resolveCompoundTokens.mjs +14 -0
  249. package/dist/esm/helpers/resolveCompoundTokens.mjs.map +1 -0
  250. package/dist/esm/helpers/resolveCompoundTokens.native.js +14 -0
  251. package/dist/esm/helpers/resolveCompoundTokens.native.js.map +1 -0
  252. package/dist/esm/helpers/skipProps.mjs +1 -1
  253. package/dist/esm/helpers/skipProps.mjs.map +1 -1
  254. package/dist/esm/helpers/skipProps.native.js +1 -1
  255. package/dist/esm/helpers/skipProps.native.js.map +1 -1
  256. package/dist/esm/helpers/themeable.mjs +4 -2
  257. package/dist/esm/helpers/themeable.mjs.map +1 -1
  258. package/dist/esm/helpers/themeable.native.js +4 -2
  259. package/dist/esm/helpers/themeable.native.js.map +1 -1
  260. package/dist/esm/helpers/useRenderElement.mjs.map +1 -1
  261. package/dist/esm/helpers/useRenderElement.native.js +1 -1
  262. package/dist/esm/helpers/useRenderElement.native.js.map +1 -1
  263. package/dist/esm/helpers/wrapStyleTags.native.js +0 -2
  264. package/dist/esm/helpers/wrapStyleTags.native.js.map +1 -1
  265. package/dist/esm/hooks/getThemeProxied.mjs +0 -3
  266. package/dist/esm/hooks/getThemeProxied.mjs.map +1 -1
  267. package/dist/esm/hooks/useComponentState.mjs +9 -5
  268. package/dist/esm/hooks/useComponentState.mjs.map +1 -1
  269. package/dist/esm/hooks/useComponentState.native.js +10 -6
  270. package/dist/esm/hooks/useComponentState.native.js.map +1 -1
  271. package/dist/esm/hooks/useMedia.mjs +21 -39
  272. package/dist/esm/hooks/useMedia.mjs.map +1 -1
  273. package/dist/esm/hooks/useMedia.native.js +22 -47
  274. package/dist/esm/hooks/useMedia.native.js.map +1 -1
  275. package/dist/esm/hooks/useProps.mjs +2 -1
  276. package/dist/esm/hooks/useProps.mjs.map +1 -1
  277. package/dist/esm/hooks/useProps.native.js +2 -1
  278. package/dist/esm/hooks/useProps.native.js.map +1 -1
  279. package/dist/esm/hooks/useTheme.mjs +4 -0
  280. package/dist/esm/hooks/useTheme.mjs.map +1 -1
  281. package/dist/esm/hooks/useTheme.native.js +4 -0
  282. package/dist/esm/hooks/useTheme.native.js.map +1 -1
  283. package/dist/esm/hooks/useThemeState.mjs +30 -13
  284. package/dist/esm/hooks/useThemeState.mjs.map +1 -1
  285. package/dist/esm/hooks/useThemeState.native.js +28 -12
  286. package/dist/esm/hooks/useThemeState.native.js.map +1 -1
  287. package/dist/esm/index.js +67 -107
  288. package/dist/esm/index.js.map +1 -6
  289. package/dist/esm/index.mjs +5 -1
  290. package/dist/esm/index.mjs.map +1 -1
  291. package/dist/esm/index.native.js +5 -1
  292. package/dist/esm/index.native.js.map +1 -1
  293. package/dist/esm/insertFont.native.js +0 -1
  294. package/dist/esm/insertFont.native.js.map +1 -1
  295. package/dist/esm/styled.mjs.map +1 -1
  296. package/dist/esm/styled.native.js.map +1 -1
  297. package/dist/esm/views/TamaguiProvider.mjs +21 -34
  298. package/dist/esm/views/TamaguiProvider.mjs.map +1 -1
  299. package/dist/esm/views/TamaguiProvider.native.js +28 -40
  300. package/dist/esm/views/TamaguiProvider.native.js.map +1 -1
  301. package/dist/esm/views/TamaguiRoot.mjs +34 -0
  302. package/dist/esm/views/TamaguiRoot.mjs.map +1 -0
  303. package/dist/esm/views/TamaguiRoot.native.js +5 -0
  304. package/dist/esm/views/TamaguiRoot.native.js.map +1 -0
  305. package/dist/esm/views/Text.mjs +1 -9
  306. package/dist/esm/views/Text.mjs.map +1 -1
  307. package/dist/esm/views/Text.native.js +0 -1
  308. package/dist/esm/views/Text.native.js.map +1 -1
  309. package/dist/esm/views/Theme.mjs +2 -0
  310. package/dist/esm/views/Theme.mjs.map +1 -1
  311. package/dist/esm/views/Theme.native.js +2 -0
  312. package/dist/esm/views/Theme.native.js.map +1 -1
  313. package/dist/esm/views/ThemeProvider.mjs +3 -1
  314. package/dist/esm/views/ThemeProvider.mjs.map +1 -1
  315. package/dist/esm/views/ThemeProvider.native.js +2 -2
  316. package/dist/esm/views/ThemeProvider.native.js.map +1 -1
  317. package/dist/esm/views/View.mjs +0 -2
  318. package/dist/esm/views/View.mjs.map +1 -1
  319. package/dist/esm/views/View.native.js +0 -2
  320. package/dist/esm/views/View.native.js.map +1 -1
  321. package/inject-styles/index.cjs +2 -0
  322. package/inject-styles/index.js +2 -0
  323. package/inject-styles.cjs +1 -0
  324. package/package.json +21 -27
  325. package/src/Tamagui.ts +1 -1
  326. package/src/_withStableStyle.tsx +44 -16
  327. package/src/animationDriverTypes.test-d.ts +76 -0
  328. package/src/config.ts +5 -1
  329. package/src/constants/constants.ts +0 -17
  330. package/src/createComponent.tsx +224 -93
  331. package/src/createTamagui.ts +20 -11
  332. package/src/createVariable.ts +1 -1
  333. package/src/eventHandling.native.ts +80 -53
  334. package/src/eventHandling.ts +2 -1
  335. package/src/helpers/createDesignSystem.ts +77 -6
  336. package/src/helpers/createMediaStyle.ts +12 -4
  337. package/src/helpers/createStyledContext.tsx +27 -18
  338. package/src/helpers/defaultAnimationDriver.tsx +0 -2
  339. package/src/helpers/expandStyle.ts +11 -0
  340. package/src/helpers/getCSSStylesAtomic.ts +13 -14
  341. package/src/helpers/getDefaultProps.ts +4 -15
  342. package/src/helpers/getGroupPropParts.ts +1 -1
  343. package/src/helpers/getSplitStyles.tsx +174 -40
  344. package/src/helpers/getThemeCSSRules.ts +16 -14
  345. package/src/helpers/getTokenForKey.ts +223 -0
  346. package/src/helpers/insertStyleRule.tsx +1 -1
  347. package/src/helpers/mainThreadPressEvents.native.ts +118 -25
  348. package/src/helpers/mediaObjectToString.ts +30 -0
  349. package/src/helpers/mediaState.ts +32 -0
  350. package/src/helpers/normalizeColor.ts +12 -8
  351. package/src/helpers/normalizeValueWithProperty.ts +8 -1
  352. package/src/helpers/parseNativeStyle.ts +193 -0
  353. package/src/helpers/parseOutlineShorthand.native.ts +62 -0
  354. package/src/helpers/parseOutlineShorthand.ts +6 -0
  355. package/src/helpers/platformResolveValue.native.ts +72 -0
  356. package/src/helpers/platformResolveValue.ts +22 -0
  357. package/src/helpers/propMapper.ts +65 -221
  358. package/src/helpers/pseudoTransitions.ts +97 -0
  359. package/src/helpers/resolveAnimationDriver.ts +23 -0
  360. package/src/helpers/resolveCompoundTokens.ts +28 -0
  361. package/src/helpers/skipProps.ts +1 -0
  362. package/src/helpers/themeable.tsx +7 -5
  363. package/src/helpers/useRenderElement.tsx +7 -0
  364. package/src/hooks/useComponentState.ts +11 -8
  365. package/src/hooks/useMedia.tsx +28 -75
  366. package/src/hooks/useProps.tsx +2 -1
  367. package/src/hooks/useTheme.tsx +4 -0
  368. package/src/hooks/useThemeState.ts +57 -14
  369. package/src/index.ts +4 -4
  370. package/src/styled.tsx +2 -2
  371. package/src/types.tsx +205 -57
  372. package/src/views/TamaguiProvider.tsx +35 -54
  373. package/src/views/TamaguiRoot.native.tsx +9 -0
  374. package/src/views/TamaguiRoot.tsx +64 -0
  375. package/src/views/Text.tsx +1 -9
  376. package/src/views/Theme.tsx +2 -0
  377. package/src/views/ThemeProvider.tsx +3 -1
  378. package/src/views/View.tsx +0 -2
  379. package/tsconfig.json +44 -0
  380. package/tsconfig.test.json +9 -0
  381. package/types/_withStableStyle.d.ts +1 -1
  382. package/types/_withStableStyle.d.ts.map +1 -1
  383. package/types/config.d.ts.map +1 -1
  384. package/types/constants/constants.d.ts +0 -3
  385. package/types/constants/constants.d.ts.map +1 -1
  386. package/types/createComponent.d.ts.map +1 -1
  387. package/types/createTamagui.d.ts.map +1 -1
  388. package/types/createVariable.d.ts +1 -1
  389. package/types/createVariable.d.ts.map +1 -1
  390. package/types/eventHandling.d.ts +1 -1
  391. package/types/eventHandling.d.ts.map +1 -1
  392. package/types/eventHandling.native.d.ts +2 -2
  393. package/types/eventHandling.native.d.ts.map +1 -1
  394. package/types/helpers/createDesignSystem.d.ts +5 -2
  395. package/types/helpers/createDesignSystem.d.ts.map +1 -1
  396. package/types/helpers/createMediaStyle.d.ts.map +1 -1
  397. package/types/helpers/createStyledContext.d.ts +1 -1
  398. package/types/helpers/createStyledContext.d.ts.map +1 -1
  399. package/types/helpers/defaultAnimationDriver.d.ts.map +1 -1
  400. package/types/helpers/expandStyle.d.ts.map +1 -1
  401. package/types/helpers/getCSSStylesAtomic.d.ts.map +1 -1
  402. package/types/helpers/getDefaultProps.d.ts +1 -1
  403. package/types/helpers/getDefaultProps.d.ts.map +1 -1
  404. package/types/helpers/getSplitStyles.d.ts +2 -2
  405. package/types/helpers/getSplitStyles.d.ts.map +1 -1
  406. package/types/helpers/getThemeCSSRules.d.ts.map +1 -1
  407. package/types/helpers/getTokenForKey.d.ts +6 -0
  408. package/types/helpers/getTokenForKey.d.ts.map +1 -0
  409. package/types/helpers/mainThreadPressEvents.native.d.ts +4 -5
  410. package/types/helpers/mainThreadPressEvents.native.d.ts.map +1 -1
  411. package/types/helpers/mediaObjectToString.d.ts +3 -0
  412. package/types/helpers/mediaObjectToString.d.ts.map +1 -0
  413. package/types/helpers/mediaState.d.ts +7 -0
  414. package/types/helpers/mediaState.d.ts.map +1 -0
  415. package/types/helpers/normalizeColor.d.ts +1 -1
  416. package/types/helpers/normalizeColor.d.ts.map +1 -1
  417. package/types/helpers/normalizeValueWithProperty.d.ts.map +1 -1
  418. package/types/helpers/parseNativeStyle.d.ts +14 -0
  419. package/types/helpers/parseNativeStyle.d.ts.map +1 -0
  420. package/types/helpers/parseOutlineShorthand.d.ts +3 -0
  421. package/types/helpers/parseOutlineShorthand.d.ts.map +1 -0
  422. package/types/helpers/parseOutlineShorthand.native.d.ts +3 -0
  423. package/types/helpers/parseOutlineShorthand.native.d.ts.map +1 -0
  424. package/types/helpers/platformResolveValue.d.ts +6 -0
  425. package/types/helpers/platformResolveValue.d.ts.map +1 -0
  426. package/types/helpers/platformResolveValue.native.d.ts +7 -0
  427. package/types/helpers/platformResolveValue.native.d.ts.map +1 -0
  428. package/types/helpers/propMapper.d.ts +2 -2
  429. package/types/helpers/propMapper.d.ts.map +1 -1
  430. package/types/helpers/pseudoTransitions.d.ts +29 -0
  431. package/types/helpers/pseudoTransitions.d.ts.map +1 -0
  432. package/types/helpers/resolveAnimationDriver.d.ts +7 -0
  433. package/types/helpers/resolveAnimationDriver.d.ts.map +1 -0
  434. package/types/helpers/resolveCompoundTokens.d.ts +9 -0
  435. package/types/helpers/resolveCompoundTokens.d.ts.map +1 -0
  436. package/types/helpers/skipProps.d.ts +1 -0
  437. package/types/helpers/skipProps.d.ts.map +1 -1
  438. package/types/helpers/themeable.d.ts.map +1 -1
  439. package/types/helpers/useRenderElement.d.ts.map +1 -1
  440. package/types/helpers/webPropsToSkip.native.d.ts +20 -20
  441. package/types/hooks/useComponentState.d.ts +2 -1
  442. package/types/hooks/useComponentState.d.ts.map +1 -1
  443. package/types/hooks/useMedia.d.ts +1 -6
  444. package/types/hooks/useMedia.d.ts.map +1 -1
  445. package/types/hooks/useProps.d.ts.map +1 -1
  446. package/types/hooks/useTheme.d.ts.map +1 -1
  447. package/types/hooks/useThemeState.d.ts.map +1 -1
  448. package/types/index.d.ts +5 -1
  449. package/types/index.d.ts.map +1 -1
  450. package/types/styled.d.ts +2 -2
  451. package/types/styled.d.ts.map +1 -1
  452. package/types/types.d.ts +105 -30
  453. package/types/types.d.ts.map +1 -1
  454. package/types/views/TamaguiProvider.d.ts +1 -4
  455. package/types/views/TamaguiProvider.d.ts.map +1 -1
  456. package/types/views/TamaguiRoot.d.ts +15 -0
  457. package/types/views/TamaguiRoot.d.ts.map +1 -0
  458. package/types/views/TamaguiRoot.native.d.ts +7 -0
  459. package/types/views/TamaguiRoot.native.d.ts.map +1 -0
  460. package/types/views/Text.d.ts.map +1 -1
  461. package/types/views/Theme.d.ts.map +1 -1
  462. package/types/views/ThemeProvider.d.ts.map +1 -1
  463. package/types/views/View.d.ts.map +1 -1
  464. package/vitest.config.d.ts +3 -0
  465. package/vitest.config.d.ts.map +1 -0
  466. package/vitest.config.ts +14 -0
  467. package/dist/cjs/Tamagui.js +0 -56
  468. package/dist/cjs/Tamagui.js.map +0 -6
  469. package/dist/cjs/_withStableStyle.js +0 -33
  470. package/dist/cjs/_withStableStyle.js.map +0 -6
  471. package/dist/cjs/animationDriverTypes.test-d.js +0 -51
  472. package/dist/cjs/animationDriverTypes.test-d.js.map +0 -6
  473. package/dist/cjs/config.js +0 -109
  474. package/dist/cjs/config.js.map +0 -6
  475. package/dist/cjs/constants/accessibilityDirectMap.js +0 -25
  476. package/dist/cjs/constants/accessibilityDirectMap.js.map +0 -6
  477. package/dist/cjs/constants/constants.js +0 -43
  478. package/dist/cjs/constants/constants.js.map +0 -6
  479. package/dist/cjs/constants/isDevTools.js +0 -28
  480. package/dist/cjs/constants/isDevTools.js.map +0 -6
  481. package/dist/cjs/constants/webToNativeProps.js +0 -22
  482. package/dist/cjs/constants/webToNativeProps.js.map +0 -6
  483. package/dist/cjs/constants/webToNativeProps.native.js +0 -115
  484. package/dist/cjs/constants/webToNativeProps.native.js.map +0 -1
  485. package/dist/cjs/contexts/ComponentContext.js +0 -30
  486. package/dist/cjs/contexts/ComponentContext.js.map +0 -6
  487. package/dist/cjs/contexts/GroupContext.js +0 -22
  488. package/dist/cjs/contexts/GroupContext.js.map +0 -6
  489. package/dist/cjs/createComponent.js +0 -697
  490. package/dist/cjs/createComponent.js.map +0 -6
  491. package/dist/cjs/createFont.js +0 -53
  492. package/dist/cjs/createFont.js.map +0 -6
  493. package/dist/cjs/createShorthands.js +0 -23
  494. package/dist/cjs/createShorthands.js.map +0 -6
  495. package/dist/cjs/createTamagui.js +0 -190
  496. package/dist/cjs/createTamagui.js.map +0 -6
  497. package/dist/cjs/createTheme.js +0 -21
  498. package/dist/cjs/createTheme.js.map +0 -6
  499. package/dist/cjs/createTheme.native.js.map +0 -1
  500. package/dist/cjs/createTokens.js +0 -24
  501. package/dist/cjs/createTokens.js.map +0 -6
  502. package/dist/cjs/createVariable.js +0 -89
  503. package/dist/cjs/createVariable.js.map +0 -6
  504. package/dist/cjs/createVariables.js +0 -56
  505. package/dist/cjs/createVariables.js.map +0 -6
  506. package/dist/cjs/defaultComponentState.js +0 -38
  507. package/dist/cjs/defaultComponentState.js.map +0 -6
  508. package/dist/cjs/eventHandling.js +0 -41
  509. package/dist/cjs/eventHandling.js.map +0 -6
  510. package/dist/cjs/helpers/createDesignSystem.js +0 -120
  511. package/dist/cjs/helpers/createDesignSystem.js.map +0 -6
  512. package/dist/cjs/helpers/createMediaStyle.js +0 -74
  513. package/dist/cjs/helpers/createMediaStyle.js.map +0 -6
  514. package/dist/cjs/helpers/createStyledContext.js +0 -52
  515. package/dist/cjs/helpers/createStyledContext.js.map +0 -6
  516. package/dist/cjs/helpers/defaultAnimationDriver.js +0 -39
  517. package/dist/cjs/helpers/defaultAnimationDriver.js.map +0 -6
  518. package/dist/cjs/helpers/defaultOffset.js +0 -21
  519. package/dist/cjs/helpers/defaultOffset.js.map +0 -6
  520. package/dist/cjs/helpers/expandStyle.js +0 -73
  521. package/dist/cjs/helpers/expandStyle.js.map +0 -6
  522. package/dist/cjs/helpers/expandStyles.js +0 -34
  523. package/dist/cjs/helpers/expandStyles.js.map +0 -6
  524. package/dist/cjs/helpers/getCSSStylesAtomic.js +0 -156
  525. package/dist/cjs/helpers/getCSSStylesAtomic.js.map +0 -6
  526. package/dist/cjs/helpers/getDefaultProps.js +0 -31
  527. package/dist/cjs/helpers/getDefaultProps.js.map +0 -6
  528. package/dist/cjs/helpers/getDynamicVal.js +0 -62
  529. package/dist/cjs/helpers/getDynamicVal.js.map +0 -6
  530. package/dist/cjs/helpers/getExpandedShorthands.js +0 -34
  531. package/dist/cjs/helpers/getExpandedShorthands.js.map +0 -6
  532. package/dist/cjs/helpers/getFontLanguage.js +0 -21
  533. package/dist/cjs/helpers/getFontLanguage.js.map +0 -6
  534. package/dist/cjs/helpers/getGroupPropParts.js +0 -34
  535. package/dist/cjs/helpers/getGroupPropParts.js.map +0 -6
  536. package/dist/cjs/helpers/getShorthandValue.js +0 -23
  537. package/dist/cjs/helpers/getShorthandValue.js.map +0 -6
  538. package/dist/cjs/helpers/getSplitStyles.js +0 -630
  539. package/dist/cjs/helpers/getSplitStyles.js.map +0 -6
  540. package/dist/cjs/helpers/getThemeCSSRules.js +0 -89
  541. package/dist/cjs/helpers/getThemeCSSRules.js.map +0 -6
  542. package/dist/cjs/helpers/getVariantExtras.js +0 -59
  543. package/dist/cjs/helpers/getVariantExtras.js.map +0 -6
  544. package/dist/cjs/helpers/insertStyleRule.js +0 -196
  545. package/dist/cjs/helpers/insertStyleRule.js.map +0 -6
  546. package/dist/cjs/helpers/isActivePlatform.js +0 -31
  547. package/dist/cjs/helpers/isActivePlatform.js.map +0 -6
  548. package/dist/cjs/helpers/isActiveTheme.js +0 -24
  549. package/dist/cjs/helpers/isActiveTheme.js.map +0 -6
  550. package/dist/cjs/helpers/isObj.js +0 -21
  551. package/dist/cjs/helpers/isObj.js.map +0 -6
  552. package/dist/cjs/helpers/isTamaguiComponent.js +0 -24
  553. package/dist/cjs/helpers/isTamaguiComponent.js.map +0 -6
  554. package/dist/cjs/helpers/isTamaguiElement.js +0 -30
  555. package/dist/cjs/helpers/isTamaguiElement.js.map +0 -6
  556. package/dist/cjs/helpers/log.js +0 -33
  557. package/dist/cjs/helpers/log.js.map +0 -6
  558. package/dist/cjs/helpers/mainThreadPressEvents.js +0 -22
  559. package/dist/cjs/helpers/mainThreadPressEvents.js.map +0 -6
  560. package/dist/cjs/helpers/matchMedia.js +0 -34
  561. package/dist/cjs/helpers/matchMedia.js.map +0 -6
  562. package/dist/cjs/helpers/mergeProps.js +0 -55
  563. package/dist/cjs/helpers/mergeProps.js.map +0 -6
  564. package/dist/cjs/helpers/mergeRenderElementProps.js +0 -25
  565. package/dist/cjs/helpers/mergeRenderElementProps.js.map +0 -6
  566. package/dist/cjs/helpers/mergeSlotStyleProps.js +0 -29
  567. package/dist/cjs/helpers/mergeSlotStyleProps.js.map +0 -6
  568. package/dist/cjs/helpers/mergeVariants.js +0 -38
  569. package/dist/cjs/helpers/mergeVariants.js.map +0 -6
  570. package/dist/cjs/helpers/nativeOnlyProps.js +0 -55
  571. package/dist/cjs/helpers/nativeOnlyProps.js.map +0 -6
  572. package/dist/cjs/helpers/normalizeColor.js +0 -26
  573. package/dist/cjs/helpers/normalizeColor.js.map +0 -6
  574. package/dist/cjs/helpers/normalizeShadow.js +0 -40
  575. package/dist/cjs/helpers/normalizeShadow.js.map +0 -6
  576. package/dist/cjs/helpers/normalizeStyle.js +0 -36
  577. package/dist/cjs/helpers/normalizeStyle.js.map +0 -6
  578. package/dist/cjs/helpers/normalizeStylePropKeys.js +0 -21
  579. package/dist/cjs/helpers/normalizeStylePropKeys.js.map +0 -6
  580. package/dist/cjs/helpers/normalizeValueWithProperty.js +0 -32
  581. package/dist/cjs/helpers/normalizeValueWithProperty.js.map +0 -6
  582. package/dist/cjs/helpers/objectIdentityKey.js +0 -38
  583. package/dist/cjs/helpers/objectIdentityKey.js.map +0 -6
  584. package/dist/cjs/helpers/parseBorderShorthand.js +0 -22
  585. package/dist/cjs/helpers/parseBorderShorthand.js.map +0 -6
  586. package/dist/cjs/helpers/pointerEvents.js +0 -22
  587. package/dist/cjs/helpers/pointerEvents.js.map +0 -6
  588. package/dist/cjs/helpers/propMapper.js +0 -257
  589. package/dist/cjs/helpers/propMapper.js.map +0 -6
  590. package/dist/cjs/helpers/proxyThemeToParents.js +0 -40
  591. package/dist/cjs/helpers/proxyThemeToParents.js.map +0 -6
  592. package/dist/cjs/helpers/proxyThemeVariables.js +0 -31
  593. package/dist/cjs/helpers/proxyThemeVariables.js.map +0 -6
  594. package/dist/cjs/helpers/pseudoDescriptors.js +0 -72
  595. package/dist/cjs/helpers/pseudoDescriptors.js.map +0 -6
  596. package/dist/cjs/helpers/registerCSSVariable.js +0 -47
  597. package/dist/cjs/helpers/registerCSSVariable.js.map +0 -6
  598. package/dist/cjs/helpers/resolveRem.js +0 -27
  599. package/dist/cjs/helpers/resolveRem.js.map +0 -6
  600. package/dist/cjs/helpers/resolveSafeArea.js +0 -29
  601. package/dist/cjs/helpers/resolveSafeArea.js.map +0 -6
  602. package/dist/cjs/helpers/setElementProps.js +0 -24
  603. package/dist/cjs/helpers/setElementProps.js.map +0 -6
  604. package/dist/cjs/helpers/skipProps.js +0 -38
  605. package/dist/cjs/helpers/skipProps.js.map +0 -6
  606. package/dist/cjs/helpers/sortString.js +0 -21
  607. package/dist/cjs/helpers/sortString.js.map +0 -6
  608. package/dist/cjs/helpers/subscribeToContextGroup.js +0 -74
  609. package/dist/cjs/helpers/subscribeToContextGroup.js.map +0 -6
  610. package/dist/cjs/helpers/themeable.js +0 -56
  611. package/dist/cjs/helpers/themeable.js.map +0 -6
  612. package/dist/cjs/helpers/themes.js +0 -33
  613. package/dist/cjs/helpers/themes.js.map +0 -6
  614. package/dist/cjs/helpers/timer.js +0 -27
  615. package/dist/cjs/helpers/timer.js.map +0 -6
  616. package/dist/cjs/helpers/transformsToString.js +0 -33
  617. package/dist/cjs/helpers/transformsToString.js.map +0 -6
  618. package/dist/cjs/helpers/useRenderElement.js +0 -42
  619. package/dist/cjs/helpers/useRenderElement.js.map +0 -6
  620. package/dist/cjs/helpers/webPropsToSkip.js +0 -21
  621. package/dist/cjs/helpers/webPropsToSkip.js.map +0 -6
  622. package/dist/cjs/helpers/wrapStyleTags.js +0 -38
  623. package/dist/cjs/helpers/wrapStyleTags.js.map +0 -6
  624. package/dist/cjs/hooks/doesRootSchemeMatchSystem.js +0 -23
  625. package/dist/cjs/hooks/doesRootSchemeMatchSystem.js.map +0 -6
  626. package/dist/cjs/hooks/getThemeProxied.js +0 -56
  627. package/dist/cjs/hooks/getThemeProxied.js.map +0 -6
  628. package/dist/cjs/hooks/useComponentState.js +0 -96
  629. package/dist/cjs/hooks/useComponentState.js.map +0 -6
  630. package/dist/cjs/hooks/useDisableSSR.js +0 -24
  631. package/dist/cjs/hooks/useDisableSSR.js.map +0 -6
  632. package/dist/cjs/hooks/useIsTouchDevice.js +0 -22
  633. package/dist/cjs/hooks/useIsTouchDevice.js.map +0 -6
  634. package/dist/cjs/hooks/useMedia.js +0 -183
  635. package/dist/cjs/hooks/useMedia.js.map +0 -6
  636. package/dist/cjs/hooks/useProps.js +0 -106
  637. package/dist/cjs/hooks/useProps.js.map +0 -6
  638. package/dist/cjs/hooks/useTheme.js +0 -35
  639. package/dist/cjs/hooks/useTheme.js.map +0 -6
  640. package/dist/cjs/hooks/useThemeName.js +0 -25
  641. package/dist/cjs/hooks/useThemeName.js.map +0 -6
  642. package/dist/cjs/hooks/useThemeState.js +0 -218
  643. package/dist/cjs/hooks/useThemeState.js.map +0 -6
  644. package/dist/cjs/index.js +0 -108
  645. package/dist/cjs/index.js.map +0 -6
  646. package/dist/cjs/inject-styles.js +0 -28
  647. package/dist/cjs/inject-styles.js.map +0 -6
  648. package/dist/cjs/insertFont.js +0 -68
  649. package/dist/cjs/insertFont.js.map +0 -6
  650. package/dist/cjs/interfaces/CSSColorNames.js +0 -14
  651. package/dist/cjs/interfaces/CSSColorNames.js.map +0 -6
  652. package/dist/cjs/interfaces/GetRef.js +0 -14
  653. package/dist/cjs/interfaces/GetRef.js.map +0 -6
  654. package/dist/cjs/interfaces/RNExclusiveTypes.js +0 -14
  655. package/dist/cjs/interfaces/RNExclusiveTypes.js.map +0 -6
  656. package/dist/cjs/interfaces/TamaguiComponentEvents.js +0 -14
  657. package/dist/cjs/interfaces/TamaguiComponentEvents.js.map +0 -6
  658. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.js +0 -14
  659. package/dist/cjs/interfaces/TamaguiComponentPropsBaseBase.js.map +0 -6
  660. package/dist/cjs/setupHooks.js +0 -25
  661. package/dist/cjs/setupHooks.js.map +0 -6
  662. package/dist/cjs/setupReactNative.js +0 -43
  663. package/dist/cjs/setupReactNative.js.map +0 -6
  664. package/dist/cjs/styled.js +0 -116
  665. package/dist/cjs/styled.js.map +0 -6
  666. package/dist/cjs/styledHtml.test-d.js +0 -136
  667. package/dist/cjs/styledHtml.test-d.js.map +0 -6
  668. package/dist/cjs/type-utils.js +0 -14
  669. package/dist/cjs/type-utils.js.map +0 -6
  670. package/dist/cjs/types.js +0 -14
  671. package/dist/cjs/types.js.map +0 -6
  672. package/dist/cjs/views/Configuration.js +0 -33
  673. package/dist/cjs/views/Configuration.js.map +0 -6
  674. package/dist/cjs/views/FontLanguage.js +0 -32
  675. package/dist/cjs/views/FontLanguage.js.map +0 -6
  676. package/dist/cjs/views/Slot.js +0 -55
  677. package/dist/cjs/views/Slot.js.map +0 -6
  678. package/dist/cjs/views/Stack.js +0 -27
  679. package/dist/cjs/views/Stack.js.map +0 -6
  680. package/dist/cjs/views/Stack.native.js.map +0 -1
  681. package/dist/cjs/views/TamaguiProvider.js +0 -93
  682. package/dist/cjs/views/TamaguiProvider.js.map +0 -6
  683. package/dist/cjs/views/Text.js +0 -59
  684. package/dist/cjs/views/Text.js.map +0 -6
  685. package/dist/cjs/views/Theme.js +0 -124
  686. package/dist/cjs/views/Theme.js.map +0 -6
  687. package/dist/cjs/views/ThemeDebug.js +0 -81
  688. package/dist/cjs/views/ThemeDebug.js.map +0 -6
  689. package/dist/cjs/views/ThemeProvider.js +0 -42
  690. package/dist/cjs/views/ThemeProvider.js.map +0 -6
  691. package/dist/cjs/views/View.js +0 -26
  692. package/dist/cjs/views/View.js.map +0 -6
  693. package/dist/esm/Tamagui.js +0 -35
  694. package/dist/esm/Tamagui.js.map +0 -6
  695. package/dist/esm/_withStableStyle.js +0 -12
  696. package/dist/esm/_withStableStyle.js.map +0 -6
  697. package/dist/esm/animationDriverTypes.test-d.js +0 -51
  698. package/dist/esm/animationDriverTypes.test-d.js.map +0 -6
  699. package/dist/esm/config.js +0 -94
  700. package/dist/esm/config.js.map +0 -6
  701. package/dist/esm/constants/accessibilityDirectMap.js +0 -9
  702. package/dist/esm/constants/accessibilityDirectMap.js.map +0 -6
  703. package/dist/esm/constants/constants.js +0 -27
  704. package/dist/esm/constants/constants.js.map +0 -6
  705. package/dist/esm/constants/isDevTools.js +0 -12
  706. package/dist/esm/constants/isDevTools.js.map +0 -6
  707. package/dist/esm/constants/webToNativeProps.js +0 -6
  708. package/dist/esm/constants/webToNativeProps.js.map +0 -6
  709. package/dist/esm/constants/webToNativeProps.mjs +0 -4
  710. package/dist/esm/constants/webToNativeProps.mjs.map +0 -1
  711. package/dist/esm/constants/webToNativeProps.native.js +0 -88
  712. package/dist/esm/constants/webToNativeProps.native.js.map +0 -1
  713. package/dist/esm/contexts/ComponentContext.js +0 -15
  714. package/dist/esm/contexts/ComponentContext.js.map +0 -6
  715. package/dist/esm/contexts/GroupContext.js +0 -6
  716. package/dist/esm/contexts/GroupContext.js.map +0 -6
  717. package/dist/esm/createComponent.js +0 -702
  718. package/dist/esm/createComponent.js.map +0 -6
  719. package/dist/esm/createFont.js +0 -37
  720. package/dist/esm/createFont.js.map +0 -6
  721. package/dist/esm/createShorthands.js +0 -7
  722. package/dist/esm/createShorthands.js.map +0 -6
  723. package/dist/esm/createTamagui.js +0 -189
  724. package/dist/esm/createTamagui.js.map +0 -6
  725. package/dist/esm/createTheme.js +0 -5
  726. package/dist/esm/createTheme.js.map +0 -6
  727. package/dist/esm/createTheme.mjs +0 -3
  728. package/dist/esm/createTheme.mjs.map +0 -1
  729. package/dist/esm/createTheme.native.js +0 -5
  730. package/dist/esm/createTheme.native.js.map +0 -1
  731. package/dist/esm/createTokens.js +0 -8
  732. package/dist/esm/createTokens.js.map +0 -6
  733. package/dist/esm/createVariable.js +0 -75
  734. package/dist/esm/createVariable.js.map +0 -6
  735. package/dist/esm/createVariables.js +0 -42
  736. package/dist/esm/createVariables.js.map +0 -6
  737. package/dist/esm/defaultComponentState.js +0 -22
  738. package/dist/esm/defaultComponentState.js.map +0 -6
  739. package/dist/esm/eventHandling.js +0 -25
  740. package/dist/esm/eventHandling.js.map +0 -6
  741. package/dist/esm/helpers/createDesignSystem.js +0 -107
  742. package/dist/esm/helpers/createDesignSystem.js.map +0 -6
  743. package/dist/esm/helpers/createMediaStyle.js +0 -60
  744. package/dist/esm/helpers/createMediaStyle.js.map +0 -6
  745. package/dist/esm/helpers/createStyledContext.js +0 -31
  746. package/dist/esm/helpers/createStyledContext.js.map +0 -6
  747. package/dist/esm/helpers/defaultAnimationDriver.js +0 -23
  748. package/dist/esm/helpers/defaultAnimationDriver.js.map +0 -6
  749. package/dist/esm/helpers/defaultOffset.js +0 -5
  750. package/dist/esm/helpers/defaultOffset.js.map +0 -6
  751. package/dist/esm/helpers/expandStyle.js +0 -59
  752. package/dist/esm/helpers/expandStyle.js.map +0 -6
  753. package/dist/esm/helpers/expandStyles.js +0 -19
  754. package/dist/esm/helpers/expandStyles.js.map +0 -6
  755. package/dist/esm/helpers/getCSSStylesAtomic.js +0 -147
  756. package/dist/esm/helpers/getCSSStylesAtomic.js.map +0 -6
  757. package/dist/esm/helpers/getDefaultProps.js +0 -15
  758. package/dist/esm/helpers/getDefaultProps.js.map +0 -6
  759. package/dist/esm/helpers/getDynamicVal.js +0 -46
  760. package/dist/esm/helpers/getDynamicVal.js.map +0 -6
  761. package/dist/esm/helpers/getExpandedShorthands.js +0 -18
  762. package/dist/esm/helpers/getExpandedShorthands.js.map +0 -6
  763. package/dist/esm/helpers/getFontLanguage.js +0 -5
  764. package/dist/esm/helpers/getFontLanguage.js.map +0 -6
  765. package/dist/esm/helpers/getGroupPropParts.js +0 -19
  766. package/dist/esm/helpers/getGroupPropParts.js.map +0 -6
  767. package/dist/esm/helpers/getShorthandValue.js +0 -7
  768. package/dist/esm/helpers/getShorthandValue.js.map +0 -6
  769. package/dist/esm/helpers/getSplitStyles.js +0 -650
  770. package/dist/esm/helpers/getSplitStyles.js.map +0 -6
  771. package/dist/esm/helpers/getThemeCSSRules.js +0 -78
  772. package/dist/esm/helpers/getThemeCSSRules.js.map +0 -6
  773. package/dist/esm/helpers/getVariantExtras.js +0 -44
  774. package/dist/esm/helpers/getVariantExtras.js.map +0 -6
  775. package/dist/esm/helpers/insertStyleRule.js +0 -181
  776. package/dist/esm/helpers/insertStyleRule.js.map +0 -6
  777. package/dist/esm/helpers/isActivePlatform.js +0 -15
  778. package/dist/esm/helpers/isActivePlatform.js.map +0 -6
  779. package/dist/esm/helpers/isActiveTheme.js +0 -8
  780. package/dist/esm/helpers/isActiveTheme.js.map +0 -6
  781. package/dist/esm/helpers/isObj.js +0 -5
  782. package/dist/esm/helpers/isObj.js.map +0 -6
  783. package/dist/esm/helpers/isTamaguiComponent.js +0 -8
  784. package/dist/esm/helpers/isTamaguiComponent.js.map +0 -6
  785. package/dist/esm/helpers/isTamaguiElement.js +0 -7
  786. package/dist/esm/helpers/isTamaguiElement.js.map +0 -6
  787. package/dist/esm/helpers/log.js +0 -17
  788. package/dist/esm/helpers/log.js.map +0 -6
  789. package/dist/esm/helpers/mainThreadPressEvents.js +0 -6
  790. package/dist/esm/helpers/mainThreadPressEvents.js.map +0 -6
  791. package/dist/esm/helpers/matchMedia.js +0 -18
  792. package/dist/esm/helpers/matchMedia.js.map +0 -6
  793. package/dist/esm/helpers/mergeProps.js +0 -39
  794. package/dist/esm/helpers/mergeProps.js.map +0 -6
  795. package/dist/esm/helpers/mergeRenderElementProps.js +0 -9
  796. package/dist/esm/helpers/mergeRenderElementProps.js.map +0 -6
  797. package/dist/esm/helpers/mergeSlotStyleProps.js +0 -14
  798. package/dist/esm/helpers/mergeSlotStyleProps.js.map +0 -6
  799. package/dist/esm/helpers/mergeVariants.js +0 -22
  800. package/dist/esm/helpers/mergeVariants.js.map +0 -6
  801. package/dist/esm/helpers/nativeOnlyProps.js +0 -39
  802. package/dist/esm/helpers/nativeOnlyProps.js.map +0 -6
  803. package/dist/esm/helpers/normalizeColor.js +0 -10
  804. package/dist/esm/helpers/normalizeColor.js.map +0 -6
  805. package/dist/esm/helpers/normalizeShadow.js +0 -24
  806. package/dist/esm/helpers/normalizeShadow.js.map +0 -6
  807. package/dist/esm/helpers/normalizeStyle.js +0 -24
  808. package/dist/esm/helpers/normalizeStyle.js.map +0 -6
  809. package/dist/esm/helpers/normalizeStylePropKeys.js +0 -5
  810. package/dist/esm/helpers/normalizeStylePropKeys.js.map +0 -6
  811. package/dist/esm/helpers/normalizeValueWithProperty.js +0 -17
  812. package/dist/esm/helpers/normalizeValueWithProperty.js.map +0 -6
  813. package/dist/esm/helpers/objectIdentityKey.js +0 -22
  814. package/dist/esm/helpers/objectIdentityKey.js.map +0 -6
  815. package/dist/esm/helpers/parseBorderShorthand.js +0 -6
  816. package/dist/esm/helpers/parseBorderShorthand.js.map +0 -6
  817. package/dist/esm/helpers/pointerEvents.js +0 -6
  818. package/dist/esm/helpers/pointerEvents.js.map +0 -6
  819. package/dist/esm/helpers/propMapper.js +0 -251
  820. package/dist/esm/helpers/propMapper.js.map +0 -6
  821. package/dist/esm/helpers/proxyThemeToParents.js +0 -24
  822. package/dist/esm/helpers/proxyThemeToParents.js.map +0 -6
  823. package/dist/esm/helpers/proxyThemeVariables.js +0 -15
  824. package/dist/esm/helpers/proxyThemeVariables.js.map +0 -6
  825. package/dist/esm/helpers/pseudoDescriptors.js +0 -56
  826. package/dist/esm/helpers/pseudoDescriptors.js.map +0 -6
  827. package/dist/esm/helpers/registerCSSVariable.js +0 -31
  828. package/dist/esm/helpers/registerCSSVariable.js.map +0 -6
  829. package/dist/esm/helpers/resolveRem.js +0 -11
  830. package/dist/esm/helpers/resolveRem.js.map +0 -6
  831. package/dist/esm/helpers/resolveSafeArea.js +0 -13
  832. package/dist/esm/helpers/resolveSafeArea.js.map +0 -6
  833. package/dist/esm/helpers/setElementProps.js +0 -8
  834. package/dist/esm/helpers/setElementProps.js.map +0 -6
  835. package/dist/esm/helpers/skipProps.js +0 -23
  836. package/dist/esm/helpers/skipProps.js.map +0 -6
  837. package/dist/esm/helpers/sortString.js +0 -5
  838. package/dist/esm/helpers/sortString.js.map +0 -6
  839. package/dist/esm/helpers/subscribeToContextGroup.js +0 -59
  840. package/dist/esm/helpers/subscribeToContextGroup.js.map +0 -6
  841. package/dist/esm/helpers/themeable.js +0 -35
  842. package/dist/esm/helpers/themeable.js.map +0 -6
  843. package/dist/esm/helpers/themes.js +0 -17
  844. package/dist/esm/helpers/themes.js.map +0 -6
  845. package/dist/esm/helpers/timer.js +0 -11
  846. package/dist/esm/helpers/timer.js.map +0 -6
  847. package/dist/esm/helpers/transformsToString.js +0 -17
  848. package/dist/esm/helpers/transformsToString.js.map +0 -6
  849. package/dist/esm/helpers/useRenderElement.js +0 -28
  850. package/dist/esm/helpers/useRenderElement.js.map +0 -6
  851. package/dist/esm/helpers/webPropsToSkip.js +0 -5
  852. package/dist/esm/helpers/webPropsToSkip.js.map +0 -6
  853. package/dist/esm/helpers/wrapStyleTags.js +0 -23
  854. package/dist/esm/helpers/wrapStyleTags.js.map +0 -6
  855. package/dist/esm/hooks/doesRootSchemeMatchSystem.js +0 -7
  856. package/dist/esm/hooks/doesRootSchemeMatchSystem.js.map +0 -6
  857. package/dist/esm/hooks/getThemeProxied.js +0 -44
  858. package/dist/esm/hooks/getThemeProxied.js.map +0 -6
  859. package/dist/esm/hooks/useComponentState.js +0 -91
  860. package/dist/esm/hooks/useComponentState.js.map +0 -6
  861. package/dist/esm/hooks/useDisableSSR.js +0 -8
  862. package/dist/esm/hooks/useDisableSSR.js.map +0 -6
  863. package/dist/esm/hooks/useIsTouchDevice.js +0 -7
  864. package/dist/esm/hooks/useIsTouchDevice.js.map +0 -6
  865. package/dist/esm/hooks/useMedia.js +0 -172
  866. package/dist/esm/hooks/useMedia.js.map +0 -6
  867. package/dist/esm/hooks/useProps.js +0 -92
  868. package/dist/esm/hooks/useProps.js.map +0 -6
  869. package/dist/esm/hooks/useTheme.js +0 -21
  870. package/dist/esm/hooks/useTheme.js.map +0 -6
  871. package/dist/esm/hooks/useThemeName.js +0 -9
  872. package/dist/esm/hooks/useThemeName.js.map +0 -6
  873. package/dist/esm/hooks/useThemeState.js +0 -212
  874. package/dist/esm/hooks/useThemeState.js.map +0 -6
  875. package/dist/esm/inject-styles.js +0 -12
  876. package/dist/esm/inject-styles.js.map +0 -6
  877. package/dist/esm/insertFont.js +0 -56
  878. package/dist/esm/insertFont.js.map +0 -6
  879. package/dist/esm/interfaces/CSSColorNames.js +0 -1
  880. package/dist/esm/interfaces/CSSColorNames.js.map +0 -6
  881. package/dist/esm/interfaces/GetRef.js +0 -1
  882. package/dist/esm/interfaces/GetRef.js.map +0 -6
  883. package/dist/esm/interfaces/RNExclusiveTypes.js +0 -1
  884. package/dist/esm/interfaces/RNExclusiveTypes.js.map +0 -6
  885. package/dist/esm/interfaces/TamaguiComponentEvents.js +0 -1
  886. package/dist/esm/interfaces/TamaguiComponentEvents.js.map +0 -6
  887. package/dist/esm/interfaces/TamaguiComponentPropsBaseBase.js +0 -1
  888. package/dist/esm/interfaces/TamaguiComponentPropsBaseBase.js.map +0 -6
  889. package/dist/esm/setupHooks.js +0 -9
  890. package/dist/esm/setupHooks.js.map +0 -6
  891. package/dist/esm/setupReactNative.js +0 -27
  892. package/dist/esm/setupReactNative.js.map +0 -6
  893. package/dist/esm/styled.js +0 -102
  894. package/dist/esm/styled.js.map +0 -6
  895. package/dist/esm/styledHtml.test-d.js +0 -137
  896. package/dist/esm/styledHtml.test-d.js.map +0 -6
  897. package/dist/esm/type-utils.js +0 -1
  898. package/dist/esm/type-utils.js.map +0 -6
  899. package/dist/esm/types.js +0 -1
  900. package/dist/esm/types.js.map +0 -6
  901. package/dist/esm/views/Configuration.js +0 -12
  902. package/dist/esm/views/Configuration.js.map +0 -6
  903. package/dist/esm/views/FontLanguage.js +0 -16
  904. package/dist/esm/views/FontLanguage.js.map +0 -6
  905. package/dist/esm/views/Slot.js +0 -43
  906. package/dist/esm/views/Slot.js.map +0 -6
  907. package/dist/esm/views/Stack.js +0 -13
  908. package/dist/esm/views/Stack.js.map +0 -6
  909. package/dist/esm/views/Stack.mjs +0 -11
  910. package/dist/esm/views/Stack.mjs.map +0 -1
  911. package/dist/esm/views/Stack.native.js +0 -11
  912. package/dist/esm/views/Stack.native.js.map +0 -1
  913. package/dist/esm/views/TamaguiProvider.js +0 -77
  914. package/dist/esm/views/TamaguiProvider.js.map +0 -6
  915. package/dist/esm/views/Text.js +0 -44
  916. package/dist/esm/views/Text.js.map +0 -6
  917. package/dist/esm/views/Theme.js +0 -110
  918. package/dist/esm/views/Theme.js.map +0 -6
  919. package/dist/esm/views/ThemeDebug.js +0 -69
  920. package/dist/esm/views/ThemeDebug.js.map +0 -6
  921. package/dist/esm/views/ThemeProvider.js +0 -31
  922. package/dist/esm/views/ThemeProvider.js.map +0 -6
  923. package/dist/esm/views/View.js +0 -12
  924. package/dist/esm/views/View.js.map +0 -6
  925. package/types/constants/webToNativeProps.d.ts.map +0 -1
  926. package/types/constants/webToNativeProps.native.d.ts.map +0 -1
  927. package/types/createTheme.d.ts.map +0 -1
  928. package/types/helpers/expandStyle.native.d.ts.map +0 -1
  929. package/types/helpers/propMapper.native.d.ts.map +0 -1
  930. package/types/views/Stack.d.ts.map +0 -1
@@ -1,15 +1,20 @@
1
1
  import { isServer, isWeb } from '@tamagui/constants'
2
2
  import { useRef, useSyncExternalStore } from 'react'
3
- import { getConfig, getSetting } from '../config'
3
+ import { getSetting } from '../config'
4
4
  import { resetMediaStyleCache } from '../helpers/createMediaStyle'
5
5
  import { matchMedia } from '../helpers/matchMedia'
6
+ import { mediaObjectToString } from '../helpers/mediaObjectToString'
7
+ import {
8
+ getMedia,
9
+ mediaKeys,
10
+ mediaQueryConfig,
11
+ setMediaState,
12
+ } from '../helpers/mediaState'
6
13
  import type {
7
14
  ComponentContextI,
8
15
  DebugProp,
9
16
  GetStyleState,
10
17
  IsMediaType,
11
- MediaQueries,
12
- MediaQueryObject,
13
18
  MediaQueryState,
14
19
  TamaguiInternalConfig,
15
20
  UseMediaState,
@@ -17,33 +22,6 @@ import type {
17
22
  } from '../types'
18
23
  import { defaultMediaImportance } from '../helpers/pseudoDescriptors'
19
24
 
20
- export let mediaState: MediaQueryState =
21
- // development only safeguard
22
- process.env.NODE_ENV === 'development'
23
- ? new Proxy(
24
- {},
25
- {
26
- get(target, key) {
27
- if (
28
- typeof key === 'string' &&
29
- key[0] === '$' &&
30
- // dont error on $$typeof
31
- key[1] !== '$'
32
- ) {
33
- throw new Error(`Access mediaState should not use "$": ${key}`)
34
- }
35
- return Reflect.get(target, key)
36
- },
37
- }
38
- )
39
- : ({} as any)
40
-
41
- export const mediaQueryConfig: MediaQueries = {}
42
-
43
- export const getMedia = () => mediaState
44
-
45
- export const mediaKeys = new Set<string>() // with $ prefix
46
-
47
25
  const mediaKeyRegex = /\$(platform|theme|group)-/
48
26
 
49
27
  export const isMediaKey = (key: string): boolean => {
@@ -89,11 +67,11 @@ export const configureMedia = (config: TamaguiInternalConfig) => {
89
67
  // reset cached media style prefixes/selectors so they get recalculated with new key order
90
68
  resetMediaStyleCache()
91
69
  for (const key in media) {
92
- mediaState[key] = mediaQueryDefaultActive?.[key] || false
70
+ getMedia()[key] = mediaQueryDefaultActive?.[key] || false
93
71
  mediaKeys.add(`$${key}`)
94
72
  }
95
73
  Object.assign(mediaQueryConfig, media)
96
- initState = { ...mediaState }
74
+ initState = { ...getMedia() }
97
75
  mediaKeysOrdered = Object.keys(media)
98
76
  setupMediaListeners()
99
77
  }
@@ -121,7 +99,7 @@ export function setupMediaListeners() {
121
99
  unlisten()
122
100
 
123
101
  for (const key in mediaQueryConfig) {
124
- const str = mediaObjectToString(mediaQueryConfig[key], key)
102
+ const str = mediaObjectToString(mediaQueryConfig[key])
125
103
  const getMatch = () => matchMedia(str)
126
104
  const match = getMatch()
127
105
  if (!match) {
@@ -136,8 +114,8 @@ export function setupMediaListeners() {
136
114
 
137
115
  function update() {
138
116
  const next = !!getMatch().matches
139
- if (next === mediaState[key]) return
140
- mediaState = { ...mediaState, [key]: next }
117
+ if (next === getMedia()[key]) return
118
+ setMediaState({ ...getMedia(), [key]: next })
141
119
  updateMediaListeners()
142
120
  }
143
121
 
@@ -148,7 +126,7 @@ export function setupMediaListeners() {
148
126
  const listeners = new Set<any>()
149
127
 
150
128
  export function updateMediaListeners() {
151
- listeners.forEach((cb) => cb(mediaState))
129
+ listeners.forEach((cb) => cb(getMedia()))
152
130
  }
153
131
 
154
132
  type MediaState = {
@@ -185,6 +163,8 @@ export function useMedia(
185
163
  componentContext?: ComponentContextI,
186
164
  debug?: DebugProp
187
165
  ): UseMediaState {
166
+ 'use no memo'
167
+
188
168
  const componentState = componentContext ? States.get(componentContext) : null
189
169
 
190
170
  const internalRef = useRef<{
@@ -195,7 +175,7 @@ export function useMedia(
195
175
  if (!internalRef.current) {
196
176
  internalRef.current = {
197
177
  keys: new Set(),
198
- lastState: mediaState,
178
+ lastState: getMedia(),
199
179
  }
200
180
  }
201
181
 
@@ -222,22 +202,23 @@ export function useMedia(
222
202
  return lastState
223
203
  }
224
204
 
205
+ const ms = getMedia()
225
206
  for (const key of curKeys) {
226
- if (mediaState[key] !== (pendingState || lastState)[key]) {
207
+ if (ms[key] !== (pendingState || lastState)[key]) {
227
208
  if (process.env.NODE_ENV === 'development' && debug) {
228
- console.warn(`useMedia() ✍️`, key, lastState[key], '=>', mediaState[key])
209
+ console.warn(`useMedia() ✍️`, key, lastState[key], '=>', ms[key])
229
210
  }
230
211
 
231
212
  // in emitter mode (no-rerender) avoid changing state, instead emit
232
213
  if (componentContext?.mediaEmit) {
233
- componentContext.mediaEmit(mediaState)
234
- internalRef.current!.pendingState = mediaState
214
+ componentContext.mediaEmit(ms)
215
+ internalRef.current!.pendingState = ms
235
216
  return lastState
236
217
  }
237
218
 
238
- internalRef.current!.lastState = mediaState
219
+ internalRef.current!.lastState = ms
239
220
 
240
- return mediaState
221
+ return ms
241
222
  }
242
223
  }
243
224
 
@@ -291,41 +272,13 @@ export const getMediaImportanceIfMoreImportant = (
291
272
  return !usedKeys[key] || importance > usedKeys[key] ? importance : null
292
273
  }
293
274
 
294
- function camelToHyphen(str: string) {
295
- return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`).toLowerCase()
296
- }
297
-
298
- const cache = new WeakMap<any, string>()
299
275
  const cachedMediaKeyToQuery: Record<string, string> = {}
300
276
 
301
- export function mediaObjectToString(query: string | MediaQueryObject, key?: string) {
302
- if (typeof query === 'string') {
303
- return query
304
- }
305
- if (cache.has(query)) {
306
- return cache.get(query)!
307
- }
308
- const res = Object.entries(query)
309
- .map(([feature, value]) => {
310
- feature = camelToHyphen(feature)
311
- if (typeof value === 'string') {
312
- return `(${feature}: ${value})`
313
- }
314
- if (typeof value === 'number' && /[height|width]$/.test(feature)) {
315
- value = `${value}px`
316
- }
317
- return `(${feature}: ${value})`
318
- })
319
- .join(' and ')
320
- if (key) {
321
- cachedMediaKeyToQuery[key] = res
322
- }
323
- cache.set(query, res)
324
- return res
325
- }
326
-
327
277
  export function mediaKeyToQuery(key: string) {
328
- return cachedMediaKeyToQuery[key] || mediaObjectToString(mediaQueryConfig[key], key)
278
+ return (
279
+ cachedMediaKeyToQuery[key] ||
280
+ (cachedMediaKeyToQuery[key] = mediaObjectToString(mediaQueryConfig[key]))
281
+ )
329
282
  }
330
283
 
331
284
  export function mediaKeyMatch(
@@ -9,7 +9,8 @@ import type { SplitStyleProps, StaticConfig, ThemeParsed, UseMediaState } from '
9
9
  import type { ViewProps, ViewStyle } from '../views/View'
10
10
  import { View } from '../views/View'
11
11
  import { useComponentState } from './useComponentState'
12
- import { mediaState, useMedia } from './useMedia'
12
+ import { mediaState } from '../helpers/mediaState'
13
+ import { useMedia } from './useMedia'
13
14
  import { useThemeWithState } from './useTheme'
14
15
 
15
16
  type UsePropsOptions = Pick<
@@ -6,6 +6,8 @@ import { useThemeState } from './useThemeState'
6
6
  const EMPTY = {}
7
7
 
8
8
  export const useTheme = () => {
9
+ 'use no memo'
10
+
9
11
  const [theme] = useThemeWithState(EMPTY)
10
12
  const res = theme
11
13
  return res as ThemeProxied
@@ -20,6 +22,8 @@ export const useThemeWithState = (
20
22
  props: UseThemeWithStateProps,
21
23
  isRoot = false
22
24
  ): ThemeWithState => {
25
+ 'use no memo'
26
+
23
27
  const keys = useRef<Set<string> | null>(null)
24
28
  const schemeKeys = useRef<Set<string> | null>(null)
25
29
  const themeState = useThemeState(props, isRoot, keys, schemeKeys)
@@ -40,9 +40,12 @@ export const forceUpdateThemes = () => {
40
40
 
41
41
  export const getThemeState = (id: ID) => states.get(id)
42
42
 
43
- // const cache = new Map<string, ThemeState>()
44
43
  let cacheVersion = 0
45
44
 
45
+ // cache for getNewThemeName - invalidated on cacheVersion change
46
+ const themeNameCache = new Map<string, string | null>()
47
+ let themeNameCacheVer = -1
48
+
46
49
  let themes: Record<string, ThemeParsed> | null = null
47
50
 
48
51
  let rootThemeState: ThemeState | null = null
@@ -57,11 +60,19 @@ export const useThemeState = (
57
60
  keys: MutableRefObject<Set<string> | null>,
58
61
  schemeKeys?: MutableRefObject<Set<string> | null>
59
62
  ): ThemeState => {
63
+ 'use no memo'
64
+
60
65
  const { disable } = props
61
66
  const parentId = useContext(ThemeStateContext)
62
67
 
63
68
  if (!parentId && !isRoot) {
64
- throw new Error(MISSING_THEME_MESSAGE)
69
+ throw new Error(
70
+ process.env.NODE_ENV === 'development'
71
+ ? `${MISSING_THEME_MESSAGE}
72
+
73
+ Looked for theme${props.name ? ` "${props.name}"` : ''}${props.componentName ? ` (component: ${props.componentName})` : ''}, but no parent theme context was found (parentId: ${parentId}).`
74
+ : MISSING_THEME_MESSAGE
75
+ )
65
76
  }
66
77
 
67
78
  if (disable) {
@@ -78,7 +89,7 @@ export const useThemeState = (
78
89
  const id = useId()
79
90
  const subscribe = useCallback(
80
91
  (cb: Function) => {
81
- listenersByParent[parentId] ||= new Set()
92
+ listenersByParent[parentId] = listenersByParent[parentId] || new Set()
82
93
  listenersByParent[parentId].add(id)
83
94
  allListeners.set(id, () => {
84
95
  PendingUpdate.set(id, shouldForce ? 'force' : true)
@@ -101,6 +112,17 @@ export const useThemeState = (
101
112
  let local = localStates.get(id)
102
113
  const parentState = states.get(parentId)
103
114
 
115
+ // fast path: nothing changed since last snapshot
116
+ if (local && !PendingUpdate.has(id)) {
117
+ if (
118
+ parentState &&
119
+ (local as any)._parentName === parentState.name &&
120
+ (local as any)._propsKey === propsKey
121
+ ) {
122
+ return local
123
+ }
124
+ }
125
+
104
126
  // check if this is a scheme-only change (light↔dark) where DynamicColorIOS handles it
105
127
  const isSchemeOnlyChange =
106
128
  process.env.TAMAGUI_TARGET === 'native' &&
@@ -130,13 +152,6 @@ export const useThemeState = (
130
152
  ? true
131
153
  : props.needsUpdate?.()
132
154
 
133
- // const cacheKey = `${cacheVersion}${id}${propsKey}${parentState?.name || ''}${isRoot}`
134
- // if (!needsUpdate) {
135
- // if (cache.has(cacheKey)) {
136
- // return cache.get(cacheKey)!
137
- // }
138
- // }
139
-
140
155
  const [rerender, next] = getNextState(
141
156
  local,
142
157
  props,
@@ -176,8 +191,12 @@ export const useThemeState = (
176
191
  console.groupEnd()
177
192
  }
178
193
 
179
- Object.assign(local, next)
180
- local.id = id
194
+ if (next !== local) {
195
+ Object.assign(local, next)
196
+ local.id = id
197
+ }
198
+ ;(local as any)._parentName = parentState?.name
199
+ ;(local as any)._propsKey = propsKey
181
200
  states.set(id, next)
182
201
 
183
202
  return local
@@ -258,6 +277,9 @@ const getNextState = (
258
277
  }
259
278
 
260
279
  if (isSameAsParent) {
280
+ if (!shouldRerender && lastState && lastState.name === parentState!.name) {
281
+ return [false, lastState]
282
+ }
261
283
  return [shouldRerender, { ...parentState, isNew: false }]
262
284
  }
263
285
 
@@ -265,7 +287,13 @@ const getNextState = (
265
287
  const next = lastState ?? parentState
266
288
 
267
289
  if (!next) {
268
- throw new Error(MISSING_THEME_MESSAGE)
290
+ throw new Error(
291
+ process.env.NODE_ENV === 'development'
292
+ ? `${MISSING_THEME_MESSAGE}
293
+
294
+ Looked for theme${props.name ? ` "${props.name}"` : ''}${props.componentName ? ` (component: ${props.componentName})` : ''}, but no theme state was resolved (parentId: ${parentId}, id: ${id}).`
295
+ : MISSING_THEME_MESSAGE
296
+ )
269
297
  }
270
298
 
271
299
  if (shouldRerender) {
@@ -372,6 +400,16 @@ function getNewThemeName(
372
400
  )
373
401
  }
374
402
 
403
+ // check cache
404
+ const cacheKey = `${parentName}|${name || ''}|${componentName || ''}|${reset ? 1 : 0}|${forceUpdate ? 1 : 0}`
405
+ if (themeNameCacheVer !== cacheVersion) {
406
+ themeNameCache.clear()
407
+ themeNameCacheVer = cacheVersion
408
+ } else {
409
+ const cached = themeNameCache.get(cacheKey)
410
+ if (cached !== undefined) return cached
411
+ }
412
+
375
413
  const { themes } = getConfig()
376
414
 
377
415
  if (reset) {
@@ -381,7 +419,9 @@ function getNewThemeName(
381
419
  const isSchemeOnly = parentName === 'light' || parentName === 'dark'
382
420
  if (isSchemeOnly) {
383
421
  // If parent is just a scheme, go to the opposite scheme
384
- return parentName === 'light' ? 'dark' : 'light'
422
+ const result = parentName === 'light' ? 'dark' : 'light'
423
+ themeNameCache.set(cacheKey, result)
424
+ return result
385
425
  }
386
426
 
387
427
  // For compound themes like "dark_blue", extract the scheme
@@ -390,6 +430,7 @@ function getNewThemeName(
390
430
  const name = lastPartIndex <= 0 ? parentName : parentName.slice(lastPartIndex)
391
431
  const scheme = parentName.slice(0, lastPartIndex)
392
432
  const result = themes[name] ? name : scheme
433
+ themeNameCache.set(cacheKey, result)
393
434
  return result
394
435
  }
395
436
 
@@ -502,9 +543,11 @@ function getNewThemeName(
502
543
  // and we want to avoid reparenting
503
544
  !validSchemes[found]
504
545
  ) {
546
+ themeNameCache.set(cacheKey, null)
505
547
  return null
506
548
  }
507
549
 
550
+ themeNameCache.set(cacheKey, found)
508
551
  return found
509
552
  }
510
553
 
package/src/index.ts CHANGED
@@ -28,6 +28,7 @@ export * from './helpers/propMapper'
28
28
  export * from './helpers/proxyThemeToParents'
29
29
  export * from './helpers/proxyThemeVariables'
30
30
  export * from './helpers/pseudoDescriptors'
31
+ export * from './helpers/pseudoTransitions'
31
32
  export * from './helpers/themeable'
32
33
  export * from './helpers/themes'
33
34
  export * from './helpers/transformsToString'
@@ -73,19 +74,18 @@ export * from './hooks/useIsTouchDevice'
73
74
  export {
74
75
  _disableMediaTouch,
75
76
  configureMedia,
76
- getMedia,
77
77
  mediaKeyMatch,
78
- mediaObjectToString,
79
- mediaQueryConfig,
80
- mediaState,
81
78
  useMedia,
82
79
  } from './hooks/useMedia'
80
+ export { mediaObjectToString } from './helpers/mediaObjectToString'
81
+ export { getMedia, mediaQueryConfig, mediaState } from './helpers/mediaState'
83
82
  export * from './hooks/useProps'
84
83
  export * from './hooks/useTheme'
85
84
  export * from './hooks/useThemeName'
86
85
  export { forceUpdateThemes } from './hooks/useThemeState'
87
86
 
88
87
  export * from './views/Configuration'
88
+ export * from './views/TamaguiRoot'
89
89
  export * from './views/FontLanguage'
90
90
  export * from './views/Slot'
91
91
  export * from './views/TamaguiProvider'
package/src/styled.tsx CHANGED
@@ -31,6 +31,7 @@ import type {
31
31
  TamaguiComponentPropsBase,
32
32
  TextStyle,
33
33
  TextStylePropsBase,
34
+ ThemeValueByCategory,
34
35
  ThemeValueGet,
35
36
  VariantDefinitions,
36
37
  VariantSpreadFunction,
@@ -232,7 +233,6 @@ function styled<
232
233
  ) {
233
234
  // do type stuff at top for easier readability
234
235
 
235
- // get parent props without pseudos and medias so we can rebuild both with new variants
236
236
  // get parent props without pseudos and medias so we can rebuild both with new variants
237
237
  type ParentNonStyledProps = GetNonStyledProps<ParentComponent>
238
238
  type ParentStylesBase = GetBaseStyles<ParentComponent, StyledConfig>
@@ -262,7 +262,7 @@ function styled<
262
262
  ? Partial<InferStyleProps<ParentComponent, StyledConfig>>
263
263
  : Accepted[Key] extends 'textStyle'
264
264
  ? Partial<InferStyleProps<typeof Text, StyledConfig>>
265
- : Omit<ThemeValueGet<Accepted[Key]>, 'unset'>)
265
+ : ThemeValueByCategory<Accepted[Key]>)
266
266
  }
267
267
  : {}
268
268