@hanzogui/react-native-web-internals 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (420) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/StyleSheet/__tests__/compiler-createReactDOMStyle-test.cjs +240 -0
  3. package/dist/cjs/StyleSheet/__tests__/compiler-test.cjs +407 -0
  4. package/dist/cjs/StyleSheet/__tests__/dom-createOrderedCSSStyleSheet-test.cjs +121 -0
  5. package/dist/cjs/StyleSheet/__tests__/index-test.cjs +404 -0
  6. package/dist/cjs/StyleSheet/__tests__/preprocess-test.cjs +108 -0
  7. package/dist/cjs/StyleSheet/__tests__/validate-test.cjs +36 -0
  8. package/dist/cjs/StyleSheet/compiler/createReactDOMStyle.cjs +87 -0
  9. package/dist/cjs/StyleSheet/compiler/hash.cjs +26 -0
  10. package/dist/cjs/StyleSheet/compiler/hyphenateStyleName.cjs +36 -0
  11. package/dist/cjs/StyleSheet/compiler/index.cjs +318 -0
  12. package/dist/cjs/StyleSheet/compiler/normalizeColor.cjs +40 -0
  13. package/dist/cjs/StyleSheet/compiler/normalizeValueWithProperty.cjs +43 -0
  14. package/dist/cjs/StyleSheet/compiler/resolveShadowValue.cjs +48 -0
  15. package/dist/cjs/StyleSheet/dom/createCSSStyleSheet.cjs +37 -0
  16. package/dist/cjs/StyleSheet/dom/createOrderedCSSStyleSheet.cjs +110 -0
  17. package/dist/cjs/StyleSheet/dom/index.cjs +67 -0
  18. package/dist/cjs/StyleSheet/index.cjs +57 -0
  19. package/dist/cjs/StyleSheet/preprocess.cjs +101 -0
  20. package/dist/cjs/StyleSheet/validate.cjs +69 -0
  21. package/dist/cjs/TextAncestorContext.cjs +27 -0
  22. package/dist/cjs/colorProps.cjs +37 -0
  23. package/dist/cjs/index.cjs +103 -0
  24. package/dist/cjs/modules/AccessibilityUtil/__tests__/propsToAccessibilityComponent-test.cjs +50 -0
  25. package/dist/cjs/modules/AccessibilityUtil/__tests__/propsToAriaRole-test.cjs +40 -0
  26. package/dist/cjs/modules/AccessibilityUtil/index.cjs +33 -0
  27. package/dist/cjs/modules/AccessibilityUtil/isDisabled.cjs +26 -0
  28. package/dist/cjs/modules/AccessibilityUtil/propsToAccessibilityComponent.cjs +57 -0
  29. package/dist/cjs/modules/AccessibilityUtil/propsToAriaRole.cjs +47 -0
  30. package/dist/cjs/modules/AssetRegistry/index.cjs +33 -0
  31. package/dist/cjs/modules/ImageLoader/index.cjs +111 -0
  32. package/dist/cjs/modules/InteractionManager.cjs +184 -0
  33. package/dist/cjs/modules/Platform/__tests__/index-test.cjs +48 -0
  34. package/dist/cjs/modules/Platform/index.cjs +30 -0
  35. package/dist/cjs/modules/TextInputState/index.cjs +55 -0
  36. package/dist/cjs/modules/UIManager/__tests__/index-test.cjs +90 -0
  37. package/dist/cjs/modules/UIManager/index.cjs +60 -0
  38. package/dist/cjs/modules/canUseDOM.cjs +26 -0
  39. package/dist/cjs/modules/createDOMProps/__tests__/index-test.cjs +156 -0
  40. package/dist/cjs/modules/createDOMProps/index.cjs +179 -0
  41. package/dist/cjs/modules/createEventHandle/__tests__/index-test.cjs +344 -0
  42. package/dist/cjs/modules/createEventHandle/index.cjs +67 -0
  43. package/dist/cjs/modules/dismissKeyboard/index.cjs +29 -0
  44. package/dist/cjs/modules/forwardedProps/index.cjs +161 -0
  45. package/dist/cjs/modules/getBoundingClientRect/index.cjs +28 -0
  46. package/dist/cjs/modules/invariant.cjs +36 -0
  47. package/dist/cjs/modules/isSelectionValid/index.cjs +35 -0
  48. package/dist/cjs/modules/isWebColor/index.cjs +26 -0
  49. package/dist/cjs/modules/mergeRefs/__tests__/index-test.cjs +42 -0
  50. package/dist/cjs/modules/mergeRefs/index.cjs +42 -0
  51. package/dist/cjs/modules/modality/__tests__/index-test.cjs +32 -0
  52. package/dist/cjs/modules/modality/index.cjs +135 -0
  53. package/dist/cjs/modules/multiplyStyleLengthValue/__tests__/index-test.cjs +30 -0
  54. package/dist/cjs/modules/multiplyStyleLengthValue/index.cjs +35 -0
  55. package/dist/cjs/modules/normalizeColor/index.cjs +39 -0
  56. package/dist/cjs/modules/pick/index.cjs +30 -0
  57. package/dist/cjs/modules/processColor/__tests__/index-test.cjs +66 -0
  58. package/dist/cjs/modules/processColor/index.cjs +42 -0
  59. package/dist/cjs/modules/requestIdleCallback/index.cjs +44 -0
  60. package/dist/cjs/modules/setValueForStyles/dangerousStyleValue.cjs +35 -0
  61. package/dist/cjs/modules/setValueForStyles/index.cjs +35 -0
  62. package/dist/cjs/modules/unitlessNumbers/index.cjs +85 -0
  63. package/dist/cjs/modules/useElementLayout/index.cjs +39 -0
  64. package/dist/cjs/modules/useEvent/__tests__/index-test.cjs +408 -0
  65. package/dist/cjs/modules/useEvent/index.cjs +45 -0
  66. package/dist/cjs/modules/useHover/__tests__/index-test.cjs +273 -0
  67. package/dist/cjs/modules/useHover/index.cjs +97 -0
  68. package/dist/cjs/modules/useLayoutEffect/index.cjs +39 -0
  69. package/dist/cjs/modules/useLocale/index.cjs +66 -0
  70. package/dist/cjs/modules/useLocale/isLocaleRTL.cjs +83 -0
  71. package/dist/cjs/modules/useMergeRefs/__tests__/index-test.cjs +102 -0
  72. package/dist/cjs/modules/useMergeRefs/index.cjs +43 -0
  73. package/dist/cjs/modules/usePlatformMethods/index.cjs +35 -0
  74. package/dist/cjs/modules/useStable/__tests__/index-test.cjs +92 -0
  75. package/dist/cjs/modules/useStable/index.cjs +42 -0
  76. package/dist/cjs/styleTypes.cjs +16 -0
  77. package/dist/cjs/types.cjs +16 -0
  78. package/dist/esm/StyleSheet/__tests__/compiler-createReactDOMStyle-test.mjs +219 -0
  79. package/dist/esm/StyleSheet/__tests__/compiler-createReactDOMStyle-test.mjs.map +1 -0
  80. package/dist/esm/StyleSheet/__tests__/compiler-test.mjs +408 -0
  81. package/dist/esm/StyleSheet/__tests__/compiler-test.mjs.map +1 -0
  82. package/dist/esm/StyleSheet/__tests__/dom-createOrderedCSSStyleSheet-test.mjs +100 -0
  83. package/dist/esm/StyleSheet/__tests__/dom-createOrderedCSSStyleSheet-test.mjs.map +1 -0
  84. package/dist/esm/StyleSheet/__tests__/index-test.mjs +383 -0
  85. package/dist/esm/StyleSheet/__tests__/index-test.mjs.map +1 -0
  86. package/dist/esm/StyleSheet/__tests__/preprocess-test.mjs +109 -0
  87. package/dist/esm/StyleSheet/__tests__/preprocess-test.mjs.map +1 -0
  88. package/dist/esm/StyleSheet/__tests__/validate-test.mjs +37 -0
  89. package/dist/esm/StyleSheet/__tests__/validate-test.mjs.map +1 -0
  90. package/dist/esm/StyleSheet/compiler/createReactDOMStyle.mjs +63 -0
  91. package/dist/esm/StyleSheet/compiler/createReactDOMStyle.mjs.map +1 -0
  92. package/dist/esm/StyleSheet/compiler/hash.mjs +3 -0
  93. package/dist/esm/StyleSheet/compiler/hash.mjs.map +1 -0
  94. package/dist/esm/StyleSheet/compiler/hyphenateStyleName.mjs +13 -0
  95. package/dist/esm/StyleSheet/compiler/hyphenateStyleName.mjs.map +1 -0
  96. package/dist/esm/StyleSheet/compiler/index.mjs +292 -0
  97. package/dist/esm/StyleSheet/compiler/index.mjs.map +1 -0
  98. package/dist/esm/StyleSheet/compiler/normalizeColor.mjs +17 -0
  99. package/dist/esm/StyleSheet/compiler/normalizeColor.mjs.map +1 -0
  100. package/dist/esm/StyleSheet/compiler/normalizeValueWithProperty.mjs +20 -0
  101. package/dist/esm/StyleSheet/compiler/normalizeValueWithProperty.mjs.map +1 -0
  102. package/dist/esm/StyleSheet/compiler/resolveShadowValue.mjs +25 -0
  103. package/dist/esm/StyleSheet/compiler/resolveShadowValue.mjs.map +1 -0
  104. package/dist/esm/StyleSheet/dom/createCSSStyleSheet.mjs +14 -0
  105. package/dist/esm/StyleSheet/dom/createCSSStyleSheet.mjs.map +1 -0
  106. package/dist/esm/StyleSheet/dom/createOrderedCSSStyleSheet.mjs +87 -0
  107. package/dist/esm/StyleSheet/dom/createOrderedCSSStyleSheet.mjs.map +1 -0
  108. package/dist/esm/StyleSheet/dom/index.mjs +44 -0
  109. package/dist/esm/StyleSheet/dom/index.mjs.map +1 -0
  110. package/dist/esm/StyleSheet/index.mjs +33 -0
  111. package/dist/esm/StyleSheet/index.mjs.map +1 -0
  112. package/dist/esm/StyleSheet/preprocess.mjs +75 -0
  113. package/dist/esm/StyleSheet/preprocess.mjs.map +1 -0
  114. package/dist/esm/StyleSheet/validate.mjs +46 -0
  115. package/dist/esm/StyleSheet/validate.mjs.map +1 -0
  116. package/dist/esm/TextAncestorContext.mjs +4 -0
  117. package/dist/esm/TextAncestorContext.mjs.map +1 -0
  118. package/dist/esm/colorProps.mjs +14 -0
  119. package/dist/esm/colorProps.mjs.map +1 -0
  120. package/dist/esm/index.js +45 -0
  121. package/dist/esm/index.js.map +1 -0
  122. package/dist/esm/index.mjs +45 -0
  123. package/dist/esm/index.mjs.map +1 -0
  124. package/dist/esm/modules/AccessibilityUtil/__tests__/propsToAccessibilityComponent-test.mjs +29 -0
  125. package/dist/esm/modules/AccessibilityUtil/__tests__/propsToAccessibilityComponent-test.mjs.map +1 -0
  126. package/dist/esm/modules/AccessibilityUtil/__tests__/propsToAriaRole-test.mjs +19 -0
  127. package/dist/esm/modules/AccessibilityUtil/__tests__/propsToAriaRole-test.mjs.map +1 -0
  128. package/dist/esm/modules/AccessibilityUtil/index.mjs +10 -0
  129. package/dist/esm/modules/AccessibilityUtil/index.mjs.map +1 -0
  130. package/dist/esm/modules/AccessibilityUtil/isDisabled.mjs +3 -0
  131. package/dist/esm/modules/AccessibilityUtil/isDisabled.mjs.map +1 -0
  132. package/dist/esm/modules/AccessibilityUtil/propsToAccessibilityComponent.mjs +34 -0
  133. package/dist/esm/modules/AccessibilityUtil/propsToAccessibilityComponent.mjs.map +1 -0
  134. package/dist/esm/modules/AccessibilityUtil/propsToAriaRole.mjs +24 -0
  135. package/dist/esm/modules/AccessibilityUtil/propsToAriaRole.mjs.map +1 -0
  136. package/dist/esm/modules/AssetRegistry/index.mjs +9 -0
  137. package/dist/esm/modules/AssetRegistry/index.mjs.map +1 -0
  138. package/dist/esm/modules/ImageLoader/index.mjs +87 -0
  139. package/dist/esm/modules/ImageLoader/index.mjs.map +1 -0
  140. package/dist/esm/modules/InteractionManager.mjs +161 -0
  141. package/dist/esm/modules/InteractionManager.mjs.map +1 -0
  142. package/dist/esm/modules/Platform/__tests__/index-test.mjs +27 -0
  143. package/dist/esm/modules/Platform/__tests__/index-test.mjs.map +1 -0
  144. package/dist/esm/modules/Platform/index.mjs +7 -0
  145. package/dist/esm/modules/Platform/index.mjs.map +1 -0
  146. package/dist/esm/modules/TextInputState/index.mjs +32 -0
  147. package/dist/esm/modules/TextInputState/index.mjs.map +1 -0
  148. package/dist/esm/modules/UIManager/__tests__/index-test.mjs +69 -0
  149. package/dist/esm/modules/UIManager/__tests__/index-test.mjs.map +1 -0
  150. package/dist/esm/modules/UIManager/index.mjs +37 -0
  151. package/dist/esm/modules/UIManager/index.mjs.map +1 -0
  152. package/dist/esm/modules/canUseDOM.mjs +3 -0
  153. package/dist/esm/modules/canUseDOM.mjs.map +1 -0
  154. package/dist/esm/modules/createDOMProps/__tests__/index-test.mjs +135 -0
  155. package/dist/esm/modules/createDOMProps/__tests__/index-test.mjs.map +1 -0
  156. package/dist/esm/modules/createDOMProps/index.mjs +155 -0
  157. package/dist/esm/modules/createDOMProps/index.mjs.map +1 -0
  158. package/dist/esm/modules/createEventHandle/__tests__/index-test.mjs +323 -0
  159. package/dist/esm/modules/createEventHandle/__tests__/index-test.mjs.map +1 -0
  160. package/dist/esm/modules/createEventHandle/index.mjs +42 -0
  161. package/dist/esm/modules/createEventHandle/index.mjs.map +1 -0
  162. package/dist/esm/modules/dismissKeyboard/index.mjs +6 -0
  163. package/dist/esm/modules/dismissKeyboard/index.mjs.map +1 -0
  164. package/dist/esm/modules/forwardedProps/index.mjs +128 -0
  165. package/dist/esm/modules/forwardedProps/index.mjs.map +1 -0
  166. package/dist/esm/modules/getBoundingClientRect/index.mjs +5 -0
  167. package/dist/esm/modules/getBoundingClientRect/index.mjs.map +1 -0
  168. package/dist/esm/modules/invariant.mjs +12 -0
  169. package/dist/esm/modules/invariant.mjs.map +1 -0
  170. package/dist/esm/modules/isSelectionValid/index.mjs +12 -0
  171. package/dist/esm/modules/isSelectionValid/index.mjs.map +1 -0
  172. package/dist/esm/modules/isWebColor/index.mjs +3 -0
  173. package/dist/esm/modules/isWebColor/index.mjs.map +1 -0
  174. package/dist/esm/modules/mergeRefs/__tests__/index-test.mjs +21 -0
  175. package/dist/esm/modules/mergeRefs/__tests__/index-test.mjs.map +1 -0
  176. package/dist/esm/modules/mergeRefs/index.mjs +19 -0
  177. package/dist/esm/modules/mergeRefs/index.mjs.map +1 -0
  178. package/dist/esm/modules/modality/__tests__/index-test.mjs +33 -0
  179. package/dist/esm/modules/modality/__tests__/index-test.mjs.map +1 -0
  180. package/dist/esm/modules/modality/index.mjs +109 -0
  181. package/dist/esm/modules/modality/index.mjs.map +1 -0
  182. package/dist/esm/modules/multiplyStyleLengthValue/__tests__/index-test.mjs +9 -0
  183. package/dist/esm/modules/multiplyStyleLengthValue/__tests__/index-test.mjs.map +1 -0
  184. package/dist/esm/modules/multiplyStyleLengthValue/index.mjs +12 -0
  185. package/dist/esm/modules/multiplyStyleLengthValue/index.mjs.map +1 -0
  186. package/dist/esm/modules/normalizeColor/index.mjs +16 -0
  187. package/dist/esm/modules/normalizeColor/index.mjs.map +1 -0
  188. package/dist/esm/modules/pick/index.mjs +7 -0
  189. package/dist/esm/modules/pick/index.mjs.map +1 -0
  190. package/dist/esm/modules/processColor/__tests__/index-test.mjs +45 -0
  191. package/dist/esm/modules/processColor/__tests__/index-test.mjs.map +1 -0
  192. package/dist/esm/modules/processColor/index.mjs +8 -0
  193. package/dist/esm/modules/processColor/index.mjs.map +1 -0
  194. package/dist/esm/modules/requestIdleCallback/index.mjs +20 -0
  195. package/dist/esm/modules/requestIdleCallback/index.mjs.map +1 -0
  196. package/dist/esm/modules/setValueForStyles/dangerousStyleValue.mjs +12 -0
  197. package/dist/esm/modules/setValueForStyles/dangerousStyleValue.mjs.map +1 -0
  198. package/dist/esm/modules/setValueForStyles/index.mjs +12 -0
  199. package/dist/esm/modules/setValueForStyles/index.mjs.map +1 -0
  200. package/dist/esm/modules/unitlessNumbers/index.mjs +62 -0
  201. package/dist/esm/modules/unitlessNumbers/index.mjs.map +1 -0
  202. package/dist/esm/modules/useElementLayout/index.mjs +16 -0
  203. package/dist/esm/modules/useElementLayout/index.mjs.map +1 -0
  204. package/dist/esm/modules/useEvent/__tests__/index-test.mjs +387 -0
  205. package/dist/esm/modules/useEvent/__tests__/index-test.mjs.map +1 -0
  206. package/dist/esm/modules/useEvent/index.mjs +22 -0
  207. package/dist/esm/modules/useEvent/index.mjs.map +1 -0
  208. package/dist/esm/modules/useHover/__tests__/index-test.mjs +252 -0
  209. package/dist/esm/modules/useHover/__tests__/index-test.mjs.map +1 -0
  210. package/dist/esm/modules/useHover/index.mjs +74 -0
  211. package/dist/esm/modules/useHover/index.mjs.map +1 -0
  212. package/dist/esm/modules/useLayoutEffect/index.mjs +5 -0
  213. package/dist/esm/modules/useLayoutEffect/index.mjs.map +1 -0
  214. package/dist/esm/modules/useLocale/index.mjs +30 -0
  215. package/dist/esm/modules/useLocale/index.mjs.map +1 -0
  216. package/dist/esm/modules/useLocale/isLocaleRTL.mjs +60 -0
  217. package/dist/esm/modules/useLocale/isLocaleRTL.mjs.map +1 -0
  218. package/dist/esm/modules/useMergeRefs/__tests__/index-test.mjs +81 -0
  219. package/dist/esm/modules/useMergeRefs/__tests__/index-test.mjs.map +1 -0
  220. package/dist/esm/modules/useMergeRefs/index.mjs +9 -0
  221. package/dist/esm/modules/useMergeRefs/index.mjs.map +1 -0
  222. package/dist/esm/modules/usePlatformMethods/index.mjs +12 -0
  223. package/dist/esm/modules/usePlatformMethods/index.mjs.map +1 -0
  224. package/dist/esm/modules/useStable/__tests__/index-test.mjs +71 -0
  225. package/dist/esm/modules/useStable/__tests__/index-test.mjs.map +1 -0
  226. package/dist/esm/modules/useStable/index.mjs +8 -0
  227. package/dist/esm/modules/useStable/index.mjs.map +1 -0
  228. package/dist/esm/styleTypes.mjs +2 -0
  229. package/dist/esm/styleTypes.mjs.map +1 -0
  230. package/dist/esm/types.mjs +2 -0
  231. package/dist/esm/types.mjs.map +1 -0
  232. package/package.json +58 -0
  233. package/src/StyleSheet/__tests__/compiler-createReactDOMStyle-test.tsx +236 -0
  234. package/src/StyleSheet/__tests__/compiler-test.tsx +426 -0
  235. package/src/StyleSheet/__tests__/dom-createOrderedCSSStyleSheet-test.tsx +169 -0
  236. package/src/StyleSheet/__tests__/index-test.tsx +406 -0
  237. package/src/StyleSheet/__tests__/preprocess-test.tsx +107 -0
  238. package/src/StyleSheet/__tests__/validate-test.tsx +42 -0
  239. package/src/StyleSheet/compiler/createReactDOMStyle.tsx +215 -0
  240. package/src/StyleSheet/compiler/hash.tsx +1 -0
  241. package/src/StyleSheet/compiler/hyphenateStyleName.tsx +25 -0
  242. package/src/StyleSheet/compiler/index.tsx +478 -0
  243. package/src/StyleSheet/compiler/normalizeColor.tsx +35 -0
  244. package/src/StyleSheet/compiler/normalizeValueWithProperty.tsx +34 -0
  245. package/src/StyleSheet/compiler/resolveShadowValue.tsx +26 -0
  246. package/src/StyleSheet/dom/createCSSStyleSheet.tsx +42 -0
  247. package/src/StyleSheet/dom/createOrderedCSSStyleSheet.tsx +195 -0
  248. package/src/StyleSheet/dom/index.tsx +92 -0
  249. package/src/StyleSheet/index.tsx +99 -0
  250. package/src/StyleSheet/preprocess.tsx +119 -0
  251. package/src/StyleSheet/validate.tsx +90 -0
  252. package/src/TextAncestorContext.tsx +13 -0
  253. package/src/colorProps.tsx +12 -0
  254. package/src/index.tsx +58 -0
  255. package/src/modules/AccessibilityUtil/__tests__/propsToAccessibilityComponent-test.tsx +44 -0
  256. package/src/modules/AccessibilityUtil/__tests__/propsToAriaRole-test.tsx +25 -0
  257. package/src/modules/AccessibilityUtil/index.tsx +18 -0
  258. package/src/modules/AccessibilityUtil/isDisabled.tsx +13 -0
  259. package/src/modules/AccessibilityUtil/propsToAccessibilityComponent.tsx +54 -0
  260. package/src/modules/AccessibilityUtil/propsToAriaRole.tsx +37 -0
  261. package/src/modules/AssetRegistry/index.tsx +32 -0
  262. package/src/modules/ImageLoader/index.tsx +165 -0
  263. package/src/modules/InteractionManager.tsx +315 -0
  264. package/src/modules/Platform/__tests__/index-test.tsx +45 -0
  265. package/src/modules/Platform/index.tsx +15 -0
  266. package/src/modules/TextInputState/index.tsx +62 -0
  267. package/src/modules/UIManager/__tests__/index-test.tsx +87 -0
  268. package/src/modules/UIManager/index.tsx +68 -0
  269. package/src/modules/canUseDOM.tsx +14 -0
  270. package/src/modules/createDOMProps/__tests__/index-test.tsx +138 -0
  271. package/src/modules/createDOMProps/index.tsx +436 -0
  272. package/src/modules/createEventHandle/__tests__/index-test.tsx +459 -0
  273. package/src/modules/createEventHandle/index.tsx +100 -0
  274. package/src/modules/dismissKeyboard/index.tsx +14 -0
  275. package/src/modules/forwardedProps/index.tsx +145 -0
  276. package/src/modules/getBoundingClientRect/index.tsx +17 -0
  277. package/src/modules/invariant.ts +23 -0
  278. package/src/modules/isSelectionValid/index.tsx +20 -0
  279. package/src/modules/isWebColor/index.tsx +14 -0
  280. package/src/modules/mergeRefs/__tests__/index-test.tsx +32 -0
  281. package/src/modules/mergeRefs/index.tsx +36 -0
  282. package/src/modules/modality/__tests__/index-test.tsx +66 -0
  283. package/src/modules/modality/index.tsx +228 -0
  284. package/src/modules/multiplyStyleLengthValue/__tests__/index-test.tsx +23 -0
  285. package/src/modules/multiplyStyleLengthValue/index.tsx +26 -0
  286. package/src/modules/normalizeColor/index.tsx +32 -0
  287. package/src/modules/pick/index.tsx +25 -0
  288. package/src/modules/processColor/__tests__/index-test.tsx +78 -0
  289. package/src/modules/processColor/index.tsx +28 -0
  290. package/src/modules/requestIdleCallback/index.tsx +35 -0
  291. package/src/modules/setValueForStyles/dangerousStyleValue.tsx +74 -0
  292. package/src/modules/setValueForStyles/index.tsx +39 -0
  293. package/src/modules/unitlessNumbers/index.tsx +77 -0
  294. package/src/modules/useElementLayout/index.tsx +28 -0
  295. package/src/modules/useEvent/__tests__/index-test.tsx +511 -0
  296. package/src/modules/useEvent/index.tsx +64 -0
  297. package/src/modules/useHover/__tests__/index-test.tsx +342 -0
  298. package/src/modules/useHover/index.tsx +181 -0
  299. package/src/modules/useLayoutEffect/index.ts +15 -0
  300. package/src/modules/useLocale/index.tsx +57 -0
  301. package/src/modules/useLocale/isLocaleRTL.tsx +74 -0
  302. package/src/modules/useMergeRefs/__tests__/index-test.tsx +91 -0
  303. package/src/modules/useMergeRefs/index.tsx +22 -0
  304. package/src/modules/usePlatformMethods/index.tsx +40 -0
  305. package/src/modules/useStable/__tests__/index-test.tsx +101 -0
  306. package/src/modules/useStable/index.tsx +24 -0
  307. package/src/styleTypes.ts +321 -0
  308. package/src/types.ts +77 -0
  309. package/types/StyleSheet/compiler/createReactDOMStyle.d.ts +18 -0
  310. package/types/StyleSheet/compiler/createReactDOMStyle.d.ts.map +1 -0
  311. package/types/StyleSheet/compiler/hash.d.ts +2 -0
  312. package/types/StyleSheet/compiler/hash.d.ts.map +1 -0
  313. package/types/StyleSheet/compiler/hyphenateStyleName.d.ts +10 -0
  314. package/types/StyleSheet/compiler/hyphenateStyleName.d.ts.map +1 -0
  315. package/types/StyleSheet/compiler/index.d.ts +39 -0
  316. package/types/StyleSheet/compiler/index.d.ts.map +1 -0
  317. package/types/StyleSheet/compiler/normalizeColor.d.ts +10 -0
  318. package/types/StyleSheet/compiler/normalizeColor.d.ts.map +1 -0
  319. package/types/StyleSheet/compiler/normalizeValueWithProperty.d.ts +10 -0
  320. package/types/StyleSheet/compiler/normalizeValueWithProperty.d.ts.map +1 -0
  321. package/types/StyleSheet/compiler/resolveShadowValue.d.ts +10 -0
  322. package/types/StyleSheet/compiler/resolveShadowValue.d.ts.map +1 -0
  323. package/types/StyleSheet/dom/createCSSStyleSheet.d.ts +10 -0
  324. package/types/StyleSheet/dom/createCSSStyleSheet.d.ts.map +1 -0
  325. package/types/StyleSheet/dom/createOrderedCSSStyleSheet.d.ts +29 -0
  326. package/types/StyleSheet/dom/createOrderedCSSStyleSheet.d.ts.map +1 -0
  327. package/types/StyleSheet/dom/index.d.ts +15 -0
  328. package/types/StyleSheet/dom/index.d.ts.map +1 -0
  329. package/types/StyleSheet/index.d.ts +69 -0
  330. package/types/StyleSheet/index.d.ts.map +1 -0
  331. package/types/StyleSheet/preprocess.d.ts +16 -0
  332. package/types/StyleSheet/preprocess.d.ts.map +1 -0
  333. package/types/StyleSheet/validate.d.ts +10 -0
  334. package/types/StyleSheet/validate.d.ts.map +1 -0
  335. package/types/TextAncestorContext.d.ts +11 -0
  336. package/types/TextAncestorContext.d.ts.map +1 -0
  337. package/types/colorProps.d.ts +13 -0
  338. package/types/colorProps.d.ts.map +1 -0
  339. package/types/index.d.ts +45 -0
  340. package/types/index.d.ts.map +1 -0
  341. package/types/modules/AccessibilityUtil/index.d.ts +16 -0
  342. package/types/modules/AccessibilityUtil/index.d.ts.map +1 -0
  343. package/types/modules/AccessibilityUtil/isDisabled.d.ts +10 -0
  344. package/types/modules/AccessibilityUtil/isDisabled.d.ts.map +1 -0
  345. package/types/modules/AccessibilityUtil/propsToAccessibilityComponent.d.ts +10 -0
  346. package/types/modules/AccessibilityUtil/propsToAccessibilityComponent.d.ts.map +1 -0
  347. package/types/modules/AccessibilityUtil/propsToAriaRole.d.ts +12 -0
  348. package/types/modules/AccessibilityUtil/propsToAriaRole.d.ts.map +1 -0
  349. package/types/modules/AssetRegistry/index.d.ts +22 -0
  350. package/types/modules/AssetRegistry/index.d.ts.map +1 -0
  351. package/types/modules/ImageLoader/index.d.ts +27 -0
  352. package/types/modules/ImageLoader/index.d.ts.map +1 -0
  353. package/types/modules/InteractionManager.d.ts +48 -0
  354. package/types/modules/InteractionManager.d.ts.map +1 -0
  355. package/types/modules/Platform/index.d.ts +15 -0
  356. package/types/modules/Platform/index.d.ts.map +1 -0
  357. package/types/modules/TextInputState/index.d.ts +38 -0
  358. package/types/modules/TextInputState/index.d.ts.map +1 -0
  359. package/types/modules/UIManager/index.d.ts +23 -0
  360. package/types/modules/UIManager/index.d.ts.map +1 -0
  361. package/types/modules/canUseDOM.d.ts +10 -0
  362. package/types/modules/canUseDOM.d.ts.map +1 -0
  363. package/types/modules/createDOMProps/index.d.ts +12 -0
  364. package/types/modules/createDOMProps/index.d.ts.map +1 -0
  365. package/types/modules/createEventHandle/index.d.ts +20 -0
  366. package/types/modules/createEventHandle/index.d.ts.map +1 -0
  367. package/types/modules/dismissKeyboard/index.d.ts +10 -0
  368. package/types/modules/dismissKeyboard/index.d.ts.map +1 -0
  369. package/types/modules/forwardedProps/index.d.ts +383 -0
  370. package/types/modules/forwardedProps/index.d.ts.map +1 -0
  371. package/types/modules/getBoundingClientRect/index.d.ts +10 -0
  372. package/types/modules/getBoundingClientRect/index.d.ts.map +1 -0
  373. package/types/modules/invariant.d.ts +3 -0
  374. package/types/modules/invariant.d.ts.map +1 -0
  375. package/types/modules/isSelectionValid/index.d.ts +10 -0
  376. package/types/modules/isSelectionValid/index.d.ts.map +1 -0
  377. package/types/modules/isWebColor/index.d.ts +10 -0
  378. package/types/modules/isWebColor/index.d.ts.map +1 -0
  379. package/types/modules/mergeRefs/index.d.ts +11 -0
  380. package/types/modules/mergeRefs/index.d.ts.map +1 -0
  381. package/types/modules/modality/index.d.ts +17 -0
  382. package/types/modules/modality/index.d.ts.map +1 -0
  383. package/types/modules/multiplyStyleLengthValue/index.d.ts +10 -0
  384. package/types/modules/multiplyStyleLengthValue/index.d.ts.map +1 -0
  385. package/types/modules/normalizeColor/index.d.ts +10 -0
  386. package/types/modules/normalizeColor/index.d.ts.map +1 -0
  387. package/types/modules/pick/index.d.ts +12 -0
  388. package/types/modules/pick/index.d.ts.map +1 -0
  389. package/types/modules/processColor/index.d.ts +11 -0
  390. package/types/modules/processColor/index.d.ts.map +1 -0
  391. package/types/modules/requestIdleCallback/index.d.ts +3 -0
  392. package/types/modules/requestIdleCallback/index.d.ts.map +1 -0
  393. package/types/modules/setValueForStyles/dangerousStyleValue.d.ts +11 -0
  394. package/types/modules/setValueForStyles/dangerousStyleValue.d.ts.map +1 -0
  395. package/types/modules/setValueForStyles/index.d.ts +9 -0
  396. package/types/modules/setValueForStyles/index.d.ts.map +1 -0
  397. package/types/modules/unitlessNumbers/index.d.ts +60 -0
  398. package/types/modules/unitlessNumbers/index.d.ts.map +1 -0
  399. package/types/modules/useElementLayout/index.d.ts +4 -0
  400. package/types/modules/useElementLayout/index.d.ts.map +1 -0
  401. package/types/modules/useEvent/index.d.ts +24 -0
  402. package/types/modules/useEvent/index.d.ts.map +1 -0
  403. package/types/modules/useHover/index.d.ts +21 -0
  404. package/types/modules/useHover/index.d.ts.map +1 -0
  405. package/types/modules/useLayoutEffect/index.d.ts +13 -0
  406. package/types/modules/useLayoutEffect/index.d.ts.map +1 -0
  407. package/types/modules/useLocale/index.d.ts +14 -0
  408. package/types/modules/useLocale/index.d.ts.map +1 -0
  409. package/types/modules/useLocale/isLocaleRTL.d.ts +13 -0
  410. package/types/modules/useLocale/isLocaleRTL.d.ts.map +1 -0
  411. package/types/modules/useMergeRefs/index.d.ts +11 -0
  412. package/types/modules/useMergeRefs/index.d.ts.map +1 -0
  413. package/types/modules/usePlatformMethods/index.d.ts +18 -0
  414. package/types/modules/usePlatformMethods/index.d.ts.map +1 -0
  415. package/types/modules/useStable/index.d.ts +10 -0
  416. package/types/modules/useStable/index.d.ts.map +1 -0
  417. package/types/styleTypes.d.ts +211 -0
  418. package/types/styleTypes.d.ts.map +1 -0
  419. package/types/types.d.ts +46 -0
  420. package/types/types.d.ts.map +1 -0
@@ -0,0 +1,35 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all) __defProp(target, name, {
7
+ get: all[name],
8
+ enumerable: !0
9
+ });
10
+ },
11
+ __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
13
+ get: () => from[key],
14
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
15
+ });
16
+ return to;
17
+ };
18
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
19
+ value: !0
20
+ }), mod);
21
+ var setValueForStyles_exports = {};
22
+ __export(setValueForStyles_exports, {
23
+ setValueForStyles: () => setValueForStyles
24
+ });
25
+ module.exports = __toCommonJS(setValueForStyles_exports);
26
+ var import_dangerousStyleValue = require("./dangerousStyleValue.cjs");
27
+ function setValueForStyles(node, styles) {
28
+ const style = node.style;
29
+ for (let styleName in styles) {
30
+ if (!styles.hasOwnProperty(styleName)) continue;
31
+ const isCustomProperty = styleName.indexOf("--") === 0,
32
+ styleValue = (0, import_dangerousStyleValue.dangerousStyleValue)(styleName, styles[styleName], isCustomProperty);
33
+ styleName === "float" && (styleName = "cssFloat"), isCustomProperty ? style.setProperty(styleName, styleValue) : style[styleName] = styleValue;
34
+ }
35
+ }
@@ -0,0 +1,85 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all) __defProp(target, name, {
7
+ get: all[name],
8
+ enumerable: !0
9
+ });
10
+ },
11
+ __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
13
+ get: () => from[key],
14
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
15
+ });
16
+ return to;
17
+ };
18
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
19
+ value: !0
20
+ }), mod);
21
+ var unitlessNumbers_exports = {};
22
+ __export(unitlessNumbers_exports, {
23
+ unitlessNumbers: () => unitlessNumbers
24
+ });
25
+ module.exports = __toCommonJS(unitlessNumbers_exports);
26
+ const unitlessNumbers = {
27
+ animationIterationCount: !0,
28
+ aspectRatio: !0,
29
+ borderImageOutset: !0,
30
+ borderImageSlice: !0,
31
+ borderImageWidth: !0,
32
+ boxFlex: !0,
33
+ boxFlexGroup: !0,
34
+ boxOrdinalGroup: !0,
35
+ columnCount: !0,
36
+ flex: !0,
37
+ flexGrow: !0,
38
+ flexOrder: !0,
39
+ flexPositive: !0,
40
+ flexShrink: !0,
41
+ flexNegative: !0,
42
+ fontWeight: !0,
43
+ gap: !0,
44
+ columnGap: !0,
45
+ rowGap: !0,
46
+ gridRow: !0,
47
+ gridRowEnd: !0,
48
+ gridRowGap: !0,
49
+ gridRowStart: !0,
50
+ gridColumn: !0,
51
+ gridColumnEnd: !0,
52
+ gridColumnGap: !0,
53
+ gridColumnStart: !0,
54
+ lineClamp: !0,
55
+ opacity: !0,
56
+ order: !0,
57
+ orphans: !0,
58
+ tabSize: !0,
59
+ widows: !0,
60
+ zIndex: !0,
61
+ zoom: !0,
62
+ // SVG-related
63
+ fillOpacity: !0,
64
+ floodOpacity: !0,
65
+ stopOpacity: !0,
66
+ strokeDasharray: !0,
67
+ strokeDashoffset: !0,
68
+ strokeMiterlimit: !0,
69
+ strokeOpacity: !0,
70
+ strokeWidth: !0,
71
+ // transform types
72
+ scale: !0,
73
+ scaleX: !0,
74
+ scaleY: !0,
75
+ scaleZ: !0,
76
+ // RN properties
77
+ shadowOpacity: !0
78
+ },
79
+ prefixes = ["ms", "Moz", "O", "Webkit"],
80
+ prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1);
81
+ Object.keys(unitlessNumbers).forEach(prop => {
82
+ prefixes.forEach(prefix => {
83
+ unitlessNumbers[prefixKey(prefix, prop)] = unitlessNumbers[prop];
84
+ });
85
+ });
@@ -0,0 +1,39 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all) __defProp(target, name, {
7
+ get: all[name],
8
+ enumerable: !0
9
+ });
10
+ },
11
+ __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
13
+ get: () => from[key],
14
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
15
+ });
16
+ return to;
17
+ };
18
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
19
+ value: !0
20
+ }), mod);
21
+ var useElementLayout_exports = {};
22
+ __export(useElementLayout_exports, {
23
+ useElementLayout: () => useElementLayout
24
+ });
25
+ module.exports = __toCommonJS(useElementLayout_exports);
26
+ var import_use_element_layout = require("@hanzogui/use-element-layout"),
27
+ import_react = require("react");
28
+ function useElementLayout(ref, onLayout) {
29
+ const wrappedRef = (0, import_react.useMemo)(() => ({
30
+ current: {
31
+ get host() {
32
+ return ref.current;
33
+ }
34
+ }
35
+ }), [ref]);
36
+ return (0, import_react.useEffect)(() => {
37
+ (0, import_use_element_layout.enable)();
38
+ }, []), (0, import_use_element_layout.useElementLayout)(wrappedRef, onLayout);
39
+ }
@@ -0,0 +1,408 @@
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,
6
+ __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __copyProps = (to, from, except, desc) => {
8
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
9
+ get: () => from[key],
10
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
11
+ });
12
+ return to;
13
+ };
14
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
15
+ // If the importer is in node compatibility mode or this is not an ESM
16
+ // file that has been converted to a CommonJS file using a Babel-
17
+ // compatible transform (i.e. "__esModule" has not been set), then set
18
+ // "default" to the CommonJS "module.exports" for node compatibility.
19
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
20
+ value: mod,
21
+ enumerable: !0
22
+ }) : target, mod));
23
+ var import_dom_event_testing_library = require("dom-event-testing-library"),
24
+ React = __toESM(require("react"), 1),
25
+ ReactDOM = __toESM(require("react-dom"), 1),
26
+ import_test_utils = require("react-dom/test-utils"),
27
+ import__ = __toESM(require("../index.cjs"), 1),
28
+ import_jsx_runtime = require("react/jsx-runtime");
29
+ function createRoot(rootNode) {
30
+ return {
31
+ render(element) {
32
+ ReactDOM.render(element, rootNode);
33
+ }
34
+ };
35
+ }
36
+ describe("use-event", () => {
37
+ let root, rootNode;
38
+ beforeEach(() => {
39
+ rootNode = document.createElement("div"), document.body.appendChild(rootNode), root = createRoot(rootNode);
40
+ }), afterEach(() => {
41
+ root.render(null), document.body.removeChild(rootNode), rootNode = null, root = null;
42
+ }), describe("setListener()", () => {
43
+ test("event dispatched on target", () => {
44
+ const listener = jest.fn(),
45
+ targetRef = React.createRef();
46
+ function Component() {
47
+ const addClickListener = (0, import__.default)("click");
48
+ return React.useEffect(() => {
49
+ addClickListener(targetRef.current, listener);
50
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
51
+ ref: targetRef
52
+ });
53
+ }
54
+ (0, import_test_utils.act)(() => {
55
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
56
+ });
57
+ const target = (0, import_dom_event_testing_library.createEventTarget)(targetRef.current);
58
+ (0, import_test_utils.act)(() => {
59
+ target.click();
60
+ }), expect(listener).toBeCalledTimes(1);
61
+ }), test("event dispatched on parent", () => {
62
+ const listener = jest.fn(),
63
+ listenerCapture = jest.fn(),
64
+ targetRef = React.createRef(),
65
+ parentRef = React.createRef();
66
+ function Component() {
67
+ const addClickListener = (0, import__.default)("click"),
68
+ addClickCaptureListener = (0, import__.default)("click", {
69
+ capture: !0
70
+ });
71
+ return React.useEffect(() => {
72
+ addClickListener(targetRef.current, listener), addClickCaptureListener(targetRef.current, listenerCapture);
73
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
74
+ ref: parentRef,
75
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
76
+ ref: targetRef
77
+ })
78
+ });
79
+ }
80
+ (0, import_test_utils.act)(() => {
81
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
82
+ });
83
+ const parent = (0, import_dom_event_testing_library.createEventTarget)(parentRef.current);
84
+ (0, import_test_utils.act)(() => {
85
+ parent.click();
86
+ }), expect(listener).toBeCalledTimes(0), expect(listenerCapture).toBeCalledTimes(0);
87
+ }), test("event dispatched on child", () => {
88
+ const log = [],
89
+ listener = jest.fn(() => {
90
+ log.push("bubble");
91
+ }),
92
+ listenerCapture = jest.fn(() => {
93
+ log.push("capture");
94
+ }),
95
+ targetRef = React.createRef(),
96
+ childRef = React.createRef();
97
+ function Component() {
98
+ const addClickListener = (0, import__.default)("click"),
99
+ addClickCaptureListener = (0, import__.default)("click", {
100
+ capture: !0
101
+ });
102
+ return React.useEffect(() => {
103
+ addClickListener(targetRef.current, listener), addClickCaptureListener(targetRef.current, listenerCapture);
104
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
105
+ ref: targetRef,
106
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
107
+ ref: childRef
108
+ })
109
+ });
110
+ }
111
+ (0, import_test_utils.act)(() => {
112
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
113
+ });
114
+ const child = (0, import_dom_event_testing_library.createEventTarget)(childRef.current);
115
+ (0, import_test_utils.act)(() => {
116
+ child.click();
117
+ }), expect(listenerCapture).toBeCalledTimes(1), expect(listener).toBeCalledTimes(1), expect(log).toEqual(["capture", "bubble"]);
118
+ }), test("event dispatched on text node", () => {
119
+ const listener = jest.fn(),
120
+ targetRef = React.createRef(),
121
+ childRef = React.createRef();
122
+ function Component() {
123
+ const addClickListener = (0, import__.default)("click");
124
+ return React.useEffect(() => {
125
+ addClickListener(targetRef.current, listener);
126
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
127
+ ref: targetRef,
128
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
129
+ ref: childRef,
130
+ children: "text"
131
+ })
132
+ });
133
+ }
134
+ (0, import_test_utils.act)(() => {
135
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
136
+ });
137
+ const text = (0, import_dom_event_testing_library.createEventTarget)(childRef.current.firstChild);
138
+ (0, import_test_utils.act)(() => {
139
+ text.click();
140
+ }), expect(listener).toBeCalledTimes(1);
141
+ }), test("listener can be attached to document ", () => {
142
+ const listener = jest.fn(),
143
+ targetRef = React.createRef();
144
+ function Component({
145
+ target: target2
146
+ }) {
147
+ const addClickListener = (0, import__.default)("click");
148
+ return React.useEffect(() => {
149
+ addClickListener(target2, listener);
150
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
151
+ ref: targetRef
152
+ });
153
+ }
154
+ (0, import_test_utils.act)(() => {
155
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {
156
+ target: document
157
+ }));
158
+ });
159
+ const target = (0, import_dom_event_testing_library.createEventTarget)(targetRef.current);
160
+ (0, import_test_utils.act)(() => {
161
+ target.click();
162
+ }), expect(listener).toBeCalledTimes(1);
163
+ }), test("listener can be attached to window ", () => {
164
+ const listener = jest.fn(),
165
+ targetRef = React.createRef();
166
+ function Component({
167
+ target: target2
168
+ }) {
169
+ const addClickListener = (0, import__.default)("click");
170
+ return React.useEffect(() => {
171
+ addClickListener(target2, listener);
172
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
173
+ ref: targetRef
174
+ });
175
+ }
176
+ (0, import_test_utils.act)(() => {
177
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {
178
+ target: window
179
+ }));
180
+ });
181
+ const target = (0, import_dom_event_testing_library.createEventTarget)(targetRef.current);
182
+ (0, import_test_utils.act)(() => {
183
+ target.click();
184
+ }), expect(listener).toBeCalledTimes(1);
185
+ }), test("listener is replaceable", () => {
186
+ const listener = jest.fn(),
187
+ listenerAlt = jest.fn(),
188
+ targetRef = React.createRef();
189
+ function Component({
190
+ onClick
191
+ }) {
192
+ const addClickListener = (0, import__.default)("click");
193
+ return React.useEffect(() => {
194
+ addClickListener(targetRef.current, onClick);
195
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
196
+ ref: targetRef
197
+ });
198
+ }
199
+ (0, import_test_utils.act)(() => {
200
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {
201
+ onClick: listener
202
+ }));
203
+ });
204
+ const target = (0, import_dom_event_testing_library.createEventTarget)(targetRef.current);
205
+ (0, import_test_utils.act)(() => {
206
+ target.click();
207
+ }), expect(listener).toBeCalledTimes(1), (0, import_test_utils.act)(() => {
208
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {
209
+ onClick: listenerAlt
210
+ }));
211
+ }), (0, import_test_utils.act)(() => {
212
+ target.click();
213
+ }), expect(listener).toBeCalledTimes(1), expect(listenerAlt).toBeCalledTimes(1);
214
+ }), test("listener is removed when value is null", () => {
215
+ const listener = jest.fn(),
216
+ targetRef = React.createRef();
217
+ function Component({
218
+ off
219
+ }) {
220
+ const addClickListener = (0, import__.default)("click");
221
+ return React.useEffect(() => {
222
+ addClickListener(targetRef.current, off ? null : listener);
223
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
224
+ ref: targetRef
225
+ });
226
+ }
227
+ (0, import_test_utils.act)(() => {
228
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {
229
+ off: !1
230
+ }));
231
+ });
232
+ const target = (0, import_dom_event_testing_library.createEventTarget)(targetRef.current);
233
+ (0, import_test_utils.act)(() => {
234
+ target.click();
235
+ }), expect(listener).toBeCalledTimes(1), (0, import_test_utils.act)(() => {
236
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {
237
+ off: !0
238
+ }));
239
+ }), listener.mockClear(), (0, import_test_utils.act)(() => {
240
+ target.click();
241
+ }), expect(listener).toBeCalledTimes(0);
242
+ }), test("custom event dispatched on target", () => {
243
+ const listener = jest.fn(),
244
+ targetRef = React.createRef();
245
+ function Component() {
246
+ const addMagicEventListener = (0, import__.default)("magic-event");
247
+ return React.useEffect(() => {
248
+ addMagicEventListener(targetRef.current, listener);
249
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
250
+ ref: targetRef
251
+ });
252
+ }
253
+ (0, import_test_utils.act)(() => {
254
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
255
+ }), (0, import_test_utils.act)(() => {
256
+ const event = new CustomEvent("magic-event", {
257
+ bubbles: !0
258
+ });
259
+ targetRef.current.dispatchEvent(event);
260
+ }), expect(listener).toBeCalledTimes(1);
261
+ }), test("listeners can be set on multiple targets simultaneously", () => {
262
+ const log = [],
263
+ targetRef = React.createRef(),
264
+ parentRef = React.createRef(),
265
+ childRef = React.createRef(),
266
+ listener = jest.fn(e => {
267
+ log.push(["bubble", e.currentTarget.id]);
268
+ }),
269
+ listenerCapture = jest.fn(e => {
270
+ log.push(["capture", e.currentTarget.id]);
271
+ });
272
+ function Component() {
273
+ const addClickListener = (0, import__.default)("click"),
274
+ addClickCaptureListener = (0, import__.default)("click", {
275
+ capture: !0
276
+ });
277
+ return React.useEffect(() => {
278
+ addClickListener(targetRef.current, listener), addClickListener(parentRef.current, listener), addClickCaptureListener(targetRef.current, listenerCapture), addClickCaptureListener(parentRef.current, listenerCapture);
279
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
280
+ id: "parent",
281
+ ref: parentRef,
282
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
283
+ id: "target",
284
+ ref: targetRef,
285
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
286
+ ref: childRef
287
+ })
288
+ })
289
+ });
290
+ }
291
+ (0, import_test_utils.act)(() => {
292
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
293
+ });
294
+ const child = (0, import_dom_event_testing_library.createEventTarget)(childRef.current);
295
+ (0, import_test_utils.act)(() => {
296
+ child.click();
297
+ }), expect(listenerCapture).toBeCalledTimes(2), expect(listener).toBeCalledTimes(2), expect(log).toEqual([["capture", "parent"], ["capture", "target"], ["bubble", "target"], ["bubble", "parent"]]);
298
+ }), test("listeners are specific to each event handle", () => {
299
+ const log = [],
300
+ targetRef = React.createRef(),
301
+ childRef = React.createRef(),
302
+ listener = jest.fn(e => {
303
+ log.push(["bubble", "target"]);
304
+ }),
305
+ listenerAlt = jest.fn(e => {
306
+ log.push(["bubble", "target-alt"]);
307
+ }),
308
+ listenerCapture = jest.fn(e => {
309
+ log.push(["capture", "target"]);
310
+ }),
311
+ listenerCaptureAlt = jest.fn(e => {
312
+ log.push(["capture", "target-alt"]);
313
+ });
314
+ function Component() {
315
+ const addClickListener = (0, import__.default)("click"),
316
+ addClickAltListener = (0, import__.default)("click"),
317
+ addClickCaptureListener = (0, import__.default)("click", {
318
+ capture: !0
319
+ }),
320
+ addClickCaptureAltListener = (0, import__.default)("click", {
321
+ capture: !0
322
+ });
323
+ return React.useEffect(() => {
324
+ addClickListener(targetRef.current, listener), addClickAltListener(targetRef.current, listenerAlt), addClickCaptureListener(targetRef.current, listenerCapture), addClickCaptureAltListener(targetRef.current, listenerCaptureAlt);
325
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
326
+ id: "target",
327
+ ref: targetRef,
328
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
329
+ ref: childRef
330
+ })
331
+ });
332
+ }
333
+ (0, import_test_utils.act)(() => {
334
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
335
+ });
336
+ const child = (0, import_dom_event_testing_library.createEventTarget)(childRef.current);
337
+ (0, import_test_utils.act)(() => {
338
+ child.click();
339
+ }), expect(listenerCapture).toBeCalledTimes(1), expect(listenerCaptureAlt).toBeCalledTimes(1), expect(listener).toBeCalledTimes(1), expect(listenerAlt).toBeCalledTimes(1), expect(log).toEqual([["capture", "target"], ["capture", "target-alt"], ["bubble", "target"], ["bubble", "target-alt"]]);
340
+ });
341
+ }), describe("cleanup", () => {
342
+ test("removes all listeners for given event type from targets", () => {
343
+ const clickListener = jest.fn();
344
+ function Component() {
345
+ const addClickListener = (0, import__.default)("click");
346
+ return React.useEffect(() => {
347
+ addClickListener(document, clickListener);
348
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {});
349
+ }
350
+ (0, import_test_utils.act)(() => {
351
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {})), root.render(null);
352
+ });
353
+ const target = (0, import_dom_event_testing_library.createEventTarget)(document);
354
+ (0, import_test_utils.act)(() => {
355
+ target.click();
356
+ }), expect(clickListener).toBeCalledTimes(0);
357
+ });
358
+ }), describe("stopPropagation and stopImmediatePropagation", () => {
359
+ test("stopPropagation works as expected", () => {
360
+ const childListener = jest.fn(e => {
361
+ e.stopPropagation();
362
+ }),
363
+ targetListener = jest.fn(),
364
+ targetRef = React.createRef(),
365
+ childRef = React.createRef();
366
+ function Component() {
367
+ const addClickListener = (0, import__.default)("click");
368
+ return React.useEffect(() => {
369
+ addClickListener(childRef.current, childListener), addClickListener(targetRef.current, targetListener);
370
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
371
+ ref: targetRef,
372
+ children: /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
373
+ ref: childRef
374
+ })
375
+ });
376
+ }
377
+ (0, import_test_utils.act)(() => {
378
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
379
+ });
380
+ const child = (0, import_dom_event_testing_library.createEventTarget)(childRef.current);
381
+ (0, import_test_utils.act)(() => {
382
+ child.click();
383
+ }), expect(childListener).toBeCalledTimes(1), expect(targetListener).toBeCalledTimes(0);
384
+ }), test("stopImmediatePropagation works as expected", () => {
385
+ const firstListener = jest.fn(e => {
386
+ e.stopImmediatePropagation();
387
+ }),
388
+ secondListener = jest.fn(),
389
+ targetRef = React.createRef();
390
+ function Component() {
391
+ const addFirstClickListener = (0, import__.default)("click"),
392
+ addSecondClickListener = (0, import__.default)("click");
393
+ return React.useEffect(() => {
394
+ addFirstClickListener(targetRef.current, firstListener), addSecondClickListener(targetRef.current, secondListener);
395
+ }), /* @__PURE__ */(0, import_jsx_runtime.jsx)("div", {
396
+ ref: targetRef
397
+ });
398
+ }
399
+ (0, import_test_utils.act)(() => {
400
+ root.render(/* @__PURE__ */(0, import_jsx_runtime.jsx)(Component, {}));
401
+ });
402
+ const target = (0, import_dom_event_testing_library.createEventTarget)(targetRef.current);
403
+ (0, import_test_utils.act)(() => {
404
+ target.click();
405
+ }), expect(firstListener).toBeCalledTimes(1), expect(secondListener).toBeCalledTimes(0);
406
+ });
407
+ });
408
+ });
@@ -0,0 +1,45 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all) __defProp(target, name, {
7
+ get: all[name],
8
+ enumerable: !0
9
+ });
10
+ },
11
+ __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
13
+ get: () => from[key],
14
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
15
+ });
16
+ return to;
17
+ };
18
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
19
+ value: !0
20
+ }), mod);
21
+ var useEvent_exports = {};
22
+ __export(useEvent_exports, {
23
+ useEvent: () => useEvent
24
+ });
25
+ module.exports = __toCommonJS(useEvent_exports);
26
+ var import_createEventHandle = require("../createEventHandle/index.cjs"),
27
+ import_useLayoutEffect = require("../useLayoutEffect/index.cjs"),
28
+ import_useStable = require("../useStable/index.cjs");
29
+ function useEvent(event, options) {
30
+ const targetListeners = (0, import_useStable.useStable)(() => /* @__PURE__ */new Map()),
31
+ addListener = (0, import_useStable.useStable)(() => {
32
+ const addEventListener = (0, import_createEventHandle.createEventHandle)(event, options);
33
+ return (target, callback) => {
34
+ const removeTargetListener = targetListeners.get(target);
35
+ removeTargetListener?.(), callback == null && targetListeners.delete(target);
36
+ const removeEventListener = addEventListener(target, callback);
37
+ return targetListeners.set(target, removeEventListener), removeEventListener;
38
+ };
39
+ });
40
+ return (0, import_useLayoutEffect.useLayoutEffectImpl)(() => () => {
41
+ targetListeners.forEach(removeListener => {
42
+ removeListener();
43
+ }), targetListeners.clear();
44
+ }, [targetListeners]), addListener;
45
+ }