@zuzjs/ui 0.7.7 → 0.7.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/comps/Accordion/index.js +2 -1
- package/dist/cjs/comps/Actionbar/index.d.ts +1 -1
- package/dist/cjs/comps/Actionbar/index.js +3 -2
- package/dist/cjs/comps/Alert/index.d.ts +1 -1
- package/dist/cjs/comps/Alert/index.js +1 -0
- package/dist/cjs/comps/AutoComplete/index.js +1 -0
- package/dist/cjs/comps/Avatar/index.js +3 -2
- package/dist/cjs/comps/Box/index.d.ts +1 -2
- package/dist/cjs/comps/Box/index.js +15 -13
- package/dist/cjs/comps/Button/index.d.ts +2 -2
- package/dist/cjs/comps/Button/index.js +4 -3
- package/dist/cjs/comps/Button/types.d.ts +1 -1
- package/dist/cjs/comps/CheckBox/index.d.ts +2 -2
- package/dist/cjs/comps/CheckBox/index.js +2 -1
- package/dist/cjs/comps/ColorScheme/index.d.ts +3 -2
- package/dist/cjs/comps/ColorScheme/index.js +29 -9
- package/dist/cjs/comps/ColorScheme/types.d.ts +4 -0
- package/dist/cjs/comps/ColorScheme/types.js +1 -0
- package/dist/cjs/comps/ContextMenu/index.js +4 -4
- package/dist/cjs/comps/CookiesConsent/index.js +3 -2
- package/dist/cjs/comps/Cover/index.d.ts +1 -1
- package/dist/cjs/comps/Cover/index.js +3 -2
- package/dist/cjs/comps/Crumb/index.d.ts +4 -0
- package/dist/cjs/comps/Crumb/index.js +13 -0
- package/dist/cjs/comps/Crumb/types.d.ts +11 -0
- package/dist/cjs/comps/Crumb/types.js +1 -0
- package/dist/cjs/comps/Drawer/index.js +17 -15
- package/dist/cjs/comps/Editor/Timeline/index.js +4 -3
- package/dist/cjs/comps/Editor/index.js +2 -1
- package/dist/cjs/comps/Fab/index.d.ts +1 -2
- package/dist/cjs/comps/Fab/index.js +2 -1
- package/dist/cjs/comps/Filters/index.d.ts +4 -1
- package/dist/cjs/comps/Filters/index.js +1 -0
- package/dist/cjs/comps/Form/index.d.ts +3 -59
- package/dist/cjs/comps/Form/index.js +5 -7
- package/dist/cjs/comps/Form/types.d.ts +43 -0
- package/dist/cjs/comps/Form/types.js +1 -0
- package/dist/cjs/comps/Icon/index.d.ts +1 -1
- package/dist/cjs/comps/Icon/index.js +2 -2
- package/dist/cjs/comps/Image/index.js +1 -1
- package/dist/cjs/comps/Input/index.js +1 -0
- package/dist/cjs/comps/KeyboardKeys/index.d.ts +8 -0
- package/dist/cjs/comps/KeyboardKeys/index.js +33 -0
- package/dist/cjs/comps/KeyboardKeys/types.d.ts +13 -0
- package/dist/cjs/comps/KeyboardKeys/types.js +51 -0
- package/dist/cjs/comps/Label/index.js +1 -1
- package/dist/cjs/comps/List/index.d.ts +4 -1
- package/dist/cjs/comps/List/index.js +5 -4
- package/dist/cjs/comps/List/item.d.ts +6 -3
- package/dist/cjs/comps/List/item.js +6 -1
- package/dist/cjs/comps/List/types.d.ts +4 -1
- package/dist/cjs/comps/Network/index.js +6 -7
- package/dist/cjs/comps/Overlay/index.js +2 -1
- package/dist/cjs/comps/Pagination/index.js +3 -2
- package/dist/cjs/comps/Password/index.js +2 -1
- package/dist/cjs/comps/PinInput/index.js +2 -1
- package/dist/cjs/comps/ProgressBar/index.js +1 -0
- package/dist/cjs/comps/Radio/index.js +1 -0
- package/dist/cjs/comps/ScrollView/index.d.ts +5 -0
- package/dist/cjs/comps/ScrollView/index.js +13 -0
- package/dist/cjs/comps/ScrollView/types.d.ts +6 -0
- package/dist/cjs/comps/ScrollView/types.js +1 -0
- package/dist/cjs/comps/Search/index.d.ts +7 -10
- package/dist/cjs/comps/Search/index.js +12 -7
- package/dist/cjs/comps/Search/types.d.ts +12 -0
- package/dist/cjs/comps/Search/types.js +1 -0
- package/dist/cjs/comps/Segmented/index.d.ts +3 -2
- package/dist/cjs/comps/Segmented/index.js +6 -5
- package/dist/cjs/comps/Segmented/item.d.ts +4 -1
- package/dist/cjs/comps/Segmented/item.js +16 -14
- package/dist/cjs/comps/Segmented/types.d.ts +5 -1
- package/dist/cjs/comps/Select/index.d.ts +2 -4
- package/dist/cjs/comps/Select/index.js +4 -3
- package/dist/cjs/comps/Select/optionItem.d.ts +4 -1
- package/dist/cjs/comps/Select/optionItem.js +1 -0
- package/dist/cjs/comps/Select/types.d.ts +1 -1
- package/dist/cjs/comps/Sheet/index.d.ts +1 -1
- package/dist/cjs/comps/Sheet/index.js +12 -8
- package/dist/cjs/comps/Sidebar/index.js +1 -0
- package/dist/cjs/comps/Slider/index.d.ts +1 -1
- package/dist/cjs/comps/Slider/index.js +3 -2
- package/dist/cjs/comps/Span/index.js +1 -0
- package/dist/cjs/comps/Spinner/index.d.ts +1 -1
- package/dist/cjs/comps/Spinner/index.js +4 -7
- package/dist/cjs/comps/Switch/index.d.ts +1 -1
- package/dist/cjs/comps/Switch/index.js +2 -1
- package/dist/cjs/comps/TabView/body.js +1 -0
- package/dist/cjs/comps/TabView/index.d.ts +1 -1
- package/dist/cjs/comps/TabView/index.js +1 -0
- package/dist/cjs/comps/TabView/tab.d.ts +4 -1
- package/dist/cjs/comps/TabView/tab.js +1 -0
- package/dist/cjs/comps/TabView/types.d.ts +2 -2
- package/dist/cjs/comps/Table/col.d.ts +9 -6
- package/dist/cjs/comps/Table/col.js +1 -0
- package/dist/cjs/comps/Table/index.js +13 -5
- package/dist/cjs/comps/Table/row.d.ts +4 -1
- package/dist/cjs/comps/Table/row.js +5 -3
- package/dist/cjs/comps/Table/types.d.ts +88 -1
- package/dist/cjs/comps/Text/index.d.ts +2 -0
- package/dist/cjs/comps/Text/index.js +4 -2
- package/dist/cjs/comps/TextArea/index.d.ts +2 -0
- package/dist/cjs/comps/TextArea/index.js +3 -3
- package/dist/cjs/comps/TextWheel/index.js +1 -0
- package/dist/cjs/comps/Tooltip/index.d.ts +1 -2
- package/dist/cjs/comps/Tooltip/index.js +2 -1
- package/dist/cjs/comps/Treeview/index.d.ts +1 -2
- package/dist/cjs/comps/Treeview/index.js +3 -1
- package/dist/cjs/comps/Treeview/item.d.ts +3 -2
- package/dist/cjs/comps/Treeview/item.js +12 -7
- package/dist/cjs/comps/Treeview/types.d.ts +6 -2
- package/dist/cjs/comps/VideoPlayer/index.d.ts +2 -0
- package/dist/cjs/comps/VideoPlayer/index.js +7 -0
- package/dist/cjs/comps/index.d.ts +26 -18
- package/dist/cjs/comps/index.js +8 -0
- package/dist/cjs/funs/css.d.ts +3 -3
- package/dist/cjs/funs/css.js +20 -18
- package/dist/cjs/funs/index.d.ts +3 -1
- package/dist/cjs/funs/index.js +14 -3
- package/dist/cjs/funs/stylesheet.js +5 -0
- package/dist/cjs/hooks/index.d.ts +15 -9
- package/dist/cjs/hooks/index.js +14 -7
- package/dist/cjs/hooks/useAnchorPosition.d.ts +1 -2
- package/dist/cjs/hooks/useAnchorPosition.js +1 -0
- package/dist/cjs/hooks/useBase.js +27 -13
- package/dist/cjs/hooks/useCalendar.js +1 -0
- package/dist/cjs/hooks/useColorScheme.js +2 -2
- package/dist/cjs/hooks/useContextMenu.js +1 -0
- package/dist/cjs/hooks/useDB.js +1 -0
- package/dist/cjs/hooks/useDebounce.js +2 -1
- package/dist/cjs/hooks/useDelayed.d.ts +17 -0
- package/dist/cjs/hooks/useDelayed.js +26 -0
- package/dist/cjs/hooks/useDevice.js +1 -0
- package/dist/cjs/hooks/useDimensions.js +2 -1
- package/dist/cjs/hooks/useDom.d.ts +2 -0
- package/dist/cjs/hooks/useDom.js +3 -0
- package/dist/cjs/hooks/useDomMutation.d.ts +3 -0
- package/dist/cjs/hooks/useDomMutation.js +19 -0
- package/dist/cjs/hooks/useDrag.js +2 -1
- package/dist/cjs/hooks/useFileManager.d.ts +2 -0
- package/dist/cjs/hooks/useFileManager.js +3 -0
- package/dist/cjs/hooks/useImage.js +1 -0
- package/dist/cjs/hooks/useIntersectionObserver.js +2 -1
- package/dist/cjs/hooks/useMediaPlayer.d.ts +32 -0
- package/dist/cjs/hooks/useMediaPlayer.js +86 -0
- package/dist/cjs/hooks/useMergedRefs.d.ts +2 -0
- package/dist/cjs/hooks/useMergedRefs.js +14 -0
- package/dist/cjs/hooks/useMutationObserver.d.ts +3 -0
- package/dist/cjs/hooks/useMutationObserver.js +20 -0
- package/dist/cjs/hooks/useNetworkStatus.js +2 -1
- package/dist/cjs/hooks/usePlayer.d.ts +32 -0
- package/dist/cjs/hooks/usePlayer.js +85 -0
- package/dist/cjs/hooks/useResizeObserver.js +2 -1
- package/dist/cjs/hooks/useScrollbar.d.ts +16 -0
- package/dist/cjs/hooks/useScrollbar.js +160 -0
- package/dist/cjs/hooks/useSheet.js +1 -0
- package/dist/cjs/hooks/useShortcuts.d.ts +7 -0
- package/dist/cjs/hooks/useShortcuts.js +29 -0
- package/dist/cjs/hooks/useSlider.d.ts +7 -0
- package/dist/cjs/hooks/useSlider.js +23 -0
- package/dist/cjs/hooks/useTruncateText.d.ts +2 -0
- package/dist/cjs/hooks/useTruncateText.js +17 -0
- package/dist/cjs/hooks/useViewTransition.d.ts +2 -0
- package/dist/cjs/hooks/useViewTransition.js +13 -0
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/types/enums.d.ts +1 -0
- package/dist/cjs/types/enums.js +1 -0
- package/dist/cjs/types/index.d.ts +2 -1
- package/dist/cjs/types/interfaces.d.ts +2 -0
- package/dist/css/styles.css +1 -1
- package/dist/esm/comps/Accordion/index.js +2 -1
- package/dist/esm/comps/Actionbar/index.d.ts +1 -1
- package/dist/esm/comps/Actionbar/index.js +3 -2
- package/dist/esm/comps/Alert/index.d.ts +1 -1
- package/dist/esm/comps/Alert/index.js +1 -0
- package/dist/esm/comps/AutoComplete/index.js +1 -0
- package/dist/esm/comps/Avatar/index.js +3 -2
- package/dist/esm/comps/Box/index.d.ts +1 -2
- package/dist/esm/comps/Box/index.js +15 -13
- package/dist/esm/comps/Button/index.d.ts +2 -2
- package/dist/esm/comps/Button/index.js +4 -3
- package/dist/esm/comps/Button/types.d.ts +1 -1
- package/dist/esm/comps/CheckBox/index.d.ts +2 -2
- package/dist/esm/comps/CheckBox/index.js +2 -1
- package/dist/esm/comps/ColorScheme/index.d.ts +3 -2
- package/dist/esm/comps/ColorScheme/index.js +29 -9
- package/dist/esm/comps/ColorScheme/types.d.ts +4 -0
- package/dist/esm/comps/ColorScheme/types.js +1 -0
- package/dist/esm/comps/ContextMenu/index.js +4 -4
- package/dist/esm/comps/CookiesConsent/index.js +3 -2
- package/dist/esm/comps/Cover/index.d.ts +1 -1
- package/dist/esm/comps/Cover/index.js +3 -2
- package/dist/esm/comps/Crumb/index.d.ts +4 -0
- package/dist/esm/comps/Crumb/index.js +13 -0
- package/dist/esm/comps/Crumb/types.d.ts +11 -0
- package/dist/esm/comps/Crumb/types.js +1 -0
- package/dist/esm/comps/Drawer/index.js +17 -15
- package/dist/esm/comps/Editor/Timeline/index.js +4 -3
- package/dist/esm/comps/Editor/index.js +2 -1
- package/dist/esm/comps/Fab/index.d.ts +1 -2
- package/dist/esm/comps/Fab/index.js +2 -1
- package/dist/esm/comps/Filters/index.d.ts +4 -1
- package/dist/esm/comps/Filters/index.js +1 -0
- package/dist/esm/comps/Form/index.d.ts +3 -59
- package/dist/esm/comps/Form/index.js +5 -7
- package/dist/esm/comps/Form/types.d.ts +43 -0
- package/dist/esm/comps/Form/types.js +1 -0
- package/dist/esm/comps/Icon/index.d.ts +1 -1
- package/dist/esm/comps/Icon/index.js +2 -2
- package/dist/esm/comps/Image/index.js +1 -1
- package/dist/esm/comps/Input/index.js +1 -0
- package/dist/esm/comps/KeyboardKeys/index.d.ts +8 -0
- package/dist/esm/comps/KeyboardKeys/index.js +33 -0
- package/dist/esm/comps/KeyboardKeys/types.d.ts +13 -0
- package/dist/esm/comps/KeyboardKeys/types.js +51 -0
- package/dist/esm/comps/Label/index.js +1 -1
- package/dist/esm/comps/List/index.d.ts +4 -1
- package/dist/esm/comps/List/index.js +5 -4
- package/dist/esm/comps/List/item.d.ts +6 -3
- package/dist/esm/comps/List/item.js +6 -1
- package/dist/esm/comps/List/types.d.ts +4 -1
- package/dist/esm/comps/Network/index.js +6 -7
- package/dist/esm/comps/Overlay/index.js +2 -1
- package/dist/esm/comps/Pagination/index.js +3 -2
- package/dist/esm/comps/Password/index.js +2 -1
- package/dist/esm/comps/PinInput/index.js +2 -1
- package/dist/esm/comps/ProgressBar/index.js +1 -0
- package/dist/esm/comps/Radio/index.js +1 -0
- package/dist/esm/comps/ScrollView/index.d.ts +5 -0
- package/dist/esm/comps/ScrollView/index.js +13 -0
- package/dist/esm/comps/ScrollView/types.d.ts +6 -0
- package/dist/esm/comps/ScrollView/types.js +1 -0
- package/dist/esm/comps/Search/index.d.ts +7 -10
- package/dist/esm/comps/Search/index.js +12 -7
- package/dist/esm/comps/Search/types.d.ts +12 -0
- package/dist/esm/comps/Search/types.js +1 -0
- package/dist/esm/comps/Segmented/index.d.ts +3 -2
- package/dist/esm/comps/Segmented/index.js +6 -5
- package/dist/esm/comps/Segmented/item.d.ts +4 -1
- package/dist/esm/comps/Segmented/item.js +16 -14
- package/dist/esm/comps/Segmented/types.d.ts +5 -1
- package/dist/esm/comps/Select/index.d.ts +2 -4
- package/dist/esm/comps/Select/index.js +4 -3
- package/dist/esm/comps/Select/optionItem.d.ts +4 -1
- package/dist/esm/comps/Select/optionItem.js +1 -0
- package/dist/esm/comps/Select/types.d.ts +1 -1
- package/dist/esm/comps/Sheet/index.d.ts +1 -1
- package/dist/esm/comps/Sheet/index.js +12 -8
- package/dist/esm/comps/Sidebar/index.js +1 -0
- package/dist/esm/comps/Slider/index.d.ts +1 -1
- package/dist/esm/comps/Slider/index.js +3 -2
- package/dist/esm/comps/Span/index.js +1 -0
- package/dist/esm/comps/Spinner/index.d.ts +1 -1
- package/dist/esm/comps/Spinner/index.js +4 -7
- package/dist/esm/comps/Switch/index.d.ts +1 -1
- package/dist/esm/comps/Switch/index.js +2 -1
- package/dist/esm/comps/TabView/body.js +1 -0
- package/dist/esm/comps/TabView/index.d.ts +1 -1
- package/dist/esm/comps/TabView/index.js +1 -0
- package/dist/esm/comps/TabView/tab.d.ts +4 -1
- package/dist/esm/comps/TabView/tab.js +1 -0
- package/dist/esm/comps/TabView/types.d.ts +2 -2
- package/dist/esm/comps/Table/col.d.ts +9 -6
- package/dist/esm/comps/Table/col.js +1 -0
- package/dist/esm/comps/Table/index.js +13 -5
- package/dist/esm/comps/Table/row.d.ts +4 -1
- package/dist/esm/comps/Table/row.js +5 -3
- package/dist/esm/comps/Table/types.d.ts +88 -1
- package/dist/esm/comps/Text/index.d.ts +2 -0
- package/dist/esm/comps/Text/index.js +4 -2
- package/dist/esm/comps/TextArea/index.d.ts +2 -0
- package/dist/esm/comps/TextArea/index.js +3 -3
- package/dist/esm/comps/TextWheel/index.js +1 -0
- package/dist/esm/comps/Tooltip/index.d.ts +1 -2
- package/dist/esm/comps/Tooltip/index.js +2 -1
- package/dist/esm/comps/Treeview/index.d.ts +1 -2
- package/dist/esm/comps/Treeview/index.js +3 -1
- package/dist/esm/comps/Treeview/item.d.ts +3 -2
- package/dist/esm/comps/Treeview/item.js +12 -7
- package/dist/esm/comps/Treeview/types.d.ts +6 -2
- package/dist/esm/comps/VideoPlayer/index.d.ts +2 -0
- package/dist/esm/comps/VideoPlayer/index.js +7 -0
- package/dist/esm/comps/index.d.ts +26 -18
- package/dist/esm/comps/index.js +8 -0
- package/dist/esm/funs/css.d.ts +3 -3
- package/dist/esm/funs/css.js +20 -18
- package/dist/esm/funs/index.d.ts +3 -1
- package/dist/esm/funs/index.js +14 -3
- package/dist/esm/funs/stylesheet.js +5 -0
- package/dist/esm/hooks/index.d.ts +15 -9
- package/dist/esm/hooks/index.js +14 -7
- package/dist/esm/hooks/useAnchorPosition.d.ts +1 -2
- package/dist/esm/hooks/useAnchorPosition.js +1 -0
- package/dist/esm/hooks/useBase.js +27 -13
- package/dist/esm/hooks/useCalendar.js +1 -0
- package/dist/esm/hooks/useColorScheme.js +2 -2
- package/dist/esm/hooks/useContextMenu.js +1 -0
- package/dist/esm/hooks/useDB.js +1 -0
- package/dist/esm/hooks/useDebounce.js +2 -1
- package/dist/esm/hooks/useDelayed.d.ts +17 -0
- package/dist/esm/hooks/useDelayed.js +26 -0
- package/dist/esm/hooks/useDevice.js +1 -0
- package/dist/esm/hooks/useDimensions.js +2 -1
- package/dist/esm/hooks/useDom.d.ts +2 -0
- package/dist/esm/hooks/useDom.js +3 -0
- package/dist/esm/hooks/useDomMutation.d.ts +3 -0
- package/dist/esm/hooks/useDomMutation.js +19 -0
- package/dist/esm/hooks/useDrag.js +2 -1
- package/dist/esm/hooks/useFileManager.d.ts +2 -0
- package/dist/esm/hooks/useFileManager.js +3 -0
- package/dist/esm/hooks/useImage.js +1 -0
- package/dist/esm/hooks/useIntersectionObserver.js +2 -1
- package/dist/esm/hooks/useMediaPlayer.d.ts +32 -0
- package/dist/esm/hooks/useMediaPlayer.js +86 -0
- package/dist/esm/hooks/useMergedRefs.d.ts +2 -0
- package/dist/esm/hooks/useMergedRefs.js +14 -0
- package/dist/esm/hooks/useMutationObserver.d.ts +3 -0
- package/dist/esm/hooks/useMutationObserver.js +20 -0
- package/dist/esm/hooks/useNetworkStatus.js +2 -1
- package/dist/esm/hooks/usePlayer.d.ts +32 -0
- package/dist/esm/hooks/usePlayer.js +85 -0
- package/dist/esm/hooks/useResizeObserver.js +2 -1
- package/dist/esm/hooks/useScrollbar.d.ts +16 -0
- package/dist/esm/hooks/useScrollbar.js +160 -0
- package/dist/esm/hooks/useSheet.js +1 -0
- package/dist/esm/hooks/useShortcuts.d.ts +7 -0
- package/dist/esm/hooks/useShortcuts.js +29 -0
- package/dist/esm/hooks/useSlider.d.ts +7 -0
- package/dist/esm/hooks/useSlider.js +23 -0
- package/dist/esm/hooks/useTruncateText.d.ts +2 -0
- package/dist/esm/hooks/useTruncateText.js +17 -0
- package/dist/esm/hooks/useViewTransition.d.ts +2 -0
- package/dist/esm/hooks/useViewTransition.js +13 -0
- package/dist/esm/index.js +1 -0
- package/dist/esm/types/enums.d.ts +1 -0
- package/dist/esm/types/enums.js +1 -0
- package/dist/esm/types/index.d.ts +2 -1
- package/dist/esm/types/interfaces.d.ts +2 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { cleanProps, css } from "../funs";
|
|
2
2
|
import { buildWithStyles, getAnimationCurve, getAnimationTransition } from "../funs/css";
|
|
3
3
|
import { cssFilterKeys, cssTransformKeys, cssWithKeys } from "../funs/stylesheet";
|
|
4
|
-
|
|
4
|
+
let useDrag = null;
|
|
5
5
|
const buildSkeletonStyle = (s) => {
|
|
6
6
|
const makeValue = (v, unit = `px`) => {
|
|
7
7
|
return v ?
|
|
@@ -29,12 +29,15 @@ const buildSkeletonStyle = (s) => {
|
|
|
29
29
|
return style;
|
|
30
30
|
};
|
|
31
31
|
const useBase = (props) => {
|
|
32
|
-
const { as, fx, animate, skeleton, className, shimmer, propsToRemove, draggable, dragOptions, ...rest } = props || {};
|
|
32
|
+
const { as, fx, animate, transition: autoTransition, skeleton, className, shimmer, propsToRemove, draggable, dragOptions, ...rest } = props || {};
|
|
33
33
|
let cx = [];
|
|
34
34
|
if (as) {
|
|
35
35
|
cx = css().Build(`string` == typeof as ? as : as.join(` `)).cx;
|
|
36
36
|
}
|
|
37
|
-
const { transition, from, to, when, duration, delay, curve } =
|
|
37
|
+
const { transition, from, to, when, duration, delay, curve } = autoTransition ? {
|
|
38
|
+
transition: autoTransition,
|
|
39
|
+
duration: 0.3
|
|
40
|
+
} : fx || animate || {};
|
|
38
41
|
let _style = {};
|
|
39
42
|
if (undefined === when) {
|
|
40
43
|
_style = transition ? getAnimationTransition(transition, true) : { ...from, ...to };
|
|
@@ -67,19 +70,30 @@ const useBase = (props) => {
|
|
|
67
70
|
});
|
|
68
71
|
_transition.transition = _transitionList.join(`, `);
|
|
69
72
|
}
|
|
70
|
-
// console.log(_style, _transition)
|
|
71
|
-
const
|
|
73
|
+
// // console.log(_style, _transition)
|
|
74
|
+
const is = typeof window !== "undefined";
|
|
72
75
|
let dragProps = {};
|
|
73
76
|
let dragStyle = {};
|
|
74
|
-
if (draggable) {
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
77
|
+
if (draggable && is) {
|
|
78
|
+
if (!useDrag) {
|
|
79
|
+
import("./useDrag")
|
|
80
|
+
.then(module => {
|
|
81
|
+
useDrag = module.default;
|
|
82
|
+
})
|
|
83
|
+
.catch(err => {
|
|
84
|
+
console.error("Error loading useDrag:", err);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
if (useDrag) {
|
|
88
|
+
const drag = useDrag(dragOptions);
|
|
89
|
+
dragProps = {
|
|
90
|
+
onMouseDown: drag.onMouseDown,
|
|
91
|
+
};
|
|
92
|
+
dragStyle = {
|
|
93
|
+
transform: `translate(${drag.position.x}px, ${drag.position.y}px)`,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
81
96
|
}
|
|
82
|
-
// console.log(`x`, buildWithStyles(_style),)
|
|
83
97
|
return {
|
|
84
98
|
style: {
|
|
85
99
|
...buildWithStyles(_style),
|
|
@@ -71,8 +71,8 @@ const Theme = ({ children, storageKey, forceTheme }) => {
|
|
|
71
71
|
useEffect(() => {
|
|
72
72
|
applyColorScheme((forceTheme || colorScheme || `system`));
|
|
73
73
|
}, [colorScheme]);
|
|
74
|
-
return (_jsxs(ThemeContext, { value: { colorScheme: colorScheme, resolvedScheme: resolvedTheme, setColorScheme: switchColorScheme }, children: [_jsx("script", { suppressHydrationWarning: true, dangerouslySetInnerHTML: {
|
|
75
|
-
__html:
|
|
74
|
+
return (_jsxs(ThemeContext, { value: { colorScheme: colorScheme, resolvedScheme: resolvedTheme, setColorScheme: switchColorScheme }, children: [forceTheme ? null : _jsx("script", { suppressHydrationWarning: true, dangerouslySetInnerHTML: {
|
|
75
|
+
__html: `const el = document.documentElement
|
|
76
76
|
const themes = ['light', 'dark']
|
|
77
77
|
let theme = localStorage.getItem(\`${storageKey}\`) || "system";
|
|
78
78
|
if (theme === "system") {
|
package/dist/cjs/hooks/useDB.js
CHANGED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Custom hook that sets a mounted state to true after a specified delay.
|
|
3
|
+
*
|
|
4
|
+
* @param {number} [delay=100] - The delay in milliseconds before setting the mounted state to true.
|
|
5
|
+
* @returns {boolean} - The mounted state.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* const isMounted = useMounted(200);
|
|
9
|
+
*
|
|
10
|
+
* useEffect(() => {
|
|
11
|
+
* if (isMounted) {
|
|
12
|
+
* // Component is mounted after 200ms
|
|
13
|
+
* }
|
|
14
|
+
* }, [isMounted]);
|
|
15
|
+
*/
|
|
16
|
+
declare const useMounted: (delay?: number) => boolean;
|
|
17
|
+
export default useMounted;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
3
|
+
/**
|
|
4
|
+
* Custom hook that sets a mounted state to true after a specified delay.
|
|
5
|
+
*
|
|
6
|
+
* @param {number} [delay=100] - The delay in milliseconds before setting the mounted state to true.
|
|
7
|
+
* @returns {boolean} - The mounted state.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* const isMounted = useMounted(200);
|
|
11
|
+
*
|
|
12
|
+
* useEffect(() => {
|
|
13
|
+
* if (isMounted) {
|
|
14
|
+
* // Component is mounted after 200ms
|
|
15
|
+
* }
|
|
16
|
+
* }, [isMounted]);
|
|
17
|
+
*/
|
|
18
|
+
const useMounted = (delay = 100) => {
|
|
19
|
+
const [mounted, setMounted] = useState(false);
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
const timer = setTimeout(() => setMounted(true), delay);
|
|
22
|
+
return () => clearTimeout(timer); // Cleanup the timer on unmount
|
|
23
|
+
}, [delay]);
|
|
24
|
+
return mounted;
|
|
25
|
+
};
|
|
26
|
+
export default useMounted;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { useEffect, useRef } from "react";
|
|
2
|
+
const useMutationObserver = (target, callback, options = { childList: true, subtree: true }) => {
|
|
3
|
+
const observerRef = useRef(null);
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
if (!target)
|
|
6
|
+
return;
|
|
7
|
+
// Create a new MutationObserver and pass the callback
|
|
8
|
+
observerRef.current = new MutationObserver(callback);
|
|
9
|
+
// Start observing the target element
|
|
10
|
+
observerRef.current.observe(target, options);
|
|
11
|
+
// Cleanup function to disconnect the observer
|
|
12
|
+
return () => {
|
|
13
|
+
if (observerRef.current) {
|
|
14
|
+
observerRef.current.disconnect();
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
}, [target, callback, options]);
|
|
18
|
+
};
|
|
19
|
+
export default useMutationObserver;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
"use client";
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
2
3
|
const useIntersectionObserver = (refs, options = {}) => {
|
|
3
4
|
const [intersectionRatio, setIntersectionRatio] = useState(refs && refs.length > 0 ? new Array(refs.length).fill(0) : []);
|
|
4
5
|
useEffect(() => {
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export type MediaType = "video" | "audio";
|
|
2
|
+
export type MediaPlayerProps = {
|
|
3
|
+
src: string;
|
|
4
|
+
type?: MediaType;
|
|
5
|
+
autoPlay?: boolean;
|
|
6
|
+
loop?: boolean;
|
|
7
|
+
controls?: boolean;
|
|
8
|
+
};
|
|
9
|
+
declare const useMediaPlayer: ({ src, type, autoPlay, loop, controls }: MediaPlayerProps) => {
|
|
10
|
+
mediaRef: import("react").RefObject<(HTMLVideoElement & HTMLAudioElement) | null>;
|
|
11
|
+
isPlaying: boolean;
|
|
12
|
+
togglePlay: () => void;
|
|
13
|
+
seek: (time: number) => void;
|
|
14
|
+
volume: number;
|
|
15
|
+
changeVolume: (newVolume: number) => void;
|
|
16
|
+
isFullscreen: boolean;
|
|
17
|
+
toggleFullscreen: () => void;
|
|
18
|
+
currentTime: number;
|
|
19
|
+
duration: number;
|
|
20
|
+
handleTimeUpdate: () => void;
|
|
21
|
+
handleLoadedMetadata: () => void;
|
|
22
|
+
mediaProps: {
|
|
23
|
+
ref: import("react").RefObject<(HTMLVideoElement & HTMLAudioElement) | null>;
|
|
24
|
+
src: string;
|
|
25
|
+
autoPlay: boolean;
|
|
26
|
+
loop: boolean;
|
|
27
|
+
controls: boolean;
|
|
28
|
+
onTimeUpdate: () => void;
|
|
29
|
+
onLoadedMetadata: () => void;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
export default useMediaPlayer;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useCallback, useRef, useState } from "react";
|
|
3
|
+
const useMediaPlayer = ({ src, type = "video", autoPlay = false, loop = false, controls = false }) => {
|
|
4
|
+
const mediaRef = useRef(null);
|
|
5
|
+
const [isPlaying, setIsPlaying] = useState(autoPlay);
|
|
6
|
+
const [volume, setVolume] = useState(1);
|
|
7
|
+
const [isFullscreen, setIsFullscreen] = useState(false);
|
|
8
|
+
const [currentTime, setCurrentTime] = useState(0);
|
|
9
|
+
const [duration, setDuration] = useState(0);
|
|
10
|
+
// Play / Pause toggle
|
|
11
|
+
const togglePlay = useCallback(() => {
|
|
12
|
+
if (mediaRef.current) {
|
|
13
|
+
if (mediaRef.current.paused) {
|
|
14
|
+
mediaRef.current.play();
|
|
15
|
+
setIsPlaying(true);
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
mediaRef.current.pause();
|
|
19
|
+
setIsPlaying(false);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
}, []);
|
|
23
|
+
// Seek media
|
|
24
|
+
const seek = useCallback((time) => {
|
|
25
|
+
if (mediaRef.current) {
|
|
26
|
+
mediaRef.current.currentTime = time;
|
|
27
|
+
setCurrentTime(time);
|
|
28
|
+
}
|
|
29
|
+
}, []);
|
|
30
|
+
// Change volume
|
|
31
|
+
const changeVolume = useCallback((newVolume) => {
|
|
32
|
+
if (mediaRef.current) {
|
|
33
|
+
mediaRef.current.volume = newVolume;
|
|
34
|
+
setVolume(newVolume);
|
|
35
|
+
}
|
|
36
|
+
}, []);
|
|
37
|
+
// Toggle fullscreen (only for video)
|
|
38
|
+
const toggleFullscreen = useCallback(() => {
|
|
39
|
+
if (type === "video" && mediaRef.current) {
|
|
40
|
+
if (!document.fullscreenElement) {
|
|
41
|
+
mediaRef.current.requestFullscreen?.();
|
|
42
|
+
setIsFullscreen(true);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
document.exitFullscreen?.();
|
|
46
|
+
setIsFullscreen(false);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}, [type]);
|
|
50
|
+
// Update time
|
|
51
|
+
const handleTimeUpdate = useCallback(() => {
|
|
52
|
+
if (mediaRef.current) {
|
|
53
|
+
setCurrentTime(mediaRef.current.currentTime);
|
|
54
|
+
}
|
|
55
|
+
}, []);
|
|
56
|
+
// Set duration
|
|
57
|
+
const handleLoadedMetadata = useCallback(() => {
|
|
58
|
+
if (mediaRef.current) {
|
|
59
|
+
setDuration(mediaRef.current.duration);
|
|
60
|
+
}
|
|
61
|
+
}, []);
|
|
62
|
+
return {
|
|
63
|
+
mediaRef,
|
|
64
|
+
isPlaying,
|
|
65
|
+
togglePlay,
|
|
66
|
+
seek,
|
|
67
|
+
volume,
|
|
68
|
+
changeVolume,
|
|
69
|
+
isFullscreen,
|
|
70
|
+
toggleFullscreen,
|
|
71
|
+
currentTime,
|
|
72
|
+
duration,
|
|
73
|
+
handleTimeUpdate,
|
|
74
|
+
handleLoadedMetadata,
|
|
75
|
+
mediaProps: {
|
|
76
|
+
ref: mediaRef,
|
|
77
|
+
src,
|
|
78
|
+
autoPlay,
|
|
79
|
+
loop,
|
|
80
|
+
controls,
|
|
81
|
+
onTimeUpdate: handleTimeUpdate,
|
|
82
|
+
onLoadedMetadata: handleLoadedMetadata,
|
|
83
|
+
},
|
|
84
|
+
};
|
|
85
|
+
};
|
|
86
|
+
export default useMediaPlayer;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { useCallback } from "react";
|
|
2
|
+
const useMergedRefs = (...refs) => {
|
|
3
|
+
return useCallback((node) => {
|
|
4
|
+
refs.forEach((ref) => {
|
|
5
|
+
if (!ref)
|
|
6
|
+
return;
|
|
7
|
+
if (typeof ref === "function")
|
|
8
|
+
ref(node);
|
|
9
|
+
else if ("current" in ref)
|
|
10
|
+
ref.current = node;
|
|
11
|
+
});
|
|
12
|
+
}, [refs]);
|
|
13
|
+
};
|
|
14
|
+
export default useMergedRefs;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useEffect, useRef } from "react";
|
|
3
|
+
const useMutationObserver = (target, callback, options = { childList: true, subtree: true }) => {
|
|
4
|
+
const observerRef = useRef(null);
|
|
5
|
+
useEffect(() => {
|
|
6
|
+
if (!target)
|
|
7
|
+
return;
|
|
8
|
+
// Create a new MutationObserver and pass the callback
|
|
9
|
+
observerRef.current = new MutationObserver(callback);
|
|
10
|
+
// Start observing the target element
|
|
11
|
+
observerRef.current.observe(target, options);
|
|
12
|
+
// Cleanup function to disconnect the observer
|
|
13
|
+
return () => {
|
|
14
|
+
if (observerRef.current) {
|
|
15
|
+
observerRef.current.disconnect();
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
}, [target, callback, options]);
|
|
19
|
+
};
|
|
20
|
+
export default useMutationObserver;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export type MediaType = "video" | "audio";
|
|
2
|
+
export type MediaPlayerProps = {
|
|
3
|
+
src: string;
|
|
4
|
+
type?: MediaType;
|
|
5
|
+
autoPlay?: boolean;
|
|
6
|
+
loop?: boolean;
|
|
7
|
+
controls?: boolean;
|
|
8
|
+
};
|
|
9
|
+
declare const useMediaPlayer: ({ src, type, autoPlay, loop, controls }: MediaPlayerProps) => {
|
|
10
|
+
mediaRef: import("react").RefObject<(HTMLVideoElement & HTMLAudioElement) | null>;
|
|
11
|
+
isPlaying: boolean;
|
|
12
|
+
togglePlay: () => void;
|
|
13
|
+
seek: (time: number) => void;
|
|
14
|
+
volume: number;
|
|
15
|
+
changeVolume: (newVolume: number) => void;
|
|
16
|
+
isFullscreen: boolean;
|
|
17
|
+
toggleFullscreen: () => void;
|
|
18
|
+
currentTime: number;
|
|
19
|
+
duration: number;
|
|
20
|
+
handleTimeUpdate: () => void;
|
|
21
|
+
handleLoadedMetadata: () => void;
|
|
22
|
+
mediaProps: {
|
|
23
|
+
ref: import("react").RefObject<(HTMLVideoElement & HTMLAudioElement) | null>;
|
|
24
|
+
src: string;
|
|
25
|
+
autoPlay: boolean;
|
|
26
|
+
loop: boolean;
|
|
27
|
+
controls: boolean;
|
|
28
|
+
onTimeUpdate: () => void;
|
|
29
|
+
onLoadedMetadata: () => void;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
export default useMediaPlayer;
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { useCallback, useRef, useState } from "react";
|
|
2
|
+
const useMediaPlayer = ({ src, type = "video", autoPlay = false, loop = false, controls = false }) => {
|
|
3
|
+
const mediaRef = useRef(null);
|
|
4
|
+
const [isPlaying, setIsPlaying] = useState(autoPlay);
|
|
5
|
+
const [volume, setVolume] = useState(1);
|
|
6
|
+
const [isFullscreen, setIsFullscreen] = useState(false);
|
|
7
|
+
const [currentTime, setCurrentTime] = useState(0);
|
|
8
|
+
const [duration, setDuration] = useState(0);
|
|
9
|
+
// Play / Pause toggle
|
|
10
|
+
const togglePlay = useCallback(() => {
|
|
11
|
+
if (mediaRef.current) {
|
|
12
|
+
if (mediaRef.current.paused) {
|
|
13
|
+
mediaRef.current.play();
|
|
14
|
+
setIsPlaying(true);
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
mediaRef.current.pause();
|
|
18
|
+
setIsPlaying(false);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}, []);
|
|
22
|
+
// Seek media
|
|
23
|
+
const seek = useCallback((time) => {
|
|
24
|
+
if (mediaRef.current) {
|
|
25
|
+
mediaRef.current.currentTime = time;
|
|
26
|
+
setCurrentTime(time);
|
|
27
|
+
}
|
|
28
|
+
}, []);
|
|
29
|
+
// Change volume
|
|
30
|
+
const changeVolume = useCallback((newVolume) => {
|
|
31
|
+
if (mediaRef.current) {
|
|
32
|
+
mediaRef.current.volume = newVolume;
|
|
33
|
+
setVolume(newVolume);
|
|
34
|
+
}
|
|
35
|
+
}, []);
|
|
36
|
+
// Toggle fullscreen (only for video)
|
|
37
|
+
const toggleFullscreen = useCallback(() => {
|
|
38
|
+
if (type === "video" && mediaRef.current) {
|
|
39
|
+
if (!document.fullscreenElement) {
|
|
40
|
+
mediaRef.current.requestFullscreen?.();
|
|
41
|
+
setIsFullscreen(true);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
document.exitFullscreen?.();
|
|
45
|
+
setIsFullscreen(false);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}, [type]);
|
|
49
|
+
// Update time
|
|
50
|
+
const handleTimeUpdate = useCallback(() => {
|
|
51
|
+
if (mediaRef.current) {
|
|
52
|
+
setCurrentTime(mediaRef.current.currentTime);
|
|
53
|
+
}
|
|
54
|
+
}, []);
|
|
55
|
+
// Set duration
|
|
56
|
+
const handleLoadedMetadata = useCallback(() => {
|
|
57
|
+
if (mediaRef.current) {
|
|
58
|
+
setDuration(mediaRef.current.duration);
|
|
59
|
+
}
|
|
60
|
+
}, []);
|
|
61
|
+
return {
|
|
62
|
+
mediaRef,
|
|
63
|
+
isPlaying,
|
|
64
|
+
togglePlay,
|
|
65
|
+
seek,
|
|
66
|
+
volume,
|
|
67
|
+
changeVolume,
|
|
68
|
+
isFullscreen,
|
|
69
|
+
toggleFullscreen,
|
|
70
|
+
currentTime,
|
|
71
|
+
duration,
|
|
72
|
+
handleTimeUpdate,
|
|
73
|
+
handleLoadedMetadata,
|
|
74
|
+
mediaProps: {
|
|
75
|
+
ref: mediaRef,
|
|
76
|
+
src,
|
|
77
|
+
autoPlay,
|
|
78
|
+
loop,
|
|
79
|
+
controls,
|
|
80
|
+
onTimeUpdate: handleTimeUpdate,
|
|
81
|
+
onLoadedMetadata: handleLoadedMetadata,
|
|
82
|
+
},
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
export default useMediaPlayer;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export interface ScrollBreakpoint {
|
|
2
|
+
[key: number]: () => void;
|
|
3
|
+
}
|
|
4
|
+
declare const useScrollbar: (breakpoints?: ScrollBreakpoint) => {
|
|
5
|
+
rootRef: import("react").RefObject<HTMLDivElement | null>;
|
|
6
|
+
containerRef: import("react").RefObject<HTMLDivElement | null>;
|
|
7
|
+
thumbY: import("react").RefObject<HTMLDivElement | null>;
|
|
8
|
+
thumbX: import("react").RefObject<HTMLDivElement | null>;
|
|
9
|
+
scrollToTop: () => void | undefined;
|
|
10
|
+
scrollToBottom: () => void | undefined;
|
|
11
|
+
scrollToLeft: () => void | undefined;
|
|
12
|
+
scrollToRight: () => void | undefined;
|
|
13
|
+
onScrollY: (e: React.MouseEvent) => void;
|
|
14
|
+
onScrollX: (e: React.MouseEvent) => void;
|
|
15
|
+
};
|
|
16
|
+
export default useScrollbar;
|