@koine/react 1.0.10 → 1.0.11
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/Alert/Alert.d.ts +5 -0
- package/Alert/Alert.js +16 -0
- package/Alert/index.d.ts +1 -0
- package/Alert/index.js +1 -0
- package/Alert/package.json +6 -0
- package/Animations/Reveal.d.ts +4 -0
- package/Animations/Reveal.js +15 -0
- package/Animations/Underline.d.ts +1 -0
- package/Animations/Underline.js +15 -0
- package/Animations/index.d.ts +3 -0
- package/Animations/index.js +3 -0
- package/Animations/package.json +6 -0
- package/Animations/useReveal.d.ts +33 -0
- package/Animations/useReveal.js +70 -0
- package/Autocomplete/AutocompleteDownshift.d.ts +1 -0
- package/Autocomplete/AutocompleteDownshift.js +158 -0
- package/Autocomplete/AutocompleteDownshiftMultiselect.d.ts +1 -0
- package/Autocomplete/AutocompleteDownshiftMultiselect.js +353 -0
- package/Autocomplete/AutocompleteMui.d.ts +47 -0
- package/Autocomplete/AutocompleteMui.js +177 -0
- package/Autocomplete/AutocompleteReach.d.ts +1 -0
- package/Autocomplete/AutocompleteReach.js +112 -0
- package/Autocomplete/components.d.ts +21 -0
- package/Autocomplete/components.js +89 -0
- package/Autocomplete/helpers.d.ts +3 -0
- package/Autocomplete/helpers.js +28 -0
- package/Autocomplete/index.d.ts +2 -0
- package/Autocomplete/index.js +3 -0
- package/Autocomplete/package.json +6 -0
- package/Bg/BgColor.d.ts +36 -0
- package/Bg/BgColor.js +31 -0
- package/Bg/BgPhoto.d.ts +13 -0
- package/Bg/BgPhoto.js +59 -0
- package/Bg/BgSvg.d.ts +7 -0
- package/Bg/BgSvg.js +15 -0
- package/Bg/index.d.ts +3 -0
- package/Bg/index.js +3 -0
- package/Bg/package.json +6 -0
- package/Breadcrumbs/Breadcrumbs.d.ts +13 -0
- package/Breadcrumbs/Breadcrumbs.js +67 -0
- package/Breadcrumbs/index.d.ts +1 -0
- package/Breadcrumbs/index.js +1 -0
- package/Breadcrumbs/package.json +6 -0
- package/Buttons/Button.d.ts +18 -0
- package/Buttons/Button.js +79 -0
- package/Buttons/ButtonComposite.d.ts +23 -0
- package/Buttons/ButtonComposite.js +49 -0
- package/Buttons/ButtonFab.d.ts +7 -0
- package/Buttons/ButtonFab.js +8 -0
- package/Buttons/ButtonLink.d.ts +8 -0
- package/Buttons/ButtonLink.js +10 -0
- package/Buttons/IconButton.d.ts +11 -0
- package/Buttons/IconButton.js +19 -0
- package/Buttons/index.d.ts +5 -0
- package/Buttons/index.js +5 -0
- package/Buttons/package.json +6 -0
- package/Calendar/CalendarDaygridCell.d.ts +36 -0
- package/Calendar/CalendarDaygridCell.js +51 -0
- package/Calendar/CalendarDaygridNav.d.ts +27 -0
- package/Calendar/CalendarDaygridNav.js +22 -0
- package/Calendar/CalendarDaygridTable.d.ts +25 -0
- package/Calendar/CalendarDaygridTable.js +55 -0
- package/Calendar/CalendarLegend.d.ts +19 -0
- package/Calendar/CalendarLegend.js +11 -0
- package/Calendar/calendar-api-google.d.ts +18 -0
- package/Calendar/calendar-api-google.js +94 -0
- package/Calendar/index.d.ts +6 -0
- package/Calendar/index.js +6 -0
- package/Calendar/package.json +6 -0
- package/Calendar/types.d.ts +81 -0
- package/Calendar/types.js +1 -0
- package/Calendar/useCalendar.d.ts +49 -0
- package/Calendar/useCalendar.js +182 -0
- package/Calendar/utils.d.ts +11 -0
- package/Calendar/utils.js +203 -0
- package/Carousel/Carousel.d.ts +1 -0
- package/Carousel/Carousel.js +378 -0
- package/Carousel/CarouselCss.d.ts +47 -0
- package/Carousel/CarouselCss.js +37 -0
- package/Carousel/index.d.ts +1 -0
- package/Carousel/index.js +1 -0
- package/Carousel/package.json +6 -0
- package/Collapsable/Collapsable.d.ts +1 -0
- package/Collapsable/Collapsable.js +1 -0
- package/Collapsable/CollapsableReach.d.ts +6 -0
- package/Collapsable/CollapsableReach.js +253 -0
- package/Collapsable/index.d.ts +1 -0
- package/Collapsable/index.js +2 -0
- package/Collapsable/package.json +6 -0
- package/Debug/Debug.d.ts +4 -0
- package/Debug/Debug.js +21 -0
- package/Debug/index.d.ts +1 -0
- package/Debug/index.js +1 -0
- package/Debug/package.json +6 -0
- package/Details/Details.d.ts +114 -0
- package/Details/Details.js +62 -0
- package/Details/index.d.ts +1 -0
- package/Details/index.js +1 -0
- package/Details/package.json +6 -0
- package/Dialog/DialogMui.d.ts +139 -0
- package/Dialog/DialogMui.js +78 -0
- package/Dialog/css/bare.d.ts +145 -0
- package/Dialog/css/bare.js +19 -0
- package/Dialog/index.d.ts +2 -0
- package/Dialog/index.js +1 -0
- package/Dialog/m/bare.d.ts +56 -0
- package/Dialog/m/bare.js +48 -0
- package/Dialog/m/basic.d.ts +4 -0
- package/Dialog/m/basic.js +31 -0
- package/Dialog/m/index.d.ts +2 -0
- package/Dialog/m/index.js +4 -0
- package/Dialog/m/package.json +6 -0
- package/Dialog/package.json +6 -0
- package/Dialog/sc/bare.d.ts +105 -0
- package/Dialog/sc/bare.js +61 -0
- package/Dialog/sc/framer.d.ts +80 -0
- package/Dialog/sc/framer.js +16 -0
- package/Dialog/sc/framerMaterial.d.ts +79 -0
- package/Dialog/sc/framerMaterial.js +16 -0
- package/Dialog/sc/material.d.ts +94 -0
- package/Dialog/sc/material.js +41 -0
- package/Dialog/tw/bare.d.ts +196 -0
- package/Dialog/tw/bare.js +36 -0
- package/Dialog/tw/elegant.d.ts +244 -0
- package/Dialog/tw/elegant.js +18 -0
- package/Dialog/tw/framer.d.ts +112 -0
- package/Dialog/tw/framer.js +16 -0
- package/Dialog/tw/framerMaterial.d.ts +167 -0
- package/Dialog/tw/framerMaterial.js +16 -0
- package/Dialog/tw/material.d.ts +244 -0
- package/Dialog/tw/material.js +18 -0
- package/Editor/Editor--tiptap.d.ts +9 -0
- package/Editor/Editor--tiptap.js +23 -0
- package/Editor/components.d.ts +7 -0
- package/Editor/components.js +28 -0
- package/Editor/index.d.ts +1 -0
- package/Editor/index.js +1 -0
- package/Editor/package.json +6 -0
- package/Favicon/FaviconTags.d.ts +18 -0
- package/Favicon/FaviconTags.js +14 -0
- package/Favicon/index.d.ts +1 -0
- package/Favicon/index.js +1 -0
- package/Favicon/package.json +6 -0
- package/Form/Form.d.ts +111 -0
- package/Form/Form.js +59 -0
- package/Form/index.d.ts +1 -0
- package/Form/index.js +1 -0
- package/Form/package.json +6 -0
- package/Form/sc/bare.d.ts +33 -0
- package/Form/sc/bare.js +29 -0
- package/Forms/Checkbox/Checkbox.d.ts +11 -0
- package/Forms/Checkbox/Checkbox.js +24 -0
- package/Forms/Checkbox/index.d.ts +1 -0
- package/Forms/Checkbox/index.js +1 -0
- package/Forms/Checkbox/package.json +6 -0
- package/Forms/Feedback/Feedback.d.ts +5 -0
- package/Forms/Feedback/Feedback.js +10 -0
- package/Forms/Feedback/index.d.ts +1 -0
- package/Forms/Feedback/index.js +1 -0
- package/Forms/Feedback/package.json +6 -0
- package/Forms/Field/Field.d.ts +15 -0
- package/Forms/Field/Field.js +59 -0
- package/Forms/Field/FieldControl.d.ts +26 -0
- package/Forms/Field/FieldControl.js +43 -0
- package/Forms/Field/FieldHint.d.ts +1 -0
- package/Forms/Field/FieldHint.js +6 -0
- package/Forms/Field/index.d.ts +2 -0
- package/Forms/Field/index.js +2 -0
- package/Forms/Field/package.json +6 -0
- package/Forms/Input/Input.d.ts +9 -0
- package/Forms/Input/Input.js +23 -0
- package/Forms/Input/index.d.ts +1 -0
- package/Forms/Input/index.js +1 -0
- package/Forms/Input/package.json +6 -0
- package/Forms/InputGroup/InputGroup.d.ts +13 -0
- package/Forms/InputGroup/InputGroup.js +42 -0
- package/Forms/InputGroup/index.d.ts +1 -0
- package/Forms/InputGroup/index.js +1 -0
- package/Forms/InputGroup/package.json +6 -0
- package/Forms/Label/Label.d.ts +3 -0
- package/Forms/Label/Label.js +24 -0
- package/Forms/Label/index.d.ts +1 -0
- package/Forms/Label/index.js +1 -0
- package/Forms/Label/package.json +6 -0
- package/Forms/Password/Password.d.ts +5 -0
- package/Forms/Password/Password.js +30 -0
- package/Forms/Password/index.d.ts +1 -0
- package/Forms/Password/index.js +1 -0
- package/Forms/Password/package.json +6 -0
- package/Forms/Radio/Radio.d.ts +12 -0
- package/Forms/Radio/Radio.js +28 -0
- package/Forms/Radio/index.d.ts +1 -0
- package/Forms/Radio/index.js +1 -0
- package/Forms/Radio/package.json +6 -0
- package/Forms/Switch/Switch.d.ts +9 -0
- package/Forms/Switch/Switch.js +50 -0
- package/Forms/Switch/index.d.ts +1 -0
- package/Forms/Switch/index.js +1 -0
- package/Forms/Switch/package.json +6 -0
- package/Forms/Textarea/Textarea.d.ts +5 -0
- package/Forms/Textarea/Textarea.js +13 -0
- package/Forms/Textarea/TextareaRich.d.ts +6 -0
- package/Forms/Textarea/TextareaRich.js +42 -0
- package/Forms/Textarea/index.d.ts +2 -0
- package/Forms/Textarea/index.js +2 -0
- package/Forms/Textarea/package.json +6 -0
- package/Forms/Toggle/Toggle.d.ts +19 -0
- package/Forms/Toggle/Toggle.js +80 -0
- package/Forms/Toggle/index.d.ts +1 -0
- package/Forms/Toggle/index.js +1 -0
- package/Forms/Toggle/package.json +6 -0
- package/Forms/Toggle/useToggle.d.ts +46 -0
- package/Forms/Toggle/useToggle.js +145 -0
- package/Forms/antispam.d.ts +24 -0
- package/Forms/antispam.js +56 -0
- package/Forms/helpers.d.ts +26 -0
- package/Forms/helpers.js +44 -0
- package/Forms/index.d.ts +15 -0
- package/Forms/index.js +16 -0
- package/Forms/package.json +6 -0
- package/Forms/styles.d.ts +19 -0
- package/Forms/styles.js +60 -0
- package/Gauge/Gauge.d.ts +5 -0
- package/Gauge/Gauge.js +102 -0
- package/Grid/Grid.d.ts +64 -0
- package/Grid/Grid.js +79 -0
- package/Grid/index.d.ts +1 -0
- package/Grid/index.js +1 -0
- package/Grid/package.json +6 -0
- package/Hamburger/Hamburger.d.ts +6 -0
- package/Hamburger/Hamburger.js +64 -0
- package/Hamburger/index.d.ts +1 -0
- package/Hamburger/index.js +1 -0
- package/Hamburger/package.json +6 -0
- package/Header/index.d.ts +1 -0
- package/Header/index.js +1 -0
- package/Header/package.json +6 -0
- package/Header/useHeader.d.ts +24 -0
- package/Header/useHeader.js +30 -0
- package/Hidden/Hidden.d.ts +6 -0
- package/Hidden/Hidden.js +14 -0
- package/Hidden/index.d.ts +1 -0
- package/Hidden/index.js +1 -0
- package/Hidden/package.json +6 -0
- package/Img/index.d.ts +1 -0
- package/Img/index.js +1 -0
- package/Img/package.json +6 -0
- package/Img/sc/bare.d.ts +2 -0
- package/Img/sc/bare.js +37 -0
- package/Img/types.d.ts +9 -0
- package/Img/types.js +1 -0
- package/Link/Link.d.ts +5 -0
- package/Link/Link.js +2 -0
- package/Link/LinkBlank.d.ts +8 -0
- package/Link/LinkBlank.js +26 -0
- package/Link/index.d.ts +2 -0
- package/Link/index.js +2 -0
- package/Link/package.json +6 -0
- package/Menu/Menu.d.ts +1 -0
- package/Menu/Menu.js +11 -0
- package/Menu/index.d.ts +1 -0
- package/Menu/index.js +1 -0
- package/Menu/package.json +6 -0
- package/MenuItem/MenuItem.d.ts +4 -0
- package/MenuItem/MenuItem.js +20 -0
- package/MenuItem/index.d.ts +1 -0
- package/MenuItem/index.js +1 -0
- package/MenuItem/package.json +6 -0
- package/Meta/Meta.d.ts +14 -0
- package/Meta/Meta.js +4 -0
- package/Meta/index.d.ts +1 -0
- package/Meta/index.js +1 -0
- package/Meta/package.json +6 -0
- package/NoJs/NoJs.d.ts +2 -0
- package/NoJs/NoJs.js +6 -0
- package/NoJs/index.d.ts +1 -0
- package/NoJs/index.js +1 -0
- package/NoJs/package.json +6 -0
- package/Pagination/PaginationNav.d.ts +22 -0
- package/Pagination/PaginationNav.js +83 -0
- package/Pagination/PaginationResults.d.ts +3 -0
- package/Pagination/PaginationResults.js +10 -0
- package/Pagination/index.d.ts +2 -0
- package/Pagination/index.js +2 -0
- package/Pagination/package.json +6 -0
- package/Pill/Pill.d.ts +5 -0
- package/Pill/Pill.js +37 -0
- package/Pill/index.d.ts +1 -0
- package/Pill/index.js +1 -0
- package/Pill/package.json +6 -0
- package/Progress/ProgressCircular.d.ts +19 -0
- package/Progress/ProgressCircular.js +36 -0
- package/Progress/ProgressLinear.d.ts +22 -0
- package/Progress/ProgressLinear.js +32 -0
- package/Progress/ProgressOverlay.d.ts +4 -0
- package/Progress/ProgressOverlay.js +40 -0
- package/Progress/index.d.ts +3 -0
- package/Progress/index.js +3 -0
- package/Progress/package.json +6 -0
- package/Rating/Rating.d.ts +35 -0
- package/Rating/Rating.js +91 -0
- package/Rating/index.d.ts +11 -0
- package/Rating/index.js +45 -0
- package/Rating/package.json +6 -0
- package/Select/SelectDownshift.d.ts +5 -0
- package/Select/SelectDownshift.js +38 -0
- package/Select/components.d.ts +6 -0
- package/Select/components.js +18 -0
- package/Select/index.d.ts +2 -0
- package/Select/index.js +3 -0
- package/Select/package.json +6 -0
- package/Sidebar/Sidebar.d.ts +3 -0
- package/Sidebar/Sidebar.js +48 -0
- package/Sidebar/index.d.ts +1 -0
- package/Sidebar/index.js +1 -0
- package/Sidebar/package.json +6 -0
- package/Spacing/Spacing.d.ts +30 -0
- package/Spacing/Spacing.js +45 -0
- package/Spacing/index.d.ts +1 -0
- package/Spacing/index.js +1 -0
- package/Spacing/package.json +6 -0
- package/Sticky/Sticky.d.ts +2 -0
- package/Sticky/Sticky.js +219 -0
- package/Sticky/StickyCss.d.ts +5 -0
- package/Sticky/StickyCss.js +4 -0
- package/Sticky/index.d.ts +1 -0
- package/Sticky/index.js +1 -0
- package/Sticky/package.json +6 -0
- package/Tabs/TabsMui.d.ts +244 -0
- package/Tabs/TabsMui.js +43 -0
- package/Tabs/index.d.ts +1 -0
- package/Tabs/index.js +1 -0
- package/Tabs/package.json +6 -0
- package/Tabs/sc/bare.d.ts +5 -0
- package/Tabs/sc/bare.js +87 -0
- package/Tabs/tw/bare.d.ts +248 -0
- package/Tabs/tw/bare.js +15 -0
- package/Tabs/tw/material.d.ts +472 -0
- package/Tabs/tw/material.js +14 -0
- package/Tabs/useTabs.d.ts +43 -0
- package/Tabs/useTabs.js +44 -0
- package/Typography/CopyPasteVisible.d.ts +1 -0
- package/Typography/CopyPasteVisible.js +6 -0
- package/Typography/Native.d.ts +10 -0
- package/Typography/Native.js +47 -0
- package/Typography/ReadMore.d.ts +12 -0
- package/Typography/ReadMore.js +69 -0
- package/Typography/TextLoop.d.ts +16 -0
- package/Typography/TextLoop.js +49 -0
- package/Typography/TypeStairs.d.ts +6 -0
- package/Typography/TypeStairs.js +46 -0
- package/Typography/index.d.ts +5 -0
- package/Typography/index.js +5 -0
- package/Typography/package.json +6 -0
- package/css/index.d.ts +2 -0
- package/css/index.js +31 -0
- package/css/package.json +6 -0
- package/helpers/classed.d.ts +22 -0
- package/helpers/classed.js +65 -0
- package/helpers/extend-component.d.ts +28 -0
- package/helpers/extend-component.js +12 -0
- package/helpers/index.d.ts +3 -0
- package/helpers/index.js +2 -0
- package/helpers/package.json +6 -0
- package/hooks/index.d.ts +14 -0
- package/hooks/index.js +15 -0
- package/hooks/package.json +6 -0
- package/hooks/types.d.ts +8 -0
- package/hooks/types.js +1 -0
- package/hooks/useAsyncFn.d.ts +26 -0
- package/hooks/useAsyncFn.js +29 -0
- package/hooks/useDateLocale.d.ts +7 -0
- package/hooks/useDateLocale.js +29 -0
- package/hooks/useEffectOnce.d.ts +5 -0
- package/hooks/useEffectOnce.js +8 -0
- package/hooks/useFirstMountState.d.ts +4 -0
- package/hooks/useFirstMountState.js +12 -0
- package/hooks/useFocus.d.ts +4 -0
- package/hooks/useFocus.js +11 -0
- package/hooks/useId.d.ts +4 -0
- package/hooks/useId.js +7 -0
- package/hooks/useIsomorphicLayoutEffect.d.ts +5 -0
- package/hooks/useIsomorphicLayoutEffect.js +8 -0
- package/hooks/useMount.d.ts +4 -0
- package/hooks/useMount.js +9 -0
- package/hooks/useMountedState.d.ts +4 -0
- package/hooks/useMountedState.js +15 -0
- package/hooks/usePrevious.d.ts +1 -0
- package/hooks/usePrevious.js +8 -0
- package/hooks/useScrollPosition.d.ts +15 -0
- package/hooks/useScrollPosition.js +75 -0
- package/hooks/useScrollTo.d.ts +1 -0
- package/hooks/useScrollTo.js +19 -0
- package/hooks/useTraceUpdate.d.ts +4 -0
- package/hooks/useTraceUpdate.js +20 -0
- package/hooks/useUpdateEffect.d.ts +5 -0
- package/hooks/useUpdateEffect.js +14 -0
- package/hooks/useWindowSize.d.ts +1 -0
- package/hooks/useWindowSize.js +13 -0
- package/index.d.ts +1 -0
- package/index.js +5 -0
- package/m/MotionProvider.d.ts +37 -0
- package/m/MotionProvider.js +37 -0
- package/m/index.d.ts +6 -0
- package/m/index.js +6 -0
- package/m/lite.d.ts +2 -0
- package/m/lite.js +2 -0
- package/m/max.d.ts +2 -0
- package/m/max.js +2 -0
- package/m/package.json +6 -0
- package/node/Alert/Alert.js +21 -0
- package/node/Alert/index.js +4 -0
- package/node/Animations/Reveal.js +19 -0
- package/node/Animations/Underline.js +19 -0
- package/node/Animations/index.js +6 -0
- package/node/Animations/useReveal.js +74 -0
- package/node/Autocomplete/AutocompleteDownshift.js +161 -0
- package/node/Autocomplete/AutocompleteDownshiftMultiselect.js +356 -0
- package/node/Autocomplete/AutocompleteMui.js +175 -0
- package/node/Autocomplete/AutocompleteReach.js +115 -0
- package/node/Autocomplete/components.js +93 -0
- package/node/Autocomplete/helpers.js +32 -0
- package/node/Autocomplete/index.js +7 -0
- package/node/Bg/BgColor.js +36 -0
- package/node/Bg/BgPhoto.js +64 -0
- package/node/Bg/BgSvg.js +20 -0
- package/node/Bg/index.js +6 -0
- package/node/Breadcrumbs/Breadcrumbs.js +72 -0
- package/node/Breadcrumbs/index.js +4 -0
- package/node/Buttons/Button.js +83 -0
- package/node/Buttons/ButtonComposite.js +54 -0
- package/node/Buttons/ButtonFab.js +12 -0
- package/node/Buttons/ButtonLink.js +15 -0
- package/node/Buttons/IconButton.js +23 -0
- package/node/Buttons/index.js +8 -0
- package/node/Calendar/CalendarDaygridCell.js +55 -0
- package/node/Calendar/CalendarDaygridNav.js +27 -0
- package/node/Calendar/CalendarDaygridTable.js +60 -0
- package/node/Calendar/CalendarLegend.js +15 -0
- package/node/Calendar/calendar-api-google.js +99 -0
- package/node/Calendar/index.js +9 -0
- package/node/Calendar/types.js +2 -0
- package/node/Calendar/useCalendar.js +186 -0
- package/node/Calendar/utils.js +217 -0
- package/node/Carousel/Carousel.js +381 -0
- package/node/Carousel/CarouselCss.js +42 -0
- package/node/Carousel/index.js +4 -0
- package/node/Collapsable/Collapsable.js +4 -0
- package/node/Collapsable/CollapsableReach.js +253 -0
- package/node/Collapsable/index.js +5 -0
- package/node/Debug/Debug.js +26 -0
- package/node/Debug/index.js +4 -0
- package/node/Details/Details.js +65 -0
- package/node/Details/index.js +4 -0
- package/node/Dialog/DialogMui.js +82 -0
- package/node/Dialog/css/bare.js +23 -0
- package/node/Dialog/index.js +5 -0
- package/node/Dialog/m/bare.js +51 -0
- package/node/Dialog/m/basic.js +35 -0
- package/node/Dialog/m/index.js +8 -0
- package/node/Dialog/sc/bare.js +65 -0
- package/node/Dialog/sc/framer.js +19 -0
- package/node/Dialog/sc/framerMaterial.js +19 -0
- package/node/Dialog/sc/material.js +45 -0
- package/node/Dialog/tw/bare.js +40 -0
- package/node/Dialog/tw/elegant.js +21 -0
- package/node/Dialog/tw/framer.js +19 -0
- package/node/Dialog/tw/framerMaterial.js +19 -0
- package/node/Dialog/tw/material.js +21 -0
- package/node/Editor/Editor--tiptap.js +29 -0
- package/node/Editor/components.js +34 -0
- package/node/Editor/index.js +4 -0
- package/node/Favicon/FaviconTags.js +18 -0
- package/node/Favicon/index.js +4 -0
- package/node/Form/Form.js +63 -0
- package/node/Form/index.js +4 -0
- package/node/Form/sc/bare.js +33 -0
- package/node/Forms/Checkbox/Checkbox.js +28 -0
- package/node/Forms/Checkbox/index.js +4 -0
- package/node/Forms/Feedback/Feedback.js +15 -0
- package/node/Forms/Feedback/index.js +4 -0
- package/node/Forms/Field/Field.js +64 -0
- package/node/Forms/Field/FieldControl.js +47 -0
- package/node/Forms/Field/FieldHint.js +10 -0
- package/node/Forms/Field/index.js +5 -0
- package/node/Forms/Input/Input.js +27 -0
- package/node/Forms/Input/index.js +4 -0
- package/node/Forms/InputGroup/InputGroup.js +47 -0
- package/node/Forms/InputGroup/index.js +4 -0
- package/node/Forms/Label/Label.js +28 -0
- package/node/Forms/Label/index.js +4 -0
- package/node/Forms/Password/Password.js +34 -0
- package/node/Forms/Password/index.js +4 -0
- package/node/Forms/Radio/Radio.js +32 -0
- package/node/Forms/Radio/index.js +4 -0
- package/node/Forms/Switch/Switch.js +54 -0
- package/node/Forms/Switch/index.js +4 -0
- package/node/Forms/Textarea/Textarea.js +17 -0
- package/node/Forms/Textarea/TextareaRich.js +46 -0
- package/node/Forms/Textarea/index.js +5 -0
- package/node/Forms/Toggle/Toggle.js +86 -0
- package/node/Forms/Toggle/index.js +4 -0
- package/node/Forms/Toggle/useToggle.js +149 -0
- package/node/Forms/antispam.js +61 -0
- package/node/Forms/helpers.js +51 -0
- package/node/Forms/index.js +19 -0
- package/node/Forms/styles.js +64 -0
- package/node/Gauge/Gauge.js +106 -0
- package/node/Grid/Grid.js +83 -0
- package/node/Grid/index.js +4 -0
- package/node/Hamburger/Hamburger.js +69 -0
- package/node/Hamburger/index.js +4 -0
- package/node/Header/index.js +4 -0
- package/node/Header/useHeader.js +34 -0
- package/node/Hidden/Hidden.js +18 -0
- package/node/Hidden/index.js +4 -0
- package/node/Img/index.js +4 -0
- package/node/Img/sc/bare.js +41 -0
- package/node/Img/types.js +2 -0
- package/node/Link/Link.js +6 -0
- package/node/Link/LinkBlank.js +31 -0
- package/node/Link/index.js +5 -0
- package/node/Menu/Menu.js +15 -0
- package/node/Menu/index.js +4 -0
- package/node/MenuItem/MenuItem.js +24 -0
- package/node/MenuItem/index.js +4 -0
- package/node/Meta/Meta.js +8 -0
- package/node/Meta/index.js +4 -0
- package/node/NoJs/NoJs.js +10 -0
- package/node/NoJs/index.js +4 -0
- package/node/Pagination/PaginationNav.js +88 -0
- package/node/Pagination/PaginationResults.js +15 -0
- package/node/Pagination/index.js +5 -0
- package/node/Pill/Pill.js +41 -0
- package/node/Pill/index.js +4 -0
- package/node/Progress/ProgressCircular.js +41 -0
- package/node/Progress/ProgressLinear.js +37 -0
- package/node/Progress/ProgressOverlay.js +45 -0
- package/node/Progress/index.js +6 -0
- package/node/Rating/Rating.js +97 -0
- package/node/Rating/index.js +53 -0
- package/node/Select/SelectDownshift.js +41 -0
- package/node/Select/components.js +22 -0
- package/node/Select/index.js +7 -0
- package/node/Sidebar/Sidebar.js +53 -0
- package/node/Sidebar/index.js +4 -0
- package/node/Spacing/Spacing.js +50 -0
- package/node/Spacing/index.js +4 -0
- package/node/Sticky/Sticky.js +222 -0
- package/node/Sticky/StickyCss.js +8 -0
- package/node/Sticky/index.js +4 -0
- package/node/Tabs/TabsMui.js +47 -0
- package/node/Tabs/index.js +4 -0
- package/node/Tabs/sc/bare.js +87 -0
- package/node/Tabs/tw/bare.js +19 -0
- package/node/Tabs/tw/material.js +17 -0
- package/node/Tabs/useTabs.js +48 -0
- package/node/Typography/CopyPasteVisible.js +10 -0
- package/node/Typography/Native.js +51 -0
- package/node/Typography/ReadMore.js +74 -0
- package/node/Typography/TextLoop.js +54 -0
- package/node/Typography/TypeStairs.js +49 -0
- package/node/Typography/index.js +8 -0
- package/node/css/index.js +36 -0
- package/node/helpers/classed.js +69 -0
- package/node/helpers/extend-component.js +16 -0
- package/node/helpers/index.js +5 -0
- package/node/hooks/index.js +18 -0
- package/node/hooks/types.js +2 -0
- package/node/hooks/useAsyncFn.js +33 -0
- package/node/hooks/useDateLocale.js +56 -0
- package/node/hooks/useEffectOnce.js +12 -0
- package/node/hooks/useFirstMountState.js +16 -0
- package/node/hooks/useFocus.js +15 -0
- package/node/hooks/useId.js +11 -0
- package/node/hooks/useIsomorphicLayoutEffect.js +11 -0
- package/node/hooks/useMount.js +13 -0
- package/node/hooks/useMountedState.js +19 -0
- package/node/hooks/usePrevious.js +12 -0
- package/node/hooks/useScrollPosition.js +79 -0
- package/node/hooks/useScrollTo.js +23 -0
- package/node/hooks/useTraceUpdate.js +24 -0
- package/node/hooks/useUpdateEffect.js +18 -0
- package/node/hooks/useWindowSize.js +17 -0
- package/node/index.js +8 -0
- package/node/m/MotionProvider.js +41 -0
- package/node/m/index.js +9 -0
- package/node/m/lite.js +4 -0
- package/node/m/max.js +4 -0
- package/node/sc/index.js +37 -0
- package/node/scm/index.js +36 -0
- package/node/shared/index.js +11 -0
- package/node/styles/Body.js +21 -0
- package/node/styles/Global.js +53 -0
- package/node/styles/index.js +10 -0
- package/node/styles/media.js +156 -0
- package/node/styles/spacing.js +53 -0
- package/node/styles/styled.js +31 -0
- package/node/styles/theme--vanilla.js +59 -0
- package/node/styles/theme.js +45 -0
- package/node/tw/index.js +36 -0
- package/node/twm/index.js +36 -0
- package/node/types.js +2 -0
- package/package.json +3 -6
- package/sc/index.d.ts +30 -0
- package/sc/index.js +31 -0
- package/sc/package.json +6 -0
- package/scm/index.d.ts +29 -0
- package/scm/index.js +31 -0
- package/scm/package.json +6 -0
- package/shared/index.d.ts +8 -0
- package/shared/index.js +8 -0
- package/shared/package.json +6 -0
- package/styles/Body.d.ts +10 -0
- package/styles/Body.js +17 -0
- package/styles/Global.d.ts +15 -0
- package/styles/Global.js +50 -0
- package/styles/index.d.ts +7 -0
- package/styles/index.js +7 -0
- package/styles/media.d.ts +67 -0
- package/styles/media.js +150 -0
- package/styles/package.json +6 -0
- package/styles/spacing.d.ts +13 -0
- package/styles/spacing.js +46 -0
- package/styles/styled.d.ts +12 -0
- package/styles/styled.js +27 -0
- package/styles/theme--vanilla.d.ts +18 -0
- package/styles/theme--vanilla.js +53 -0
- package/styles/theme.d.ts +82 -0
- package/styles/theme.js +41 -0
- package/tw/index.d.ts +2 -0
- package/tw/index.js +31 -0
- package/tw/package.json +6 -0
- package/twm/index.d.ts +2 -0
- package/twm/index.js +31 -0
- package/twm/package.json +6 -0
- package/types.d.ts +10 -0
- package/types.js +1 -0
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type { FunctionReturningPromise, PromiseType } from "./types";
|
|
3
|
+
export declare type AsyncState<T> = {
|
|
4
|
+
loading: boolean;
|
|
5
|
+
error?: undefined;
|
|
6
|
+
value?: undefined;
|
|
7
|
+
} | {
|
|
8
|
+
loading: true;
|
|
9
|
+
error?: Error | undefined;
|
|
10
|
+
value?: T;
|
|
11
|
+
} | {
|
|
12
|
+
loading: false;
|
|
13
|
+
error: Error;
|
|
14
|
+
value?: undefined;
|
|
15
|
+
} | {
|
|
16
|
+
loading: false;
|
|
17
|
+
error?: undefined;
|
|
18
|
+
value: T;
|
|
19
|
+
};
|
|
20
|
+
declare type StateFromFunctionReturningPromise<T extends FunctionReturningPromise> = AsyncState<PromiseType<ReturnType<T>>>;
|
|
21
|
+
export declare type AsyncFnReturn<T extends FunctionReturningPromise = FunctionReturningPromise> = [StateFromFunctionReturningPromise<T>, T];
|
|
22
|
+
/**
|
|
23
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useAsyncFn.ts)
|
|
24
|
+
*/
|
|
25
|
+
export declare function useAsyncFn<T extends FunctionReturningPromise>(fn: T, deps?: React.DependencyList, initialState?: StateFromFunctionReturningPromise<T>): AsyncFnReturn<T>;
|
|
26
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { useCallback, useRef, useState } from "react";
|
|
2
|
+
import { useMountedState } from "./useMountedState";
|
|
3
|
+
/**
|
|
4
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useAsyncFn.ts)
|
|
5
|
+
*/
|
|
6
|
+
export function useAsyncFn(fn, deps = [], initialState = { loading: false }) {
|
|
7
|
+
const lastCallId = useRef(0);
|
|
8
|
+
const isMounted = useMountedState();
|
|
9
|
+
const [state, set] = useState(initialState);
|
|
10
|
+
const callback = useCallback((...args) => {
|
|
11
|
+
const callId = ++lastCallId.current;
|
|
12
|
+
if (!state.loading) {
|
|
13
|
+
set((prevState) => ({ ...prevState, loading: true }));
|
|
14
|
+
}
|
|
15
|
+
return fn(...args).then((value) => {
|
|
16
|
+
isMounted() &&
|
|
17
|
+
callId === lastCallId.current &&
|
|
18
|
+
set({ value, loading: false });
|
|
19
|
+
return value;
|
|
20
|
+
}, (error) => {
|
|
21
|
+
isMounted() &&
|
|
22
|
+
callId === lastCallId.current &&
|
|
23
|
+
set({ error, loading: false });
|
|
24
|
+
return error;
|
|
25
|
+
});
|
|
26
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
27
|
+
}, deps);
|
|
28
|
+
return [state, callback];
|
|
29
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Dynamically import the date-fns correct locale
|
|
3
|
+
*
|
|
4
|
+
* Inspired by:
|
|
5
|
+
* @see https://robertmarshall.dev/blog/dynamically-import-datefns-locale-mui-datepicker-localization/
|
|
6
|
+
*/
|
|
7
|
+
export declare function useDateLocale(locale?: string, defaultLocale?: string): globalThis.Locale | undefined;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { useEffect, useState } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* Dynamically import the date-fns correct locale
|
|
4
|
+
*
|
|
5
|
+
* Inspired by:
|
|
6
|
+
* @see https://robertmarshall.dev/blog/dynamically-import-datefns-locale-mui-datepicker-localization/
|
|
7
|
+
*/
|
|
8
|
+
export function useDateLocale(locale, defaultLocale = "en") {
|
|
9
|
+
const [data, setData] = useState();
|
|
10
|
+
const [current, setCurrent] = useState(defaultLocale);
|
|
11
|
+
// const [ready, setReady] = useState(false);
|
|
12
|
+
// If the user changes the locale listen to the change and import the locale that is now required.
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
const importLocaleFile = async () => {
|
|
15
|
+
// This webpack option stops all of the date-fns files being imported and chunked.
|
|
16
|
+
const localeToSet = await import(
|
|
17
|
+
/* webpackMode: "lazy", webpackChunkName: "df-[index]", webpackExclude: /_lib/ */
|
|
18
|
+
`date-fns/locale/${locale}/index.js`);
|
|
19
|
+
setCurrent(locale || current);
|
|
20
|
+
setData(localeToSet.default);
|
|
21
|
+
// setReady(true);
|
|
22
|
+
};
|
|
23
|
+
// If the locale has not yet been loaded.
|
|
24
|
+
if (locale !== current) {
|
|
25
|
+
importLocaleFile();
|
|
26
|
+
}
|
|
27
|
+
}, [locale, current]);
|
|
28
|
+
return data;
|
|
29
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useEffectOnce.ts)
|
|
4
|
+
*/
|
|
5
|
+
export const useEffectOnce = (effect) => {
|
|
6
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
7
|
+
useEffect(effect, []);
|
|
8
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { useRef } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useFirstMountState.ts)
|
|
4
|
+
*/
|
|
5
|
+
export function useFirstMountState() {
|
|
6
|
+
const isFirst = useRef(true);
|
|
7
|
+
if (isFirst.current) {
|
|
8
|
+
isFirst.current = false;
|
|
9
|
+
return true;
|
|
10
|
+
}
|
|
11
|
+
return isFirst.current;
|
|
12
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { useRef } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* @see https://stackoverflow.com/a/54159564/1938970
|
|
4
|
+
*/
|
|
5
|
+
export const useFocus = () => {
|
|
6
|
+
const element = useRef(null);
|
|
7
|
+
const setFocus = () => {
|
|
8
|
+
element.current && element.current.focus();
|
|
9
|
+
};
|
|
10
|
+
return [element, setFocus];
|
|
11
|
+
};
|
package/hooks/useId.d.ts
ADDED
package/hooks/useId.js
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { useEffect, useLayoutEffect } from "react";
|
|
2
|
+
import { isBrowser } from "@koine/utils";
|
|
3
|
+
/**
|
|
4
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useFirstMountState.ts)
|
|
5
|
+
*/
|
|
6
|
+
export const useIsomorphicLayoutEffect = isBrowser
|
|
7
|
+
? useLayoutEffect
|
|
8
|
+
: useEffect;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { useCallback, useEffect, useRef } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useMountedState.ts)
|
|
4
|
+
*/
|
|
5
|
+
export function useMountedState() {
|
|
6
|
+
const mountedRef = useRef(false);
|
|
7
|
+
const get = useCallback(() => mountedRef.current, []);
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
mountedRef.current = true;
|
|
10
|
+
return () => {
|
|
11
|
+
mountedRef.current = false;
|
|
12
|
+
};
|
|
13
|
+
}, []);
|
|
14
|
+
return get;
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function usePrevious<T>(value: T): T | undefined;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
declare type Position = {
|
|
3
|
+
x: number;
|
|
4
|
+
y: number;
|
|
5
|
+
};
|
|
6
|
+
declare type ElementRef = React.MutableRefObject<HTMLElement | undefined>;
|
|
7
|
+
/**
|
|
8
|
+
* @borrows [@n8tb1t/use-scroll-position@2.0.3](https://github.com/n8tb1t/use-scroll-position) by `n8tb1t <n8tb1t@gmail.com>`
|
|
9
|
+
*
|
|
10
|
+
* We've just:
|
|
11
|
+
* - reused internal helper functions
|
|
12
|
+
* - compacted object arguments in functions as plain argument list to improve compression
|
|
13
|
+
*/
|
|
14
|
+
export declare const useScrollPosition: (effect: (currentPosition: Position, prevPosition: Position) => void, deps?: import("react").DependencyList, element?: ElementRef | undefined, useWindow?: boolean | undefined, wait?: number | undefined, boundingElement?: ElementRef | undefined) => void;
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { useRef } from "react";
|
|
2
|
+
import { isBrowser } from "@koine/utils";
|
|
3
|
+
import { useIsomorphicLayoutEffect } from "./useIsomorphicLayoutEffect";
|
|
4
|
+
const zeroPosition = { x: 0, y: 0 };
|
|
5
|
+
const getClientRect = (element) => element?.getBoundingClientRect();
|
|
6
|
+
const getScrollPosition = (element, useWindow, boundingElement) => {
|
|
7
|
+
if (!isBrowser) {
|
|
8
|
+
return zeroPosition;
|
|
9
|
+
}
|
|
10
|
+
if (useWindow) {
|
|
11
|
+
return { x: window.scrollX, y: window.scrollY };
|
|
12
|
+
}
|
|
13
|
+
const targetPosition = getClientRect(element?.current || document.body);
|
|
14
|
+
const containerPosition = getClientRect(boundingElement?.current);
|
|
15
|
+
if (!targetPosition) {
|
|
16
|
+
return zeroPosition;
|
|
17
|
+
}
|
|
18
|
+
return containerPosition
|
|
19
|
+
? {
|
|
20
|
+
x: (containerPosition.x || 0) - (targetPosition.x || 0),
|
|
21
|
+
y: (containerPosition.y || 0) - (targetPosition.y || 0),
|
|
22
|
+
}
|
|
23
|
+
: { x: targetPosition.left, y: targetPosition.top };
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* @borrows [@n8tb1t/use-scroll-position@2.0.3](https://github.com/n8tb1t/use-scroll-position) by `n8tb1t <n8tb1t@gmail.com>`
|
|
27
|
+
*
|
|
28
|
+
* We've just:
|
|
29
|
+
* - reused internal helper functions
|
|
30
|
+
* - compacted object arguments in functions as plain argument list to improve compression
|
|
31
|
+
*/
|
|
32
|
+
export const useScrollPosition = (effect, deps = [], element, useWindow, wait, boundingElement) => {
|
|
33
|
+
const position = useRef(getScrollPosition(null, useWindow, boundingElement));
|
|
34
|
+
let throttleTimeout = null;
|
|
35
|
+
const callBack = () => {
|
|
36
|
+
const current = getScrollPosition(element, useWindow, boundingElement);
|
|
37
|
+
effect(current, position.current);
|
|
38
|
+
position.current = current;
|
|
39
|
+
throttleTimeout = null;
|
|
40
|
+
};
|
|
41
|
+
useIsomorphicLayoutEffect(() => {
|
|
42
|
+
if (!isBrowser) {
|
|
43
|
+
return undefined;
|
|
44
|
+
}
|
|
45
|
+
const handleScroll = () => {
|
|
46
|
+
if (wait) {
|
|
47
|
+
if (throttleTimeout === null) {
|
|
48
|
+
throttleTimeout = window.setTimeout(callBack, wait);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
callBack();
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
if (boundingElement) {
|
|
56
|
+
boundingElement.current?.addEventListener("scroll", handleScroll, {
|
|
57
|
+
passive: true,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
window.addEventListener("scroll", handleScroll, { passive: true });
|
|
62
|
+
}
|
|
63
|
+
return () => {
|
|
64
|
+
if (boundingElement) {
|
|
65
|
+
boundingElement.current?.removeEventListener("scroll", handleScroll);
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
window.removeEventListener("scroll", handleScroll);
|
|
69
|
+
}
|
|
70
|
+
if (throttleTimeout) {
|
|
71
|
+
clearTimeout(throttleTimeout);
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
}, deps);
|
|
75
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function useScrollTo(id?: string, offset?: number): void;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { isBrowser } from "@koine/utils";
|
|
2
|
+
import { useHeader } from "../Header/useHeader";
|
|
3
|
+
export function useScrollTo(id = "", offset = 0) {
|
|
4
|
+
const [, , headerHeight] = useHeader();
|
|
5
|
+
if (!isBrowser) {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
const headerOffset = headerHeight || 0;
|
|
9
|
+
let element = document.getElementById(id);
|
|
10
|
+
let top = 0;
|
|
11
|
+
if (element && element.offsetParent) {
|
|
12
|
+
do {
|
|
13
|
+
top += element.offsetTop;
|
|
14
|
+
} while ((element = element.offsetParent));
|
|
15
|
+
}
|
|
16
|
+
top -= offset;
|
|
17
|
+
top -= headerOffset;
|
|
18
|
+
window.scroll(0, top);
|
|
19
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { useEffect, useRef } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* @see https://stackoverflow.com/a/51082563/9122820
|
|
4
|
+
*/
|
|
5
|
+
export function useTraceUpdate(props) {
|
|
6
|
+
const prev = useRef(props);
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
const changedProps = Object.entries(props).reduce((ps, [k, v]) => {
|
|
9
|
+
if (prev.current[k] !== v) {
|
|
10
|
+
// @ts-expect-error Does not matter here...
|
|
11
|
+
ps[k] = [prev.current[k], v];
|
|
12
|
+
}
|
|
13
|
+
return ps;
|
|
14
|
+
}, {});
|
|
15
|
+
if (Object.keys(changedProps).length > 0) {
|
|
16
|
+
console.log("Changed props:", changedProps);
|
|
17
|
+
}
|
|
18
|
+
prev.current = props;
|
|
19
|
+
});
|
|
20
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { useFirstMountState } from "./useFirstMountState";
|
|
3
|
+
/**
|
|
4
|
+
* @borrows [streamich/react-use](https://github.com/streamich/react-use/blob/master/src/useUpdateEffect.ts)
|
|
5
|
+
*/
|
|
6
|
+
export const useUpdateEffect = (effect, deps) => {
|
|
7
|
+
const isFirstMount = useFirstMountState();
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (!isFirstMount) {
|
|
10
|
+
return effect();
|
|
11
|
+
}
|
|
12
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
13
|
+
}, deps);
|
|
14
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function useWindowSize(): number[];
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useEffect, useState } from "react";
|
|
2
|
+
export function useWindowSize() {
|
|
3
|
+
const [size, setSize] = useState([0, 0]);
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
function updateSize() {
|
|
6
|
+
setSize([window.innerWidth, window.innerHeight]);
|
|
7
|
+
}
|
|
8
|
+
window.addEventListener("resize", updateSize);
|
|
9
|
+
updateSize();
|
|
10
|
+
return () => window.removeEventListener("resize", updateSize);
|
|
11
|
+
}, []);
|
|
12
|
+
return size;
|
|
13
|
+
}
|
package/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./shared";
|
package/index.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { LazyProps } from "framer-motion";
|
|
3
|
+
export declare type MotionProviderFeatures = LazyProps["features"];
|
|
4
|
+
export declare type MotionProviderProps = LazyProps & React.PropsWithChildren<{}>;
|
|
5
|
+
/**
|
|
6
|
+
* `<LazyMotion />` provider wrapper from `framer-motion`
|
|
7
|
+
*
|
|
8
|
+
* @see https://www.framer.com/docs/guide-reduce-bundle-size/
|
|
9
|
+
*
|
|
10
|
+
* About the difference between `lite` and `max`
|
|
11
|
+
* @see https://www.framer.com/docs/guide-reduce-bundle-size/#available-features
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
*
|
|
15
|
+
* `lite` version:
|
|
16
|
+
* ```tsx
|
|
17
|
+
* import { MotionProvider } from "@koine/react/m";
|
|
18
|
+
*
|
|
19
|
+
* const features = () => import("@koine/react/m/lite").then((m) => m.default);
|
|
20
|
+
*
|
|
21
|
+
* <MotionProvider features={features}>
|
|
22
|
+
* <App />
|
|
23
|
+
* </MotionProvider>
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* ### `max` version
|
|
27
|
+
* ```tsx
|
|
28
|
+
* import { MotionProvider } from "@koine/react/m";
|
|
29
|
+
*
|
|
30
|
+
* const features = () => import("@koine/react/m/max").then((m) => m.default);
|
|
31
|
+
*
|
|
32
|
+
* <MotionProvider features={features}>
|
|
33
|
+
* <App />
|
|
34
|
+
* </MotionProvider>
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
export declare const MotionProvider: ({ features, children }: MotionProviderProps) => JSX.Element;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { LazyMotion } from "framer-motion";
|
|
3
|
+
/**
|
|
4
|
+
* `<LazyMotion />` provider wrapper from `framer-motion`
|
|
5
|
+
*
|
|
6
|
+
* @see https://www.framer.com/docs/guide-reduce-bundle-size/
|
|
7
|
+
*
|
|
8
|
+
* About the difference between `lite` and `max`
|
|
9
|
+
* @see https://www.framer.com/docs/guide-reduce-bundle-size/#available-features
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
*
|
|
13
|
+
* `lite` version:
|
|
14
|
+
* ```tsx
|
|
15
|
+
* import { MotionProvider } from "@koine/react/m";
|
|
16
|
+
*
|
|
17
|
+
* const features = () => import("@koine/react/m/lite").then((m) => m.default);
|
|
18
|
+
*
|
|
19
|
+
* <MotionProvider features={features}>
|
|
20
|
+
* <App />
|
|
21
|
+
* </MotionProvider>
|
|
22
|
+
* ```
|
|
23
|
+
*
|
|
24
|
+
* ### `max` version
|
|
25
|
+
* ```tsx
|
|
26
|
+
* import { MotionProvider } from "@koine/react/m";
|
|
27
|
+
*
|
|
28
|
+
* const features = () => import("@koine/react/m/max").then((m) => m.default);
|
|
29
|
+
*
|
|
30
|
+
* <MotionProvider features={features}>
|
|
31
|
+
* <App />
|
|
32
|
+
* </MotionProvider>
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
export const MotionProvider = ({ features, children }) => {
|
|
36
|
+
return _jsx(LazyMotion, { features: features, children: children });
|
|
37
|
+
};
|
package/m/index.d.ts
ADDED
package/m/index.js
ADDED
package/m/lite.d.ts
ADDED
package/m/lite.js
ADDED
package/m/max.d.ts
ADDED
package/m/max.js
ADDED
package/m/package.json
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Alert = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const styled_components_1 = tslib_1.__importDefault(require("styled-components"));
|
|
7
|
+
const AlertRoot = styled_components_1.default.div `
|
|
8
|
+
font-size: 12px;
|
|
9
|
+
${(p) => (p.$danger ? `color: var(--danger)` : "")}
|
|
10
|
+
`;
|
|
11
|
+
const AlertInner = styled_components_1.default.div `
|
|
12
|
+
padding: 1em;
|
|
13
|
+
background-color: rgba(0, 0, 0, 0.05);
|
|
14
|
+
/* border: 1px solid var(--grey700); */
|
|
15
|
+
/* background: pink; */
|
|
16
|
+
/* color: red; */
|
|
17
|
+
`;
|
|
18
|
+
const Alert = ({ $danger, children, ...props }) => {
|
|
19
|
+
return ((0, jsx_runtime_1.jsx)(AlertRoot, { "$danger": $danger, ...props, children: (0, jsx_runtime_1.jsx)(AlertInner, { children: children }) }));
|
|
20
|
+
};
|
|
21
|
+
exports.Alert = Alert;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Reveal = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const framer_motion_1 = require("framer-motion");
|
|
6
|
+
const useReveal_1 = require("./useReveal");
|
|
7
|
+
const Reveal = ({ children, direction, offsetStartY, offsetEndY, offsetStartX, ...props }) => {
|
|
8
|
+
const effectOptions = { direction, offsetStartY, offsetEndY, offsetStartX };
|
|
9
|
+
const prefersReducedMotion = (0, framer_motion_1.useReducedMotion)();
|
|
10
|
+
const { ref, startY, endY, startX } = (0, useReveal_1.useReveal)(effectOptions);
|
|
11
|
+
const { scrollYProgress } = (0, framer_motion_1.useViewportScroll)();
|
|
12
|
+
const xRange = (0, framer_motion_1.useTransform)(scrollYProgress, [startY, endY], [startX, 0]);
|
|
13
|
+
const opacityRange = (0, framer_motion_1.useTransform)(scrollYProgress, [startY, endY], [0, 1]);
|
|
14
|
+
const x = (0, framer_motion_1.useSpring)(xRange, { stiffness: 400, damping: 90 });
|
|
15
|
+
const opacity = (0, framer_motion_1.useSpring)(opacityRange);
|
|
16
|
+
// console.log("start, end", startY, endY)
|
|
17
|
+
return ((0, jsx_runtime_1.jsx)(framer_motion_1.motion.div, { ...props, ref: ref, style: prefersReducedMotion ? {} : { x, opacity }, children: children }));
|
|
18
|
+
};
|
|
19
|
+
exports.Reveal = Reveal;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UnderlineSkewed = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const styled_components_1 = tslib_1.__importDefault(require("styled-components"));
|
|
6
|
+
const framer_motion_1 = require("framer-motion");
|
|
7
|
+
exports.UnderlineSkewed = (0, styled_components_1.default)(framer_motion_1.m.i) `
|
|
8
|
+
display: block;
|
|
9
|
+
position: absolute;
|
|
10
|
+
top: 50%;
|
|
11
|
+
left: 15%;
|
|
12
|
+
right: 15%;
|
|
13
|
+
height: 20px;
|
|
14
|
+
margin-top: -10px;
|
|
15
|
+
z-index: 0;
|
|
16
|
+
pointer-events: none;
|
|
17
|
+
background: var(--accent400);
|
|
18
|
+
transform: skewY(-5deg);
|
|
19
|
+
`;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./Reveal"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./Underline"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./useReveal"), exports);
|