thread-ui 0.5.0 → 0.7.0
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/README.md +10 -2
- package/dist/components/data-display/data-display-controls/data-display-controls.d.ts +2 -0
- package/dist/components/data-display/data-display-controls/data-display-controls.js +48 -0
- package/dist/components/data-display/data-display-controls/data-display-controls.js.map +1 -0
- package/dist/components/data-display/data-display-controls/data-display-controls.types.d.ts +19 -0
- package/dist/components/data-display/data-display-controls/data-display-controls.types.js +2 -0
- package/dist/components/data-display/data-display-controls/data-display-controls.types.js.map +1 -0
- package/dist/components/data-display/data-display-controls/index.d.ts +2 -0
- package/dist/components/data-display/data-display-controls/index.js +2 -0
- package/dist/components/data-display/data-display-controls/index.js.map +1 -0
- package/dist/components/data-display/data-display-controls/use-data-display-controls.d.ts +2 -0
- package/dist/components/data-display/data-display-controls/use-data-display-controls.js +41 -0
- package/dist/components/data-display/data-display-controls/use-data-display-controls.js.map +1 -0
- package/dist/components/data-display/filter-controls/filter-controls.types.d.ts +91 -0
- package/dist/components/data-display/filter-controls/filter-controls.types.js +2 -0
- package/dist/components/data-display/filter-controls/filter-controls.types.js.map +1 -0
- package/dist/components/data-display/filter-controls/index.d.ts +4 -0
- package/dist/components/data-display/filter-controls/index.js +4 -0
- package/dist/components/data-display/filter-controls/index.js.map +1 -0
- package/dist/components/data-display/filter-controls/use-filter-controls.d.ts +23 -0
- package/dist/components/data-display/filter-controls/use-filter-controls.js +98 -0
- package/dist/components/data-display/filter-controls/use-filter-controls.js.map +1 -0
- package/dist/components/data-display/filter-controls/variants/filter-controls.d.ts +10 -0
- package/dist/components/data-display/filter-controls/variants/filter-controls.js +52 -0
- package/dist/components/data-display/filter-controls/variants/filter-controls.js.map +1 -0
- package/dist/components/data-display/filter-controls/variants/inline-filter-controls.d.ts +13 -0
- package/dist/components/data-display/filter-controls/variants/inline-filter-controls.js +77 -0
- package/dist/components/data-display/filter-controls/variants/inline-filter-controls.js.map +1 -0
- package/dist/components/data-display/index.d.ts +3 -0
- package/dist/components/data-display/index.js +4 -0
- package/dist/components/data-display/index.js.map +1 -0
- package/dist/components/data-display/sort-controls/index.d.ts +3 -0
- package/dist/components/data-display/sort-controls/index.js +3 -0
- package/dist/components/data-display/sort-controls/index.js.map +1 -0
- package/dist/components/data-display/sort-controls/sort-controls.d.ts +11 -0
- package/dist/components/data-display/sort-controls/sort-controls.js +58 -0
- package/dist/components/data-display/sort-controls/sort-controls.js.map +1 -0
- package/dist/components/data-display/sort-controls/sort-controls.types.d.ts +68 -0
- package/dist/components/data-display/sort-controls/sort-controls.types.js +2 -0
- package/dist/components/data-display/sort-controls/sort-controls.types.js.map +1 -0
- package/dist/components/data-display/sort-controls/use-sort-controls.d.ts +23 -0
- package/dist/components/data-display/sort-controls/use-sort-controls.js +94 -0
- package/dist/components/data-display/sort-controls/use-sort-controls.js.map +1 -0
- package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/dropdown.d.ts +1 -1
- package/dist/components/form-elements/dropdowns/dropdown/dropdown.js +41 -0
- package/dist/components/form-elements/dropdowns/dropdown/dropdown.js.map +1 -0
- package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/dropdown.types.d.ts +7 -9
- package/dist/components/form-elements/dropdowns/dropdown/dropdown.types.js.map +1 -0
- package/dist/components/form-elements/dropdowns/dropdown/index.js.map +1 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.d.ts +8 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.js +46 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.js.map +1 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.d.ts +26 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.js +2 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.js.map +1 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/index.d.ts +2 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/index.js +2 -0
- package/dist/components/form-elements/dropdowns/dropdown-base/index.js.map +1 -0
- package/dist/components/form-elements/dropdowns/index.d.ts +2 -0
- package/dist/components/form-elements/dropdowns/index.js +3 -0
- package/dist/components/form-elements/dropdowns/index.js.map +1 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/index.d.ts +2 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/index.js +2 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/index.js.map +1 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.d.ts +15 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.js +55 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.js.map +1 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.d.ts +25 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.js +2 -0
- package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.js.map +1 -0
- package/dist/components/form-elements/file-upload/components/file-upload-content.js +12 -12
- package/dist/components/form-elements/file-upload/components/file-upload-content.js.map +1 -1
- package/dist/components/form-elements/file-upload/components/file-upload-preview.js +35 -35
- package/dist/components/form-elements/file-upload/components/file-upload-preview.js.map +1 -1
- package/dist/components/form-elements/file-upload/components/item-previews.js +22 -22
- package/dist/components/form-elements/file-upload/components/item-previews.js.map +1 -1
- package/dist/components/form-elements/form-label/form-label.d.ts +1 -1
- package/dist/components/form-elements/form-label/form-label.js +35 -9
- package/dist/components/form-elements/form-label/form-label.js.map +1 -1
- package/dist/components/form-elements/form-label/form-label.types.d.ts +3 -0
- package/dist/components/form-elements/index.d.ts +2 -2
- package/dist/components/form-elements/index.js +2 -2
- package/dist/components/form-elements/index.js.map +1 -1
- package/dist/components/form-elements/input-wrapper.js +8 -8
- package/dist/components/form-elements/input-wrapper.js.map +1 -1
- package/dist/components/form-elements/number-input/number-input.js +55 -55
- package/dist/components/form-elements/number-input/number-input.js.map +1 -1
- package/dist/components/form-elements/text-input/text-input.js +4 -4
- package/dist/components/form-elements/text-input/text-input.js.map +1 -1
- package/dist/components/index.d.ts +1 -0
- package/dist/components/index.js +1 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/layouts/column-layout/column-layout.d.ts +1 -1
- package/dist/components/layouts/column-layout/column-layout.js +25 -22
- package/dist/components/layouts/column-layout/column-layout.js.map +1 -1
- package/dist/components/layouts/column-layout/column-layout.types.d.ts +4 -1
- package/dist/components/layouts/container/container.d.ts +11 -0
- package/dist/components/layouts/container/container.js +28 -0
- package/dist/components/layouts/container/container.js.map +1 -0
- package/dist/components/layouts/container/container.types.d.ts +11 -0
- package/dist/components/layouts/container/container.types.js +2 -0
- package/dist/components/layouts/container/container.types.js.map +1 -0
- package/dist/components/layouts/container/index.d.ts +2 -0
- package/dist/components/layouts/container/index.js +2 -0
- package/dist/components/layouts/container/index.js.map +1 -0
- package/dist/components/layouts/footer/footer.js +38 -38
- package/dist/components/layouts/footer/footer.js.map +1 -1
- package/dist/components/layouts/index.d.ts +1 -0
- package/dist/components/layouts/index.js +1 -0
- package/dist/components/layouts/index.js.map +1 -1
- package/dist/components/layouts/layout-component.types.d.ts +9 -0
- package/dist/components/layouts/layout-component.types.js +2 -0
- package/dist/components/layouts/layout-component.types.js.map +1 -0
- package/dist/components/layouts/layout-wrapper.d.ts +7 -0
- package/dist/components/layouts/layout-wrapper.js +9 -0
- package/dist/components/layouts/layout-wrapper.js.map +1 -0
- package/dist/components/layouts/masonry-layout/masonry-layout.d.ts +1 -1
- package/dist/components/layouts/masonry-layout/masonry-layout.js +18 -18
- package/dist/components/layouts/masonry-layout/masonry-layout.js.map +1 -1
- package/dist/components/layouts/masonry-layout/masonry-layout.types.d.ts +3 -2
- package/dist/components/media/info-card/info-card.js +51 -52
- package/dist/components/media/info-card/info-card.js.map +1 -1
- package/dist/components/media/media-card/media-card.js +133 -119
- package/dist/components/media/media-card/media-card.js.map +1 -1
- package/dist/components/navigation/nav-menu/items/base-item/base-item.d.ts +1 -1
- package/dist/components/navigation/nav-menu/items/base-item/base-item.js +38 -38
- package/dist/components/navigation/nav-menu/items/base-item/base-item.js.map +1 -1
- package/dist/components/navigation/nav-menu/items/nav-drop-down-item/nav-drop-down-item.js +58 -58
- package/dist/components/navigation/nav-menu/items/nav-drop-down-item/nav-drop-down-item.js.map +1 -1
- package/dist/components/navigation/nav-menu/nav-menu.js +104 -104
- package/dist/components/navigation/nav-menu/nav-menu.js.map +1 -1
- package/dist/components/navigation/side-nav/side-nav-item/side-nav-item.js +42 -42
- package/dist/components/navigation/side-nav/side-nav-item/side-nav-item.js.map +1 -1
- package/dist/components/navigation/side-nav/side-nav.js +15 -15
- package/dist/components/navigation/side-nav/side-nav.js.map +1 -1
- package/dist/components/typography/page-header/page-header.js +14 -14
- package/dist/components/typography/page-header/page-header.js.map +1 -1
- package/dist/components/typography/typography.d.ts +10 -8
- package/dist/components/typography/typography.js +42 -8
- package/dist/components/typography/typography.js.map +1 -1
- package/dist/components/ui/button/button-recipe.js +90 -6
- package/dist/components/ui/button/button-recipe.js.map +1 -1
- package/dist/components/ui/button/button.d.ts +1 -1
- package/dist/components/ui/button/button.js +3 -2
- package/dist/components/ui/button/button.js.map +1 -1
- package/dist/components/ui/button/button.types.d.ts +5 -1
- package/dist/components/ui/card/card.js +72 -72
- package/dist/components/ui/card/card.js.map +1 -1
- package/dist/components/ui/divider/divider.js +24 -22
- package/dist/components/ui/divider/divider.js.map +1 -1
- package/dist/components/ui/icon/icon.d.ts +1 -1
- package/dist/components/ui/icon/icon.js +1 -1
- package/dist/components/ui/icon-button/icon-button.d.ts +1 -1
- package/dist/components/ui/icon-button/icon-button.js +4 -7
- package/dist/components/ui/icon-button/icon-button.js.map +1 -1
- package/dist/components/ui/loaders/dots-loader/dots-loader.js +46 -46
- package/dist/components/ui/loaders/dots-loader/dots-loader.js.map +1 -1
- package/dist/components/ui/loaders/skeleton/skeleton.js +17 -17
- package/dist/components/ui/loaders/skeleton/skeleton.js.map +1 -1
- package/dist/components/ui/loaders/spin-loader/spin-loader.js +28 -28
- package/dist/components/ui/loaders/spin-loader/spin-loader.js.map +1 -1
- package/dist/components/ui/modal/components/modal-content.js +80 -80
- package/dist/components/ui/modal/components/modal-content.js.map +1 -1
- package/dist/components/ui/modal/modal.js +33 -15
- package/dist/components/ui/modal/modal.js.map +1 -1
- package/dist/components/ui/modal/modal.types.d.ts +2 -0
- package/dist/components/ui/toggle/toggle.js +37 -48
- package/dist/components/ui/toggle/toggle.js.map +1 -1
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.js +4 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/use-click-outside/index.d.ts +1 -0
- package/dist/hooks/use-click-outside/index.js +2 -0
- package/dist/hooks/use-click-outside/index.js.map +1 -0
- package/dist/hooks/use-click-outside/use-click-outside.d.ts +10 -0
- package/dist/hooks/use-click-outside/use-click-outside.js +26 -0
- package/dist/hooks/use-click-outside/use-click-outside.js.map +1 -0
- package/dist/hooks/use-dismiss/index.d.ts +1 -0
- package/dist/hooks/use-dismiss/index.js +2 -0
- package/dist/hooks/use-dismiss/index.js.map +1 -0
- package/dist/hooks/use-dismiss/use-dismiss.d.ts +13 -0
- package/dist/hooks/use-dismiss/use-dismiss.js +42 -0
- package/dist/hooks/use-dismiss/use-dismiss.js.map +1 -0
- package/dist/hooks/use-pathname/index.js.map +1 -0
- package/dist/hooks/use-pathname/use-pathname.d.ts +8 -0
- package/dist/{utils/hooks → hooks}/use-pathname/use-pathname.js +7 -0
- package/dist/hooks/use-pathname/use-pathname.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/internal-components/conditional-wrapper/conditional-wrapper.d.ts +2 -0
- package/dist/internal-components/conditional-wrapper/conditional-wrapper.js +12 -0
- package/dist/internal-components/conditional-wrapper/conditional-wrapper.js.map +1 -0
- package/dist/internal-components/conditional-wrapper/conditional-wrapper.types.d.ts +9 -0
- package/dist/internal-components/conditional-wrapper/conditional-wrapper.types.js +2 -0
- package/dist/internal-components/conditional-wrapper/conditional-wrapper.types.js.map +1 -0
- package/dist/internal-components/conditional-wrapper/index.d.ts +2 -0
- package/dist/internal-components/conditional-wrapper/index.js +2 -0
- package/dist/internal-components/conditional-wrapper/index.js.map +1 -0
- package/dist/internal-components/image/render-image.js.map +1 -1
- package/dist/internal-components/index.d.ts +3 -1
- package/dist/internal-components/index.js +3 -1
- package/dist/internal-components/index.js.map +1 -1
- package/dist/internal-components/optional-icon-button/index.d.ts +2 -0
- package/dist/internal-components/optional-icon-button/index.js +2 -0
- package/dist/internal-components/optional-icon-button/index.js.map +1 -0
- package/dist/internal-components/optional-icon-button/optional-icon-button.d.ts +2 -0
- package/dist/internal-components/optional-icon-button/optional-icon-button.js +9 -0
- package/dist/internal-components/optional-icon-button/optional-icon-button.js.map +1 -0
- package/dist/internal-components/optional-icon-button/optional-icon-button.types.d.ts +4 -0
- package/dist/internal-components/optional-icon-button/optional-icon-button.types.js +2 -0
- package/dist/internal-components/optional-icon-button/optional-icon-button.types.js.map +1 -0
- package/dist/styled-system/recipes/button.d.ts +2 -1
- package/dist/styled-system/recipes/button.mjs +114 -1
- package/dist/styled-system/styles.css +1 -1
- package/dist/styles/panda.css +1 -1
- package/dist/theme/css-name-configurations/theme-css-names.d.ts +13 -1
- package/dist/types/colors/utility-color-options.types.d.ts +2 -0
- package/dist/types/image/image.types.d.ts +2 -0
- package/dist/types/theme/theme.types.d.ts +37 -23
- package/dist/types/utility/deep-partial.types.d.ts +1 -0
- package/dist/types/utility/index.d.ts +1 -0
- package/dist/types/utility/type-production.types.d.ts +4 -0
- package/dist/types/utility/type-production.types.js +2 -0
- package/dist/types/utility/type-production.types.js.map +1 -0
- package/dist/utils/index.d.ts +0 -1
- package/dist/utils/index.js +0 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/theme-utilities/get-utility-icon-size/get-utility-icon-size.js +4 -4
- package/dist/utils/theme-utilities/get-utility-icon-size/get-utility-icon-size.js.map +1 -1
- package/package.json +1 -1
- package/dist/components/form-elements/dropdown/dropdown.js +0 -83
- package/dist/components/form-elements/dropdown/dropdown.js.map +0 -1
- package/dist/components/form-elements/dropdown/dropdown.types.js.map +0 -1
- package/dist/components/form-elements/dropdown/index.js.map +0 -1
- package/dist/utils/hooks/index.d.ts +0 -2
- package/dist/utils/hooks/index.js +0 -3
- package/dist/utils/hooks/index.js.map +0 -1
- package/dist/utils/hooks/use-outside-close-click/index.d.ts +0 -1
- package/dist/utils/hooks/use-outside-close-click/index.js +0 -2
- package/dist/utils/hooks/use-outside-close-click/index.js.map +0 -1
- package/dist/utils/hooks/use-outside-close-click/use-outside-close-click.d.ts +0 -2
- package/dist/utils/hooks/use-outside-close-click/use-outside-close-click.js +0 -16
- package/dist/utils/hooks/use-outside-close-click/use-outside-close-click.js.map +0 -1
- package/dist/utils/hooks/use-pathname/index.js.map +0 -1
- package/dist/utils/hooks/use-pathname/use-pathname.d.ts +0 -1
- package/dist/utils/hooks/use-pathname/use-pathname.js.map +0 -1
- /package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/dropdown.types.js +0 -0
- /package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/index.d.ts +0 -0
- /package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/index.js +0 -0
- /package/dist/{utils/hooks → hooks}/use-pathname/index.d.ts +0 -0
- /package/dist/{utils/hooks → hooks}/use-pathname/index.js +0 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { SortControlsProps } from './sort-controls.types';
|
|
2
|
+
/**
|
|
3
|
+
* Renders a row of sort toggle buttons and a reset button.
|
|
4
|
+
* Each button cycles through asc → desc → off with a directional arrow indicator.
|
|
5
|
+
* Designed to be used with `useSortControls` via `sortControlsProps`.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* const { sortedData, sortControlsProps } = useSortControls({ data, fields });
|
|
9
|
+
* <SortControls {...sortControlsProps} />
|
|
10
|
+
*/
|
|
11
|
+
export declare const SortControls: <T>({ color, fields, activeSort, onToggle, onClear, size, isDefault, hideReset, neutralWhenInactive, showSortLabel, }: SortControlsProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { cva } from '../../../styled-system/css';
|
|
4
|
+
import { Button, Icon, Text } from '../../../components';
|
|
5
|
+
import { OptionalIconButton } from '../../../internal-components';
|
|
6
|
+
const styles = {
|
|
7
|
+
container: cva({
|
|
8
|
+
base: {
|
|
9
|
+
display: 'flex',
|
|
10
|
+
flexDirection: 'row',
|
|
11
|
+
},
|
|
12
|
+
variants: {
|
|
13
|
+
inner: {
|
|
14
|
+
true: {},
|
|
15
|
+
false: {
|
|
16
|
+
alignItems: 'start',
|
|
17
|
+
flexDirection: 'column',
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
size: {
|
|
21
|
+
sm: {
|
|
22
|
+
gap: '1',
|
|
23
|
+
},
|
|
24
|
+
md: {
|
|
25
|
+
gap: '2',
|
|
26
|
+
},
|
|
27
|
+
lg: {
|
|
28
|
+
gap: '3',
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
}),
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* Renders a row of sort toggle buttons and a reset button.
|
|
36
|
+
* Each button cycles through asc → desc → off with a directional arrow indicator.
|
|
37
|
+
* Designed to be used with `useSortControls` via `sortControlsProps`.
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* const { sortedData, sortControlsProps } = useSortControls({ data, fields });
|
|
41
|
+
* <SortControls {...sortControlsProps} />
|
|
42
|
+
*/
|
|
43
|
+
export const SortControls = ({ color = 'tertiary', fields, activeSort, onToggle, onClear, size = 'sm', isDefault, hideReset = false, neutralWhenInactive = false, showSortLabel = false, }) => {
|
|
44
|
+
const getState = (key) => activeSort.find((s) => s.key === key);
|
|
45
|
+
return (_jsxs("div", { className: styles.container({ inner: false, size }), children: [showSortLabel && _jsx(Text, { bold: true, children: "Sort" }), _jsxs("div", { className: styles.container({ inner: true, size }), children: [fields.map(({ key, label, icon, color: fieldColor }) => {
|
|
46
|
+
const state = getState(key);
|
|
47
|
+
const resolvedFieldColor = !state && neutralWhenInactive ? 'neutral' : (fieldColor ?? color);
|
|
48
|
+
const buttonProps = {
|
|
49
|
+
color: resolvedFieldColor,
|
|
50
|
+
size,
|
|
51
|
+
onClick: () => onToggle(key),
|
|
52
|
+
name: icon,
|
|
53
|
+
};
|
|
54
|
+
return (_jsxs(OptionalIconButton, { ...buttonProps, children: [label, state && _jsx(SortIndicator, { direction: state.direction })] }, String(key)));
|
|
55
|
+
}), !isDefault && !hideReset && (_jsx(Button, { color: "text", onClick: onClear, size: size, text: true, ariaLabel: "Clear all sorting", children: "Reset" }))] })] }));
|
|
56
|
+
};
|
|
57
|
+
const SortIndicator = ({ direction }) => direction === 'asc' ? _jsx(Icon, { size: 8, name: "ArrowUp" }) : _jsx(Icon, { size: 8, name: "ArrowDown" });
|
|
58
|
+
//# sourceMappingURL=sort-controls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sort-controls.js","sourceRoot":"","sources":["../../../../src/components/data-display/sort-controls/sort-controls.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { IconNames } from '../../../components/ui';
|
|
2
|
+
import { UtilityColorOptions, UtilitySizeOptions } from '../../../types';
|
|
3
|
+
export type SortDirection = 'asc' | 'desc';
|
|
4
|
+
/** Configuration for a single sortable field */
|
|
5
|
+
export type SortField<T> = {
|
|
6
|
+
/** Key of the data object this field sorts on */
|
|
7
|
+
key: keyof T;
|
|
8
|
+
/** Display label for the sort button */
|
|
9
|
+
label: string;
|
|
10
|
+
/** Optional icon displayed in the sort button */
|
|
11
|
+
icon?: IconNames;
|
|
12
|
+
/** Optional color accent for the sort button */
|
|
13
|
+
color?: UtilityColorOptions;
|
|
14
|
+
/** Custom sort order. Accepts an explicit value array or a comparator function */
|
|
15
|
+
sortOrder?: T[keyof T][] | ((a: T[keyof T], b: T[keyof T]) => number);
|
|
16
|
+
};
|
|
17
|
+
/** A currently active sort with a direction */
|
|
18
|
+
export type ActiveSort<T> = {
|
|
19
|
+
/** The field being sorted */
|
|
20
|
+
key: keyof T;
|
|
21
|
+
direction: SortDirection;
|
|
22
|
+
};
|
|
23
|
+
/** Configuration passed to `useSortControls` to set up sorting behavior */
|
|
24
|
+
export type SortControlsConfig<T> = {
|
|
25
|
+
/** Dataset to sort */
|
|
26
|
+
data: T[];
|
|
27
|
+
/** Fields available for sorting */
|
|
28
|
+
fields: SortField<T>[];
|
|
29
|
+
/** Sort applied on initial render */
|
|
30
|
+
defaultSort?: ActiveSort<T>[];
|
|
31
|
+
/** Allows multiple fields to be sorted simultaneously @default `false` */
|
|
32
|
+
multiSort?: boolean;
|
|
33
|
+
};
|
|
34
|
+
/** Return value of `useSortControls` — sorted data plus props to pass to `SortControls` */
|
|
35
|
+
export type SortControlsData<T> = {
|
|
36
|
+
/** The dataset after all active sorts are applied */
|
|
37
|
+
sortedData: T[];
|
|
38
|
+
/** Currently active sorts */
|
|
39
|
+
activeSort: ActiveSort<T>[];
|
|
40
|
+
/** Cycles a field through asc → desc → off */
|
|
41
|
+
toggleSort: (key: keyof T) => void;
|
|
42
|
+
/** Resets all active sorts to `defaultSort` */
|
|
43
|
+
clearSort: () => void;
|
|
44
|
+
/** Pre-assembled props to spread directly onto `SortControls` */
|
|
45
|
+
sortControlsProps: SortControlsProps<T>;
|
|
46
|
+
};
|
|
47
|
+
export type SortControlsProps<T> = {
|
|
48
|
+
/** Size variant for the sort controls @default `'sm'` */
|
|
49
|
+
size?: UtilitySizeOptions;
|
|
50
|
+
/** Fallback color for sort buttons when a field has no color set @default `'tertiary'` */
|
|
51
|
+
color?: UtilityColorOptions;
|
|
52
|
+
/** Fields available for sorting */
|
|
53
|
+
fields: SortField<T>[];
|
|
54
|
+
/** Currently active sorts */
|
|
55
|
+
activeSort: ActiveSort<T>[];
|
|
56
|
+
/** Called when a sort field button is clicked */
|
|
57
|
+
onToggle: (key: keyof T) => void;
|
|
58
|
+
/** Called when the reset button is clicked */
|
|
59
|
+
onClear: () => void;
|
|
60
|
+
/** Hides the reset button when true, indicating sort is in its default state */
|
|
61
|
+
isDefault?: boolean;
|
|
62
|
+
/** Optionally hide button to reset sorts */
|
|
63
|
+
hideReset?: boolean;
|
|
64
|
+
/** Display Sort Buttons as neutral when no sort is applied @default `'false'`` */
|
|
65
|
+
neutralWhenInactive?: boolean;
|
|
66
|
+
/** Optionally display title `Sort` above filters */
|
|
67
|
+
showSortLabel?: boolean;
|
|
68
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sort-controls.types.js","sourceRoot":"","sources":["../../../../src/components/data-display/sort-controls/sort-controls.types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { SortControlsConfig, SortControlsData } from './sort-controls.types';
|
|
2
|
+
/**
|
|
3
|
+
* Manages sort state for a dataset and returns sorted data alongside
|
|
4
|
+
* pre-assembled props for `SortControls`.
|
|
5
|
+
*
|
|
6
|
+
* Supports single and multi-field sorting, custom sort orders, and comparator functions.
|
|
7
|
+
* Each field cycles through asc → desc → off on toggle.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* const { sortedData, sortControlsProps } = useSortControls({
|
|
11
|
+
* data: products,
|
|
12
|
+
* fields: [{ key: 'price', label: 'Price' }],
|
|
13
|
+
* multi: true,
|
|
14
|
+
* });
|
|
15
|
+
*
|
|
16
|
+
* return (
|
|
17
|
+
* <>
|
|
18
|
+
* <SortControls {...sortControlsProps} />
|
|
19
|
+
* <ProductList data={sortedData} />
|
|
20
|
+
* </>
|
|
21
|
+
* );
|
|
22
|
+
*/
|
|
23
|
+
export declare const useSortControls: <T>({ data, fields, multiSort, defaultSort, }: SortControlsConfig<T>) => SortControlsData<T>;
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { useState, useMemo } from 'react';
|
|
3
|
+
/**
|
|
4
|
+
* Manages sort state for a dataset and returns sorted data alongside
|
|
5
|
+
* pre-assembled props for `SortControls`.
|
|
6
|
+
*
|
|
7
|
+
* Supports single and multi-field sorting, custom sort orders, and comparator functions.
|
|
8
|
+
* Each field cycles through asc → desc → off on toggle.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* const { sortedData, sortControlsProps } = useSortControls({
|
|
12
|
+
* data: products,
|
|
13
|
+
* fields: [{ key: 'price', label: 'Price' }],
|
|
14
|
+
* multi: true,
|
|
15
|
+
* });
|
|
16
|
+
*
|
|
17
|
+
* return (
|
|
18
|
+
* <>
|
|
19
|
+
* <SortControls {...sortControlsProps} />
|
|
20
|
+
* <ProductList data={sortedData} />
|
|
21
|
+
* </>
|
|
22
|
+
* );
|
|
23
|
+
*/
|
|
24
|
+
export const useSortControls = ({ data, fields, multiSort = false, defaultSort, }) => {
|
|
25
|
+
const [activeSort, setActiveSort] = useState(defaultSort ?? []);
|
|
26
|
+
const toggleSort = (key) => {
|
|
27
|
+
setActiveSort((prev) => {
|
|
28
|
+
const existing = prev.find((s) => s.key === key);
|
|
29
|
+
if (!existing) {
|
|
30
|
+
const next = { key, direction: 'asc' };
|
|
31
|
+
return multiSort ? [...prev, next] : [next];
|
|
32
|
+
}
|
|
33
|
+
if (existing.direction === 'asc') {
|
|
34
|
+
// flip to desc
|
|
35
|
+
return prev.map((s) => s.key === key ? { ...s, direction: 'desc' } : s);
|
|
36
|
+
}
|
|
37
|
+
// remove (was desc, now off)
|
|
38
|
+
return prev.filter((s) => s.key !== key);
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
const clearSort = () => setActiveSort(defaultSort ?? []);
|
|
42
|
+
const sortedData = useMemo(() => {
|
|
43
|
+
if (activeSort.length === 0)
|
|
44
|
+
return data;
|
|
45
|
+
return [...data].sort((a, b) => {
|
|
46
|
+
for (const { key, direction } of activeSort) {
|
|
47
|
+
const aVal = a[key];
|
|
48
|
+
const bVal = b[key];
|
|
49
|
+
const dir = direction === 'asc' ? 1 : -1;
|
|
50
|
+
const field = fields.find((f) => f.key === key);
|
|
51
|
+
const { sortOrder } = field ?? {};
|
|
52
|
+
let cmp = 0;
|
|
53
|
+
if (typeof sortOrder === 'function') {
|
|
54
|
+
cmp = sortOrder(aVal, bVal);
|
|
55
|
+
}
|
|
56
|
+
else if (Array.isArray(sortOrder)) {
|
|
57
|
+
const aIdx = sortOrder.indexOf(aVal);
|
|
58
|
+
const bIdx = sortOrder.indexOf(bVal);
|
|
59
|
+
// unknowns sort to the end
|
|
60
|
+
const aNorm = aIdx === -1 ? Infinity : aIdx;
|
|
61
|
+
const bNorm = bIdx === -1 ? Infinity : bIdx;
|
|
62
|
+
cmp = aNorm - bNorm;
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
cmp = aVal < bVal ? -1 : aVal > bVal ? 1 : 0;
|
|
66
|
+
}
|
|
67
|
+
if (cmp !== 0)
|
|
68
|
+
return cmp * dir;
|
|
69
|
+
}
|
|
70
|
+
return 0;
|
|
71
|
+
});
|
|
72
|
+
}, [data, activeSort, fields]);
|
|
73
|
+
const isDefault = useMemo(() => {
|
|
74
|
+
if (!defaultSort)
|
|
75
|
+
return activeSort.length === 0;
|
|
76
|
+
if (activeSort.length !== defaultSort.length)
|
|
77
|
+
return false;
|
|
78
|
+
return activeSort.every((s, i) => s.key === defaultSort[i].key && s.direction === defaultSort[i].direction);
|
|
79
|
+
}, [activeSort, defaultSort]);
|
|
80
|
+
return {
|
|
81
|
+
sortedData,
|
|
82
|
+
activeSort,
|
|
83
|
+
toggleSort,
|
|
84
|
+
clearSort,
|
|
85
|
+
sortControlsProps: {
|
|
86
|
+
fields,
|
|
87
|
+
activeSort,
|
|
88
|
+
onToggle: toggleSort,
|
|
89
|
+
onClear: clearSort,
|
|
90
|
+
isDefault,
|
|
91
|
+
},
|
|
92
|
+
};
|
|
93
|
+
};
|
|
94
|
+
//# sourceMappingURL=use-sort-controls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-sort-controls.js","sourceRoot":"","sources":["../../../../src/components/data-display/sort-controls/use-sort-controls.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,4 +10,4 @@ import { DropdownProps } from './dropdown.types';
|
|
|
10
10
|
* onSelect={(val) => setStatus(val)}
|
|
11
11
|
* />
|
|
12
12
|
*/
|
|
13
|
-
export declare const Dropdown: ({ id, title, value, options, onSelect, placeholder, }: DropdownProps) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export declare const Dropdown: ({ id, title, value, options, onSelect, placeholder, size, color, }: DropdownProps) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useState } from 'react';
|
|
4
|
+
import { cva } from '../../../../styled-system/css';
|
|
5
|
+
import { DropdownBase } from '../dropdown-base/dropdown-base';
|
|
6
|
+
const itemStyles = cva({
|
|
7
|
+
base: {
|
|
8
|
+
cursor: 'pointer',
|
|
9
|
+
paddingX: '4',
|
|
10
|
+
paddingY: '2',
|
|
11
|
+
_hover: { backgroundColor: 'surface' },
|
|
12
|
+
},
|
|
13
|
+
variants: {
|
|
14
|
+
isSelected: {
|
|
15
|
+
true: { backgroundColor: 'elevated' },
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
/**
|
|
20
|
+
* Single-select dropdown with an option list and outside-click dismissal.
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* <Dropdown
|
|
24
|
+
* title="Status"
|
|
25
|
+
* value={status}
|
|
26
|
+
* options={[{ label: 'Active', value: 'active' }, { label: 'Inactive', value: 'inactive' }]}
|
|
27
|
+
* onSelect={(val) => setStatus(val)}
|
|
28
|
+
* />
|
|
29
|
+
*/
|
|
30
|
+
export const Dropdown = ({ id, title, value, options, onSelect, placeholder = 'Select an option...', size, color, }) => {
|
|
31
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
32
|
+
const selected = options.find((opt) => opt.value === value);
|
|
33
|
+
const handleSelect = (option) => {
|
|
34
|
+
onSelect(option.value);
|
|
35
|
+
setIsOpen(false);
|
|
36
|
+
};
|
|
37
|
+
return (_jsx(DropdownBase, { id: id, title: title, options: options, isOpen: isOpen, onToggle: () => setIsOpen((prev) => !prev), onClose: () => {
|
|
38
|
+
setIsOpen(false);
|
|
39
|
+
}, triggerLabel: selected ? selected.label : placeholder, renderItem: (option, index) => (_jsx("li", { className: itemStyles({ isSelected: option.value === selected?.value }), onClick: () => handleSelect(option), children: option.label }, index)), size: size, color: color }));
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=dropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/dropdown/dropdown.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAG1C,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAE9D,MAAM,UAAU,GAAG,GAAG,CAAC;IACtB,IAAI,EAAE;QACL,MAAM,EAAE,SAAS;QACjB,QAAQ,EAAE,GAAG;QACb,QAAQ,EAAE,GAAG;QACb,MAAM,EAAE,EAAE,eAAe,EAAE,SAAS,EAAE;KACtC;IACD,QAAQ,EAAE;QACT,UAAU,EAAE;YACX,IAAI,EAAE,EAAE,eAAe,EAAE,UAAU,EAAE;SACrC;KACD;CACD,CAAC,CAAC;AAEH;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EACxB,EAAE,EACF,KAAK,EACL,KAAK,EACL,OAAO,EACP,QAAQ,EACR,WAAW,GAAG,qBAAqB,EACnC,IAAI,EACJ,KAAK,GACU,EAAE,EAAE;IACnB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC5C,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;IAE5D,MAAM,YAAY,GAAG,CAAC,MAAsB,EAAE,EAAE;QAC/C,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvB,SAAS,CAAC,KAAK,CAAC,CAAC;IAClB,CAAC,CAAC;IAEF,OAAO,CACN,KAAC,YAAY,IACZ,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,EAC1C,OAAO,EAAE,GAAG,EAAE;YACb,SAAS,CAAC,KAAK,CAAC,CAAC;QAClB,CAAC,EACD,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,EACrD,UAAU,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAC9B,aAEC,SAAS,EAAE,UAAU,CAAC,EAAE,UAAU,EAAE,MAAM,CAAC,KAAK,KAAK,QAAQ,EAAE,KAAK,EAAE,CAAC,EACvE,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,YAElC,MAAM,CAAC,KAAK,IAJR,KAAK,CAKN,CACL,EACD,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,GACX,CACF,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import { UtilitySizeOptions } from '../../../../types';
|
|
2
|
+
import { DropdownOption } from '../dropdown-base/dropdown-base.types';
|
|
3
|
+
import { ButtonProps } from '../../../../components/ui';
|
|
1
4
|
export type DropdownProps = {
|
|
2
5
|
/** Dropdown ID */
|
|
3
6
|
id?: string;
|
|
@@ -11,13 +14,8 @@ export type DropdownProps = {
|
|
|
11
14
|
onSelect: (value: string | number) => void;
|
|
12
15
|
/** Placeholder text shown when no value is selected @default 'Select an option...' */
|
|
13
16
|
placeholder?: string;
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
export type DropdownOption = {
|
|
19
|
-
/** Display text shown in the list */
|
|
20
|
-
label: string;
|
|
21
|
-
/** Value passed to `onSelect` when this option is chosen */
|
|
22
|
-
value: string | number;
|
|
17
|
+
/** Size of Form Label @default `'md'`` */
|
|
18
|
+
size?: UtilitySizeOptions;
|
|
19
|
+
/** Dropdown Color @default 'neutral' */
|
|
20
|
+
color?: ButtonProps['color'];
|
|
23
21
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown.types.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/dropdown/dropdown.types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/dropdown/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { DropdownBaseProps } from './dropdown-base.types';
|
|
2
|
+
export declare const styles: {
|
|
3
|
+
container: string;
|
|
4
|
+
interior: string;
|
|
5
|
+
surfaceButton: string;
|
|
6
|
+
list: string;
|
|
7
|
+
};
|
|
8
|
+
export declare const DropdownBase: ({ id, title, isOpen, onClose, onToggle, triggerLabel, renderItem, options, listHeader, size, icon, color, }: DropdownBaseProps) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useRef } from 'react';
|
|
4
|
+
import { InputWrapper } from '../../input-wrapper';
|
|
5
|
+
import { FormLabel } from '../../form-label';
|
|
6
|
+
import { Icon } from '../../../../components/ui';
|
|
7
|
+
import { css } from '../../../../styled-system/css';
|
|
8
|
+
import { useClickOutside } from '../../../../hooks';
|
|
9
|
+
import { getUtilityIconSize } from '../../../../utils';
|
|
10
|
+
import { ConditionalWrapper, OptionalIconButton } from '../../../../internal-components';
|
|
11
|
+
export const styles = {
|
|
12
|
+
container: css({
|
|
13
|
+
width: '100%',
|
|
14
|
+
color: 'text.standard',
|
|
15
|
+
}),
|
|
16
|
+
interior: css({
|
|
17
|
+
width: '100%',
|
|
18
|
+
position: 'relative',
|
|
19
|
+
}),
|
|
20
|
+
surfaceButton: css({
|
|
21
|
+
width: '100%',
|
|
22
|
+
display: 'flex',
|
|
23
|
+
justifyContent: 'space-between',
|
|
24
|
+
alignItems: 'center',
|
|
25
|
+
}),
|
|
26
|
+
list: css({
|
|
27
|
+
backgroundColor: 'background',
|
|
28
|
+
position: 'absolute',
|
|
29
|
+
width: 'fit-content',
|
|
30
|
+
minWidth: '75%',
|
|
31
|
+
borderWidth: 'md',
|
|
32
|
+
borderColor: 'structure',
|
|
33
|
+
borderRadius: 'md',
|
|
34
|
+
marginTop: '3',
|
|
35
|
+
boxShadow: 'lg',
|
|
36
|
+
zIndex: '10',
|
|
37
|
+
maxHeight: '60',
|
|
38
|
+
overflow: 'auto',
|
|
39
|
+
}),
|
|
40
|
+
};
|
|
41
|
+
export const DropdownBase = ({ id, title, isOpen, onClose, onToggle, triggerLabel, renderItem, options, listHeader, size = 'md', icon, color = 'neutral', }) => {
|
|
42
|
+
const listRef = useRef(null);
|
|
43
|
+
useClickOutside(listRef, isOpen, onClose, false);
|
|
44
|
+
return (_jsx("div", { id: id, className: styles.container, children: _jsxs(ConditionalWrapper, { wrapper: title ? InputWrapper : 'fragment', children: [title && _jsx(FormLabel, { size: size, name: title, title: title }), _jsxs("div", { className: styles.interior, children: [_jsxs(OptionalIconButton, { size: size, color: color, onClick: onToggle, type: "button", name: icon, children: [triggerLabel, _jsx(Icon, { name: isOpen ? 'CaretUp' : 'CaretDown', size: getUtilityIconSize(size) })] }), isOpen && (_jsxs("ul", { className: styles.list, ref: listRef, children: [listHeader && _jsx("li", { children: listHeader }), options.map((option, index) => renderItem(option, index))] }))] })] }) }));
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=dropdown-base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-base.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/dropdown-base/dropdown-base.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ButtonProps, IconNames } from '../../../../components/ui';
|
|
2
|
+
import { UtilitySizeOptions } from '../../../../types';
|
|
3
|
+
/**
|
|
4
|
+
* A single option in the Dropdown list.
|
|
5
|
+
*/
|
|
6
|
+
export type DropdownOption = {
|
|
7
|
+
/** Display text shown in the list */
|
|
8
|
+
label: string;
|
|
9
|
+
/** Value passed to `onSelect` when this option is chosen */
|
|
10
|
+
value: string | number;
|
|
11
|
+
};
|
|
12
|
+
export type DropdownBaseProps = {
|
|
13
|
+
id?: string;
|
|
14
|
+
title?: string;
|
|
15
|
+
placeholder?: string;
|
|
16
|
+
options: DropdownOption[];
|
|
17
|
+
isOpen: boolean;
|
|
18
|
+
onClose: () => void;
|
|
19
|
+
onToggle: () => void;
|
|
20
|
+
triggerLabel: string;
|
|
21
|
+
renderItem: (option: DropdownOption, index: number) => React.ReactNode;
|
|
22
|
+
listHeader?: React.ReactNode;
|
|
23
|
+
size?: UtilitySizeOptions;
|
|
24
|
+
icon?: IconNames;
|
|
25
|
+
color?: ButtonProps['color'];
|
|
26
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-base.types.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/dropdown-base/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/form-elements/dropdowns/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/multi-dropdown/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { MultiDropdownProps } from './multi-dropdown.types';
|
|
2
|
+
/**
|
|
3
|
+
* Multi-select dropdown — stays open on selection, renders a count badge
|
|
4
|
+
* when values are active, and exposes a per-field clear.
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* <MultiDropdown
|
|
8
|
+
* title="Course"
|
|
9
|
+
* options={[{ label: 'Main', value: 'main' }, { label: 'Dessert', value: 'dessert' }]}
|
|
10
|
+
* values={selected}
|
|
11
|
+
* onToggle={(val) => toggle(val)}
|
|
12
|
+
* onClear={() => clear()}
|
|
13
|
+
* />
|
|
14
|
+
*/
|
|
15
|
+
export declare const MultiDropdown: ({ id, title, options, values, onToggle, onClear, size, icon, showLabel, color, }: MultiDropdownProps) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useState } from 'react';
|
|
4
|
+
import { cva, css } from '../../../../styled-system/css';
|
|
5
|
+
import { DropdownBase } from '../dropdown-base/dropdown-base';
|
|
6
|
+
import { Icon, IconButton } from '../../../../components/ui';
|
|
7
|
+
const styles = {
|
|
8
|
+
itemStyles: cva({
|
|
9
|
+
base: {
|
|
10
|
+
cursor: 'pointer',
|
|
11
|
+
paddingX: '4',
|
|
12
|
+
paddingY: '2',
|
|
13
|
+
display: 'flex',
|
|
14
|
+
alignItems: 'center',
|
|
15
|
+
gap: '2',
|
|
16
|
+
_hover: { backgroundColor: 'surface' },
|
|
17
|
+
},
|
|
18
|
+
variants: {
|
|
19
|
+
isSelected: {
|
|
20
|
+
true: { backgroundColor: 'elevated' },
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
}),
|
|
24
|
+
headerStyles: css({
|
|
25
|
+
height: '5',
|
|
26
|
+
paddingX: 3,
|
|
27
|
+
display: 'flex',
|
|
28
|
+
flexDirection: 'row',
|
|
29
|
+
}),
|
|
30
|
+
};
|
|
31
|
+
/**
|
|
32
|
+
* Multi-select dropdown — stays open on selection, renders a count badge
|
|
33
|
+
* when values are active, and exposes a per-field clear.
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* <MultiDropdown
|
|
37
|
+
* title="Course"
|
|
38
|
+
* options={[{ label: 'Main', value: 'main' }, { label: 'Dessert', value: 'dessert' }]}
|
|
39
|
+
* values={selected}
|
|
40
|
+
* onToggle={(val) => toggle(val)}
|
|
41
|
+
* onClear={() => clear()}
|
|
42
|
+
* />
|
|
43
|
+
*/
|
|
44
|
+
export const MultiDropdown = ({ id, title, options, values, onToggle, onClear, size, icon, showLabel = true, color, }) => {
|
|
45
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
46
|
+
const placeholder = !showLabel && title ? title : 'Select...';
|
|
47
|
+
const triggerLabel = values.length === 0 ? placeholder : `${title ?? 'Selected'} (${values.length})`;
|
|
48
|
+
return (_jsx(DropdownBase, { id: id, title: showLabel ? title : undefined, options: options, isOpen: isOpen, onToggle: () => setIsOpen((prev) => !prev), onClose: () => {
|
|
49
|
+
setIsOpen(false);
|
|
50
|
+
}, listHeader: _jsx("div", { className: styles.headerStyles, children: values.length > 0 && (_jsx(IconButton, { ariaLabel: "Clear selected filters", onClick: onClear, color: "text", name: "X", text: true, size: "sm", children: "Clear" })) }), triggerLabel: triggerLabel, renderItem: (option, index) => {
|
|
51
|
+
const isSelected = values.includes(option.value);
|
|
52
|
+
return (_jsxs("li", { className: styles.itemStyles({ isSelected }), onClick: () => onToggle(option.value), children: [_jsx(Icon, { name: isSelected ? 'CheckSquare' : 'Square', size: 12 }), option.label] }, index));
|
|
53
|
+
}, size: size, icon: icon, color: color }));
|
|
54
|
+
};
|
|
55
|
+
//# sourceMappingURL=multi-dropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-dropdown.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { DropdownOption } from '../dropdown-base/dropdown-base.types';
|
|
2
|
+
import { UtilityColorOptions, UtilitySizeOptions } from '../../../../types';
|
|
3
|
+
import { IconNames } from '../../../../components/ui';
|
|
4
|
+
export type MultiDropdownProps = {
|
|
5
|
+
/** Defaults to `title` if not provided */
|
|
6
|
+
id?: string;
|
|
7
|
+
/** Label displayed on the dropdown trigger button */
|
|
8
|
+
title?: string;
|
|
9
|
+
/** List of selectable options */
|
|
10
|
+
options: DropdownOption[];
|
|
11
|
+
/** Currently selected values */
|
|
12
|
+
values: (string | number)[];
|
|
13
|
+
/** Called when an option is toggled on or off */
|
|
14
|
+
onToggle: (value: string | number) => void;
|
|
15
|
+
/** Called when all selected values are cleared */
|
|
16
|
+
onClear: () => void;
|
|
17
|
+
/** Icon displayed in the dropdown trigger button */
|
|
18
|
+
icon?: IconNames;
|
|
19
|
+
/** Color variant for the trigger button */
|
|
20
|
+
color?: UtilityColorOptions;
|
|
21
|
+
/** Size variant for the trigger button @default `'md'` */
|
|
22
|
+
size?: UtilitySizeOptions;
|
|
23
|
+
/** Shows the title label above the dropdown @default `true` */
|
|
24
|
+
showLabel?: boolean;
|
|
25
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-dropdown.types.js","sourceRoot":"","sources":["../../../../../src/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.ts"],"names":[],"mappings":""}
|