@salt-ds/lab 1.0.0-alpha.16 → 1.0.0-alpha.18

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 (204) hide show
  1. package/dist-cjs/badge/Badge.css.js +1 -1
  2. package/dist-cjs/cascading-menu/CascadingMenu.js.map +1 -1
  3. package/dist-cjs/color-chooser/ColorChooser.js +1 -1
  4. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  5. package/dist-cjs/color-chooser/GetColorPalettes.js +2 -2
  6. package/dist-cjs/color-chooser/GetColorPalettes.js.map +1 -1
  7. package/dist-cjs/color-chooser/Swatch.css.js +1 -1
  8. package/dist-cjs/color-chooser/Swatch.js +9 -0
  9. package/dist-cjs/color-chooser/Swatch.js.map +1 -1
  10. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  11. package/dist-cjs/combo-box-next/ComboBoxNext.css.js +1 -1
  12. package/dist-cjs/combo-box-next/ComboBoxNext.js +51 -45
  13. package/dist-cjs/combo-box-next/ComboBoxNext.js.map +1 -1
  14. package/dist-cjs/combo-box-next/useComboBox.js +27 -17
  15. package/dist-cjs/combo-box-next/useComboBox.js.map +1 -1
  16. package/dist-cjs/combo-box-next/useComboboxPortal.js +16 -10
  17. package/dist-cjs/combo-box-next/useComboboxPortal.js.map +1 -1
  18. package/dist-cjs/combo-box-next/utils.js +4 -4
  19. package/dist-cjs/combo-box-next/utils.js.map +1 -1
  20. package/dist-cjs/contact-details/ContactMetadataItem.js +1 -0
  21. package/dist-cjs/contact-details/ContactMetadataItem.js.map +1 -1
  22. package/dist-cjs/dialog/Dialog.js +34 -32
  23. package/dist-cjs/dialog/Dialog.js.map +1 -1
  24. package/dist-cjs/dialog/DialogActions.js +17 -15
  25. package/dist-cjs/dialog/DialogActions.js.map +1 -1
  26. package/dist-cjs/dialog/DialogContent.css.js +1 -1
  27. package/dist-cjs/dialog/DialogContent.js +19 -17
  28. package/dist-cjs/dialog/DialogContent.js.map +1 -1
  29. package/dist-cjs/drawer/Drawer.js +25 -23
  30. package/dist-cjs/drawer/Drawer.js.map +1 -1
  31. package/dist-cjs/dropdown-next/DropdownNext.css.js +1 -1
  32. package/dist-cjs/dropdown-next/DropdownNext.js +19 -19
  33. package/dist-cjs/dropdown-next/DropdownNext.js.map +1 -1
  34. package/dist-cjs/dropdown-next/useDropdownNext.js +16 -10
  35. package/dist-cjs/dropdown-next/useDropdownNext.js.map +1 -1
  36. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  37. package/dist-cjs/list/keyset.js.map +1 -1
  38. package/dist-cjs/list-next/ListItemNext.css.js +1 -1
  39. package/dist-cjs/list-next/ListNext.js +1 -0
  40. package/dist-cjs/list-next/ListNext.js.map +1 -1
  41. package/dist-cjs/list-next/useList.js +11 -7
  42. package/dist-cjs/list-next/useList.js.map +1 -1
  43. package/dist-cjs/metric/MetricHeader.js +1 -0
  44. package/dist-cjs/metric/MetricHeader.js.map +1 -1
  45. package/dist-cjs/navigation-item/ConditionalWrapper.js +37 -0
  46. package/dist-cjs/navigation-item/ConditionalWrapper.js.map +1 -0
  47. package/dist-cjs/navigation-item/NavigationItem.css.js +1 -1
  48. package/dist-cjs/navigation-item/NavigationItem.js +11 -27
  49. package/dist-cjs/navigation-item/NavigationItem.js.map +1 -1
  50. package/dist-cjs/pill/Pill.css.js +1 -1
  51. package/dist-cjs/pill-next/PillNext.css.js +1 -1
  52. package/dist-cjs/responsive/useDynamicCollapse.js.map +1 -1
  53. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  54. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  55. package/dist-cjs/stepper-input/StepperInput.css.js +1 -1
  56. package/dist-cjs/tabs/Tab.css.js +1 -1
  57. package/dist-cjs/tabs/Tab.js +7 -13
  58. package/dist-cjs/tabs/Tab.js.map +1 -1
  59. package/dist-cjs/tabs/useActivationIndicator.js.map +1 -1
  60. package/dist-cjs/tabs-next/TabNext.css.js +1 -1
  61. package/dist-cjs/tokenized-input/TokenizedInput.css.js +1 -1
  62. package/dist-es/badge/Badge.css.js +1 -1
  63. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  64. package/dist-es/color-chooser/ColorChooser.js +1 -1
  65. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  66. package/dist-es/color-chooser/GetColorPalettes.js +2 -2
  67. package/dist-es/color-chooser/GetColorPalettes.js.map +1 -1
  68. package/dist-es/color-chooser/Swatch.css.js +1 -1
  69. package/dist-es/color-chooser/Swatch.js +9 -0
  70. package/dist-es/color-chooser/Swatch.js.map +1 -1
  71. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  72. package/dist-es/combo-box-next/ComboBoxNext.css.js +1 -1
  73. package/dist-es/combo-box-next/ComboBoxNext.js +52 -46
  74. package/dist-es/combo-box-next/ComboBoxNext.js.map +1 -1
  75. package/dist-es/combo-box-next/useComboBox.js +28 -18
  76. package/dist-es/combo-box-next/useComboBox.js.map +1 -1
  77. package/dist-es/combo-box-next/useComboboxPortal.js +16 -10
  78. package/dist-es/combo-box-next/useComboboxPortal.js.map +1 -1
  79. package/dist-es/combo-box-next/utils.js +4 -4
  80. package/dist-es/combo-box-next/utils.js.map +1 -1
  81. package/dist-es/contact-details/ContactMetadataItem.js +1 -0
  82. package/dist-es/contact-details/ContactMetadataItem.js.map +1 -1
  83. package/dist-es/dialog/Dialog.js +35 -33
  84. package/dist-es/dialog/Dialog.js.map +1 -1
  85. package/dist-es/dialog/DialogActions.js +17 -15
  86. package/dist-es/dialog/DialogActions.js.map +1 -1
  87. package/dist-es/dialog/DialogContent.css.js +1 -1
  88. package/dist-es/dialog/DialogContent.js +19 -17
  89. package/dist-es/dialog/DialogContent.js.map +1 -1
  90. package/dist-es/drawer/Drawer.js +26 -24
  91. package/dist-es/drawer/Drawer.js.map +1 -1
  92. package/dist-es/dropdown-next/DropdownNext.css.js +1 -1
  93. package/dist-es/dropdown-next/DropdownNext.js +20 -20
  94. package/dist-es/dropdown-next/DropdownNext.js.map +1 -1
  95. package/dist-es/dropdown-next/useDropdownNext.js +16 -10
  96. package/dist-es/dropdown-next/useDropdownNext.js.map +1 -1
  97. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  98. package/dist-es/list/keyset.js.map +1 -1
  99. package/dist-es/list-next/ListItemNext.css.js +1 -1
  100. package/dist-es/list-next/ListNext.js +1 -0
  101. package/dist-es/list-next/ListNext.js.map +1 -1
  102. package/dist-es/list-next/useList.js +11 -7
  103. package/dist-es/list-next/useList.js.map +1 -1
  104. package/dist-es/metric/MetricHeader.js +1 -0
  105. package/dist-es/metric/MetricHeader.js.map +1 -1
  106. package/dist-es/navigation-item/ConditionalWrapper.js +33 -0
  107. package/dist-es/navigation-item/ConditionalWrapper.js.map +1 -0
  108. package/dist-es/navigation-item/NavigationItem.css.js +1 -1
  109. package/dist-es/navigation-item/NavigationItem.js +11 -27
  110. package/dist-es/navigation-item/NavigationItem.js.map +1 -1
  111. package/dist-es/pill/Pill.css.js +1 -1
  112. package/dist-es/pill-next/PillNext.css.js +1 -1
  113. package/dist-es/responsive/useDynamicCollapse.js.map +1 -1
  114. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  115. package/dist-es/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  116. package/dist-es/stepper-input/StepperInput.css.js +1 -1
  117. package/dist-es/tabs/Tab.css.js +1 -1
  118. package/dist-es/tabs/Tab.js +8 -14
  119. package/dist-es/tabs/Tab.js.map +1 -1
  120. package/dist-es/tabs/useActivationIndicator.js.map +1 -1
  121. package/dist-es/tabs-next/TabNext.css.js +1 -1
  122. package/dist-es/tokenized-input/TokenizedInput.css.js +1 -1
  123. package/dist-types/breadcrumbs/internal/BreadcrumbsContext.d.ts +0 -1
  124. package/dist-types/breadcrumbs/internal/BreadcrumbsSeparator.d.ts +0 -1
  125. package/dist-types/breadcrumbs/internal/useFocusMenuRemount.d.ts +0 -1
  126. package/dist-types/button-bar/OrderedButton.d.ts +0 -1
  127. package/dist-types/button-bar/internal/ButtonBarContext.d.ts +0 -1
  128. package/dist-types/calendar/Calendar.d.ts +0 -1
  129. package/dist-types/calendar/internal/CalendarCarousel.d.ts +0 -1
  130. package/dist-types/calendar/internal/CalendarContext.d.ts +0 -1
  131. package/dist-types/cascading-menu/CascadingMenu.d.ts +0 -1
  132. package/dist-types/cascading-menu/CascadingMenuList.d.ts +0 -1
  133. package/dist-types/cascading-menu/internal/useMountedRef.d.ts +0 -1
  134. package/dist-types/color-chooser/AlphaInputField.d.ts +0 -1
  135. package/dist-types/color-chooser/DictTabs.d.ts +0 -1
  136. package/dist-types/color-chooser/HexInput.d.ts +0 -1
  137. package/dist-types/color-chooser/HexInputField.d.ts +0 -1
  138. package/dist-types/color-chooser/RGBAInputField.d.ts +0 -1
  139. package/dist-types/color-chooser/Swatches.d.ts +0 -1
  140. package/dist-types/color-chooser/SwatchesPicker.d.ts +0 -1
  141. package/dist-types/combo-box-deprecated/internal/MultiSelectComboBox.d.ts +0 -1
  142. package/dist-types/combo-box-next/ComboBoxNext.d.ts +40 -27
  143. package/dist-types/combo-box-next/useComboBox.d.ts +12 -3
  144. package/dist-types/combo-box-next/useComboboxPortal.d.ts +7 -0
  145. package/dist-types/combo-box-next/utils.d.ts +1 -2
  146. package/dist-types/common-hooks/useTypeahead.d.ts +0 -1
  147. package/dist-types/contact-details/ContactAvatar.d.ts +0 -1
  148. package/dist-types/contact-details/ContactFavoriteToggle.d.ts +0 -1
  149. package/dist-types/contact-details/MailLinkComponent.d.ts +0 -1
  150. package/dist-types/contact-details/internal/ContactDetailsContext.d.ts +0 -1
  151. package/dist-types/contact-details/internal/FavoriteToggleWithTooltip.d.ts +0 -1
  152. package/dist-types/dialog/DialogActions.d.ts +8 -2
  153. package/dist-types/dialog/DialogCloseButton.d.ts +0 -1
  154. package/dist-types/dialog/DialogContent.d.ts +8 -2
  155. package/dist-types/dialog/DialogContext.d.ts +0 -1
  156. package/dist-types/dialog/useDialog.d.ts +4 -5
  157. package/dist-types/drawer/Drawer.d.ts +1 -1
  158. package/dist-types/drawer/useDrawer.d.ts +4 -5
  159. package/dist-types/dropdown/DropdownBase.d.ts +0 -1
  160. package/dist-types/dropdown-next/DropdownNext.d.ts +10 -3
  161. package/dist-types/dropdown-next/useDropdownNext.d.ts +7 -0
  162. package/dist-types/form-field-legacy/FormActivationIndicator.d.ts +0 -1
  163. package/dist-types/form-field-legacy/FormControlContext.d.ts +0 -1
  164. package/dist-types/formatted-input/FormattedInput.d.ts +0 -1
  165. package/dist-types/layer-layout/LayerLayout.d.ts +1 -1
  166. package/dist-types/list-next/ListNext.d.ts +4 -1
  167. package/dist-types/list-next/useList.d.ts +4 -1
  168. package/dist-types/metric/internal/MetricContext.d.ts +0 -1
  169. package/dist-types/navigation-item/ConditionalWrapper.d.ts +8 -0
  170. package/dist-types/navigation-item/ExpansionIcon.d.ts +0 -1
  171. package/dist-types/navigation-item/NavigationItem.d.ts +2 -2
  172. package/dist-types/pagination/ArrowButton.d.ts +0 -1
  173. package/dist-types/pagination/CompactControls.d.ts +0 -1
  174. package/dist-types/pagination/CompactInput.d.ts +0 -1
  175. package/dist-types/pagination/PageButton.d.ts +0 -1
  176. package/dist-types/pagination/PaginationContext.d.ts +0 -1
  177. package/dist-types/pagination/RegularControls.d.ts +0 -1
  178. package/dist-types/pill/ClosablePill.d.ts +0 -1
  179. package/dist-types/pill/internal/DeleteButton.d.ts +0 -1
  180. package/dist-types/pill/internal/PillCheckbox.d.ts +0 -1
  181. package/dist-types/progress/Info.d.ts +0 -1
  182. package/dist-types/query-input/internal/CategoryListContext.d.ts +0 -1
  183. package/dist-types/responsive/overflowUtils.d.ts +0 -1
  184. package/dist-types/scrim/ScrimContext.d.ts +0 -1
  185. package/dist-types/skip-link/internal/useManageFocusOnTarget.d.ts +1 -1
  186. package/dist-types/slider/internal/SliderMarkLabels.d.ts +0 -1
  187. package/dist-types/slider/internal/SliderRail.d.ts +0 -1
  188. package/dist-types/slider/internal/SliderSelection.d.ts +0 -1
  189. package/dist-types/stepped-tracker/StepLabel/StepLabel.d.ts +8 -3
  190. package/dist-types/stepped-tracker/TrackerConnector/TrackerConnector.d.ts +0 -1
  191. package/dist-types/stepper-input/internal/useDynamicAriaLabel.d.ts +0 -1
  192. package/dist-types/tabs/TabActivationIndicator.d.ts +0 -1
  193. package/dist-types/tabs/Tabs.d.ts +0 -1
  194. package/dist-types/tabs/drag-drop/DropIndicator.d.ts +0 -1
  195. package/dist-types/toolbar/Toolbar.d.ts +0 -1
  196. package/dist-types/toolbar/ToolbarButton.d.ts +0 -1
  197. package/dist-types/toolbar/Tooltray.d.ts +0 -1
  198. package/dist-types/toolbar/internal/ToolbarHiddenItemIdsContext.d.ts +0 -1
  199. package/dist-types/toolbar/internal/renderToolbarItems.d.ts +0 -1
  200. package/dist-types/toolbar/toolbar-field/ToolbarField.d.ts +0 -1
  201. package/dist-types/tree/Tree.d.ts +0 -1
  202. package/dist-types/window/ElectronWindow.d.ts +0 -1
  203. package/dist-types/window/desktop-utils.d.ts +0 -1
  204. package/package.json +29 -27
@@ -1,9 +1,8 @@
1
1
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
2
  import { forwardRef, useRef } from 'react';
3
- import { makePrefixer, useId, useForkRef, Input, SaltProvider } from '@salt-ds/core';
3
+ import { makePrefixer, useId, useForkRef, useFloatingComponent, Input } from '@salt-ds/core';
4
4
  import { ListNext } from '../list-next/ListNext.js';
5
5
  import '../list-next/ListItemNext.js';
6
- import { FloatingPortal } from '@floating-ui/react';
7
6
  import { useComboBox } from './useComboBox.js';
8
7
  import { useWindow } from '@salt-ds/window';
9
8
  import { useComponentCssInjection } from '@salt-ds/styles';
@@ -14,23 +13,26 @@ import { clsx } from 'clsx';
14
13
 
15
14
  const withBaseName = makePrefixer("saltComboBoxNext");
16
15
  const ComboBoxNext = forwardRef(function ComboBoxNext2({
17
- InputProps: InputProps2 = {},
18
16
  ListProps = {},
19
17
  PortalProps = {},
20
- disabled,
18
+ inputValue: inputValueProp,
21
19
  highlightedItem: highlightedItemProp,
22
- selected,
20
+ selected: selectedProp,
21
+ defaultInputValue,
23
22
  defaultSelected,
24
- onKeyDown,
25
- onChange,
26
- onBlur,
27
- onFocus,
28
- onMouseOver,
23
+ disabled,
24
+ variant = "primary",
29
25
  source,
26
+ listRef: listRefProp,
30
27
  ListItem = DefaultListItem,
31
28
  itemFilter = defaultFilter,
32
- variant = "primary",
33
- listRef: listRefProp,
29
+ onMouseOver,
30
+ onBlur,
31
+ onFocus,
32
+ onKeyDown,
33
+ onSelect,
34
+ onListChange,
35
+ onChange: onInputChange,
34
36
  ...rest
35
37
  }, ref) {
36
38
  const targetWindow = useWindow();
@@ -43,10 +45,12 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
43
45
  const listRef = useRef(null);
44
46
  const setListRef = useForkRef(listRefProp, listRef);
45
47
  const listProps = {
48
+ disabled,
46
49
  highlightedItem: highlightedItemProp,
47
- selected,
50
+ selected: selectedProp,
48
51
  defaultSelected,
49
- onChange,
52
+ onChange: onListChange,
53
+ onSelect,
50
54
  id: listId,
51
55
  ref: listRef
52
56
  };
@@ -65,6 +69,8 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
65
69
  setHighlightedItem,
66
70
  mouseOverHandler
67
71
  } = useComboBox({
72
+ defaultInputValue,
73
+ inputValue: inputValueProp,
68
74
  onBlur,
69
75
  onFocus,
70
76
  onMouseOver,
@@ -78,19 +84,21 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
78
84
  floating,
79
85
  reference,
80
86
  getTriggerProps,
81
- getPortalProps
87
+ getPortalProps,
88
+ getPosition
82
89
  } = portalProps;
83
90
  const triggerRef = useForkRef(ref, reference);
84
91
  const inputRef = useForkRef(triggerRef, focusVisibleRef);
92
+ const { Component: FloatingComponent } = useFloatingComponent();
85
93
  const getFilteredSource = () => {
86
94
  if (!source)
87
95
  return null;
88
- if (selectedItem)
96
+ if (selectedItem && inputValue === selectedItem)
89
97
  return source;
90
98
  return itemFilter && itemFilter(source, inputValue);
91
99
  };
92
100
  const filteredSource = getFilteredSource();
93
- const onInputChange = (event) => {
101
+ const onChange = (event) => {
94
102
  const value = event.target.value;
95
103
  setInputValue(value);
96
104
  if (value === "") {
@@ -104,7 +112,7 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
104
112
  setHighlightedItem(filteredSource[0]);
105
113
  }
106
114
  }
107
- onChange == null ? void 0 : onChange(event, { value: inputValue || "" });
115
+ onInputChange == null ? void 0 : onInputChange(event, { value: inputValue || "" });
108
116
  };
109
117
  const adornment = open ? /* @__PURE__ */ jsx(ChevronUpIcon, {
110
118
  className: withBaseName("chevron")
@@ -112,7 +120,7 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
112
120
  className: withBaseName("chevron")
113
121
  });
114
122
  const { className: listClassName, ...restListProps } = ListProps;
115
- const { className: inputClassName, ...restInputProps } = InputProps2;
123
+ const { className: inputClassName, ...restInputProps } = rest;
116
124
  return /* @__PURE__ */ jsxs(Fragment, {
117
125
  children: [
118
126
  /* @__PURE__ */ jsx(Input, {
@@ -121,7 +129,7 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
121
129
  className: clsx(withBaseName("input"), inputClassName),
122
130
  disabled,
123
131
  endAdornment: adornment,
124
- onChange: onInputChange,
132
+ onChange,
125
133
  onBlur: blurHandler,
126
134
  inputRef,
127
135
  inputProps: {
@@ -136,32 +144,30 @@ const ComboBoxNext = forwardRef(function ComboBoxNext2({
136
144
  ...getTriggerProps(),
137
145
  ...restInputProps
138
146
  }),
139
- open && filteredSource && /* @__PURE__ */ jsx(FloatingPortal, {
140
- children: /* @__PURE__ */ jsx(SaltProvider, {
141
- children: /* @__PURE__ */ jsx("div", {
142
- ref: floating,
143
- ...getPortalProps(),
144
- children: /* @__PURE__ */ jsx(ListNext, {
145
- className: clsx(withBaseName("list"), listClassName),
146
- disableFocus: true,
147
- highlightedItem,
148
- onMouseOver: mouseOverHandler,
149
- selected: selectedItem,
150
- ...restListProps,
151
- ref: setListRef,
152
- children: filteredSource.map((value, index) => {
153
- const onMouseDown = (event) => {
154
- var _a, _b;
155
- setSelectedItem((_a = event.currentTarget) == null ? void 0 : _a.dataset.value);
156
- setInputValue((_b = event.currentTarget) == null ? void 0 : _b.dataset.value);
157
- };
158
- return /* @__PURE__ */ jsx(ListItem, {
159
- value,
160
- matchPattern: inputValue,
161
- onMouseDown
162
- }, index);
163
- })
164
- })
147
+ /* @__PURE__ */ jsx(FloatingComponent, {
148
+ open: Boolean(open && !disabled && filteredSource),
149
+ ref: floating,
150
+ ...getPortalProps(),
151
+ ...getPosition(),
152
+ children: /* @__PURE__ */ jsx(ListNext, {
153
+ className: clsx(withBaseName("list"), listClassName),
154
+ disableFocus: true,
155
+ highlightedItem,
156
+ onMouseOver: mouseOverHandler,
157
+ selected: selectedItem,
158
+ ...restListProps,
159
+ ref: setListRef,
160
+ children: filteredSource == null ? void 0 : filteredSource.map((value, index) => {
161
+ const onMouseDown = (event) => {
162
+ var _a, _b;
163
+ setSelectedItem((_a = event.currentTarget) == null ? void 0 : _a.dataset.value);
164
+ setInputValue((_b = event.currentTarget) == null ? void 0 : _b.dataset.value);
165
+ };
166
+ return ListItem && /* @__PURE__ */ jsx(ListItem, {
167
+ value,
168
+ matchPattern: inputValue,
169
+ onMouseDown
170
+ }, index);
165
171
  })
166
172
  })
167
173
  })
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxNext.js","sources":["../src/combo-box-next/ComboBoxNext.tsx"],"sourcesContent":["import {\n ChangeEvent,\n ComponentPropsWithoutRef,\n FocusEvent,\n ForwardedRef,\n forwardRef,\n KeyboardEvent,\n ReactElement,\n Ref,\n SyntheticEvent,\n useRef,\n} from \"react\";\nimport {\n Input,\n makePrefixer,\n SaltProvider,\n useForkRef,\n useId,\n InputProps,\n} from \"@salt-ds/core\";\nimport { ListNext, ListNextProps } from \"../list-next\";\nimport { FloatingPortal } from \"@floating-ui/react\";\nimport { useComboBox } from \"./useComboBox\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport comboBoxNextCss from \"./ComboBoxNext.css\";\nimport { ChevronDownIcon, ChevronUpIcon } from \"@salt-ds/icons\";\nimport { DefaultListItem, defaultFilter, ComboBoxItemProps } from \"./utils\";\nimport { clsx } from \"clsx\";\nimport { UseComboBoxPortalProps } from \"./useComboboxPortal\";\n\nconst withBaseName = makePrefixer(\"saltComboBoxNext\");\n\nexport interface ComboBoxNextProps<T>\n extends Omit<ComponentPropsWithoutRef<\"input\">, \"onChange\"> {\n /**\n * Additional props for the input component.\n */\n InputProps?: InputProps;\n /**\n * Additional props for the list component.\n */\n ListProps?: ListNextProps;\n /**\n * Additional props for the portal.\n */\n PortalProps?: UseComboBoxPortalProps;\n /**\n * If `true`, the component will be disabled.\n */\n disabled: boolean;\n /* Highlighted index for when the list is controlled. */\n highlightedItem?: string;\n /* Selected value for when the list is controlled. */\n selected?: string;\n /* Initial selected value for when the list is controlled. */\n defaultSelected?: string;\n /**\n * The source of combobox items.\n */\n source: T[];\n /**\n * Callback for blur event\n */\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n /**\n * Callback for focus event\n */\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n /**\n * Callback for keyDown event\n */\n onKeyDown?: (event: KeyboardEvent<HTMLInputElement>) => void;\n /**\n * Callback for mouse over event\n */\n onMouseOver?: (event: SyntheticEvent) => void;\n /**\n * Optional ref for the input component\n */\n inputRef?: Ref<HTMLInputElement>;\n /**\n * Optional ref for the list component\n */\n listRef?: Ref<HTMLUListElement>;\n /**\n * The component used for item instead of the default.\n */\n ListItem: (props: ComboBoxItemProps<T>) => ReactElement<ComboBoxItemProps<T>>;\n /**\n * Function to be used as filter.\n */\n itemFilter?: (source: T[], filterValue?: string) => T[];\n /* Callback for change event in input. */\n onChange?: (event: SyntheticEvent, data: { value: string }) => void;\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n}\n\nexport const ComboBoxNext = forwardRef(function ComboBoxNext<T>(\n {\n InputProps = {},\n ListProps = {},\n PortalProps = {},\n disabled,\n highlightedItem: highlightedItemProp,\n selected,\n defaultSelected,\n onKeyDown,\n onChange,\n onBlur,\n onFocus,\n onMouseOver,\n source,\n ListItem = DefaultListItem as unknown as ComboBoxNextProps<T>[\"ListItem\"],\n itemFilter = defaultFilter as unknown as ComboBoxNextProps<T>[\"itemFilter\"],\n variant = \"primary\",\n listRef: listRefProp,\n ...rest\n }: ComboBoxNextProps<T>,\n ref?: ForwardedRef<HTMLInputElement>\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-combo-box-next\",\n css: comboBoxNextCss,\n window: targetWindow,\n });\n const listId = useId(ListProps?.id);\n const listRef = useRef<HTMLUListElement>(null);\n\n const setListRef = useForkRef(listRefProp, listRef);\n const listProps = {\n highlightedItem: highlightedItemProp,\n selected,\n defaultSelected,\n onChange,\n id: listId,\n ref: listRef,\n };\n\n const {\n inputValue,\n setInputValue,\n portalProps,\n selectedItem,\n highlightedItem,\n activeDescendant,\n focusVisibleRef,\n keyDownHandler,\n focusHandler,\n blurHandler,\n setSelectedItem,\n setHighlightedItem,\n mouseOverHandler,\n } = useComboBox({\n onBlur,\n onFocus,\n onMouseOver,\n onKeyDown,\n listProps,\n PortalProps,\n });\n\n const {\n open,\n setOpen,\n floating,\n reference,\n getTriggerProps,\n getPortalProps,\n } = portalProps;\n\n // floating references\n const triggerRef = useForkRef(ref, reference);\n const inputRef = useForkRef(triggerRef, focusVisibleRef);\n\n const getFilteredSource = () => {\n if (!source) return null;\n if (selectedItem) return source;\n return itemFilter && itemFilter(source, inputValue);\n };\n const filteredSource = getFilteredSource();\n\n const onInputChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setInputValue(value);\n if (value === \"\") {\n setHighlightedItem(undefined);\n setSelectedItem(value);\n } else {\n if (!open) {\n setOpen(true);\n }\n if (filteredSource) {\n setHighlightedItem(filteredSource[0] as unknown as string);\n }\n }\n onChange?.(event, { value: inputValue || \"\" });\n };\n\n const adornment = open ? (\n <ChevronUpIcon className={withBaseName(\"chevron\")} />\n ) : (\n <ChevronDownIcon className={withBaseName(\"chevron\")} />\n );\n\n const { className: listClassName, ...restListProps } = ListProps;\n const { className: inputClassName, ...restInputProps } = InputProps;\n\n return (\n <>\n <Input\n aria-controls={listId}\n aria-activedescendant={disabled ? undefined : activeDescendant}\n className={clsx(withBaseName(\"input\"), inputClassName)}\n disabled={disabled}\n endAdornment={adornment}\n onChange={onInputChange}\n onBlur={blurHandler}\n inputRef={inputRef as Ref<HTMLInputElement>}\n inputProps={{\n \"aria-expanded\": open,\n tabIndex: disabled ? -1 : 0,\n onFocus: focusHandler,\n onKeyDown: keyDownHandler,\n }}\n role=\"combobox\"\n variant={variant}\n value={inputValue}\n {...getTriggerProps()}\n {...restInputProps}\n />\n {open && filteredSource && (\n <FloatingPortal>\n {/* The provider is needed to support the use case where an app has nested modes. The portal element needs to have the same style as the current scope */}\n <SaltProvider>\n <div ref={floating} {...getPortalProps()}>\n <ListNext\n className={clsx(withBaseName(\"list\"), listClassName)}\n disableFocus\n highlightedItem={highlightedItem}\n onMouseOver={mouseOverHandler}\n selected={selectedItem}\n {...restListProps}\n ref={setListRef}\n >\n {filteredSource.map((value, index) => {\n const onMouseDown = (\n event: SyntheticEvent<HTMLLIElement>\n ) => {\n setSelectedItem(event.currentTarget?.dataset.value);\n setInputValue(event.currentTarget?.dataset.value);\n };\n return (\n <ListItem\n key={index}\n value={value}\n matchPattern={inputValue}\n onMouseDown={onMouseDown}\n />\n );\n })}\n </ListNext>\n </div>\n </SaltProvider>\n </FloatingPortal>\n )}\n </>\n );\n});\n"],"names":["ComboBoxNext","InputProps","comboBoxNextCss"],"mappings":"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"}
1
+ {"version":3,"file":"ComboBoxNext.js","sources":["../src/combo-box-next/ComboBoxNext.tsx"],"sourcesContent":["import {\n ChangeEvent,\n ComponentPropsWithoutRef,\n ForwardedRef,\n forwardRef,\n ReactElement,\n Ref,\n SyntheticEvent,\n useRef,\n} from \"react\";\nimport {\n Input,\n makePrefixer,\n useForkRef,\n useId,\n useFloatingComponent,\n} from \"@salt-ds/core\";\nimport { ListNext, ListNextProps } from \"../list-next\";\nimport { useComboBox } from \"./useComboBox\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport comboBoxNextCss from \"./ComboBoxNext.css\";\nimport { ChevronDownIcon, ChevronUpIcon } from \"@salt-ds/icons\";\nimport { DefaultListItem, defaultFilter, ComboBoxItemProps } from \"./utils\";\nimport { clsx } from \"clsx\";\nimport { UseComboBoxPortalProps } from \"./useComboboxPortal\";\n\nconst withBaseName = makePrefixer(\"saltComboBoxNext\");\n\nexport interface ComboBoxNextProps<T>\n extends Omit<ComponentPropsWithoutRef<\"input\">, \"onChange\" | \"onSelect\"> {\n /**\n * Additional props for the list component.\n */\n ListProps?: ListNextProps;\n /**\n * Additional props for the portal.\n */\n PortalProps?: UseComboBoxPortalProps;\n /**\n * Controlled prop. Controls the Input value in the Combo Box Input.\n */\n inputValue?: string;\n /**\n * Controlled prop. Controls the Highlighted item in the Combo Box list.\n */\n highlightedItem?: string;\n /**\n * Controlled prop. Controls the Selected value in the Combo Box list.\n */\n selected?: string;\n /**\n * Initial input value for when the list is uncontrolled.\n */\n defaultInputValue?: string;\n /**\n * Initial selected value for when the list is uncontrolled.\n */\n defaultSelected?: string;\n /**\n * If `true`, the component will be disabled.\n */\n disabled?: boolean;\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n /**\n /**\n * The source of combobox items.\n */\n source: T[];\n /**\n * Optional ref for the list component\n */\n listRef?: Ref<HTMLUListElement>;\n /**\n * The component used for item instead of the default.\n */\n ListItem?: (\n props: ComboBoxItemProps<T>\n ) => ReactElement<ComboBoxItemProps<T>>;\n /**\n * Function to be used as filter.\n */\n itemFilter?: (source: T[], filterValue?: string) => T[];\n /**\n * Callback for mouse over event\n */\n onMouseOver?: (event: SyntheticEvent) => void;\n /**\n * Callback for list selection event\n */\n onSelect?: (event: SyntheticEvent, data: { value: string }) => void;\n /**\n /**\n * Callback for list change event\n */\n onListChange?: (\n event: SyntheticEvent,\n data: { value: string | undefined }\n ) => void;\n /**\n * Callback for input change event\n */\n onChange?: (event: SyntheticEvent, data: { value: string }) => void;\n}\n\nexport const ComboBoxNext = forwardRef(function ComboBoxNext<T>(\n {\n ListProps = {},\n PortalProps = {},\n inputValue: inputValueProp,\n highlightedItem: highlightedItemProp,\n selected: selectedProp,\n defaultInputValue,\n defaultSelected,\n disabled,\n variant = \"primary\",\n source,\n listRef: listRefProp,\n ListItem = DefaultListItem as unknown as ComboBoxNextProps<T>[\"ListItem\"],\n itemFilter = defaultFilter as unknown as ComboBoxNextProps<T>[\"itemFilter\"],\n onMouseOver,\n onBlur,\n onFocus,\n onKeyDown,\n onSelect,\n onListChange,\n onChange: onInputChange,\n ...rest\n }: ComboBoxNextProps<T>,\n ref?: ForwardedRef<HTMLInputElement>\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-combo-box-next\",\n css: comboBoxNextCss,\n window: targetWindow,\n });\n const listId = useId(ListProps?.id);\n const listRef = useRef<HTMLUListElement>(null);\n\n const setListRef = useForkRef(listRefProp, listRef);\n const listProps = {\n disabled,\n highlightedItem: highlightedItemProp,\n selected: selectedProp,\n defaultSelected,\n onChange: onListChange,\n onSelect: onSelect,\n id: listId,\n ref: listRef,\n };\n\n const {\n inputValue,\n setInputValue,\n portalProps,\n selectedItem,\n highlightedItem,\n activeDescendant,\n focusVisibleRef,\n keyDownHandler,\n focusHandler,\n blurHandler,\n setSelectedItem,\n setHighlightedItem,\n mouseOverHandler,\n } = useComboBox({\n defaultInputValue,\n inputValue: inputValueProp,\n onBlur,\n onFocus,\n onMouseOver,\n onKeyDown,\n listProps,\n PortalProps,\n });\n\n const {\n open,\n setOpen,\n floating,\n reference,\n getTriggerProps,\n getPortalProps,\n getPosition,\n } = portalProps;\n\n // floating references\n const triggerRef = useForkRef(ref, reference);\n const inputRef = useForkRef(triggerRef, focusVisibleRef);\n\n const { Component: FloatingComponent } = useFloatingComponent();\n\n const getFilteredSource = () => {\n if (!source) return null;\n if (selectedItem && inputValue === selectedItem) return source;\n return itemFilter && itemFilter(source, inputValue);\n };\n const filteredSource = getFilteredSource();\n\n const onChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setInputValue(value);\n if (value === \"\") {\n setHighlightedItem(undefined);\n setSelectedItem(value);\n } else {\n if (!open) {\n setOpen(true);\n }\n if (filteredSource) {\n setHighlightedItem(filteredSource[0] as unknown as string);\n }\n }\n onInputChange?.(event, { value: inputValue || \"\" });\n };\n\n const adornment = open ? (\n <ChevronUpIcon className={withBaseName(\"chevron\")} />\n ) : (\n <ChevronDownIcon className={withBaseName(\"chevron\")} />\n );\n\n const { className: listClassName, ...restListProps } = ListProps;\n const { className: inputClassName, ...restInputProps } = rest;\n\n return (\n <>\n <Input\n aria-controls={listId}\n aria-activedescendant={disabled ? undefined : activeDescendant}\n className={clsx(withBaseName(\"input\"), inputClassName)}\n disabled={disabled}\n endAdornment={adornment}\n onChange={onChange}\n onBlur={blurHandler}\n inputRef={inputRef as Ref<HTMLInputElement>}\n inputProps={{\n \"aria-expanded\": open,\n tabIndex: disabled ? -1 : 0,\n onFocus: focusHandler,\n onKeyDown: keyDownHandler,\n }}\n role=\"combobox\"\n variant={variant}\n value={inputValue}\n {...getTriggerProps()}\n {...restInputProps}\n />\n\n <FloatingComponent\n open={Boolean(open && !disabled && filteredSource)}\n ref={floating}\n {...getPortalProps()}\n {...getPosition()}\n >\n <ListNext\n className={clsx(withBaseName(\"list\"), listClassName)}\n disableFocus\n highlightedItem={highlightedItem}\n onMouseOver={mouseOverHandler}\n selected={selectedItem}\n {...restListProps}\n ref={setListRef}\n >\n {filteredSource?.map((value, index) => {\n const onMouseDown = (event: SyntheticEvent<HTMLLIElement>) => {\n setSelectedItem(event.currentTarget?.dataset.value);\n setInputValue(event.currentTarget?.dataset.value);\n };\n return (\n ListItem && (\n <ListItem\n key={index}\n value={value}\n matchPattern={inputValue}\n onMouseDown={onMouseDown}\n />\n )\n );\n })}\n </ListNext>\n </FloatingComponent>\n </>\n );\n});\n"],"names":["ComboBoxNext","comboBoxNextCss"],"mappings":"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"}
@@ -1,26 +1,32 @@
1
- import { useState } from 'react';
1
+ import { useEffect } from 'react';
2
2
  import { useList } from '../list-next/useList.js';
3
3
  import { useComboboxPortal } from './useComboboxPortal.js';
4
+ import { useControlled } from '@salt-ds/core';
4
5
 
5
6
  const useComboBox = ({
7
+ defaultInputValue,
6
8
  onFocus,
7
9
  onBlur,
8
10
  onMouseOver,
9
11
  onKeyDown,
12
+ inputValue: inputValueProp,
10
13
  PortalProps,
11
14
  listProps
12
15
  }) => {
13
- const { defaultSelected, ...restListProps } = listProps;
14
- const [inputValue, setInputValue] = useState(
15
- defaultSelected
16
- );
16
+ const [inputValue, setInputValue] = useControlled({
17
+ controlled: inputValueProp,
18
+ default: defaultInputValue,
19
+ name: "Combo Box",
20
+ state: "inputValue"
21
+ });
17
22
  const {
18
23
  open,
19
24
  setOpen,
20
25
  floating,
21
26
  reference,
22
27
  getPortalProps,
23
- getTriggerProps
28
+ getTriggerProps,
29
+ getPosition
24
30
  } = useComboboxPortal(PortalProps);
25
31
  const {
26
32
  keyDownHandler: listKeyDownHandler,
@@ -32,8 +38,15 @@ const useComboBox = ({
32
38
  setHighlightedItem,
33
39
  highlightedItem
34
40
  } = useList({
35
- ...restListProps
41
+ ...listProps
36
42
  });
43
+ const setSelected = (value) => {
44
+ setSelectedItem(value);
45
+ setInputValue(value);
46
+ };
47
+ useEffect(() => {
48
+ setInputValue(selectedItem);
49
+ }, [selectedItem]);
37
50
  const focusHandler = (event) => {
38
51
  setOpen(true);
39
52
  listFocusHandler(event);
@@ -42,8 +55,7 @@ const useComboBox = ({
42
55
  const blurHandler = (event) => {
43
56
  setOpen(false);
44
57
  if (!selectedItem) {
45
- setSelectedItem(void 0);
46
- setInputValue(void 0);
58
+ setSelected(void 0);
47
59
  setHighlightedItem(void 0);
48
60
  }
49
61
  onBlur == null ? void 0 : onBlur(event);
@@ -60,8 +72,7 @@ const useComboBox = ({
60
72
  if (altKey) {
61
73
  event.preventDefault();
62
74
  if (open && !selectedItem) {
63
- setSelectedItem(void 0);
64
- setInputValue(void 0);
75
+ setSelected(void 0);
65
76
  }
66
77
  setOpen(!open);
67
78
  break;
@@ -83,8 +94,7 @@ const useComboBox = ({
83
94
  if (!open) {
84
95
  setOpen(true);
85
96
  } else {
86
- setSelectedItem(highlightedItem);
87
- setInputValue(highlightedItem);
97
+ setSelected(highlightedItem);
88
98
  setOpen(false);
89
99
  }
90
100
  break;
@@ -92,8 +102,7 @@ const useComboBox = ({
92
102
  if (open) {
93
103
  setOpen(false);
94
104
  if (!selectedItem) {
95
- setSelectedItem(void 0);
96
- setInputValue(void 0);
105
+ setSelected(void 0);
97
106
  }
98
107
  }
99
108
  break;
@@ -106,16 +115,17 @@ const useComboBox = ({
106
115
  onKeyDown == null ? void 0 : onKeyDown(event);
107
116
  };
108
117
  return {
118
+ inputValue,
119
+ setInputValue,
109
120
  portalProps: {
110
121
  open,
111
122
  setOpen,
112
123
  floating,
113
124
  reference,
114
125
  getTriggerProps,
115
- getPortalProps
126
+ getPortalProps,
127
+ getPosition
116
128
  },
117
- inputValue,
118
- setInputValue,
119
129
  selectedItem,
120
130
  setSelectedItem,
121
131
  highlightedItem,
@@ -1 +1 @@
1
- {"version":3,"file":"useComboBox.js","sources":["../src/combo-box-next/useComboBox.tsx"],"sourcesContent":["import { FocusEvent, KeyboardEvent, SyntheticEvent, useState } from \"react\";\nimport { useList, UseListProps } from \"../list-next/useList\";\nimport { useComboboxPortal, UseComboBoxPortalProps } from \"./useComboboxPortal\";\n\ninterface UseComboBoxProps {\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n onMouseOver?: (event: SyntheticEvent) => void;\n onKeyDown?: (event: KeyboardEvent<HTMLInputElement>) => void;\n PortalProps?: UseComboBoxPortalProps;\n listProps: UseListProps;\n}\n\nexport const useComboBox = ({\n onFocus,\n onBlur,\n onMouseOver,\n onKeyDown,\n PortalProps,\n listProps,\n}: UseComboBoxProps) => {\n const { defaultSelected, ...restListProps } = listProps;\n const [inputValue, setInputValue] = useState<string | undefined>(\n defaultSelected\n );\n\n const {\n open,\n setOpen,\n floating,\n reference,\n getPortalProps,\n getTriggerProps,\n } = useComboboxPortal(PortalProps);\n\n const {\n keyDownHandler: listKeyDownHandler,\n focusHandler: listFocusHandler,\n activeDescendant,\n focusVisibleRef,\n selectedItem,\n setSelectedItem,\n setHighlightedItem,\n highlightedItem,\n } = useList({\n ...restListProps,\n });\n\n const focusHandler = (event: FocusEvent<HTMLInputElement>) => {\n setOpen(true);\n listFocusHandler(event);\n onFocus?.(event);\n };\n\n const blurHandler = (event: FocusEvent<HTMLInputElement>) => {\n setOpen(false);\n if (!selectedItem) {\n setSelectedItem(undefined);\n setInputValue(undefined);\n setHighlightedItem(undefined);\n }\n onBlur?.(event);\n };\n\n const mouseOverHandler = (event: SyntheticEvent<HTMLElement>) => {\n setHighlightedItem(event.currentTarget.dataset.value);\n onMouseOver?.(event);\n };\n\n const keyDownHandler = (event: KeyboardEvent<HTMLInputElement>) => {\n const { key, altKey } = event;\n switch (key) {\n case \"ArrowDown\":\n case \"ArrowUp\":\n if (altKey) {\n event.preventDefault();\n if (open && !selectedItem) {\n setSelectedItem(undefined);\n setInputValue(undefined);\n }\n setOpen(!open);\n break;\n }\n if (!open) {\n setOpen(true);\n }\n listKeyDownHandler(event);\n break;\n case \"PageDown\":\n case \"PageUp\":\n case \"Home\":\n case \"End\":\n if (open) {\n listKeyDownHandler(event);\n }\n break;\n case \"Enter\":\n if (!open) {\n setOpen(true);\n } else {\n setSelectedItem(highlightedItem);\n setInputValue(highlightedItem);\n setOpen(false);\n }\n break;\n case \"Escape\":\n if (open) {\n setOpen(false);\n if (!selectedItem) {\n setSelectedItem(undefined);\n setInputValue(undefined);\n }\n }\n break;\n case \"Backspace\":\n if (!open) {\n setOpen(true);\n }\n break;\n default:\n break;\n }\n onKeyDown?.(event);\n };\n\n return {\n // portal\n portalProps: {\n open,\n setOpen,\n floating,\n reference,\n getTriggerProps,\n getPortalProps,\n },\n // list\n inputValue,\n setInputValue,\n selectedItem,\n setSelectedItem,\n highlightedItem,\n setHighlightedItem,\n activeDescendant,\n focusVisibleRef,\n keyDownHandler,\n focusHandler,\n blurHandler,\n mouseOverHandler,\n };\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useComboBox.js","sources":["../src/combo-box-next/useComboBox.tsx"],"sourcesContent":["import { FocusEvent, KeyboardEvent, SyntheticEvent, useEffect } from \"react\";\nimport { useList, UseListProps } from \"../list-next/useList\";\nimport { useComboboxPortal, UseComboBoxPortalProps } from \"./useComboboxPortal\";\nimport { useControlled } from \"@salt-ds/core\";\n\ninterface UseComboBoxProps {\n inputValue?: string;\n defaultInputValue?: string;\n onBlur?: (event: FocusEvent<HTMLInputElement>) => void;\n onFocus?: (event: FocusEvent<HTMLInputElement>) => void;\n onMouseOver?: (event: SyntheticEvent) => void;\n onKeyDown?: (event: KeyboardEvent<HTMLInputElement>) => void;\n PortalProps?: UseComboBoxPortalProps;\n listProps: UseListProps;\n}\n\nexport const useComboBox = ({\n defaultInputValue,\n onFocus,\n onBlur,\n onMouseOver,\n onKeyDown,\n inputValue: inputValueProp,\n PortalProps,\n listProps,\n}: UseComboBoxProps) => {\n const [inputValue, setInputValue] = useControlled({\n controlled: inputValueProp,\n default: defaultInputValue,\n name: \"Combo Box\",\n state: \"inputValue\",\n });\n\n const {\n open,\n setOpen,\n floating,\n reference,\n getPortalProps,\n getTriggerProps,\n getPosition,\n } = useComboboxPortal(PortalProps);\n\n const {\n keyDownHandler: listKeyDownHandler,\n focusHandler: listFocusHandler,\n activeDescendant,\n focusVisibleRef,\n selectedItem,\n setSelectedItem,\n setHighlightedItem,\n highlightedItem,\n } = useList({\n ...listProps,\n });\n\n const setSelected = (value: string | undefined) => {\n setSelectedItem(value);\n setInputValue(value);\n };\n\n useEffect(() => {\n setInputValue(selectedItem);\n }, [selectedItem]);\n\n const focusHandler = (event: FocusEvent<HTMLInputElement>) => {\n setOpen(true);\n listFocusHandler(event);\n onFocus?.(event);\n };\n\n const blurHandler = (event: FocusEvent<HTMLInputElement>) => {\n setOpen(false);\n if (!selectedItem) {\n setSelected(undefined);\n setHighlightedItem(undefined);\n }\n onBlur?.(event);\n };\n\n const mouseOverHandler = (event: SyntheticEvent<HTMLElement>) => {\n setHighlightedItem(event.currentTarget.dataset.value);\n onMouseOver?.(event);\n };\n\n const keyDownHandler = (event: KeyboardEvent<HTMLInputElement>) => {\n const { key, altKey } = event;\n switch (key) {\n case \"ArrowDown\":\n case \"ArrowUp\":\n if (altKey) {\n event.preventDefault();\n if (open && !selectedItem) {\n setSelected(undefined);\n }\n setOpen(!open);\n break;\n }\n if (!open) {\n setOpen(true);\n }\n listKeyDownHandler(event);\n break;\n case \"PageDown\":\n case \"PageUp\":\n case \"Home\":\n case \"End\":\n if (open) {\n listKeyDownHandler(event);\n }\n break;\n case \"Enter\":\n if (!open) {\n setOpen(true);\n } else {\n setSelected(highlightedItem);\n setOpen(false);\n }\n break;\n case \"Escape\":\n if (open) {\n setOpen(false);\n if (!selectedItem) {\n setSelected(undefined);\n }\n }\n break;\n case \"Backspace\":\n if (!open) {\n setOpen(true);\n }\n break;\n default:\n break;\n }\n onKeyDown?.(event);\n };\n\n return {\n inputValue,\n setInputValue,\n // portal\n portalProps: {\n open,\n setOpen,\n floating,\n reference,\n getTriggerProps,\n getPortalProps,\n getPosition,\n },\n // list\n selectedItem,\n setSelectedItem,\n highlightedItem,\n setHighlightedItem,\n activeDescendant,\n focusVisibleRef,\n keyDownHandler,\n focusHandler,\n blurHandler,\n mouseOverHandler,\n };\n};\n"],"names":[],"mappings":"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"}
@@ -17,15 +17,15 @@ function useComboboxPortal(props) {
17
17
  setOpen(open2);
18
18
  onOpenChangeProp == null ? void 0 : onOpenChangeProp(open2);
19
19
  };
20
- const { floating, reference, x, y, strategy, context } = useFloatingUI({
20
+ const { floating, reference, x, y, strategy, context, elements } = useFloatingUI({
21
21
  open,
22
22
  onOpenChange,
23
23
  placement: placementProp,
24
24
  middleware: [
25
25
  offset(0),
26
26
  size({
27
- apply({ rects, elements }) {
28
- Object.assign(elements.floating.style, {
27
+ apply({ rects, elements: elements2 }) {
28
+ Object.assign(elements2.floating.style, {
29
29
  width: `${rects.reference.width}px`
30
30
  });
31
31
  }
@@ -40,24 +40,30 @@ function useComboboxPortal(props) {
40
40
  ]);
41
41
  const getPortalProps = () => {
42
42
  return getFloatingProps({
43
- ref: floating,
44
- style: {
45
- top: y != null ? y : 0,
46
- left: x != null ? x : 0,
47
- position: strategy
48
- }
43
+ ref: floating
49
44
  });
50
45
  };
51
46
  const getTriggerProps = () => getReferenceProps({
52
47
  ref: reference
53
48
  });
49
+ const getPosition = () => {
50
+ var _a, _b;
51
+ return {
52
+ top: y != null ? y : 0,
53
+ left: x != null ? x : 0,
54
+ position: strategy,
55
+ width: (_a = elements.floating) == null ? void 0 : _a.clientWidth,
56
+ height: (_b = elements.floating) == null ? void 0 : _b.clientHeight
57
+ };
58
+ };
54
59
  return {
55
60
  open,
56
61
  setOpen,
57
62
  floating,
58
63
  reference,
59
64
  getPortalProps,
60
- getTriggerProps
65
+ getTriggerProps,
66
+ getPosition
61
67
  };
62
68
  }
63
69
 
@@ -1 +1 @@
1
- {"version":3,"file":"useComboboxPortal.js","sources":["../src/combo-box-next/useComboboxPortal.ts"],"sourcesContent":["import {\n flip,\n limitShift,\n offset,\n Placement,\n shift,\n size,\n useDismiss,\n useInteractions,\n useRole,\n} from \"@floating-ui/react\";\nimport { HTMLProps } from \"react\";\nimport { useControlled, useFloatingUI } from \"@salt-ds/core\";\n\nexport interface UseComboBoxPortalProps {\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n placement?: Placement;\n}\n\nexport function useComboboxPortal(props?: UseComboBoxPortalProps) {\n const {\n open: openProp,\n onOpenChange: onOpenChangeProp,\n placement: placementProp = \"bottom\",\n } = props || {};\n const [open, setOpen] = useControlled({\n controlled: openProp,\n default: false,\n name: \"Combo Box\",\n state: \"open\",\n });\n\n const onOpenChange = (open: boolean) => {\n setOpen(open);\n onOpenChangeProp?.(open);\n };\n\n const { floating, reference, x, y, strategy, context } = useFloatingUI({\n open,\n onOpenChange: onOpenChange,\n placement: placementProp,\n middleware: [\n offset(0),\n size({\n apply({ rects, elements }) {\n Object.assign(elements.floating.style, {\n width: `${rects.reference.width}px`,\n });\n },\n }),\n flip(),\n shift({ limiter: limitShift() }),\n ],\n });\n\n const { getReferenceProps, getFloatingProps } = useInteractions([\n useRole(context, { role: \"listbox\" }),\n useDismiss(context),\n ]);\n\n const getPortalProps = (): HTMLProps<HTMLDivElement> => {\n return getFloatingProps({\n ref: floating,\n style: {\n top: y ?? 0,\n left: x ?? 0,\n position: strategy,\n },\n });\n };\n\n const getTriggerProps = () =>\n getReferenceProps({\n ref: reference,\n });\n\n return {\n open,\n setOpen,\n floating,\n reference,\n getPortalProps,\n getTriggerProps,\n };\n}\n"],"names":["open"],"mappings":";;;AAoBO,SAAS,kBAAkB,KAAgC,EAAA;AAChE,EAAM,MAAA;AAAA,IACJ,IAAM,EAAA,QAAA;AAAA,IACN,YAAc,EAAA,gBAAA;AAAA,IACd,WAAW,aAAgB,GAAA,QAAA;AAAA,GAC7B,GAAI,SAAS,EAAC,CAAA;AACd,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAI,aAAc,CAAA;AAAA,IACpC,UAAY,EAAA,QAAA;AAAA,IACZ,OAAS,EAAA,KAAA;AAAA,IACT,IAAM,EAAA,WAAA;AAAA,IACN,KAAO,EAAA,MAAA;AAAA,GACR,CAAA,CAAA;AAED,EAAM,MAAA,YAAA,GAAe,CAACA,KAAkB,KAAA;AACtC,IAAA,OAAA,CAAQA,KAAI,CAAA,CAAA;AACZ,IAAmBA,gBAAAA,IAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,gBAAAA,CAAAA,KAAAA,CAAAA,CAAAA;AAAA,GACrB,CAAA;AAEA,EAAM,MAAA,EAAE,UAAU,SAAW,EAAA,CAAA,EAAG,GAAG,QAAU,EAAA,OAAA,KAAY,aAAc,CAAA;AAAA,IACrE,IAAA;AAAA,IACA,YAAA;AAAA,IACA,SAAW,EAAA,aAAA;AAAA,IACX,UAAY,EAAA;AAAA,MACV,OAAO,CAAC,CAAA;AAAA,MACR,IAAK,CAAA;AAAA,QACH,KAAM,CAAA,EAAE,KAAO,EAAA,QAAA,EAAY,EAAA;AACzB,UAAO,MAAA,CAAA,MAAA,CAAO,QAAS,CAAA,QAAA,CAAS,KAAO,EAAA;AAAA,YACrC,KAAA,EAAO,CAAG,EAAA,KAAA,CAAM,SAAU,CAAA,KAAA,CAAA,EAAA,CAAA;AAAA,WAC3B,CAAA,CAAA;AAAA,SACH;AAAA,OACD,CAAA;AAAA,MACD,IAAK,EAAA;AAAA,MACL,KAAM,CAAA,EAAE,OAAS,EAAA,UAAA,IAAc,CAAA;AAAA,KACjC;AAAA,GACD,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,iBAAA,EAAmB,gBAAiB,EAAA,GAAI,eAAgB,CAAA;AAAA,IAC9D,OAAQ,CAAA,OAAA,EAAS,EAAE,IAAA,EAAM,WAAW,CAAA;AAAA,IACpC,WAAW,OAAO,CAAA;AAAA,GACnB,CAAA,CAAA;AAED,EAAA,MAAM,iBAAiB,MAAiC;AACtD,IAAA,OAAO,gBAAiB,CAAA;AAAA,MACtB,GAAK,EAAA,QAAA;AAAA,MACL,KAAO,EAAA;AAAA,QACL,KAAK,CAAK,IAAA,IAAA,GAAA,CAAA,GAAA,CAAA;AAAA,QACV,MAAM,CAAK,IAAA,IAAA,GAAA,CAAA,GAAA,CAAA;AAAA,QACX,QAAU,EAAA,QAAA;AAAA,OACZ;AAAA,KACD,CAAA,CAAA;AAAA,GACH,CAAA;AAEA,EAAM,MAAA,eAAA,GAAkB,MACtB,iBAAkB,CAAA;AAAA,IAChB,GAAK,EAAA,SAAA;AAAA,GACN,CAAA,CAAA;AAEH,EAAO,OAAA;AAAA,IACL,IAAA;AAAA,IACA,OAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,cAAA;AAAA,IACA,eAAA;AAAA,GACF,CAAA;AACF;;;;"}
1
+ {"version":3,"file":"useComboboxPortal.js","sources":["../src/combo-box-next/useComboboxPortal.ts"],"sourcesContent":["import {\n flip,\n limitShift,\n offset,\n Placement,\n shift,\n size,\n useDismiss,\n useInteractions,\n useRole,\n} from \"@floating-ui/react\";\nimport { HTMLProps } from \"react\";\nimport { useControlled, useFloatingUI } from \"@salt-ds/core\";\n\nexport interface UseComboBoxPortalProps {\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n placement?: Placement;\n}\n\nexport function useComboboxPortal(props?: UseComboBoxPortalProps) {\n const {\n open: openProp,\n onOpenChange: onOpenChangeProp,\n placement: placementProp = \"bottom\",\n } = props || {};\n const [open, setOpen] = useControlled({\n controlled: openProp,\n default: false,\n name: \"Combo Box\",\n state: \"open\",\n });\n\n const onOpenChange = (open: boolean) => {\n setOpen(open);\n onOpenChangeProp?.(open);\n };\n\n const { floating, reference, x, y, strategy, context, elements } =\n useFloatingUI({\n open,\n onOpenChange: onOpenChange,\n placement: placementProp,\n middleware: [\n offset(0),\n size({\n apply({ rects, elements }) {\n Object.assign(elements.floating.style, {\n width: `${rects.reference.width}px`,\n });\n },\n }),\n flip(),\n shift({ limiter: limitShift() }),\n ],\n });\n\n const { getReferenceProps, getFloatingProps } = useInteractions([\n useRole(context, { role: \"listbox\" }),\n useDismiss(context),\n ]);\n\n const getPortalProps = (): HTMLProps<HTMLDivElement> => {\n return getFloatingProps({\n ref: floating,\n });\n };\n\n const getTriggerProps = () =>\n getReferenceProps({\n ref: reference,\n });\n\n const getPosition = () => ({\n top: y ?? 0,\n left: x ?? 0,\n position: strategy,\n width: elements.floating?.clientWidth,\n height: elements.floating?.clientHeight,\n });\n\n return {\n open,\n setOpen,\n floating,\n reference,\n getPortalProps,\n getTriggerProps,\n getPosition,\n };\n}\n"],"names":["open","elements"],"mappings":"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"}
@@ -4,7 +4,7 @@ import { ListItemNext } from '../list-next/ListItemNext.js';
4
4
  import { Highlighter } from '../list/Highlighter.js';
5
5
  import '../list/ListItem.js';
6
6
  import '../list/List.js';
7
- import 'react';
7
+ import { forwardRef } from 'react';
8
8
  import '@salt-ds/core';
9
9
  import '../common-hooks/collectionProvider.js';
10
10
  import '../common-hooks/keyUtils.js';
@@ -14,12 +14,12 @@ import '../list/VirtualizedList.js';
14
14
  const defaultFilter = (source, filterValue) => source.filter(
15
15
  (item) => !filterValue ? item : item.toLowerCase().includes(filterValue.toLowerCase())
16
16
  );
17
- const DefaultListItem = ({
17
+ const DefaultListItem = forwardRef(function DefaultListItem2({
18
18
  value,
19
19
  matchPattern,
20
20
  onMouseDown,
21
21
  ...rest
22
- }) => {
22
+ }) {
23
23
  return /* @__PURE__ */ jsx(ListItemNext, {
24
24
  value,
25
25
  onMouseDown,
@@ -29,7 +29,7 @@ const DefaultListItem = ({
29
29
  text: value
30
30
  })
31
31
  });
32
- };
32
+ });
33
33
 
34
34
  export { DefaultListItem, defaultFilter };
35
35
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../src/combo-box-next/utils.tsx"],"sourcesContent":["import { ListItemNext, ListItemNextProps } from \"../list-next\";\nimport { Highlighter } from \"../list\";\n\nexport const defaultFilter = (source: string[], filterValue?: string) =>\n source.filter((item: string) =>\n !filterValue ? item : item.toLowerCase().includes(filterValue.toLowerCase())\n );\n\nexport interface ComboBoxItemProps<T> extends Omit<ListItemNextProps, \"value\"> {\n value: T;\n matchPattern?: RegExp | string;\n}\n\nexport const DefaultListItem = ({\n value,\n matchPattern,\n onMouseDown,\n ...rest\n}: ComboBoxItemProps<string>) => {\n return (\n <ListItemNext value={value} onMouseDown={onMouseDown} {...rest}>\n <Highlighter matchPattern={matchPattern} text={value} />\n </ListItemNext>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;AAGO,MAAM,aAAgB,GAAA,CAAC,MAAkB,EAAA,WAAA,KAC9C,MAAO,CAAA,MAAA;AAAA,EAAO,CAAC,IACb,KAAA,CAAC,WAAc,GAAA,IAAA,GAAO,IAAK,CAAA,WAAA,EAAc,CAAA,QAAA,CAAS,WAAY,CAAA,WAAA,EAAa,CAAA;AAC7E,EAAA;AAOK,MAAM,kBAAkB,CAAC;AAAA,EAC9B,KAAA;AAAA,EACA,YAAA;AAAA,EACA,WAAA;AAAA,EACG,GAAA,IAAA;AACL,CAAiC,KAAA;AAC/B,EAAA,uBACG,GAAA,CAAA,YAAA,EAAA;AAAA,IAAa,KAAA;AAAA,IAAc,WAAA;AAAA,IAA2B,GAAG,IAAA;AAAA,IACxD,QAAC,kBAAA,GAAA,CAAA,WAAA,EAAA;AAAA,MAAY,YAAA;AAAA,MAA4B,IAAM,EAAA,KAAA;AAAA,KAAO,CAAA;AAAA,GACxD,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"utils.js","sources":["../src/combo-box-next/utils.tsx"],"sourcesContent":["import { ListItemNext, ListItemNextProps } from \"../list-next\";\nimport { Highlighter } from \"../list\";\nimport { forwardRef } from \"react\";\n\nexport const defaultFilter = (source: string[], filterValue?: string) =>\n source.filter((item: string) =>\n !filterValue ? item : item.toLowerCase().includes(filterValue.toLowerCase())\n );\n\nexport interface ComboBoxItemProps<T> extends Omit<ListItemNextProps, \"value\"> {\n value: T;\n matchPattern?: RegExp | string;\n}\nexport const DefaultListItem = forwardRef(function DefaultListItem({\n value,\n matchPattern,\n onMouseDown,\n ...rest\n}: ComboBoxItemProps<string>) {\n return (\n <ListItemNext value={value} onMouseDown={onMouseDown} {...rest}>\n <Highlighter matchPattern={matchPattern} text={value} />\n </ListItemNext>\n );\n});\n"],"names":["DefaultListItem"],"mappings":";;;;;;;;;;;;;AAIO,MAAM,aAAgB,GAAA,CAAC,MAAkB,EAAA,WAAA,KAC9C,MAAO,CAAA,MAAA;AAAA,EAAO,CAAC,IACb,KAAA,CAAC,WAAc,GAAA,IAAA,GAAO,IAAK,CAAA,WAAA,EAAc,CAAA,QAAA,CAAS,WAAY,CAAA,WAAA,EAAa,CAAA;AAC7E,EAAA;AAMW,MAAA,eAAA,GAAkB,UAAW,CAAA,SAASA,gBAAgB,CAAA;AAAA,EACjE,KAAA;AAAA,EACA,YAAA;AAAA,EACA,WAAA;AAAA,EACG,GAAA,IAAA;AACL,CAA8B,EAAA;AAC5B,EAAA,uBACG,GAAA,CAAA,YAAA,EAAA;AAAA,IAAa,KAAA;AAAA,IAAc,WAAA;AAAA,IAA2B,GAAG,IAAA;AAAA,IACxD,QAAC,kBAAA,GAAA,CAAA,WAAA,EAAA;AAAA,MAAY,YAAA;AAAA,MAA4B,IAAM,EAAA,KAAA;AAAA,KAAO,CAAA;AAAA,GACxD,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -14,6 +14,7 @@ const ContactMetadataItem = forwardRef(function ContactMetadataItem2(props, ref)
14
14
  !Icon ? /* @__PURE__ */ jsx(Text, {
15
15
  maxRows: 1,
16
16
  className: withBaseName("label"),
17
+ variant: "secondary",
17
18
  children: label
18
19
  }) : null,
19
20
  Icon ? /* @__PURE__ */ jsx(Icon, {
@@ -1 +1 @@
1
- {"version":3,"file":"ContactMetadataItem.js","sources":["../src/contact-details/ContactMetadataItem.tsx"],"sourcesContent":["import { makePrefixer, Text } from \"@salt-ds/core\";\nimport { IconProps } from \"@salt-ds/icons\";\nimport { ComponentType, forwardRef, HTMLAttributes } from \"react\";\nimport { MailLinkComponent } from \"./MailLinkComponent\";\nimport { ValueComponentProps } from \"./types\";\n\nconst withBaseName = makePrefixer(\"saltContactMetadataItem\");\n\nexport interface ContactMetadataItemProps\n extends HTMLAttributes<HTMLDivElement> {\n label?: string;\n value: string;\n icon?: ComponentType<IconProps>;\n ValueComponent?: ComponentType<ValueComponentProps>;\n}\n\nexport const ContactMetadataItem = forwardRef<\n HTMLDivElement,\n ContactMetadataItemProps\n>(function ContactMetadataItem(props, ref) {\n const { label, value, icon: Icon, ValueComponent, ...restProps } = props;\n return (\n <div {...restProps} ref={ref} className={withBaseName()}>\n {!Icon ? (\n <Text maxRows={1} className={withBaseName(\"label\")}>\n {label}\n </Text>\n ) : null}\n {Icon ? <Icon className={withBaseName(\"icon\")} /> : null}\n\n {ValueComponent ? (\n <ValueComponent value={value} />\n ) : (\n <MailLinkComponent value={value} />\n )}\n </div>\n );\n});\n"],"names":["ContactMetadataItem"],"mappings":";;;;;AAMA,MAAM,YAAA,GAAe,aAAa,yBAAyB,CAAA,CAAA;AAUpD,MAAM,mBAAsB,GAAA,UAAA,CAGjC,SAASA,oBAAAA,CAAoB,OAAO,GAAK,EAAA;AACzC,EAAA,MAAM,EAAE,KAAO,EAAA,KAAA,EAAO,MAAM,IAAM,EAAA,cAAA,EAAA,GAAmB,WAAc,GAAA,KAAA,CAAA;AACnE,EAAA,uBACG,IAAA,CAAA,KAAA,EAAA;AAAA,IAAK,GAAG,SAAA;AAAA,IAAW,GAAA;AAAA,IAAU,WAAW,YAAa,EAAA;AAAA,IACnD,QAAA,EAAA;AAAA,MAAA,CAAC,uBACC,GAAA,CAAA,IAAA,EAAA;AAAA,QAAK,OAAS,EAAA,CAAA;AAAA,QAAG,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,QAC9C,QAAA,EAAA,KAAA;AAAA,OACH,CACE,GAAA,IAAA;AAAA,MACH,uBAAQ,GAAA,CAAA,IAAA,EAAA;AAAA,QAAK,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,OAAG,CAAK,GAAA,IAAA;AAAA,MAEnD,iCACE,GAAA,CAAA,cAAA,EAAA;AAAA,QAAe,KAAA;AAAA,OAAc,oBAE7B,GAAA,CAAA,iBAAA,EAAA;AAAA,QAAkB,KAAA;AAAA,OAAc,CAAA;AAAA,KAAA;AAAA,GAErC,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"ContactMetadataItem.js","sources":["../src/contact-details/ContactMetadataItem.tsx"],"sourcesContent":["import { makePrefixer, Text } from \"@salt-ds/core\";\nimport { IconProps } from \"@salt-ds/icons\";\nimport { ComponentType, forwardRef, HTMLAttributes } from \"react\";\nimport { MailLinkComponent } from \"./MailLinkComponent\";\nimport { ValueComponentProps } from \"./types\";\n\nconst withBaseName = makePrefixer(\"saltContactMetadataItem\");\n\nexport interface ContactMetadataItemProps\n extends HTMLAttributes<HTMLDivElement> {\n label?: string;\n value: string;\n icon?: ComponentType<IconProps>;\n ValueComponent?: ComponentType<ValueComponentProps>;\n}\n\nexport const ContactMetadataItem = forwardRef<\n HTMLDivElement,\n ContactMetadataItemProps\n>(function ContactMetadataItem(props, ref) {\n const { label, value, icon: Icon, ValueComponent, ...restProps } = props;\n return (\n <div {...restProps} ref={ref} className={withBaseName()}>\n {!Icon ? (\n <Text maxRows={1} className={withBaseName(\"label\")} variant=\"secondary\">\n {label}\n </Text>\n ) : null}\n {Icon ? <Icon className={withBaseName(\"icon\")} /> : null}\n\n {ValueComponent ? (\n <ValueComponent value={value} />\n ) : (\n <MailLinkComponent value={value} />\n )}\n </div>\n );\n});\n"],"names":["ContactMetadataItem"],"mappings":";;;;;AAMA,MAAM,YAAA,GAAe,aAAa,yBAAyB,CAAA,CAAA;AAUpD,MAAM,mBAAsB,GAAA,UAAA,CAGjC,SAASA,oBAAAA,CAAoB,OAAO,GAAK,EAAA;AACzC,EAAA,MAAM,EAAE,KAAO,EAAA,KAAA,EAAO,MAAM,IAAM,EAAA,cAAA,EAAA,GAAmB,WAAc,GAAA,KAAA,CAAA;AACnE,EAAA,uBACG,IAAA,CAAA,KAAA,EAAA;AAAA,IAAK,GAAG,SAAA;AAAA,IAAW,GAAA;AAAA,IAAU,WAAW,YAAa,EAAA;AAAA,IACnD,QAAA,EAAA;AAAA,MAAA,CAAC,uBACC,GAAA,CAAA,IAAA,EAAA;AAAA,QAAK,OAAS,EAAA,CAAA;AAAA,QAAG,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,QAAG,OAAQ,EAAA,WAAA;AAAA,QACzD,QAAA,EAAA,KAAA;AAAA,OACH,CACE,GAAA,IAAA;AAAA,MACH,uBAAQ,GAAA,CAAA,IAAA,EAAA;AAAA,QAAK,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,OAAG,CAAK,GAAA,IAAA;AAAA,MAEnD,iCACE,GAAA,CAAA,cAAA,EAAA;AAAA,QAAe,KAAA;AAAA,OAAc,oBAE7B,GAAA,CAAA,iBAAA,EAAA;AAAA,QAAkB,KAAA;AAAA,OAAc,CAAA;AAAA,KAAA;AAAA,GAErC,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -2,7 +2,7 @@ import { jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef, useState, useEffect, useMemo } from 'react';
3
3
  import { clsx } from 'clsx';
4
4
  import { FloatingPortal, FloatingOverlay, FloatingFocusManager } from '@floating-ui/react';
5
- import { makePrefixer, useId, useForkRef } from '@salt-ds/core';
5
+ import { makePrefixer, useId, useForkRef, SaltProvider } from '@salt-ds/core';
6
6
  import { useWindow } from '@salt-ds/window';
7
7
  import { useComponentCssInjection } from '@salt-ds/styles';
8
8
  import { useDialog } from './useDialog.js';
@@ -43,39 +43,41 @@ const Dialog = forwardRef(function Dialog2(props, ref) {
43
43
  [dialogId, status]
44
44
  );
45
45
  return /* @__PURE__ */ jsx(FloatingPortal, {
46
- children: showComponent && /* @__PURE__ */ jsx(FloatingOverlay, {
47
- className: withBaseName("overlay"),
48
- lockScroll: true,
49
- children: /* @__PURE__ */ jsx(FloatingFocusManager, {
50
- context,
51
- modal: true,
52
- initialFocus,
53
- children: /* @__PURE__ */ jsx(DialogContext.Provider, {
54
- value: contextValue,
55
- children: /* @__PURE__ */ jsx("div", {
56
- id: dialogId,
57
- className: clsx(
58
- withBaseName(),
59
- {
60
- [withBaseName("enterAnimation")]: open,
61
- [withBaseName("exitAnimation")]: !open,
62
- [withBaseName("withStatus")]: status,
63
- [withBaseName(status)]: status
46
+ children: /* @__PURE__ */ jsx(SaltProvider, {
47
+ children: showComponent && /* @__PURE__ */ jsx(FloatingOverlay, {
48
+ className: withBaseName("overlay"),
49
+ lockScroll: true,
50
+ children: /* @__PURE__ */ jsx(FloatingFocusManager, {
51
+ context,
52
+ modal: true,
53
+ initialFocus,
54
+ children: /* @__PURE__ */ jsx(DialogContext.Provider, {
55
+ value: contextValue,
56
+ children: /* @__PURE__ */ jsx("div", {
57
+ id: dialogId,
58
+ className: clsx(
59
+ withBaseName(),
60
+ {
61
+ [withBaseName("enterAnimation")]: open,
62
+ [withBaseName("exitAnimation")]: !open,
63
+ [withBaseName("withStatus")]: status,
64
+ [withBaseName(status)]: status
65
+ },
66
+ className
67
+ ),
68
+ onAnimationEnd: () => {
69
+ if (!open && showComponent) {
70
+ setShowComponent(false);
71
+ }
64
72
  },
65
- className
66
- ),
67
- onAnimationEnd: () => {
68
- if (!open && showComponent) {
69
- setShowComponent(false);
70
- }
71
- },
72
- ref: floatingRef,
73
- "aria-labelledby": `${dialogId}-heading`,
74
- "aria-describedby": `${dialogId}-description`,
75
- "aria-modal": "true",
76
- ...getFloatingProps(),
77
- ...rest,
78
- children
73
+ ref: floatingRef,
74
+ "aria-labelledby": `${dialogId}-heading`,
75
+ "aria-describedby": `${dialogId}-description`,
76
+ "aria-modal": "true",
77
+ ...getFloatingProps(),
78
+ ...rest,
79
+ children
80
+ })
79
81
  })
80
82
  })
81
83
  })