@onepercentio/one-ui 0.8.4 → 0.8.5-beta.10

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 (334) hide show
  1. package/WebpackConfigs/email-templates.js +35 -3
  2. package/cypress/support/commands.ts +12 -1
  3. package/cypress/support/component-index.html +8 -2
  4. package/dist/assets/styles/variables.scss +1 -0
  5. package/dist/components/AdaptiveContainer/AdaptiveContainer.d.ts +8 -1
  6. package/dist/components/AdaptiveContainer/AdaptiveContainer.js +36 -15
  7. package/dist/components/AdaptiveContainer/AdaptiveContainer.js.map +1 -1
  8. package/dist/components/AdaptiveContainer/AdaptiveContainer.module.scss +1 -1
  9. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.d.ts +13 -10
  10. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js +5 -2
  11. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js.map +1 -1
  12. package/dist/components/AnimatedEntrance/AnimatedEntrance.d.ts +1 -1
  13. package/dist/components/AnimatedEntrance/AnimatedEntrance.js +25 -10
  14. package/dist/components/AnimatedEntrance/AnimatedEntrance.js.map +1 -1
  15. package/dist/components/Button/Button.d.ts +2 -2
  16. package/dist/components/Button/Button.js.map +1 -1
  17. package/dist/components/Collapsable/Collapsable.d.ts +11 -1
  18. package/dist/components/Collapsable/Collapsable.js +13 -3
  19. package/dist/components/Collapsable/Collapsable.js.map +1 -1
  20. package/dist/components/EmailInput/EmailInput.d.ts +2 -2
  21. package/dist/components/FadeIn/FadeIn.d.ts +1 -0
  22. package/dist/components/FadeIn/FadeIn.js +14 -2
  23. package/dist/components/FadeIn/FadeIn.js.map +1 -1
  24. package/dist/components/InfinityScroll/InfinityScroll.d.ts +7 -0
  25. package/dist/components/InfinityScroll/InfinityScroll.js +39 -22
  26. package/dist/components/InfinityScroll/InfinityScroll.js.map +1 -1
  27. package/dist/components/Input/Input.d.ts +1 -1
  28. package/dist/components/Loader/Loader.d.ts +3 -2
  29. package/dist/components/Loader/Loader.js +14 -2
  30. package/dist/components/Loader/Loader.js.map +1 -1
  31. package/dist/components/OrderableList/OrderableList.d.ts +21 -0
  32. package/dist/components/OrderableList/OrderableList.js +253 -0
  33. package/dist/components/OrderableList/OrderableList.js.map +1 -0
  34. package/dist/components/OrderableList/OrderableList.module.scss +42 -0
  35. package/dist/components/OrderableList/index.d.ts +1 -0
  36. package/dist/components/OrderableList/index.js +9 -0
  37. package/dist/components/OrderableList/index.js.map +1 -0
  38. package/dist/components/PaginationIndicator/PaginationIndicator.d.ts +26 -0
  39. package/dist/components/PaginationIndicator/PaginationIndicator.js +131 -0
  40. package/dist/components/PaginationIndicator/PaginationIndicator.js.map +1 -0
  41. package/dist/components/PaginationIndicator/PaginationIndicator.module.scss +48 -0
  42. package/dist/components/PaginationIndicator/index.d.ts +1 -0
  43. package/dist/components/PaginationIndicator/index.js +9 -0
  44. package/dist/components/PaginationIndicator/index.js.map +1 -0
  45. package/dist/components/PasswordInput/PasswordInput.d.ts +1 -1
  46. package/dist/components/Select/Select.d.ts +3 -1
  47. package/dist/components/Select/Select.js +2 -2
  48. package/dist/components/Select/Select.js.map +1 -1
  49. package/dist/components/Tabs/Tabs.d.ts +2 -1
  50. package/dist/components/Tabs/Tabs.js +16 -8
  51. package/dist/components/Tabs/Tabs.js.map +1 -1
  52. package/dist/components/Tabs/Tabs.module.scss +0 -1
  53. package/dist/components/Text/Text.d.ts +2 -2
  54. package/dist/components/Text/Text.js.map +1 -1
  55. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js.map +1 -1
  56. package/dist/context/AsyncProcessQueue.d.ts +71 -0
  57. package/dist/context/AsyncProcessQueue.development.d.ts +8 -0
  58. package/dist/context/AsyncProcessQueue.development.js +42 -0
  59. package/dist/context/AsyncProcessQueue.development.js.map +1 -0
  60. package/dist/context/AsyncProcessQueue.js +186 -0
  61. package/dist/context/AsyncProcessQueue.js.map +1 -0
  62. package/dist/context/OneUIProvider.d.ts +10 -1
  63. package/dist/context/OneUIProvider.js +1 -1
  64. package/dist/context/OneUIProvider.js.map +1 -1
  65. package/dist/hooks/ui/usePaginationControls.d.ts +14 -0
  66. package/dist/hooks/ui/usePaginationControls.js +92 -0
  67. package/dist/hooks/ui/usePaginationControls.js.map +1 -0
  68. package/dist/hooks/ui/usePaginationControls.module.scss +16 -0
  69. package/dist/hooks/useAsyncControl.d.ts +4 -1
  70. package/dist/hooks/useAsyncControl.js +3 -1
  71. package/dist/hooks/useAsyncControl.js.map +1 -1
  72. package/dist/hooks/useContainedRepositioning.d.ts +3 -1
  73. package/dist/hooks/useContainedRepositioning.js +13 -10
  74. package/dist/hooks/useContainedRepositioning.js.map +1 -1
  75. package/dist/hooks/useElementFit.d.ts +2 -2
  76. package/dist/hooks/useElementFit.js.map +1 -1
  77. package/dist/hooks/useFreeze.d.ts +1 -1
  78. package/dist/hooks/useHero.d.ts +13 -0
  79. package/dist/hooks/useHero.js +97 -0
  80. package/dist/hooks/useHero.js.map +1 -0
  81. package/dist/hooks/useMergeRefs.d.ts +5 -0
  82. package/dist/hooks/useMergeRefs.js +15 -0
  83. package/dist/hooks/useMergeRefs.js.map +1 -0
  84. package/dist/hooks/usePagination.d.ts +5 -4
  85. package/dist/hooks/usePagination.js +22 -16
  86. package/dist/hooks/usePagination.js.map +1 -1
  87. package/dist/hooks/usePaginationControls.d.ts +5 -0
  88. package/dist/hooks/usePaginationControls.js +8 -0
  89. package/dist/hooks/usePaginationControls.js.map +1 -0
  90. package/dist/hooks/useShortIntl.js.map +1 -1
  91. package/dist/models/GenericContract.d.ts +1 -1
  92. package/dist/types.d.ts +72 -0
  93. package/dist/types.js +3 -0
  94. package/dist/types.js.map +1 -0
  95. package/package.json +8 -16
  96. package/src/{types.d.ts → types.ts} +7 -7
  97. package/tsconfig.json +108 -0
  98. package/WebpackConfigs/__snapshots__/email-templates.test.js.snap +0 -9
  99. package/WebpackConfigs/email-templates.test.js +0 -53
  100. package/WebpackConfigs/loaders/css-var-removal.test.ts +0 -17
  101. package/dist/__test__/analytics.d.ts +0 -3
  102. package/dist/__test__/analytics.js +0 -20
  103. package/dist/__test__/analytics.js.map +0 -1
  104. package/dist/__test__/firestore.d.ts +0 -2
  105. package/dist/__test__/firestore.js +0 -26
  106. package/dist/__test__/firestore.js.map +0 -1
  107. package/dist/__test__/utils.d.ts +0 -16
  108. package/dist/__test__/utils.js +0 -164
  109. package/dist/__test__/utils.js.map +0 -1
  110. package/dist/components/AdaptiveButton/AdaptiveButton.stories.d.ts +0 -18
  111. package/dist/components/AdaptiveButton/AdaptiveButton.stories.js +0 -82
  112. package/dist/components/AdaptiveButton/AdaptiveButton.stories.js.map +0 -1
  113. package/dist/components/AdaptiveContainer/AdaptiveContainer.stories.d.ts +0 -17
  114. package/dist/components/AdaptiveContainer/AdaptiveContainer.stories.js +0 -82
  115. package/dist/components/AdaptiveContainer/AdaptiveContainer.stories.js.map +0 -1
  116. package/dist/components/AdaptiveDialog/AdaptiveDialog.stories.d.ts +0 -20
  117. package/dist/components/AdaptiveDialog/AdaptiveDialog.stories.js +0 -94
  118. package/dist/components/AdaptiveDialog/AdaptiveDialog.stories.js.map +0 -1
  119. package/dist/components/AdaptiveDialog/AdaptiveDialog.test.d.ts +0 -1
  120. package/dist/components/AdaptiveDialog/AdaptiveDialog.test.js +0 -15
  121. package/dist/components/AdaptiveDialog/AdaptiveDialog.test.js.map +0 -1
  122. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.stories.d.ts +0 -19
  123. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.stories.js +0 -21
  124. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.stories.js.map +0 -1
  125. package/dist/components/AnchoredTooltip/AnchoredTooltip.stories.d.ts +0 -16
  126. package/dist/components/AnchoredTooltip/AnchoredTooltip.stories.js +0 -86
  127. package/dist/components/AnchoredTooltip/AnchoredTooltip.stories.js.map +0 -1
  128. package/dist/components/AnchoredTooltip/AnchoredTooltip.test.d.ts +0 -1
  129. package/dist/components/AnchoredTooltip/AnchoredTooltip.test.js +0 -20
  130. package/dist/components/AnchoredTooltip/AnchoredTooltip.test.js.map +0 -1
  131. package/dist/components/AnimatedEntrance/AnimatedEntrance.stories.d.ts +0 -14
  132. package/dist/components/AnimatedEntrance/AnimatedEntrance.stories.js +0 -67
  133. package/dist/components/AnimatedEntrance/AnimatedEntrance.stories.js.map +0 -1
  134. package/dist/components/AsyncWrapper/AsyncWrapper.stories.d.ts +0 -18
  135. package/dist/components/AsyncWrapper/AsyncWrapper.stories.js +0 -34
  136. package/dist/components/AsyncWrapper/AsyncWrapper.stories.js.map +0 -1
  137. package/dist/components/AsyncWrapper/AsyncWrapper.test.d.ts +0 -1
  138. package/dist/components/AsyncWrapper/AsyncWrapper.test.js +0 -19
  139. package/dist/components/AsyncWrapper/AsyncWrapper.test.js.map +0 -1
  140. package/dist/components/Avatar/Avatar.stories.d.ts +0 -14
  141. package/dist/components/Avatar/Avatar.stories.js +0 -19
  142. package/dist/components/Avatar/Avatar.stories.js.map +0 -1
  143. package/dist/components/Avatar/Avatar.test.d.ts +0 -1
  144. package/dist/components/Avatar/Avatar.test.js +0 -36
  145. package/dist/components/Avatar/Avatar.test.js.map +0 -1
  146. package/dist/components/BucketFill/BucketFill.stories.d.ts +0 -17
  147. package/dist/components/BucketFill/BucketFill.stories.js +0 -141
  148. package/dist/components/BucketFill/BucketFill.stories.js.map +0 -1
  149. package/dist/components/BucketFill/BucketFill.stories.module.scss +0 -3
  150. package/dist/components/Button/Button.stories.d.ts +0 -9
  151. package/dist/components/Button/Button.stories.js +0 -58
  152. package/dist/components/Button/Button.stories.js.map +0 -1
  153. package/dist/components/Button/Button.test.d.ts +0 -1
  154. package/dist/components/Button/Button.test.js +0 -15
  155. package/dist/components/Button/Button.test.js.map +0 -1
  156. package/dist/components/Card/Card.stories.d.ts +0 -15
  157. package/dist/components/Card/Card.stories.js +0 -16
  158. package/dist/components/Card/Card.stories.js.map +0 -1
  159. package/dist/components/CheckBox/CheckBox.stories.d.ts +0 -20
  160. package/dist/components/CheckBox/CheckBox.stories.js +0 -53
  161. package/dist/components/CheckBox/CheckBox.stories.js.map +0 -1
  162. package/dist/components/Collapsable/Collapsable.stories.d.ts +0 -39
  163. package/dist/components/Collapsable/Collapsable.stories.js +0 -28
  164. package/dist/components/Collapsable/Collapsable.stories.js.map +0 -1
  165. package/dist/components/Countdown/Countdown.stories.d.ts +0 -14
  166. package/dist/components/Countdown/Countdown.stories.js +0 -55
  167. package/dist/components/Countdown/Countdown.stories.js.map +0 -1
  168. package/dist/components/Divider/Divider.stories.d.ts +0 -7
  169. package/dist/components/Divider/Divider.stories.js +0 -15
  170. package/dist/components/Divider/Divider.stories.js.map +0 -1
  171. package/dist/components/EmailInput/EmailInput.stories.d.ts +0 -28
  172. package/dist/components/EmailInput/EmailInput.stories.js +0 -15
  173. package/dist/components/EmailInput/EmailInput.stories.js.map +0 -1
  174. package/dist/components/EmailInput/EmailInput.test.d.ts +0 -1
  175. package/dist/components/EmailInput/EmailInput.test.js +0 -77
  176. package/dist/components/EmailInput/EmailInput.test.js.map +0 -1
  177. package/dist/components/FadeIn/FadeIn.stories.d.ts +0 -24
  178. package/dist/components/FadeIn/FadeIn.stories.js +0 -16
  179. package/dist/components/FadeIn/FadeIn.stories.js.map +0 -1
  180. package/dist/components/FadeIn/FadeIn.test.d.ts +0 -1
  181. package/dist/components/FadeIn/FadeIn.test.js +0 -22
  182. package/dist/components/FadeIn/FadeIn.test.js.map +0 -1
  183. package/dist/components/FileInput/FileInput.stories.d.ts +0 -19
  184. package/dist/components/FileInput/FileInput.stories.js +0 -59
  185. package/dist/components/FileInput/FileInput.stories.js.map +0 -1
  186. package/dist/components/FlowController/FlowController.stories.d.ts +0 -43
  187. package/dist/components/FlowController/FlowController.stories.js +0 -101
  188. package/dist/components/FlowController/FlowController.stories.js.map +0 -1
  189. package/dist/components/FlowController/FlowController.test.d.ts +0 -1
  190. package/dist/components/FlowController/FlowController.test.js +0 -166
  191. package/dist/components/FlowController/FlowController.test.js.map +0 -1
  192. package/dist/components/Form/Form.stories.d.ts +0 -13
  193. package/dist/components/Form/Form.stories.js +0 -36
  194. package/dist/components/Form/Form.stories.js.map +0 -1
  195. package/dist/components/Freeze/Freeze.stories.d.ts +0 -7
  196. package/dist/components/Freeze/Freeze.stories.js +0 -56
  197. package/dist/components/Freeze/Freeze.stories.js.map +0 -1
  198. package/dist/components/Freeze/Freeze.test.d.ts +0 -1
  199. package/dist/components/Freeze/Freeze.test.js +0 -15
  200. package/dist/components/Freeze/Freeze.test.js.map +0 -1
  201. package/dist/components/Header/Header.stories.d.ts +0 -28
  202. package/dist/components/Header/Header.stories.js +0 -41
  203. package/dist/components/Header/Header.stories.js.map +0 -1
  204. package/dist/components/Header/Header.test.d.ts +0 -1
  205. package/dist/components/Header/Header.test.js +0 -100
  206. package/dist/components/Header/Header.test.js.map +0 -1
  207. package/dist/components/HeaderCloseBtn/HeaderCloseBtn.stories.d.ts +0 -14
  208. package/dist/components/HeaderCloseBtn/HeaderCloseBtn.stories.js +0 -16
  209. package/dist/components/HeaderCloseBtn/HeaderCloseBtn.stories.js.map +0 -1
  210. package/dist/components/InfinityScroll/InfinityScroll.stories.d.ts +0 -23
  211. package/dist/components/InfinityScroll/InfinityScroll.stories.js +0 -54
  212. package/dist/components/InfinityScroll/InfinityScroll.stories.js.map +0 -1
  213. package/dist/components/InfinityScroll/InfinityScroll.test.d.ts +0 -1
  214. package/dist/components/InfinityScroll/InfinityScroll.test.js +0 -189
  215. package/dist/components/InfinityScroll/InfinityScroll.test.js.map +0 -1
  216. package/dist/components/Input/Input.stories.d.ts +0 -24
  217. package/dist/components/Input/Input.stories.js +0 -21
  218. package/dist/components/Input/Input.stories.js.map +0 -1
  219. package/dist/components/Input/Input.test.d.ts +0 -1
  220. package/dist/components/Input/Input.test.js +0 -58
  221. package/dist/components/Input/Input.test.js.map +0 -1
  222. package/dist/components/InstantCounter/InstantCounter.stories.d.ts +0 -41
  223. package/dist/components/InstantCounter/InstantCounter.stories.js +0 -61
  224. package/dist/components/InstantCounter/InstantCounter.stories.js.map +0 -1
  225. package/dist/components/InstantCounter/InstantCounter.test.d.ts +0 -1
  226. package/dist/components/InstantCounter/InstantCounter.test.js +0 -50
  227. package/dist/components/InstantCounter/InstantCounter.test.js.map +0 -1
  228. package/dist/components/LinkToId/LinkToId.stories.d.ts +0 -7
  229. package/dist/components/LinkToId/LinkToId.stories.js +0 -15
  230. package/dist/components/LinkToId/LinkToId.stories.js.map +0 -1
  231. package/dist/components/LinkToId/LinkToId.test.d.ts +0 -1
  232. package/dist/components/LinkToId/LinkToId.test.js +0 -12
  233. package/dist/components/LinkToId/LinkToId.test.js.map +0 -1
  234. package/dist/components/Loader/Loader.stories.d.ts +0 -12
  235. package/dist/components/Loader/Loader.stories.js +0 -16
  236. package/dist/components/Loader/Loader.stories.js.map +0 -1
  237. package/dist/components/LoaderDotsIndicator/LoaderDotsIndicator.stories.d.ts +0 -7
  238. package/dist/components/LoaderDotsIndicator/LoaderDotsIndicator.stories.js +0 -15
  239. package/dist/components/LoaderDotsIndicator/LoaderDotsIndicator.stories.js.map +0 -1
  240. package/dist/components/MainGrid/MainGrid.stories.d.ts +0 -14
  241. package/dist/components/MainGrid/MainGrid.stories.js +0 -70
  242. package/dist/components/MainGrid/MainGrid.stories.js.map +0 -1
  243. package/dist/components/MainGrid/MainGrid.test.d.ts +0 -1
  244. package/dist/components/MainGrid/MainGrid.test.js +0 -18
  245. package/dist/components/MainGrid/MainGrid.test.js.map +0 -1
  246. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.stories.d.ts +0 -21
  247. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.stories.js +0 -74
  248. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.stories.js.map +0 -1
  249. package/dist/components/Notification/Notification.stories.d.ts +0 -15
  250. package/dist/components/Notification/Notification.stories.js +0 -19
  251. package/dist/components/Notification/Notification.stories.js.map +0 -1
  252. package/dist/components/Parallax/Parallax.stories.d.ts +0 -32
  253. package/dist/components/Parallax/Parallax.stories.js +0 -23
  254. package/dist/components/Parallax/Parallax.stories.js.map +0 -1
  255. package/dist/components/Parallax/Parallax.test.d.ts +0 -1
  256. package/dist/components/Parallax/Parallax.test.js +0 -22
  257. package/dist/components/Parallax/Parallax.test.js.map +0 -1
  258. package/dist/components/PasswordInput/PasswordInput.stories.d.ts +0 -45
  259. package/dist/components/PasswordInput/PasswordInput.stories.js +0 -22
  260. package/dist/components/PasswordInput/PasswordInput.stories.js.map +0 -1
  261. package/dist/components/PasswordInput/PasswordInput.test.d.ts +0 -1
  262. package/dist/components/PasswordInput/PasswordInput.test.js +0 -157
  263. package/dist/components/PasswordInput/PasswordInput.test.js.map +0 -1
  264. package/dist/components/PixelatedScan/PixelatedScan.stories.d.ts +0 -15
  265. package/dist/components/PixelatedScan/PixelatedScan.stories.js +0 -40
  266. package/dist/components/PixelatedScan/PixelatedScan.stories.js.map +0 -1
  267. package/dist/components/Portal/Portal.stories.d.ts +0 -7
  268. package/dist/components/Portal/Portal.stories.js +0 -15
  269. package/dist/components/Portal/Portal.stories.js.map +0 -1
  270. package/dist/components/ProgressBar/ProgressBar.stories.d.ts +0 -14
  271. package/dist/components/ProgressBar/ProgressBar.stories.js +0 -52
  272. package/dist/components/ProgressBar/ProgressBar.stories.js.map +0 -1
  273. package/dist/components/ProgressTexts/ProgressTexts.stories.d.ts +0 -24
  274. package/dist/components/ProgressTexts/ProgressTexts.stories.js +0 -90
  275. package/dist/components/ProgressTexts/ProgressTexts.stories.js.map +0 -1
  276. package/dist/components/ProgressTexts/ProgressTexts.test.d.ts +0 -1
  277. package/dist/components/ProgressTexts/ProgressTexts.test.js +0 -52
  278. package/dist/components/ProgressTexts/ProgressTexts.test.js.map +0 -1
  279. package/dist/components/SectionContainer/SectionContainer.stories.d.ts +0 -14
  280. package/dist/components/SectionContainer/SectionContainer.stories.js +0 -15
  281. package/dist/components/SectionContainer/SectionContainer.stories.js.map +0 -1
  282. package/dist/components/Select/Select.stories.d.ts +0 -56
  283. package/dist/components/Select/Select.stories.js +0 -34
  284. package/dist/components/Select/Select.stories.js.map +0 -1
  285. package/dist/components/Select/Select.test.d.ts +0 -1
  286. package/dist/components/Select/Select.test.js +0 -12
  287. package/dist/components/Select/Select.test.js.map +0 -1
  288. package/dist/components/Spacing/Spacing.stories.d.ts +0 -7
  289. package/dist/components/Spacing/Spacing.stories.js +0 -35
  290. package/dist/components/Spacing/Spacing.stories.js.map +0 -1
  291. package/dist/components/Table/Table.stories.d.ts +0 -15
  292. package/dist/components/Table/Table.stories.js +0 -88
  293. package/dist/components/Table/Table.stories.js.map +0 -1
  294. package/dist/components/Table/Table.test.d.ts +0 -1
  295. package/dist/components/Table/Table.test.js +0 -35
  296. package/dist/components/Table/Table.test.js.map +0 -1
  297. package/dist/components/Tabs/Tabs.stories.d.ts +0 -17
  298. package/dist/components/Tabs/Tabs.stories.js +0 -57
  299. package/dist/components/Tabs/Tabs.stories.js.map +0 -1
  300. package/dist/components/Tabs/Tabs.test.d.ts +0 -1
  301. package/dist/components/Tabs/Tabs.test.js +0 -39
  302. package/dist/components/Tabs/Tabs.test.js.map +0 -1
  303. package/dist/components/Text/Text.stories.d.ts +0 -7
  304. package/dist/components/Text/Text.stories.js +0 -43
  305. package/dist/components/Text/Text.stories.js.map +0 -1
  306. package/dist/components/Text/Text.test.d.ts +0 -1
  307. package/dist/components/Text/Text.test.js +0 -12
  308. package/dist/components/Text/Text.test.js.map +0 -1
  309. package/dist/components/Transition/Transition.stories.d.ts +0 -10
  310. package/dist/components/Transition/Transition.stories.js +0 -29
  311. package/dist/components/Transition/Transition.stories.js.map +0 -1
  312. package/dist/components/Transition/Transition.test.d.ts +0 -1
  313. package/dist/components/Transition/Transition.test.js +0 -55
  314. package/dist/components/Transition/Transition.test.js.map +0 -1
  315. package/dist/components/UncontrolledTransition/UncontrolledTransition.stories.d.ts +0 -33
  316. package/dist/components/UncontrolledTransition/UncontrolledTransition.stories.js +0 -225
  317. package/dist/components/UncontrolledTransition/UncontrolledTransition.stories.js.map +0 -1
  318. package/dist/components/UncontrolledTransition/UncontrolledTransition.stories.module.scss +0 -66
  319. package/dist/components/UncontrolledTransition/UncontrolledTransition.test.d.ts +0 -1
  320. package/dist/components/UncontrolledTransition/UncontrolledTransition.test.js +0 -135
  321. package/dist/components/UncontrolledTransition/UncontrolledTransition.test.js.map +0 -1
  322. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.d.ts +0 -70
  323. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.js +0 -65
  324. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.js.map +0 -1
  325. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.test.d.ts +0 -1
  326. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.test.js +0 -137
  327. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.test.js.map +0 -1
  328. package/dist/context/__mocks__/OneUIProvider.d.ts +0 -74
  329. package/dist/context/__mocks__/OneUIProvider.js +0 -13
  330. package/dist/context/__mocks__/OneUIProvider.js.map +0 -1
  331. package/dist/hooks/usePooling.test.d.ts +0 -1
  332. package/dist/hooks/usePooling.test.js +0 -104
  333. package/dist/hooks/usePooling.test.js.map +0 -1
  334. package/scripts/start-emulator.js +0 -48
@@ -0,0 +1,186 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.useAsyncProcessQueue = exports.useRecoveries = exports.useAsyncProcessQueueContext = exports.AsyncProcessQueueProvider = exports.AsyncQueueErrors = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const AsyncProcessQueue_development_1 = require("./AsyncProcessQueue.development");
29
+ var AsyncQueueErrors;
30
+ (function (AsyncQueueErrors) {
31
+ AsyncQueueErrors["RECOVERY_IS_NOT_BEING_CALLED"] = "A recovery is not set for this call. If the user reloads the page, this process will not return to the async list";
32
+ })(AsyncQueueErrors = exports.AsyncQueueErrors || (exports.AsyncQueueErrors = {}));
33
+ const Context = (0, react_1.createContext)(null);
34
+ function useCounter() {
35
+ const [count, setCounter] = (0, react_1.useState)(0);
36
+ return {
37
+ count,
38
+ setCounter,
39
+ increment: () => setCounter((prev) => prev + 1),
40
+ decrement: () => setCounter((prev) => prev - 1),
41
+ reset: () => setCounter(0),
42
+ };
43
+ }
44
+ /**
45
+ * This propagates the utilitary functions
46
+ */
47
+ function AsyncProcessQueueProvider({ children, recoveries, uiFactory, }) {
48
+ const targetRef = (0, react_1.useRef)(null);
49
+ const pendingCounter = useCounter();
50
+ const [UIs, setUIs] = (0, react_1.useState)([]);
51
+ const _recoveries = process.env.NODE_ENV === "development"
52
+ ? Object.entries(recoveries).reduce((r, [k, v]) => (Object.assign(Object.assign({}, r), { [k]: Object.assign(Object.assign({}, v), { write: (...args) => {
53
+ (0, AsyncProcessQueue_development_1.countRegistration)();
54
+ return v.write(...args);
55
+ } }) })), {})
56
+ : recoveries;
57
+ const watchPromise = (0, react_1.useCallback)((promise, retry, uiType, ...uiParams) => {
58
+ const Factory = uiFactory(uiType);
59
+ const LoadingUIInstance = Object.assign(Object.assign({}, Factory("loading")), { status: "loading" });
60
+ if (process.env.NODE_ENV === "development" && !LoadingUIInstance.key)
61
+ throw new Error(`The UI generate for the async process should have a key`);
62
+ setUIs((prev) => [
63
+ ...prev.filter((a) => a.key !== LoadingUIInstance.key),
64
+ LoadingUIInstance,
65
+ ]);
66
+ promise.then((result) => {
67
+ // Write success UI
68
+ setUIs((prev) => prev.map((a) => a === LoadingUIInstance
69
+ ? Object.assign(Object.assign({}, Factory("succeded")), { status: "succeded" }) : a));
70
+ return result;
71
+ });
72
+ promise.catch((error) => {
73
+ const UIInstance = Factory("failed", error, () => setUIs((prev) => prev.filter((ui) => ui !== UIInstance)), () => watchPromise(retry(), retry, uiType, ...uiParams));
74
+ // Write success UI
75
+ setUIs((prev) => prev.map((a) => a === LoadingUIInstance ? Object.assign(Object.assign({}, UIInstance), { status: "failed" }) : a));
76
+ throw error;
77
+ });
78
+ return promise;
79
+ }, []);
80
+ (0, react_1.useEffect)(() => {
81
+ for (let recovery in recoveries) {
82
+ const recoveredProcesses = recoveries[recovery].recover();
83
+ for (let [promise, ...recoveredProcess] of recoveredProcesses) {
84
+ watchPromise(promise.catch(() => { }), ...recoveredProcess);
85
+ }
86
+ }
87
+ }, []);
88
+ return (react_1.default.createElement(Context.Provider, { value: {
89
+ targetElRef: targetRef,
90
+ pendingTransactions: pendingCounter,
91
+ watchPromise,
92
+ setUIs,
93
+ UIs,
94
+ recoveries: _recoveries,
95
+ } }, children));
96
+ }
97
+ exports.AsyncProcessQueueProvider = AsyncProcessQueueProvider;
98
+ function useAsyncProcessQueueContext() {
99
+ return (0, react_1.useContext)(Context);
100
+ }
101
+ exports.useAsyncProcessQueueContext = useAsyncProcessQueueContext;
102
+ function calculateCenter(el) {
103
+ const boundsOnViewport = el.getBoundingClientRect();
104
+ return {
105
+ x: boundsOnViewport.x + boundsOnViewport.width / 2,
106
+ y: boundsOnViewport.y + boundsOnViewport.height / 2,
107
+ };
108
+ }
109
+ /** This exposes the recovery registration functions available for abtract types of calls */
110
+ function useRecoveries() {
111
+ return useAsyncProcessQueueContext().recoveries;
112
+ }
113
+ exports.useRecoveries = useRecoveries;
114
+ /**
115
+ * This function wraps other async functions and decides when the ongoing promise should be put on the queue or not
116
+ */
117
+ function useAsyncProcessQueue(functionsToQueue, UIParamsFactory) {
118
+ const loadingRef = (0, react_1.useRef)(null);
119
+ const wrapped = (0, react_1.useRef)(false);
120
+ const elToTransitionToQueue = (0, react_1.useRef)(null);
121
+ const { targetElRef: targetEl, watchPromise } = (0, react_1.useContext)(Context);
122
+ const initialCenter = (0, react_1.useRef)();
123
+ (0, react_1.useEffect)(() => {
124
+ if (targetEl.current)
125
+ initialCenter.current = {
126
+ center: calculateCenter(targetEl.current),
127
+ dimensions: [
128
+ targetEl.current.clientWidth,
129
+ targetEl.current.clientHeight,
130
+ ],
131
+ };
132
+ }, []);
133
+ const wrapQueue = (0, react_1.useCallback)(() => {
134
+ if (wrapped.current || !loadingRef.current || !targetEl.current)
135
+ return;
136
+ const wrapUI = loadingRef.current;
137
+ wrapped.current = true;
138
+ const clone = elToTransitionToQueue.current.cloneNode(true);
139
+ const currPositionOnViewport = elToTransitionToQueue.current.getBoundingClientRect();
140
+ const currPosCenter = calculateCenter(elToTransitionToQueue.current);
141
+ const targetCenter = targetEl.current
142
+ ? calculateCenter(targetEl.current)
143
+ : initialCenter.current.center;
144
+ clone.style.position = "fixed";
145
+ clone.style.top = `${currPositionOnViewport.top}px`;
146
+ clone.style.left = `${currPositionOnViewport.left}px`;
147
+ clone.style.width = `${currPositionOnViewport.width}px`;
148
+ clone.style.height = `${currPositionOnViewport.height}px`;
149
+ clone.style.transition = `transform 250ms ease-out, opacity 250ms ease-in`;
150
+ clone.style.opacity = "1";
151
+ clone.ontransitionend = ({ target, currentTarget }) => {
152
+ if (target === currentTarget)
153
+ wrapUI();
154
+ };
155
+ const targetHeight = Math.min(targetEl.current
156
+ ? targetEl.current.clientHeight
157
+ : initialCenter.current.dimensions[1], elToTransitionToQueue.current.clientHeight);
158
+ const targetWidth = Math.min(targetHeight, targetEl.current
159
+ ? targetEl.current.clientWidth
160
+ : initialCenter.current.dimensions[0], elToTransitionToQueue.current.clientWidth);
161
+ const targetScaleX = targetWidth / elToTransitionToQueue.current.clientWidth;
162
+ const targetScaleY = targetHeight / elToTransitionToQueue.current.clientHeight;
163
+ document.body.appendChild(clone);
164
+ setTimeout(() => {
165
+ clone.style.opacity = "0";
166
+ clone.style.transform = `translateX(${targetCenter.x - currPosCenter.x}px) translateY(${targetCenter.y - currPosCenter.y}px) scaleX(${targetScaleX}) scaleY(${targetScaleY})`;
167
+ clone.addEventListener("transitionend", ({ target, currentTarget }) => {
168
+ if (target === currentTarget)
169
+ clone.remove();
170
+ });
171
+ }, 100);
172
+ }, []);
173
+ return Object.entries(functionsToQueue).reduce((r, [k, v]) => {
174
+ const _process = (...args) => {
175
+ let promise = v(...args);
176
+ loadingRef.current = () => watchPromise(promise, () => v(...args), ...UIParamsFactory(k));
177
+ promise.finally(() => (loadingRef.current = null));
178
+ if (process.env.NODE_ENV === "development")
179
+ promise = (0, AsyncProcessQueue_development_1.securePromise)(promise);
180
+ return promise;
181
+ };
182
+ return Object.assign(Object.assign({}, r), { [k]: _process });
183
+ }, { elToTransitionToQueue, wrapQueue });
184
+ }
185
+ exports.useAsyncProcessQueue = useAsyncProcessQueue;
186
+ //# sourceMappingURL=AsyncProcessQueue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AsyncProcessQueue.js","sourceRoot":"","sources":["../../src/context/AsyncProcessQueue.tsx"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { Get } from "type-fest";
2
- import React from "react";
2
+ import React, { ReactElement } from "react";
3
3
  import { PropsWithChildren } from "react";
4
4
  import { FieldPath } from "../utils";
5
5
  declare type DeepPartial<T> = {
@@ -64,6 +64,15 @@ export declare type ContextSpecs = {
64
64
  className?: string;
65
65
  };
66
66
  };
67
+ hook: {
68
+ ui: {
69
+ usePaginationControls: {
70
+ LeftControl: () => ReactElement;
71
+ RightControl: () => ReactElement;
72
+ className?: string;
73
+ };
74
+ };
75
+ };
67
76
  };
68
77
  declare type ContextConfigSpecs = DeepPartial<ContextSpecs>;
69
78
  export default function OneUIProvider({ children, config, }: PropsWithChildren<{
@@ -61,7 +61,7 @@ function useOneUIConfig(prop, defaultValue) {
61
61
  const context = (0, react_2.useContext)(Context);
62
62
  if (process.env.NODE_ENV === "development") {
63
63
  const val = (0, get_1.default)(context, prop);
64
- if (typeof val === "string")
64
+ if (typeof val === "string" || typeof val === "function")
65
65
  return val;
66
66
  return ErrorWrapper(val || defaultValue);
67
67
  }
@@ -1 +1 @@
1
- {"version":3,"file":"OneUIProvider.js","sourceRoot":"","sources":["../../src/context/OneUIProvider.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"OneUIProvider.js","sourceRoot":"","sources":["../../src/context/OneUIProvider.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { RefObject } from "react";
2
+ /**
3
+ * This hook handles the display of pagination controls for the user to move to another page
4
+ */
5
+ export default function usePaginationControls(containerRef: RefObject<HTMLDivElement>, { snapToPage, }?: {
6
+ snapToPage?: boolean;
7
+ }): {
8
+ controls: JSX.Element[];
9
+ checkControlsRequirement: () => void;
10
+ };
11
+ export declare enum usePaginationControlsTestIds {
12
+ LEFT_CONTROL = "page-l",
13
+ RIGHT_CONTROL = "page-r"
14
+ }
@@ -0,0 +1,92 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.usePaginationControlsTestIds = void 0;
30
+ const throttle_1 = __importDefault(require("lodash/throttle"));
31
+ const react_1 = __importStar(require("react"));
32
+ const FadeIn_1 = __importDefault(require("../../components/FadeIn"));
33
+ const OneUIProvider_1 = require("../../context/OneUIProvider");
34
+ const usePaginationControls_module_scss_1 = __importDefault(require("./usePaginationControls.module.scss"));
35
+ /**
36
+ * This hook handles the display of pagination controls for the user to move to another page
37
+ */
38
+ function usePaginationControls(containerRef, { snapToPage, } = {}) {
39
+ const [[leftControl, rightControl], setControls] = (0, react_1.useState)([false, false]);
40
+ const LeftControl = (0, OneUIProvider_1.useOneUIConfig)("hook.ui.usePaginationControls.LeftControl");
41
+ const RightControl = (0, OneUIProvider_1.useOneUIConfig)("hook.ui.usePaginationControls.RightControl");
42
+ const className = (0, OneUIProvider_1.useOneUIConfig)("hook.ui.usePaginationControls.className", "");
43
+ function move(direction) {
44
+ return () => {
45
+ const rest = containerRef.current.scrollLeft % containerRef.current.clientWidth;
46
+ const snapOffset = snapToPage
47
+ ? direction === "l"
48
+ ? rest
49
+ ? containerRef.current.clientWidth - rest
50
+ : 0
51
+ : rest
52
+ : 0;
53
+ containerRef.current.scrollBy({
54
+ left: (containerRef.current.clientWidth - snapOffset) *
55
+ (direction === "l" ? -1 : 1),
56
+ behavior: "smooth",
57
+ });
58
+ };
59
+ }
60
+ function checkControlsRequirement() {
61
+ const el = containerRef.current;
62
+ const shouldHaveAnyControl = el.scrollWidth > el.clientWidth;
63
+ if (!shouldHaveAnyControl)
64
+ setControls([false, false]);
65
+ else {
66
+ const shouldHaveRightControl = el.scrollLeft < el.scrollWidth - el.clientWidth;
67
+ const shouldHaveLeftControl = el.scrollLeft > 0;
68
+ setControls([shouldHaveLeftControl, shouldHaveRightControl]);
69
+ }
70
+ }
71
+ (0, react_1.useEffect)(() => {
72
+ const el = containerRef.current;
73
+ const throttledCheck = (0, throttle_1.default)(checkControlsRequirement, 1000 / 4);
74
+ checkControlsRequirement();
75
+ el.addEventListener("scroll", throttledCheck);
76
+ return () => el.removeEventListener("scroll", throttledCheck);
77
+ }, []);
78
+ return {
79
+ controls: [
80
+ react_1.default.createElement(FadeIn_1.default, { active: leftControl, className: `${usePaginationControls_module_scss_1.default.left} ${usePaginationControls_module_scss_1.default.control} ${className}`, "data-testid": usePaginationControlsTestIds.LEFT_CONTROL, onClick: move("l") }, leftControl && react_1.default.createElement(LeftControl, null)),
81
+ react_1.default.createElement(FadeIn_1.default, { active: rightControl, className: `${usePaginationControls_module_scss_1.default.right} ${usePaginationControls_module_scss_1.default.control} ${className}`, "data-testid": usePaginationControlsTestIds.RIGHT_CONTROL, onClick: move("r") }, rightControl && react_1.default.createElement(RightControl, null)),
82
+ ],
83
+ checkControlsRequirement,
84
+ };
85
+ }
86
+ exports.default = usePaginationControls;
87
+ var usePaginationControlsTestIds;
88
+ (function (usePaginationControlsTestIds) {
89
+ usePaginationControlsTestIds["LEFT_CONTROL"] = "page-l";
90
+ usePaginationControlsTestIds["RIGHT_CONTROL"] = "page-r";
91
+ })(usePaginationControlsTestIds = exports.usePaginationControlsTestIds || (exports.usePaginationControlsTestIds = {}));
92
+ //# sourceMappingURL=usePaginationControls.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usePaginationControls.js","sourceRoot":"","sources":["../../../src/hooks/ui/usePaginationControls.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ .control {
2
+ position: absolute;
3
+ top: 0px;
4
+ bottom: 0px;
5
+ display: flex;
6
+ align-items: center;
7
+ justify-content: center;
8
+ }
9
+
10
+ .right {
11
+ right: 0px;
12
+ }
13
+
14
+ .left {
15
+ left: 0px;
16
+ }
@@ -1,5 +1,8 @@
1
1
  /// <reference types="react" />
2
- export default function useAsyncControl<E = any, F = {}>(functionsToWrap?: F): {
2
+ import { Primitive } from "type-fest";
3
+ export default function useAsyncControl<E = any, F extends {
4
+ [f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;
5
+ } = {}>(functionsToWrap?: F): {
3
6
  process: (asyncFn: () => Promise<any>) => Promise<any>;
4
7
  loading: boolean;
5
8
  error: Error | E | undefined;
@@ -33,7 +33,9 @@ function useAsyncControl(functionsToWrap) {
33
33
  error,
34
34
  setError,
35
35
  setLoading }, Object.entries(functionsToWrap || {}).reduce((r, [k, func]) => {
36
- return Object.assign(Object.assign({}, r), { [k]: typeof func === "function" ? (...args) => _process(() => func(...args)) : func });
36
+ return Object.assign(Object.assign({}, r), { [k]: typeof func === "function"
37
+ ? (...args) => _process(() => func(...args))
38
+ : func });
37
39
  }, {}));
38
40
  }
39
41
  exports.default = useAsyncControl;
@@ -1 +1 @@
1
- {"version":3,"file":"useAsyncControl.js","sourceRoot":"","sources":["../../src/hooks/useAsyncControl.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,iCAA8C;AAG9C,SAAwB,eAAe,CAAkB,eAAmB;IAC1E,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,GAAa,CAAC;IAChD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IAEvD,MAAM,QAAQ,GAAG,IAAA,mBAAW,EAAC,CAAO,OAA2B,EAAE,EAAE;QACjE,IAAI;YACF,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,QAAQ,CAAC,SAAS,CAAC,CAAC;YACpB,OAAO,MAAM,OAAO,EAAE,CAAC;SACxB;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa;gBAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC7D,QAAQ,CAAC,CAAM,CAAC,CAAC;YACjB,MAAM,CAAC,CAAC;SACT;gBAAS;YACR,UAAU,CAAC,KAAK,CAAC,CAAC;SACnB;IACH,CAAC,CAAA,EAAE,EAAE,CAAC,CAAC;IAEP,uBACE,OAAO,EAAE,QAAQ,EACjB,OAAO;QACP,KAAK;QACL,QAAQ;QACR,UAAU,IACP,MAAM,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,EAAE;QAC/D,uCACK,CAAC,KACJ,CAAC,CAAC,CAAC,EAAE,OAAO,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAE,IAAY,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IACpG;IACH,CAAC,EAAE,EAAO,CAAM,EAChB;AACJ,CAAC;AA/BD,kCA+BC"}
1
+ {"version":3,"file":"useAsyncControl.js","sourceRoot":"","sources":["../../src/hooks/useAsyncControl.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,iCAA8C;AAG9C,SAAwB,eAAe,CAKrC,eAAmB;IACnB,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,GAAa,CAAC;IAChD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IAEvD,MAAM,QAAQ,GAAG,IAAA,mBAAW,EAAC,CAAO,OAA2B,EAAE,EAAE;QACjE,IAAI;YACF,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,QAAQ,CAAC,SAAS,CAAC,CAAC;YACpB,OAAO,MAAM,OAAO,EAAE,CAAC;SACxB;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa;gBAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC7D,QAAQ,CAAC,CAAM,CAAC,CAAC;YACjB,MAAM,CAAC,CAAC;SACT;gBAAS;YACR,UAAU,CAAC,KAAK,CAAC,CAAC;SACnB;IACH,CAAC,CAAA,EAAE,EAAE,CAAC,CAAC;IAEP,uBACE,OAAO,EAAE,QAAQ,EACjB,OAAO;QACP,KAAK;QACL,QAAQ;QACR,UAAU,IACN,MAAM,CAAC,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,EAAE;QAChE,uCACK,CAAC,KACJ,CAAC,CAAC,CAAC,EACD,OAAO,IAAI,KAAK,UAAU;gBACxB,CAAC,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAE,IAAY,CAAC,GAAG,IAAI,CAAC,CAAC;gBAC5D,CAAC,CAAC,IAAI,IACV;IACJ,CAAC,EAAE,EAAO,CAAO,EACjB;AACJ,CAAC;AAvCD,kCAuCC"}
@@ -3,11 +3,13 @@
3
3
  * This hook takes an html and checks if its outside its parent
4
4
  * If it is, it should move it so it can be totally visible inside the container
5
5
  */
6
- export default function useContainedRepositioning(focused: boolean, getParent: (el: HTMLElement) => HTMLElement, { offset, scale }?: {
6
+ export default function useContainedRepositioning(focused: boolean, getParent: (el: HTMLElement) => HTMLElement, { offset, scale, offsetLimit, }?: {
7
7
  /** The offset the element will be moved by from the closest bound */
8
8
  offset?: number;
9
9
  /** The scaled element width to be considered. usefull for when the focused element will change size */
10
10
  scale?: number;
11
+ /** Limit offset */
12
+ offsetLimit?: number;
11
13
  }): {
12
14
  elementToCheck: import("react").RefObject<HTMLDivElement>;
13
15
  };
@@ -9,7 +9,7 @@ const react_1 = require("react");
9
9
  * This hook takes an html and checks if its outside its parent
10
10
  * If it is, it should move it so it can be totally visible inside the container
11
11
  */
12
- function useContainedRepositioning(focused, getParent, { offset = 16, scale = 1 } = {}) {
12
+ function useContainedRepositioning(focused, getParent, { offset = 16, scale = 1, offsetLimit = Number.POSITIVE_INFINITY, } = {}) {
13
13
  const elementToCheck = (0, react_1.useRef)(null);
14
14
  (0, react_1.useEffect)(() => {
15
15
  const el = elementToCheck.current;
@@ -32,19 +32,23 @@ function useContainedRepositioning(focused, getParent, { offset = 16, scale = 1
32
32
  const offsetOfScale = (elWidth - curr.clientWidth) / 2;
33
33
  const cardLimit = curr.offsetLeft - offsetOfScale + alreadyRight + elWidth;
34
34
  const exceedingSpace = cardLimit - limitOffset;
35
- const offsetLeft = curr.offsetLeft - offsetOfScale + alreadyRight - relativeParent.scrollLeft;
35
+ const offsetLeft = curr.offsetLeft -
36
+ offsetOfScale +
37
+ alreadyRight -
38
+ relativeParent.scrollLeft;
36
39
  const isOverflowedRight = exceedingSpace > 0;
37
40
  const isOverflowedLeft = offsetLeft < 0;
38
- const limit = (exceedingSpace + -offsetLeft);
41
+ const limit = exceedingSpace + -offsetLeft;
39
42
  if (isOverflowedRight) {
40
- curr.style.right = `${exceedingSpace - -Math.min(Math.abs(limit / 2), offset)}px`;
43
+ const val = Math.min(exceedingSpace - -Math.min(Math.abs(limit / 2), offset), offsetLimit);
44
+ curr.style.right = `${val}px`;
41
45
  }
42
- ;
43
46
  if (isOverflowedLeft) {
44
- curr.style.right = `${offsetLeft - Math.min(Math.abs(limit) / 2, offset)}px`;
47
+ const val = Math.max(offsetLeft - Math.min(Math.abs(limit) / 2, offset), -offsetLimit);
48
+ curr.style.right = `${val}px`;
45
49
  }
46
50
  if (isOverflowedLeft || isOverflowedRight) {
47
- curr.style.zIndex = '1000';
51
+ curr.style.zIndex = "1000";
48
52
  }
49
53
  }, 50);
50
54
  reposition();
@@ -56,9 +60,8 @@ function useContainedRepositioning(focused, getParent, { offset = 16, scale = 1
56
60
  el.style.right = `0px`;
57
61
  const restore = ({ propertyName, currentTarget }) => {
58
62
  const targetTransformation = window.getComputedStyle(currentTarget).right;
59
- if (propertyName === "right" &&
60
- targetTransformation === "0px") {
61
- curr.style.zIndex = '';
63
+ if (propertyName === "right" && targetTransformation === "0px") {
64
+ curr.style.zIndex = "";
62
65
  el.removeEventListener("transitionend", restore);
63
66
  }
64
67
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useContainedRepositioning.js","sourceRoot":"","sources":["../../src/hooks/useContainedRepositioning.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useContainedRepositioning.js","sourceRoot":"","sources":["../../src/hooks/useContainedRepositioning.ts"],"names":[],"mappings":";;;;;AAAA,+DAAuC;AACvC,iCAA0C;AAE1C;;;GAGG;AACH,SAAwB,yBAAyB,CAC/C,OAAgB,EAChB,SAA2C,EAC3C,EACE,MAAM,GAAG,EAAE,EACX,KAAK,GAAG,CAAC,EACT,WAAW,GAAG,MAAM,CAAC,iBAAiB,MAUpC,EAAE;IAEN,MAAM,cAAc,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IACpD,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,EAAE,GAAG,cAAc,CAAC,OAAO,CAAC;QAClC,IAAI,CAAC,EAAE;YAAE,OAAO;QAEhB,MAAM,IAAI,GAAG,EAAE,CAAC;QAChB,MAAM,cAAc,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;QAEvC,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,EAAE;YAC1C,IAAI,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,QAAQ,KAAK,UAAU;gBACrD,MAAM,IAAI,KAAK,CACb,mEAAmE,CACpE,CAAC;YACJ,IAAI,MAAM,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC,QAAQ,KAAK,UAAU;gBACjE,MAAM,IAAI,KAAK,CACb,uGAAuG,CACxG,CAAC;SACL;QAED,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;YACzB,MAAM,UAAU,GAAG,IAAA,kBAAQ,EAAC,GAAG,EAAE;gBAC/B,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;gBAChE,MAAM,WAAW,GACf,cAAc,CAAC,UAAU,GAAG,cAAc,CAAC,WAAW,CAAC;gBACzD,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzC,MAAM,aAAa,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBACvD,MAAM,SAAS,GACb,IAAI,CAAC,UAAU,GAAG,aAAa,GAAG,YAAY,GAAG,OAAO,CAAC;gBAC3D,MAAM,cAAc,GAAG,SAAS,GAAG,WAAW,CAAC;gBAC/C,MAAM,UAAU,GACd,IAAI,CAAC,UAAU;oBACf,aAAa;oBACb,YAAY;oBACZ,cAAc,CAAC,UAAU,CAAC;gBAC5B,MAAM,iBAAiB,GAAG,cAAc,GAAG,CAAC,CAAC;gBAC7C,MAAM,gBAAgB,GAAG,UAAU,GAAG,CAAC,CAAC;gBACxC,MAAM,KAAK,GAAG,cAAc,GAAG,CAAC,UAAU,CAAC;gBAE3C,IAAI,iBAAiB,EAAE;oBACrB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAClB,cAAc,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,EACvD,WAAW,CACZ,CAAC;oBACF,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC;iBAC/B;gBACD,IAAI,gBAAgB,EAAE;oBACpB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAClB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,EAClD,CAAC,WAAW,CACb,CAAC;oBACF,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC;iBAC/B;gBACD,IAAI,gBAAgB,IAAI,iBAAiB,EAAE;oBACzC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;iBAC5B;YACH,CAAC,EAAE,EAAE,CAAC,CAAC;YACP,UAAU,EAAE,CAAC;YACb,UAAU,CAAC,KAAK,EAAE,CAAC;YAEnB,cAAc,CAAC,gBAAgB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACtD,OAAO,GAAG,EAAE;gBACV,UAAU,CAAC,MAAM,EAAE,CAAC;gBACpB,cAAc,CAAC,mBAAmB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;gBACzD,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;gBACvB,MAAM,OAAO,GAAG,CAAC,EAAE,YAAY,EAAE,aAAa,EAAmB,EAAE,EAAE;oBACnE,MAAM,oBAAoB,GAAG,MAAM,CAAC,gBAAgB,CAClD,aAA+B,CAChC,CAAC,KAAK,CAAC;oBACR,IAAI,YAAY,KAAK,OAAO,IAAI,oBAAoB,KAAK,KAAK,EAAE;wBAC9D,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC;wBACvB,EAAE,CAAC,mBAAmB,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;qBAClD;gBACH,CAAC,CAAC;gBACF,EAAE,CAAC,gBAAgB,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;YAChD,CAAC,CAAC;SACH;IACH,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEd,OAAO;QACL,cAAc;KACf,CAAC;AACJ,CAAC;AApGD,4CAoGC"}
@@ -1,4 +1,4 @@
1
- import { Ref } from "react";
1
+ import { RefObject } from "react";
2
2
  /**
3
3
  * This hook receives a base width of an element and returns how much items fit **vertically** inside the referenced html element
4
4
  *
@@ -8,5 +8,5 @@ export default function useElementFit(baseWidth: number, baseHeight?: number): {
8
8
  /** The amount of items that are able to fit in the available width */
9
9
  itemsToShow?: number;
10
10
  /** The ref to be sent to the element that will receive the items */
11
- ref: Ref<HTMLDivElement>;
11
+ ref: RefObject<HTMLDivElement>;
12
12
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useElementFit.js","sourceRoot":"","sources":["../../src/hooks/useElementFit.ts"],"names":[],"mappings":";;AAAA,iCAA6E;AAE7E;;;;GAIG;AACH,SAAwB,aAAa,CAAC,SAAiB,EAAE,UAAmB;IAOxE,MAAM,GAAG,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IACzC,SAAS,kBAAkB;;QACvB,SAAS,WAAW;YAChB,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,UAAU,KAAK,SAAS;gBACxC,OAAO,CAAC,CAAC;YACb,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAQ,CAAC,YAAY,GAAG,UAAU,CAAC,CAAA;QAC5D,CAAC;QACD,IAAK,MAAc,CAAC,SAAS;YAAE,OAAO,CAAC,CAAC;QAExC,MAAM,KAAK,GAAG,CAAA,MAAA,GAAG,CAAC,OAAO,0CAAE,WAAW,KAAI,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;QACtE,MAAM,kBAAkB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;QAE9D,OAAO,kBAAkB,GAAG,WAAW,EAAE,CAAC;IAC9C,CAAC;IACD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAE,MAAc,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAC1F,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,cAAc,CAAC,kBAAkB,EAAE,CAAC,CAAC;QACrC,SAAS,QAAQ;YACb,cAAc,CAAC,kBAAkB,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC5C,OAAO,GAAG,EAAE;YACR,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACnD,CAAC,CAAC;IACN,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO;QACH,WAAW;QACX,GAAG;KACN,CAAA;AACL,CAAC;AArCD,gCAqCC"}
1
+ {"version":3,"file":"useElementFit.js","sourceRoot":"","sources":["../../src/hooks/useElementFit.ts"],"names":[],"mappings":";;AAAA,iCAA6E;AAE7E;;;;GAIG;AACH,SAAwB,aAAa,CAAC,SAAiB,EAAE,UAAmB;IAOxE,MAAM,GAAG,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IACzC,SAAS,kBAAkB;;QACvB,SAAS,WAAW;YAChB,IAAI,CAAC,GAAG,CAAC,OAAO,IAAI,UAAU,KAAK,SAAS;gBACxC,OAAO,CAAC,CAAC;YACb,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAQ,CAAC,YAAY,GAAG,UAAU,CAAC,CAAA;QAC5D,CAAC;QACD,IAAK,MAAc,CAAC,SAAS;YAAE,OAAO,CAAC,CAAC;QAExC,MAAM,KAAK,GAAG,CAAA,MAAA,GAAG,CAAC,OAAO,0CAAE,WAAW,KAAI,MAAM,CAAC,cAAe,CAAC,KAAK,CAAC;QACvE,MAAM,kBAAkB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;QAE9D,OAAO,kBAAkB,GAAG,WAAW,EAAE,CAAC;IAC9C,CAAC;IACD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,IAAA,gBAAQ,EAAE,MAAc,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAC1F,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,cAAc,CAAC,kBAAkB,EAAE,CAAC,CAAC;QACrC,SAAS,QAAQ;YACb,cAAc,CAAC,kBAAkB,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC5C,OAAO,GAAG,EAAE;YACR,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACnD,CAAC,CAAC;IACN,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO;QACH,WAAW;QACX,GAAG;KACN,CAAA;AACL,CAAC;AArCD,gCAqCC"}
@@ -2,4 +2,4 @@
2
2
  * This hook pipes a data and when it is set to a falsy value ("", undefined, null, 0),
3
3
  * it returns the previous valid value
4
4
  */
5
- export default function useFreeze<T>(something: T): T | null;
5
+ export default function useFreeze<T>(something: T): NonNullable<T> | null;
@@ -0,0 +1,13 @@
1
+ import { CSSProperties } from "react";
2
+ /**
3
+ * This hook implements the logic for a hero animation between 2 elements
4
+ */
5
+ export default function useHero(id: string, propsToTransition?: Omit<keyof CSSProperties, "width" | "height" | "top" | "left">[], events?: {
6
+ /** Returns if the element should be heroed */
7
+ onHeroDetect?: (el: HTMLDivElement) => boolean;
8
+ onHeroEnd?: () => void;
9
+ onHeroStart?: (clone: HTMLDivElement) => void;
10
+ }): {
11
+ heroRef: import("react").RefObject<HTMLDivElement>;
12
+ getHerosOnScreen: () => HTMLDivElement[];
13
+ };