@mantine/core 9.1.0 → 9.2.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 (236) hide show
  1. package/cjs/components/Autocomplete/Autocomplete.cjs +5 -1
  2. package/cjs/components/Autocomplete/Autocomplete.cjs.map +1 -1
  3. package/cjs/components/Card/Card.cjs +1 -1
  4. package/cjs/components/Card/Card.cjs.map +1 -1
  5. package/cjs/components/Checkbox/Checkbox.cjs +4 -1
  6. package/cjs/components/Checkbox/Checkbox.cjs.map +1 -1
  7. package/cjs/components/ColorInput/ColorInput.cjs +5 -1
  8. package/cjs/components/ColorInput/ColorInput.cjs.map +1 -1
  9. package/cjs/components/Combobox/ComboboxClearButton/ComboboxClearButton.cjs +1 -1
  10. package/cjs/components/Combobox/ComboboxClearButton/ComboboxClearButton.cjs.map +1 -1
  11. package/cjs/components/Combobox/ComboboxEventsTarget/ComboboxEventsTarget.cjs +1 -0
  12. package/cjs/components/Combobox/ComboboxEventsTarget/ComboboxEventsTarget.cjs.map +1 -1
  13. package/cjs/components/Combobox/ComboboxSearch/ComboboxSearch.cjs +2 -1
  14. package/cjs/components/Combobox/ComboboxSearch/ComboboxSearch.cjs.map +1 -1
  15. package/cjs/components/Combobox/ComboboxTarget/ComboboxTarget.cjs +1 -0
  16. package/cjs/components/Combobox/ComboboxTarget/ComboboxTarget.cjs.map +1 -1
  17. package/cjs/components/Combobox/use-combobox-target-props/use-combobox-target-props.cjs +18 -12
  18. package/cjs/components/Combobox/use-combobox-target-props/use-combobox-target-props.cjs.map +1 -1
  19. package/cjs/components/Combobox/use-pills-reorder/move-pill.cjs +17 -0
  20. package/cjs/components/Combobox/use-pills-reorder/move-pill.cjs.map +1 -0
  21. package/cjs/components/Combobox/use-pills-reorder/use-pills-reorder.cjs +170 -0
  22. package/cjs/components/Combobox/use-pills-reorder/use-pills-reorder.cjs.map +1 -0
  23. package/cjs/components/FileInput/FileInput.cjs +5 -1
  24. package/cjs/components/FileInput/FileInput.cjs.map +1 -1
  25. package/cjs/components/Highlight/highlighter/highlighter.cjs +3 -3
  26. package/cjs/components/Highlight/highlighter/highlighter.cjs.map +1 -1
  27. package/cjs/components/Input/use-input-props.cjs +5 -1
  28. package/cjs/components/Input/use-input-props.cjs.map +1 -1
  29. package/cjs/components/JsonInput/JsonInput.cjs +5 -2
  30. package/cjs/components/JsonInput/JsonInput.cjs.map +1 -1
  31. package/cjs/components/MaskInput/MaskInput.cjs +5 -1
  32. package/cjs/components/MaskInput/MaskInput.cjs.map +1 -1
  33. package/cjs/components/MaskInput/use-mask-input-props.cjs +3 -2
  34. package/cjs/components/MaskInput/use-mask-input-props.cjs.map +1 -1
  35. package/cjs/components/MultiSelect/MultiSelect.cjs +19 -3
  36. package/cjs/components/MultiSelect/MultiSelect.cjs.map +1 -1
  37. package/cjs/components/NativeSelect/NativeSelect.cjs +5 -1
  38. package/cjs/components/NativeSelect/NativeSelect.cjs.map +1 -1
  39. package/cjs/components/NumberInput/NumberInput.cjs +5 -1
  40. package/cjs/components/NumberInput/NumberInput.cjs.map +1 -1
  41. package/cjs/components/PasswordInput/PasswordInput.cjs +6 -2
  42. package/cjs/components/PasswordInput/PasswordInput.cjs.map +1 -1
  43. package/cjs/components/Pill/Pill.module.cjs.map +1 -1
  44. package/cjs/components/PillsInput/PillsInput.cjs +5 -1
  45. package/cjs/components/PillsInput/PillsInput.cjs.map +1 -1
  46. package/cjs/components/PinInput/PinInput.cjs +1 -1
  47. package/cjs/components/PinInput/PinInput.cjs.map +1 -1
  48. package/cjs/components/Popover/Popover.context.cjs.map +1 -1
  49. package/cjs/components/Popover/PopoverDropdown/PopoverDropdown.cjs +1 -1
  50. package/cjs/components/Popover/PopoverDropdown/PopoverDropdown.cjs.map +1 -1
  51. package/cjs/components/Radio/Radio.module.cjs.map +1 -1
  52. package/cjs/components/RollingNumber/DigitColumn.cjs +46 -0
  53. package/cjs/components/RollingNumber/DigitColumn.cjs.map +1 -0
  54. package/cjs/components/RollingNumber/RollingNumber.cjs +102 -0
  55. package/cjs/components/RollingNumber/RollingNumber.cjs.map +1 -0
  56. package/cjs/components/RollingNumber/RollingNumber.module.cjs +13 -0
  57. package/cjs/components/RollingNumber/RollingNumber.module.cjs.map +1 -0
  58. package/cjs/components/RollingNumber/build-value.cjs +22 -0
  59. package/cjs/components/RollingNumber/build-value.cjs.map +1 -0
  60. package/cjs/components/RollingNumber/get-digit-parts.cjs +40 -0
  61. package/cjs/components/RollingNumber/get-digit-parts.cjs.map +1 -0
  62. package/cjs/components/RollingNumber/get-render-slots.cjs +78 -0
  63. package/cjs/components/RollingNumber/get-render-slots.cjs.map +1 -0
  64. package/cjs/components/ScrollArea/ScrollArea.cjs +24 -10
  65. package/cjs/components/ScrollArea/ScrollArea.cjs.map +1 -1
  66. package/cjs/components/Select/Select.cjs +5 -1
  67. package/cjs/components/Select/Select.cjs.map +1 -1
  68. package/cjs/components/TagsInput/TagsInput.cjs +19 -4
  69. package/cjs/components/TagsInput/TagsInput.cjs.map +1 -1
  70. package/cjs/components/TextInput/TextInput.cjs +5 -1
  71. package/cjs/components/TextInput/TextInput.cjs.map +1 -1
  72. package/cjs/components/Textarea/Textarea.cjs +5 -2
  73. package/cjs/components/Textarea/Textarea.cjs.map +1 -1
  74. package/cjs/components/Tree/FlatTreeNode.cjs +2 -1
  75. package/cjs/components/Tree/FlatTreeNode.cjs.map +1 -1
  76. package/cjs/components/Tree/Tree.cjs +3 -1
  77. package/cjs/components/Tree/Tree.cjs.map +1 -1
  78. package/cjs/components/Tree/TreeNode.cjs +10 -5
  79. package/cjs/components/Tree/TreeNode.cjs.map +1 -1
  80. package/cjs/components/Tree/is-node-checked/is-node-checked.cjs +1 -0
  81. package/cjs/components/Tree/is-node-indeterminate/is-node-indeterminate.cjs +1 -0
  82. package/cjs/components/Tree/use-tree-node-drag-drop.cjs +46 -15
  83. package/cjs/components/Tree/use-tree-node-drag-drop.cjs.map +1 -1
  84. package/cjs/components/TreeSelect/TreeSelect.cjs +601 -0
  85. package/cjs/components/TreeSelect/TreeSelect.cjs.map +1 -0
  86. package/cjs/components/TreeSelect/TreeSelect.module.cjs +16 -0
  87. package/cjs/components/TreeSelect/TreeSelect.module.cjs.map +1 -0
  88. package/cjs/components/TreeSelect/TreeSelectOption.cjs +95 -0
  89. package/cjs/components/TreeSelect/TreeSelectOption.cjs.map +1 -0
  90. package/cjs/components/TreeSelect/flatten-tree-select-data.cjs +34 -0
  91. package/cjs/components/TreeSelect/flatten-tree-select-data.cjs.map +1 -0
  92. package/cjs/components/TreeSelect/get-checked-values-by-strategy.cjs +30 -0
  93. package/cjs/components/TreeSelect/get-checked-values-by-strategy.cjs.map +1 -0
  94. package/cjs/core/MantineProvider/use-props/use-props.cjs +10 -2
  95. package/cjs/core/MantineProvider/use-props/use-props.cjs.map +1 -1
  96. package/cjs/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.cjs +2 -2
  97. package/cjs/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.cjs.map +1 -1
  98. package/cjs/index.cjs +8 -0
  99. package/esm/components/Autocomplete/Autocomplete.mjs +5 -1
  100. package/esm/components/Autocomplete/Autocomplete.mjs.map +1 -1
  101. package/esm/components/Card/Card.mjs +1 -1
  102. package/esm/components/Card/Card.mjs.map +1 -1
  103. package/esm/components/Checkbox/Checkbox.mjs +4 -1
  104. package/esm/components/Checkbox/Checkbox.mjs.map +1 -1
  105. package/esm/components/ColorInput/ColorInput.mjs +5 -1
  106. package/esm/components/ColorInput/ColorInput.mjs.map +1 -1
  107. package/esm/components/Combobox/ComboboxClearButton/ComboboxClearButton.mjs +1 -1
  108. package/esm/components/Combobox/ComboboxClearButton/ComboboxClearButton.mjs.map +1 -1
  109. package/esm/components/Combobox/ComboboxEventsTarget/ComboboxEventsTarget.mjs +1 -0
  110. package/esm/components/Combobox/ComboboxEventsTarget/ComboboxEventsTarget.mjs.map +1 -1
  111. package/esm/components/Combobox/ComboboxSearch/ComboboxSearch.mjs +2 -1
  112. package/esm/components/Combobox/ComboboxSearch/ComboboxSearch.mjs.map +1 -1
  113. package/esm/components/Combobox/ComboboxTarget/ComboboxTarget.mjs +1 -0
  114. package/esm/components/Combobox/ComboboxTarget/ComboboxTarget.mjs.map +1 -1
  115. package/esm/components/Combobox/use-combobox-target-props/use-combobox-target-props.mjs +18 -12
  116. package/esm/components/Combobox/use-combobox-target-props/use-combobox-target-props.mjs.map +1 -1
  117. package/esm/components/Combobox/use-pills-reorder/move-pill.mjs +17 -0
  118. package/esm/components/Combobox/use-pills-reorder/move-pill.mjs.map +1 -0
  119. package/esm/components/Combobox/use-pills-reorder/use-pills-reorder.mjs +169 -0
  120. package/esm/components/Combobox/use-pills-reorder/use-pills-reorder.mjs.map +1 -0
  121. package/esm/components/FileInput/FileInput.mjs +5 -1
  122. package/esm/components/FileInput/FileInput.mjs.map +1 -1
  123. package/esm/components/Highlight/highlighter/highlighter.mjs +3 -3
  124. package/esm/components/Highlight/highlighter/highlighter.mjs.map +1 -1
  125. package/esm/components/Input/use-input-props.mjs +5 -1
  126. package/esm/components/Input/use-input-props.mjs.map +1 -1
  127. package/esm/components/JsonInput/JsonInput.mjs +5 -2
  128. package/esm/components/JsonInput/JsonInput.mjs.map +1 -1
  129. package/esm/components/MaskInput/MaskInput.mjs +5 -1
  130. package/esm/components/MaskInput/MaskInput.mjs.map +1 -1
  131. package/esm/components/MaskInput/use-mask-input-props.mjs +4 -3
  132. package/esm/components/MaskInput/use-mask-input-props.mjs.map +1 -1
  133. package/esm/components/MultiSelect/MultiSelect.mjs +19 -3
  134. package/esm/components/MultiSelect/MultiSelect.mjs.map +1 -1
  135. package/esm/components/NativeSelect/NativeSelect.mjs +5 -1
  136. package/esm/components/NativeSelect/NativeSelect.mjs.map +1 -1
  137. package/esm/components/NumberInput/NumberInput.mjs +5 -1
  138. package/esm/components/NumberInput/NumberInput.mjs.map +1 -1
  139. package/esm/components/PasswordInput/PasswordInput.mjs +6 -2
  140. package/esm/components/PasswordInput/PasswordInput.mjs.map +1 -1
  141. package/esm/components/Pill/Pill.module.mjs.map +1 -1
  142. package/esm/components/PillsInput/PillsInput.mjs +5 -1
  143. package/esm/components/PillsInput/PillsInput.mjs.map +1 -1
  144. package/esm/components/PinInput/PinInput.mjs +1 -1
  145. package/esm/components/PinInput/PinInput.mjs.map +1 -1
  146. package/esm/components/Popover/Popover.context.mjs.map +1 -1
  147. package/esm/components/Popover/PopoverDropdown/PopoverDropdown.mjs +1 -1
  148. package/esm/components/Popover/PopoverDropdown/PopoverDropdown.mjs.map +1 -1
  149. package/esm/components/Radio/Radio.module.mjs.map +1 -1
  150. package/esm/components/RollingNumber/DigitColumn.mjs +45 -0
  151. package/esm/components/RollingNumber/DigitColumn.mjs.map +1 -0
  152. package/esm/components/RollingNumber/RollingNumber.mjs +101 -0
  153. package/esm/components/RollingNumber/RollingNumber.mjs.map +1 -0
  154. package/esm/components/RollingNumber/RollingNumber.module.mjs +13 -0
  155. package/esm/components/RollingNumber/RollingNumber.module.mjs.map +1 -0
  156. package/esm/components/RollingNumber/build-value.mjs +22 -0
  157. package/esm/components/RollingNumber/build-value.mjs.map +1 -0
  158. package/esm/components/RollingNumber/get-digit-parts.mjs +40 -0
  159. package/esm/components/RollingNumber/get-digit-parts.mjs.map +1 -0
  160. package/esm/components/RollingNumber/get-render-slots.mjs +78 -0
  161. package/esm/components/RollingNumber/get-render-slots.mjs.map +1 -0
  162. package/esm/components/ScrollArea/ScrollArea.mjs +25 -11
  163. package/esm/components/ScrollArea/ScrollArea.mjs.map +1 -1
  164. package/esm/components/Select/Select.mjs +5 -1
  165. package/esm/components/Select/Select.mjs.map +1 -1
  166. package/esm/components/TagsInput/TagsInput.mjs +19 -4
  167. package/esm/components/TagsInput/TagsInput.mjs.map +1 -1
  168. package/esm/components/TextInput/TextInput.mjs +5 -1
  169. package/esm/components/TextInput/TextInput.mjs.map +1 -1
  170. package/esm/components/Textarea/Textarea.mjs +5 -2
  171. package/esm/components/Textarea/Textarea.mjs.map +1 -1
  172. package/esm/components/Tree/FlatTreeNode.mjs +2 -1
  173. package/esm/components/Tree/FlatTreeNode.mjs.map +1 -1
  174. package/esm/components/Tree/Tree.mjs +3 -1
  175. package/esm/components/Tree/Tree.mjs.map +1 -1
  176. package/esm/components/Tree/TreeNode.mjs +10 -5
  177. package/esm/components/Tree/TreeNode.mjs.map +1 -1
  178. package/esm/components/Tree/is-node-checked/is-node-checked.mjs +1 -1
  179. package/esm/components/Tree/is-node-indeterminate/is-node-indeterminate.mjs +1 -1
  180. package/esm/components/Tree/use-tree-node-drag-drop.mjs +45 -15
  181. package/esm/components/Tree/use-tree-node-drag-drop.mjs.map +1 -1
  182. package/esm/components/TreeSelect/TreeSelect.mjs +600 -0
  183. package/esm/components/TreeSelect/TreeSelect.mjs.map +1 -0
  184. package/esm/components/TreeSelect/TreeSelect.module.mjs +16 -0
  185. package/esm/components/TreeSelect/TreeSelect.module.mjs.map +1 -0
  186. package/esm/components/TreeSelect/TreeSelectOption.mjs +94 -0
  187. package/esm/components/TreeSelect/TreeSelectOption.mjs.map +1 -0
  188. package/esm/components/TreeSelect/flatten-tree-select-data.mjs +34 -0
  189. package/esm/components/TreeSelect/flatten-tree-select-data.mjs.map +1 -0
  190. package/esm/components/TreeSelect/get-checked-values-by-strategy.mjs +29 -0
  191. package/esm/components/TreeSelect/get-checked-values-by-strategy.mjs.map +1 -0
  192. package/esm/core/MantineProvider/use-props/use-props.mjs +10 -2
  193. package/esm/core/MantineProvider/use-props/use-props.mjs.map +1 -1
  194. package/esm/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.mjs +2 -2
  195. package/esm/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.mjs.map +1 -1
  196. package/esm/index.mjs +5 -1
  197. package/lib/components/Combobox/Combobox.types.d.ts +3 -0
  198. package/lib/components/Combobox/ComboboxClearButton/ComboboxClearButton.d.ts +1 -1
  199. package/lib/components/Combobox/index.d.ts +2 -0
  200. package/lib/components/Combobox/use-combobox-target-props/use-combobox-target-props.d.ts +3 -1
  201. package/lib/components/Combobox/use-pills-reorder/move-pill.d.ts +2 -0
  202. package/lib/components/Combobox/use-pills-reorder/use-pills-reorder.d.ts +26 -0
  203. package/lib/components/MaskInput/MaskInput.d.ts +2 -0
  204. package/lib/components/MultiSelect/MultiSelect.d.ts +3 -1
  205. package/lib/components/Popover/Popover.context.d.ts +1 -1
  206. package/lib/components/RollingNumber/DigitColumn.d.ts +11 -0
  207. package/lib/components/RollingNumber/RollingNumber.d.ts +41 -0
  208. package/lib/components/RollingNumber/build-value.d.ts +10 -0
  209. package/lib/components/RollingNumber/get-digit-parts.d.ts +12 -0
  210. package/lib/components/RollingNumber/get-render-slots.d.ts +35 -0
  211. package/lib/components/RollingNumber/index.d.ts +9 -0
  212. package/lib/components/Select/Select.d.ts +1 -1
  213. package/lib/components/TagsInput/TagsInput.d.ts +2 -0
  214. package/lib/components/Tree/Tree.d.ts +10 -0
  215. package/lib/components/Tree/TreeNode.d.ts +4 -1
  216. package/lib/components/Tree/index.d.ts +1 -0
  217. package/lib/components/Tree/use-tree-node-drag-drop.d.ts +19 -7
  218. package/lib/components/TreeSelect/TreeSelect.d.ts +124 -0
  219. package/lib/components/TreeSelect/TreeSelectOption.d.ts +36 -0
  220. package/lib/components/TreeSelect/flatten-tree-select-data.d.ts +12 -0
  221. package/lib/components/TreeSelect/get-checked-values-by-strategy.d.ts +4 -0
  222. package/lib/components/TreeSelect/index.d.ts +13 -0
  223. package/lib/components/index.d.ts +2 -0
  224. package/lib/core/MantineProvider/use-props/use-props.d.ts +1 -1
  225. package/lib/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.d.ts +2 -2
  226. package/package.json +2 -2
  227. package/styles/Pill.css +35 -0
  228. package/styles/Pill.layer.css +35 -0
  229. package/styles/Radio.css +3 -2
  230. package/styles/Radio.layer.css +3 -2
  231. package/styles/RollingNumber.css +60 -0
  232. package/styles/RollingNumber.layer.css +61 -0
  233. package/styles/TreeSelect.css +113 -0
  234. package/styles/TreeSelect.layer.css +114 -0
  235. package/styles.css +213 -2
  236. package/styles.layer.css +213 -2
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TreeSelect.mjs","names":["useId","classes"],"sources":["../../../src/components/TreeSelect/TreeSelect.tsx"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef } from 'react';\nimport { useId, useUncontrolled } from '@mantine/hooks';\nimport {\n BoxProps,\n ElementProps,\n extractStyleProps,\n Factory,\n genericFactory,\n MantineColor,\n StylesApiProps,\n useProps,\n useResolvedStylesApi,\n useStyles,\n} from '../../core';\nimport { Combobox, ComboboxLikeStylesNames, useCombobox } from '../Combobox';\nimport {\n __BaseInputProps,\n __InputStylesNames,\n ClearSectionMode,\n InputClearButtonProps,\n InputVariant,\n} from '../Input';\nimport { InputBase } from '../InputBase';\nimport { Pill } from '../Pill';\nimport { PillsInput } from '../PillsInput';\nimport { ScrollArea, ScrollAreaProps } from '../ScrollArea';\nimport type { TreeNodeData } from '../Tree';\nimport { filterTreeData } from '../Tree/filter-tree-data/filter-tree-data';\nimport {\n findTreeNode,\n getChildrenNodesValues,\n} from '../Tree/get-children-nodes-values/get-children-nodes-values';\nimport { isNodeChecked } from '../Tree/is-node-checked/is-node-checked';\nimport { isNodeIndeterminate } from '../Tree/is-node-indeterminate/is-node-indeterminate';\nimport { getTreeExpandedState, TreeExpandedState } from '../Tree/use-tree';\nimport { flattenTreeSelectData } from './flatten-tree-select-data';\nimport {\n CheckedStrategy,\n checkedToValue,\n expandToLeafChecked,\n} from './get-checked-values-by-strategy';\nimport {\n TreeSelectChevronAriaLabels,\n TreeSelectOption,\n TreeSelectRenderNodePayload,\n} from './TreeSelectOption';\nimport classes from './TreeSelect.module.css';\n\nexport type TreeSelectStylesNames =\n | __InputStylesNames\n | ComboboxLikeStylesNames\n | 'pill'\n | 'pillsList'\n | 'inputField';\n\nexport type TreeSelectMode = 'single' | 'multiple' | 'checkbox';\n\nexport type TreeSelectValue<Mode extends TreeSelectMode> = Mode extends 'single'\n ? string | null\n : string[];\n\nexport interface TreeSelectProps<Mode extends TreeSelectMode = 'single'>\n extends\n BoxProps,\n __BaseInputProps,\n StylesApiProps<TreeSelectFactory>,\n ElementProps<'input', 'size' | 'value' | 'defaultValue' | 'onChange'> {\n /** Tree data */\n data: TreeNodeData[];\n\n /** Selection mode: 'single', 'multiple', or 'checkbox' (with cascade) @default 'single' */\n mode?: Mode;\n\n /** Controlled value */\n value?: TreeSelectValue<Mode>;\n\n /** Default value */\n defaultValue?: TreeSelectValue<Mode>;\n\n /** Called when value changes */\n onChange?: (value: TreeSelectValue<Mode>) => void;\n\n /** Disables parent-child cascade in checkbox mode @default false */\n checkStrictly?: boolean;\n\n /** Controls which checked nodes appear in value/pills in checkbox mode @default 'child' */\n checkedStrategy?: CheckedStrategy;\n\n /** Default expanded node values */\n defaultExpandedValues?: string[];\n\n /** Expand all nodes by default @default false */\n defaultExpandAll?: boolean;\n\n /** Controlled expanded state */\n expandedValues?: string[];\n\n /** Called when expanded state changes */\n onExpandedChange?: (values: string[]) => void;\n\n /** Also toggle expand when clicking a parent node (not just the chevron). In `single` and `multiple` modes, parent clicks only expand; only leaves can be selected. In `checkbox` mode, parent clicks both check and expand. @default false */\n expandOnClick?: boolean;\n\n /** Enables search filtering @default false */\n searchable?: boolean;\n\n /** Controlled search value */\n searchValue?: string;\n\n /** Default search value */\n defaultSearchValue?: string;\n\n /** Called when search changes */\n onSearchChange?: (value: string) => void;\n\n /** Custom filter function */\n filter?: (query: string, node: TreeNodeData) => boolean;\n\n /** Message when no nodes match search */\n nothingFoundMessage?: React.ReactNode;\n\n /** Allows deselecting in single mode @default true */\n allowDeselect?: boolean;\n\n /** Shows clear button @default false */\n clearable?: boolean;\n\n /** Determines how the clear button and rightSection are rendered @default 'both' */\n clearSectionMode?: ClearSectionMode;\n\n /** Props for the clear button */\n clearButtonProps?: InputClearButtonProps;\n\n /** Maximum selectable values (multiple/checkbox mode) */\n maxValues?: number;\n\n /** Maximum displayed pills before \"+N more\" */\n maxDisplayedValues?: number;\n\n /** Content shown when values overflow maxDisplayedValues */\n maxDisplayedValuesContent?: React.ReactNode | ((overflow: number) => React.ReactNode);\n\n /** Called with removed value in multiple/checkbox mode */\n onRemove?: (value: string) => void;\n\n /** Called when clear button is clicked */\n onClear?: () => void;\n\n /** Custom node rendering in the dropdown */\n renderNode?: (payload: TreeSelectRenderNodePayload) => React.ReactNode;\n\n /** Show tree connection lines between parent and child nodes @default true */\n withLines?: boolean;\n\n /** Props for the hidden input */\n hiddenInputProps?: Omit<React.ComponentProps<'input'>, 'value'>;\n\n /** Divider for hidden input values @default ',' */\n hiddenInputValuesDivider?: string;\n\n /** Props for the ScrollArea in the dropdown */\n scrollAreaProps?: ScrollAreaProps;\n\n /** Controls the default chevron color */\n chevronColor?: MantineColor;\n\n /** Max dropdown height @default 220 */\n maxDropdownHeight?: number | string;\n\n /** Controlled dropdown state */\n dropdownOpened?: boolean;\n\n /** Default dropdown state */\n defaultDropdownOpened?: boolean;\n\n /** Called when dropdown opens */\n onDropdownOpen?: () => void;\n\n /** Called when dropdown closes */\n onDropdownClose?: () => void;\n\n /** Props passed to the underlying Combobox */\n comboboxProps?: Record<string, any>;\n\n /** Clear search on selection change @default true */\n clearSearchOnChange?: boolean;\n\n /** Opens dropdown on focus (searchable mode) @default true */\n openOnFocus?: boolean;\n\n /** aria-label values for the expand/collapse chevron button */\n chevronAriaLabels?: TreeSelectChevronAriaLabels;\n}\n\nexport type TreeSelectFactory = Factory<{\n props: TreeSelectProps;\n ref: HTMLInputElement;\n stylesNames: TreeSelectStylesNames;\n variant: InputVariant;\n signature: <Mode extends TreeSelectMode = 'single'>(\n props: TreeSelectProps<Mode>\n ) => React.JSX.Element;\n}>;\n\nconst defaultProps = {\n mode: 'single',\n allowDeselect: true,\n checkedStrategy: 'child',\n maxValues: Infinity,\n hiddenInputValuesDivider: ',',\n clearSearchOnChange: true,\n openOnFocus: true,\n size: 'sm',\n withLines: true,\n} satisfies Partial<TreeSelectProps<TreeSelectMode>>;\n\nconst clearSectionOffset: Record<string, number> = {\n xs: 41,\n sm: 50,\n md: 60,\n lg: 72,\n xl: 89,\n};\n\nfunction getAncestorsToNode(value: string, nodes: TreeNodeData[]): string[] | null {\n for (const node of nodes) {\n if (node.value === value) {\n return [];\n }\n if (Array.isArray(node.children)) {\n const path = getAncestorsToNode(value, node.children);\n if (path !== null) {\n return [node.value, ...path];\n }\n }\n }\n return null;\n}\n\nexport const TreeSelect = genericFactory<TreeSelectFactory>((_props) => {\n const props = useProps(['Input', 'InputWrapper', 'TreeSelect'], defaultProps as any, _props);\n const {\n classNames,\n className,\n style,\n styles,\n unstyled,\n vars,\n size,\n data,\n mode,\n value,\n defaultValue,\n onChange,\n checkStrictly,\n checkedStrategy,\n defaultExpandedValues,\n defaultExpandAll,\n expandedValues,\n onExpandedChange,\n expandOnClick,\n searchable,\n searchValue,\n defaultSearchValue,\n onSearchChange,\n filter,\n nothingFoundMessage,\n allowDeselect,\n clearable,\n clearSectionMode,\n clearButtonProps,\n maxValues,\n maxDisplayedValues,\n maxDisplayedValuesContent,\n onRemove,\n onClear,\n renderNode,\n withLines,\n hiddenInputProps,\n hiddenInputValuesDivider,\n scrollAreaProps,\n chevronColor,\n maxDropdownHeight,\n dropdownOpened,\n defaultDropdownOpened,\n onDropdownOpen,\n onDropdownClose,\n comboboxProps,\n clearSearchOnChange,\n openOnFocus,\n chevronAriaLabels,\n variant,\n onKeyDown,\n onFocus,\n onBlur,\n onClick,\n readOnly,\n disabled,\n radius,\n rightSection,\n rightSectionWidth,\n rightSectionPointerEvents,\n rightSectionProps,\n leftSection,\n leftSectionWidth,\n leftSectionPointerEvents,\n leftSectionProps,\n inputContainer,\n inputWrapperOrder,\n withAsterisk,\n labelProps,\n descriptionProps,\n errorProps,\n wrapperProps,\n description,\n label,\n error,\n withErrorStyles,\n name,\n form,\n id,\n placeholder,\n required,\n mod,\n attributes,\n ...others\n } = props;\n\n const isMulti = mode === 'multiple' || mode === 'checkbox';\n const isCheckbox = mode === 'checkbox';\n const _id = useId(id);\n\n const combobox = useCombobox({\n opened: dropdownOpened,\n defaultOpened: defaultDropdownOpened,\n onDropdownOpen: () => {\n onDropdownOpen?.();\n combobox.updateSelectedOptionIndex('active', { scrollIntoView: true });\n },\n onDropdownClose: () => {\n onDropdownClose?.();\n combobox.resetSelectedOption();\n },\n });\n\n const initialExpanded = useMemo(() => {\n if (defaultExpandAll) {\n return getTreeExpandedState(data, '*');\n }\n if (defaultExpandedValues) {\n return getTreeExpandedState(data, defaultExpandedValues);\n }\n return getTreeExpandedState(data, []);\n }, []);\n\n const expandedToRecord = useCallback(\n (values: string[] | undefined): TreeExpandedState | undefined => {\n if (!values) {\n return undefined;\n }\n return getTreeExpandedState(data, values);\n },\n [data]\n );\n\n const [_expandedState, setExpandedState] = useUncontrolled<TreeExpandedState>({\n value: expandedToRecord(expandedValues),\n defaultValue: initialExpanded,\n finalValue: {},\n onChange: (val) => {\n if (onExpandedChange) {\n onExpandedChange(\n Object.entries(val)\n .filter(([, v]) => v)\n .map(([k]) => k)\n );\n }\n },\n });\n\n const toggleExpand = useCallback(\n (nodeValue: string) => {\n setExpandedState({ ..._expandedState, [nodeValue]: !_expandedState[nodeValue] });\n },\n [_expandedState]\n );\n\n const initialSearchValue = useMemo(() => {\n if (mode !== 'single' || !defaultValue) {\n return '';\n }\n const node = findTreeNode(defaultValue as string, data);\n return node ? (typeof node.label === 'string' ? node.label : '') : '';\n }, []);\n\n const [_searchValue, setSearchValue] = useUncontrolled({\n value: searchValue,\n defaultValue: defaultSearchValue,\n finalValue: initialSearchValue,\n onChange: onSearchChange,\n });\n\n const handleSearchChange = (val: string) => {\n setSearchValue(val);\n combobox.resetSelectedOption();\n };\n\n const [_value, setValue] = useUncontrolled({\n value: value as any,\n defaultValue: defaultValue as any,\n finalValue: isMulti ? [] : null,\n onChange,\n });\n\n const internalChecked = useMemo(() => {\n if (!isCheckbox || !_value || !Array.isArray(_value)) {\n return [];\n }\n if (checkStrictly) {\n return _value;\n }\n return expandToLeafChecked(_value, data);\n }, [isCheckbox, _value, data, checkStrictly]);\n\n const filteredData = useMemo(() => {\n if (!searchable || !_searchValue) {\n return data;\n }\n if (mode === 'single' && _value) {\n const node = findTreeNode(_value as string, data);\n if (node && _searchValue === (typeof node.label === 'string' ? node.label : '')) {\n return data;\n }\n }\n return filterTreeData(data, _searchValue, filter);\n }, [data, _searchValue, filter, searchable, mode, _value]);\n\n const expandedForRender = useMemo(() => {\n if (_searchValue && filteredData !== data) {\n const expanded = { ..._expandedState };\n const expandFilteredParents = (nodes: TreeNodeData[]) => {\n for (const node of nodes) {\n if (Array.isArray(node.children) && node.children.length > 0) {\n expanded[node.value] = true;\n expandFilteredParents(node.children);\n }\n }\n };\n expandFilteredParents(filteredData);\n return expanded;\n }\n return _expandedState;\n }, [filteredData, _expandedState, _searchValue, data]);\n\n const flatNodes = useMemo(\n () => flattenTreeSelectData(filteredData, expandedForRender),\n [filteredData, expandedForRender]\n );\n\n const flatNodesRef = useRef(flatNodes);\n flatNodesRef.current = flatNodes;\n\n const nodeLookup = useMemo(() => {\n const lookup: Record<string, TreeNodeData> = {};\n const walk = (nodes: TreeNodeData[]) => {\n for (const node of nodes) {\n lookup[node.value] = node;\n if (Array.isArray(node.children)) {\n walk(node.children);\n }\n }\n };\n walk(data);\n return lookup;\n }, [data]);\n\n const getNodeLabel = (nodeValue: string): string => {\n const node = nodeLookup[nodeValue];\n if (!node) {\n return nodeValue;\n }\n return typeof node.label === 'string' ? node.label : nodeValue;\n };\n\n const getStyles = useStyles<TreeSelectFactory>({\n name: 'TreeSelect',\n classes: {} as any,\n props: props as any,\n classNames,\n styles,\n unstyled,\n attributes,\n });\n\n const { resolvedClassNames, resolvedStyles } = useResolvedStylesApi<TreeSelectFactory>({\n props,\n styles,\n classNames,\n });\n\n const {\n styleProps,\n rest: { type, autoComplete, ...rest },\n } = extractStyleProps(others);\n\n const handleOptionSubmit = (val: string) => {\n if (mode === 'single') {\n if (expandOnClick) {\n const node = findTreeNode(val, data);\n if (node && Array.isArray(node.children) && node.children.length > 0) {\n toggleExpand(val);\n return;\n }\n }\n const nextValue = allowDeselect && val === _value ? null : val;\n setValue(nextValue);\n combobox.closeDropdown();\n if (clearSearchOnChange) {\n handleSearchChange(nextValue ? getNodeLabel(nextValue) : '');\n }\n } else if (mode === 'multiple') {\n if (expandOnClick) {\n const node = findTreeNode(val, data);\n if (node && Array.isArray(node.children) && node.children.length > 0) {\n toggleExpand(val);\n return;\n }\n }\n const arr = (_value as string[]) || [];\n if (arr.includes(val)) {\n setValue(arr.filter((v: string) => v !== val));\n onRemove?.(val);\n } else if (arr.length < (maxValues ?? Infinity)) {\n setValue([...arr, val]);\n } else {\n return;\n }\n if (clearSearchOnChange) {\n setSearchValue('');\n }\n } else if (mode === 'checkbox') {\n const nodeChecked = checkStrictly\n ? internalChecked.includes(val)\n : isNodeChecked(val, data, internalChecked);\n\n let newInternalChecked: string[];\n if (checkStrictly) {\n newInternalChecked = nodeChecked\n ? internalChecked.filter((v) => v !== val)\n : [...internalChecked, val];\n } else {\n const childLeaves = getChildrenNodesValues(val, data);\n if (nodeChecked) {\n newInternalChecked = internalChecked.filter((v) => !childLeaves.includes(v));\n } else {\n newInternalChecked = [...new Set([...internalChecked, ...childLeaves])];\n }\n }\n\n const newValue = checkedToValue(newInternalChecked, data, checkedStrategy!);\n if (!nodeChecked && newValue.length > (maxValues ?? Infinity)) {\n return;\n }\n setValue(newValue);\n if (clearSearchOnChange) {\n setSearchValue('');\n }\n\n if (expandOnClick) {\n const node = findTreeNode(val, data);\n if (node && Array.isArray(node.children) && node.children.length > 0) {\n if (!_expandedState[val]) {\n toggleExpand(val);\n }\n }\n }\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n onKeyDown?.(event);\n\n if (event.key === ' ' && !searchable && isMulti) {\n event.preventDefault();\n combobox.toggleDropdown();\n }\n\n if (event.key === 'Backspace' && _searchValue.length === 0 && isMulti) {\n const arr = (_value as string[]) || [];\n if (arr.length > 0) {\n const removed = arr[arr.length - 1];\n onRemove?.(removed);\n setValue(arr.slice(0, -1));\n }\n }\n\n if (!combobox.dropdownOpened) {\n return;\n }\n\n const index = combobox.getSelectedOptionIndex();\n if (index < 0 || index >= flatNodesRef.current.length) {\n return;\n }\n\n const currentNode = flatNodesRef.current[index];\n\n if (event.key === 'ArrowRight') {\n if (currentNode.hasChildren && !currentNode.expanded) {\n event.preventDefault();\n toggleExpand(currentNode.node.value);\n }\n }\n\n if (event.key === 'ArrowLeft') {\n if (currentNode.hasChildren && currentNode.expanded) {\n event.preventDefault();\n toggleExpand(currentNode.node.value);\n } else if (currentNode.parent) {\n event.preventDefault();\n const parentIndex = flatNodesRef.current.findIndex(\n (n) => n.node.value === currentNode.parent\n );\n if (parentIndex >= 0) {\n combobox.selectOption(parentIndex);\n }\n }\n }\n };\n\n useEffect(() => {\n if (mode !== 'single' || !searchable) {\n return;\n }\n if (value === null) {\n handleSearchChange('');\n } else if (typeof value === 'string') {\n handleSearchChange(getNodeLabel(value));\n }\n }, [value]);\n\n const prevDropdownOpenedRef = useRef(false);\n useEffect(() => {\n if (combobox.dropdownOpened && !prevDropdownOpenedRef.current && searchable && _value) {\n const targets = Array.isArray(_value) ? _value : [_value];\n const newExpanded = { ..._expandedState };\n let changed = false;\n for (const target of targets) {\n const ancestors = getAncestorsToNode(target as string, data);\n if (ancestors) {\n for (const a of ancestors) {\n if (!newExpanded[a]) {\n newExpanded[a] = true;\n changed = true;\n }\n }\n }\n }\n if (changed) {\n setExpandedState(newExpanded);\n requestAnimationFrame(() => {\n combobox.updateSelectedOptionIndex('active', { scrollIntoView: true });\n });\n }\n }\n prevDropdownOpenedRef.current = combobox.dropdownOpened;\n });\n\n const clearButton = (\n <Combobox.ClearButton\n {...clearButtonProps}\n onClear={() => {\n onClear?.();\n setValue(isMulti ? [] : null);\n handleSearchChange('');\n }}\n />\n );\n\n const hasValue = isMulti\n ? Array.isArray(_value) && _value.length > 0\n : _value != null && _value !== '';\n const _clearable = clearable && hasValue && !disabled && !readOnly;\n\n const singleDisplayLabel = useMemo(() => {\n if (mode !== 'single' || !_value) {\n return '';\n }\n return getNodeLabel(_value as string);\n }, [mode, _value, nodeLookup]);\n\n const displayValues = useMemo(() => {\n if (!isMulti || !Array.isArray(_value)) {\n return [];\n }\n return _value as string[];\n }, [isMulti, _value]);\n\n const pillsListStyle =\n _clearable && isMulti\n ? { paddingInlineEnd: clearSectionOffset[size as string] ?? clearSectionOffset.sm }\n : undefined;\n\n const visiblePills =\n maxDisplayedValues != null ? displayValues.slice(0, maxDisplayedValues) : displayValues;\n\n const overflowCount =\n maxDisplayedValues != null ? Math.max(0, displayValues.length - maxDisplayedValues) : 0;\n\n const pills = visiblePills.map((item, index) => (\n <Pill\n key={`${item}-${index}`}\n withRemoveButton={!readOnly}\n onRemove={() => {\n if (isCheckbox) {\n const childLeaves = checkStrictly ? [item] : getChildrenNodesValues(item, data);\n const newInternal = internalChecked.filter((v) => !childLeaves.includes(v));\n setValue(checkedToValue(newInternal, data, checkedStrategy!));\n } else {\n setValue((_value as string[]).filter((v: string) => v !== item));\n }\n onRemove?.(item);\n }}\n unstyled={unstyled}\n disabled={disabled}\n {...getStyles('pill')}\n >\n {getNodeLabel(item)}\n </Pill>\n ));\n\n if (overflowCount > 0) {\n const overflowContent =\n typeof maxDisplayedValuesContent === 'function'\n ? maxDisplayedValuesContent(overflowCount)\n : maxDisplayedValuesContent || `+${overflowCount} more`;\n pills.push(\n <Pill key=\"__overflow\" unstyled={unstyled} disabled={disabled} {...getStyles('pill')}>\n {overflowContent}\n </Pill>\n );\n }\n\n const isEmpty = flatNodes.length === 0;\n\n const options = flatNodes.map((flatNode) => {\n const isSelected =\n mode === 'single'\n ? _value === flatNode.node.value\n : mode === 'multiple'\n ? ((_value as string[]) || []).includes(flatNode.node.value)\n : false;\n\n const nodeChecked = isCheckbox\n ? checkStrictly\n ? internalChecked.includes(flatNode.node.value)\n : isNodeChecked(flatNode.node.value, data, internalChecked)\n : false;\n\n const nodeIndeterminate =\n isCheckbox && !checkStrictly\n ? isNodeIndeterminate(flatNode.node.value, data, internalChecked)\n : false;\n\n return (\n <TreeSelectOption\n key={flatNode.node.value}\n node={flatNode.node}\n level={flatNode.level}\n expanded={flatNode.expanded}\n hasChildren={flatNode.hasChildren}\n selected={isSelected}\n checked={nodeChecked}\n indeterminate={nodeIndeterminate}\n showCheckbox={isCheckbox}\n isLastChild={flatNode.isLastChild}\n lineGuides={flatNode.lineGuides}\n withLines={!!withLines}\n onToggleExpand={toggleExpand}\n renderNode={renderNode}\n chevronAriaLabels={chevronAriaLabels}\n />\n );\n });\n\n const dropdown = (\n <Combobox.Dropdown hidden={readOnly || disabled}>\n <Combobox.Options\n className={classes.optionsWrapper}\n aria-multiselectable={isMulti || undefined}\n >\n <ScrollArea.Autosize\n mah={maxDropdownHeight ?? 220}\n type=\"scroll\"\n scrollbarSize=\"var(--combobox-padding)\"\n offsetScrollbars=\"y\"\n {...scrollAreaProps}\n >\n {options}\n </ScrollArea.Autosize>\n {isEmpty && nothingFoundMessage && <Combobox.Empty>{nothingFoundMessage}</Combobox.Empty>}\n </Combobox.Options>\n </Combobox.Dropdown>\n );\n\n if (isMulti) {\n return (\n <>\n <Combobox\n store={combobox}\n classNames={resolvedClassNames}\n styles={resolvedStyles}\n unstyled={unstyled}\n size={size}\n readOnly={readOnly}\n __staticSelector=\"TreeSelect\"\n attributes={attributes}\n onOptionSubmit={handleOptionSubmit}\n {...comboboxProps}\n >\n <Combobox.DropdownTarget>\n <PillsInput\n {...styleProps}\n __staticSelector=\"TreeSelect\"\n classNames={resolvedClassNames}\n styles={resolvedStyles}\n unstyled={unstyled}\n size={size}\n className={className}\n style={style}\n variant={variant}\n disabled={disabled}\n radius={radius}\n __defaultRightSection={\n <Combobox.Chevron\n size={size}\n error={error}\n unstyled={unstyled}\n color={chevronColor}\n />\n }\n __clearSection={clearButton}\n __clearable={_clearable}\n __clearSectionMode={clearSectionMode}\n rightSection={rightSection}\n rightSectionPointerEvents={rightSectionPointerEvents || 'none'}\n rightSectionWidth={rightSectionWidth}\n rightSectionProps={rightSectionProps}\n leftSection={leftSection}\n leftSectionWidth={leftSectionWidth}\n leftSectionPointerEvents={leftSectionPointerEvents}\n leftSectionProps={leftSectionProps}\n inputContainer={inputContainer}\n inputWrapperOrder={inputWrapperOrder}\n withAsterisk={withAsterisk}\n labelProps={labelProps}\n descriptionProps={descriptionProps}\n errorProps={errorProps}\n wrapperProps={wrapperProps}\n description={description}\n label={label}\n error={error}\n withErrorStyles={withErrorStyles}\n __stylesApiProps={{\n ...props,\n rightSectionPointerEvents: rightSectionPointerEvents || 'none',\n multiline: true,\n }}\n pointer={!searchable}\n onClick={() => (searchable ? combobox.openDropdown() : combobox.toggleDropdown())}\n data-expanded={combobox.dropdownOpened || undefined}\n id={_id}\n required={required}\n mod={mod}\n attributes={attributes}\n >\n <Pill.Group\n attributes={attributes}\n disabled={disabled}\n unstyled={unstyled}\n {...getStyles('pillsList', { style: pillsListStyle })}\n >\n {pills}\n <Combobox.EventsTarget autoComplete={autoComplete}>\n <PillsInput.Field\n {...rest}\n id={_id}\n placeholder={placeholder}\n type={!searchable && !placeholder ? 'hidden' : 'visible'}\n {...getStyles('inputField')}\n unstyled={unstyled}\n onFocus={(event) => {\n onFocus?.(event);\n if (openOnFocus && searchable) {\n combobox.openDropdown();\n }\n }}\n onBlur={(event) => {\n onBlur?.(event);\n combobox.closeDropdown();\n handleSearchChange('');\n }}\n onKeyDown={handleKeyDown}\n value={_searchValue}\n onChange={(event) => {\n handleSearchChange(event.currentTarget.value);\n if (searchable) {\n combobox.openDropdown();\n }\n }}\n disabled={disabled}\n readOnly={readOnly || !searchable}\n pointer={!searchable}\n />\n </Combobox.EventsTarget>\n </Pill.Group>\n </PillsInput>\n </Combobox.DropdownTarget>\n {dropdown}\n </Combobox>\n <Combobox.HiddenInput\n name={name}\n valuesDivider={hiddenInputValuesDivider}\n value={_value}\n form={form}\n disabled={disabled}\n {...hiddenInputProps}\n />\n </>\n );\n }\n\n return (\n <>\n <Combobox\n store={combobox}\n __staticSelector=\"TreeSelect\"\n classNames={resolvedClassNames}\n styles={resolvedStyles}\n unstyled={unstyled}\n readOnly={readOnly}\n size={size}\n attributes={attributes}\n onOptionSubmit={handleOptionSubmit}\n {...comboboxProps}\n >\n <Combobox.Target targetType={searchable ? 'input' : 'button'} autoComplete={autoComplete}>\n <InputBase\n id={_id}\n __defaultRightSection={\n <Combobox.Chevron\n size={size}\n error={error}\n unstyled={unstyled}\n color={chevronColor}\n />\n }\n __clearSection={clearButton}\n __clearable={_clearable}\n __clearSectionMode={clearSectionMode}\n rightSection={rightSection}\n rightSectionPointerEvents={rightSectionPointerEvents || 'none'}\n {...rest}\n {...styleProps}\n size={size}\n __staticSelector=\"TreeSelect\"\n disabled={disabled}\n readOnly={readOnly || !searchable}\n value={searchable ? _searchValue : singleDisplayLabel}\n onChange={(event) => {\n handleSearchChange(event.currentTarget.value);\n combobox.openDropdown();\n }}\n onFocus={(event) => {\n if (openOnFocus && searchable) {\n combobox.openDropdown();\n }\n onFocus?.(event);\n }}\n onBlur={(event) => {\n if (searchable) {\n combobox.closeDropdown();\n }\n handleSearchChange(_value ? getNodeLabel(_value as string) : '');\n onBlur?.(event);\n }}\n onClick={(event) => {\n searchable ? combobox.openDropdown() : combobox.toggleDropdown();\n onClick?.(event);\n }}\n onKeyDown={handleKeyDown}\n classNames={resolvedClassNames}\n styles={resolvedStyles}\n unstyled={unstyled}\n pointer={!searchable}\n error={error}\n attributes={attributes}\n className={className}\n style={style}\n variant={variant}\n radius={radius}\n leftSection={leftSection}\n leftSectionWidth={leftSectionWidth}\n leftSectionPointerEvents={leftSectionPointerEvents}\n leftSectionProps={leftSectionProps}\n rightSectionWidth={rightSectionWidth}\n rightSectionProps={rightSectionProps}\n inputContainer={inputContainer}\n inputWrapperOrder={inputWrapperOrder}\n withAsterisk={withAsterisk}\n labelProps={labelProps}\n descriptionProps={descriptionProps}\n errorProps={errorProps}\n wrapperProps={wrapperProps}\n description={description}\n label={label}\n withErrorStyles={withErrorStyles}\n placeholder={placeholder}\n required={required}\n mod={mod}\n />\n </Combobox.Target>\n {dropdown}\n </Combobox>\n <Combobox.HiddenInput\n value={_value}\n name={name}\n form={form}\n disabled={disabled}\n {...hiddenInputProps}\n />\n </>\n );\n});\n\nTreeSelect.classes = { ...InputBase.classes, ...Combobox.classes };\nTreeSelect.displayName = '@mantine/core/TreeSelect';\n"],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ "use client";
2
+ //#region packages/@mantine/core/src/components/TreeSelect/TreeSelect.module.css
3
+ var TreeSelect_module_default = {
4
+ "optionsWrapper": "m_529d33e8",
5
+ "option": "m_28bb748",
6
+ "expandIcon": "m_aa3e3f86",
7
+ "checkIcon": "m_eaa4cdee",
8
+ "label": "m_ffe3a9c1",
9
+ "guideLine": "m_57207d5d",
10
+ "branchVertical": "m_41b9db0b",
11
+ "branchHorizontal": "m_1246e79"
12
+ };
13
+ //#endregion
14
+ export { TreeSelect_module_default as default };
15
+
16
+ //# sourceMappingURL=TreeSelect.module.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TreeSelect.module.mjs","names":[],"sources":["../../../src/components/TreeSelect/TreeSelect.module.css"],"sourcesContent":[".optionsWrapper {\n --ts-level-offset: 20px;\n --ts-line-width: rem(1px);\n --ts-line-color: var(--mantine-color-default-border);\n --ts-option-padding-y: 4px;\n --ts-option-padding-x: 8px;\n}\n\n.option {\n display: flex;\n align-items: center;\n gap: 6px;\n position: relative;\n padding: var(--ts-option-padding-y) var(--ts-option-padding-x);\n padding-inline-start: var(--ts-option-padding-x);\n}\n\n.expandIcon {\n display: flex;\n align-items: center;\n justify-content: center;\n --_ts-expand-icon-size: calc(1.45 * var(--combobox-option-fz, var(--mantine-font-size-sm)));\n width: var(--_ts-expand-icon-size);\n min-width: var(--_ts-expand-icon-size);\n height: var(--_ts-expand-icon-size);\n border-radius: var(--mantine-radius-sm);\n cursor: pointer;\n color: var(--mantine-color-dimmed);\n transform: rotate(-90deg);\n\n :where([data-combobox-selected]) & {\n color: var(--mantine-color-white);\n }\n\n @mixin where-rtl {\n transform: rotate(90deg);\n }\n\n &:where([data-expanded]) {\n transform: rotate(0deg);\n }\n\n @mixin hover {\n @mixin where-light {\n background-color: var(--mantine-color-gray-1);\n }\n\n @mixin where-dark {\n background-color: var(--mantine-color-dark-5);\n }\n }\n}\n\n.checkIcon {\n opacity: 0.4;\n width: 0.8em;\n min-width: 0.8em;\n height: 0.8em;\n margin-inline-start: auto;\n\n :where([data-combobox-selected]) & {\n opacity: 1;\n }\n}\n\n.label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n/* Tree lines */\n.guideLine {\n position: absolute;\n top: 0;\n bottom: 0;\n width: 0;\n border-inline-start: var(--ts-line-width) solid var(--ts-line-color);\n pointer-events: none;\n}\n\n.branchVertical {\n position: absolute;\n top: 0;\n bottom: 0;\n width: 0;\n border-inline-start: var(--ts-line-width) solid var(--ts-line-color);\n pointer-events: none;\n\n &:where([data-last]) {\n bottom: auto;\n height: 50%;\n }\n}\n\n.branchHorizontal {\n position: absolute;\n top: 50%;\n height: 0;\n border-top: var(--ts-line-width) solid var(--ts-line-color);\n pointer-events: none;\n}\n"],"mappings":""}
@@ -0,0 +1,94 @@
1
+ "use client";
2
+ import { AccordionChevron } from "../Accordion/AccordionChevron.mjs";
3
+ import { Combobox } from "../Combobox/Combobox.mjs";
4
+ import { CheckIcon } from "../Checkbox/CheckIcon.mjs";
5
+ import { CheckboxIndicator } from "../Checkbox/CheckboxIndicator/CheckboxIndicator.mjs";
6
+ import TreeSelect_module_default from "./TreeSelect.module.mjs";
7
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
8
+ //#region packages/@mantine/core/src/components/TreeSelect/TreeSelectOption.tsx
9
+ const LEVEL_OFFSET = 20;
10
+ const BASE_PADDING = 8;
11
+ const LINE_CONTENT_GAP = 5;
12
+ const OPTION_GAP = 6;
13
+ function TreeSelectOption({ node, level, expanded, hasChildren, selected, checked, indeterminate, showCheckbox, isLastChild, lineGuides, withLines, onToggleExpand, renderNode, chevronAriaLabels }) {
14
+ const indentPx = (level - 1) * LEVEL_OFFSET;
15
+ const handleExpandClick = (event) => {
16
+ event.stopPropagation();
17
+ event.preventDefault();
18
+ onToggleExpand(node.value);
19
+ };
20
+ const handleExpandMouseDown = (event) => {
21
+ event.preventDefault();
22
+ };
23
+ const customContent = renderNode ? renderNode({
24
+ node,
25
+ level,
26
+ expanded,
27
+ hasChildren,
28
+ selected,
29
+ checked,
30
+ indeterminate
31
+ }) : null;
32
+ const lineElements = withLines && level > 1 ? /* @__PURE__ */ jsxs(Fragment, { children: [
33
+ lineGuides.map((show, g) => show ? /* @__PURE__ */ jsx("span", {
34
+ className: TreeSelect_module_default.guideLine,
35
+ style: { insetInlineStart: BASE_PADDING + (g + 1) * LEVEL_OFFSET - LEVEL_OFFSET / 2 }
36
+ }, `g${g}`) : null),
37
+ /* @__PURE__ */ jsx("span", {
38
+ className: TreeSelect_module_default.branchVertical,
39
+ "data-last": isLastChild || void 0,
40
+ style: { insetInlineStart: BASE_PADDING + (level - 1) * LEVEL_OFFSET - LEVEL_OFFSET / 2 }
41
+ }),
42
+ /* @__PURE__ */ jsx("span", {
43
+ className: TreeSelect_module_default.branchHorizontal,
44
+ style: {
45
+ insetInlineStart: BASE_PADDING + (level - 1) * LEVEL_OFFSET - LEVEL_OFFSET / 2,
46
+ width: LEVEL_OFFSET / 2
47
+ }
48
+ })
49
+ ] }) : null;
50
+ const isActive = selected || checked;
51
+ const showCheckMark = !showCheckbox && isActive;
52
+ const ariaChecked = showCheckbox ? indeterminate && !checked ? "mixed" : checked : void 0;
53
+ return /* @__PURE__ */ jsxs(Combobox.Option, {
54
+ value: node.value,
55
+ disabled: node.nodeProps?.disabled,
56
+ active: isActive,
57
+ className: TreeSelect_module_default.option,
58
+ style: { paddingInlineStart: BASE_PADDING + indentPx + (withLines && level > 1 ? LINE_CONTENT_GAP : 0) + (!hasChildren ? OPTION_GAP : 0) },
59
+ "aria-selected": isActive,
60
+ "aria-level": level,
61
+ "aria-expanded": hasChildren ? expanded : void 0,
62
+ "aria-checked": ariaChecked,
63
+ children: [lineElements, customContent || /* @__PURE__ */ jsxs(Fragment, { children: [
64
+ hasChildren && /* @__PURE__ */ jsx("span", {
65
+ className: TreeSelect_module_default.expandIcon,
66
+ "data-expanded": expanded || void 0,
67
+ onClick: handleExpandClick,
68
+ onKeyDown: (e) => {
69
+ if (e.key === "Enter") handleExpandClick(e);
70
+ },
71
+ onMouseDown: handleExpandMouseDown,
72
+ role: "button",
73
+ tabIndex: -1,
74
+ "aria-label": expanded ? chevronAriaLabels?.collapse ?? "Collapse" : chevronAriaLabels?.expand ?? "Expand",
75
+ children: /* @__PURE__ */ jsx(AccordionChevron, { size: "80%" })
76
+ }),
77
+ showCheckbox && /* @__PURE__ */ jsx(CheckboxIndicator, {
78
+ checked: checked || indeterminate,
79
+ indeterminate: !checked && indeterminate,
80
+ size: "18px"
81
+ }),
82
+ /* @__PURE__ */ jsx("span", {
83
+ className: TreeSelect_module_default.label,
84
+ children: node.label
85
+ }),
86
+ showCheckMark && /* @__PURE__ */ jsx(CheckIcon, { className: TreeSelect_module_default.checkIcon })
87
+ ] })]
88
+ });
89
+ }
90
+ TreeSelectOption.displayName = "@mantine/core/TreeSelectOption";
91
+ //#endregion
92
+ export { TreeSelectOption };
93
+
94
+ //# sourceMappingURL=TreeSelectOption.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TreeSelectOption.mjs","names":["classes"],"sources":["../../../src/components/TreeSelect/TreeSelectOption.tsx"],"sourcesContent":["import { AccordionChevron } from '../Accordion';\nimport { CheckboxIndicator } from '../Checkbox/CheckboxIndicator/CheckboxIndicator';\nimport { CheckIcon } from '../Checkbox/CheckIcon';\nimport { Combobox } from '../Combobox';\nimport type { TreeNodeData } from '../Tree';\nimport classes from './TreeSelect.module.css';\n\nconst LEVEL_OFFSET = 20;\nconst BASE_PADDING = 8;\nconst LINE_CONTENT_GAP = 5;\nconst OPTION_GAP = 6;\n\nexport interface TreeSelectChevronAriaLabels {\n /** aria-label for the expand button when the node is collapsed @default 'Expand' */\n expand?: string;\n\n /** aria-label for the expand button when the node is expanded @default 'Collapse' */\n collapse?: string;\n}\n\nexport interface TreeSelectOptionProps {\n node: TreeNodeData;\n level: number;\n expanded: boolean;\n hasChildren: boolean;\n selected: boolean;\n checked: boolean;\n indeterminate: boolean;\n showCheckbox: boolean;\n isLastChild: boolean;\n lineGuides: boolean[];\n withLines: boolean;\n onToggleExpand: (value: string) => void;\n renderNode?: (payload: TreeSelectRenderNodePayload) => React.ReactNode;\n chevronAriaLabels?: TreeSelectChevronAriaLabels;\n}\n\nexport interface TreeSelectRenderNodePayload {\n node: TreeNodeData;\n level: number;\n expanded: boolean;\n hasChildren: boolean;\n selected: boolean;\n checked: boolean;\n indeterminate: boolean;\n}\n\nexport function TreeSelectOption({\n node,\n level,\n expanded,\n hasChildren,\n selected,\n checked,\n indeterminate,\n showCheckbox,\n isLastChild,\n lineGuides,\n withLines,\n onToggleExpand,\n renderNode,\n chevronAriaLabels,\n}: TreeSelectOptionProps) {\n const indentPx = (level - 1) * LEVEL_OFFSET;\n\n const handleExpandClick = (event: React.MouseEvent) => {\n event.stopPropagation();\n event.preventDefault();\n onToggleExpand(node.value);\n };\n\n const handleExpandMouseDown = (event: React.MouseEvent) => {\n event.preventDefault();\n };\n\n const customContent = renderNode\n ? renderNode({ node, level, expanded, hasChildren, selected, checked, indeterminate })\n : null;\n\n const lineElements =\n withLines && level > 1 ? (\n <>\n {lineGuides.map((show, g) =>\n show ? (\n <span\n key={`g${g}`}\n className={classes.guideLine}\n style={{ insetInlineStart: BASE_PADDING + (g + 1) * LEVEL_OFFSET - LEVEL_OFFSET / 2 }}\n />\n ) : null\n )}\n <span\n className={classes.branchVertical}\n data-last={isLastChild || undefined}\n style={{\n insetInlineStart: BASE_PADDING + (level - 1) * LEVEL_OFFSET - LEVEL_OFFSET / 2,\n }}\n />\n <span\n className={classes.branchHorizontal}\n style={{\n insetInlineStart: BASE_PADDING + (level - 1) * LEVEL_OFFSET - LEVEL_OFFSET / 2,\n width: LEVEL_OFFSET / 2,\n }}\n />\n </>\n ) : null;\n\n const isActive = selected || checked;\n const showCheckMark = !showCheckbox && isActive;\n\n const ariaChecked = showCheckbox ? (indeterminate && !checked ? 'mixed' : checked) : undefined;\n\n return (\n <Combobox.Option\n value={node.value}\n disabled={node.nodeProps?.disabled}\n active={isActive}\n className={classes.option}\n style={{\n paddingInlineStart:\n BASE_PADDING +\n indentPx +\n (withLines && level > 1 ? LINE_CONTENT_GAP : 0) +\n (!hasChildren ? OPTION_GAP : 0),\n }}\n aria-selected={isActive}\n aria-level={level}\n aria-expanded={hasChildren ? expanded : undefined}\n aria-checked={ariaChecked}\n >\n {lineElements}\n {customContent || (\n <>\n {hasChildren && (\n <span\n className={classes.expandIcon}\n data-expanded={expanded || undefined}\n onClick={handleExpandClick}\n onKeyDown={(e) => {\n if (e.key === 'Enter') {\n handleExpandClick(e as any);\n }\n }}\n onMouseDown={handleExpandMouseDown}\n role=\"button\"\n tabIndex={-1}\n aria-label={\n expanded\n ? (chevronAriaLabels?.collapse ?? 'Collapse')\n : (chevronAriaLabels?.expand ?? 'Expand')\n }\n >\n <AccordionChevron size=\"80%\" />\n </span>\n )}\n {showCheckbox && (\n <CheckboxIndicator\n checked={checked || indeterminate}\n indeterminate={!checked && indeterminate}\n size=\"18px\"\n />\n )}\n <span className={classes.label}>{node.label}</span>\n {showCheckMark && <CheckIcon className={classes.checkIcon} />}\n </>\n )}\n </Combobox.Option>\n );\n}\n\nTreeSelectOption.displayName = '@mantine/core/TreeSelectOption';\n"],"mappings":";;;;;;;;AAOA,MAAM,eAAe;AACrB,MAAM,eAAe;AACrB,MAAM,mBAAmB;AACzB,MAAM,aAAa;AAqCnB,SAAgB,iBAAiB,EAC/B,MACA,OACA,UACA,aACA,UACA,SACA,eACA,cACA,aACA,YACA,WACA,gBACA,YACA,qBACwB;CACxB,MAAM,YAAY,QAAQ,KAAK;CAE/B,MAAM,qBAAqB,UAA4B;AACrD,QAAM,iBAAiB;AACvB,QAAM,gBAAgB;AACtB,iBAAe,KAAK,MAAM;;CAG5B,MAAM,yBAAyB,UAA4B;AACzD,QAAM,gBAAgB;;CAGxB,MAAM,gBAAgB,aAClB,WAAW;EAAE;EAAM;EAAO;EAAU;EAAa;EAAU;EAAS;EAAe,CAAC,GACpF;CAEJ,MAAM,eACJ,aAAa,QAAQ,IACnB,qBAAA,UAAA,EAAA,UAAA;EACG,WAAW,KAAK,MAAM,MACrB,OACE,oBAAC,QAAD;GAEE,WAAWA,0BAAQ;GACnB,OAAO,EAAE,kBAAkB,gBAAgB,IAAI,KAAK,eAAe,eAAe,GAAG;GACrF,EAHK,IAAI,IAGT,GACA,KACL;EACD,oBAAC,QAAD;GACE,WAAWA,0BAAQ;GACnB,aAAW,eAAe,KAAA;GAC1B,OAAO,EACL,kBAAkB,gBAAgB,QAAQ,KAAK,eAAe,eAAe,GAC9E;GACD,CAAA;EACF,oBAAC,QAAD;GACE,WAAWA,0BAAQ;GACnB,OAAO;IACL,kBAAkB,gBAAgB,QAAQ,KAAK,eAAe,eAAe;IAC7E,OAAO,eAAe;IACvB;GACD,CAAA;EACD,EAAA,CAAA,GACD;CAEN,MAAM,WAAW,YAAY;CAC7B,MAAM,gBAAgB,CAAC,gBAAgB;CAEvC,MAAM,cAAc,eAAgB,iBAAiB,CAAC,UAAU,UAAU,UAAW,KAAA;AAErF,QACE,qBAAC,SAAS,QAAV;EACE,OAAO,KAAK;EACZ,UAAU,KAAK,WAAW;EAC1B,QAAQ;EACR,WAAWA,0BAAQ;EACnB,OAAO,EACL,oBACE,eACA,YACC,aAAa,QAAQ,IAAI,mBAAmB,MAC5C,CAAC,cAAc,aAAa,IAChC;EACD,iBAAe;EACf,cAAY;EACZ,iBAAe,cAAc,WAAW,KAAA;EACxC,gBAAc;YAfhB,CAiBG,cACA,iBACC,qBAAA,UAAA,EAAA,UAAA;GACG,eACC,oBAAC,QAAD;IACE,WAAWA,0BAAQ;IACnB,iBAAe,YAAY,KAAA;IAC3B,SAAS;IACT,YAAY,MAAM;AAChB,SAAI,EAAE,QAAQ,QACZ,mBAAkB,EAAS;;IAG/B,aAAa;IACb,MAAK;IACL,UAAU;IACV,cACE,WACK,mBAAmB,YAAY,aAC/B,mBAAmB,UAAU;cAGpC,oBAAC,kBAAD,EAAkB,MAAK,OAAQ,CAAA;IAC1B,CAAA;GAER,gBACC,oBAAC,mBAAD;IACE,SAAS,WAAW;IACpB,eAAe,CAAC,WAAW;IAC3B,MAAK;IACL,CAAA;GAEJ,oBAAC,QAAD;IAAM,WAAWA,0BAAQ;cAAQ,KAAK;IAAa,CAAA;GAClD,iBAAiB,oBAAC,WAAD,EAAW,WAAWA,0BAAQ,WAAa,CAAA;GAC5D,EAAA,CAAA,CAEW;;;AAItB,iBAAiB,cAAc"}
@@ -0,0 +1,34 @@
1
+ "use client";
2
+ //#region packages/@mantine/core/src/components/TreeSelect/flatten-tree-select-data.ts
3
+ function flattenTo(acc, data, expandedState, parent, level, parentGuides) {
4
+ for (let i = 0; i < data.length; i++) {
5
+ const node = data[i];
6
+ const isLast = i === data.length - 1;
7
+ const hasLoadedChildren = Array.isArray(node.children);
8
+ const hasAsyncChildren = !!node.hasChildren && !hasLoadedChildren;
9
+ const hasChildren = hasLoadedChildren || hasAsyncChildren;
10
+ const expanded = expandedState[node.value] || false;
11
+ acc.push({
12
+ node,
13
+ level,
14
+ parent,
15
+ hasChildren,
16
+ expanded,
17
+ isLastChild: isLast,
18
+ lineGuides: parentGuides
19
+ });
20
+ if (expanded && hasLoadedChildren) {
21
+ const childGuides = level >= 2 ? [...parentGuides, !isLast] : [];
22
+ flattenTo(acc, node.children, expandedState, node.value, level + 1, childGuides);
23
+ }
24
+ }
25
+ }
26
+ function flattenTreeSelectData(data, expandedState) {
27
+ const result = [];
28
+ flattenTo(result, data, expandedState, null, 1, []);
29
+ return result;
30
+ }
31
+ //#endregion
32
+ export { flattenTreeSelectData };
33
+
34
+ //# sourceMappingURL=flatten-tree-select-data.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flatten-tree-select-data.mjs","names":[],"sources":["../../../src/components/TreeSelect/flatten-tree-select-data.ts"],"sourcesContent":["import type { TreeNodeData } from '../Tree';\nimport type { TreeExpandedState } from '../Tree/use-tree';\n\nexport interface TreeSelectFlatNode {\n node: TreeNodeData;\n level: number;\n parent: string | null;\n hasChildren: boolean;\n expanded: boolean;\n isLastChild: boolean;\n lineGuides: boolean[];\n}\n\nfunction flattenTo(\n acc: TreeSelectFlatNode[],\n data: TreeNodeData[],\n expandedState: TreeExpandedState,\n parent: string | null,\n level: number,\n parentGuides: boolean[]\n): void {\n for (let i = 0; i < data.length; i++) {\n const node = data[i];\n const isLast = i === data.length - 1;\n const hasLoadedChildren = Array.isArray(node.children);\n const hasAsyncChildren = !!node.hasChildren && !hasLoadedChildren;\n const hasChildren = hasLoadedChildren || hasAsyncChildren;\n const expanded = expandedState[node.value] || false;\n\n acc.push({\n node,\n level,\n parent,\n hasChildren,\n expanded,\n isLastChild: isLast,\n lineGuides: parentGuides,\n });\n\n if (expanded && hasLoadedChildren) {\n const childGuides = level >= 2 ? [...parentGuides, !isLast] : [];\n flattenTo(acc, node.children!, expandedState, node.value, level + 1, childGuides);\n }\n }\n}\n\nexport function flattenTreeSelectData(\n data: TreeNodeData[],\n expandedState: TreeExpandedState\n): TreeSelectFlatNode[] {\n const result: TreeSelectFlatNode[] = [];\n flattenTo(result, data, expandedState, null, 1, []);\n return result;\n}\n"],"mappings":";;AAaA,SAAS,UACP,KACA,MACA,eACA,QACA,OACA,cACM;AACN,MAAK,IAAI,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;EACpC,MAAM,OAAO,KAAK;EAClB,MAAM,SAAS,MAAM,KAAK,SAAS;EACnC,MAAM,oBAAoB,MAAM,QAAQ,KAAK,SAAS;EACtD,MAAM,mBAAmB,CAAC,CAAC,KAAK,eAAe,CAAC;EAChD,MAAM,cAAc,qBAAqB;EACzC,MAAM,WAAW,cAAc,KAAK,UAAU;AAE9C,MAAI,KAAK;GACP;GACA;GACA;GACA;GACA;GACA,aAAa;GACb,YAAY;GACb,CAAC;AAEF,MAAI,YAAY,mBAAmB;GACjC,MAAM,cAAc,SAAS,IAAI,CAAC,GAAG,cAAc,CAAC,OAAO,GAAG,EAAE;AAChE,aAAU,KAAK,KAAK,UAAW,eAAe,KAAK,OAAO,QAAQ,GAAG,YAAY;;;;AAKvF,SAAgB,sBACd,MACA,eACsB;CACtB,MAAM,SAA+B,EAAE;AACvC,WAAU,QAAQ,MAAM,eAAe,MAAM,GAAG,EAAE,CAAC;AACnD,QAAO"}
@@ -0,0 +1,29 @@
1
+ "use client";
2
+ import { getChildrenNodesValues } from "../Tree/get-children-nodes-values/get-children-nodes-values.mjs";
3
+ import { getAllCheckedNodes } from "../Tree/get-all-checked-nodes/get-all-checked-nodes.mjs";
4
+ import { isNodeChecked } from "../Tree/is-node-checked/is-node-checked.mjs";
5
+ //#region packages/@mantine/core/src/components/TreeSelect/get-checked-values-by-strategy.ts
6
+ function expandToLeafChecked(value, data) {
7
+ const leaves = /* @__PURE__ */ new Set();
8
+ for (const v of value) for (const leaf of getChildrenNodesValues(v, data)) leaves.add(leaf);
9
+ return Array.from(leaves);
10
+ }
11
+ function getTopmostCheckedParents(data, checkedState) {
12
+ const result = [];
13
+ for (const node of data) if (isNodeChecked(node.value, data, checkedState)) result.push(node.value);
14
+ else if (Array.isArray(node.children) && node.children.length > 0) result.push(...getTopmostCheckedParents(node.children, checkedState));
15
+ return result;
16
+ }
17
+ function checkedToValue(checkedState, data, strategy) {
18
+ if (checkedState.length === 0) return [];
19
+ switch (strategy) {
20
+ case "child": return checkedState;
21
+ case "all": return getAllCheckedNodes(data, checkedState).result.filter((n) => n.checked).map((n) => n.value);
22
+ case "parent": return getTopmostCheckedParents(data, checkedState);
23
+ default: return checkedState;
24
+ }
25
+ }
26
+ //#endregion
27
+ export { checkedToValue, expandToLeafChecked };
28
+
29
+ //# sourceMappingURL=get-checked-values-by-strategy.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-checked-values-by-strategy.mjs","names":[],"sources":["../../../src/components/TreeSelect/get-checked-values-by-strategy.ts"],"sourcesContent":["import type { TreeNodeData } from '../Tree';\nimport { getAllCheckedNodes } from '../Tree/get-all-checked-nodes/get-all-checked-nodes';\nimport { getChildrenNodesValues } from '../Tree/get-children-nodes-values/get-children-nodes-values';\nimport { isNodeChecked } from '../Tree/is-node-checked/is-node-checked';\n\nexport type CheckedStrategy = 'all' | 'parent' | 'child';\n\nexport function expandToLeafChecked(value: string[], data: TreeNodeData[]): string[] {\n const leaves = new Set<string>();\n for (const v of value) {\n for (const leaf of getChildrenNodesValues(v, data)) {\n leaves.add(leaf);\n }\n }\n return Array.from(leaves);\n}\n\nfunction getTopmostCheckedParents(data: TreeNodeData[], checkedState: string[]): string[] {\n const result: string[] = [];\n for (const node of data) {\n if (isNodeChecked(node.value, data, checkedState)) {\n result.push(node.value);\n } else if (Array.isArray(node.children) && node.children.length > 0) {\n result.push(...getTopmostCheckedParents(node.children, checkedState));\n }\n }\n return result;\n}\n\nexport function checkedToValue(\n checkedState: string[],\n data: TreeNodeData[],\n strategy: CheckedStrategy\n): string[] {\n if (checkedState.length === 0) {\n return [];\n }\n\n switch (strategy) {\n case 'child':\n return checkedState;\n case 'all':\n return getAllCheckedNodes(data, checkedState)\n .result.filter((n) => n.checked)\n .map((n) => n.value);\n case 'parent':\n return getTopmostCheckedParents(data, checkedState);\n default:\n return checkedState;\n }\n}\n"],"mappings":";;;;;AAOA,SAAgB,oBAAoB,OAAiB,MAAgC;CACnF,MAAM,yBAAS,IAAI,KAAa;AAChC,MAAK,MAAM,KAAK,MACd,MAAK,MAAM,QAAQ,uBAAuB,GAAG,KAAK,CAChD,QAAO,IAAI,KAAK;AAGpB,QAAO,MAAM,KAAK,OAAO;;AAG3B,SAAS,yBAAyB,MAAsB,cAAkC;CACxF,MAAM,SAAmB,EAAE;AAC3B,MAAK,MAAM,QAAQ,KACjB,KAAI,cAAc,KAAK,OAAO,MAAM,aAAa,CAC/C,QAAO,KAAK,KAAK,MAAM;UACd,MAAM,QAAQ,KAAK,SAAS,IAAI,KAAK,SAAS,SAAS,EAChE,QAAO,KAAK,GAAG,yBAAyB,KAAK,UAAU,aAAa,CAAC;AAGzE,QAAO;;AAGT,SAAgB,eACd,cACA,MACA,UACU;AACV,KAAI,aAAa,WAAW,EAC1B,QAAO,EAAE;AAGX,SAAQ,UAAR;EACE,KAAK,QACH,QAAO;EACT,KAAK,MACH,QAAO,mBAAmB,MAAM,aAAa,CAC1C,OAAO,QAAQ,MAAM,EAAE,QAAQ,CAC/B,KAAK,MAAM,EAAE,MAAM;EACxB,KAAK,SACH,QAAO,yBAAyB,MAAM,aAAa;EACrD,QACE,QAAO"}
@@ -4,8 +4,16 @@ import { useMantineTheme } from "../MantineThemeProvider/MantineThemeProvider.mj
4
4
  //#region packages/@mantine/core/src/core/MantineProvider/use-props/use-props.ts
5
5
  function useProps(component, defaultProps, props) {
6
6
  const theme = useMantineTheme();
7
- const contextPropsPayload = theme.components[component]?.defaultProps;
8
- const contextProps = typeof contextPropsPayload === "function" ? contextPropsPayload(theme) : contextPropsPayload;
7
+ const names = (Array.isArray(component) ? component : [component]).filter(Boolean);
8
+ let contextProps = {};
9
+ for (const name of names) {
10
+ const payload = theme.components[name]?.defaultProps;
11
+ const resolved = typeof payload === "function" ? payload(theme) : payload;
12
+ if (resolved) contextProps = {
13
+ ...contextProps,
14
+ ...resolved
15
+ };
16
+ }
9
17
  return {
10
18
  ...defaultProps,
11
19
  ...contextProps,
@@ -1 +1 @@
1
- {"version":3,"file":"use-props.mjs","names":[],"sources":["../../../../src/core/MantineProvider/use-props/use-props.ts"],"sourcesContent":["import { filterProps } from '../../utils';\nimport { useMantineTheme } from '../MantineThemeProvider';\n\nexport function useProps<T extends Record<string, any>, U extends Partial<T> | null = {}>(\n component: string,\n defaultProps: U,\n props: T\n): T &\n (U extends null | undefined\n ? {}\n : {\n [Key in Extract<keyof T, keyof U>]-?: U[Key] | NonNullable<T[Key]>;\n }) {\n const theme = useMantineTheme();\n const contextPropsPayload = theme.components[component]?.defaultProps;\n const contextProps =\n typeof contextPropsPayload === 'function' ? contextPropsPayload(theme) : contextPropsPayload;\n\n return { ...defaultProps, ...contextProps, ...filterProps(props) };\n}\n"],"mappings":";;;;AAGA,SAAgB,SACd,WACA,cACA,OAMO;CACP,MAAM,QAAQ,iBAAiB;CAC/B,MAAM,sBAAsB,MAAM,WAAW,YAAY;CACzD,MAAM,eACJ,OAAO,wBAAwB,aAAa,oBAAoB,MAAM,GAAG;AAE3E,QAAO;EAAE,GAAG;EAAc,GAAG;EAAc,GAAG,YAAY,MAAM;EAAE"}
1
+ {"version":3,"file":"use-props.mjs","names":[],"sources":["../../../../src/core/MantineProvider/use-props/use-props.ts"],"sourcesContent":["import { filterProps } from '../../utils';\nimport { useMantineTheme } from '../MantineThemeProvider';\n\nexport function useProps<T extends Record<string, any>, U extends Partial<T> | null = {}>(\n component: string | (string | undefined)[],\n defaultProps: U,\n props: T\n): T &\n (U extends null | undefined\n ? {}\n : {\n [Key in Extract<keyof T, keyof U>]-?: U[Key] | NonNullable<T[Key]>;\n }) {\n const theme = useMantineTheme();\n const names = (Array.isArray(component) ? component : [component]).filter(Boolean) as string[];\n\n let contextProps: Record<string, any> = {};\n for (const name of names) {\n const payload = theme.components[name]?.defaultProps;\n const resolved = typeof payload === 'function' ? payload(theme) : payload;\n if (resolved) {\n contextProps = { ...contextProps, ...resolved };\n }\n }\n\n return { ...defaultProps, ...contextProps, ...filterProps(props) } as any;\n}\n"],"mappings":";;;;AAGA,SAAgB,SACd,WACA,cACA,OAMO;CACP,MAAM,QAAQ,iBAAiB;CAC/B,MAAM,SAAS,MAAM,QAAQ,UAAU,GAAG,YAAY,CAAC,UAAU,EAAE,OAAO,QAAQ;CAElF,IAAI,eAAoC,EAAE;AAC1C,MAAK,MAAM,QAAQ,OAAO;EACxB,MAAM,UAAU,MAAM,WAAW,OAAO;EACxC,MAAM,WAAW,OAAO,YAAY,aAAa,QAAQ,MAAM,GAAG;AAClE,MAAI,SACF,gBAAe;GAAE,GAAG;GAAc,GAAG;GAAU;;AAInD,QAAO;EAAE,GAAG;EAAc,GAAG;EAAc,GAAG,YAAY,MAAM;EAAE"}
@@ -6,13 +6,13 @@ import { useMantineTheme } from "../../MantineProvider/MantineThemeProvider/Mant
6
6
  function useResolvedStylesApi({ classNames, styles, props, stylesCtx }) {
7
7
  const theme = useMantineTheme();
8
8
  return {
9
- resolvedClassNames: resolveClassNames({
9
+ resolvedClassNames: classNames === void 0 ? void 0 : resolveClassNames({
10
10
  theme,
11
11
  classNames,
12
12
  props,
13
13
  stylesCtx: stylesCtx || void 0
14
14
  }),
15
- resolvedStyles: resolveStyles({
15
+ resolvedStyles: styles === void 0 ? void 0 : resolveStyles({
16
16
  theme,
17
17
  styles,
18
18
  props,
@@ -1 +1 @@
1
- {"version":3,"file":"use-resolved-styles-api.mjs","names":[],"sources":["../../../../src/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.ts"],"sourcesContent":["import { FactoryPayload } from '../../factory';\nimport { useMantineTheme } from '../../MantineProvider';\nimport { ClassNames, Styles } from '../styles-api.types';\nimport { resolveClassNames } from '../use-styles/get-class-name/resolve-class-names/resolve-class-names';\nimport { resolveStyles } from '../use-styles/get-style/resolve-styles/resolve-styles';\n\nexport interface UseResolvedStylesApiInput<Payload extends FactoryPayload> {\n classNames: ClassNames<Payload> | undefined;\n styles: Styles<Payload> | undefined;\n props: Record<string, any>;\n stylesCtx?: Record<string, any>;\n}\n\nexport function useResolvedStylesApi<Payload extends FactoryPayload>({\n classNames,\n styles,\n props,\n stylesCtx,\n}: UseResolvedStylesApiInput<Payload>) {\n const theme = useMantineTheme();\n\n return {\n resolvedClassNames: resolveClassNames({\n theme,\n classNames,\n props,\n stylesCtx: stylesCtx || undefined,\n }),\n\n resolvedStyles: resolveStyles({\n theme,\n styles,\n props,\n stylesCtx: stylesCtx || undefined,\n }),\n };\n}\n"],"mappings":";;;;;AAaA,SAAgB,qBAAqD,EACnE,YACA,QACA,OACA,aACqC;CACrC,MAAM,QAAQ,iBAAiB;AAE/B,QAAO;EACL,oBAAoB,kBAAkB;GACpC;GACA;GACA;GACA,WAAW,aAAa,KAAA;GACzB,CAAC;EAEF,gBAAgB,cAAc;GAC5B;GACA;GACA;GACA,WAAW,aAAa,KAAA;GACzB,CAAC;EACH"}
1
+ {"version":3,"file":"use-resolved-styles-api.mjs","names":[],"sources":["../../../../src/core/styles-api/use-resolved-styles-api/use-resolved-styles-api.ts"],"sourcesContent":["import { FactoryPayload } from '../../factory';\nimport { useMantineTheme } from '../../MantineProvider';\nimport { ClassNames, Styles } from '../styles-api.types';\nimport { resolveClassNames } from '../use-styles/get-class-name/resolve-class-names/resolve-class-names';\nimport { resolveStyles } from '../use-styles/get-style/resolve-styles/resolve-styles';\n\nexport interface UseResolvedStylesApiInput<Payload extends FactoryPayload> {\n classNames: ClassNames<Payload> | undefined;\n styles: Styles<Payload> | undefined;\n props: Record<string, any>;\n stylesCtx?: Record<string, any>;\n}\n\nexport function useResolvedStylesApi<Payload extends FactoryPayload>({\n classNames,\n styles,\n props,\n stylesCtx,\n}: UseResolvedStylesApiInput<Payload>) {\n const theme = useMantineTheme();\n\n return {\n resolvedClassNames:\n classNames === undefined\n ? undefined\n : resolveClassNames({\n theme,\n classNames,\n props,\n stylesCtx: stylesCtx || undefined,\n }),\n\n resolvedStyles:\n styles === undefined\n ? undefined\n : resolveStyles({\n theme,\n styles,\n props,\n stylesCtx: stylesCtx || undefined,\n }),\n };\n}\n"],"mappings":";;;;;AAaA,SAAgB,qBAAqD,EACnE,YACA,QACA,OACA,aACqC;CACrC,MAAM,QAAQ,iBAAiB;AAE/B,QAAO;EACL,oBACE,eAAe,KAAA,IACX,KAAA,IACA,kBAAkB;GAChB;GACA;GACA;GACA,WAAW,aAAa,KAAA;GACzB,CAAC;EAER,gBACE,WAAW,KAAA,IACP,KAAA,IACA,cAAc;GACZ;GACA;GACA;GACA,WAAW,aAAa,KAAA;GACzB,CAAC;EACT"}
package/esm/index.mjs CHANGED
@@ -180,6 +180,7 @@ import { isOptionsGroup } from "./components/Combobox/OptionsDropdown/is-options
180
180
  import { defaultOptionsFilter } from "./components/Combobox/OptionsDropdown/default-options-filter.mjs";
181
181
  import { OptionsDropdown } from "./components/Combobox/OptionsDropdown/OptionsDropdown.mjs";
182
182
  import { useVirtualizedCombobox } from "./components/Combobox/use-combobox/use-virtualized-combobox.mjs";
183
+ import { usePillsReorder } from "./components/Combobox/use-pills-reorder/use-pills-reorder.mjs";
183
184
  import { Autocomplete } from "./components/Autocomplete/Autocomplete.mjs";
184
185
  import { AvatarGroup, AvatarGroupContext } from "./components/Avatar/AvatarGroup/AvatarGroup.mjs";
185
186
  import { Avatar } from "./components/Avatar/Avatar.mjs";
@@ -297,6 +298,7 @@ import { RadioIcon } from "./components/Radio/RadioIcon.mjs";
297
298
  import { RadioIndicator } from "./components/Radio/RadioIndicator/RadioIndicator.mjs";
298
299
  import { Radio } from "./components/Radio/Radio.mjs";
299
300
  import { Rating } from "./components/Rating/Rating.mjs";
301
+ import { RollingNumber } from "./components/RollingNumber/RollingNumber.mjs";
300
302
  import { TooltipFloating } from "./components/Tooltip/TooltipFloating/TooltipFloating.mjs";
301
303
  import { TooltipGroup, TooltipGroupContext } from "./components/Tooltip/TooltipGroup/TooltipGroup.mjs";
302
304
  import { Tooltip } from "./components/Tooltip/Tooltip.mjs";
@@ -341,6 +343,8 @@ import { moveTreeNode } from "./components/Tree/move-tree-node/move-tree-node.mj
341
343
  import { defaultTreeNodeFilter, filterTreeData } from "./components/Tree/filter-tree-data/filter-tree-data.mjs";
342
344
  import { flattenTreeData } from "./components/Tree/flatten-tree-data/flatten-tree-data.mjs";
343
345
  import { FlatTreeNode } from "./components/Tree/FlatTreeNode.mjs";
346
+ import { TreeSelectOption } from "./components/TreeSelect/TreeSelectOption.mjs";
347
+ import { TreeSelect } from "./components/TreeSelect/TreeSelect.mjs";
344
348
  import { Typography } from "./components/Typography/Typography.mjs";
345
349
  import { RemoveScroll } from "react-remove-scroll";
346
- export { Accordion, AccordionChevron, AccordionControl, AccordionItem, AccordionPanel, ActionIcon, ActionIconGroup, ActionIconGroupSection, Affix, Alert, AlphaSlider, Anchor, AngleSlider, AppShell, AppShellAside, AppShellFooter, AppShellHeader, AppShellMain, AppShellNavbar, AppShellSection, AspectRatio, Autocomplete, Avatar, AvatarGroup, AvatarGroupContext, BackgroundImage, Badge, Blockquote, Box, Breadcrumbs, Burger, Button, ButtonGroup, ButtonGroupSection, Card, CardSection, Center, CheckIcon, Checkbox, CheckboxCard, CheckboxCardContext, CheckboxGroup, CheckboxGroupContext, CheckboxIndicator, Chip, ChipGroup, ChipGroupContext, CloseButton, CloseIcon, Code, Collapse, ColorInput, ColorPicker, ColorSchemeScript, ColorSwatch, Combobox, ComboboxChevron, ComboboxClearButton, ComboboxDropdown, ComboboxDropdownTarget, ComboboxEmpty, ComboboxEventsTarget, ComboboxFooter, ComboboxGroup, ComboboxHeader, ComboboxHiddenInput, ComboboxOption, ComboboxOptions, ComboboxSearch, ComboboxTarget, Container, CopyButton, DEFAULT_THEME, Dialog, DirectionContext, DirectionProvider, Divider, Drawer, DrawerBody, DrawerCloseButton, DrawerContent, DrawerHeader, DrawerOverlay, DrawerRoot, DrawerStack, DrawerStackContext, DrawerTitle, FLEX_STYLE_PROPS_DATA, FOCUS_CLASS_NAMES, Fieldset, FileButton, FileInput, FlatTreeNode, Flex, FloatingArrow, FloatingIndicator, FloatingWindow, FocusTrap, FocusTrapInitialFocus, Grid, GridCol, Group, HeadlessMantineProvider, Highlight, HoverCard, HoverCardDropdown, HoverCardGroup, HoverCardGroupContext, HoverCardTarget, HueSlider, Image, Indicator, InlineStyles, Input, InputBase, InputClearButton, InputClearSection, InputDescription, InputError, InputLabel, InputPlaceholder, InputWrapper, InputWrapperContext, JsonInput, Kbd, List, ListItem, Loader, LoadingOverlay, transitions as MANTINE_TRANSITIONS, MantineContext, MantineProvider, MantineThemeContext, MantineThemeProvider, Mark, Marquee, MaskInput, Menu, MenuDivider, MenuDropdown, MenuItem, MenuLabel, MenuSub, MenuSubDropdown, MenuSubItem, MenuSubTarget, MenuTarget, Modal, ModalBase, ModalBaseBody, ModalBaseCloseButton, ModalBaseContent, ModalBaseHeader, ModalBaseOverlay, ModalBaseTitle, ModalBody, ModalCloseButton, ModalContent, ModalHeader, ModalOverlay, ModalRoot, ModalStack, ModalStackContext, ModalTitle, MultiSelect, NativeScrollArea, NativeSelect, NavLink, Notification, NumberFormatter, NumberInput, OptionalPortal, OptionsDropdown, OverflowList, Overlay, Pagination, PaginationControl, PaginationDots, PaginationFirst, PaginationItems, PaginationLast, PaginationNext, PaginationPrevious, PaginationRoot, Paper, PasswordInput, Pill, PillGroup, PillsInput, PillsInputContext, PillsInputField, PinInput, Popover, PopoverDropdown, PopoverTarget, Portal, Progress, ProgressLabel, ProgressRoot, ProgressSection, Radio, RadioCard, RadioCardContext, RadioGroup, RadioGroupContext, RadioIcon, RadioIndicator, RangeSlider, Rating, RemoveScroll, RingProgress, STYlE_PROPS_DATA, ScrollArea, ScrollAreaAutosize, Scroller, SegmentedControl, Select, SemiCircleProgress, SimpleGrid, Skeleton, Slider, Space, Spoiler, Stack, Stepper, StepperCompleted, StepperStep, Switch, SwitchGroup, SwitchGroupContext, Table, TableCaption, TableOfContents, TableScrollContainer, TableTbody, TableTd, TableTfoot, TableTh, TableThead, TableTr, Tabs, TabsList, TabsPanel, TabsTab, TagsInput, Text, TextInput, Textarea, ThemeIcon, Timeline, TimelineItem, Title, Tooltip, TooltipFloating, TooltipGroup, TooltipGroupContext, Transition, Tree, Typography, UnstyledButton, VisuallyHidden, alpha, camelToKebabCase, closeOnEscape, colorsTuple, convertCssVariables, convertHsvaTo, createEventHandler, createPolymorphicComponent, createSafeContext, createScopedKeydownHandler, createTheme, createUseExternalEvents, createVarsResolver, darken, deepMerge, defaultCssVariablesResolver, defaultLoaders, defaultOptionsFilter, defaultTreeNodeFilter, defaultVariantColorsResolver, em, extractStyleProps, factory, filterProps, filterTreeData, findClosestNumber, findElementAncestor, findElementBySelector, findElementsBySelector, flattenTreeData, genericFactory, getAutoContrastValue, getBaseValue, getBreakpointValue, getCSSColorVariables, getContextItemIndex, getContrastColor, getDefaultZIndex, getEnv, getFloatingPosition, getFontSize, getGradient, getLineHeight, getOptionsLockup, getParsedComboboxData, getPrimaryContrastColor, getPrimaryShade, getRadius, getRefProp, getRootElement, getSafeId, getShadow, getSingleElementChild, getSize, getSortedBreakpoints, getSpacing, getStyleObject, getThemeColor, getTransitionProps, getTreeExpandedState, hashStyleProps, isColorValid, isElement, isLightColor, isMantineColorScheme, isNumberLike, isOptionsGroup, isPrimitive, isVirtualColor, keys, lighten, localStorageColorSchemeManager, luminance, mantineHtmlProps, memoize, mergeAsyncChildren, mergeMantineTheme, mergeThemeOverrides, moveTreeNode, noop, parseColor, parseStyleProps, parseThemeColor, polymorphic, polymorphicFactory, px, rem, resolveClassNames, resolveStyles, rgba, stylesToString, toRgba, useAccordionContext, useAccordionItemContext, useAppShellContext, useCombobox, useComboboxContext, useComboboxTargetProps, useComputedColorScheme, useDelayedHover, useDirection, useDrawerContext, useDrawersStack, useGridContext, useHoverCardContext, useHovered, useInputProps, useListContext, useMantineClassNamesPrefix, useMantineColorScheme, useMantineContext, useMantineCssVariablesResolver, useMantineDeduplicateInlineStyles, useMantineEnv, useMantineIsHeadless, useMantineStyleNonce, useMantineStylesTransform, useMantineSxTransform, useMantineTheme, useMantineWithStaticClasses, useMatches, useMenuContext, useModalContext, useModalsStack, usePaginationContext, usePopoverContext, useProgressContext, useProps, useProviderColorScheme, useRandomClassName, useResolvedStylesApi, useSafeMantineTheme, useScrollAreaContext, useStepperContext, useStyles, useTableContext, useTabsContext, useTree, useVirtualizedCombobox, v8CssVariablesResolver, validateMantineTheme, virtualColor };
350
+ export { Accordion, AccordionChevron, AccordionControl, AccordionItem, AccordionPanel, ActionIcon, ActionIconGroup, ActionIconGroupSection, Affix, Alert, AlphaSlider, Anchor, AngleSlider, AppShell, AppShellAside, AppShellFooter, AppShellHeader, AppShellMain, AppShellNavbar, AppShellSection, AspectRatio, Autocomplete, Avatar, AvatarGroup, AvatarGroupContext, BackgroundImage, Badge, Blockquote, Box, Breadcrumbs, Burger, Button, ButtonGroup, ButtonGroupSection, Card, CardSection, Center, CheckIcon, Checkbox, CheckboxCard, CheckboxCardContext, CheckboxGroup, CheckboxGroupContext, CheckboxIndicator, Chip, ChipGroup, ChipGroupContext, CloseButton, CloseIcon, Code, Collapse, ColorInput, ColorPicker, ColorSchemeScript, ColorSwatch, Combobox, ComboboxChevron, ComboboxClearButton, ComboboxDropdown, ComboboxDropdownTarget, ComboboxEmpty, ComboboxEventsTarget, ComboboxFooter, ComboboxGroup, ComboboxHeader, ComboboxHiddenInput, ComboboxOption, ComboboxOptions, ComboboxSearch, ComboboxTarget, Container, CopyButton, DEFAULT_THEME, Dialog, DirectionContext, DirectionProvider, Divider, Drawer, DrawerBody, DrawerCloseButton, DrawerContent, DrawerHeader, DrawerOverlay, DrawerRoot, DrawerStack, DrawerStackContext, DrawerTitle, FLEX_STYLE_PROPS_DATA, FOCUS_CLASS_NAMES, Fieldset, FileButton, FileInput, FlatTreeNode, Flex, FloatingArrow, FloatingIndicator, FloatingWindow, FocusTrap, FocusTrapInitialFocus, Grid, GridCol, Group, HeadlessMantineProvider, Highlight, HoverCard, HoverCardDropdown, HoverCardGroup, HoverCardGroupContext, HoverCardTarget, HueSlider, Image, Indicator, InlineStyles, Input, InputBase, InputClearButton, InputClearSection, InputDescription, InputError, InputLabel, InputPlaceholder, InputWrapper, InputWrapperContext, JsonInput, Kbd, List, ListItem, Loader, LoadingOverlay, transitions as MANTINE_TRANSITIONS, MantineContext, MantineProvider, MantineThemeContext, MantineThemeProvider, Mark, Marquee, MaskInput, Menu, MenuDivider, MenuDropdown, MenuItem, MenuLabel, MenuSub, MenuSubDropdown, MenuSubItem, MenuSubTarget, MenuTarget, Modal, ModalBase, ModalBaseBody, ModalBaseCloseButton, ModalBaseContent, ModalBaseHeader, ModalBaseOverlay, ModalBaseTitle, ModalBody, ModalCloseButton, ModalContent, ModalHeader, ModalOverlay, ModalRoot, ModalStack, ModalStackContext, ModalTitle, MultiSelect, NativeScrollArea, NativeSelect, NavLink, Notification, NumberFormatter, NumberInput, OptionalPortal, OptionsDropdown, OverflowList, Overlay, Pagination, PaginationControl, PaginationDots, PaginationFirst, PaginationItems, PaginationLast, PaginationNext, PaginationPrevious, PaginationRoot, Paper, PasswordInput, Pill, PillGroup, PillsInput, PillsInputContext, PillsInputField, PinInput, Popover, PopoverDropdown, PopoverTarget, Portal, Progress, ProgressLabel, ProgressRoot, ProgressSection, Radio, RadioCard, RadioCardContext, RadioGroup, RadioGroupContext, RadioIcon, RadioIndicator, RangeSlider, Rating, RemoveScroll, RingProgress, RollingNumber, STYlE_PROPS_DATA, ScrollArea, ScrollAreaAutosize, Scroller, SegmentedControl, Select, SemiCircleProgress, SimpleGrid, Skeleton, Slider, Space, Spoiler, Stack, Stepper, StepperCompleted, StepperStep, Switch, SwitchGroup, SwitchGroupContext, Table, TableCaption, TableOfContents, TableScrollContainer, TableTbody, TableTd, TableTfoot, TableTh, TableThead, TableTr, Tabs, TabsList, TabsPanel, TabsTab, TagsInput, Text, TextInput, Textarea, ThemeIcon, Timeline, TimelineItem, Title, Tooltip, TooltipFloating, TooltipGroup, TooltipGroupContext, Transition, Tree, TreeSelect, TreeSelectOption, Typography, UnstyledButton, VisuallyHidden, alpha, camelToKebabCase, closeOnEscape, colorsTuple, convertCssVariables, convertHsvaTo, createEventHandler, createPolymorphicComponent, createSafeContext, createScopedKeydownHandler, createTheme, createUseExternalEvents, createVarsResolver, darken, deepMerge, defaultCssVariablesResolver, defaultLoaders, defaultOptionsFilter, defaultTreeNodeFilter, defaultVariantColorsResolver, em, extractStyleProps, factory, filterProps, filterTreeData, findClosestNumber, findElementAncestor, findElementBySelector, findElementsBySelector, flattenTreeData, genericFactory, getAutoContrastValue, getBaseValue, getBreakpointValue, getCSSColorVariables, getContextItemIndex, getContrastColor, getDefaultZIndex, getEnv, getFloatingPosition, getFontSize, getGradient, getLineHeight, getOptionsLockup, getParsedComboboxData, getPrimaryContrastColor, getPrimaryShade, getRadius, getRefProp, getRootElement, getSafeId, getShadow, getSingleElementChild, getSize, getSortedBreakpoints, getSpacing, getStyleObject, getThemeColor, getTransitionProps, getTreeExpandedState, hashStyleProps, isColorValid, isElement, isLightColor, isMantineColorScheme, isNumberLike, isOptionsGroup, isPrimitive, isVirtualColor, keys, lighten, localStorageColorSchemeManager, luminance, mantineHtmlProps, memoize, mergeAsyncChildren, mergeMantineTheme, mergeThemeOverrides, moveTreeNode, noop, parseColor, parseStyleProps, parseThemeColor, polymorphic, polymorphicFactory, px, rem, resolveClassNames, resolveStyles, rgba, stylesToString, toRgba, useAccordionContext, useAccordionItemContext, useAppShellContext, useCombobox, useComboboxContext, useComboboxTargetProps, useComputedColorScheme, useDelayedHover, useDirection, useDrawerContext, useDrawersStack, useGridContext, useHoverCardContext, useHovered, useInputProps, useListContext, useMantineClassNamesPrefix, useMantineColorScheme, useMantineContext, useMantineCssVariablesResolver, useMantineDeduplicateInlineStyles, useMantineEnv, useMantineIsHeadless, useMantineStyleNonce, useMantineStylesTransform, useMantineSxTransform, useMantineTheme, useMantineWithStaticClasses, useMatches, useMenuContext, useModalContext, useModalsStack, usePaginationContext, usePillsReorder, usePopoverContext, useProgressContext, useProps, useProviderColorScheme, useRandomClassName, useResolvedStylesApi, useSafeMantineTheme, useScrollAreaContext, useStepperContext, useStyles, useTableContext, useTabsContext, useTree, useVirtualizedCombobox, v8CssVariablesResolver, validateMantineTheme, virtualColor };
@@ -1,6 +1,7 @@
1
1
  import { Primitive } from '../../core';
2
2
  import type { ComboboxProps, ComboboxStylesNames } from './Combobox';
3
3
  import type { OptionsFilter } from './OptionsDropdown/OptionsDropdown';
4
+ import type { PillReorderProps } from './use-pills-reorder/use-pills-reorder';
4
5
  export interface ComboboxGenericItem<Value extends Primitive = string> {
5
6
  value: Value;
6
7
  disabled?: boolean;
@@ -57,4 +58,6 @@ export interface ComboboxRenderPillInput<Value extends Primitive = string> {
57
58
  value?: Value;
58
59
  onRemove?: () => void;
59
60
  disabled?: boolean;
61
+ /** Props to spread into the pill element to enable drag-and-drop reordering. Defined only when `withPillsReorder` is set. */
62
+ reorderProps?: PillReorderProps;
60
63
  }
@@ -3,7 +3,7 @@ import { InputClearButtonProps } from '../../Input';
3
3
  export interface ComboboxClearButtonProps extends InputClearButtonProps, ElementProps<'button'> {
4
4
  onClear: () => void;
5
5
  }
6
- export declare function ComboboxClearButton({ size, onMouseDown, onClick, onClear, ...others }: ComboboxClearButtonProps): import("react/jsx-runtime").JSX.Element;
6
+ export declare function ComboboxClearButton({ onMouseDown, onClick, onClear, ...others }: ComboboxClearButtonProps): import("react/jsx-runtime").JSX.Element;
7
7
  export declare namespace ComboboxClearButton {
8
8
  var displayName: string;
9
9
  }
@@ -22,6 +22,7 @@ export { useComboboxTargetProps } from './use-combobox-target-props/use-combobox
22
22
  export { isOptionsGroup } from './OptionsDropdown/is-options-group';
23
23
  export { defaultOptionsFilter } from './OptionsDropdown/default-options-filter';
24
24
  export { useComboboxContext } from './Combobox.context';
25
+ export { usePillsReorder } from './use-pills-reorder/use-pills-reorder';
25
26
  export type { ComboboxFactory, ComboboxProps, ComboboxStylesNames } from './Combobox';
26
27
  export type { ComboboxContextValue } from './Combobox.context';
27
28
  export type { ComboboxData, ComboboxGenericData, ComboboxGenericItem, ComboboxItem, ComboboxItemGroup, ComboboxLikeProps, ComboboxLikeRenderOptionInput, ComboboxLikeStylesNames, ComboboxParsedItem, ComboboxParsedItemGroup, ComboboxRenderPillInput, } from './Combobox.types';
@@ -42,3 +43,4 @@ export type { ComboboxTargetProps } from './ComboboxTarget/ComboboxTarget';
42
43
  export type { OptionsData, OptionsDropdownProps, OptionsFilter, } from './OptionsDropdown/OptionsDropdown';
43
44
  export type { ComboboxDropdownEventSource, ComboboxStore, UseComboboxOptions, } from './use-combobox/use-combobox';
44
45
  export type { UseVirtualizedComboboxOptions } from './use-combobox/use-virtualized-combobox';
46
+ export type { PillReorderProps, UsePillsReorderInput } from './use-pills-reorder/use-pills-reorder';
@@ -4,9 +4,11 @@ interface UseComboboxTargetPropsInput {
4
4
  withKeyboardNavigation: boolean | undefined;
5
5
  withExpandedAttribute: boolean | undefined;
6
6
  onKeyDown: React.KeyboardEventHandler<HTMLInputElement> | undefined;
7
+ onClick: React.MouseEventHandler<HTMLInputElement> | undefined;
7
8
  autoComplete: string | undefined;
8
9
  }
9
- export declare function useComboboxTargetProps({ onKeyDown, withKeyboardNavigation, withAriaAttributes, withExpandedAttribute, targetType, autoComplete, }: UseComboboxTargetPropsInput): {
10
+ export declare function useComboboxTargetProps({ onKeyDown, onClick, withKeyboardNavigation, withAriaAttributes, withExpandedAttribute, targetType, autoComplete, }: UseComboboxTargetPropsInput): {
10
11
  onKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;
12
+ onClick: (event: React.MouseEvent<HTMLInputElement>) => void;
11
13
  };
12
14
  export {};
@@ -0,0 +1,2 @@
1
+ export type PillReorderPosition = 'before' | 'after';
2
+ export declare function movePill<T>(value: T[], from: number, to: number, position: PillReorderPosition): T[];
@@ -0,0 +1,26 @@
1
+ export interface PillReorderProps {
2
+ draggable: boolean;
3
+ tabIndex: number;
4
+ 'data-mantine-pill-index': number;
5
+ 'aria-keyshortcuts': string;
6
+ onMouseDown: (event: React.MouseEvent<HTMLElement>) => void;
7
+ onDragStart: (event: React.DragEvent<HTMLElement>) => void;
8
+ onDragOver: (event: React.DragEvent<HTMLElement>) => void;
9
+ onDragLeave: (event: React.DragEvent<HTMLElement>) => void;
10
+ onDrop: (event: React.DragEvent<HTMLElement>) => void;
11
+ onDragEnd: (event: React.DragEvent<HTMLElement>) => void;
12
+ onKeyDown: (event: React.KeyboardEvent<HTMLElement>) => void;
13
+ }
14
+ export interface PillsReorderListProps {
15
+ ref?: (node: HTMLDivElement | null) => void;
16
+ }
17
+ export interface UsePillsReorderInput<T> {
18
+ value: T[];
19
+ onChange: (value: T[]) => void;
20
+ enabled: boolean | undefined;
21
+ }
22
+ export declare function usePillsReorder<T>({ value, onChange, enabled }: UsePillsReorderInput<T>): {
23
+ getPillProps: (index: number) => PillReorderProps | undefined;
24
+ getListProps: () => PillsReorderListProps;
25
+ handleInputKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;
26
+ };
@@ -53,6 +53,8 @@ export interface MaskInputProps extends BoxProps, __BaseInputProps, StylesApiPro
53
53
  end: number;
54
54
  } | null;
55
55
  };
56
+ /** Assigns a function that clears the input value to the given ref */
57
+ resetRef?: React.RefObject<(() => void) | null>;
56
58
  }
57
59
  export type MaskInputFactory = Factory<{
58
60
  props: MaskInputProps;
@@ -47,7 +47,7 @@ export interface MultiSelectProps<Value extends Primitive = string> extends BoxP
47
47
  /** Divider used to separate values in the hidden input `value` attribute @default ',' */
48
48
  hiddenInputValuesDivider?: string;
49
49
  /** A function to render content of the option, replaces the default content of the option */
50
- renderOption?: (item: ComboboxLikeRenderOptionInput<ComboboxItem>) => React.ReactNode;
50
+ renderOption?: (item: ComboboxLikeRenderOptionInput<ComboboxItem<Value>>) => React.ReactNode;
51
51
  /** A function to render content of the pill */
52
52
  renderPill?: (props: ComboboxRenderPillInput<Value>) => React.ReactNode;
53
53
  /** Props passed down to the underlying `ScrollArea` component in the dropdown */
@@ -58,6 +58,8 @@ export interface MultiSelectProps<Value extends Primitive = string> extends BoxP
58
58
  clearSearchOnChange?: boolean;
59
59
  /** Controls whether dropdown opens when the input receives focus @default true */
60
60
  openOnFocus?: boolean;
61
+ /** If set, selected values can be reordered by dragging pills. Disabled when `disabled` or `readOnly` is set. @default false */
62
+ withPillsReorder?: boolean;
61
63
  }
62
64
  export type MultiSelectFactory = Factory<{
63
65
  props: MultiSelectProps;
@@ -45,7 +45,7 @@ export interface PopoverContextValue {
45
45
  variant: string | undefined;
46
46
  keepMounted: boolean | undefined;
47
47
  getStyles: GetStylesApi<PopoverFactory>;
48
- resolvedStyles: Record<string, any>;
48
+ resolvedStyles: Record<string, any> | undefined;
49
49
  floatingStrategy: FloatingStrategy | undefined;
50
50
  referenceHidden: boolean | undefined;
51
51
  }
@@ -0,0 +1,11 @@
1
+ import { useStyles } from '../../core';
2
+ import type { RollingNumberFactory } from './RollingNumber';
3
+ interface DigitColumnProps {
4
+ digit: string;
5
+ getStyles: ReturnType<typeof useStyles<RollingNumberFactory>>;
6
+ previousDigit: string | null;
7
+ empty?: boolean;
8
+ valueDirection: 'up' | 'down';
9
+ }
10
+ export declare function DigitColumn({ digit, getStyles, previousDigit, empty, valueDirection, }: DigitColumnProps): import("react/jsx-runtime").JSX.Element;
11
+ export {};