@koine/react 2.0.0-beta.14 → 2.0.0-beta.15
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.js +10 -0
- package/Alert/index.d.ts +1 -1
- package/Alert/index.js +1 -0
- package/Animations/Reveal.d.ts +1 -2
- package/Animations/Reveal.js +16 -0
- package/Animations/Underline.js +5 -0
- package/Animations/index.d.ts +3 -3
- package/Animations/index.js +3 -0
- package/Animations/useReveal.d.ts +0 -21
- package/Animations/useReveal.js +42 -0
- package/Autocomplete/AutocompleteDownshift.js +1 -0
- package/Autocomplete/AutocompleteDownshiftMultiselect.js +1 -0
- package/Autocomplete/AutocompleteMui.d.ts +2 -27
- package/Autocomplete/AutocompleteMui.js +93 -0
- package/Autocomplete/AutocompleteReach.js +1 -0
- package/Autocomplete/components.d.ts +0 -5
- package/Autocomplete/components.js +26 -0
- package/Autocomplete/helpers.d.ts +1 -1
- package/Autocomplete/helpers.js +17 -0
- package/Autocomplete/index.d.ts +2 -2
- package/Autocomplete/index.js +1 -0
- package/Bg/BgColor.d.ts +1 -20
- package/Bg/BgColor.js +16 -0
- package/Bg/BgPhoto.d.ts +1 -6
- package/Bg/BgPhoto.js +16 -0
- package/Bg/BgSvg.d.ts +0 -3
- package/Bg/BgSvg.js +9 -0
- package/Bg/index.d.ts +3 -3
- package/Bg/index.js +3 -0
- package/Breadcrumbs/Breadcrumbs.d.ts +1 -1
- package/Breadcrumbs/Breadcrumbs.js +27 -0
- package/Breadcrumbs/index.d.ts +1 -1
- package/Breadcrumbs/index.js +1 -0
- package/Buttons/Button.d.ts +0 -4
- package/Buttons/Button.js +10 -0
- package/Buttons/ButtonComposite.d.ts +3 -4
- package/Buttons/ButtonComposite.js +28 -0
- package/Buttons/ButtonFab.d.ts +1 -2
- package/Buttons/ButtonFab.js +6 -0
- package/Buttons/ButtonLink.d.ts +3 -3
- package/Buttons/ButtonLink.js +11 -0
- package/Buttons/IconButton.d.ts +1 -2
- package/Buttons/IconButton.js +7 -0
- package/Buttons/index.d.ts +5 -5
- package/Buttons/index.js +5 -0
- package/Calendar/CalendarDaygridCell.d.ts +3 -4
- package/Calendar/CalendarDaygridCell.js +46 -0
- package/Calendar/CalendarDaygridNav.d.ts +2 -2
- package/Calendar/CalendarDaygridNav.js +23 -0
- package/Calendar/CalendarDaygridTable.d.ts +3 -3
- package/Calendar/CalendarDaygridTable.js +45 -0
- package/Calendar/CalendarLegend.d.ts +2 -3
- package/Calendar/CalendarLegend.js +8 -0
- package/Calendar/calendar-api-google.d.ts +1 -9
- package/Calendar/calendar-api-google.js +126 -0
- package/Calendar/index.d.ts +6 -6
- package/Calendar/index.js +6 -0
- package/Calendar/types.d.ts +0 -19
- package/Calendar/types.js +1 -0
- package/Calendar/useCalendar.d.ts +4 -19
- package/Calendar/useCalendar.js +176 -0
- package/Calendar/utils.d.ts +1 -1
- package/Calendar/utils.js +185 -0
- package/Carousel/Carousel.js +1 -0
- package/Carousel/CarouselCss.d.ts +1 -23
- package/Carousel/CarouselCss.js +19 -0
- package/Carousel/index.d.ts +1 -1
- package/Carousel/index.js +1 -0
- package/Collapsable/Collapsable.js +1 -0
- package/Collapsable/CollapsableReach.d.ts +0 -6
- package/Collapsable/CollapsableReach.js +1 -0
- package/Collapsable/index.d.ts +1 -1
- package/Collapsable/index.js +1 -0
- package/Debug/Debug.js +9 -0
- package/Debug/index.d.ts +1 -1
- package/Debug/index.js +1 -0
- package/Details/Details.d.ts +0 -6
- package/Details/Details.js +52 -0
- package/Details/index.d.ts +1 -1
- package/Details/index.js +1 -0
- package/Dialog/DialogMui.d.ts +1 -3
- package/Dialog/DialogMui.js +39 -0
- package/Dialog/css/bare.d.ts +1 -2
- package/Dialog/css/bare.js +20 -0
- package/Dialog/index.d.ts +2 -2
- package/Dialog/index.js +1 -0
- package/Dialog/m/bare.js +3 -0
- package/Dialog/m/basic.d.ts +1 -1
- package/Dialog/m/basic.js +28 -0
- package/Dialog/m/index.d.ts +1 -2
- package/Dialog/m/index.js +4 -0
- package/Dialog/sc/bare.d.ts +2 -12
- package/Dialog/sc/bare.js +31 -0
- package/Dialog/sc/framer.d.ts +1 -2
- package/Dialog/sc/framer.js +16 -0
- package/Dialog/sc/framerMaterial.js +16 -0
- package/Dialog/sc/material.d.ts +1 -2
- package/Dialog/sc/material.js +21 -0
- package/Dialog/tw/bare.d.ts +2 -17
- package/Dialog/tw/bare.js +28 -0
- package/Dialog/tw/elegant.d.ts +1 -2
- package/Dialog/tw/elegant.js +20 -0
- package/Dialog/tw/framer.d.ts +1 -2
- package/Dialog/tw/framer.js +16 -0
- package/Dialog/tw/framerMaterial.js +16 -0
- package/Dialog/tw/material.d.ts +1 -2
- package/Dialog/tw/material.js +20 -0
- package/Editor/Editor--tiptap.js +26 -0
- package/Editor/components.js +10 -0
- package/Editor/index.d.ts +1 -1
- package/Editor/index.js +1 -0
- package/FaviconTags.d.ts +0 -10
- package/FaviconTags.js +6 -0
- package/Form/Form.d.ts +1 -14
- package/Form/Form.js +60 -0
- package/Form/index.d.ts +1 -1
- package/Form/index.js +1 -0
- package/Form/sc/bare.d.ts +1 -2
- package/Form/sc/bare.js +20 -0
- package/Forms/Checkbox/Checkbox.d.ts +1 -5
- package/Forms/Checkbox/Checkbox.js +15 -0
- package/Forms/Checkbox/index.d.ts +1 -1
- package/Forms/Checkbox/index.js +1 -0
- package/Forms/Feedback/Feedback.js +9 -0
- package/Forms/Feedback/index.d.ts +1 -1
- package/Forms/Feedback/index.js +1 -0
- package/Forms/Field/Field.d.ts +1 -19
- package/Forms/Field/Field.js +25 -0
- package/Forms/Field/FieldControl.d.ts +2 -14
- package/Forms/Field/FieldControl.js +35 -0
- package/Forms/Field/FieldHint.js +4 -0
- package/Forms/Field/index.d.ts +2 -2
- package/Forms/Field/index.js +2 -0
- package/Forms/Input/Input.d.ts +1 -2
- package/Forms/Input/Input.js +16 -0
- package/Forms/Input/index.d.ts +1 -1
- package/Forms/Input/index.js +1 -0
- package/Forms/InputGroup/InputGroup.d.ts +1 -2
- package/Forms/InputGroup/InputGroup.js +15 -0
- package/Forms/InputGroup/index.d.ts +1 -1
- package/Forms/InputGroup/index.js +1 -0
- package/Forms/Label/Label.js +6 -0
- package/Forms/Label/index.d.ts +1 -1
- package/Forms/Label/index.js +1 -0
- package/Forms/Password/Password.d.ts +1 -2
- package/Forms/Password/Password.js +17 -0
- package/Forms/Password/index.d.ts +1 -1
- package/Forms/Password/index.js +1 -0
- package/Forms/Radio/Radio.d.ts +1 -2
- package/Forms/Radio/Radio.js +25 -0
- package/Forms/Radio/index.d.ts +1 -1
- package/Forms/Radio/index.js +1 -0
- package/Forms/Switch/Switch.d.ts +1 -5
- package/Forms/Switch/Switch.js +17 -0
- package/Forms/Switch/index.d.ts +1 -1
- package/Forms/Switch/index.js +1 -0
- package/Forms/Textarea/Textarea.d.ts +1 -2
- package/Forms/Textarea/Textarea.js +12 -0
- package/Forms/Textarea/TextareaRich.d.ts +1 -2
- package/Forms/Textarea/TextareaRich.js +26 -0
- package/Forms/Textarea/index.d.ts +2 -2
- package/Forms/Textarea/index.js +2 -0
- package/Forms/Toggle/Toggle-tailwind.js +1 -0
- package/Forms/Toggle/Toggle.d.ts +0 -1
- package/Forms/Toggle/Toggle.js +25 -0
- package/Forms/Toggle/index.d.ts +1 -1
- package/Forms/Toggle/index.js +1 -0
- package/Forms/Toggle/useToggle-tailwind.js +1 -0
- package/Forms/Toggle/useToggle.d.ts +1 -31
- package/Forms/Toggle/useToggle.js +85 -0
- package/Forms/antispam.d.ts +0 -20
- package/Forms/antispam.js +31 -0
- package/Forms/helpers.d.ts +0 -8
- package/Forms/helpers.js +36 -0
- package/Forms/index.d.ts +15 -15
- package/Forms/index.js +15 -0
- package/Forms/styles.d.ts +0 -6
- package/Forms/styles.js +19 -0
- package/Gauge/Gauge.d.ts +0 -1
- package/Gauge/Gauge.js +1 -0
- package/Grid/Grid.d.ts +1 -10
- package/Grid/Grid.js +52 -0
- package/Grid/index.d.ts +1 -1
- package/Grid/index.js +1 -0
- package/Hamburger/Hamburger.d.ts +0 -1
- package/Hamburger/Hamburger.js +47 -0
- package/Hamburger/index.d.ts +1 -1
- package/Hamburger/index.js +1 -0
- package/Header/index.d.ts +1 -1
- package/Header/index.js +1 -0
- package/Header/useHeader.d.ts +0 -4
- package/Header/useHeader.js +31 -0
- package/Hidden/Hidden.d.ts +1 -1
- package/Hidden/Hidden.js +10 -0
- package/Hidden/index.d.ts +1 -1
- package/Hidden/index.js +1 -0
- package/Img/index.d.ts +1 -1
- package/Img/index.js +1 -0
- package/Img/sc/bare.js +4 -0
- package/Img/types.js +1 -0
- package/Link/Link.js +4 -0
- package/Link/LinkBlank.js +15 -0
- package/Link/index.d.ts +2 -2
- package/Link/index.js +2 -0
- package/Menu/Menu.js +4 -0
- package/Menu/MenuMui.js +1 -0
- package/Menu/index.d.ts +1 -1
- package/Menu/index.js +1 -0
- package/MenuItem/MenuItem.js +4 -0
- package/MenuItem/MenuItemMui.js +1 -0
- package/MenuItem/index.d.ts +1 -1
- package/MenuItem/index.js +1 -0
- package/MenuItem/useMenuItem.js +42 -0
- package/Meta/Meta.d.ts +0 -10
- package/Meta/Meta.js +6 -0
- package/Meta/index.d.ts +2 -2
- package/Meta/index.js +2 -0
- package/NoJs/NoJs.js +7 -0
- package/NoJs/index.d.ts +2 -2
- package/NoJs/index.js +2 -0
- package/Pagination/PaginationNav.d.ts +1 -9
- package/Pagination/PaginationNav.js +48 -0
- package/Pagination/PaginationResults.js +11 -0
- package/Pagination/index.d.ts +2 -2
- package/Pagination/index.js +2 -0
- package/Pill/Pill.js +7 -0
- package/Pill/index.d.ts +1 -1
- package/Pill/index.js +1 -0
- package/Progress/ProgressCircular.d.ts +1 -7
- package/Progress/ProgressCircular.js +12 -0
- package/Progress/ProgressLinear.d.ts +1 -8
- package/Progress/ProgressLinear.js +21 -0
- package/Progress/ProgressOverlay.js +23 -0
- package/Progress/index.d.ts +3 -3
- package/Progress/index.js +3 -0
- package/Rating/Rating.d.ts +0 -8
- package/Rating/Rating.js +43 -0
- package/Rating/index.d.ts +1 -4
- package/Rating/index.js +45 -0
- package/Select/SelectDownshift.d.ts +1 -1
- package/Select/SelectDownshift.js +1 -0
- package/Select/components.js +12 -0
- package/Select/index.d.ts +2 -2
- package/Select/index.js +1 -0
- package/Sidebar/Sidebar.js +23 -0
- package/Sidebar/index.d.ts +1 -1
- package/Sidebar/index.js +1 -0
- package/Spacing/Spacing.d.ts +1 -14
- package/Spacing/Spacing.js +32 -0
- package/Spacing/index.d.ts +1 -1
- package/Spacing/index.js +1 -0
- package/Sticky/Sticky.js +1 -0
- package/Sticky/StickyCss.js +6 -0
- package/Sticky/index.d.ts +1 -1
- package/Sticky/index.js +1 -0
- package/Tabs/TabsMui.d.ts +2 -3
- package/Tabs/TabsMui.js +30 -0
- package/Tabs/index.d.ts +1 -1
- package/Tabs/index.js +1 -0
- package/Tabs/sc/bare.d.ts +0 -5
- package/Tabs/sc/bare.js +1 -0
- package/Tabs/tw/bare.d.ts +1 -2
- package/Tabs/tw/bare.js +16 -0
- package/Tabs/tw/material.d.ts +1 -2
- package/Tabs/tw/material.js +18 -0
- package/Tabs/useTabs.d.ts +0 -22
- package/Tabs/useTabs.js +43 -0
- package/Typography/CopyPasteVisible.js +4 -0
- package/Typography/Native.js +14 -0
- package/Typography/ReadMore.d.ts +0 -2
- package/Typography/ReadMore.js +42 -0
- package/Typography/TextLoop.js +45 -0
- package/Typography/TypeStairs.js +42 -0
- package/Typography/index.d.ts +5 -5
- package/Typography/index.js +5 -0
- package/css/index.d.ts +2 -2
- package/css/index.js +2 -0
- package/helpers/classed.d.ts +0 -19
- package/helpers/classed.js +43 -0
- package/helpers/createUseMediaQueryWidth.d.ts +0 -6
- package/helpers/createUseMediaQueryWidth.js +39 -0
- package/helpers/extend-component.d.ts +0 -11
- package/helpers/extend-component.js +9 -0
- package/helpers/index.d.ts +4 -4
- package/helpers/index.js +4 -0
- package/helpers/{mergeRefs.mjs → mergeRefs.js} +4 -3
- package/hooks/index.d.ts +20 -20
- package/hooks/index.js +20 -0
- package/hooks/types.d.ts +0 -6
- package/hooks/types.js +1 -0
- package/hooks/useAsyncFn.d.ts +1 -4
- package/hooks/useAsyncFn.js +33 -0
- package/hooks/useDateLocale.d.ts +0 -6
- package/hooks/useDateLocale.js +28 -0
- package/hooks/useFirstMountState.d.ts +0 -3
- package/hooks/useFirstMountState.js +10 -0
- package/hooks/useFixedOffset.d.ts +0 -9
- package/hooks/useFixedOffset.js +45 -0
- package/hooks/useFocus.d.ts +0 -3
- package/hooks/useFocus.js +9 -0
- package/hooks/useInterval.d.ts +0 -5
- package/hooks/useInterval.js +22 -0
- package/hooks/useIsomorphicLayoutEffect.d.ts +0 -3
- package/hooks/useIsomorphicLayoutEffect.js +6 -0
- package/hooks/useKeyUp.js +18 -0
- package/hooks/useMeasure.d.ts +0 -5
- package/hooks/useMeasure.js +134 -0
- package/hooks/useMountedState.d.ts +0 -3
- package/hooks/useMountedState.js +13 -0
- package/hooks/useNavigateAway.d.ts +0 -29
- package/hooks/useNavigateAway.js +25 -0
- package/hooks/usePrevious.d.ts +0 -3
- package/hooks/usePrevious.js +9 -0
- package/hooks/{usePreviousRef.mjs → usePreviousRef.js} +2 -2
- package/hooks/useScrollPosition.d.ts +0 -7
- package/hooks/useScrollPosition.js +61 -0
- package/hooks/useScrollThreshold.js +26 -0
- package/hooks/useScrollTo.js +22 -0
- package/hooks/useSmoothScroll.d.ts +0 -6
- package/hooks/useSmoothScroll.js +33 -0
- package/hooks/useSpinDelay.d.ts +0 -12
- package/hooks/useSpinDelay.js +38 -0
- package/hooks/useTraceUpdate.d.ts +0 -3
- package/hooks/useTraceUpdate.js +18 -0
- package/hooks/useUpdateEffect.d.ts +0 -3
- package/hooks/useUpdateEffect.js +11 -0
- package/hooks/useWindowSize.d.ts +0 -9
- package/hooks/useWindowSize.js +20 -0
- package/index.d.ts +1 -1
- package/index.js +1 -0
- package/m/MotionProvider.d.ts +0 -32
- package/m/MotionProvider.js +7 -0
- package/m/index.d.ts +1 -6
- package/m/index.js +1 -0
- package/package.json +624 -22
- package/sc/index.d.ts +30 -30
- package/sc/index.js +30 -0
- package/scm/index.d.ts +29 -29
- package/scm/index.js +29 -0
- package/shared/index.d.ts +8 -8
- package/shared/index.js +8 -0
- package/styles/Body.d.ts +0 -8
- package/styles/Body.js +5 -0
- package/styles/Global.d.ts +0 -13
- package/styles/Global.js +5 -0
- package/styles/index.d.ts +7 -7
- package/styles/index.js +7 -0
- package/styles/media.d.ts +1 -50
- package/styles/media.js +74 -0
- package/styles/spacing.d.ts +1 -2
- package/styles/spacing.js +45 -0
- package/styles/styled.d.ts +0 -4
- package/styles/styled.js +9 -0
- package/styles/theme--vanilla.js +46 -0
- package/styles/theme.d.ts +0 -29
- package/styles/theme.js +30 -0
- package/tw/index.d.ts +2 -2
- package/tw/index.js +2 -0
- package/twm/index.d.ts +2 -2
- package/twm/index.js +2 -0
- package/types.d.ts +1 -2
- package/types.js +1 -0
- package/Alert/Alert.mjs +0 -22
- package/Alert/Alert.stories.mjs +0 -18
- package/Alert/index.mjs +0 -1
- package/Animations/Reveal.mjs +0 -43
- package/Animations/Underline.mjs +0 -15
- package/Animations/index.mjs +0 -3
- package/Animations/useReveal.mjs +0 -73
- package/Autocomplete/AutocompleteDownshift.mjs +0 -157
- package/Autocomplete/AutocompleteDownshiftMultiselect.mjs +0 -352
- package/Autocomplete/AutocompleteMui.mjs +0 -219
- package/Autocomplete/AutocompleteReach.mjs +0 -111
- package/Autocomplete/components.mjs +0 -87
- package/Autocomplete/helpers.mjs +0 -35
- package/Autocomplete/index.mjs +0 -4
- package/Bg/BgColor.mjs +0 -42
- package/Bg/BgPhoto.mjs +0 -71
- package/Bg/BgSvg.mjs +0 -22
- package/Bg/index.mjs +0 -3
- package/Breadcrumbs/Breadcrumbs.mjs +0 -91
- package/Breadcrumbs/index.mjs +0 -1
- package/Buttons/Button.mjs +0 -78
- package/Buttons/ButtonComposite.mjs +0 -105
- package/Buttons/ButtonFab.mjs +0 -8
- package/Buttons/ButtonLink.mjs +0 -18
- package/Buttons/IconButton.mjs +0 -19
- package/Buttons/index.mjs +0 -5
- package/Calendar/CalendarDaygridCell.mjs +0 -95
- package/Calendar/CalendarDaygridNav.mjs +0 -52
- package/Calendar/CalendarDaygridTable.mjs +0 -115
- package/Calendar/CalendarLegend.mjs +0 -29
- package/Calendar/calendar-api-google.mjs +0 -99
- package/Calendar/index.mjs +0 -6
- package/Calendar/types.mjs +0 -1
- package/Calendar/useCalendar.mjs +0 -225
- package/Calendar/utils.mjs +0 -209
- package/Carousel/Carousel.mjs +0 -377
- package/Carousel/CarouselCss.mjs +0 -44
- package/Carousel/index.mjs +0 -1
- package/Collapsable/Collapsable.mjs +0 -1
- package/Collapsable/CollapsableReach.mjs +0 -250
- package/Collapsable/index.mjs +0 -1
- package/Debug/Debug.mjs +0 -23
- package/Debug/index.mjs +0 -1
- package/Details/Details.mjs +0 -90
- package/Details/Details.stories.mjs +0 -21
- package/Details/index.mjs +0 -1
- package/Dialog/DialogMui.mjs +0 -105
- package/Dialog/DialogMui.stories.mjs +0 -20
- package/Dialog/css/bare.mjs +0 -19
- package/Dialog/css/index.stories.mjs +0 -75
- package/Dialog/index.mjs +0 -1
- package/Dialog/m/bare.mjs +0 -115
- package/Dialog/m/basic.mjs +0 -31
- package/Dialog/m/index.mjs +0 -4
- package/Dialog/sc/bare.mjs +0 -54
- package/Dialog/sc/framer.mjs +0 -16
- package/Dialog/sc/framerMaterial.mjs +0 -16
- package/Dialog/sc/index.stories.mjs +0 -48
- package/Dialog/sc/material.mjs +0 -41
- package/Dialog/tw/bare.mjs +0 -29
- package/Dialog/tw/elegant.mjs +0 -18
- package/Dialog/tw/framer.mjs +0 -16
- package/Dialog/tw/framerMaterial.mjs +0 -16
- package/Dialog/tw/index.stories.mjs +0 -83
- package/Dialog/tw/material.mjs +0 -18
- package/Editor/Editor--tiptap.mjs +0 -53
- package/Editor/components.mjs +0 -28
- package/Editor/index.mjs +0 -1
- package/FaviconTags.mjs +0 -64
- package/Form/Form.mjs +0 -95
- package/Form/index.mjs +0 -1
- package/Form/sc/bare.mjs +0 -29
- package/Forms/Checkbox/Checkbox.mjs +0 -36
- package/Forms/Checkbox/index.mjs +0 -1
- package/Forms/Feedback/Feedback.mjs +0 -14
- package/Forms/Feedback/index.mjs +0 -1
- package/Forms/Field/Field.mjs +0 -50
- package/Forms/Field/FieldControl.mjs +0 -67
- package/Forms/Field/FieldHint.mjs +0 -6
- package/Forms/Field/index.mjs +0 -2
- package/Forms/Input/Input.mjs +0 -36
- package/Forms/Input/index.mjs +0 -1
- package/Forms/InputGroup/InputGroup.mjs +0 -57
- package/Forms/InputGroup/index.mjs +0 -1
- package/Forms/Label/Label.mjs +0 -24
- package/Forms/Label/index.mjs +0 -1
- package/Forms/Password/Password.mjs +0 -53
- package/Forms/Password/index.mjs +0 -1
- package/Forms/Radio/Radio.mjs +0 -57
- package/Forms/Radio/index.mjs +0 -1
- package/Forms/Switch/Switch.mjs +0 -60
- package/Forms/Switch/index.mjs +0 -1
- package/Forms/Textarea/Textarea.mjs +0 -26
- package/Forms/Textarea/TextareaRich.mjs +0 -48
- package/Forms/Textarea/index.mjs +0 -2
- package/Forms/Toggle/Toggle-tailwind.mjs +0 -98
- package/Forms/Toggle/Toggle.mjs +0 -123
- package/Forms/Toggle/index.mjs +0 -1
- package/Forms/Toggle/useToggle-tailwind.mjs +0 -201
- package/Forms/Toggle/useToggle.mjs +0 -163
- package/Forms/antispam.mjs +0 -58
- package/Forms/helpers.mjs +0 -52
- package/Forms/index.mjs +0 -16
- package/Forms/styles.mjs +0 -61
- package/Gauge/Gauge.mjs +0 -101
- package/Grid/Grid.mjs +0 -75
- package/Grid/index.mjs +0 -1
- package/Hamburger/Hamburger.mjs +0 -79
- package/Hamburger/index.mjs +0 -1
- package/Header/index.mjs +0 -1
- package/Header/useHeader.mjs +0 -36
- package/Hidden/Hidden.mjs +0 -10
- package/Hidden/index.mjs +0 -1
- package/Img/index.mjs +0 -1
- package/Img/sc/bare.mjs +0 -36
- package/Img/types.mjs +0 -1
- package/Link/Link.mjs +0 -2
- package/Link/LinkBlank.mjs +0 -32
- package/Link/index.mjs +0 -2
- package/Menu/Menu.mjs +0 -11
- package/Menu/MenuMui.mjs +0 -164
- package/Menu/index.mjs +0 -1
- package/MenuItem/MenuItem.mjs +0 -20
- package/MenuItem/MenuItemMui.mjs +0 -31
- package/MenuItem/index.mjs +0 -1
- package/MenuItem/useMenuItem.mjs +0 -78
- package/Meta/Meta.mjs +0 -8
- package/Meta/index.mjs +0 -2
- package/NoJs/NoJs.mjs +0 -10
- package/NoJs/index.mjs +0 -2
- package/Pagination/PaginationNav.mjs +0 -122
- package/Pagination/PaginationResults.mjs +0 -34
- package/Pagination/index.mjs +0 -2
- package/Pill/Pill.mjs +0 -37
- package/Pill/index.mjs +0 -1
- package/Progress/ProgressCircular.mjs +0 -53
- package/Progress/ProgressLinear.mjs +0 -44
- package/Progress/ProgressOverlay.mjs +0 -64
- package/Progress/index.mjs +0 -3
- package/README.md +0 -1
- package/Rating/Rating.mjs +0 -154
- package/Rating/index.mjs +0 -62
- package/Select/SelectDownshift.mjs +0 -37
- package/Select/components.mjs +0 -25
- package/Select/index.mjs +0 -2
- package/Sidebar/Sidebar.mjs +0 -63
- package/Sidebar/index.mjs +0 -1
- package/Spacing/Spacing.mjs +0 -55
- package/Spacing/index.mjs +0 -1
- package/Sticky/Sticky.mjs +0 -218
- package/Sticky/StickyCss.mjs +0 -10
- package/Sticky/index.mjs +0 -1
- package/Tabs/TabsMui.mjs +0 -61
- package/Tabs/TabsMui.stories.mjs +0 -20
- package/Tabs/index.mjs +0 -1
- package/Tabs/sc/bare.mjs +0 -85
- package/Tabs/sc/index.stories.mjs +0 -0
- package/Tabs/tw/bare.mjs +0 -15
- package/Tabs/tw/index.stories.mjs +0 -25
- package/Tabs/tw/material.mjs +0 -14
- package/Tabs/useTabs.mjs +0 -46
- package/Typography/CopyPasteVisible.mjs +0 -6
- package/Typography/Native.mjs +0 -47
- package/Typography/ReadMore.mjs +0 -114
- package/Typography/TextLoop.mjs +0 -90
- package/Typography/TypeStairs.mjs +0 -61
- package/Typography/index.mjs +0 -5
- package/css/index.mjs +0 -30
- package/helpers/classed.mjs +0 -65
- package/helpers/classed.stories.mjs +0 -121
- package/helpers/createUseMediaQueryWidth.mjs +0 -178
- package/helpers/extend-component.mjs +0 -13
- package/helpers/index.mjs +0 -4
- package/hooks/index.mjs +0 -21
- package/hooks/types.mjs +0 -3
- package/hooks/useAsyncFn.mjs +0 -39
- package/hooks/useDateLocale.mjs +0 -37
- package/hooks/useFirstMountState.mjs +0 -12
- package/hooks/useFixedOffset.mjs +0 -56
- package/hooks/useFocus.mjs +0 -14
- package/hooks/useInterval.mjs +0 -29
- package/hooks/useIsomorphicLayoutEffect.mjs +0 -6
- package/hooks/useKeyUp.mjs +0 -21
- package/hooks/useMeasure.mjs +0 -174
- package/hooks/useMountedState.mjs +0 -15
- package/hooks/useNavigateAway.mjs +0 -69
- package/hooks/usePrevious.mjs +0 -17
- package/hooks/useScrollPosition.mjs +0 -70
- package/hooks/useScrollThreshold.mjs +0 -33
- package/hooks/useScrollTo.mjs +0 -20
- package/hooks/useSmoothScroll.mjs +0 -35
- package/hooks/useSpinDelay.mjs +0 -52
- package/hooks/useTraceUpdate.mjs +0 -23
- package/hooks/useUpdateEffect.mjs +0 -14
- package/hooks/useWindowSize.mjs +0 -32
- package/index.mjs +0 -4
- package/m/MotionProvider.mjs +0 -40
- package/m/index.mjs +0 -5
- package/sc/index.mjs +0 -31
- package/scm/index.mjs +0 -31
- package/shared/index.mjs +0 -43
- package/styles/Body.mjs +0 -16
- package/styles/Global.mjs +0 -49
- package/styles/index.mjs +0 -7
- package/styles/media.mjs +0 -151
- package/styles/spacing.mjs +0 -46
- package/styles/styled.mjs +0 -26
- package/styles/theme--vanilla.mjs +0 -65
- package/styles/theme.mjs +0 -38
- package/tw/index.mjs +0 -30
- package/twm/index.mjs +0 -30
- package/types.mjs +0 -1
- /package/m/{lite.mjs → lite.js} +0 -0
- /package/m/{max.mjs → max.js} +0 -0
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { __makeTemplateObject } from "tslib";
|
|
2
|
+
import styled, { css } from "styled-components";
|
|
3
|
+
import { IconButton } from "./IconButton.js";
|
|
4
|
+
export var buttonFab = css(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n box-shadow: 3px 3px 6px -4px rgb(0, 0, 0, 0.5);\n"], ["\n box-shadow: 3px 3px 6px -4px rgb(0, 0, 0, 0.5);\n"])));
|
|
5
|
+
export var IconButtonFab = styled(IconButton)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n ", "\n"], ["\n ", "\n"])), buttonFab);
|
|
6
|
+
var templateObject_1, templateObject_2;
|
package/Buttons/ButtonLink.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { KoineLinkProps } from "../Link";
|
|
2
|
-
import { KoineComponent, KoineComponentProps } from "../types";
|
|
3
|
-
import { KoineButtonUiProps } from "./Button";
|
|
1
|
+
import { KoineLinkProps } from "../Link/index.js";
|
|
2
|
+
import { KoineComponent, KoineComponentProps } from "../types.js";
|
|
3
|
+
import { KoineButtonUiProps } from "./Button.js";
|
|
4
4
|
export type KoineButtonLinkProps = KoineButtonUiProps & KoineLinkProps;
|
|
5
5
|
export type ButtonLinkProps = KoineComponentProps<KoineButtonLinkProps, {
|
|
6
6
|
Link?: KoineComponent;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { __assign, __makeTemplateObject, __rest } from "tslib";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import styled from "styled-components";
|
|
4
|
+
import { KoineButton } from "./Button.js";
|
|
5
|
+
var Root = styled(KoineButton)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n text-decoration: none;\n"], ["\n text-decoration: none;\n"])));
|
|
6
|
+
export var KoineButtonLink = function (_a) {
|
|
7
|
+
var href = _a.href, _b = _a.Link, Link = _b === void 0 ? "a" : _b, props = __rest(_a, ["href", "Link"]);
|
|
8
|
+
var isRelative = href && href.startsWith("/");
|
|
9
|
+
return isRelative ? (_jsx(Root, __assign({ href: href }, props, { as: Link }))) : (_jsx(Root, __assign({ href: href }, props, { as: "a" })));
|
|
10
|
+
};
|
|
11
|
+
var templateObject_1;
|
package/Buttons/IconButton.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
import { KoineButtonUiProps } from "./Button";
|
|
1
|
+
import { KoineButtonUiProps } from "./Button.js";
|
|
3
2
|
export declare const iconBtnStyleReset: import("styled-components").FlattenSimpleInterpolation;
|
|
4
3
|
export declare const iconBtnStyleBase: import("styled-components").FlattenSimpleInterpolation;
|
|
5
4
|
export declare const IconButton: any;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { __makeTemplateObject } from "tslib";
|
|
2
|
+
import styled, { css } from "styled-components";
|
|
3
|
+
import { btnStyleContained, btnStyleOutlined, btnStyleReset, } from "./Button.js";
|
|
4
|
+
export var iconBtnStyleReset = css(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 44px;\n height: 44px;\n border-radius: 100%;\n ", "\n"], ["\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 44px;\n height: 44px;\n border-radius: 100%;\n ", "\n"])), btnStyleReset);
|
|
5
|
+
export var iconBtnStyleBase = css(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n ", "\n"], ["\n ", "\n"])), iconBtnStyleReset);
|
|
6
|
+
export var IconButton = styled.button(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n ", "\n ", "\n ", "\n"], ["\n ", "\n ", "\n ", "\n"])), iconBtnStyleBase, function (p) { return p.$variant === "outlined" && btnStyleOutlined; }, function (p) { return p.$variant === "contained" && btnStyleContained; });
|
|
7
|
+
var templateObject_1, templateObject_2, templateObject_3;
|
package/Buttons/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export * from "./Button";
|
|
2
|
-
export * from "./ButtonComposite";
|
|
3
|
-
export * from "./ButtonFab";
|
|
4
|
-
export * from "./ButtonLink";
|
|
5
|
-
export * from "./IconButton";
|
|
1
|
+
export * from "./Button.js";
|
|
2
|
+
export * from "./ButtonComposite.js";
|
|
3
|
+
export * from "./ButtonFab.js";
|
|
4
|
+
export * from "./ButtonLink.js";
|
|
5
|
+
export * from "./IconButton.js";
|
package/Buttons/index.js
ADDED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
import type {
|
|
3
|
-
import
|
|
4
|
-
import { UseCalendarReturn } from "./useCalendar";
|
|
1
|
+
import type { KoineComponent, KoineComponentProps } from "../types.js";
|
|
2
|
+
import type { CalendarView, CalendarViewDayProps, CalendarViewEvent, CalendarsMap } from "./types.js";
|
|
3
|
+
import { UseCalendarReturn } from "./useCalendar.js";
|
|
5
4
|
export type KoineCalendarDaygridCellProps = {
|
|
6
5
|
eventClicked?: UseCalendarReturn["eventClicked"];
|
|
7
6
|
setEventClicked: UseCalendarReturn["setEventClicked"];
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { __assign } from "tslib";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { Fragment, useState } from "react";
|
|
4
|
+
import { MdAdd as IconExpand, } from "react-icons/md";
|
|
5
|
+
import { getDisplayTime } from "./utils.js";
|
|
6
|
+
var styleBtn = {
|
|
7
|
+
overflow: "hidden",
|
|
8
|
+
whiteSpace: "nowrap",
|
|
9
|
+
textOverflow: "ellipsis",
|
|
10
|
+
};
|
|
11
|
+
export var CalendarDaygridCell = function (_a) {
|
|
12
|
+
var eventClicked = _a.eventClicked, setEventClicked = _a.setEventClicked, setEventHovered = _a.setEventHovered, view = _a.view, maxEvents = _a.maxEvents, events = _a.events, calendarsMap = _a.calendarsMap, _b = _a.Cell, Cell = _b === void 0 ? "div" : _b, _c = _a.CellOverflow, CellOverflow = _c === void 0 ? "div" : _c, _d = _a.CellEvent, CellEvent = _d === void 0 ? "div" : _d, _e = _a.CellEventBtn, CellEventBtn = _e === void 0 ? "div" : _e, _f = _a.CellEventTitle, CellEventTitle = _f === void 0 ? "span" : _f, _g = _a.CellEventStart, CellEventStart = _g === void 0 ? "span" : _g;
|
|
13
|
+
var _h = useState(false), isExpanded = _h[0], expand = _h[1];
|
|
14
|
+
var eventsWithoutPlaceholders = events.filter(function (event) { return !event.placeholder; });
|
|
15
|
+
return (_jsx(Cell, { children: events.map(function (event, i) {
|
|
16
|
+
if (i === maxEvents && !isExpanded) {
|
|
17
|
+
return (_jsxs(CellOverflow, { onClick: function () { return expand(true); }, children: [_jsx(IconExpand, {}), eventsWithoutPlaceholders.length - maxEvents] }, "overflowMessage" + i));
|
|
18
|
+
}
|
|
19
|
+
if (i > maxEvents && !isExpanded)
|
|
20
|
+
return null;
|
|
21
|
+
if (event.placeholder) {
|
|
22
|
+
return (_jsx(Fragment, { children: _jsx(CellEvent, { "$placeholder": true, children: _jsx(CellEventBtn, { "aria-hidden": "true", style: { visibility: "hidden" }, "$placeholder": true, children: _jsx(CellEventTitle, { children: "\u00A0" }) }) }) }, event.key));
|
|
23
|
+
}
|
|
24
|
+
var styleEvent = {
|
|
25
|
+
zIndex: event.firstOfMulti ? 1 : 0,
|
|
26
|
+
position: "relative",
|
|
27
|
+
width: event.firstOfMulti ? "".concat(100 * event.width, "%") : "100%",
|
|
28
|
+
};
|
|
29
|
+
if (!calendarsMap[event.calendar.id].on) {
|
|
30
|
+
styleBtn.display = "none";
|
|
31
|
+
}
|
|
32
|
+
var styledProps = {
|
|
33
|
+
$view: view,
|
|
34
|
+
$selected: (eventClicked === null || eventClicked === void 0 ? void 0 : eventClicked.uid) === event.uid,
|
|
35
|
+
$past: event.isPast,
|
|
36
|
+
$color: event.color,
|
|
37
|
+
$isOutOfRange: event.$isOutOfRange,
|
|
38
|
+
$isToday: event.$isToday,
|
|
39
|
+
};
|
|
40
|
+
return (_jsx(Fragment, { children: _jsx(CellEvent, __assign({ style: styleEvent }, styledProps, { children: _jsx(CellEventBtn, __assign({ role: "button", style: styleBtn }, styledProps, { onClick: function () {
|
|
41
|
+
return setEventClicked(function (prev) {
|
|
42
|
+
return (prev === null || prev === void 0 ? void 0 : prev.uid) === event.uid ? null : event;
|
|
43
|
+
});
|
|
44
|
+
}, onMouseEnter: function () { return setEventHovered(event); }, onMouseLeave: function () { return setEventHovered(null); }, children: event.allDay ? (_jsx(CellEventTitle, { children: event.title })) : (_jsxs(_Fragment, { children: [_jsx(CellEventStart, { children: getDisplayTime(event.start) }), _jsx(CellEventTitle, { children: event.title })] })) })) })) }, event.key));
|
|
45
|
+
}) }));
|
|
46
|
+
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { KoineComponent, KoineComponentProps } from "../types";
|
|
2
|
-
import type { CalendarRange, CalendarView } from "./types";
|
|
1
|
+
import type { KoineComponent, KoineComponentProps } from "../types.js";
|
|
2
|
+
import type { CalendarRange, CalendarView } from "./types.js";
|
|
3
3
|
export type KoineCalendarDaygridNavProps = {
|
|
4
4
|
locale: string;
|
|
5
5
|
range: CalendarRange;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import format from "date-fns/format";
|
|
3
|
+
import { useDateLocale } from "../hooks/useDateLocale.js";
|
|
4
|
+
export var KoineCalendarDaygridNav = function (_a) {
|
|
5
|
+
var range = _a.range, view = _a.view, todayInView = _a.todayInView, handlePrev = _a.handlePrev, handleNext = _a.handleNext, handleToday = _a.handleToday, handleView = _a.handleView, localeCode = _a.locale, _b = _a.NavRoot, NavRoot = _b === void 0 ? "nav" : _b, _c = _a.NavTitle, NavTitle = _c === void 0 ? "div" : _c, _d = _a.NavBtns, NavBtns = _d === void 0 ? "div" : _d, _e = _a.NavBtnPrev, NavBtnPrev = _e === void 0 ? "button" : _e, _f = _a.NavBtnNext, NavBtnNext = _f === void 0 ? "button" : _f, _g = _a.NavBtnToday, NavBtnToday = _g === void 0 ? "button" : _g, _h = _a.NavBtnViewMonth, NavBtnViewMonth = _h === void 0 ? "button" : _h, _j = _a.NavBtnViewWeek, NavBtnViewWeek = _j === void 0 ? "button" : _j;
|
|
6
|
+
var start = range[0], end = range[1];
|
|
7
|
+
var locale = useDateLocale(localeCode);
|
|
8
|
+
var opts = { locale: locale };
|
|
9
|
+
var formatted = "";
|
|
10
|
+
if (view === "month") {
|
|
11
|
+
formatted = format(start, "MMMM yyyy", opts);
|
|
12
|
+
}
|
|
13
|
+
if (view === "week") {
|
|
14
|
+
var inSameMonth = start.getMonth() === end.getMonth();
|
|
15
|
+
if (inSameMonth) {
|
|
16
|
+
formatted = format(start, "# MMMM yyyy", opts).replace("#", "".concat(start.getDate(), "-").concat(end.getDate()));
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
formatted = "".concat(format(start, "d MMMM", opts), " - ").concat(format(end, "d MMMM yyyy", opts));
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
return (_jsxs(NavRoot, { children: [_jsxs(NavBtns, { children: [_jsx(NavBtnPrev, { onClick: handlePrev }), _jsx(NavBtnNext, { onClick: handleNext }), _jsx(NavBtnToday, { onClick: handleToday, disabled: todayInView }), _jsx(NavBtnViewMonth, { onClick: function () { return handleView("month"); }, disabled: view === "month" }), _jsx(NavBtnViewWeek, { onClick: function () { return handleView("week"); }, disabled: view === "week" })] }), _jsx(NavTitle, { range: range, formatted: formatted })] }));
|
|
23
|
+
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type { KoineComponent, KoineComponentProps } from "../types";
|
|
2
|
-
import { CalendarDaygridCellComponents, CalendarDaygridCellProps } from "./CalendarDaygridCell";
|
|
3
|
-
import type { CalendarEventsMap, CalendarRange, CalendarView, CalendarViewDayProps } from "./types";
|
|
1
|
+
import type { KoineComponent, KoineComponentProps } from "../types.js";
|
|
2
|
+
import { CalendarDaygridCellComponents, CalendarDaygridCellProps } from "./CalendarDaygridCell.js";
|
|
3
|
+
import type { CalendarEventsMap, CalendarRange, CalendarView, CalendarViewDayProps } from "./types.js";
|
|
4
4
|
export type CalendarDaygridTableBodyCellProps = CalendarViewDayProps;
|
|
5
5
|
export type CalendarDaygridTableBodyCellDateProps = CalendarViewDayProps;
|
|
6
6
|
export type KoineCalendarDaygridTableProps = {
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { __assign } from "tslib";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import eachWeekOfInterval from "date-fns/eachWeekOfInterval";
|
|
4
|
+
import { useEffect, useMemo, useState } from "react";
|
|
5
|
+
import { useSwipeable } from "react-swipeable";
|
|
6
|
+
import { useDateLocale } from "../hooks/index.js";
|
|
7
|
+
import { CalendarDaygridCell, } from "./CalendarDaygridCell.js";
|
|
8
|
+
import { processEventsInView } from "./utils.js";
|
|
9
|
+
function getView(range) {
|
|
10
|
+
var start = range[0], end = range[1];
|
|
11
|
+
var weeks = eachWeekOfInterval({ start: start, end: end }, { weekStartsOn: 1 });
|
|
12
|
+
return {
|
|
13
|
+
month: start.getMonth(),
|
|
14
|
+
weeks: weeks,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export var KoineCalendarDaygridTable = function (_a) {
|
|
18
|
+
var localeCode = _a.locale, handlePrev = _a.handlePrev, handleNext = _a.handleNext, events = _a.events, dayLabels = _a.dayLabels, view = _a.view, range = _a.range, eventClicked = _a.eventClicked, setEventClicked = _a.setEventClicked, eventHovered = _a.eventHovered, setEventHovered = _a.setEventHovered, _b = _a.calendarsMap, calendarsMap = _b === void 0 ? {} : _b, _c = _a.maxEvents, maxEvents = _c === void 0 ? 5 : _c, _d = _a.Table, Table = _d === void 0 ? "table" : _d, _e = _a.TableHead, TableHead = _e === void 0 ? "thead" : _e, _f = _a.TableHeadCell, TableHeadCell = _f === void 0 ? "th" : _f, _g = _a.TableBody, TableBody = _g === void 0 ? "tbody" : _g, _h = _a.TableBodyRow, TableBodyRow = _h === void 0 ? "tr" : _h, _j = _a.TableBodyCell, TableBodyCell = _j === void 0 ? "td" : _j, _k = _a.TableBodyCellDate, TableBodyCellDate = _k === void 0 ? "div" : _k, Cell = _a.Cell, CellOverflow = _a.CellOverflow, CellEvent = _a.CellEvent, CellEventBtn = _a.CellEventBtn, CellEventTitle = _a.CellEventTitle, CellEventStart = _a.CellEventStart;
|
|
19
|
+
var restKoine = {
|
|
20
|
+
Cell: Cell,
|
|
21
|
+
CellOverflow: CellOverflow,
|
|
22
|
+
CellEvent: CellEvent,
|
|
23
|
+
CellEventBtn: CellEventBtn,
|
|
24
|
+
CellEventTitle: CellEventTitle,
|
|
25
|
+
CellEventStart: CellEventStart,
|
|
26
|
+
};
|
|
27
|
+
var _l = useState(dayLabels || [0, 1, 2, 3, 4, 5, 6]), days = _l[0], setDays = _l[1];
|
|
28
|
+
var _m = useState([]), weeksEvents = _m[0], setWeeksEvents = _m[1];
|
|
29
|
+
var locale = useDateLocale(localeCode);
|
|
30
|
+
var _o = useMemo(function () { return getView(range); }, [range]), month = _o.month, weeks = _o.weeks;
|
|
31
|
+
var swipeableHandlers = useSwipeable({
|
|
32
|
+
onSwipedLeft: handleNext,
|
|
33
|
+
onSwipedRight: handlePrev,
|
|
34
|
+
});
|
|
35
|
+
useEffect(function () {
|
|
36
|
+
setWeeksEvents(processEventsInView(events, view, month, weeks));
|
|
37
|
+
}, [events, view, month, weeks]);
|
|
38
|
+
useEffect(function () {
|
|
39
|
+
if (locale && locale.localize && !dayLabels) {
|
|
40
|
+
setDays([1, 2, 3, 4, 5, 6, 0].map(function (i) { return locale.localize.day(i, { width: "abbreviated" }); }));
|
|
41
|
+
}
|
|
42
|
+
}, [locale, dayLabels]);
|
|
43
|
+
return (_jsxs(Table, __assign({}, swipeableHandlers, { children: [_jsx(TableHead, { children: _jsx("tr", { children: days.map(function (day) { return (_jsx(TableHeadCell, { scope: "column", children: day }, day)); }) }) }), _jsx(TableBody, { children: weeksEvents.map(function (week, i) { return (_jsx(TableBodyRow, __assign({}, week.props, { children: week.days.map(function (day) { return (_jsxs(TableBodyCell, __assign({}, day.props, { children: [_jsx(TableBodyCellDate, __assign({}, day.props, { children: day.label })), day.events.length > 0 && (_jsx(CalendarDaygridCell, __assign({ eventClicked: eventClicked, setEventClicked: setEventClicked, eventHovered: eventHovered, setEventHovered: setEventHovered, view: view, maxEvents: maxEvents, events: day.events,
|
|
44
|
+
timestamp: day.timestamp, calendarsMap: calendarsMap }, restKoine)))] }))); }) }))); }) })] })));
|
|
45
|
+
};
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
import type {
|
|
3
|
-
import type { CalendarsMap } from "./types";
|
|
1
|
+
import type { KoineComponent, KoineComponentProps } from "../types.js";
|
|
2
|
+
import type { CalendarsMap } from "./types.js";
|
|
4
3
|
export type KoineCalendarLegendProps = {
|
|
5
4
|
toggleCalendarVisibility: (id: string) => void;
|
|
6
5
|
calendarsMap: CalendarsMap;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
export var KoineCalendarLegend = function (_a) {
|
|
3
|
+
var _b = _a.calendarsMap, calendarsMap = _b === void 0 ? {} : _b, toggleCalendarVisibility = _a.toggleCalendarVisibility, _c = _a.LegendItem, LegendItem = _c === void 0 ? "div" : _c, _d = _a.LegendItemStatus, LegendItemStatus = _d === void 0 ? "span" : _d, _e = _a.LegendItemLabel, LegendItemLabel = _e === void 0 ? "span" : _e, _f = _a.LegendItemEvents, LegendItemEvents = _f === void 0 ? "span" : _f;
|
|
4
|
+
return (_jsx(_Fragment, { children: Object.entries(calendarsMap).map(function (_a) {
|
|
5
|
+
var id = _a[0], calendar = _a[1];
|
|
6
|
+
return (_jsxs(LegendItem, { onClick: function () { return toggleCalendarVisibility(id); }, "$color": calendar.color, "$empty": calendar.events === 0, disabled: calendar.events === 0, children: [_jsx(LegendItemStatus, { children: calendar.on ? "\u2b24" : "\u2b58" }), _jsx(LegendItemLabel, { children: calendar.name }), _jsx(LegendItemEvents, { children: calendar.events })] }, "CalendarLegend." + id));
|
|
7
|
+
}) }));
|
|
8
|
+
};
|
|
@@ -1,17 +1,9 @@
|
|
|
1
|
-
import type { CalendarEventsMap, Calendars } from "./types";
|
|
1
|
+
import type { CalendarEventsMap, Calendars } from "./types.js";
|
|
2
2
|
type GetCalendarsEventsFromGoogleOptions = {
|
|
3
|
-
/** Fall back to `process.env.GOOGLE_CALENDAR_API_KEY */
|
|
4
3
|
apiKey?: string;
|
|
5
|
-
/** Start gethering events from date */
|
|
6
4
|
start: Date;
|
|
7
|
-
/** End gethering events at date */
|
|
8
5
|
end: Date;
|
|
9
|
-
/**
|
|
10
|
-
* The default is the time zone of the calendar
|
|
11
|
-
* @see https://developers.google.com/calendar/api/v3/reference/events/list
|
|
12
|
-
*/
|
|
13
6
|
timeZone?: string;
|
|
14
|
-
/** The calendars settings */
|
|
15
7
|
calendars: Calendars;
|
|
16
8
|
};
|
|
17
9
|
export declare function getCalendarsEventsFromGoogle({ calendars, ...options }: GetCalendarsEventsFromGoogleOptions): Promise<CalendarEventsMap>;
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { __assign, __awaiter, __generator, __rest } from "tslib";
|
|
2
|
+
import differenceInDays from "date-fns/differenceInDays";
|
|
3
|
+
import subDays from "date-fns/subDays";
|
|
4
|
+
import arrayToLookup from "@koine/utils/arrayToLookup";
|
|
5
|
+
import isString from "@koine/utils/isString";
|
|
6
|
+
import isUndefined from "@koine/utils/isUndefined";
|
|
7
|
+
import { addCalendarEvents, getEventTimestamp } from "./utils.js";
|
|
8
|
+
var baseURL = "https://www.googleapis.com/calendar/v3/calendars/";
|
|
9
|
+
export function getCalendarsEventsFromGoogle(_a) {
|
|
10
|
+
var calendars = _a.calendars, options = __rest(_a, ["calendars"]);
|
|
11
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
12
|
+
var allEvents;
|
|
13
|
+
var _this = this;
|
|
14
|
+
return __generator(this, function (_b) {
|
|
15
|
+
switch (_b.label) {
|
|
16
|
+
case 0:
|
|
17
|
+
allEvents = {};
|
|
18
|
+
return [4, Promise.all(calendars.map(function (calendar) { return __awaiter(_this, void 0, void 0, function () {
|
|
19
|
+
var events;
|
|
20
|
+
return __generator(this, function (_a) {
|
|
21
|
+
switch (_a.label) {
|
|
22
|
+
case 0: return [4, getCalendarEventsFromGoogle(__assign({ calendar: calendar }, options))];
|
|
23
|
+
case 1:
|
|
24
|
+
events = _a.sent();
|
|
25
|
+
addCalendarEvents(events, allEvents);
|
|
26
|
+
return [2];
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}); }))];
|
|
30
|
+
case 1:
|
|
31
|
+
_b.sent();
|
|
32
|
+
return [2, allEvents];
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
function getCalendarEventsFromGoogle(_a) {
|
|
38
|
+
var apiKey = _a.apiKey, calendar = _a.calendar, _b = _a.timeZone, timeZone = _b === void 0 ? "" : _b, start = _a.start, end = _a.end;
|
|
39
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
40
|
+
var events, params, url, response, data, e_1;
|
|
41
|
+
return __generator(this, function (_c) {
|
|
42
|
+
switch (_c.label) {
|
|
43
|
+
case 0:
|
|
44
|
+
events = {};
|
|
45
|
+
params = new URLSearchParams({
|
|
46
|
+
calendarId: calendar.id,
|
|
47
|
+
timeZone: timeZone,
|
|
48
|
+
singleEvents: "true",
|
|
49
|
+
maxAttendees: "1",
|
|
50
|
+
maxResults: "9999",
|
|
51
|
+
sanitizeHtml: "true",
|
|
52
|
+
timeMin: start.toISOString(),
|
|
53
|
+
timeMax: end.toISOString(),
|
|
54
|
+
key: apiKey || process.env["GOOGLE_CALENDAR_API_KEY"] || "",
|
|
55
|
+
}).toString();
|
|
56
|
+
url = baseURL + calendar.id + "/events?" + params;
|
|
57
|
+
_c.label = 1;
|
|
58
|
+
case 1:
|
|
59
|
+
_c.trys.push([1, 4, , 5]);
|
|
60
|
+
return [4, fetch(url, { method: "GET" })];
|
|
61
|
+
case 2:
|
|
62
|
+
response = _c.sent();
|
|
63
|
+
return [4, response.json()];
|
|
64
|
+
case 3:
|
|
65
|
+
data = (_c.sent());
|
|
66
|
+
calendar.name = calendar.name || data.summary;
|
|
67
|
+
data.items.forEach(function (googleEvent) {
|
|
68
|
+
var event = transformCalendarEventFromGoogle(googleEvent, calendar);
|
|
69
|
+
events[event.uid] = event;
|
|
70
|
+
});
|
|
71
|
+
return [3, 5];
|
|
72
|
+
case 4:
|
|
73
|
+
e_1 = _c.sent();
|
|
74
|
+
return [3, 5];
|
|
75
|
+
case 5: return [2, events];
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
function transformCalendarEventFromGoogle(event, calendar) {
|
|
81
|
+
var created = new Date(event.created);
|
|
82
|
+
var link = event.htmlLink;
|
|
83
|
+
var title = event.summary;
|
|
84
|
+
var status = event.status;
|
|
85
|
+
var start = new Date(event.start.date || event.start.dateTime);
|
|
86
|
+
var end = new Date(event.end.date || event.end.dateTime);
|
|
87
|
+
var color = calendar.color;
|
|
88
|
+
var allDay = isUndefined(event.end.dateTime) && isString(event.end.date);
|
|
89
|
+
var location = event.location || "";
|
|
90
|
+
var description = event.description || "";
|
|
91
|
+
var uid = created.getTime() + "" + start.getTime();
|
|
92
|
+
if (allDay && end > start) {
|
|
93
|
+
end = subDays(end, 1);
|
|
94
|
+
end.setHours(23, 59, 59);
|
|
95
|
+
}
|
|
96
|
+
var days = getDays();
|
|
97
|
+
var daysMap = arrayToLookup(days);
|
|
98
|
+
var multi = days.length > 1;
|
|
99
|
+
function getDays() {
|
|
100
|
+
var from = new Date(start);
|
|
101
|
+
var to = new Date(end);
|
|
102
|
+
var days = [getEventTimestamp(from)];
|
|
103
|
+
while (differenceInDays(to, from)) {
|
|
104
|
+
from.setDate(from.getDate() + 1);
|
|
105
|
+
days.push(getEventTimestamp(from));
|
|
106
|
+
}
|
|
107
|
+
return days;
|
|
108
|
+
}
|
|
109
|
+
return {
|
|
110
|
+
calendar: calendar,
|
|
111
|
+
created: created,
|
|
112
|
+
link: link,
|
|
113
|
+
title: title,
|
|
114
|
+
status: status,
|
|
115
|
+
start: start,
|
|
116
|
+
end: end,
|
|
117
|
+
days: days,
|
|
118
|
+
daysMap: daysMap,
|
|
119
|
+
multi: multi,
|
|
120
|
+
color: color,
|
|
121
|
+
allDay: allDay,
|
|
122
|
+
location: location,
|
|
123
|
+
description: description,
|
|
124
|
+
uid: uid,
|
|
125
|
+
};
|
|
126
|
+
}
|
package/Calendar/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export * from "./CalendarDaygridCell";
|
|
2
|
-
export * from "./CalendarDaygridNav";
|
|
3
|
-
export * from "./CalendarDaygridTable";
|
|
4
|
-
export * from "./CalendarLegend";
|
|
5
|
-
export * from "./useCalendar";
|
|
6
|
-
export * from "./types";
|
|
1
|
+
export * from "./CalendarDaygridCell.js";
|
|
2
|
+
export * from "./CalendarDaygridNav.js";
|
|
3
|
+
export * from "./CalendarDaygridTable.js";
|
|
4
|
+
export * from "./CalendarLegend.js";
|
|
5
|
+
export * from "./useCalendar.js";
|
|
6
|
+
export * from "./types.js";
|
package/Calendar/types.d.ts
CHANGED
|
@@ -1,10 +1,6 @@
|
|
|
1
1
|
export type Calendar = {
|
|
2
2
|
id: string;
|
|
3
3
|
color: string;
|
|
4
|
-
/**
|
|
5
|
-
* If not defined the name is gathered from the remote calendar response,
|
|
6
|
-
* for google calendars that comes from the `summary` value.
|
|
7
|
-
*/
|
|
8
4
|
name?: string;
|
|
9
5
|
};
|
|
10
6
|
export type Calendars = Calendar[];
|
|
@@ -16,17 +12,8 @@ export type CalendarRange = [Date, Date];
|
|
|
16
12
|
export type CalendarView = "month" | "week";
|
|
17
13
|
export type CalendarEvent = {
|
|
18
14
|
calendar: Calendar;
|
|
19
|
-
/**
|
|
20
|
-
* List of day timestamps across which the event spans
|
|
21
|
-
*/
|
|
22
15
|
days: number[];
|
|
23
|
-
/**
|
|
24
|
-
* Lookup object for day timestamps across which the event spans
|
|
25
|
-
*/
|
|
26
16
|
daysMap: Record<number, 1>;
|
|
27
|
-
/**
|
|
28
|
-
* Flag for events that spans across multiple days
|
|
29
|
-
*/
|
|
30
17
|
multi: boolean;
|
|
31
18
|
allDay: boolean;
|
|
32
19
|
link: string;
|
|
@@ -40,13 +27,7 @@ export type CalendarEvent = {
|
|
|
40
27
|
description: string;
|
|
41
28
|
uid: string;
|
|
42
29
|
};
|
|
43
|
-
/**
|
|
44
|
-
* Calendar events mapped by day `timestamp` number
|
|
45
|
-
*/
|
|
46
30
|
export type CalendarEventsByTimestamp = Record<number, CalendarEventsMap>;
|
|
47
|
-
/**
|
|
48
|
-
* Calendar events map by `uid`
|
|
49
|
-
*/
|
|
50
31
|
export type CalendarEventsMap = Record<CalendarEvent["uid"], CalendarEvent>;
|
|
51
32
|
export type CalendarViewWeeks = CalendarViewWeek[];
|
|
52
33
|
export type CalendarViewWeek = {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,30 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
import type {
|
|
3
|
-
import type {
|
|
4
|
-
import type {
|
|
5
|
-
import type { CalendarEvent, CalendarEventsMap, CalendarView, Calendars } from "./types";
|
|
1
|
+
import type { KoineCalendarDaygridNavProps } from "./CalendarDaygridNav.js";
|
|
2
|
+
import type { KoineCalendarDaygridTableProps } from "./CalendarDaygridTable.js";
|
|
3
|
+
import type { KoineCalendarLegendProps } from "./CalendarLegend.js";
|
|
4
|
+
import type { CalendarEvent, CalendarEventsMap, CalendarView, Calendars } from "./types.js";
|
|
6
5
|
export type UseCalendarProps = {
|
|
7
|
-
/** The locale to format with `date-fns` */
|
|
8
6
|
locale: string;
|
|
9
|
-
/** Calendars infos to use */
|
|
10
7
|
calendars: Calendars;
|
|
11
|
-
/** Fall back to `process.env.GOOGLE_CALENDAR_API_KEY */
|
|
12
8
|
apiKey?: string;
|
|
13
|
-
/** The key is the event `uid` */
|
|
14
9
|
events?: CalendarEventsMap;
|
|
15
|
-
/** It defaults to the first of the current month */
|
|
16
10
|
start?: Date;
|
|
17
|
-
/** It defaults to the last day of the current month */
|
|
18
11
|
end?: Date;
|
|
19
|
-
/**
|
|
20
|
-
* The calendar view
|
|
21
|
-
* @default "month"
|
|
22
|
-
*/
|
|
23
12
|
view?: CalendarView;
|
|
24
|
-
/**
|
|
25
|
-
* The default is the time zone of the calendar
|
|
26
|
-
* @see https://developers.google.com/calendar/api/v3/reference/events/list
|
|
27
|
-
*/
|
|
28
13
|
timeZone?: string;
|
|
29
14
|
onError?: (e: any) => void;
|
|
30
15
|
};
|