@mdigital_ui/ui 0.3.7 → 0.3.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/accordion/index.d.ts.map +1 -1
- package/dist/accordion/index.js +2 -2
- package/dist/badge/index.d.ts +1 -1
- package/dist/badge/index.d.ts.map +1 -1
- package/dist/badge/index.js +2 -2
- package/dist/breadcrumbs/index.js +5 -4
- package/dist/button/index.d.ts +9 -0
- package/dist/button/index.d.ts.map +1 -1
- package/dist/button/index.js +4 -3
- package/dist/button/types.d.ts +18 -0
- package/dist/button/types.d.ts.map +1 -1
- package/dist/card/index.d.ts +14 -14
- package/dist/card/index.d.ts.map +1 -1
- package/dist/card/index.js +2 -2
- package/dist/carousel/index.d.ts +1 -1
- package/dist/carousel/index.d.ts.map +1 -1
- package/dist/carousel/index.js +1 -1
- package/dist/cascader/index.js +2 -2
- package/dist/checkbox/index.js +2 -2
- package/dist/{chunk-7P3Q6H2V.js → chunk-2F5MMMVP.js} +4 -4
- package/dist/{chunk-7P3Q6H2V.js.map → chunk-2F5MMMVP.js.map} +1 -1
- package/dist/chunk-2TLOWZE4.js +689 -0
- package/dist/chunk-2TLOWZE4.js.map +1 -0
- package/dist/{chunk-ITCXCSUS.js → chunk-3BZE6BBJ.js} +9 -4
- package/dist/chunk-3BZE6BBJ.js.map +1 -0
- package/dist/{chunk-6QZFWSN7.js → chunk-3PWILVOE.js} +13 -6
- package/dist/chunk-3PWILVOE.js.map +1 -0
- package/dist/{chunk-M3AALH7G.js → chunk-4F7U5UPY.js} +16 -8
- package/dist/chunk-4F7U5UPY.js.map +1 -0
- package/dist/{chunk-QKSDVYKF.js → chunk-4FFVNUTK.js} +5 -8
- package/dist/chunk-4FFVNUTK.js.map +1 -0
- package/dist/{chunk-OV6K6GML.js → chunk-5QQH5LYU.js} +8 -8
- package/dist/chunk-5QQH5LYU.js.map +1 -0
- package/dist/{chunk-FCODTRKL.js → chunk-6BAP6QUT.js} +3 -3
- package/dist/{chunk-FCODTRKL.js.map → chunk-6BAP6QUT.js.map} +1 -1
- package/dist/chunk-6G3BMY4N.js +349 -0
- package/dist/chunk-6G3BMY4N.js.map +1 -0
- package/dist/{chunk-WMTEAMPB.js → chunk-6LYRMQOI.js} +83 -9
- package/dist/chunk-6LYRMQOI.js.map +1 -0
- package/dist/{chunk-DUNER5Q3.js → chunk-6YOOKE6C.js} +11 -6
- package/dist/chunk-6YOOKE6C.js.map +1 -0
- package/dist/chunk-764UKE6X.js +359 -0
- package/dist/chunk-764UKE6X.js.map +1 -0
- package/dist/{chunk-EGNF7BRT.js → chunk-C4SHFLFR.js} +3 -3
- package/dist/{chunk-EGNF7BRT.js.map → chunk-C4SHFLFR.js.map} +1 -1
- package/dist/{chunk-ZQTJBYKO.js → chunk-C5IGZLIT.js} +3 -3
- package/dist/{chunk-ZQTJBYKO.js.map → chunk-C5IGZLIT.js.map} +1 -1
- package/dist/{chunk-SX5UNM6C.js → chunk-CH3YMDCF.js} +6 -6
- package/dist/chunk-CH3YMDCF.js.map +1 -0
- package/dist/{chunk-I75ZSXD6.js → chunk-DUIL5BYS.js} +3 -3
- package/dist/{chunk-I75ZSXD6.js.map → chunk-DUIL5BYS.js.map} +1 -1
- package/dist/{chunk-ZPVBIQ2R.js → chunk-EHWXPH76.js} +3 -3
- package/dist/chunk-EHWXPH76.js.map +1 -0
- package/dist/{chunk-ZSS6E4T2.js → chunk-EPE3OODP.js} +31 -7
- package/dist/chunk-EPE3OODP.js.map +1 -0
- package/dist/{chunk-E222IQHF.js → chunk-ERRZ2CSG.js} +16 -8
- package/dist/chunk-ERRZ2CSG.js.map +1 -0
- package/dist/{chunk-GVEEUHM2.js → chunk-FAD45WRP.js} +7 -6
- package/dist/chunk-FAD45WRP.js.map +1 -0
- package/dist/{chunk-YPHVSPWM.js → chunk-FZSCLZF6.js} +5 -5
- package/dist/{chunk-YPHVSPWM.js.map → chunk-FZSCLZF6.js.map} +1 -1
- package/dist/{chunk-S2DZXTRN.js → chunk-GJPZOMFE.js} +8 -8
- package/dist/{chunk-S2DZXTRN.js.map → chunk-GJPZOMFE.js.map} +1 -1
- package/dist/{chunk-SB3JGUGE.js → chunk-GOLARX5K.js} +3 -3
- package/dist/{chunk-SB3JGUGE.js.map → chunk-GOLARX5K.js.map} +1 -1
- package/dist/{chunk-ZESEEYEJ.js → chunk-GVVP5TZM.js} +72 -231
- package/dist/chunk-GVVP5TZM.js.map +1 -0
- package/dist/{chunk-UK4RHCMM.js → chunk-H6G4BUPA.js} +99 -235
- package/dist/chunk-H6G4BUPA.js.map +1 -0
- package/dist/{chunk-MOQDO4XZ.js → chunk-HCOTO5WX.js} +3 -3
- package/dist/{chunk-MOQDO4XZ.js.map → chunk-HCOTO5WX.js.map} +1 -1
- package/dist/chunk-HECAAILV.js +94 -0
- package/dist/chunk-HECAAILV.js.map +1 -0
- package/dist/{chunk-OKCKLIFP.js → chunk-HK3NJMSY.js} +8 -6
- package/dist/chunk-HK3NJMSY.js.map +1 -0
- package/dist/{chunk-GGDDE7LC.js → chunk-HQLHE5RX.js} +3 -9
- package/dist/chunk-HQLHE5RX.js.map +1 -0
- package/dist/{chunk-56BHCAPI.js → chunk-I32ZQUYY.js} +6 -6
- package/dist/chunk-I32ZQUYY.js.map +1 -0
- package/dist/{chunk-D53OQERO.js → chunk-JWTWPZ32.js} +14 -6
- package/dist/chunk-JWTWPZ32.js.map +1 -0
- package/dist/{chunk-KYDQJSSW.js → chunk-KH577UDI.js} +46 -82
- package/dist/chunk-KH577UDI.js.map +1 -0
- package/dist/{chunk-XOIX5WIL.js → chunk-KJTMZJ7V.js} +6 -6
- package/dist/{chunk-XOIX5WIL.js.map → chunk-KJTMZJ7V.js.map} +1 -1
- package/dist/{chunk-XHDUO3UW.js → chunk-L5UYN5LX.js} +3 -3
- package/dist/{chunk-XHDUO3UW.js.map → chunk-L5UYN5LX.js.map} +1 -1
- package/dist/{chunk-DRCT6VZ7.js → chunk-N2WHJ3FI.js} +3 -3
- package/dist/{chunk-DRCT6VZ7.js.map → chunk-N2WHJ3FI.js.map} +1 -1
- package/dist/{chunk-ZHPYJTWP.js → chunk-O3V3BTIJ.js} +16 -6
- package/dist/chunk-O3V3BTIJ.js.map +1 -0
- package/dist/chunk-OFUPJH35.js +74 -0
- package/dist/chunk-OFUPJH35.js.map +1 -0
- package/dist/{chunk-6YVT3AL2.js → chunk-OLTQAMV2.js} +4 -5
- package/dist/chunk-OLTQAMV2.js.map +1 -0
- package/dist/chunk-ONGJXAYQ.js +144 -0
- package/dist/chunk-ONGJXAYQ.js.map +1 -0
- package/dist/{chunk-KJRKPYYZ.js → chunk-OQFYIKWR.js} +27 -25
- package/dist/chunk-OQFYIKWR.js.map +1 -0
- package/dist/{chunk-X5XIBIEF.js → chunk-PMA4VCAH.js} +3 -3
- package/dist/{chunk-X5XIBIEF.js.map → chunk-PMA4VCAH.js.map} +1 -1
- package/dist/chunk-POLVJ36Y.js +210 -0
- package/dist/chunk-POLVJ36Y.js.map +1 -0
- package/dist/{chunk-LK4EPTNG.js → chunk-POXI7JJ4.js} +27 -121
- package/dist/chunk-POXI7JJ4.js.map +1 -0
- package/dist/{chunk-L76WWJGR.js → chunk-R3TLU26W.js} +21 -33
- package/dist/chunk-R3TLU26W.js.map +1 -0
- package/dist/chunk-RFHTC6AH.js +250 -0
- package/dist/chunk-RFHTC6AH.js.map +1 -0
- package/dist/{chunk-IAQDQN6W.js → chunk-RPWYIGD3.js} +15 -36
- package/dist/chunk-RPWYIGD3.js.map +1 -0
- package/dist/{chunk-HXPMYGSR.js → chunk-T7RWQLUB.js} +4 -10
- package/dist/chunk-T7RWQLUB.js.map +1 -0
- package/dist/chunk-WRSG7WU5.js +278 -0
- package/dist/chunk-WRSG7WU5.js.map +1 -0
- package/dist/{chunk-ZYWDJMHF.js → chunk-X3YNHX77.js} +4 -4
- package/dist/{chunk-ZYWDJMHF.js.map → chunk-X3YNHX77.js.map} +1 -1
- package/dist/chunk-Y4XAXZHB.js +42 -0
- package/dist/chunk-Y4XAXZHB.js.map +1 -0
- package/dist/{chunk-JZ5F6XDO.js → chunk-YS5AIY4A.js} +3 -3
- package/dist/{chunk-JZ5F6XDO.js.map → chunk-YS5AIY4A.js.map} +1 -1
- package/dist/chunk-ZIYA7TGX.js +141 -0
- package/dist/chunk-ZIYA7TGX.js.map +1 -0
- package/dist/{chunk-QLUGKHAA.js → chunk-ZKEDJ536.js} +4 -4
- package/dist/{chunk-QLUGKHAA.js.map → chunk-ZKEDJ536.js.map} +1 -1
- package/dist/clipboard/index.d.ts.map +1 -1
- package/dist/clipboard/index.js +3 -2
- package/dist/collapse/index.js +2 -2
- package/dist/command/index.js +1 -1
- package/dist/context-menu/index.d.ts.map +1 -1
- package/dist/context-menu/index.js +2 -1
- package/dist/date-picker/index.d.ts.map +1 -1
- package/dist/date-picker/index.js +3 -3
- package/dist/date-picker/types.d.ts +0 -2
- package/dist/date-picker/types.d.ts.map +1 -1
- package/dist/dropdown/index.d.ts.map +1 -1
- package/dist/dropdown/index.js +4 -3
- package/dist/fetching-overlay/index.d.ts +1 -1
- package/dist/fetching-overlay/index.d.ts.map +1 -1
- package/dist/fetching-overlay/index.js +3 -3
- package/dist/float-input/index.js +3 -3
- package/dist/grid/index.d.ts +1 -1
- package/dist/grid/index.d.ts.map +1 -1
- package/dist/grid/index.js +1 -1
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/useControllable.d.ts +6 -0
- package/dist/hooks/useControllable.d.ts.map +1 -0
- package/dist/hooks/useDebounce.d.ts +2 -0
- package/dist/hooks/useDebounce.d.ts.map +1 -0
- package/dist/hooks/useMediaQuery.d.ts +2 -0
- package/dist/hooks/useMediaQuery.d.ts.map +1 -0
- package/dist/hooks/useRipple.d.ts +29 -0
- package/dist/hooks/useRipple.d.ts.map +1 -0
- package/dist/hooks/useThrottle.d.ts +2 -0
- package/dist/hooks/useThrottle.d.ts.map +1 -0
- package/dist/image/index.d.ts.map +1 -1
- package/dist/image/index.js +1 -1
- package/dist/image/types.d.ts +4 -0
- package/dist/image/types.d.ts.map +1 -1
- package/dist/index.d.ts +10 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +114 -56
- package/dist/index.js.map +1 -1
- package/dist/input/index.d.ts.map +1 -1
- package/dist/input/index.js +3 -3
- package/dist/input-otp/index.js +1 -1
- package/dist/input-password/index.js +4 -4
- package/dist/kbd/index.js +2 -2
- package/dist/link/index.d.ts +1 -1
- package/dist/link/index.d.ts.map +1 -1
- package/dist/link/index.js +1 -1
- package/dist/menubar/index.js +3 -3
- package/dist/multi-select/index.d.ts.map +1 -1
- package/dist/multi-select/index.js +5 -3
- package/dist/multi-select/utils.d.ts.map +1 -1
- package/dist/navigation-menu/index.js +1 -1
- package/dist/notification/index.js +2 -2
- package/dist/number-input/index.d.ts.map +1 -1
- package/dist/number-input/index.js +4 -3
- package/dist/pagination/index.d.ts.map +1 -1
- package/dist/pagination/index.js +2 -1
- package/dist/popover/index.js +2 -2
- package/dist/progress/index.d.ts.map +1 -1
- package/dist/progress/index.js +1 -1
- package/dist/progress/styles.d.ts +39 -0
- package/dist/progress/styles.d.ts.map +1 -0
- package/dist/radio/index.d.ts.map +1 -1
- package/dist/radio/index.js +2 -2
- package/dist/select/index.d.ts.map +1 -1
- package/dist/select/index.js +5 -4
- package/dist/shared/useSelectBase.d.ts +56 -0
- package/dist/shared/useSelectBase.d.ts.map +1 -0
- package/dist/skeleton/index.js +2 -2
- package/dist/slider/index.d.ts.map +1 -1
- package/dist/slider/index.js +1 -1
- package/dist/spinner/index.d.ts +1 -1
- package/dist/spinner/index.d.ts.map +1 -1
- package/dist/spinner/index.js +2 -2
- package/dist/stepper/index.js +1 -1
- package/dist/switch/index.d.ts.map +1 -1
- package/dist/switch/index.js +2 -2
- package/dist/table/index.d.ts.map +1 -1
- package/dist/table/index.js +10 -9
- package/dist/table/variants.d.ts +0 -4
- package/dist/table/variants.d.ts.map +1 -1
- package/dist/tabs/index.d.ts.map +1 -1
- package/dist/tabs/index.js +2 -2
- package/dist/tabs/types.d.ts +4 -0
- package/dist/tabs/types.d.ts.map +1 -1
- package/dist/tag/index.d.ts +1 -1
- package/dist/tag/index.d.ts.map +1 -1
- package/dist/tag/index.js +2 -2
- package/dist/timeline/index.d.ts.map +1 -1
- package/dist/timeline/index.js +1 -1
- package/dist/toast/index.d.ts.map +1 -1
- package/dist/toast/index.js +2 -2
- package/dist/toggle/index.d.ts.map +1 -1
- package/dist/toggle/index.js +2 -1
- package/dist/toggle-group/index.d.ts.map +1 -1
- package/dist/toggle-group/index.js +2 -1
- package/dist/tooltip/index.js +2 -2
- package/dist/transfer/index.d.ts +0 -1
- package/dist/transfer/index.d.ts.map +1 -1
- package/dist/transfer/index.js +3 -3
- package/dist/tree/index.d.ts.map +1 -1
- package/dist/tree/index.js +1 -1
- package/dist/tree-select/index.js +4 -4
- package/dist/upload/index.d.ts.map +1 -1
- package/dist/upload/index.js +2 -1
- package/dist/variants.d.ts +44 -163
- package/dist/variants.d.ts.map +1 -1
- package/package.json +44 -231
- package/styles/global.css +327 -220
- package/styles/themes/dark.css +57 -44
- package/styles/themes/light.css +3 -3
- package/styles/themes/presets/corporate.css +32 -30
- package/styles/themes/presets/minimal.css +32 -30
- package/styles/themes/presets/vibrant.css +38 -36
- package/dist/chunk-2K7MDR7K.js +0 -212
- package/dist/chunk-2K7MDR7K.js.map +0 -1
- package/dist/chunk-2SYAIIJE.js +0 -143
- package/dist/chunk-2SYAIIJE.js.map +0 -1
- package/dist/chunk-56BHCAPI.js.map +0 -1
- package/dist/chunk-6QZFWSN7.js.map +0 -1
- package/dist/chunk-6YVT3AL2.js.map +0 -1
- package/dist/chunk-D53OQERO.js.map +0 -1
- package/dist/chunk-DRL4CJMI.js +0 -147
- package/dist/chunk-DRL4CJMI.js.map +0 -1
- package/dist/chunk-DUNER5Q3.js.map +0 -1
- package/dist/chunk-E222IQHF.js.map +0 -1
- package/dist/chunk-FVTMKQUE.js +0 -67
- package/dist/chunk-FVTMKQUE.js.map +0 -1
- package/dist/chunk-GGDDE7LC.js.map +0 -1
- package/dist/chunk-GVEEUHM2.js.map +0 -1
- package/dist/chunk-HQVTIFXN.js +0 -494
- package/dist/chunk-HQVTIFXN.js.map +0 -1
- package/dist/chunk-HXPMYGSR.js.map +0 -1
- package/dist/chunk-IAQDQN6W.js.map +0 -1
- package/dist/chunk-ITCXCSUS.js.map +0 -1
- package/dist/chunk-KJRKPYYZ.js.map +0 -1
- package/dist/chunk-KYDQJSSW.js.map +0 -1
- package/dist/chunk-L76WWJGR.js.map +0 -1
- package/dist/chunk-LK4EPTNG.js.map +0 -1
- package/dist/chunk-M3AALH7G.js.map +0 -1
- package/dist/chunk-MBAZ7OW5.js +0 -607
- package/dist/chunk-MBAZ7OW5.js.map +0 -1
- package/dist/chunk-MGKFJWQU.js +0 -194
- package/dist/chunk-MGKFJWQU.js.map +0 -1
- package/dist/chunk-OKCKLIFP.js.map +0 -1
- package/dist/chunk-OV6K6GML.js.map +0 -1
- package/dist/chunk-PHQOHVG3.js +0 -45
- package/dist/chunk-PHQOHVG3.js.map +0 -1
- package/dist/chunk-QKSDVYKF.js.map +0 -1
- package/dist/chunk-SJHNFRXG.js +0 -276
- package/dist/chunk-SJHNFRXG.js.map +0 -1
- package/dist/chunk-SX5UNM6C.js.map +0 -1
- package/dist/chunk-T4MGK3WE.js +0 -143
- package/dist/chunk-T4MGK3WE.js.map +0 -1
- package/dist/chunk-UK4RHCMM.js.map +0 -1
- package/dist/chunk-WAPZ4QAN.js +0 -76
- package/dist/chunk-WAPZ4QAN.js.map +0 -1
- package/dist/chunk-WMTEAMPB.js.map +0 -1
- package/dist/chunk-ZESEEYEJ.js.map +0 -1
- package/dist/chunk-ZHPYJTWP.js.map +0 -1
- package/dist/chunk-ZPVBIQ2R.js.map +0 -1
- package/dist/chunk-ZSS6E4T2.js.map +0 -1
- package/dist/form/index.d.ts +0 -31
- package/dist/form/index.d.ts.map +0 -1
- package/dist/form/index.js +0 -4
- package/dist/form/index.js.map +0 -1
- package/dist/form/types.d.ts +0 -45
- package/dist/form/types.d.ts.map +0 -1
- package/dist/ribbon/index.d.ts +0 -6
- package/dist/ribbon/index.d.ts.map +0 -1
- package/dist/ribbon/index.js +0 -4
- package/dist/ribbon/index.js.map +0 -1
- package/dist/ribbon/types.d.ts +0 -26
- package/dist/ribbon/types.d.ts.map +0 -1
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
import { getValidationStatus } from './chunk-NGYLRX6F.js';
|
|
2
|
+
import { useVirtualizer } from '@tanstack/react-virtual';
|
|
3
|
+
import React, { useId, useCallback } from 'react';
|
|
4
|
+
|
|
5
|
+
function useSelectBase(config) {
|
|
6
|
+
const {
|
|
7
|
+
options,
|
|
8
|
+
virtualizeThreshold = 50,
|
|
9
|
+
maxDropdownHeight = 300,
|
|
10
|
+
label,
|
|
11
|
+
idPrefix,
|
|
12
|
+
error,
|
|
13
|
+
warning,
|
|
14
|
+
info,
|
|
15
|
+
success,
|
|
16
|
+
helperText
|
|
17
|
+
} = config;
|
|
18
|
+
const uniqueId = useId();
|
|
19
|
+
const labelId = `${idPrefix}-label-${uniqueId}`;
|
|
20
|
+
const listboxId = `${idPrefix}-listbox-${uniqueId}`;
|
|
21
|
+
const helperId = `${idPrefix}-helper-${uniqueId}`;
|
|
22
|
+
const { status, message: helperMessage } = getValidationStatus({
|
|
23
|
+
error,
|
|
24
|
+
warning,
|
|
25
|
+
info,
|
|
26
|
+
success,
|
|
27
|
+
helperText
|
|
28
|
+
});
|
|
29
|
+
const [isOpen, setIsOpen] = React.useState(false);
|
|
30
|
+
const [parentNode, setParentNode] = React.useState(
|
|
31
|
+
null
|
|
32
|
+
);
|
|
33
|
+
const [searchQuery, setSearchQuery] = React.useState("");
|
|
34
|
+
const [highlightedIndex, setHighlightedIndex] = React.useState(-1);
|
|
35
|
+
const [showTopArrow, setShowTopArrow] = React.useState(false);
|
|
36
|
+
const [showBottomArrow, setShowBottomArrow] = React.useState(false);
|
|
37
|
+
const triggerRef = React.useRef(null);
|
|
38
|
+
const inputRef = React.useRef(null);
|
|
39
|
+
const scrollContainerRef = React.useRef(null);
|
|
40
|
+
const onSelectRef = React.useRef(config.onSelectOption);
|
|
41
|
+
React.useEffect(() => {
|
|
42
|
+
onSelectRef.current = config.onSelectOption;
|
|
43
|
+
}, [config.onSelectOption]);
|
|
44
|
+
const groupedOptions = React.useMemo(() => {
|
|
45
|
+
const groups = {};
|
|
46
|
+
const ungrouped = [];
|
|
47
|
+
options.forEach((option) => {
|
|
48
|
+
if (option.group) {
|
|
49
|
+
if (!groups[option.group]) {
|
|
50
|
+
groups[option.group] = [];
|
|
51
|
+
}
|
|
52
|
+
groups[option.group].push(option);
|
|
53
|
+
} else {
|
|
54
|
+
ungrouped.push(option);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
return { groups, ungrouped };
|
|
58
|
+
}, [options]);
|
|
59
|
+
const flattenedOptions = React.useMemo(() => {
|
|
60
|
+
const items = [];
|
|
61
|
+
groupedOptions.ungrouped.forEach((option) => {
|
|
62
|
+
items.push({ type: "option", data: option });
|
|
63
|
+
});
|
|
64
|
+
Object.entries(groupedOptions.groups).forEach(
|
|
65
|
+
([groupName, groupOptions]) => {
|
|
66
|
+
items.push({ type: "group", data: groupName });
|
|
67
|
+
groupOptions.forEach((option) => {
|
|
68
|
+
items.push({ type: "option", data: option });
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
);
|
|
72
|
+
return items;
|
|
73
|
+
}, [groupedOptions]);
|
|
74
|
+
const filteredOptions = React.useMemo(() => {
|
|
75
|
+
if (!searchQuery) return flattenedOptions;
|
|
76
|
+
const query = searchQuery.toLowerCase();
|
|
77
|
+
const matchingOptions = new Set(
|
|
78
|
+
flattenedOptions.filter(
|
|
79
|
+
(item) => item.type === "option" && item.data.label.toLowerCase().includes(query)
|
|
80
|
+
)
|
|
81
|
+
);
|
|
82
|
+
return flattenedOptions.filter((item) => {
|
|
83
|
+
if (item.type === "group") {
|
|
84
|
+
const groupName = item.data;
|
|
85
|
+
return flattenedOptions.some(
|
|
86
|
+
(other) => other.type === "option" && other.data.group === groupName && matchingOptions.has(other)
|
|
87
|
+
);
|
|
88
|
+
}
|
|
89
|
+
return matchingOptions.has(item);
|
|
90
|
+
});
|
|
91
|
+
}, [flattenedOptions, searchQuery]);
|
|
92
|
+
const selectableOptions = React.useMemo(
|
|
93
|
+
() => filteredOptions.filter(
|
|
94
|
+
(item) => item.type === "option" && !item.data.disabled
|
|
95
|
+
),
|
|
96
|
+
[filteredOptions]
|
|
97
|
+
);
|
|
98
|
+
const shouldVirtualize = filteredOptions.length > virtualizeThreshold;
|
|
99
|
+
const virtualizer = useVirtualizer({
|
|
100
|
+
count: filteredOptions.length,
|
|
101
|
+
getScrollElement: () => parentNode,
|
|
102
|
+
estimateSize: () => 40,
|
|
103
|
+
enabled: shouldVirtualize,
|
|
104
|
+
overscan: 10
|
|
105
|
+
});
|
|
106
|
+
const virtualizerRef = React.useRef(virtualizer);
|
|
107
|
+
React.useEffect(() => {
|
|
108
|
+
virtualizerRef.current = virtualizer;
|
|
109
|
+
}, [virtualizer]);
|
|
110
|
+
const refCallback = useCallback((node) => {
|
|
111
|
+
if (node) {
|
|
112
|
+
setParentNode(node);
|
|
113
|
+
scrollContainerRef.current = node;
|
|
114
|
+
}
|
|
115
|
+
}, []);
|
|
116
|
+
const handleInputChange = React.useCallback(
|
|
117
|
+
(e) => {
|
|
118
|
+
setSearchQuery(e.target.value);
|
|
119
|
+
if (!isOpen) setIsOpen(true);
|
|
120
|
+
},
|
|
121
|
+
[isOpen]
|
|
122
|
+
);
|
|
123
|
+
const handleInputClick = React.useCallback(
|
|
124
|
+
(e) => {
|
|
125
|
+
e.stopPropagation();
|
|
126
|
+
if (!isOpen) setIsOpen(true);
|
|
127
|
+
},
|
|
128
|
+
[isOpen]
|
|
129
|
+
);
|
|
130
|
+
const handleScroll = React.useCallback(
|
|
131
|
+
(e) => {
|
|
132
|
+
const element = e.currentTarget;
|
|
133
|
+
const { scrollTop, scrollHeight, clientHeight } = element;
|
|
134
|
+
setShowTopArrow(scrollTop > 0);
|
|
135
|
+
setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);
|
|
136
|
+
},
|
|
137
|
+
[]
|
|
138
|
+
);
|
|
139
|
+
const handleKeyDown = React.useCallback(
|
|
140
|
+
(e) => {
|
|
141
|
+
if (!isOpen && e.key !== "Tab") {
|
|
142
|
+
if (e.key === "Enter" || e.key === " " || e.key === "ArrowDown") {
|
|
143
|
+
e.preventDefault();
|
|
144
|
+
setIsOpen(true);
|
|
145
|
+
}
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
const currentSelectableOptions = filteredOptions.filter(
|
|
149
|
+
(item) => item.type === "option" && !item.data.disabled
|
|
150
|
+
);
|
|
151
|
+
switch (e.key) {
|
|
152
|
+
case "Escape":
|
|
153
|
+
e.preventDefault();
|
|
154
|
+
setIsOpen(false);
|
|
155
|
+
setSearchQuery("");
|
|
156
|
+
setHighlightedIndex(-1);
|
|
157
|
+
inputRef.current?.blur();
|
|
158
|
+
break;
|
|
159
|
+
case "ArrowDown":
|
|
160
|
+
e.preventDefault();
|
|
161
|
+
setHighlightedIndex((prev) => {
|
|
162
|
+
const nextIndex = Math.min(
|
|
163
|
+
prev + 1,
|
|
164
|
+
currentSelectableOptions.length - 1
|
|
165
|
+
);
|
|
166
|
+
const option = currentSelectableOptions[nextIndex];
|
|
167
|
+
if (option) {
|
|
168
|
+
const optionIndex = filteredOptions.indexOf(option);
|
|
169
|
+
if (shouldVirtualize && virtualizerRef.current) {
|
|
170
|
+
virtualizerRef.current.scrollToIndex(optionIndex, {
|
|
171
|
+
align: "auto"
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return nextIndex;
|
|
176
|
+
});
|
|
177
|
+
break;
|
|
178
|
+
case "ArrowUp":
|
|
179
|
+
e.preventDefault();
|
|
180
|
+
setHighlightedIndex((prev) => {
|
|
181
|
+
const nextIndex = Math.max(prev - 1, 0);
|
|
182
|
+
const option = currentSelectableOptions[nextIndex];
|
|
183
|
+
if (option) {
|
|
184
|
+
const optionIndex = filteredOptions.indexOf(option);
|
|
185
|
+
if (shouldVirtualize && virtualizerRef.current) {
|
|
186
|
+
virtualizerRef.current.scrollToIndex(optionIndex, {
|
|
187
|
+
align: "auto"
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
return nextIndex;
|
|
192
|
+
});
|
|
193
|
+
break;
|
|
194
|
+
case "Enter":
|
|
195
|
+
e.preventDefault();
|
|
196
|
+
if (highlightedIndex >= 0 && highlightedIndex < currentSelectableOptions.length) {
|
|
197
|
+
const item = currentSelectableOptions[highlightedIndex];
|
|
198
|
+
if (item) {
|
|
199
|
+
const option = item.data;
|
|
200
|
+
onSelectRef.current(option);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
break;
|
|
204
|
+
case "Home":
|
|
205
|
+
e.preventDefault();
|
|
206
|
+
setHighlightedIndex(0);
|
|
207
|
+
if (shouldVirtualize && virtualizerRef.current) {
|
|
208
|
+
virtualizerRef.current.scrollToIndex(0);
|
|
209
|
+
}
|
|
210
|
+
break;
|
|
211
|
+
case "End":
|
|
212
|
+
e.preventDefault();
|
|
213
|
+
setHighlightedIndex(currentSelectableOptions.length - 1);
|
|
214
|
+
if (shouldVirtualize && virtualizerRef.current) {
|
|
215
|
+
virtualizerRef.current.scrollToIndex(filteredOptions.length - 1);
|
|
216
|
+
}
|
|
217
|
+
break;
|
|
218
|
+
}
|
|
219
|
+
},
|
|
220
|
+
[isOpen, filteredOptions, highlightedIndex, shouldVirtualize]
|
|
221
|
+
);
|
|
222
|
+
React.useEffect(() => {
|
|
223
|
+
if (isOpen) {
|
|
224
|
+
const timeoutId = setTimeout(() => {
|
|
225
|
+
const element = scrollContainerRef.current;
|
|
226
|
+
if (element) {
|
|
227
|
+
const { scrollTop, scrollHeight, clientHeight } = element;
|
|
228
|
+
setShowTopArrow(scrollTop > 0);
|
|
229
|
+
setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);
|
|
230
|
+
}
|
|
231
|
+
}, 50);
|
|
232
|
+
return () => clearTimeout(timeoutId);
|
|
233
|
+
} else {
|
|
234
|
+
setShowTopArrow(false);
|
|
235
|
+
setShowBottomArrow(false);
|
|
236
|
+
return void 0;
|
|
237
|
+
}
|
|
238
|
+
}, [isOpen, filteredOptions, shouldVirtualize]);
|
|
239
|
+
return {
|
|
240
|
+
// State
|
|
241
|
+
isOpen,
|
|
242
|
+
setIsOpen,
|
|
243
|
+
searchQuery,
|
|
244
|
+
setSearchQuery,
|
|
245
|
+
highlightedIndex,
|
|
246
|
+
setHighlightedIndex,
|
|
247
|
+
showTopArrow,
|
|
248
|
+
showBottomArrow,
|
|
249
|
+
// Refs
|
|
250
|
+
triggerRef,
|
|
251
|
+
inputRef,
|
|
252
|
+
scrollContainerRef,
|
|
253
|
+
// Computed
|
|
254
|
+
filteredOptions,
|
|
255
|
+
selectableOptions,
|
|
256
|
+
shouldVirtualize,
|
|
257
|
+
virtualizer,
|
|
258
|
+
maxDropdownHeight,
|
|
259
|
+
label,
|
|
260
|
+
// IDs & validation
|
|
261
|
+
uniqueId,
|
|
262
|
+
labelId,
|
|
263
|
+
listboxId,
|
|
264
|
+
helperId,
|
|
265
|
+
status,
|
|
266
|
+
helperMessage,
|
|
267
|
+
// Handlers
|
|
268
|
+
handleInputChange,
|
|
269
|
+
handleInputClick,
|
|
270
|
+
handleScroll,
|
|
271
|
+
handleKeyDown,
|
|
272
|
+
refCallback
|
|
273
|
+
};
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
export { useSelectBase };
|
|
277
|
+
//# sourceMappingURL=chunk-WRSG7WU5.js.map
|
|
278
|
+
//# sourceMappingURL=chunk-WRSG7WU5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/shared/useSelectBase.ts"],"names":[],"mappings":"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","file":"chunk-WRSG7WU5.js","sourcesContent":["import { useVirtualizer } from \"@tanstack/react-virtual\";\nimport React, { useCallback, useId } from \"react\";\n\nimport { getValidationStatus } from \"../utils\";\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\nexport interface SelectBaseOption {\n value: string | number;\n label: string;\n disabled?: boolean;\n group?: string;\n}\n\nexport interface UseSelectBaseConfig<O extends SelectBaseOption> {\n options: O[];\n /** Called when the user presses Enter on a highlighted option (or clicks one via the hook's helpers). */\n onSelectOption: (option: O) => void;\n virtualizeThreshold?: number;\n maxDropdownHeight?: number;\n label?: string;\n idPrefix: string; // 'select' or 'multiselect'\n error?: string | boolean;\n warning?: string | boolean;\n info?: string | boolean;\n success?: string | boolean;\n helperText?: string;\n}\n\nexport interface FlattenedItem<O extends SelectBaseOption> {\n type: \"option\" | \"group\";\n data: O | string;\n}\n\n// ---------------------------------------------------------------------------\n// Hook\n// ---------------------------------------------------------------------------\n\nexport function useSelectBase<O extends SelectBaseOption>(\n config: UseSelectBaseConfig<O>,\n) {\n const {\n options,\n virtualizeThreshold = 50,\n maxDropdownHeight = 300,\n label,\n idPrefix,\n error,\n warning,\n info,\n success,\n helperText,\n } = config;\n\n // -- IDs / validation -------------------------------------------------------\n const uniqueId = useId();\n const labelId = `${idPrefix}-label-${uniqueId}`;\n const listboxId = `${idPrefix}-listbox-${uniqueId}`;\n const helperId = `${idPrefix}-helper-${uniqueId}`;\n\n const { status, message: helperMessage } = getValidationStatus({\n error,\n warning,\n info,\n success,\n helperText,\n });\n\n // -- State ------------------------------------------------------------------\n const [isOpen, setIsOpen] = React.useState(false);\n const [parentNode, setParentNode] = React.useState<HTMLDivElement | null>(\n null,\n );\n const [searchQuery, setSearchQuery] = React.useState(\"\");\n const [highlightedIndex, setHighlightedIndex] = React.useState(-1);\n const [showTopArrow, setShowTopArrow] = React.useState(false);\n const [showBottomArrow, setShowBottomArrow] = React.useState(false);\n\n // -- Refs -------------------------------------------------------------------\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const scrollContainerRef = React.useRef<HTMLDivElement>(null);\n\n // Store onSelectOption in a ref so handleKeyDown doesn't depend on it\n const onSelectRef = React.useRef(config.onSelectOption);\n React.useEffect(() => {\n onSelectRef.current = config.onSelectOption;\n }, [config.onSelectOption]);\n\n // -- Memos ------------------------------------------------------------------\n const groupedOptions = React.useMemo(() => {\n const groups: Record<string, O[]> = {};\n const ungrouped: O[] = [];\n\n options.forEach((option) => {\n if (option.group) {\n if (!groups[option.group]) {\n groups[option.group] = [];\n }\n groups[option.group]!.push(option);\n } else {\n ungrouped.push(option);\n }\n });\n\n return { groups, ungrouped };\n }, [options]);\n\n const flattenedOptions = React.useMemo(() => {\n const items: Array<FlattenedItem<O>> = [];\n\n groupedOptions.ungrouped.forEach((option) => {\n items.push({ type: \"option\", data: option });\n });\n\n Object.entries(groupedOptions.groups).forEach(\n ([groupName, groupOptions]) => {\n items.push({ type: \"group\", data: groupName });\n (groupOptions as O[]).forEach((option) => {\n items.push({ type: \"option\", data: option });\n });\n },\n );\n\n return items;\n }, [groupedOptions]);\n\n const filteredOptions = React.useMemo(() => {\n if (!searchQuery) return flattenedOptions;\n\n const query = searchQuery.toLowerCase();\n const matchingOptions = new Set(\n flattenedOptions.filter(\n (item) =>\n item.type === \"option\" &&\n (item.data as O).label.toLowerCase().includes(query),\n ),\n );\n\n return flattenedOptions.filter((item) => {\n if (item.type === \"group\") {\n const groupName = item.data as string;\n return flattenedOptions.some(\n (other) =>\n other.type === \"option\" &&\n (other.data as O).group === groupName &&\n matchingOptions.has(other),\n );\n }\n return matchingOptions.has(item);\n });\n }, [flattenedOptions, searchQuery]);\n\n const selectableOptions = React.useMemo(\n () =>\n filteredOptions.filter(\n (item) => item.type === \"option\" && !(item.data as O).disabled,\n ),\n [filteredOptions],\n );\n\n const shouldVirtualize = filteredOptions.length > virtualizeThreshold;\n\n // -- Virtualizer ------------------------------------------------------------\n const virtualizer = useVirtualizer({\n count: filteredOptions.length,\n getScrollElement: () => parentNode,\n estimateSize: () => 40,\n enabled: shouldVirtualize,\n overscan: 10,\n });\n\n const virtualizerRef = React.useRef(virtualizer);\n React.useEffect(() => {\n virtualizerRef.current = virtualizer;\n }, [virtualizer]);\n\n const refCallback = useCallback((node: HTMLDivElement) => {\n if (node) {\n setParentNode(node);\n scrollContainerRef.current = node;\n }\n }, []);\n\n // -- Handlers ---------------------------------------------------------------\n const handleInputChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setSearchQuery(e.target.value);\n if (!isOpen) setIsOpen(true);\n },\n [isOpen],\n );\n\n const handleInputClick = React.useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!isOpen) setIsOpen(true);\n },\n [isOpen],\n );\n\n const handleScroll = React.useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const element = e.currentTarget;\n const { scrollTop, scrollHeight, clientHeight } = element;\n\n setShowTopArrow(scrollTop > 0);\n setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);\n },\n [],\n );\n\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent) => {\n if (!isOpen && e.key !== \"Tab\") {\n if (e.key === \"Enter\" || e.key === \" \" || e.key === \"ArrowDown\") {\n e.preventDefault();\n setIsOpen(true);\n }\n return;\n }\n\n const currentSelectableOptions = filteredOptions.filter(\n (item) => item.type === \"option\" && !(item.data as O).disabled,\n );\n\n switch (e.key) {\n case \"Escape\":\n e.preventDefault();\n setIsOpen(false);\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n inputRef.current?.blur();\n break;\n\n case \"ArrowDown\":\n e.preventDefault();\n setHighlightedIndex((prev) => {\n const nextIndex = Math.min(\n prev + 1,\n currentSelectableOptions.length - 1,\n );\n const option = currentSelectableOptions[nextIndex];\n if (option) {\n const optionIndex = filteredOptions.indexOf(option);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(optionIndex, {\n align: \"auto\",\n });\n }\n }\n return nextIndex;\n });\n break;\n\n case \"ArrowUp\":\n e.preventDefault();\n setHighlightedIndex((prev) => {\n const nextIndex = Math.max(prev - 1, 0);\n const option = currentSelectableOptions[nextIndex];\n if (option) {\n const optionIndex = filteredOptions.indexOf(option);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(optionIndex, {\n align: \"auto\",\n });\n }\n }\n return nextIndex;\n });\n break;\n\n case \"Enter\":\n e.preventDefault();\n if (\n highlightedIndex >= 0 &&\n highlightedIndex < currentSelectableOptions.length\n ) {\n const item = currentSelectableOptions[highlightedIndex];\n if (item) {\n const option = item.data as O;\n onSelectRef.current(option);\n }\n }\n break;\n\n case \"Home\":\n e.preventDefault();\n setHighlightedIndex(0);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(0);\n }\n break;\n\n case \"End\":\n e.preventDefault();\n setHighlightedIndex(currentSelectableOptions.length - 1);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(filteredOptions.length - 1);\n }\n break;\n\n default:\n break;\n }\n },\n [isOpen, filteredOptions, highlightedIndex, shouldVirtualize],\n );\n\n // -- Effects ----------------------------------------------------------------\n // Check initial scroll state when dropdown opens\n React.useEffect(() => {\n if (isOpen) {\n const timeoutId = setTimeout(() => {\n const element = scrollContainerRef.current;\n if (element) {\n const { scrollTop, scrollHeight, clientHeight } = element;\n setShowTopArrow(scrollTop > 0);\n setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);\n }\n }, 50);\n\n return () => clearTimeout(timeoutId);\n } else {\n setShowTopArrow(false);\n setShowBottomArrow(false);\n return undefined;\n }\n }, [isOpen, filteredOptions, shouldVirtualize]);\n\n // -- Return -----------------------------------------------------------------\n return {\n // State\n isOpen,\n setIsOpen,\n searchQuery,\n setSearchQuery,\n highlightedIndex,\n setHighlightedIndex,\n showTopArrow,\n showBottomArrow,\n\n // Refs\n triggerRef,\n inputRef,\n scrollContainerRef,\n\n // Computed\n filteredOptions,\n selectableOptions,\n shouldVirtualize,\n virtualizer,\n maxDropdownHeight,\n label,\n\n // IDs & validation\n uniqueId,\n labelId,\n listboxId,\n helperId,\n status,\n helperMessage,\n\n // Handlers\n handleInputChange,\n handleInputClick,\n handleScroll,\n handleKeyDown,\n refCallback,\n };\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { createNotificationColorVariants, componentColors } from './chunk-
|
|
1
|
+
import { createNotificationColorVariants, componentColors } from './chunk-POXI7JJ4.js';
|
|
2
2
|
import { cn, iconSizes } from './chunk-NGYLRX6F.js';
|
|
3
3
|
import { cva } from 'class-variance-authority';
|
|
4
4
|
import { X } from 'lucide-react';
|
|
@@ -91,7 +91,7 @@ var Notification = React.memo(
|
|
|
91
91
|
{
|
|
92
92
|
type: "button",
|
|
93
93
|
onClick: onClose,
|
|
94
|
-
className: cn("shrink-0 rounded-sm opacity-70 hover:opacity-100 transition-
|
|
94
|
+
className: cn("shrink-0 rounded-sm opacity-70 hover:opacity-100 transition-opacity", "notification_closeButton", classNames?.closeButton),
|
|
95
95
|
"aria-label": "Close notification",
|
|
96
96
|
children: /* @__PURE__ */ jsx(X, { className: cn(iconSizes[size], "notification_icon", classNames?.icon), "aria-hidden": "true" })
|
|
97
97
|
}
|
|
@@ -105,5 +105,5 @@ Notification.displayName = "Notification";
|
|
|
105
105
|
var notification_default = Notification;
|
|
106
106
|
|
|
107
107
|
export { notification_default };
|
|
108
|
-
//# sourceMappingURL=chunk-
|
|
109
|
-
//# sourceMappingURL=chunk-
|
|
108
|
+
//# sourceMappingURL=chunk-X3YNHX77.js.map
|
|
109
|
+
//# sourceMappingURL=chunk-X3YNHX77.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/notification/index.tsx"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"sources":["../src/notification/index.tsx"],"names":[],"mappings":";;;;;;;AAUA,IAAM,oBAAA,GAAuB,GAAA;AAAA,EAC3B,kDAAA;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,OAAA,EAAS;AAAA,QACP,OAAA,EAAS,EAAA;AAAA,QACT,KAAA,EAAO,EAAA;AAAA,QACP,OAAA,EAAS,qBAAA;AAAA,QACT,IAAA,EAAM;AAAA,OACR;AAAA,MACA,KAAA,EAAO;AAAA,QACL,OAAA,EAAS,EAAA;AAAA,QACT,OAAA,EAAS,EAAA;AAAA,QACT,SAAA,EAAW,EAAA;AAAA,QACX,MAAA,EAAQ,EAAA;AAAA,QACR,OAAA,EAAS,EAAA;AAAA,QACT,KAAA,EAAO,EAAA;AAAA,QACP,OAAA,EAAS,EAAA;AAAA,QACT,IAAA,EAAM;AAAA,OACR;AAAA,MACA,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,mBAAA;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI;AAAA;AACN,KACF;AAAA,IACA,gBAAA,EAAkB,gCAAgC,eAAA,EAAiB;AAAA,MACjE,SAAA;AAAA,MACA,OAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA,KACD,CAAA;AAAA,IACD,eAAA,EAAiB;AAAA,MACf,OAAA,EAAS,SAAA;AAAA,MACT,KAAA,EAAO,SAAA;AAAA,MACP,IAAA,EAAM;AAAA;AACR;AAEJ,CAAA;AAEA,IAAM,eAAe,KAAA,CAAM,IAAA;AAAA,EACzB,CAAC;AAAA,IACC,KAAA;AAAA,IACA,WAAA;AAAA,IACA,OAAA,GAAU,SAAA;AAAA,IACV,KAAA,GAAQ,SAAA;AAAA,IACR,IAAA,GAAO,IAAA;AAAA,IACP,QAAA,GAAW,IAAA;AAAA,IACX,OAAA;AAAA,IACA,MAAA;AAAA,IACA,SAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF,KAAM;AACJ,IAAA,uBACE,IAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,IAAA,EAAK,OAAA;AAAA,QACL,WAAA,EAAU,QAAA;AAAA,QACV,aAAA,EAAY,MAAA;AAAA,QACZ,SAAA,EAAW,EAAA;AAAA,UACT,mBAAA;AAAA,UACA,oBAAA,CAAqB,EAAE,OAAA,EAAS,KAAA,EAAO,MAAM,CAAA;AAAA,UAC7C,SAAA;AAAA,UACA,UAAA,EAAY;AAAA,SACd;AAAA,QAEA,QAAA,EAAA;AAAA,0BAAA,IAAA,CAAC,SAAI,SAAA,EAAW,EAAA,CAAG,kBAAkB,sBAAA,EAAwB,UAAA,EAAY,OAAO,CAAA,EAC7E,QAAA,EAAA;AAAA,YAAA,KAAA,oBAAS,GAAA,CAAC,SAAI,SAAA,EAAW,EAAA,CAAG,8BAA8B,oBAAA,EAAsB,UAAA,EAAY,KAAK,CAAA,EAAI,QAAA,EAAA,KAAA,EAAM,CAAA;AAAA,YAC3G,WAAA,oBACC,GAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAW,EAAA,CAAG,sBAAsB,0BAAA,EAA4B,UAAA,EAAY,WAAW,CAAA,EAAI,QAAA,EAAA,WAAA,EAAY,CAAA;AAAA,YAE7G,QAAA,oBAAY,GAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,QAAQ,QAAA,EAAS,CAAA;AAAA,YAC5C,MAAA,oBACC,GAAA;AAAA,cAAC,QAAA;AAAA,cAAA;AAAA,gBACC,IAAA,EAAK,QAAA;AAAA,gBACL,SAAS,MAAA,CAAO,OAAA;AAAA,gBAChB,SAAA,EAAW,EAAA,CAAG,uDAAA,EAAyD,qBAAA,EAAuB,YAAY,MAAM,CAAA;AAAA,gBAE/G,QAAA,EAAA,MAAA,CAAO;AAAA;AAAA;AACV,WAAA,EAEJ,CAAA;AAAA,UAEC,QAAA,oBACC,GAAA;AAAA,YAAC,QAAA;AAAA,YAAA;AAAA,cACC,IAAA,EAAK,QAAA;AAAA,cACL,OAAA,EAAS,OAAA;AAAA,cACT,SAAA,EAAW,EAAA,CAAG,qEAAA,EAAuE,0BAAA,EAA4B,YAAY,WAAW,CAAA;AAAA,cACxI,YAAA,EAAW,oBAAA;AAAA,cAEX,QAAA,kBAAA,GAAA,CAAC,CAAA,EAAA,EAAE,SAAA,EAAW,EAAA,CAAG,SAAA,CAAU,IAAI,CAAA,EAAG,mBAAA,EAAqB,UAAA,EAAY,IAAI,CAAA,EAAG,aAAA,EAAY,MAAA,EAAO;AAAA;AAAA;AAC/F;AAAA;AAAA,KAEJ;AAAA,EAEJ;AACF,CAAA;AAEA,YAAA,CAAa,WAAA,GAAc,cAAA;AAG3B,IAAO,oBAAA,GAAQ","file":"chunk-X3YNHX77.js","sourcesContent":["'use client'\n\nimport { cva } from 'class-variance-authority'\nimport { X } from 'lucide-react'\nimport React from 'react'\n\nimport { cn, iconSizes } from '../utils'\nimport { componentColors, createNotificationColorVariants } from '../variants'\nimport type { NotificationProps } from './types'\n\nconst notificationVariants = cva(\n 'relative flex gap-3 rounded-md transition-colors',\n {\n variants: {\n variant: {\n default: '',\n solid: '',\n outline: 'border-2 border-l-6',\n soft: 'border-l-6',\n },\n color: {\n default: '',\n primary: '',\n secondary: '',\n accent: '',\n success: '',\n error: '',\n warning: '',\n info: '',\n },\n size: {\n xs: 'p-2 text-xs gap-2',\n sm: 'p-3 text-sm gap-2.5',\n md: 'p-4 text-base gap-3',\n lg: 'p-5 text-lg gap-3.5',\n },\n },\n compoundVariants: createNotificationColorVariants(componentColors, [\n 'default',\n 'solid',\n 'outline',\n 'soft',\n ]),\n defaultVariants: {\n variant: 'default',\n color: 'default',\n size: 'md',\n },\n },\n)\n\nconst Notification = React.memo<NotificationProps>(\n ({\n title,\n description,\n variant = 'default',\n color = 'default',\n size = 'md',\n closable = true,\n onClose,\n action,\n className,\n classNames,\n children,\n }) => {\n return (\n <div\n role=\"alert\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n className={cn(\n 'notification_root',\n notificationVariants({ variant, color, size }),\n className,\n classNames?.root,\n )}\n >\n <div className={cn('flex-1 min-w-0', 'notification_content', classNames?.content)}>\n {title && <div className={cn('font-semibold mb-1 text-sm', 'notification_title', classNames?.title)}>{title}</div>}\n {description && (\n <div className={cn('text-sm opacity-90', 'notification_description', classNames?.description)}>{description}</div>\n )}\n {children && <div className=\"mt-2\">{children}</div>}\n {action && (\n <button\n type=\"button\"\n onClick={action.onClick}\n className={cn('mt-2 text-sm font-medium underline hover:no-underline', 'notification_action', classNames?.action)}\n >\n {action.label}\n </button>\n )}\n </div>\n\n {closable && (\n <button\n type=\"button\"\n onClick={onClose}\n className={cn('shrink-0 rounded-sm opacity-70 hover:opacity-100 transition-opacity', 'notification_closeButton', classNames?.closeButton)}\n aria-label=\"Close notification\"\n >\n <X className={cn(iconSizes[size], 'notification_icon', classNames?.icon)} aria-hidden=\"true\" />\n </button>\n )}\n </div>\n )\n },\n)\n\nNotification.displayName = 'Notification'\n\nexport type * from './types'\nexport default Notification\n"]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { textColorClasses } from './chunk-POXI7JJ4.js';
|
|
2
|
+
import { cn } from './chunk-NGYLRX6F.js';
|
|
3
|
+
import { cva } from 'class-variance-authority';
|
|
4
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
5
|
+
|
|
6
|
+
var spinnerVariants = cva(
|
|
7
|
+
"inline-block border border-current border-t-transparent rounded-full animate-spin",
|
|
8
|
+
{
|
|
9
|
+
variants: {
|
|
10
|
+
size: {
|
|
11
|
+
xs: "w-3 h-3 border",
|
|
12
|
+
sm: "w-4 h-4 border",
|
|
13
|
+
md: "w-6 h-6 border-2",
|
|
14
|
+
lg: "w-8 h-8 border-2"
|
|
15
|
+
},
|
|
16
|
+
color: textColorClasses
|
|
17
|
+
},
|
|
18
|
+
defaultVariants: {
|
|
19
|
+
size: "sm",
|
|
20
|
+
color: "primary"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
);
|
|
24
|
+
var Spinner = ({ size = "sm", color = "primary", label, className }) => {
|
|
25
|
+
return /* @__PURE__ */ jsxs("div", { "data-slot": "root", className: cn("spinner_root", "inline-flex flex-col items-center gap-2", className), children: [
|
|
26
|
+
/* @__PURE__ */ jsx(
|
|
27
|
+
"div",
|
|
28
|
+
{
|
|
29
|
+
className: spinnerVariants({ size, color }),
|
|
30
|
+
role: "status",
|
|
31
|
+
"aria-label": label || "Loading"
|
|
32
|
+
}
|
|
33
|
+
),
|
|
34
|
+
label && /* @__PURE__ */ jsx("span", { className: "text-sm text-text-secondary", children: label })
|
|
35
|
+
] });
|
|
36
|
+
};
|
|
37
|
+
Spinner.displayName = "Spinner";
|
|
38
|
+
var spinner_default = Spinner;
|
|
39
|
+
|
|
40
|
+
export { Spinner, spinner_default };
|
|
41
|
+
//# sourceMappingURL=chunk-Y4XAXZHB.js.map
|
|
42
|
+
//# sourceMappingURL=chunk-Y4XAXZHB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/spinner/index.tsx"],"names":[],"mappings":";;;;;AAOA,IAAM,eAAA,GAAkB,GAAA;AAAA,EACtB,mFAAA;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,gBAAA;AAAA,QACJ,EAAA,EAAI,gBAAA;AAAA,QACJ,EAAA,EAAI,kBAAA;AAAA,QACJ,EAAA,EAAI;AAAA,OACN;AAAA,MACA,KAAA,EAAO;AAAA,KACT;AAAA,IACA,eAAA,EAAiB;AAAA,MACf,IAAA,EAAM,IAAA;AAAA,MACN,KAAA,EAAO;AAAA;AACT;AAEJ,CAAA;AAEO,IAAM,OAAA,GAAkC,CAAC,EAAE,IAAA,GAAO,MAAM,KAAA,GAAQ,SAAA,EAAW,KAAA,EAAO,SAAA,EAAU,KAAM;AACvG,EAAA,uBACE,IAAA,CAAC,SAAI,WAAA,EAAU,MAAA,EAAO,WAAW,EAAA,CAAG,cAAA,EAAgB,yCAAA,EAA2C,SAAS,CAAA,EACtG,QAAA,EAAA;AAAA,oBAAA,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAW,eAAA,CAAgB,EAAE,IAAA,EAAM,OAAO,CAAA;AAAA,QAC1C,IAAA,EAAK,QAAA;AAAA,QACL,cAAY,KAAA,IAAS;AAAA;AAAA,KACvB;AAAA,IACC,KAAA,oBAAS,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,+BAA+B,QAAA,EAAA,KAAA,EAAM;AAAA,GAAA,EACjE,CAAA;AAEJ;AAEA,OAAA,CAAQ,WAAA,GAAc,SAAA;AAGtB,IAAO,eAAA,GAAQ","file":"chunk-Y4XAXZHB.js","sourcesContent":["import { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport { textColorClasses } from '../variants'\nimport type { SpinnerProps } from './types'\n\nconst spinnerVariants = cva(\n 'inline-block border border-current border-t-transparent rounded-full animate-spin',\n {\n variants: {\n size: {\n xs: 'w-3 h-3 border',\n sm: 'w-4 h-4 border',\n md: 'w-6 h-6 border-2',\n lg: 'w-8 h-8 border-2',\n },\n color: textColorClasses,\n },\n defaultVariants: {\n size: 'sm',\n color: 'primary',\n },\n },\n)\n\nexport const Spinner: React.FC<SpinnerProps> = ({ size = 'sm', color = 'primary', label, className }) => {\n return (\n <div data-slot=\"root\" className={cn('spinner_root', 'inline-flex flex-col items-center gap-2', className)}>\n <div\n className={spinnerVariants({ size, color })}\n role=\"status\"\n aria-label={label || 'Loading'}\n />\n {label && <span className=\"text-sm text-text-secondary\">{label}</span>}\n </div>\n )\n}\n\nSpinner.displayName = 'Spinner'\n\nexport type * from './types'\nexport default Spinner\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { bgSkeletonColorClasses } from './chunk-
|
|
1
|
+
import { bgSkeletonColorClasses } from './chunk-POXI7JJ4.js';
|
|
2
2
|
import { cn } from './chunk-NGYLRX6F.js';
|
|
3
3
|
import { cva } from 'class-variance-authority';
|
|
4
4
|
import React from 'react';
|
|
@@ -39,5 +39,5 @@ Skeleton.displayName = "Skeleton";
|
|
|
39
39
|
var skeleton_default = Skeleton;
|
|
40
40
|
|
|
41
41
|
export { skeleton_default };
|
|
42
|
-
//# sourceMappingURL=chunk-
|
|
43
|
-
//# sourceMappingURL=chunk-
|
|
42
|
+
//# sourceMappingURL=chunk-YS5AIY4A.js.map
|
|
43
|
+
//# sourceMappingURL=chunk-YS5AIY4A.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/skeleton/index.tsx"],"names":[],"mappings":";;;;;;AAOA,IAAM,gBAAA,GAAmB,IAAI,uBAAA,EAAyB;AAAA,EACpD,QAAA,EAAU;AAAA,IACR,IAAA,EAAM;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI;AAAA,KACN;AAAA,IACA,KAAA,EAAO;AAAA,GACT;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,IAAA,EAAM,IAAA;AAAA,IACN,KAAA,EAAO;AAAA;AAEX,CAAC,CAAA;AAED,IAAM,WAAW,KAAA,CAAM,IAAA;AAAA,EACrB,CAAC,EAAE,KAAA,GAAQ,SAAA,EAAW,OAAO,IAAA,EAAM,SAAA,EAAW,MAAA,GAAS,KAAA,EAAM,KAAM;AACjE,IAAA,uBACE,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,WAAA,EAAU,MAAA;AAAA,QACV,SAAA,EAAW,EAAA;AAAA,UACT,eAAA;AAAA,UACA,gBAAA,CAAiB,EAAE,IAAA,EAAM,KAAA,EAAO,CAAA;AAAA,UAChC,MAAA,IAAU,4BAAA;AAAA,UACV;AAAA;AACF;AAAA,KACF;AAAA,EAEJ;AACF,CAAA;AAEA,QAAA,CAAS,WAAA,GAAc,UAAA;AAGvB,IAAO,gBAAA,GAAQ","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/skeleton/index.tsx"],"names":[],"mappings":";;;;;;AAOA,IAAM,gBAAA,GAAmB,IAAI,uBAAA,EAAyB;AAAA,EACpD,QAAA,EAAU;AAAA,IACR,IAAA,EAAM;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI;AAAA,KACN;AAAA,IACA,KAAA,EAAO;AAAA,GACT;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,IAAA,EAAM,IAAA;AAAA,IACN,KAAA,EAAO;AAAA;AAEX,CAAC,CAAA;AAED,IAAM,WAAW,KAAA,CAAM,IAAA;AAAA,EACrB,CAAC,EAAE,KAAA,GAAQ,SAAA,EAAW,OAAO,IAAA,EAAM,SAAA,EAAW,MAAA,GAAS,KAAA,EAAM,KAAM;AACjE,IAAA,uBACE,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,WAAA,EAAU,MAAA;AAAA,QACV,SAAA,EAAW,EAAA;AAAA,UACT,eAAA;AAAA,UACA,gBAAA,CAAiB,EAAE,IAAA,EAAM,KAAA,EAAO,CAAA;AAAA,UAChC,MAAA,IAAU,4BAAA;AAAA,UACV;AAAA;AACF;AAAA,KACF;AAAA,EAEJ;AACF,CAAA;AAEA,QAAA,CAAS,WAAA,GAAc,UAAA;AAGvB,IAAO,gBAAA,GAAQ","file":"chunk-YS5AIY4A.js","sourcesContent":["import { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport { bgSkeletonColorClasses } from '../variants'\nimport type { SkeletonProps } from './types'\n\nconst skeletonVariants = cva('animate-pulse rounded', {\n variants: {\n size: {\n xs: 'h-3',\n sm: 'h-4',\n md: 'h-5',\n lg: 'h-6',\n },\n color: bgSkeletonColorClasses,\n },\n defaultVariants: {\n size: 'md',\n color: 'default',\n },\n})\n\nconst Skeleton = React.memo<SkeletonProps>(\n ({ color = 'default', size = 'md', className, circle = false }) => {\n return (\n <div\n data-slot=\"root\"\n className={cn(\n 'skeleton_root',\n skeletonVariants({ size, color }),\n circle && 'rounded-full aspect-square',\n className,\n )}\n />\n )\n },\n)\n\nSkeleton.displayName = 'Skeleton'\n\nexport type * from './types'\nexport default Skeleton\n"]}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { createAllColorVariants, componentColors } from './chunk-POXI7JJ4.js';
|
|
2
|
+
import { cn } from './chunk-NGYLRX6F.js';
|
|
3
|
+
import { cva } from 'class-variance-authority';
|
|
4
|
+
import { X } from 'lucide-react';
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
7
|
+
|
|
8
|
+
var tagVariants = cva("inline-flex items-center gap-1.5 whitespace-nowrap rounded font-medium transition-colors", {
|
|
9
|
+
variants: {
|
|
10
|
+
variant: {
|
|
11
|
+
default: "border",
|
|
12
|
+
solid: "",
|
|
13
|
+
outline: "border",
|
|
14
|
+
soft: ""
|
|
15
|
+
},
|
|
16
|
+
color: {
|
|
17
|
+
default: "",
|
|
18
|
+
primary: "",
|
|
19
|
+
secondary: "",
|
|
20
|
+
accent: "",
|
|
21
|
+
success: "",
|
|
22
|
+
error: "",
|
|
23
|
+
warning: "",
|
|
24
|
+
info: ""
|
|
25
|
+
},
|
|
26
|
+
size: {
|
|
27
|
+
xs: "text-[10px] px-1.5 py-0.5",
|
|
28
|
+
sm: "text-xs px-2 py-1",
|
|
29
|
+
md: "text-sm px-2.5 py-1",
|
|
30
|
+
lg: "text-base px-3 py-1.5"
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
compoundVariants: createAllColorVariants(componentColors, ["default", "solid", "outline", "soft"]),
|
|
34
|
+
defaultVariants: {
|
|
35
|
+
variant: "solid",
|
|
36
|
+
color: "primary",
|
|
37
|
+
size: "sm"
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
var iconSizeClasses = {
|
|
41
|
+
xs: "size-2.5",
|
|
42
|
+
sm: "size-3",
|
|
43
|
+
md: "size-3.5",
|
|
44
|
+
lg: "size-4"
|
|
45
|
+
};
|
|
46
|
+
var Tag = ({
|
|
47
|
+
children,
|
|
48
|
+
color = "primary",
|
|
49
|
+
variant = "solid",
|
|
50
|
+
size = "sm",
|
|
51
|
+
closable = false,
|
|
52
|
+
onClose,
|
|
53
|
+
icon,
|
|
54
|
+
className,
|
|
55
|
+
classNames,
|
|
56
|
+
onClick,
|
|
57
|
+
disableKeyboardRemoval = false,
|
|
58
|
+
...props
|
|
59
|
+
}) => {
|
|
60
|
+
const handleClose = (e) => {
|
|
61
|
+
e.stopPropagation();
|
|
62
|
+
onClose?.(e);
|
|
63
|
+
};
|
|
64
|
+
const handleCloseKeyDown = (e) => {
|
|
65
|
+
if (e.key === "Enter" || e.key === " ") {
|
|
66
|
+
e.preventDefault();
|
|
67
|
+
e.stopPropagation();
|
|
68
|
+
onClose?.(e);
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
const handleTagKeyDown = (e) => {
|
|
72
|
+
if (!disableKeyboardRemoval && closable && (e.key === "Delete" || e.key === "Backspace")) {
|
|
73
|
+
e.preventDefault();
|
|
74
|
+
e.stopPropagation();
|
|
75
|
+
onClose?.(e);
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (onClick && (e.key === "Enter" || e.key === " ")) {
|
|
79
|
+
e.preventDefault();
|
|
80
|
+
e.stopPropagation();
|
|
81
|
+
onClick(e);
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
return /* @__PURE__ */ jsxs(
|
|
85
|
+
"span",
|
|
86
|
+
{
|
|
87
|
+
className: cn(
|
|
88
|
+
"tag_root",
|
|
89
|
+
tagVariants({ variant, color, size }),
|
|
90
|
+
(onClick || closable) && "cursor-pointer",
|
|
91
|
+
(onClick || !disableKeyboardRemoval && closable) && "focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-primary",
|
|
92
|
+
classNames?.root,
|
|
93
|
+
className
|
|
94
|
+
),
|
|
95
|
+
onClick,
|
|
96
|
+
onKeyDown: onClick || !disableKeyboardRemoval && closable ? handleTagKeyDown : void 0,
|
|
97
|
+
role: onClick || !disableKeyboardRemoval && closable ? "button" : void 0,
|
|
98
|
+
tabIndex: onClick || !disableKeyboardRemoval && closable ? 0 : void 0,
|
|
99
|
+
"aria-label": (onClick || !disableKeyboardRemoval && closable) && typeof children === "string" ? children : void 0,
|
|
100
|
+
"data-slot": "root",
|
|
101
|
+
...props,
|
|
102
|
+
children: [
|
|
103
|
+
icon && /* @__PURE__ */ jsx("span", { className: cn("inline-flex items-center justify-center flex-shrink-0", iconSizeClasses[size]), children: React.isValidElement(icon) ? React.cloneElement(icon, {
|
|
104
|
+
className: cn("w-full h-full", icon.props.className)
|
|
105
|
+
}) : icon }),
|
|
106
|
+
/* @__PURE__ */ jsx(
|
|
107
|
+
"span",
|
|
108
|
+
{
|
|
109
|
+
className: cn("tag_content", classNames?.content),
|
|
110
|
+
"data-slot": "content",
|
|
111
|
+
children
|
|
112
|
+
}
|
|
113
|
+
),
|
|
114
|
+
closable && /* @__PURE__ */ jsx(
|
|
115
|
+
"button",
|
|
116
|
+
{
|
|
117
|
+
type: "button",
|
|
118
|
+
onClick: handleClose,
|
|
119
|
+
onKeyDown: handleCloseKeyDown,
|
|
120
|
+
className: cn(
|
|
121
|
+
"tag_closeButton",
|
|
122
|
+
"inline-flex items-center justify-center flex-shrink-0 cursor-pointer rounded-sm opacity-70 hover:opacity-100 transition-opacity focus:outline-none focus:ring-2 focus:ring-current focus:ring-offset-1",
|
|
123
|
+
iconSizeClasses[size],
|
|
124
|
+
classNames?.closeButton
|
|
125
|
+
),
|
|
126
|
+
"aria-label": typeof children === "string" ? `Remove ${children}` : "Remove tag",
|
|
127
|
+
tabIndex: disableKeyboardRemoval ? 0 : -1,
|
|
128
|
+
"data-slot": "closeButton",
|
|
129
|
+
children: /* @__PURE__ */ jsx(X, { className: "w-full h-full" })
|
|
130
|
+
}
|
|
131
|
+
)
|
|
132
|
+
]
|
|
133
|
+
}
|
|
134
|
+
);
|
|
135
|
+
};
|
|
136
|
+
Tag.displayName = "Tag";
|
|
137
|
+
var tag_default = Tag;
|
|
138
|
+
|
|
139
|
+
export { tag_default };
|
|
140
|
+
//# sourceMappingURL=chunk-ZIYA7TGX.js.map
|
|
141
|
+
//# sourceMappingURL=chunk-ZIYA7TGX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tag/index.tsx"],"names":[],"mappings":"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","file":"chunk-ZIYA7TGX.js","sourcesContent":["'use client'\n\nimport { cva } from 'class-variance-authority';\nimport { X } from 'lucide-react';\nimport React from 'react';\n\nimport { cn } from '../utils';\nimport { componentColors, createAllColorVariants } from '../variants';\nimport type { TagProps } from './types';\n\n/**\n * Class variance authority configuration for the Tag component\n * Defines style variants for color, variant, and size\n */\nconst tagVariants = cva('inline-flex items-center gap-1.5 whitespace-nowrap rounded font-medium transition-colors', {\n variants: {\n variant: {\n default: 'border',\n solid: '',\n outline: 'border',\n soft: '',\n },\n color: {\n default: '',\n primary: '',\n secondary: '',\n accent: '',\n success: '',\n error: '',\n warning: '',\n info: '',\n },\n size: {\n xs: 'text-[10px] px-1.5 py-0.5',\n sm: 'text-xs px-2 py-1',\n md: 'text-sm px-2.5 py-1',\n lg: 'text-base px-3 py-1.5',\n },\n },\n compoundVariants: createAllColorVariants(componentColors, ['default', 'solid', 'outline', 'soft']),\n defaultVariants: {\n variant: 'solid',\n color: 'primary',\n size: 'sm',\n },\n});\n\n/**\n * Icon and close button size variants for different tag sizes\n */\nconst iconSizeClasses = {\n xs: 'size-2.5',\n sm: 'size-3',\n md: 'size-3.5',\n lg: 'size-4',\n};\n\n/**\n * Tag Component\n *\n * An interactive badge variant that can be used for labels, categories, or removable items.\n * Supports multiple variants, colors, sizes, icons, and close functionality.\n *\n * @component\n * @example\n * // Basic tag\n * <Tag>Label</Tag>\n *\n * @example\n * // Tag with close button\n * <Tag closable onClose={(e) => console.log('Tag removed')}>\n * Removable Tag\n * </Tag>\n *\n * @example\n * // Tag with icon\n * <Tag icon={<Star />} color=\"warning\">\n * Featured\n * </Tag>\n *\n * @example\n * // Different variants\n * <Tag variant=\"outline\" color=\"success\">Outline Tag</Tag>\n * <Tag variant=\"soft\" color=\"info\">Soft Tag</Tag>\n *\n * @example\n * // Disable keyboard removal (Backspace/Delete on tag)\n * <Tag closable disableKeyboardRemoval onClose={(e) => console.log('Tag removed')}>\n * No keyboard removal\n * </Tag>\n *\n * @example\n * // Tag with keyboard removal enabled (focus on tag and press Delete/Backspace)\n * <Tag closable onClose={(e) => console.log('Tag removed')}>\n * Press Delete or Backspace to remove\n * </Tag>\n *\n * @param {TagProps} props - Component props\n * @returns {JSX.Element} Rendered tag component\n */\nconst Tag: React.FC<TagProps> = ({\n children,\n color = 'primary',\n variant = 'solid',\n size = 'sm',\n closable = false,\n onClose,\n icon,\n className,\n classNames,\n onClick,\n disableKeyboardRemoval = false,\n ...props\n}) => {\n /**\n * Handles the close button click event\n * Stops event propagation to prevent triggering parent onClick handlers\n *\n * @param {React.MouseEvent<HTMLButtonElement>} e - Mouse event\n */\n const handleClose = (e: React.MouseEvent<HTMLButtonElement>) => {\n e.stopPropagation();\n onClose?.(e);\n };\n\n /**\n * Handles keyboard events for the close button\n * Always responds to Enter/Space for activation (accessibility requirement)\n *\n * @param {React.KeyboardEvent<HTMLButtonElement>} e - Keyboard event\n */\n const handleCloseKeyDown = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n // Always allow Enter/Space for activation (accessibility requirement)\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n onClose?.(e);\n }\n };\n\n /**\n * Handles keyboard events for the tag\n * Removes tag when Delete or Backspace is pressed (takes priority)\n * Activates onClick when Enter or Space is pressed\n *\n * @param {React.KeyboardEvent<HTMLSpanElement>} e - Keyboard event\n */\n const handleTagKeyDown = (e: React.KeyboardEvent<HTMLSpanElement>) => {\n // Handle deletion for closable tags (takes priority over onClick)\n if (!disableKeyboardRemoval && closable && (e.key === 'Delete' || e.key === 'Backspace')) {\n e.preventDefault();\n e.stopPropagation();\n onClose?.(e);\n return;\n }\n\n // Handle activation for clickable tags\n if (onClick && (e.key === 'Enter' || e.key === ' ')) {\n e.preventDefault();\n e.stopPropagation();\n onClick(e);\n }\n };\n\n return (\n <span\n className={cn(\n 'tag_root',\n tagVariants({ variant, color, size }),\n (onClick || closable) && 'cursor-pointer',\n (onClick || (!disableKeyboardRemoval && closable)) &&\n 'focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-primary',\n classNames?.root,\n className\n )}\n onClick={onClick}\n onKeyDown={onClick || (!disableKeyboardRemoval && closable) ? handleTagKeyDown : undefined}\n role={onClick || (!disableKeyboardRemoval && closable) ? 'button' : undefined}\n tabIndex={onClick || (!disableKeyboardRemoval && closable) ? 0 : undefined}\n aria-label={\n (onClick || (!disableKeyboardRemoval && closable)) && typeof children === 'string' ? children : undefined\n }\n data-slot='root'\n {...props}\n >\n {icon && (\n <span className={cn('inline-flex items-center justify-center flex-shrink-0', iconSizeClasses[size])}>\n {React.isValidElement(icon)\n ? React.cloneElement(icon, {\n className: cn('w-full h-full', (icon.props as { className?: string }).className),\n } as React.HTMLAttributes<HTMLElement>)\n : icon}\n </span>\n )}\n <span\n className={cn('tag_content', classNames?.content)}\n data-slot='content'\n >\n {children}\n </span>\n {closable && (\n <button\n type='button'\n onClick={handleClose}\n onKeyDown={handleCloseKeyDown}\n className={cn(\n 'tag_closeButton',\n 'inline-flex items-center justify-center flex-shrink-0 cursor-pointer rounded-sm opacity-70 hover:opacity-100 transition-opacity focus:outline-none focus:ring-2 focus:ring-current focus:ring-offset-1',\n iconSizeClasses[size],\n classNames?.closeButton\n )}\n aria-label={typeof children === 'string' ? `Remove ${children}` : 'Remove tag'}\n tabIndex={disableKeyboardRemoval ? 0 : -1}\n data-slot='closeButton'\n >\n <X className='w-full h-full' />\n </button>\n )}\n </span>\n );\n};\n\nTag.displayName = 'Tag';\n\nexport type * from './types';\nexport default Tag;\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { tree_default } from './chunk-
|
|
2
|
-
import { Popover, PopoverTrigger, PopoverContent } from './chunk-
|
|
1
|
+
import { tree_default } from './chunk-T7RWQLUB.js';
|
|
2
|
+
import { Popover, PopoverTrigger, PopoverContent } from './chunk-C5IGZLIT.js';
|
|
3
3
|
import { getValidationStatus, cn, iconSizes, statusMessageVariants } from './chunk-NGYLRX6F.js';
|
|
4
4
|
import { cva } from 'class-variance-authority';
|
|
5
5
|
import { X, Loader2, Search, ChevronDown } from 'lucide-react';
|
|
@@ -499,5 +499,5 @@ TreeSelect.displayName = "TreeSelect";
|
|
|
499
499
|
var tree_select_default = TreeSelect;
|
|
500
500
|
|
|
501
501
|
export { tree_select_default };
|
|
502
|
-
//# sourceMappingURL=chunk-
|
|
503
|
-
//# sourceMappingURL=chunk-
|
|
502
|
+
//# sourceMappingURL=chunk-ZKEDJ536.js.map
|
|
503
|
+
//# sourceMappingURL=chunk-ZKEDJ536.js.map
|