@onepercentio/one-ui 0.28.9 → 0.29.1
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.
- package/dist/utils/e2e.d.ts +13 -0
- package/dist/utils/e2e.js +42 -0
- package/dist-ts/assets/img/svg/checkbox.svg +3 -0
- package/dist-ts/assets/styles/index.scss +2 -0
- package/dist-ts/assets/styles/mixins.scss +12 -0
- package/dist-ts/assets/styles/variables.scss +49 -0
- package/dist-ts/components/AdaptiveButton/AdaptiveButton.d.ts +8 -0
- package/dist-ts/components/AdaptiveButton/AdaptiveButton.js +11 -0
- package/dist-ts/components/AdaptiveButton/AdaptiveButton.js.map +1 -0
- package/dist-ts/components/AdaptiveButton/AdaptiveButton.module.scss +7 -0
- package/dist-ts/components/AdaptiveButton/index.d.ts +1 -0
- package/dist-ts/components/AdaptiveButton/index.js +2 -0
- package/dist-ts/components/AdaptiveButton/index.js.map +1 -0
- package/dist-ts/components/AdaptiveContainer/AdaptiveContainer.d.ts +21 -0
- package/dist-ts/components/AdaptiveContainer/AdaptiveContainer.js +125 -0
- package/dist-ts/components/AdaptiveContainer/AdaptiveContainer.js.map +1 -0
- package/dist-ts/components/AdaptiveContainer/AdaptiveContainer.module.scss +53 -0
- package/dist-ts/components/AdaptiveContainer/index.d.ts +1 -0
- package/dist-ts/components/AdaptiveContainer/index.js +2 -0
- package/dist-ts/components/AdaptiveContainer/index.js.map +1 -0
- package/dist-ts/components/AdaptiveDialog/AdaptiveDialog.d.ts +16 -0
- package/dist-ts/components/AdaptiveDialog/AdaptiveDialog.js +39 -0
- package/dist-ts/components/AdaptiveDialog/AdaptiveDialog.js.map +1 -0
- package/dist-ts/components/AdaptiveDialog/AdaptiveDialog.module.scss +147 -0
- package/dist-ts/components/AdaptiveDialog/index.d.ts +1 -0
- package/dist-ts/components/AdaptiveDialog/index.js +2 -0
- package/dist-ts/components/AdaptiveDialog/index.js.map +1 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.d.ts +24 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.js +43 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.js.map +1 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.module.scss +49 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.sample.d.ts +1 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.sample.js +6 -0
- package/dist-ts/components/AdaptiveSidebar/AdaptiveSidebar.sample.js.map +1 -0
- package/dist-ts/components/AdaptiveSidebar/index.d.ts +1 -0
- package/dist-ts/components/AdaptiveSidebar/index.js +2 -0
- package/dist-ts/components/AdaptiveSidebar/index.js.map +1 -0
- package/dist-ts/components/AnchoredTooltip/AnchoredTooltip.d.ts +34 -0
- package/dist-ts/components/AnchoredTooltip/AnchoredTooltip.js +145 -0
- package/dist-ts/components/AnchoredTooltip/AnchoredTooltip.js.map +1 -0
- package/dist-ts/components/AnchoredTooltip/AnchoredTooltip.module.scss +64 -0
- package/dist-ts/components/AnchoredTooltip/index.d.ts +1 -0
- package/dist-ts/components/AnchoredTooltip/index.js +2 -0
- package/dist-ts/components/AnchoredTooltip/index.js.map +1 -0
- package/dist-ts/components/AnimatedEntrance/AnimatedEntrance.d.ts +18 -0
- package/dist-ts/components/AnimatedEntrance/AnimatedEntrance.js +122 -0
- package/dist-ts/components/AnimatedEntrance/AnimatedEntrance.js.map +1 -0
- package/dist-ts/components/AnimatedEntrance/AnimatedEntrance.module.scss +108 -0
- package/dist-ts/components/AnimatedEntrance/index.d.ts +1 -0
- package/dist-ts/components/AnimatedEntrance/index.js +2 -0
- package/dist-ts/components/AnimatedEntrance/index.js.map +1 -0
- package/dist-ts/components/AsyncWrapper/AsyncWrapper.d.ts +10 -0
- package/dist-ts/components/AsyncWrapper/AsyncWrapper.js +14 -0
- package/dist-ts/components/AsyncWrapper/AsyncWrapper.js.map +1 -0
- package/dist-ts/components/AsyncWrapper/index.d.ts +1 -0
- package/dist-ts/components/AsyncWrapper/index.js +2 -0
- package/dist-ts/components/AsyncWrapper/index.js.map +1 -0
- package/dist-ts/components/Avatar/Avatar.d.ts +8 -0
- package/dist-ts/components/Avatar/Avatar.js +17 -0
- package/dist-ts/components/Avatar/Avatar.js.map +1 -0
- package/dist-ts/components/Avatar/Avatar.module.scss +22 -0
- package/dist-ts/components/Avatar/index.d.ts +1 -0
- package/dist-ts/components/Avatar/index.js +2 -0
- package/dist-ts/components/Avatar/index.js.map +1 -0
- package/dist-ts/components/BucketFill/BucketFill.d.ts +12 -0
- package/dist-ts/components/BucketFill/BucketFill.js +36 -0
- package/dist-ts/components/BucketFill/BucketFill.js.map +1 -0
- package/dist-ts/components/BucketFill/BucketFill.module.scss +36 -0
- package/dist-ts/components/BucketFill/index.d.ts +1 -0
- package/dist-ts/components/BucketFill/index.js +2 -0
- package/dist-ts/components/BucketFill/index.js.map +1 -0
- package/dist-ts/components/Button/Button.d.ts +14 -0
- package/dist-ts/components/Button/Button.js +14 -0
- package/dist-ts/components/Button/Button.js.map +1 -0
- package/dist-ts/components/Button/Button.module.scss +45 -0
- package/dist-ts/components/Button/index.d.ts +1 -0
- package/dist-ts/components/Button/index.js +2 -0
- package/dist-ts/components/Button/index.js.map +1 -0
- package/dist-ts/components/Card/Card.d.ts +7 -0
- package/dist-ts/components/Card/Card.js +9 -0
- package/dist-ts/components/Card/Card.js.map +1 -0
- package/dist-ts/components/Card/Card.module.scss +12 -0
- package/dist-ts/components/Card/index.d.ts +1 -0
- package/dist-ts/components/Card/index.js +2 -0
- package/dist-ts/components/Card/index.js.map +1 -0
- package/dist-ts/components/Chart/Chart.e2e.d.ts +4 -0
- package/dist-ts/components/Chart/Chart.e2e.js +6 -0
- package/dist-ts/components/Chart/Chart.e2e.js.map +1 -0
- package/dist-ts/components/Chart/Chart.logic.d.ts +3 -0
- package/dist-ts/components/Chart/Chart.logic.js +7 -0
- package/dist-ts/components/Chart/Chart.logic.js.map +1 -0
- package/dist-ts/components/Chart/Chart.module.scss +58 -0
- package/dist-ts/components/Chart/Chart.types.d.ts +24 -0
- package/dist-ts/components/Chart/Chart.types.js +2 -0
- package/dist-ts/components/Chart/Chart.types.js.map +1 -0
- package/dist-ts/components/Chart/Chart.view.d.ts +5 -0
- package/dist-ts/components/Chart/Chart.view.js +102 -0
- package/dist-ts/components/Chart/Chart.view.js.map +1 -0
- package/dist-ts/components/Chart/index.d.ts +1 -0
- package/dist-ts/components/Chart/index.js +2 -0
- package/dist-ts/components/Chart/index.js.map +1 -0
- package/dist-ts/components/CheckBox/CheckBox.d.ts +13 -0
- package/dist-ts/components/CheckBox/CheckBox.js +14 -0
- package/dist-ts/components/CheckBox/CheckBox.js.map +1 -0
- package/dist-ts/components/CheckBox/CheckBox.module.scss +36 -0
- package/dist-ts/components/CheckBox/index.d.ts +1 -0
- package/dist-ts/components/CheckBox/index.js +2 -0
- package/dist-ts/components/CheckBox/index.js.map +1 -0
- package/dist-ts/components/CodeInput/CodeInput.d.ts +8 -0
- package/dist-ts/components/CodeInput/CodeInput.js +73 -0
- package/dist-ts/components/CodeInput/CodeInput.js.map +1 -0
- package/dist-ts/components/CodeInput/CodeInput.module.scss +5 -0
- package/dist-ts/components/CodeInput/index.d.ts +1 -0
- package/dist-ts/components/CodeInput/index.js +2 -0
- package/dist-ts/components/CodeInput/index.js.map +1 -0
- package/dist-ts/components/Collapsable/Collapsable.d.ts +49 -0
- package/dist-ts/components/Collapsable/Collapsable.js +133 -0
- package/dist-ts/components/Collapsable/Collapsable.js.map +1 -0
- package/dist-ts/components/Collapsable/Collapsable.module.scss +42 -0
- package/dist-ts/components/Collapsable/index.d.ts +1 -0
- package/dist-ts/components/Collapsable/index.js +2 -0
- package/dist-ts/components/Collapsable/index.js.map +1 -0
- package/dist-ts/components/Countdown/Countdown.d.ts +24 -0
- package/dist-ts/components/Countdown/Countdown.js +73 -0
- package/dist-ts/components/Countdown/Countdown.js.map +1 -0
- package/dist-ts/components/Countdown/index.d.ts +1 -0
- package/dist-ts/components/Countdown/index.js +2 -0
- package/dist-ts/components/Countdown/index.js.map +1 -0
- package/dist-ts/components/CurrencyInput/CurrencyInput.d.ts +7 -0
- package/dist-ts/components/CurrencyInput/CurrencyInput.hook.d.ts +6 -0
- package/dist-ts/components/CurrencyInput/CurrencyInput.hook.js +23 -0
- package/dist-ts/components/CurrencyInput/CurrencyInput.hook.js.map +1 -0
- package/dist-ts/components/CurrencyInput/CurrencyInput.js +12 -0
- package/dist-ts/components/CurrencyInput/CurrencyInput.js.map +1 -0
- package/dist-ts/components/CurrencyInput/index.d.ts +1 -0
- package/dist-ts/components/CurrencyInput/index.js +2 -0
- package/dist-ts/components/CurrencyInput/index.js.map +1 -0
- package/dist-ts/components/Divider/Divider.d.ts +6 -0
- package/dist-ts/components/Divider/Divider.js +9 -0
- package/dist-ts/components/Divider/Divider.js.map +1 -0
- package/dist-ts/components/Divider/Divider.module.scss +7 -0
- package/dist-ts/components/Divider/index.d.ts +1 -0
- package/dist-ts/components/Divider/index.js +2 -0
- package/dist-ts/components/Divider/index.js.map +1 -0
- package/dist-ts/components/EmailInput/EmailInput.d.ts +31 -0
- package/dist-ts/components/EmailInput/EmailInput.js +24 -0
- package/dist-ts/components/EmailInput/EmailInput.js.map +1 -0
- package/dist-ts/components/EmailInput/EmailInput.module.scss +0 -0
- package/dist-ts/components/EmailInput/index.d.ts +1 -0
- package/dist-ts/components/EmailInput/index.js +2 -0
- package/dist-ts/components/EmailInput/index.js.map +1 -0
- package/dist-ts/components/FadeIn/FadeIn.d.ts +15 -0
- package/dist-ts/components/FadeIn/FadeIn.js +40 -0
- package/dist-ts/components/FadeIn/FadeIn.js.map +1 -0
- package/dist-ts/components/FadeIn/FadeIn.module.scss +9 -0
- package/dist-ts/components/FadeIn/index.d.ts +1 -0
- package/dist-ts/components/FadeIn/index.js +2 -0
- package/dist-ts/components/FadeIn/index.js.map +1 -0
- package/dist-ts/components/FileInput/FileInput.d.ts +31 -0
- package/dist-ts/components/FileInput/FileInput.js +26 -0
- package/dist-ts/components/FileInput/FileInput.js.map +1 -0
- package/dist-ts/components/FileInput/FileInput.module.scss +6 -0
- package/dist-ts/components/FileInput/View/BigFactory/BigFactory.d.ts +6 -0
- package/dist-ts/components/FileInput/View/BigFactory/BigFactory.js +14 -0
- package/dist-ts/components/FileInput/View/BigFactory/BigFactory.js.map +1 -0
- package/dist-ts/components/FileInput/View/BigFactory/BigFactory.module.scss +20 -0
- package/dist-ts/components/FileInput/View/BigFactory/index.d.ts +1 -0
- package/dist-ts/components/FileInput/View/BigFactory/index.js +2 -0
- package/dist-ts/components/FileInput/View/BigFactory/index.js.map +1 -0
- package/dist-ts/components/FileInput/View/Compact/Compact.d.ts +11 -0
- package/dist-ts/components/FileInput/View/Compact/Compact.js +45 -0
- package/dist-ts/components/FileInput/View/Compact/Compact.js.map +1 -0
- package/dist-ts/components/FileInput/View/Compact/Compact.module.scss +68 -0
- package/dist-ts/components/FileInput/View/Compact/index.d.ts +1 -0
- package/dist-ts/components/FileInput/View/Compact/index.js +2 -0
- package/dist-ts/components/FileInput/View/Compact/index.js.map +1 -0
- package/dist-ts/components/FileInput/View/View.types.d.ts +8 -0
- package/dist-ts/components/FileInput/View/View.types.js +2 -0
- package/dist-ts/components/FileInput/View/View.types.js.map +1 -0
- package/dist-ts/components/FileInput/index.d.ts +1 -0
- package/dist-ts/components/FileInput/index.js +2 -0
- package/dist-ts/components/FileInput/index.js.map +1 -0
- package/dist-ts/components/FlowController/FlowController.d.ts +23 -0
- package/dist-ts/components/FlowController/FlowController.js +23 -0
- package/dist-ts/components/FlowController/FlowController.js.map +1 -0
- package/dist-ts/components/FlowController/FlowController.module.scss +47 -0
- package/dist-ts/components/FlowController/index.d.ts +1 -0
- package/dist-ts/components/FlowController/index.js +2 -0
- package/dist-ts/components/FlowController/index.js.map +1 -0
- package/dist-ts/components/Form/Form.d.ts +49 -0
- package/dist-ts/components/Form/Form.js +69 -0
- package/dist-ts/components/Form/Form.js.map +1 -0
- package/dist-ts/components/Form/index.d.ts +1 -0
- package/dist-ts/components/Form/index.js +2 -0
- package/dist-ts/components/Form/index.js.map +1 -0
- package/dist-ts/components/Form/v2/Form.d.ts +18 -0
- package/dist-ts/components/Form/v2/Form.hook.d.ts +40 -0
- package/dist-ts/components/Form/v2/Form.hook.js +222 -0
- package/dist-ts/components/Form/v2/Form.hook.js.map +1 -0
- package/dist-ts/components/Form/v2/Form.js +31 -0
- package/dist-ts/components/Form/v2/Form.js.map +1 -0
- package/dist-ts/components/Form/v2/Form.module.scss +0 -0
- package/dist-ts/components/Form/v2/Form.types.d.ts +97 -0
- package/dist-ts/components/Form/v2/Form.types.js +51 -0
- package/dist-ts/components/Form/v2/Form.types.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/DateField.d.ts +11 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/DateField.js +38 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/DateField.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/DateField.module.scss +0 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/index.d.ts +1 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/index.js +2 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/DateField/index.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.d.ts +9 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.js +57 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.module.scss +0 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/index.d.ts +1 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/index.js +2 -0
- package/dist-ts/components/Form/v2/FormField/Extensions/PhoneField/index.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/FormField.d.ts +5 -0
- package/dist-ts/components/Form/v2/FormField/FormField.js +133 -0
- package/dist-ts/components/Form/v2/FormField/FormField.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/FormField.module.scss +0 -0
- package/dist-ts/components/Form/v2/FormField/FormField.types.d.ts +90 -0
- package/dist-ts/components/Form/v2/FormField/FormField.types.js +6 -0
- package/dist-ts/components/Form/v2/FormField/FormField.types.js.map +1 -0
- package/dist-ts/components/Form/v2/FormField/index.d.ts +1 -0
- package/dist-ts/components/Form/v2/FormField/index.js +2 -0
- package/dist-ts/components/Form/v2/FormField/index.js.map +1 -0
- package/dist-ts/components/Form/v2/index.d.ts +1 -0
- package/dist-ts/components/Form/v2/index.js +2 -0
- package/dist-ts/components/Form/v2/index.js.map +1 -0
- package/dist-ts/components/Freeze/Freeze.d.ts +5 -0
- package/dist-ts/components/Freeze/Freeze.js +8 -0
- package/dist-ts/components/Freeze/Freeze.js.map +1 -0
- package/dist-ts/components/Freeze/index.d.ts +1 -0
- package/dist-ts/components/Freeze/index.js +2 -0
- package/dist-ts/components/Freeze/index.js.map +1 -0
- package/dist-ts/components/HSForms/HSForms.d.ts +8 -0
- package/dist-ts/components/HSForms/HSForms.js +46 -0
- package/dist-ts/components/HSForms/HSForms.js.map +1 -0
- package/dist-ts/components/HSForms/index.d.ts +1 -0
- package/dist-ts/components/HSForms/index.js +2 -0
- package/dist-ts/components/HSForms/index.js.map +1 -0
- package/dist-ts/components/Header/Header.d.ts +25 -0
- package/dist-ts/components/Header/Header.js +35 -0
- package/dist-ts/components/Header/Header.js.map +1 -0
- package/dist-ts/components/Header/Header.module.scss +119 -0
- package/dist-ts/components/Header/index.d.ts +1 -0
- package/dist-ts/components/Header/index.js +2 -0
- package/dist-ts/components/Header/index.js.map +1 -0
- package/dist-ts/components/HeaderCloseBtn/HeaderCloseBtn.d.ts +8 -0
- package/dist-ts/components/HeaderCloseBtn/HeaderCloseBtn.js +9 -0
- package/dist-ts/components/HeaderCloseBtn/HeaderCloseBtn.js.map +1 -0
- package/dist-ts/components/HeaderCloseBtn/HeaderCloseBtn.module.scss +44 -0
- package/dist-ts/components/HeaderCloseBtn/index.d.ts +1 -0
- package/dist-ts/components/HeaderCloseBtn/index.js +2 -0
- package/dist-ts/components/HeaderCloseBtn/index.js.map +1 -0
- package/dist-ts/components/InfinityScroll/InfinityScroll.d.ts +21 -0
- package/dist-ts/components/InfinityScroll/InfinityScroll.js +102 -0
- package/dist-ts/components/InfinityScroll/InfinityScroll.js.map +1 -0
- package/dist-ts/components/InfinityScroll/InfinityScroll.module.scss +30 -0
- package/dist-ts/components/InfinityScroll/index.d.ts +1 -0
- package/dist-ts/components/InfinityScroll/index.js +2 -0
- package/dist-ts/components/InfinityScroll/index.js.map +1 -0
- package/dist-ts/components/Input/Input.d.ts +43 -0
- package/dist-ts/components/Input/Input.js +51 -0
- package/dist-ts/components/Input/Input.js.map +1 -0
- package/dist-ts/components/Input/Input.module.scss +71 -0
- package/dist-ts/components/Input/index.d.ts +1 -0
- package/dist-ts/components/Input/index.js +2 -0
- package/dist-ts/components/Input/index.js.map +1 -0
- package/dist-ts/components/InstantCounter/InstantCounter.d.ts +16 -0
- package/dist-ts/components/InstantCounter/InstantCounter.js +35 -0
- package/dist-ts/components/InstantCounter/InstantCounter.js.map +1 -0
- package/dist-ts/components/InstantCounter/index.d.ts +1 -0
- package/dist-ts/components/InstantCounter/index.js +2 -0
- package/dist-ts/components/InstantCounter/index.js.map +1 -0
- package/dist-ts/components/LavaLamp/LavaLamp.d.ts +12 -0
- package/dist-ts/components/LavaLamp/LavaLamp.data.d.ts +16 -0
- package/dist-ts/components/LavaLamp/LavaLamp.data.js +85 -0
- package/dist-ts/components/LavaLamp/LavaLamp.data.js.map +1 -0
- package/dist-ts/components/LavaLamp/LavaLamp.js +32 -0
- package/dist-ts/components/LavaLamp/LavaLamp.js.map +1 -0
- package/dist-ts/components/LavaLamp/LavaLamp.module.scss +26 -0
- package/dist-ts/components/LavaLamp/index.d.ts +1 -0
- package/dist-ts/components/LavaLamp/index.js +2 -0
- package/dist-ts/components/LavaLamp/index.js.map +1 -0
- package/dist-ts/components/LavaLamp/v2/LavaLamp.d.ts +4 -0
- package/dist-ts/components/LavaLamp/v2/LavaLamp.js +132 -0
- package/dist-ts/components/LavaLamp/v2/LavaLamp.js.map +1 -0
- package/dist-ts/components/LavaLamp/v2/LavaLamp.module.scss +23 -0
- package/dist-ts/components/LinkToId/LinkToId.d.ts +10 -0
- package/dist-ts/components/LinkToId/LinkToId.js +25 -0
- package/dist-ts/components/LinkToId/LinkToId.js.map +1 -0
- package/dist-ts/components/LinkToId/LinkToId.module.scss +4 -0
- package/dist-ts/components/LinkToId/index.d.ts +1 -0
- package/dist-ts/components/LinkToId/index.js +2 -0
- package/dist-ts/components/LinkToId/index.js.map +1 -0
- package/dist-ts/components/Loader/Loader.d.ts +7 -0
- package/dist-ts/components/Loader/Loader.js +9 -0
- package/dist-ts/components/Loader/Loader.js.map +1 -0
- package/dist-ts/components/Loader/Loader.module.scss +40 -0
- package/dist-ts/components/Loader/index.d.ts +1 -0
- package/dist-ts/components/Loader/index.js +2 -0
- package/dist-ts/components/Loader/index.js.map +1 -0
- package/dist-ts/components/LoaderDotsIndicator/LoaderDotsIndicator.d.ts +8 -0
- package/dist-ts/components/LoaderDotsIndicator/LoaderDotsIndicator.js +17 -0
- package/dist-ts/components/LoaderDotsIndicator/LoaderDotsIndicator.js.map +1 -0
- package/dist-ts/components/LoaderDotsIndicator/index.d.ts +1 -0
- package/dist-ts/components/LoaderDotsIndicator/index.js +2 -0
- package/dist-ts/components/LoaderDotsIndicator/index.js.map +1 -0
- package/dist-ts/components/LoopableVideo/LoopableVideo.d.ts +9 -0
- package/dist-ts/components/LoopableVideo/LoopableVideo.js +15 -0
- package/dist-ts/components/LoopableVideo/LoopableVideo.js.map +1 -0
- package/dist-ts/components/LoopableVideo/index.d.ts +1 -0
- package/dist-ts/components/LoopableVideo/index.js +2 -0
- package/dist-ts/components/LoopableVideo/index.js.map +1 -0
- package/dist-ts/components/MainGrid/MainGrid.d.ts +13 -0
- package/dist-ts/components/MainGrid/MainGrid.js +23 -0
- package/dist-ts/components/MainGrid/MainGrid.js.map +1 -0
- package/dist-ts/components/MainGrid/MainGrid.module.scss +28 -0
- package/dist-ts/components/MainGrid/index.d.ts +1 -0
- package/dist-ts/components/MainGrid/index.js +2 -0
- package/dist-ts/components/MainGrid/index.js.map +1 -0
- package/dist-ts/components/MutableHamburgerButton/MutableHamburgerButton.d.ts +8 -0
- package/dist-ts/components/MutableHamburgerButton/MutableHamburgerButton.js +10 -0
- package/dist-ts/components/MutableHamburgerButton/MutableHamburgerButton.js.map +1 -0
- package/dist-ts/components/MutableHamburgerButton/MutableHamburgerButton.module.scss +220 -0
- package/dist-ts/components/MutableHamburgerButton/index.d.ts +1 -0
- package/dist-ts/components/MutableHamburgerButton/index.js +2 -0
- package/dist-ts/components/MutableHamburgerButton/index.js.map +1 -0
- package/dist-ts/components/Notification/Notification.d.ts +7 -0
- package/dist-ts/components/Notification/Notification.js +10 -0
- package/dist-ts/components/Notification/Notification.js.map +1 -0
- package/dist-ts/components/Notification/Notification.module.scss +25 -0
- package/dist-ts/components/Notification/index.d.ts +1 -0
- package/dist-ts/components/Notification/index.js +2 -0
- package/dist-ts/components/Notification/index.js.map +1 -0
- package/dist-ts/components/OrderableList/OrderableList.d.ts +38 -0
- package/dist-ts/components/OrderableList/OrderableList.js +407 -0
- package/dist-ts/components/OrderableList/OrderableList.js.map +1 -0
- package/dist-ts/components/OrderableList/OrderableList.module.scss +98 -0
- package/dist-ts/components/OrderableList/index.d.ts +1 -0
- package/dist-ts/components/OrderableList/index.js +2 -0
- package/dist-ts/components/OrderableList/index.js.map +1 -0
- package/dist-ts/components/PaginationIndicator/PaginationIndicator.d.ts +40 -0
- package/dist-ts/components/PaginationIndicator/PaginationIndicator.js +206 -0
- package/dist-ts/components/PaginationIndicator/PaginationIndicator.js.map +1 -0
- package/dist-ts/components/PaginationIndicator/index.d.ts +1 -0
- package/dist-ts/components/PaginationIndicator/index.js +2 -0
- package/dist-ts/components/PaginationIndicator/index.js.map +1 -0
- package/dist-ts/components/Parallax/Parallax.d.ts +18 -0
- package/dist-ts/components/Parallax/Parallax.js +132 -0
- package/dist-ts/components/Parallax/Parallax.js.map +1 -0
- package/dist-ts/components/Parallax/Parallax.module.scss +28 -0
- package/dist-ts/components/Parallax/index.d.ts +1 -0
- package/dist-ts/components/Parallax/index.js +2 -0
- package/dist-ts/components/Parallax/index.js.map +1 -0
- package/dist-ts/components/Parallax/math/helpers.d.ts +58 -0
- package/dist-ts/components/Parallax/math/helpers.js +222 -0
- package/dist-ts/components/Parallax/math/helpers.js.map +1 -0
- package/dist-ts/components/PasswordInput/PasswordInput.d.ts +48 -0
- package/dist-ts/components/PasswordInput/PasswordInput.js +74 -0
- package/dist-ts/components/PasswordInput/PasswordInput.js.map +1 -0
- package/dist-ts/components/PasswordInput/PasswordInput.module.scss +17 -0
- package/dist-ts/components/PasswordInput/index.d.ts +1 -0
- package/dist-ts/components/PasswordInput/index.js +2 -0
- package/dist-ts/components/PasswordInput/index.js.map +1 -0
- package/dist-ts/components/PingPongText/PingPongText.d.ts +6 -0
- package/dist-ts/components/PingPongText/PingPongText.js +58 -0
- package/dist-ts/components/PingPongText/PingPongText.js.map +1 -0
- package/dist-ts/components/PingPongText/PingPongText.module.scss +4 -0
- package/dist-ts/components/PingPongText/index.d.ts +1 -0
- package/dist-ts/components/PingPongText/index.js +2 -0
- package/dist-ts/components/PingPongText/index.js.map +1 -0
- package/dist-ts/components/PixelatedScan/PixelatedScan.d.ts +8 -0
- package/dist-ts/components/PixelatedScan/PixelatedScan.js +78 -0
- package/dist-ts/components/PixelatedScan/PixelatedScan.js.map +1 -0
- package/dist-ts/components/PixelatedScan/PixelatedScan.module.scss +86 -0
- package/dist-ts/components/PixelatedScan/index.d.ts +1 -0
- package/dist-ts/components/PixelatedScan/index.js +2 -0
- package/dist-ts/components/PixelatedScan/index.js.map +1 -0
- package/dist-ts/components/Portal/Portal.d.ts +11 -0
- package/dist-ts/components/Portal/Portal.js +31 -0
- package/dist-ts/components/Portal/Portal.js.map +1 -0
- package/dist-ts/components/Portal/Portal.module.scss +3 -0
- package/dist-ts/components/Portal/index.d.ts +1 -0
- package/dist-ts/components/Portal/index.js +2 -0
- package/dist-ts/components/Portal/index.js.map +1 -0
- package/dist-ts/components/ProgressBar/ProgressBar.d.ts +29 -0
- package/dist-ts/components/ProgressBar/ProgressBar.js +33 -0
- package/dist-ts/components/ProgressBar/ProgressBar.js.map +1 -0
- package/dist-ts/components/ProgressBar/ProgressBar.module.scss +44 -0
- package/dist-ts/components/ProgressBar/index.d.ts +1 -0
- package/dist-ts/components/ProgressBar/index.js +2 -0
- package/dist-ts/components/ProgressBar/index.js.map +1 -0
- package/dist-ts/components/ProgressTexts/ProgressTexts.d.ts +25 -0
- package/dist-ts/components/ProgressTexts/ProgressTexts.js +28 -0
- package/dist-ts/components/ProgressTexts/ProgressTexts.js.map +1 -0
- package/dist-ts/components/ProgressTexts/ProgressTexts.module.scss +37 -0
- package/dist-ts/components/ProgressTexts/index.d.ts +1 -0
- package/dist-ts/components/ProgressTexts/index.js +2 -0
- package/dist-ts/components/ProgressTexts/index.js.map +1 -0
- package/dist-ts/components/Radio/Radio.d.ts +13 -0
- package/dist-ts/components/Radio/Radio.js +14 -0
- package/dist-ts/components/Radio/Radio.js.map +1 -0
- package/dist-ts/components/Radio/Radio.module.scss +36 -0
- package/dist-ts/components/Radio/index.d.ts +1 -0
- package/dist-ts/components/Radio/index.js +2 -0
- package/dist-ts/components/Radio/index.js.map +1 -0
- package/dist-ts/components/SectionContainer/SectionContainer.d.ts +14 -0
- package/dist-ts/components/SectionContainer/SectionContainer.js +15 -0
- package/dist-ts/components/SectionContainer/SectionContainer.js.map +1 -0
- package/dist-ts/components/SectionContainer/SectionContainer.module.scss +30 -0
- package/dist-ts/components/SectionContainer/index.d.ts +1 -0
- package/dist-ts/components/SectionContainer/index.js +2 -0
- package/dist-ts/components/SectionContainer/index.js.map +1 -0
- package/dist-ts/components/Select/Select.d.ts +30 -0
- package/dist-ts/components/Select/Select.js +65 -0
- package/dist-ts/components/Select/Select.js.map +1 -0
- package/dist-ts/components/Select/Select.module.scss +58 -0
- package/dist-ts/components/Select/index.d.ts +1 -0
- package/dist-ts/components/Select/index.js +2 -0
- package/dist-ts/components/Select/index.js.map +1 -0
- package/dist-ts/components/Skeleton/Skeleton.d.ts +10 -0
- package/dist-ts/components/Skeleton/Skeleton.js +16 -0
- package/dist-ts/components/Skeleton/Skeleton.js.map +1 -0
- package/dist-ts/components/Skeleton/Skeleton.module.scss +21 -0
- package/dist-ts/components/Skeleton/index.d.ts +1 -0
- package/dist-ts/components/Skeleton/index.js +2 -0
- package/dist-ts/components/Skeleton/index.js.map +1 -0
- package/dist-ts/components/Spacing/Spacing.d.ts +6 -0
- package/dist-ts/components/Spacing/Spacing.js +16 -0
- package/dist-ts/components/Spacing/Spacing.js.map +1 -0
- package/dist-ts/components/Spacing/Spacing.module.scss +13 -0
- package/dist-ts/components/Spacing/index.d.ts +1 -0
- package/dist-ts/components/Spacing/index.js +2 -0
- package/dist-ts/components/Spacing/index.js.map +1 -0
- package/dist-ts/components/StaticScroller/StaticScroller.d.ts +6 -0
- package/dist-ts/components/StaticScroller/StaticScroller.js +50 -0
- package/dist-ts/components/StaticScroller/StaticScroller.js.map +1 -0
- package/dist-ts/components/StaticScroller/StaticScroller.module.scss +14 -0
- package/dist-ts/components/StaticScroller/index.d.ts +1 -0
- package/dist-ts/components/StaticScroller/index.js +2 -0
- package/dist-ts/components/StaticScroller/index.js.map +1 -0
- package/dist-ts/components/Switch/Switch.d.ts +10 -0
- package/dist-ts/components/Switch/Switch.js +9 -0
- package/dist-ts/components/Switch/Switch.js.map +1 -0
- package/dist-ts/components/Switch/Switch.module.scss +43 -0
- package/dist-ts/components/Switch/index.d.ts +1 -0
- package/dist-ts/components/Switch/index.js +2 -0
- package/dist-ts/components/Switch/index.js.map +1 -0
- package/dist-ts/components/Table/Table.d.ts +19 -0
- package/dist-ts/components/Table/Table.js +46 -0
- package/dist-ts/components/Table/Table.js.map +1 -0
- package/dist-ts/components/Table/Table.module.scss +76 -0
- package/dist-ts/components/Table/index.d.ts +1 -0
- package/dist-ts/components/Table/index.js +2 -0
- package/dist-ts/components/Table/index.js.map +1 -0
- package/dist-ts/components/Tabs/Tabs.d.ts +27 -0
- package/dist-ts/components/Tabs/Tabs.js +52 -0
- package/dist-ts/components/Tabs/Tabs.js.map +1 -0
- package/dist-ts/components/Tabs/Tabs.module.scss +40 -0
- package/dist-ts/components/Tabs/index.d.ts +1 -0
- package/dist-ts/components/Tabs/index.js +2 -0
- package/dist-ts/components/Tabs/index.js.map +1 -0
- package/dist-ts/components/Text/Text.d.ts +17 -0
- package/dist-ts/components/Text/Text.js +16 -0
- package/dist-ts/components/Text/Text.js.map +1 -0
- package/dist-ts/components/Text/Text.module.scss +81 -0
- package/dist-ts/components/Text/index.d.ts +1 -0
- package/dist-ts/components/Text/index.js +2 -0
- package/dist-ts/components/Text/index.js.map +1 -0
- package/dist-ts/components/Transition/MasksFactory/DiagonalReveal.d.ts +1 -0
- package/dist-ts/components/Transition/MasksFactory/DiagonalReveal.js +12 -0
- package/dist-ts/components/Transition/MasksFactory/DiagonalReveal.js.map +1 -0
- package/dist-ts/components/Transition/MasksFactory/DiagonalSquareToBalls.d.ts +5 -0
- package/dist-ts/components/Transition/MasksFactory/DiagonalSquareToBalls.js +30 -0
- package/dist-ts/components/Transition/MasksFactory/DiagonalSquareToBalls.js.map +1 -0
- package/dist-ts/components/Transition/MasksFactory/PhysicsSquares.d.ts +7 -0
- package/dist-ts/components/Transition/MasksFactory/PhysicsSquares.js +80 -0
- package/dist-ts/components/Transition/MasksFactory/PhysicsSquares.js.map +1 -0
- package/dist-ts/components/Transition/MasksFactory/SquareToBalls.d.ts +5 -0
- package/dist-ts/components/Transition/MasksFactory/SquareToBalls.js +22 -0
- package/dist-ts/components/Transition/MasksFactory/SquareToBalls.js.map +1 -0
- package/dist-ts/components/Transition/MasksFactory/utils.d.ts +8 -0
- package/dist-ts/components/Transition/MasksFactory/utils.js +27 -0
- package/dist-ts/components/Transition/MasksFactory/utils.js.map +1 -0
- package/dist-ts/components/Transition/Transition.d.ts +106 -0
- package/dist-ts/components/Transition/Transition.js +292 -0
- package/dist-ts/components/Transition/Transition.js.map +1 -0
- package/dist-ts/components/Transition/Transition.module.scss +211 -0
- package/dist-ts/components/Transition/index.d.ts +1 -0
- package/dist-ts/components/Transition/index.js +2 -0
- package/dist-ts/components/Transition/index.js.map +1 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.ai.md +9 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.d.ts +17 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.js +70 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.js.map +1 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.sample.d.ts +1 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.sample.js +18 -0
- package/dist-ts/components/UncontrolledTransition/UncontrolledTransition.sample.js.map +1 -0
- package/dist-ts/components/UncontrolledTransition/index.d.ts +2 -0
- package/dist-ts/components/UncontrolledTransition/index.js +3 -0
- package/dist-ts/components/UncontrolledTransition/index.js.map +1 -0
- package/dist-ts/components/WalletConnectionWrapper/WalletConnectionWrapper.d.ts +55 -0
- package/dist-ts/components/WalletConnectionWrapper/WalletConnectionWrapper.js +91 -0
- package/dist-ts/components/WalletConnectionWrapper/WalletConnectionWrapper.js.map +1 -0
- package/dist-ts/components/WalletConnectionWrapper/index.d.ts +1 -0
- package/dist-ts/components/WalletConnectionWrapper/index.js +2 -0
- package/dist-ts/components/WalletConnectionWrapper/index.js.map +1 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.d.ts +7 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.js +43 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.js.map +1 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.module.scss +5 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/index.d.ts +1 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/index.js +2 -0
- package/dist-ts/components/utilitary/ScrollAndFocusLock/index.js.map +1 -0
- package/dist-ts/context/AsyncProcess.d.ts +20 -0
- package/dist-ts/context/AsyncProcess.js +43 -0
- package/dist-ts/context/AsyncProcess.js.map +1 -0
- package/dist-ts/context/ContextAsyncControl.d.ts +24 -0
- package/dist-ts/context/ContextAsyncControl.js +50 -0
- package/dist-ts/context/ContextAsyncControl.js.map +1 -0
- package/dist-ts/context/CustomBrowserRouter.d.ts +13 -0
- package/dist-ts/context/CustomBrowserRouter.js +29 -0
- package/dist-ts/context/CustomBrowserRouter.js.map +1 -0
- package/dist-ts/context/OneUIProvider.d.ts +154 -0
- package/dist-ts/context/OneUIProvider.js +113 -0
- package/dist-ts/context/OneUIProvider.js.map +1 -0
- package/dist-ts/hooks/logs/useDependencyChangeDetection.d.ts +1 -0
- package/dist-ts/hooks/logs/useDependencyChangeDetection.js +16 -0
- package/dist-ts/hooks/logs/useDependencyChangeDetection.js.map +1 -0
- package/dist-ts/hooks/logs/useIsMounting.d.ts +1 -0
- package/dist-ts/hooks/logs/useIsMounting.js +7 -0
- package/dist-ts/hooks/logs/useIsMounting.js.map +1 -0
- package/dist-ts/hooks/persistence/useLocalStorage.d.ts +2 -0
- package/dist-ts/hooks/persistence/useLocalStorage.js +44 -0
- package/dist-ts/hooks/persistence/useLocalStorage.js.map +1 -0
- package/dist-ts/hooks/shims/ObjectWatchShim.d.ts +1 -0
- package/dist-ts/hooks/shims/ObjectWatchShim.js +52 -0
- package/dist-ts/hooks/shims/ObjectWatchShim.js.map +1 -0
- package/dist-ts/hooks/ui/useAdaptiveImage.d.ts +7 -0
- package/dist-ts/hooks/ui/useAdaptiveImage.js +36 -0
- package/dist-ts/hooks/ui/useAdaptiveImage.js.map +1 -0
- package/dist-ts/hooks/ui/useAlternating.d.ts +4 -0
- package/dist-ts/hooks/ui/useAlternating.js +21 -0
- package/dist-ts/hooks/ui/useAlternating.js.map +1 -0
- package/dist-ts/hooks/ui/useBreakpoint.d.ts +5 -0
- package/dist-ts/hooks/ui/useBreakpoint.js +19 -0
- package/dist-ts/hooks/ui/useBreakpoint.js.map +1 -0
- package/dist-ts/hooks/ui/useCustomScrollbar.d.ts +8 -0
- package/dist-ts/hooks/ui/useCustomScrollbar.js +17 -0
- package/dist-ts/hooks/ui/useCustomScrollbar.js.map +1 -0
- package/dist-ts/hooks/ui/useCustomScrollbar.module.scss +20 -0
- package/dist-ts/hooks/ui/useEffectIf.d.ts +2 -0
- package/dist-ts/hooks/ui/useEffectIf.js +9 -0
- package/dist-ts/hooks/ui/useEffectIf.js.map +1 -0
- package/dist-ts/hooks/ui/useMouseHover.d.ts +11 -0
- package/dist-ts/hooks/ui/useMouseHover.js +22 -0
- package/dist-ts/hooks/ui/useMouseHover.js.map +1 -0
- package/dist-ts/hooks/ui/usePaginationControls.d.ts +14 -0
- package/dist-ts/hooks/ui/usePaginationControls.js +122 -0
- package/dist-ts/hooks/ui/usePaginationControls.js.map +1 -0
- package/dist-ts/hooks/ui/usePaginationControls.module.scss +16 -0
- package/dist-ts/hooks/ui/useSnapToViewport.d.ts +5 -0
- package/dist-ts/hooks/ui/useSnapToViewport.js +19 -0
- package/dist-ts/hooks/ui/useSnapToViewport.js.map +1 -0
- package/dist-ts/hooks/ui/useSnapToViewport.module.scss +6 -0
- package/dist-ts/hooks/ui/useTilt.d.ts +46 -0
- package/dist-ts/hooks/ui/useTilt.js +131 -0
- package/dist-ts/hooks/ui/useTilt.js.map +1 -0
- package/dist-ts/hooks/ui/useZoomable.d.ts +6 -0
- package/dist-ts/hooks/ui/useZoomable.js +122 -0
- package/dist-ts/hooks/ui/useZoomable.js.map +1 -0
- package/dist-ts/hooks/ui/useZoomable.module.scss +34 -0
- package/dist-ts/hooks/useAsyncControl.ai.md +25 -0
- package/dist-ts/hooks/useAsyncControl.d.ts +32 -0
- package/dist-ts/hooks/useAsyncControl.js +67 -0
- package/dist-ts/hooks/useAsyncControl.js.map +1 -0
- package/dist-ts/hooks/useContainedRepositioning.d.ts +15 -0
- package/dist-ts/hooks/useContainedRepositioning.js +73 -0
- package/dist-ts/hooks/useContainedRepositioning.js.map +1 -0
- package/dist-ts/hooks/useCustomHistory.d.ts +14 -0
- package/dist-ts/hooks/useCustomHistory.js +15 -0
- package/dist-ts/hooks/useCustomHistory.js.map +1 -0
- package/dist-ts/hooks/useElementFit.d.ts +18 -0
- package/dist-ts/hooks/useElementFit.js +57 -0
- package/dist-ts/hooks/useElementFit.js.map +1 -0
- package/dist-ts/hooks/useFirestoreWatch.d.ts +12 -0
- package/dist-ts/hooks/useFirestoreWatch.js +42 -0
- package/dist-ts/hooks/useFirestoreWatch.js.map +1 -0
- package/dist-ts/hooks/useForm.d.ts +16 -0
- package/dist-ts/hooks/useForm.js +27 -0
- package/dist-ts/hooks/useForm.js.map +1 -0
- package/dist-ts/hooks/useFreeze.d.ts +5 -0
- package/dist-ts/hooks/useFreeze.js +12 -0
- package/dist-ts/hooks/useFreeze.js.map +1 -0
- package/dist-ts/hooks/useHero.d.ts +68 -0
- package/dist-ts/hooks/useHero.js +287 -0
- package/dist-ts/hooks/useHero.js.map +1 -0
- package/dist-ts/hooks/useHero.module.scss +41 -0
- package/dist-ts/hooks/useIntersection.d.ts +4 -0
- package/dist-ts/hooks/useIntersection.js +27 -0
- package/dist-ts/hooks/useIntersection.js.map +1 -0
- package/dist-ts/hooks/useMergeRefs.d.ts +9 -0
- package/dist-ts/hooks/useMergeRefs.js +26 -0
- package/dist-ts/hooks/useMergeRefs.js.map +1 -0
- package/dist-ts/hooks/useObserve.d.ts +2 -0
- package/dist-ts/hooks/useObserve.js +15 -0
- package/dist-ts/hooks/useObserve.js.map +1 -0
- package/dist-ts/hooks/usePagination.d.ts +52 -0
- package/dist-ts/hooks/usePagination.js +147 -0
- package/dist-ts/hooks/usePagination.js.map +1 -0
- package/dist-ts/hooks/usePooledOperation.d.ts +15 -0
- package/dist-ts/hooks/usePooledOperation.js +49 -0
- package/dist-ts/hooks/usePooledOperation.js.map +1 -0
- package/dist-ts/hooks/usePooling.d.ts +17 -0
- package/dist-ts/hooks/usePooling.js +38 -0
- package/dist-ts/hooks/usePooling.js.map +1 -0
- package/dist-ts/hooks/useRebound.d.ts +9 -0
- package/dist-ts/hooks/useRebound.js +21 -0
- package/dist-ts/hooks/useRebound.js.map +1 -0
- package/dist-ts/hooks/useShortIntl.ai.md +5 -0
- package/dist-ts/hooks/useShortIntl.d.ts +16 -0
- package/dist-ts/hooks/useShortIntl.js +62 -0
- package/dist-ts/hooks/useShortIntl.js.map +1 -0
- package/dist-ts/hooks/utility/useAsyncMemo.d.ts +13 -0
- package/dist-ts/hooks/utility/useAsyncMemo.js +31 -0
- package/dist-ts/hooks/utility/useAsyncMemo.js.map +1 -0
- package/dist-ts/hooks/utility/useDepChange.d.ts +1 -0
- package/dist-ts/hooks/utility/useDepChange.js +12 -0
- package/dist-ts/hooks/utility/useDepChange.js.map +1 -0
- package/dist-ts/hooks/utility/useEvents.d.ts +9 -0
- package/dist-ts/hooks/utility/useEvents.js +25 -0
- package/dist-ts/hooks/utility/useEvents.js.map +1 -0
- package/dist-ts/hooks/utility/useImmediate.d.ts +4 -0
- package/dist-ts/hooks/utility/useImmediate.js +8 -0
- package/dist-ts/hooks/utility/useImmediate.js.map +1 -0
- package/dist-ts/hooks/utility/useManualInit.d.ts +4 -0
- package/dist-ts/hooks/utility/useManualInit.js +17 -0
- package/dist-ts/hooks/utility/useManualInit.js.map +1 -0
- package/dist-ts/hooks/utility/useModule.d.ts +4 -0
- package/dist-ts/hooks/utility/useModule.js +12 -0
- package/dist-ts/hooks/utility/useModule.js.map +1 -0
- package/dist-ts/hooks/utility/useQuery.d.ts +7 -0
- package/dist-ts/hooks/utility/useQuery.js +11 -0
- package/dist-ts/hooks/utility/useQuery.js.map +1 -0
- package/dist-ts/hooks/utility/useUniqueEffect.d.ts +1 -0
- package/dist-ts/hooks/utility/useUniqueEffect.js +17 -0
- package/dist-ts/hooks/utility/useUniqueEffect.js.map +1 -0
- package/dist-ts/index.d.ts +3 -0
- package/dist-ts/index.js +4 -0
- package/dist-ts/index.js.map +1 -0
- package/dist-ts/models/DebugLogger.d.ts +1 -0
- package/dist-ts/models/DebugLogger.js +7 -0
- package/dist-ts/models/DebugLogger.js.map +1 -0
- package/dist-ts/models/GenericContract.d.ts +79 -0
- package/dist-ts/models/GenericContract.js +14 -0
- package/dist-ts/models/GenericContract.js.map +1 -0
- package/dist-ts/models/Orbs.d.ts +35 -0
- package/dist-ts/models/Orbs.js +61 -0
- package/dist-ts/models/Orbs.js.map +1 -0
- package/dist-ts/storybook/assets/video/txt-reversed.mp4 +0 -0
- package/dist-ts/storybookUtils/index.d.ts +5 -0
- package/dist-ts/storybookUtils/index.js +33 -0
- package/dist-ts/storybookUtils/index.js.map +1 -0
- package/dist-ts/type-utils.d.ts +49 -0
- package/dist-ts/type-utils.js +2 -0
- package/dist-ts/type-utils.js.map +1 -0
- package/dist-ts/types.d.ts +79 -0
- package/dist-ts/types.js +2 -0
- package/dist-ts/types.js.map +1 -0
- package/dist-ts/utils/blockchain.d.ts +4 -0
- package/dist-ts/utils/blockchain.js +39 -0
- package/dist-ts/utils/blockchain.js.map +1 -0
- package/dist-ts/utils/e2e.d.ts +13 -0
- package/dist-ts/utils/e2e.js +25 -0
- package/dist-ts/utils/e2e.js.map +1 -0
- package/dist-ts/utils/flatten.d.ts +4 -0
- package/dist-ts/utils/flatten.js +11 -0
- package/dist-ts/utils/flatten.js.map +1 -0
- package/dist-ts/utils/formatters.d.ts +17 -0
- package/dist-ts/utils/formatters.js +33 -0
- package/dist-ts/utils/formatters.js.map +1 -0
- package/dist-ts/utils/html.utils.d.ts +1 -0
- package/dist-ts/utils/html.utils.js +4 -0
- package/dist-ts/utils/html.utils.js.map +1 -0
- package/dist-ts/utils/ownEvent.d.ts +4 -0
- package/dist-ts/utils/ownEvent.js +10 -0
- package/dist-ts/utils/ownEvent.js.map +1 -0
- package/dist-ts/utils/test.d.ts +5 -0
- package/dist-ts/utils/test.js +11 -0
- package/dist-ts/utils/test.js.map +1 -0
- package/package.json +5 -3
- package/src/utils/e2e.ts +52 -0
- package/tsconfig.prod.json +55 -0
|
@@ -0,0 +1,287 @@
|
|
|
1
|
+
import { useCallback, useEffect, useLayoutEffect, useMemo, useRef, } from "react";
|
|
2
|
+
import ownEvent from "../utils/ownEvent";
|
|
3
|
+
import Styles from "./useHero.module.scss";
|
|
4
|
+
const ID = (id) => `${id}-hero`;
|
|
5
|
+
const viewport = window.visualViewport;
|
|
6
|
+
const DATA_TAG_HERO_COMPONENT = "data-hero-component";
|
|
7
|
+
function triggerDynamicComponents(clone, componentsFromOriginThatWillAppear, origin) {
|
|
8
|
+
const idsThatWillAppear = componentsFromOriginThatWillAppear.map((a) => a.getAttribute(DATA_TAG_HERO_COMPONENT));
|
|
9
|
+
const preexistingComponents = Array.from(clone.querySelectorAll(`[${DATA_TAG_HERO_COMPONENT}]`));
|
|
10
|
+
const removedElements = preexistingComponents.filter((el) => !idsThatWillAppear.includes(el.getAttribute(DATA_TAG_HERO_COMPONENT)));
|
|
11
|
+
for (let elementThatIsBeingRemoved of removedElements) {
|
|
12
|
+
for (let heightKey of ["height", "minHeight", "maxHeight"])
|
|
13
|
+
elementThatIsBeingRemoved.style[heightKey] = `${elementThatIsBeingRemoved.clientHeight}px`;
|
|
14
|
+
}
|
|
15
|
+
setTimeout(() => {
|
|
16
|
+
for (let elementThatIsBeingRemoved of removedElements) {
|
|
17
|
+
for (let heightKey of ["height", "minHeight", "maxHeight"])
|
|
18
|
+
elementThatIsBeingRemoved.style[heightKey] = `0px`;
|
|
19
|
+
elementThatIsBeingRemoved.style.opacity = `0`;
|
|
20
|
+
}
|
|
21
|
+
}, 0);
|
|
22
|
+
for (let componentThatWillAppear of componentsFromOriginThatWillAppear) {
|
|
23
|
+
const alreadyInjectedElement = !!clone.querySelector(`[${DATA_TAG_HERO_COMPONENT}="${componentThatWillAppear.getAttribute(DATA_TAG_HERO_COMPONENT)}"]`);
|
|
24
|
+
if (!alreadyInjectedElement) {
|
|
25
|
+
function recursiveBuildPath(fromElement, pathSuffix = "") {
|
|
26
|
+
if (fromElement === origin)
|
|
27
|
+
return pathSuffix;
|
|
28
|
+
const parent = fromElement.parentElement;
|
|
29
|
+
const parentChilds = Array.from(parent.children);
|
|
30
|
+
const elChildSelector = `:nth-child(${parentChilds.indexOf(fromElement) + 1})`;
|
|
31
|
+
if (fromElement !== origin)
|
|
32
|
+
return recursiveBuildPath(parent, `${elChildSelector}${pathSuffix ? `>${pathSuffix}` : ""}`);
|
|
33
|
+
else
|
|
34
|
+
return pathSuffix;
|
|
35
|
+
}
|
|
36
|
+
const whatIsTheElementPathFromCloneElement = recursiveBuildPath(componentThatWillAppear.parentElement);
|
|
37
|
+
const insertAtIndex = Array.from(componentThatWillAppear.parentElement.children).indexOf(componentThatWillAppear);
|
|
38
|
+
const targetElementClone = componentThatWillAppear.cloneNode(true);
|
|
39
|
+
for (let heightKey of ["height", "minHeight", "maxHeight"])
|
|
40
|
+
targetElementClone.style[heightKey] = "0px";
|
|
41
|
+
const shouldBeInsertedAtElement = whatIsTheElementPathFromCloneElement
|
|
42
|
+
? clone.querySelector(whatIsTheElementPathFromCloneElement)
|
|
43
|
+
: clone;
|
|
44
|
+
const remainingIndexes = Array.from(shouldBeInsertedAtElement.children)
|
|
45
|
+
.map((el, i) => removedElements.includes(el) ? undefined : i)
|
|
46
|
+
.filter((e) => e !== undefined);
|
|
47
|
+
if (insertAtIndex === remainingIndexes.length)
|
|
48
|
+
shouldBeInsertedAtElement.append(targetElementClone);
|
|
49
|
+
else
|
|
50
|
+
shouldBeInsertedAtElement.insertBefore(targetElementClone, shouldBeInsertedAtElement.childNodes.item(remainingIndexes[insertAtIndex]));
|
|
51
|
+
setTimeout(() => {
|
|
52
|
+
for (let heightKey of ["height", "minHeight", "maxHeight"])
|
|
53
|
+
targetElementClone.style[heightKey] = `${componentThatWillAppear.clientHeight}px`;
|
|
54
|
+
}, 0);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
const ALWAYS_TRANSITION = ["top", "left"];
|
|
59
|
+
/**
|
|
60
|
+
* This hook implements the logic for a hero animation between 2 elements sharing the same id
|
|
61
|
+
*/
|
|
62
|
+
export default function useHero(id, options = {
|
|
63
|
+
propsToTransition: [],
|
|
64
|
+
}, events = {}) {
|
|
65
|
+
const { propsToTransition: _p = [], "data-preffix": dataPreffix, repeatable, } = options;
|
|
66
|
+
const propsToTransition = useMemo(() => _p.map((p) => p.replace(/([A-Z])/g, (_, val) => `-${val.toLowerCase()}`)), [_p]);
|
|
67
|
+
const _dataPreffix = dataPreffix ? `-${dataPreffix}` : "";
|
|
68
|
+
const dataProperty = `data${_dataPreffix}-hero`;
|
|
69
|
+
const heroRef = useRef(null);
|
|
70
|
+
useLayoutEffect(() => {
|
|
71
|
+
heroRef.current.setAttribute(dataProperty, id);
|
|
72
|
+
}, [id]);
|
|
73
|
+
const getHerosOnScreen = useCallback(() => {
|
|
74
|
+
const otherElements = Array.from(document.querySelectorAll(`[${dataProperty}="${id}"]`)).filter((el) => el !== heroRef.current);
|
|
75
|
+
return otherElements;
|
|
76
|
+
}, [id]);
|
|
77
|
+
function triggerHeroAnimation() {
|
|
78
|
+
const allPropsToTransition = options.overridePropsToTransition
|
|
79
|
+
? [...ALWAYS_TRANSITION, ...propsToTransition]
|
|
80
|
+
: ["width", "height", ...ALWAYS_TRANSITION, ...propsToTransition];
|
|
81
|
+
const shouldHeroFn = events.onHeroDetect || ((...a) => true);
|
|
82
|
+
const otherElements = getHerosOnScreen().filter((el) => shouldHeroFn(el, heroRef.current));
|
|
83
|
+
const currentElement = heroRef.current;
|
|
84
|
+
const currentElCoordinates = currentElement.getBoundingClientRect();
|
|
85
|
+
if (process.env.NODE_ENV === "development" && otherElements.length > 2)
|
|
86
|
+
console.warn("There are too many elements to transition to, I will transition to the first I find", otherElements);
|
|
87
|
+
const otherElement = otherElements.find((el) => el !== heroRef.current);
|
|
88
|
+
if (otherElement) {
|
|
89
|
+
const [originContainer, targetContainer] = events.onBeforeTransition
|
|
90
|
+
? events.onBeforeTransition(otherElement, heroRef.current)
|
|
91
|
+
: [viewport, viewport];
|
|
92
|
+
const shouldSkip = isElementOutsideContainer(targetContainer, currentElCoordinates) ||
|
|
93
|
+
isElementOutsideContainer(originContainer, otherElement.getBoundingClientRect())
|
|
94
|
+
? (events.onHeroSkip || (() => true))(otherElement, heroRef.current)
|
|
95
|
+
: false;
|
|
96
|
+
if (shouldSkip) {
|
|
97
|
+
events.onHeroSkipped?.();
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
const oldClone = document.querySelector(`[${dataProperty}-clone="${ID(id)}"]`);
|
|
101
|
+
const clone = (oldClone ||
|
|
102
|
+
otherElement.cloneNode(true));
|
|
103
|
+
if (events.onHeroCloned && !oldClone)
|
|
104
|
+
events.onHeroCloned(clone);
|
|
105
|
+
// Clean up thos properties that can cause confusion since it's a clone
|
|
106
|
+
clone.style.visibility = "";
|
|
107
|
+
clone.removeAttribute(dataProperty);
|
|
108
|
+
clone.setAttribute(`${dataProperty}-clone`, ID(id));
|
|
109
|
+
/**
|
|
110
|
+
* If it's repeatable, we should keep the flag that indicates the hero existance
|
|
111
|
+
*/
|
|
112
|
+
if (!repeatable)
|
|
113
|
+
// Since a transition is now triggering from the old element, he cannot be considered for other transitions
|
|
114
|
+
otherElement.removeAttribute(dataProperty);
|
|
115
|
+
function willTheHeroMove(origin, target) {
|
|
116
|
+
return !(origin.top === target.top &&
|
|
117
|
+
origin.left === target.left &&
|
|
118
|
+
origin.width === target.width &&
|
|
119
|
+
origin.height === target.height);
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
*
|
|
123
|
+
* @param el
|
|
124
|
+
* @returns Returns if it will move
|
|
125
|
+
*/
|
|
126
|
+
function setCloneToCoordinatesOf(el) {
|
|
127
|
+
const coordinates = el.getBoundingClientRect();
|
|
128
|
+
const currentCoordinates = clone.getBoundingClientRect();
|
|
129
|
+
const willMove = willTheHeroMove(coordinates, currentCoordinates);
|
|
130
|
+
clone.style.position = "fixed";
|
|
131
|
+
clone.style.top = `${coordinates.top}px`;
|
|
132
|
+
clone.style.left = `${coordinates.left}px`;
|
|
133
|
+
if (allPropsToTransition.includes("width"))
|
|
134
|
+
clone.style.width = `${coordinates.width}px`;
|
|
135
|
+
if (allPropsToTransition.includes("height"))
|
|
136
|
+
clone.style.height = `${coordinates.height}px`;
|
|
137
|
+
return willMove;
|
|
138
|
+
}
|
|
139
|
+
const coordinates = otherElement.getBoundingClientRect();
|
|
140
|
+
const currentCoordinates = heroRef.current.getBoundingClientRect();
|
|
141
|
+
const itWontMove = !willTheHeroMove(coordinates, currentCoordinates);
|
|
142
|
+
if (itWontMove)
|
|
143
|
+
return;
|
|
144
|
+
if (!oldClone) {
|
|
145
|
+
/** Set the clone over the starting element */
|
|
146
|
+
setCloneToCoordinatesOf(otherElement);
|
|
147
|
+
document.body.appendChild(clone);
|
|
148
|
+
}
|
|
149
|
+
heroRef.current.style.visibility = "hidden";
|
|
150
|
+
otherElement.style.visibility = "hidden";
|
|
151
|
+
for (let propToTransition of propsToTransition) {
|
|
152
|
+
clone.style[propToTransition] =
|
|
153
|
+
window.getComputedStyle(otherElement)[propToTransition];
|
|
154
|
+
}
|
|
155
|
+
clone.style.transition = `${allPropsToTransition
|
|
156
|
+
.map((prop) => `${prop.replace(/[A-Z]/g, (sub) => `-${sub.toLowerCase()}`)} var(--animation--speed-fast, 250ms) ease-out`)
|
|
157
|
+
.join(", ")}`;
|
|
158
|
+
setTimeout(() => {
|
|
159
|
+
const elItWillTransitionTo = heroRef.current;
|
|
160
|
+
const cleanup = () => {
|
|
161
|
+
if (events.onHeroEnd)
|
|
162
|
+
events.onHeroEnd();
|
|
163
|
+
if (elItWillTransitionTo) {
|
|
164
|
+
if (repeatable)
|
|
165
|
+
elItWillTransitionTo.setAttribute(dataProperty, id);
|
|
166
|
+
elItWillTransitionTo.style.visibility = "";
|
|
167
|
+
}
|
|
168
|
+
setTimeout(() => {
|
|
169
|
+
clone.remove();
|
|
170
|
+
}, 0);
|
|
171
|
+
};
|
|
172
|
+
triggerDynamicComponents(clone, Array.from(heroRef.current.querySelectorAll(`[${DATA_TAG_HERO_COMPONENT}]`)), currentElement);
|
|
173
|
+
if (events.onHeroStart) {
|
|
174
|
+
events.onHeroStart(clone, otherElement, heroRef.current);
|
|
175
|
+
}
|
|
176
|
+
if (!elItWillTransitionTo) {
|
|
177
|
+
cleanup();
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
/** Set the clone over the new position */
|
|
181
|
+
const willMove = setCloneToCoordinatesOf(elItWillTransitionTo);
|
|
182
|
+
if (!willMove)
|
|
183
|
+
cleanup();
|
|
184
|
+
else {
|
|
185
|
+
for (let propToTransition of propsToTransition)
|
|
186
|
+
clone.style[propToTransition] =
|
|
187
|
+
window.getComputedStyle(elItWillTransitionTo)[propToTransition];
|
|
188
|
+
let initialOffset;
|
|
189
|
+
const s = ({ target }) => {
|
|
190
|
+
const d = target;
|
|
191
|
+
if (d.contains(elItWillTransitionTo)) {
|
|
192
|
+
if (initialOffset === undefined)
|
|
193
|
+
initialOffset = d.scrollTop;
|
|
194
|
+
else
|
|
195
|
+
clone.style.marginTop = `${-(d.scrollTop - initialOffset)}px`;
|
|
196
|
+
}
|
|
197
|
+
};
|
|
198
|
+
const transitionEndCb = ownEvent(({ target, currentTarget }) => {
|
|
199
|
+
if (target === currentTarget)
|
|
200
|
+
cleanup();
|
|
201
|
+
document.removeEventListener("scroll", s, true);
|
|
202
|
+
});
|
|
203
|
+
document.addEventListener("scroll", s, true);
|
|
204
|
+
clone.addEventListener("transitionend", transitionEndCb);
|
|
205
|
+
clone.addEventListener("transitionstart", () => {
|
|
206
|
+
const onCancelCb = ownEvent((e) => {
|
|
207
|
+
clone.removeEventListener("transitionend", transitionEndCb);
|
|
208
|
+
clone.removeEventListener("transitioncancel", onCancelCb);
|
|
209
|
+
});
|
|
210
|
+
clone.addEventListener("transitioncancel", onCancelCb);
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
}, 0);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
useEffect(() => {
|
|
217
|
+
triggerHeroAnimation();
|
|
218
|
+
}, []);
|
|
219
|
+
return {
|
|
220
|
+
heroRef,
|
|
221
|
+
getHerosOnScreen,
|
|
222
|
+
trigger: triggerHeroAnimation,
|
|
223
|
+
heroComponentRef: (componentId) => (elRef) => {
|
|
224
|
+
if (elRef) {
|
|
225
|
+
elRef.setAttribute(DATA_TAG_HERO_COMPONENT, componentId);
|
|
226
|
+
elRef.classList.add(Styles.component);
|
|
227
|
+
}
|
|
228
|
+
},
|
|
229
|
+
};
|
|
230
|
+
}
|
|
231
|
+
function isElementOutsideViewport(coordinates) {
|
|
232
|
+
const elementOverflowsViewport = coordinates.left >= viewport.width || coordinates.top >= viewport.height;
|
|
233
|
+
const elementUnderflowsViewport = coordinates.left <= -coordinates.width ||
|
|
234
|
+
coordinates.top <= -coordinates.height;
|
|
235
|
+
return elementOverflowsViewport || elementUnderflowsViewport;
|
|
236
|
+
}
|
|
237
|
+
function isElementOutsideContainer(container, coordinates) {
|
|
238
|
+
if (container instanceof VisualViewport) {
|
|
239
|
+
return isElementOutsideViewport(coordinates);
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
const containerBounds = container.getBoundingClientRect();
|
|
243
|
+
const isContainerOutsideViewport = isElementOutsideViewport(containerBounds);
|
|
244
|
+
if (isContainerOutsideViewport)
|
|
245
|
+
return true;
|
|
246
|
+
const elementOverflowsViewport = coordinates.left >= containerBounds.left + containerBounds.width ||
|
|
247
|
+
coordinates.top >= containerBounds.top + containerBounds.height;
|
|
248
|
+
const elementUnderflowsViewport = containerBounds.left - coordinates.left >= coordinates.width ||
|
|
249
|
+
containerBounds.top - coordinates.top >= coordinates.height;
|
|
250
|
+
return elementUnderflowsViewport || elementOverflowsViewport;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
function centerPoint(rect) {
|
|
254
|
+
return [rect.left + rect.width / 2, rect.top + rect.height / 2];
|
|
255
|
+
}
|
|
256
|
+
const angle = (pointA, pointB) => Number((Math.atan2(pointA[1] - pointB[1], pointA[0] - pointB[0]) *
|
|
257
|
+
(179.08 / Math.PI)).toFixed(5));
|
|
258
|
+
export const TRANSITION_FACTORY = {
|
|
259
|
+
ACCELERATION: (events) => ({
|
|
260
|
+
...events,
|
|
261
|
+
onHeroStart(clone, origin, target) {
|
|
262
|
+
if (events?.onHeroStart)
|
|
263
|
+
events.onHeroStart(clone, origin, target);
|
|
264
|
+
clone.classList.add(Styles.acceleration);
|
|
265
|
+
const centerPointOrigin = centerPoint(origin.getBoundingClientRect());
|
|
266
|
+
const centerPointDestination = centerPoint(target.getBoundingClientRect());
|
|
267
|
+
const angleBetweenElements = angle(centerPointOrigin, centerPointDestination);
|
|
268
|
+
const vectorX = Math.sin(angleBetweenElements);
|
|
269
|
+
const vectorY = Math.cos(angleBetweenElements);
|
|
270
|
+
const rotateY = (10 * vectorY).toFixed(0);
|
|
271
|
+
const originX = (vectorY + 1) * 50;
|
|
272
|
+
const rotateX = -(10 * vectorX).toFixed(0);
|
|
273
|
+
const originY = (vectorX + 1) * 50;
|
|
274
|
+
clone.style.setProperty("--stage-1", `rotateY(${rotateY}deg) rotateX(${-rotateX}deg)`);
|
|
275
|
+
clone.style.setProperty("--stage-2", `rotateY(${-rotateY * 0.3}deg) rotateX(${rotateX * 0.3}deg)`);
|
|
276
|
+
clone.style.setProperty("--origin-1", `${originX}% ${originY}%`);
|
|
277
|
+
clone.style.setProperty("--origin-2", `${100 - originX}% ${100 - originY}%`);
|
|
278
|
+
document.body.style.perspective = "100vw";
|
|
279
|
+
},
|
|
280
|
+
onHeroEnd() {
|
|
281
|
+
if (events?.onHeroEnd)
|
|
282
|
+
events.onHeroEnd();
|
|
283
|
+
document.body.style.perspective = "";
|
|
284
|
+
},
|
|
285
|
+
}),
|
|
286
|
+
};
|
|
287
|
+
//# sourceMappingURL=useHero.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useHero.js","sourceRoot":"","sources":["../../src/hooks/useHero.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
@import "../assets/styles/index.scss";
|
|
2
|
+
|
|
3
|
+
$timing: cubic-bezier(0.5, -0.45, 0.44, 1.37);
|
|
4
|
+
// $timing: cubic-bezier(0.73, -0.49, 0.16, 1.4);
|
|
5
|
+
|
|
6
|
+
.acceleration {
|
|
7
|
+
--animation--speed-fast: 1s;
|
|
8
|
+
animation-name: acceleration;
|
|
9
|
+
animation-duration: var(--animation--speed-fast);
|
|
10
|
+
animation-timing-function: $timing;
|
|
11
|
+
transition-timing-function: $timing !important;
|
|
12
|
+
transform-origin: var(--origin-1);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
@keyframes acceleration {
|
|
16
|
+
0% {
|
|
17
|
+
transform: rotateY(0deg);
|
|
18
|
+
}
|
|
19
|
+
10% {
|
|
20
|
+
transform-origin: var(--origin-1);
|
|
21
|
+
transform: var(--stage-1);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
70% {
|
|
25
|
+
transform: var(--stage-1);
|
|
26
|
+
transform-origin: var(--origin-1);
|
|
27
|
+
}
|
|
28
|
+
85% {
|
|
29
|
+
transform-origin: var(--origin-2);
|
|
30
|
+
transform: var(--stage-2);
|
|
31
|
+
}
|
|
32
|
+
100% {
|
|
33
|
+
transform: rotateY(0deg);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.component:not([data-hero-clone]) {
|
|
38
|
+
transition: height $fast linear, opacity $fast linear, min-height $fast linear,
|
|
39
|
+
max-height $fast linear !important;
|
|
40
|
+
overflow: hidden;
|
|
41
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { useMemo, useRef } from "react";
|
|
2
|
+
export default function useIntersection() {
|
|
3
|
+
const { current: targetMap } = useRef([]);
|
|
4
|
+
const { current: observer } = useRef(("IntersectionObserver" in window) ? new IntersectionObserver((els) => {
|
|
5
|
+
els.forEach((e, i) => {
|
|
6
|
+
const result = targetMap.find((el) => el[0] === e.target);
|
|
7
|
+
if (result && e.isIntersecting) {
|
|
8
|
+
result[1]();
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
}) : null);
|
|
12
|
+
return useMemo(() => {
|
|
13
|
+
return {
|
|
14
|
+
observe: (e, cb) => {
|
|
15
|
+
targetMap.push([e, cb]);
|
|
16
|
+
if (observer)
|
|
17
|
+
observer.observe(e);
|
|
18
|
+
},
|
|
19
|
+
unobserve: (e) => {
|
|
20
|
+
if (observer)
|
|
21
|
+
observer.unobserve(e);
|
|
22
|
+
targetMap.splice(targetMap.findIndex((el) => el[0] === e), 1);
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
}, []);
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=useIntersection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useIntersection.js","sourceRoot":"","sources":["../../src/hooks/useIntersection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAExC,MAAM,CAAC,OAAO,UAAU,eAAe;IACrC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,CAAmC,EAAE,CAAC,CAAC;IAC5E,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,MAAM,CAClC,CAAC,sBAAsB,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,oBAAoB,CAAC,CAAC,GAAG,EAAE,EAAE;QACpE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACnB,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAa,CAAC,CAAC;YACjE,IAAI,MAAM,IAAI,CAAC,CAAC,cAAc,EAAE,CAAC;gBAC/B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;YACd,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CACV,CAAC;IACF,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,OAAO;YACL,OAAO,EAAE,CAAC,CAAmB,EAAE,EAAc,EAAE,EAAE;gBAC/C,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;gBACxB,IAAI,QAAQ;oBACZ,QAAQ,CAAC,OAAO,CAAC,CAAQ,CAAC,CAAC;YAC7B,CAAC;YACD,SAAS,EAAE,CAAC,CAAmB,EAAE,EAAE;gBACjC,IAAI,QAAQ;oBACZ,QAAQ,CAAC,SAAS,CAAC,CAAQ,CAAC,CAAC;gBAC7B,SAAS,CAAC,MAAM,CACd,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EACxC,CAAC,CACF,CAAC;YACJ,CAAC;SACF,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;AACT,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { useRef } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* This function exists so we can work with multiple refs as a single one
|
|
4
|
+
*/
|
|
5
|
+
export default function useMergeRefs<T extends ReturnType<typeof useRef>>(mainRef: T, ...otherRefs: T[]): T;
|
|
6
|
+
/**
|
|
7
|
+
* This function exists so we can work with multiple refs as a single one, almost immediatly
|
|
8
|
+
*/
|
|
9
|
+
export declare function useMergeRefsFunc<T extends ReturnType<typeof useRef> | ((ref: any) => void)>(mainRef: T, ...otherRefs: T[]): (providedRef: any) => void;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useLayoutEffect } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* This function exists so we can work with multiple refs as a single one
|
|
4
|
+
*/
|
|
5
|
+
export default function useMergeRefs(mainRef, ...otherRefs) {
|
|
6
|
+
useLayoutEffect(() => {
|
|
7
|
+
for (let ref of otherRefs)
|
|
8
|
+
ref.current = mainRef.current;
|
|
9
|
+
}, []);
|
|
10
|
+
return mainRef;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* This function exists so we can work with multiple refs as a single one, almost immediatly
|
|
14
|
+
*/
|
|
15
|
+
export function useMergeRefsFunc(mainRef, ...otherRefs) {
|
|
16
|
+
return (providedRef) => {
|
|
17
|
+
if (providedRef)
|
|
18
|
+
for (let ref of [mainRef, ...otherRefs]) {
|
|
19
|
+
if (typeof ref === "function")
|
|
20
|
+
ref(providedRef);
|
|
21
|
+
else
|
|
22
|
+
ref.current = providedRef;
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=useMergeRefs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useMergeRefs.js","sourceRoot":"","sources":["../../src/hooks/useMergeRefs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,eAAe,EAAU,MAAM,OAAO,CAAC;AAE3D;;GAEG;AACH,MAAM,CAAC,OAAO,UAAU,YAAY,CAClC,OAAU,EACV,GAAG,SAAc;IAEjB,eAAe,CAAC,GAAG,EAAE;QACnB,KAAK,IAAI,GAAG,IAAI,SAAS;YAAE,GAAG,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAC3D,CAAC,EAAE,EAAE,CAAC,CAAC;IACP,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAE9B,OAAU,EAAE,GAAG,SAAc;IAC7B,OAAO,CAAC,WAAgB,EAAE,EAAE;QAC1B,IAAI,WAAW;YACb,KAAK,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC,EAAE,CAAC;gBACxC,IAAI,OAAO,GAAG,KAAK,UAAU;oBAAE,GAAG,CAAC,WAAW,CAAC,CAAC;;oBAC3C,GAAG,CAAC,OAAO,GAAG,WAAW,CAAC;YACjC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { useLayoutEffect, useState } from "react";
|
|
2
|
+
import "./shims/ObjectWatchShim.js";
|
|
3
|
+
export default function useObserve(toObserve, keysToObserve) {
|
|
4
|
+
const [_, ss] = useState(0);
|
|
5
|
+
useLayoutEffect(() => {
|
|
6
|
+
const arr = Array.isArray(toObserve) ? toObserve : [toObserve];
|
|
7
|
+
const unwatchers = arr.map(object => object.watch(keysToObserve, () => {
|
|
8
|
+
ss((p) => {
|
|
9
|
+
return p + 1;
|
|
10
|
+
});
|
|
11
|
+
}));
|
|
12
|
+
return () => unwatchers.forEach(unwatch => unwatch());
|
|
13
|
+
}, [toObserve]);
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=useObserve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useObserve.js","sourceRoot":"","sources":["../../src/hooks/useObserve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,eAAe,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC7D,OAAO,4BAA4B,CAAC;AAOpC,MAAM,CAAC,OAAO,UAAU,UAAU,CAChC,SAAkB,EAClB,aAA0B;IAE1B,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC5B,eAAe,CAAC,GAAG,EAAE;QACnB,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;QAC9D,MAAM,UAAU,GAAG,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAE,MAAiB,CAAC,KAAK,CAAC,aAAoB,EAAE,GAAG,EAAE;YACvF,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;gBACP,OAAO,CAAC,GAAG,CAAC,CAAA;YACd,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC,CAAA;QAEH,OAAO,GAAG,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;IACvD,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import useAsyncControl from "./useAsyncControl";
|
|
3
|
+
type UpdateEvent<I extends any> = {
|
|
4
|
+
finished: boolean;
|
|
5
|
+
items: I[];
|
|
6
|
+
totalItems: number;
|
|
7
|
+
};
|
|
8
|
+
export default function usePagination<I extends any>(request: (page: number, pageSize: number | "all", currItems?: I[]) => Promise<UpdateEvent<I>>, paginationId?: object | any[] | (() => string), startingItems?: I[]): Paginable<I>;
|
|
9
|
+
export type Paginable<I extends any, E extends any = any> = {
|
|
10
|
+
updateItems: (cb: (prevItems?: I) => UpdateEvent<I>["items"]) => void;
|
|
11
|
+
getNextPage: (pageSize: number) => void;
|
|
12
|
+
refreshCurrentPage: (pageSize: number) => void;
|
|
13
|
+
getPage: (page: number, pageSize: number) => void;
|
|
14
|
+
getAll: () => void;
|
|
15
|
+
totalItems: () => number | undefined;
|
|
16
|
+
loading: boolean;
|
|
17
|
+
error: E | Error | undefined;
|
|
18
|
+
items: I[] | undefined;
|
|
19
|
+
setError: ReturnType<typeof useAsyncControl>["setError"];
|
|
20
|
+
id: () => string;
|
|
21
|
+
};
|
|
22
|
+
export type LocalPaginable<I extends any, E extends any = any> = Paginable<I, E> & {
|
|
23
|
+
src: I;
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur
|
|
27
|
+
*/
|
|
28
|
+
export declare function useContainerPagination(cb: (pageSize: number) => void, pageSize: number, direction?: "h" | "v"): {
|
|
29
|
+
scrollableRef: import("react").RefObject<HTMLDivElement | undefined>;
|
|
30
|
+
customOptionsRef: import("react").RefObject<(() => {
|
|
31
|
+
offsetBottom?: number;
|
|
32
|
+
offsetLeft?: number;
|
|
33
|
+
}) | undefined>;
|
|
34
|
+
};
|
|
35
|
+
/**
|
|
36
|
+
* This function receives an amount of local instances and paginates it
|
|
37
|
+
*/
|
|
38
|
+
export declare function useLocalPagination<L>(items: L[] | undefined): {
|
|
39
|
+
loading: boolean;
|
|
40
|
+
src: L[] | undefined;
|
|
41
|
+
updateItems: (cb: (prevItems?: L | undefined) => L[]) => void;
|
|
42
|
+
getNextPage: (pageSize: number) => void;
|
|
43
|
+
refreshCurrentPage: (pageSize: number) => void;
|
|
44
|
+
getPage: (page: number, pageSize: number) => void;
|
|
45
|
+
getAll: () => void;
|
|
46
|
+
totalItems: () => number | undefined;
|
|
47
|
+
error: any;
|
|
48
|
+
items: L[] | undefined;
|
|
49
|
+
setError: import("react").Dispatch<unknown>;
|
|
50
|
+
id: () => string;
|
|
51
|
+
};
|
|
52
|
+
export {};
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
import { useCallback, useEffect, useMemo, useRef, useState, } from "react";
|
|
2
|
+
import useAsyncControl from "./useAsyncControl";
|
|
3
|
+
import throttle from "lodash/throttle";
|
|
4
|
+
export default function usePagination(request, paginationId = () => "default", startingItems) {
|
|
5
|
+
const paginationDataRef = useRef({});
|
|
6
|
+
const { current: paginationData } = paginationDataRef;
|
|
7
|
+
const paginationIdFactory = useMemo(() => {
|
|
8
|
+
if (typeof paginationId === "object") {
|
|
9
|
+
const randId = Math.random();
|
|
10
|
+
return () => randId.toString();
|
|
11
|
+
}
|
|
12
|
+
else
|
|
13
|
+
return paginationId;
|
|
14
|
+
}, Array.isArray(paginationId) ? paginationId : [paginationId]);
|
|
15
|
+
const [items, setItems] = useState();
|
|
16
|
+
const [id, setId] = useState(() => paginationIdFactory());
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
setId(paginationIdFactory());
|
|
19
|
+
if (startingItems)
|
|
20
|
+
setItems([paginationIdFactory(), startingItems]);
|
|
21
|
+
else
|
|
22
|
+
setItems(undefined);
|
|
23
|
+
}, [paginationIdFactory()]);
|
|
24
|
+
const { process, ...control } = useAsyncControl();
|
|
25
|
+
function updateItems(cb) {
|
|
26
|
+
setItems((prev) => [prev[0], cb()]);
|
|
27
|
+
}
|
|
28
|
+
const derivateCurrentPage = (pageSize) => {
|
|
29
|
+
if (items === undefined)
|
|
30
|
+
return 0;
|
|
31
|
+
const currentPage = Math.floor((items?.[1].length ?? 0) / pageSize) - 1;
|
|
32
|
+
return currentPage;
|
|
33
|
+
};
|
|
34
|
+
const _requestPage = useCallback(function (page, pageSize) {
|
|
35
|
+
const id = paginationIdFactory();
|
|
36
|
+
if (paginationData[id]?.finished)
|
|
37
|
+
return;
|
|
38
|
+
process(async () => {
|
|
39
|
+
const result = await request(page, pageSize, items?.[0] === id && page !== 0
|
|
40
|
+
? pageSize === "all"
|
|
41
|
+
? undefined
|
|
42
|
+
: items?.[1].slice(0, page * pageSize)
|
|
43
|
+
: undefined);
|
|
44
|
+
paginationData[id] = {
|
|
45
|
+
finished: result.finished,
|
|
46
|
+
totalItems: result.totalItems,
|
|
47
|
+
};
|
|
48
|
+
setItems((prev) => {
|
|
49
|
+
if (page === 0)
|
|
50
|
+
return [id, result.items];
|
|
51
|
+
else if (!prev || id === prev[0])
|
|
52
|
+
return [id, result.items];
|
|
53
|
+
return prev;
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
}, [items, request]);
|
|
57
|
+
return {
|
|
58
|
+
updateItems,
|
|
59
|
+
getNextPage: (pageSize) => {
|
|
60
|
+
_requestPage(derivateCurrentPage(pageSize) + 1, pageSize);
|
|
61
|
+
},
|
|
62
|
+
getPage: _requestPage,
|
|
63
|
+
getAll: () => {
|
|
64
|
+
_requestPage(0, "all");
|
|
65
|
+
},
|
|
66
|
+
refreshCurrentPage: (pageSize) => {
|
|
67
|
+
_requestPage(derivateCurrentPage(pageSize), pageSize);
|
|
68
|
+
},
|
|
69
|
+
totalItems: () => paginationData[paginationIdFactory()]?.totalItems,
|
|
70
|
+
id: () => id,
|
|
71
|
+
loading: control.loading,
|
|
72
|
+
error: control.error,
|
|
73
|
+
items: items?.[1],
|
|
74
|
+
setError: control.setError,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur
|
|
79
|
+
*/
|
|
80
|
+
export function useContainerPagination(cb, pageSize, direction = "v") {
|
|
81
|
+
const scrollableRef = useRef(undefined);
|
|
82
|
+
const customOptionsRef = useRef(undefined);
|
|
83
|
+
useEffect(() => {
|
|
84
|
+
const el = scrollableRef.current;
|
|
85
|
+
const scrollElement = el.scrollingElement || el;
|
|
86
|
+
const calculateIfReachedLimit = throttle((e) => {
|
|
87
|
+
if (e.target !== el)
|
|
88
|
+
return;
|
|
89
|
+
const { offsetBottom = 0, offsetLeft = 0 } = customOptionsRef.current?.() || {};
|
|
90
|
+
const offsetLimit = direction === "v"
|
|
91
|
+
? scrollElement.scrollHeight -
|
|
92
|
+
offsetBottom -
|
|
93
|
+
scrollElement.clientHeight * 0.6
|
|
94
|
+
: scrollElement.scrollWidth -
|
|
95
|
+
offsetLeft -
|
|
96
|
+
scrollElement.clientWidth * 0.6;
|
|
97
|
+
const offset = direction === "v"
|
|
98
|
+
? scrollElement.clientHeight + scrollElement.scrollTop
|
|
99
|
+
: scrollElement.clientWidth + scrollElement.scrollLeft;
|
|
100
|
+
if (offset >= offsetLimit) {
|
|
101
|
+
cb(pageSize);
|
|
102
|
+
}
|
|
103
|
+
}, 250, {
|
|
104
|
+
leading: false,
|
|
105
|
+
trailing: true,
|
|
106
|
+
});
|
|
107
|
+
el.addEventListener("scroll", calculateIfReachedLimit, {
|
|
108
|
+
passive: true,
|
|
109
|
+
});
|
|
110
|
+
return () => el.removeEventListener("scroll", calculateIfReachedLimit);
|
|
111
|
+
}, [cb, pageSize]);
|
|
112
|
+
return {
|
|
113
|
+
scrollableRef,
|
|
114
|
+
customOptionsRef,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* This function receives an amount of local instances and paginates it
|
|
119
|
+
*/
|
|
120
|
+
export function useLocalPagination(items) {
|
|
121
|
+
const instanceID = useMemo(() => Date.now(), [items]);
|
|
122
|
+
const cb = useCallback((page, pageSize, currItems = []) => {
|
|
123
|
+
if (!items)
|
|
124
|
+
return Promise.resolve({
|
|
125
|
+
finished: false,
|
|
126
|
+
totalItems: 0,
|
|
127
|
+
items: [],
|
|
128
|
+
});
|
|
129
|
+
if (pageSize === "all")
|
|
130
|
+
pageSize = items.length;
|
|
131
|
+
const from = pageSize * page;
|
|
132
|
+
const newArray = [...currItems, ...items.slice(from, from + pageSize)];
|
|
133
|
+
return Promise.resolve({
|
|
134
|
+
finished: newArray.length === items.length,
|
|
135
|
+
totalItems: items.length,
|
|
136
|
+
items: newArray,
|
|
137
|
+
});
|
|
138
|
+
}, [items]);
|
|
139
|
+
const pagination = usePagination(cb, () => `${instanceID}`);
|
|
140
|
+
const pagSrc = useMemo(() => items, [pagination.items]);
|
|
141
|
+
return {
|
|
142
|
+
...pagination,
|
|
143
|
+
loading: items === undefined,
|
|
144
|
+
src: pagSrc,
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=usePagination.js.map
|