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.
Files changed (252) hide show
  1. package/README.md +10 -2
  2. package/dist/components/data-display/data-display-controls/data-display-controls.d.ts +2 -0
  3. package/dist/components/data-display/data-display-controls/data-display-controls.js +48 -0
  4. package/dist/components/data-display/data-display-controls/data-display-controls.js.map +1 -0
  5. package/dist/components/data-display/data-display-controls/data-display-controls.types.d.ts +19 -0
  6. package/dist/components/data-display/data-display-controls/data-display-controls.types.js +2 -0
  7. package/dist/components/data-display/data-display-controls/data-display-controls.types.js.map +1 -0
  8. package/dist/components/data-display/data-display-controls/index.d.ts +2 -0
  9. package/dist/components/data-display/data-display-controls/index.js +2 -0
  10. package/dist/components/data-display/data-display-controls/index.js.map +1 -0
  11. package/dist/components/data-display/data-display-controls/use-data-display-controls.d.ts +2 -0
  12. package/dist/components/data-display/data-display-controls/use-data-display-controls.js +41 -0
  13. package/dist/components/data-display/data-display-controls/use-data-display-controls.js.map +1 -0
  14. package/dist/components/data-display/filter-controls/filter-controls.types.d.ts +91 -0
  15. package/dist/components/data-display/filter-controls/filter-controls.types.js +2 -0
  16. package/dist/components/data-display/filter-controls/filter-controls.types.js.map +1 -0
  17. package/dist/components/data-display/filter-controls/index.d.ts +4 -0
  18. package/dist/components/data-display/filter-controls/index.js +4 -0
  19. package/dist/components/data-display/filter-controls/index.js.map +1 -0
  20. package/dist/components/data-display/filter-controls/use-filter-controls.d.ts +23 -0
  21. package/dist/components/data-display/filter-controls/use-filter-controls.js +98 -0
  22. package/dist/components/data-display/filter-controls/use-filter-controls.js.map +1 -0
  23. package/dist/components/data-display/filter-controls/variants/filter-controls.d.ts +10 -0
  24. package/dist/components/data-display/filter-controls/variants/filter-controls.js +52 -0
  25. package/dist/components/data-display/filter-controls/variants/filter-controls.js.map +1 -0
  26. package/dist/components/data-display/filter-controls/variants/inline-filter-controls.d.ts +13 -0
  27. package/dist/components/data-display/filter-controls/variants/inline-filter-controls.js +77 -0
  28. package/dist/components/data-display/filter-controls/variants/inline-filter-controls.js.map +1 -0
  29. package/dist/components/data-display/index.d.ts +3 -0
  30. package/dist/components/data-display/index.js +4 -0
  31. package/dist/components/data-display/index.js.map +1 -0
  32. package/dist/components/data-display/sort-controls/index.d.ts +3 -0
  33. package/dist/components/data-display/sort-controls/index.js +3 -0
  34. package/dist/components/data-display/sort-controls/index.js.map +1 -0
  35. package/dist/components/data-display/sort-controls/sort-controls.d.ts +11 -0
  36. package/dist/components/data-display/sort-controls/sort-controls.js +58 -0
  37. package/dist/components/data-display/sort-controls/sort-controls.js.map +1 -0
  38. package/dist/components/data-display/sort-controls/sort-controls.types.d.ts +68 -0
  39. package/dist/components/data-display/sort-controls/sort-controls.types.js +2 -0
  40. package/dist/components/data-display/sort-controls/sort-controls.types.js.map +1 -0
  41. package/dist/components/data-display/sort-controls/use-sort-controls.d.ts +23 -0
  42. package/dist/components/data-display/sort-controls/use-sort-controls.js +94 -0
  43. package/dist/components/data-display/sort-controls/use-sort-controls.js.map +1 -0
  44. package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/dropdown.d.ts +1 -1
  45. package/dist/components/form-elements/dropdowns/dropdown/dropdown.js +41 -0
  46. package/dist/components/form-elements/dropdowns/dropdown/dropdown.js.map +1 -0
  47. package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/dropdown.types.d.ts +7 -9
  48. package/dist/components/form-elements/dropdowns/dropdown/dropdown.types.js.map +1 -0
  49. package/dist/components/form-elements/dropdowns/dropdown/index.js.map +1 -0
  50. package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.d.ts +8 -0
  51. package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.js +46 -0
  52. package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.js.map +1 -0
  53. package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.d.ts +26 -0
  54. package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.js +2 -0
  55. package/dist/components/form-elements/dropdowns/dropdown-base/dropdown-base.types.js.map +1 -0
  56. package/dist/components/form-elements/dropdowns/dropdown-base/index.d.ts +2 -0
  57. package/dist/components/form-elements/dropdowns/dropdown-base/index.js +2 -0
  58. package/dist/components/form-elements/dropdowns/dropdown-base/index.js.map +1 -0
  59. package/dist/components/form-elements/dropdowns/index.d.ts +2 -0
  60. package/dist/components/form-elements/dropdowns/index.js +3 -0
  61. package/dist/components/form-elements/dropdowns/index.js.map +1 -0
  62. package/dist/components/form-elements/dropdowns/multi-dropdown/index.d.ts +2 -0
  63. package/dist/components/form-elements/dropdowns/multi-dropdown/index.js +2 -0
  64. package/dist/components/form-elements/dropdowns/multi-dropdown/index.js.map +1 -0
  65. package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.d.ts +15 -0
  66. package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.js +55 -0
  67. package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.js.map +1 -0
  68. package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.d.ts +25 -0
  69. package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.js +2 -0
  70. package/dist/components/form-elements/dropdowns/multi-dropdown/multi-dropdown.types.js.map +1 -0
  71. package/dist/components/form-elements/file-upload/components/file-upload-content.js +12 -12
  72. package/dist/components/form-elements/file-upload/components/file-upload-content.js.map +1 -1
  73. package/dist/components/form-elements/file-upload/components/file-upload-preview.js +35 -35
  74. package/dist/components/form-elements/file-upload/components/file-upload-preview.js.map +1 -1
  75. package/dist/components/form-elements/file-upload/components/item-previews.js +22 -22
  76. package/dist/components/form-elements/file-upload/components/item-previews.js.map +1 -1
  77. package/dist/components/form-elements/form-label/form-label.d.ts +1 -1
  78. package/dist/components/form-elements/form-label/form-label.js +35 -9
  79. package/dist/components/form-elements/form-label/form-label.js.map +1 -1
  80. package/dist/components/form-elements/form-label/form-label.types.d.ts +3 -0
  81. package/dist/components/form-elements/index.d.ts +2 -2
  82. package/dist/components/form-elements/index.js +2 -2
  83. package/dist/components/form-elements/index.js.map +1 -1
  84. package/dist/components/form-elements/input-wrapper.js +8 -8
  85. package/dist/components/form-elements/input-wrapper.js.map +1 -1
  86. package/dist/components/form-elements/number-input/number-input.js +55 -55
  87. package/dist/components/form-elements/number-input/number-input.js.map +1 -1
  88. package/dist/components/form-elements/text-input/text-input.js +4 -4
  89. package/dist/components/form-elements/text-input/text-input.js.map +1 -1
  90. package/dist/components/index.d.ts +1 -0
  91. package/dist/components/index.js +1 -0
  92. package/dist/components/index.js.map +1 -1
  93. package/dist/components/layouts/column-layout/column-layout.d.ts +1 -1
  94. package/dist/components/layouts/column-layout/column-layout.js +25 -22
  95. package/dist/components/layouts/column-layout/column-layout.js.map +1 -1
  96. package/dist/components/layouts/column-layout/column-layout.types.d.ts +4 -1
  97. package/dist/components/layouts/container/container.d.ts +11 -0
  98. package/dist/components/layouts/container/container.js +28 -0
  99. package/dist/components/layouts/container/container.js.map +1 -0
  100. package/dist/components/layouts/container/container.types.d.ts +11 -0
  101. package/dist/components/layouts/container/container.types.js +2 -0
  102. package/dist/components/layouts/container/container.types.js.map +1 -0
  103. package/dist/components/layouts/container/index.d.ts +2 -0
  104. package/dist/components/layouts/container/index.js +2 -0
  105. package/dist/components/layouts/container/index.js.map +1 -0
  106. package/dist/components/layouts/footer/footer.js +38 -38
  107. package/dist/components/layouts/footer/footer.js.map +1 -1
  108. package/dist/components/layouts/index.d.ts +1 -0
  109. package/dist/components/layouts/index.js +1 -0
  110. package/dist/components/layouts/index.js.map +1 -1
  111. package/dist/components/layouts/layout-component.types.d.ts +9 -0
  112. package/dist/components/layouts/layout-component.types.js +2 -0
  113. package/dist/components/layouts/layout-component.types.js.map +1 -0
  114. package/dist/components/layouts/layout-wrapper.d.ts +7 -0
  115. package/dist/components/layouts/layout-wrapper.js +9 -0
  116. package/dist/components/layouts/layout-wrapper.js.map +1 -0
  117. package/dist/components/layouts/masonry-layout/masonry-layout.d.ts +1 -1
  118. package/dist/components/layouts/masonry-layout/masonry-layout.js +18 -18
  119. package/dist/components/layouts/masonry-layout/masonry-layout.js.map +1 -1
  120. package/dist/components/layouts/masonry-layout/masonry-layout.types.d.ts +3 -2
  121. package/dist/components/media/info-card/info-card.js +51 -52
  122. package/dist/components/media/info-card/info-card.js.map +1 -1
  123. package/dist/components/media/media-card/media-card.js +133 -119
  124. package/dist/components/media/media-card/media-card.js.map +1 -1
  125. package/dist/components/navigation/nav-menu/items/base-item/base-item.d.ts +1 -1
  126. package/dist/components/navigation/nav-menu/items/base-item/base-item.js +38 -38
  127. package/dist/components/navigation/nav-menu/items/base-item/base-item.js.map +1 -1
  128. package/dist/components/navigation/nav-menu/items/nav-drop-down-item/nav-drop-down-item.js +58 -58
  129. package/dist/components/navigation/nav-menu/items/nav-drop-down-item/nav-drop-down-item.js.map +1 -1
  130. package/dist/components/navigation/nav-menu/nav-menu.js +104 -104
  131. package/dist/components/navigation/nav-menu/nav-menu.js.map +1 -1
  132. package/dist/components/navigation/side-nav/side-nav-item/side-nav-item.js +42 -42
  133. package/dist/components/navigation/side-nav/side-nav-item/side-nav-item.js.map +1 -1
  134. package/dist/components/navigation/side-nav/side-nav.js +15 -15
  135. package/dist/components/navigation/side-nav/side-nav.js.map +1 -1
  136. package/dist/components/typography/page-header/page-header.js +14 -14
  137. package/dist/components/typography/page-header/page-header.js.map +1 -1
  138. package/dist/components/typography/typography.d.ts +10 -8
  139. package/dist/components/typography/typography.js +42 -8
  140. package/dist/components/typography/typography.js.map +1 -1
  141. package/dist/components/ui/button/button-recipe.js +90 -6
  142. package/dist/components/ui/button/button-recipe.js.map +1 -1
  143. package/dist/components/ui/button/button.d.ts +1 -1
  144. package/dist/components/ui/button/button.js +3 -2
  145. package/dist/components/ui/button/button.js.map +1 -1
  146. package/dist/components/ui/button/button.types.d.ts +5 -1
  147. package/dist/components/ui/card/card.js +72 -72
  148. package/dist/components/ui/card/card.js.map +1 -1
  149. package/dist/components/ui/divider/divider.js +24 -22
  150. package/dist/components/ui/divider/divider.js.map +1 -1
  151. package/dist/components/ui/icon/icon.d.ts +1 -1
  152. package/dist/components/ui/icon/icon.js +1 -1
  153. package/dist/components/ui/icon-button/icon-button.d.ts +1 -1
  154. package/dist/components/ui/icon-button/icon-button.js +4 -7
  155. package/dist/components/ui/icon-button/icon-button.js.map +1 -1
  156. package/dist/components/ui/loaders/dots-loader/dots-loader.js +46 -46
  157. package/dist/components/ui/loaders/dots-loader/dots-loader.js.map +1 -1
  158. package/dist/components/ui/loaders/skeleton/skeleton.js +17 -17
  159. package/dist/components/ui/loaders/skeleton/skeleton.js.map +1 -1
  160. package/dist/components/ui/loaders/spin-loader/spin-loader.js +28 -28
  161. package/dist/components/ui/loaders/spin-loader/spin-loader.js.map +1 -1
  162. package/dist/components/ui/modal/components/modal-content.js +80 -80
  163. package/dist/components/ui/modal/components/modal-content.js.map +1 -1
  164. package/dist/components/ui/modal/modal.js +33 -15
  165. package/dist/components/ui/modal/modal.js.map +1 -1
  166. package/dist/components/ui/modal/modal.types.d.ts +2 -0
  167. package/dist/components/ui/toggle/toggle.js +37 -48
  168. package/dist/components/ui/toggle/toggle.js.map +1 -1
  169. package/dist/hooks/index.d.ts +3 -0
  170. package/dist/hooks/index.js +4 -0
  171. package/dist/hooks/index.js.map +1 -0
  172. package/dist/hooks/use-click-outside/index.d.ts +1 -0
  173. package/dist/hooks/use-click-outside/index.js +2 -0
  174. package/dist/hooks/use-click-outside/index.js.map +1 -0
  175. package/dist/hooks/use-click-outside/use-click-outside.d.ts +10 -0
  176. package/dist/hooks/use-click-outside/use-click-outside.js +26 -0
  177. package/dist/hooks/use-click-outside/use-click-outside.js.map +1 -0
  178. package/dist/hooks/use-dismiss/index.d.ts +1 -0
  179. package/dist/hooks/use-dismiss/index.js +2 -0
  180. package/dist/hooks/use-dismiss/index.js.map +1 -0
  181. package/dist/hooks/use-dismiss/use-dismiss.d.ts +13 -0
  182. package/dist/hooks/use-dismiss/use-dismiss.js +42 -0
  183. package/dist/hooks/use-dismiss/use-dismiss.js.map +1 -0
  184. package/dist/hooks/use-pathname/index.js.map +1 -0
  185. package/dist/hooks/use-pathname/use-pathname.d.ts +8 -0
  186. package/dist/{utils/hooks → hooks}/use-pathname/use-pathname.js +7 -0
  187. package/dist/hooks/use-pathname/use-pathname.js.map +1 -0
  188. package/dist/index.d.ts +1 -0
  189. package/dist/index.js +2 -0
  190. package/dist/index.js.map +1 -1
  191. package/dist/internal-components/conditional-wrapper/conditional-wrapper.d.ts +2 -0
  192. package/dist/internal-components/conditional-wrapper/conditional-wrapper.js +12 -0
  193. package/dist/internal-components/conditional-wrapper/conditional-wrapper.js.map +1 -0
  194. package/dist/internal-components/conditional-wrapper/conditional-wrapper.types.d.ts +9 -0
  195. package/dist/internal-components/conditional-wrapper/conditional-wrapper.types.js +2 -0
  196. package/dist/internal-components/conditional-wrapper/conditional-wrapper.types.js.map +1 -0
  197. package/dist/internal-components/conditional-wrapper/index.d.ts +2 -0
  198. package/dist/internal-components/conditional-wrapper/index.js +2 -0
  199. package/dist/internal-components/conditional-wrapper/index.js.map +1 -0
  200. package/dist/internal-components/image/render-image.js.map +1 -1
  201. package/dist/internal-components/index.d.ts +3 -1
  202. package/dist/internal-components/index.js +3 -1
  203. package/dist/internal-components/index.js.map +1 -1
  204. package/dist/internal-components/optional-icon-button/index.d.ts +2 -0
  205. package/dist/internal-components/optional-icon-button/index.js +2 -0
  206. package/dist/internal-components/optional-icon-button/index.js.map +1 -0
  207. package/dist/internal-components/optional-icon-button/optional-icon-button.d.ts +2 -0
  208. package/dist/internal-components/optional-icon-button/optional-icon-button.js +9 -0
  209. package/dist/internal-components/optional-icon-button/optional-icon-button.js.map +1 -0
  210. package/dist/internal-components/optional-icon-button/optional-icon-button.types.d.ts +4 -0
  211. package/dist/internal-components/optional-icon-button/optional-icon-button.types.js +2 -0
  212. package/dist/internal-components/optional-icon-button/optional-icon-button.types.js.map +1 -0
  213. package/dist/styled-system/recipes/button.d.ts +2 -1
  214. package/dist/styled-system/recipes/button.mjs +114 -1
  215. package/dist/styled-system/styles.css +1 -1
  216. package/dist/styles/panda.css +1 -1
  217. package/dist/theme/css-name-configurations/theme-css-names.d.ts +13 -1
  218. package/dist/types/colors/utility-color-options.types.d.ts +2 -0
  219. package/dist/types/image/image.types.d.ts +2 -0
  220. package/dist/types/theme/theme.types.d.ts +37 -23
  221. package/dist/types/utility/deep-partial.types.d.ts +1 -0
  222. package/dist/types/utility/index.d.ts +1 -0
  223. package/dist/types/utility/type-production.types.d.ts +4 -0
  224. package/dist/types/utility/type-production.types.js +2 -0
  225. package/dist/types/utility/type-production.types.js.map +1 -0
  226. package/dist/utils/index.d.ts +0 -1
  227. package/dist/utils/index.js +0 -1
  228. package/dist/utils/index.js.map +1 -1
  229. package/dist/utils/theme-utilities/get-utility-icon-size/get-utility-icon-size.js +4 -4
  230. package/dist/utils/theme-utilities/get-utility-icon-size/get-utility-icon-size.js.map +1 -1
  231. package/package.json +1 -1
  232. package/dist/components/form-elements/dropdown/dropdown.js +0 -83
  233. package/dist/components/form-elements/dropdown/dropdown.js.map +0 -1
  234. package/dist/components/form-elements/dropdown/dropdown.types.js.map +0 -1
  235. package/dist/components/form-elements/dropdown/index.js.map +0 -1
  236. package/dist/utils/hooks/index.d.ts +0 -2
  237. package/dist/utils/hooks/index.js +0 -3
  238. package/dist/utils/hooks/index.js.map +0 -1
  239. package/dist/utils/hooks/use-outside-close-click/index.d.ts +0 -1
  240. package/dist/utils/hooks/use-outside-close-click/index.js +0 -2
  241. package/dist/utils/hooks/use-outside-close-click/index.js.map +0 -1
  242. package/dist/utils/hooks/use-outside-close-click/use-outside-close-click.d.ts +0 -2
  243. package/dist/utils/hooks/use-outside-close-click/use-outside-close-click.js +0 -16
  244. package/dist/utils/hooks/use-outside-close-click/use-outside-close-click.js.map +0 -1
  245. package/dist/utils/hooks/use-pathname/index.js.map +0 -1
  246. package/dist/utils/hooks/use-pathname/use-pathname.d.ts +0 -1
  247. package/dist/utils/hooks/use-pathname/use-pathname.js.map +0 -1
  248. /package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/dropdown.types.js +0 -0
  249. /package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/index.d.ts +0 -0
  250. /package/dist/components/form-elements/{dropdown → dropdowns/dropdown}/index.js +0 -0
  251. /package/dist/{utils/hooks → hooks}/use-pathname/index.d.ts +0 -0
  252. /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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=sort-controls.types.js.map
@@ -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
- * A single option in the Dropdown list.
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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=dropdown-base.types.js.map
@@ -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,2 @@
1
+ export type { DropdownBaseProps } from './dropdown-base.types';
2
+ export { DropdownBase } from './dropdown-base';
@@ -0,0 +1,2 @@
1
+ export { DropdownBase } from './dropdown-base';
2
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ export * from './dropdown';
2
+ export * from './multi-dropdown';
@@ -0,0 +1,3 @@
1
+ export * from './dropdown';
2
+ export * from './multi-dropdown';
3
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ export type { MultiDropdownProps } from './multi-dropdown.types';
2
+ export { MultiDropdown } from './multi-dropdown';
@@ -0,0 +1,2 @@
1
+ export { MultiDropdown } from './multi-dropdown';
2
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=multi-dropdown.types.js.map
@@ -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":""}