@salt-ds/lab 1.0.0-alpha.70 → 1.0.0-alpha.72

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 (861) hide show
  1. package/CHANGELOG.md +154 -0
  2. package/css/salt-lab.css +239 -346
  3. package/dist-cjs/app-header/AppHeader.css.js +1 -1
  4. package/dist-cjs/app-header/AppHeader.js +5 -5
  5. package/dist-cjs/app-header/AppHeader.js.map +1 -1
  6. package/dist-cjs/breadcrumbs/Breadcrumb.js +3 -3
  7. package/dist-cjs/breadcrumbs/Breadcrumb.js.map +1 -1
  8. package/dist-cjs/breadcrumbs/Breadcrumbs.js +3 -3
  9. package/dist-cjs/breadcrumbs/Breadcrumbs.js.map +1 -1
  10. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  11. package/dist-cjs/button-bar/ButtonBar.js +4 -4
  12. package/dist-cjs/button-bar/ButtonBar.js.map +1 -1
  13. package/dist-cjs/button-bar/OrderedButton.js +3 -3
  14. package/dist-cjs/button-bar/OrderedButton.js.map +1 -1
  15. package/dist-cjs/button-bar/internal/DescendantContext.js.map +1 -1
  16. package/dist-cjs/calendar/Calendar.js +35 -10
  17. package/dist-cjs/calendar/Calendar.js.map +1 -1
  18. package/dist-cjs/calendar/CalendarGrid.js +2 -2
  19. package/dist-cjs/calendar/CalendarGrid.js.map +1 -1
  20. package/dist-cjs/calendar/CalendarMonthHeader.js +2 -2
  21. package/dist-cjs/calendar/CalendarMonthHeader.js.map +1 -1
  22. package/dist-cjs/calendar/CalendarNavigation.js.map +1 -1
  23. package/dist-cjs/calendar/CalendarWeekHeader.css.js +1 -1
  24. package/dist-cjs/calendar/CalendarWeekHeader.js +3 -3
  25. package/dist-cjs/calendar/CalendarWeekHeader.js.map +1 -1
  26. package/dist-cjs/calendar/internal/CalendarDay.css.js +1 -1
  27. package/dist-cjs/calendar/internal/CalendarDay.js.map +1 -1
  28. package/dist-cjs/calendar/internal/CalendarMonth.css.js +1 -1
  29. package/dist-cjs/calendar/internal/CalendarMonth.js +3 -3
  30. package/dist-cjs/calendar/internal/CalendarMonth.js.map +1 -1
  31. package/dist-cjs/calendar/internal/useFocusManagement.js +1 -1
  32. package/dist-cjs/calendar/internal/useFocusManagement.js.map +1 -1
  33. package/dist-cjs/calendar/useCalendar.js +6 -0
  34. package/dist-cjs/calendar/useCalendar.js.map +1 -1
  35. package/dist-cjs/calendar/useCalendarSelection.js +185 -103
  36. package/dist-cjs/calendar/useCalendarSelection.js.map +1 -1
  37. package/dist-cjs/cascading-menu/CascadingMenu.js.map +1 -1
  38. package/dist-cjs/cascading-menu/CascadingMenuItem.css.js +1 -1
  39. package/dist-cjs/cascading-menu/CascadingMenuItem.js +3 -3
  40. package/dist-cjs/cascading-menu/CascadingMenuItem.js.map +1 -1
  41. package/dist-cjs/cascading-menu/CascadingMenuList.js +5 -5
  42. package/dist-cjs/cascading-menu/CascadingMenuList.js.map +1 -1
  43. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  44. package/dist-cjs/color-chooser/AlphaInputField.js +2 -2
  45. package/dist-cjs/color-chooser/AlphaInputField.js.map +1 -1
  46. package/dist-cjs/color-chooser/ColorChooser.css.js +1 -1
  47. package/dist-cjs/color-chooser/ColorChooser.js +38 -40
  48. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  49. package/dist-cjs/color-chooser/ColorPicker.css.js +1 -1
  50. package/dist-cjs/color-chooser/ColorPicker.js +3 -3
  51. package/dist-cjs/color-chooser/ColorPicker.js.map +1 -1
  52. package/dist-cjs/color-chooser/DictTabs.js +2 -2
  53. package/dist-cjs/color-chooser/HexInput.css.js +1 -1
  54. package/dist-cjs/color-chooser/HexInput.js +2 -2
  55. package/dist-cjs/color-chooser/HexInput.js.map +1 -1
  56. package/dist-cjs/color-chooser/RGBAInput.css.js +1 -1
  57. package/dist-cjs/color-chooser/RGBAInput.js +3 -3
  58. package/dist-cjs/color-chooser/RGBAInput.js.map +1 -1
  59. package/dist-cjs/color-chooser/RGBAInputField.js +2 -2
  60. package/dist-cjs/color-chooser/RGBAInputField.js.map +1 -1
  61. package/dist-cjs/color-chooser/Swatch.css.js +1 -1
  62. package/dist-cjs/color-chooser/Swatches.js +3 -3
  63. package/dist-cjs/color-chooser/Swatches.js.map +1 -1
  64. package/dist-cjs/color-chooser/SwatchesPicker.js +3 -3
  65. package/dist-cjs/color-chooser/SwatchesPicker.js.map +1 -1
  66. package/dist-cjs/combo-box/ComboBox.js +6 -6
  67. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  68. package/dist-cjs/combo-box/useCombobox.js +1 -1
  69. package/dist-cjs/combo-box/useCombobox.js.map +1 -1
  70. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js +3 -3
  71. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  72. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js +2 -2
  73. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  74. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js +2 -2
  75. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js +1 -1
  76. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js +1 -1
  77. package/dist-cjs/common-hooks/collectionProvider.js.map +1 -1
  78. package/dist-cjs/common-hooks/itemToString.js +1 -1
  79. package/dist-cjs/common-hooks/itemToString.js.map +1 -1
  80. package/dist-cjs/common-hooks/selectionTypes.js.map +1 -1
  81. package/dist-cjs/common-hooks/useCollapsibleGroups.js.map +1 -1
  82. package/dist-cjs/common-hooks/useCollectionItems.js +1 -1
  83. package/dist-cjs/common-hooks/useCollectionItems.js.map +1 -1
  84. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js +6 -10
  85. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  86. package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
  87. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  88. package/dist-cjs/common-hooks/useTypeahead.js.map +1 -1
  89. package/dist-cjs/common-hooks/utils/collection-item-utils.js +2 -2
  90. package/dist-cjs/common-hooks/utils/collection-item-utils.js.map +1 -1
  91. package/dist-cjs/contact-details/ContactActions.js +1 -1
  92. package/dist-cjs/contact-details/ContactActions.js.map +1 -1
  93. package/dist-cjs/contact-details/ContactAvatar.js +1 -1
  94. package/dist-cjs/contact-details/ContactDetails.js +4 -4
  95. package/dist-cjs/contact-details/ContactDetails.js.map +1 -1
  96. package/dist-cjs/contact-details/ContactFavoriteToggle.js +1 -1
  97. package/dist-cjs/contact-details/ContactMetadata.js +2 -2
  98. package/dist-cjs/contact-details/ContactMetadata.js.map +1 -1
  99. package/dist-cjs/contact-details/ContactMetadataItem.js.map +1 -1
  100. package/dist-cjs/contact-details/ContactPrimaryInfo.js +1 -1
  101. package/dist-cjs/contact-details/ContactPrimaryInfo.js.map +1 -1
  102. package/dist-cjs/contact-details/ContactSecondaryInfo.js +1 -1
  103. package/dist-cjs/contact-details/ContactSecondaryInfo.js.map +1 -1
  104. package/dist-cjs/contact-details/ContactTertiaryInfo.js +1 -1
  105. package/dist-cjs/contact-details/ContactTertiaryInfo.js.map +1 -1
  106. package/dist-cjs/contact-details/internal/FavoriteToggle.js.map +1 -1
  107. package/dist-cjs/contact-details/internal/StarIconContainer.js.map +1 -1
  108. package/dist-cjs/content-status/ContentStatus.js +3 -3
  109. package/dist-cjs/content-status/ContentStatus.js.map +1 -1
  110. package/dist-cjs/content-status/internal/StatusIndicator.js.map +1 -1
  111. package/dist-cjs/date-input/DateInput.css.js +1 -1
  112. package/dist-cjs/date-input/DateInputRange.js.map +1 -1
  113. package/dist-cjs/date-input/DateInputSingle.js.map +1 -1
  114. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  115. package/dist-cjs/date-picker/DatePickerActions.js.map +1 -1
  116. package/dist-cjs/date-picker/DatePickerContext.js +10 -10
  117. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  118. package/dist-cjs/date-picker/DatePickerOverlay.css.js +1 -1
  119. package/dist-cjs/date-picker/DatePickerOverlay.js.map +1 -1
  120. package/dist-cjs/date-picker/DatePickerOverlayProvider.js +4 -0
  121. package/dist-cjs/date-picker/DatePickerOverlayProvider.js.map +1 -1
  122. package/dist-cjs/date-picker/DatePickerPanel.css.js +1 -1
  123. package/dist-cjs/date-picker/DatePickerRangeGridPanel.js +3 -3
  124. package/dist-cjs/date-picker/DatePickerRangeGridPanel.js.map +1 -1
  125. package/dist-cjs/date-picker/DatePickerRangeInput.js +1 -1
  126. package/dist-cjs/date-picker/DatePickerRangeInput.js.map +1 -1
  127. package/dist-cjs/date-picker/DatePickerRangePanel.js +3 -3
  128. package/dist-cjs/date-picker/DatePickerRangePanel.js.map +1 -1
  129. package/dist-cjs/date-picker/DatePickerSingleGridPanel.js +3 -3
  130. package/dist-cjs/date-picker/DatePickerSingleGridPanel.js.map +1 -1
  131. package/dist-cjs/date-picker/DatePickerSingleInput.js +1 -1
  132. package/dist-cjs/date-picker/DatePickerSingleInput.js.map +1 -1
  133. package/dist-cjs/date-picker/DatePickerTrigger.js.map +1 -1
  134. package/dist-cjs/deck-item/DeckItem.js +2 -2
  135. package/dist-cjs/deck-item/DeckItem.js.map +1 -1
  136. package/dist-cjs/deck-layout/DeckLayout.js +3 -3
  137. package/dist-cjs/deck-layout/DeckLayout.js.map +1 -1
  138. package/dist-cjs/dropdown/Dropdown.js +1 -1
  139. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  140. package/dist-cjs/dropdown/DropdownBase.js +3 -3
  141. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  142. package/dist-cjs/dropdown/DropdownButton.js +2 -2
  143. package/dist-cjs/dropdown/DropdownButton.js.map +1 -1
  144. package/dist-cjs/dropdown/useDropdown.js +1 -1
  145. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  146. package/dist-cjs/dropdown/useDropdownBase.js.map +1 -1
  147. package/dist-cjs/editable-label/EditableLabel.js +2 -2
  148. package/dist-cjs/editable-label/EditableLabel.js.map +1 -1
  149. package/dist-cjs/form-field-legacy/FormActivationIndicator.js.map +1 -1
  150. package/dist-cjs/form-field-legacy/FormFieldLegacy.css.js +1 -1
  151. package/dist-cjs/form-field-legacy/FormFieldLegacy.js +4 -4
  152. package/dist-cjs/form-field-legacy/FormFieldLegacy.js.map +1 -1
  153. package/dist-cjs/form-field-legacy/FormHelperText.js.map +1 -1
  154. package/dist-cjs/form-field-legacy/FormLabel.css.js +1 -1
  155. package/dist-cjs/form-field-legacy/FormLabel.js +3 -3
  156. package/dist-cjs/form-field-legacy/FormLabel.js.map +1 -1
  157. package/dist-cjs/form-field-legacy/StatusIndicator.js.map +1 -1
  158. package/dist-cjs/form-group/FormGroup.js +2 -2
  159. package/dist-cjs/form-group/FormGroup.js.map +1 -1
  160. package/dist-cjs/formatted-input/FormattedInput.js +3 -3
  161. package/dist-cjs/formatted-input/FormattedInput.js.map +1 -1
  162. package/dist-cjs/formatted-input/internal/InputWithMask.js.map +1 -1
  163. package/dist-cjs/index.js +105 -115
  164. package/dist-cjs/index.js.map +1 -1
  165. package/dist-cjs/input-legacy/InputLegacy.css.js +1 -1
  166. package/dist-cjs/input-legacy/InputLegacy.js +3 -3
  167. package/dist-cjs/input-legacy/InputLegacy.js.map +1 -1
  168. package/dist-cjs/input-legacy/StaticInputAdornment.js +2 -2
  169. package/dist-cjs/input-legacy/StaticInputAdornment.js.map +1 -1
  170. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  171. package/dist-cjs/list/Highlighter.js +2 -2
  172. package/dist-cjs/list/Highlighter.js.map +1 -1
  173. package/dist-cjs/list/List.css.js +1 -1
  174. package/dist-cjs/list/List.js +3 -3
  175. package/dist-cjs/list/List.js.map +1 -1
  176. package/dist-cjs/list/ListItem.css.js +1 -1
  177. package/dist-cjs/list/ListItem.js +2 -2
  178. package/dist-cjs/list/ListItem.js.map +1 -1
  179. package/dist-cjs/list/VirtualizedList.js +4 -4
  180. package/dist-cjs/list/VirtualizedList.js.map +1 -1
  181. package/dist-cjs/list/useList.js +2 -2
  182. package/dist-cjs/list/useList.js.map +1 -1
  183. package/dist-cjs/list/useListHeight.js +1 -1
  184. package/dist-cjs/list-deprecated/List.css.js +1 -1
  185. package/dist-cjs/list-deprecated/List.js +2 -2
  186. package/dist-cjs/list-deprecated/List.js.map +1 -1
  187. package/dist-cjs/list-deprecated/ListBase.js +15 -19
  188. package/dist-cjs/list-deprecated/ListBase.js.map +1 -1
  189. package/dist-cjs/list-deprecated/ListItem.css.js +1 -1
  190. package/dist-cjs/list-deprecated/ListItem.js +1 -1
  191. package/dist-cjs/list-deprecated/ListItem.js.map +1 -1
  192. package/dist-cjs/list-deprecated/ListItemBase.js +2 -2
  193. package/dist-cjs/list-deprecated/ListItemBase.js.map +1 -1
  194. package/dist-cjs/list-deprecated/internal/DescendantContext.js +7 -4
  195. package/dist-cjs/list-deprecated/internal/DescendantContext.js.map +1 -1
  196. package/dist-cjs/list-deprecated/internal/Highlighter.js +2 -2
  197. package/dist-cjs/list-deprecated/internal/Highlighter.js.map +1 -1
  198. package/dist-cjs/list-deprecated/itemToString.js +1 -1
  199. package/dist-cjs/list-deprecated/itemToString.js.map +1 -1
  200. package/dist-cjs/list-deprecated/useList.js.map +1 -1
  201. package/dist-cjs/list-next/ListItemNext.css.js +1 -1
  202. package/dist-cjs/list-next/ListItemNext.js +2 -2
  203. package/dist-cjs/list-next/ListItemNext.js.map +1 -1
  204. package/dist-cjs/list-next/ListNext.css.js +1 -1
  205. package/dist-cjs/list-next/ListNext.js.map +1 -1
  206. package/dist-cjs/logo/Logo.js +2 -2
  207. package/dist-cjs/logo/Logo.js.map +1 -1
  208. package/dist-cjs/logo/LogoSeparator.css.js +1 -1
  209. package/dist-cjs/logo/LogoSeparator.js +2 -2
  210. package/dist-cjs/logo/LogoSeparator.js.map +1 -1
  211. package/dist-cjs/menu-button/MenuButton.js +1 -1
  212. package/dist-cjs/menu-button/MenuButton.js.map +1 -1
  213. package/dist-cjs/menu-button/MenuButtonTrigger.js +2 -2
  214. package/dist-cjs/menu-button/MenuButtonTrigger.js.map +1 -1
  215. package/dist-cjs/metric/Metric.js +2 -2
  216. package/dist-cjs/metric/Metric.js.map +1 -1
  217. package/dist-cjs/metric/MetricContent.css.js +1 -1
  218. package/dist-cjs/metric/MetricContent.js +2 -2
  219. package/dist-cjs/metric/MetricContent.js.map +1 -1
  220. package/dist-cjs/metric/MetricHeader.js +2 -2
  221. package/dist-cjs/metric/MetricHeader.js.map +1 -1
  222. package/dist-cjs/number-input/NumberInput.css.js +1 -1
  223. package/dist-cjs/number-input/NumberInput.js +146 -79
  224. package/dist-cjs/number-input/NumberInput.js.map +1 -1
  225. package/dist-cjs/number-input/internal/useCaret.js +34 -0
  226. package/dist-cjs/number-input/internal/useCaret.js.map +1 -0
  227. package/dist-cjs/number-input/internal/utils.js +56 -14
  228. package/dist-cjs/number-input/internal/utils.js.map +1 -1
  229. package/dist-cjs/number-input/useNumberInput.js +34 -26
  230. package/dist-cjs/number-input/useNumberInput.js.map +1 -1
  231. package/dist-cjs/portal/Portal.js.map +1 -1
  232. package/dist-cjs/query-input/QueryInput.css.js +1 -1
  233. package/dist-cjs/query-input/QueryInput.js +3 -3
  234. package/dist-cjs/query-input/QueryInput.js.map +1 -1
  235. package/dist-cjs/query-input/internal/CategoryList.js +1 -1
  236. package/dist-cjs/query-input/internal/CategoryListItem.js +1 -1
  237. package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
  238. package/dist-cjs/query-input/internal/SearchList.js +3 -3
  239. package/dist-cjs/query-input/internal/SearchList.js.map +1 -1
  240. package/dist-cjs/query-input/internal/ValueList.js +1 -1
  241. package/dist-cjs/query-input/internal/ValueSelector.js +1 -1
  242. package/dist-cjs/query-input/useQueryInput.js.map +1 -1
  243. package/dist-cjs/responsive/OverflowReducer.js.map +1 -1
  244. package/dist-cjs/responsive/useOverflowCollectionItems.js.map +1 -1
  245. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  246. package/dist-cjs/responsive/useWidth.js.map +1 -1
  247. package/dist-cjs/search-input/SearchInput.js +2 -2
  248. package/dist-cjs/search-input/SearchInput.js.map +1 -1
  249. package/dist-cjs/static-list/StaticList.js.map +1 -1
  250. package/dist-cjs/static-list/StaticListItemContent.js.map +1 -1
  251. package/dist-cjs/system-status/SystemStatus.css.js +1 -1
  252. package/dist-cjs/system-status/SystemStatus.js +2 -2
  253. package/dist-cjs/system-status/SystemStatus.js.map +1 -1
  254. package/dist-cjs/system-status/SystemStatusActions.js +2 -2
  255. package/dist-cjs/system-status/SystemStatusActions.js.map +1 -1
  256. package/dist-cjs/system-status/SystemStatusContent.js +2 -2
  257. package/dist-cjs/system-status/SystemStatusContent.js.map +1 -1
  258. package/dist-cjs/tabs/Tab.css.js +1 -1
  259. package/dist-cjs/tabs/Tab.js.map +1 -1
  260. package/dist-cjs/tabs/TabActivationIndicator.css.js +1 -1
  261. package/dist-cjs/tabs/TabActivationIndicator.js +2 -2
  262. package/dist-cjs/tabs/TabActivationIndicator.js.map +1 -1
  263. package/dist-cjs/tabs/TabPanel.js.map +1 -1
  264. package/dist-cjs/tabs/Tabs.js +3 -3
  265. package/dist-cjs/tabs/Tabs.js.map +1 -1
  266. package/dist-cjs/tabs/Tabstrip.css.js +1 -1
  267. package/dist-cjs/tabs/Tabstrip.js +5 -5
  268. package/dist-cjs/tabs/Tabstrip.js.map +1 -1
  269. package/dist-cjs/tabs/drag-drop/Draggable.css.js +1 -1
  270. package/dist-cjs/tabs/drag-drop/Draggable.js +2 -2
  271. package/dist-cjs/tabs/drag-drop/Draggable.js.map +1 -1
  272. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js +2 -2
  273. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  274. package/dist-cjs/tabs/useActivationIndicator.js +1 -1
  275. package/dist-cjs/tabs/useActivationIndicator.js.map +1 -1
  276. package/dist-cjs/tabs/useItemsWithIds.js.map +1 -1
  277. package/dist-cjs/tabs/useTabstrip.js +1 -1
  278. package/dist-cjs/tabs/useTabstrip.js.map +1 -1
  279. package/dist-cjs/tabs-next/TabBar.css.js +1 -1
  280. package/dist-cjs/tabs-next/TabBar.js +2 -2
  281. package/dist-cjs/tabs-next/TabBar.js.map +1 -1
  282. package/dist-cjs/tabs-next/TabListNext.js +2 -2
  283. package/dist-cjs/tabs-next/TabListNext.js.map +1 -1
  284. package/dist-cjs/tabs-next/TabNext.css.js +1 -1
  285. package/dist-cjs/tabs-next/TabNext.js.map +1 -1
  286. package/dist-cjs/tabs-next/TabNextTrigger.js.map +1 -1
  287. package/dist-cjs/tabs-next/TabOverflowList.css.js +1 -1
  288. package/dist-cjs/tabs-next/TabOverflowList.js +1 -1
  289. package/dist-cjs/tabs-next/TabOverflowList.js.map +1 -1
  290. package/dist-cjs/tabs-next/TabsNext.js +2 -2
  291. package/dist-cjs/tabs-next/TabsNext.js.map +1 -1
  292. package/dist-cjs/tokenized-input/TokenizedInput.css.js +1 -1
  293. package/dist-cjs/tokenized-input/TokenizedInputBase.js +2 -2
  294. package/dist-cjs/tokenized-input/TokenizedInputBase.js.map +1 -1
  295. package/dist-cjs/tokenized-input/internal/InputPill.js.map +1 -1
  296. package/dist-cjs/tokenized-input/internal/InputRuler.js.map +1 -1
  297. package/dist-cjs/tokenized-input/internal/calcFirstHiddenIndex.js.map +1 -1
  298. package/dist-cjs/tokenized-input/internal/defaultItemToString.js +1 -1
  299. package/dist-cjs/tokenized-input/internal/defaultItemToString.js.map +1 -1
  300. package/dist-cjs/tokenized-input/useTokenizedInput.js.map +1 -1
  301. package/dist-cjs/tokenized-input-next/TokenizedInputNext.css.js +1 -1
  302. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js +1 -1
  303. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  304. package/dist-cjs/tokenized-input-next/internal/InputPill.js.map +1 -1
  305. package/dist-cjs/tokenized-input-next/internal/calcFirstHiddenIndex.js.map +1 -1
  306. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  307. package/dist-cjs/toolbar/Toolbar.css.js +1 -1
  308. package/dist-cjs/toolbar/Toolbar.js +6 -6
  309. package/dist-cjs/toolbar/Toolbar.js.map +1 -1
  310. package/dist-cjs/toolbar/ToolbarButton.js +1 -1
  311. package/dist-cjs/toolbar/ToolbarButton.js.map +1 -1
  312. package/dist-cjs/toolbar/Tooltray.js +3 -3
  313. package/dist-cjs/toolbar/Tooltray.js.map +1 -1
  314. package/dist-cjs/toolbar/internal/renderToolbarItems.js +3 -3
  315. package/dist-cjs/toolbar/internal/renderToolbarItems.js.map +1 -1
  316. package/dist-cjs/toolbar/internal/renderTrayTools.js.map +1 -1
  317. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.css.js +1 -1
  318. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js +5 -5
  319. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  320. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.css.js +1 -1
  321. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js +1 -1
  322. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  323. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  324. package/dist-cjs/tree/Tree.js +4 -4
  325. package/dist-cjs/tree/Tree.js.map +1 -1
  326. package/dist-cjs/tree/TreeNode.js +2 -2
  327. package/dist-cjs/tree/TreeNode.js.map +1 -1
  328. package/dist-cjs/tree/useTree.js +2 -2
  329. package/dist-cjs/tree/useTree.js.map +1 -1
  330. package/dist-cjs/utils/useEventCallback.js +1 -1
  331. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  332. package/dist-cjs/window/ElectronWindow.js +4 -4
  333. package/dist-cjs/window/ElectronWindow.js.map +1 -1
  334. package/dist-es/app-header/AppHeader.css.js +1 -1
  335. package/dist-es/app-header/AppHeader.js +5 -5
  336. package/dist-es/app-header/AppHeader.js.map +1 -1
  337. package/dist-es/breadcrumbs/Breadcrumb.js +3 -3
  338. package/dist-es/breadcrumbs/Breadcrumb.js.map +1 -1
  339. package/dist-es/breadcrumbs/Breadcrumbs.js +3 -3
  340. package/dist-es/breadcrumbs/Breadcrumbs.js.map +1 -1
  341. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  342. package/dist-es/button-bar/ButtonBar.js +4 -4
  343. package/dist-es/button-bar/ButtonBar.js.map +1 -1
  344. package/dist-es/button-bar/OrderedButton.js +3 -3
  345. package/dist-es/button-bar/OrderedButton.js.map +1 -1
  346. package/dist-es/button-bar/internal/DescendantContext.js.map +1 -1
  347. package/dist-es/calendar/Calendar.js +35 -10
  348. package/dist-es/calendar/Calendar.js.map +1 -1
  349. package/dist-es/calendar/CalendarGrid.js +2 -2
  350. package/dist-es/calendar/CalendarGrid.js.map +1 -1
  351. package/dist-es/calendar/CalendarMonthHeader.js +2 -2
  352. package/dist-es/calendar/CalendarMonthHeader.js.map +1 -1
  353. package/dist-es/calendar/CalendarNavigation.js.map +1 -1
  354. package/dist-es/calendar/CalendarWeekHeader.css.js +1 -1
  355. package/dist-es/calendar/CalendarWeekHeader.js +3 -3
  356. package/dist-es/calendar/CalendarWeekHeader.js.map +1 -1
  357. package/dist-es/calendar/internal/CalendarDay.css.js +1 -1
  358. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  359. package/dist-es/calendar/internal/CalendarMonth.css.js +1 -1
  360. package/dist-es/calendar/internal/CalendarMonth.js +3 -3
  361. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  362. package/dist-es/calendar/internal/useFocusManagement.js +1 -1
  363. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  364. package/dist-es/calendar/useCalendar.js +6 -0
  365. package/dist-es/calendar/useCalendar.js.map +1 -1
  366. package/dist-es/calendar/useCalendarSelection.js +186 -102
  367. package/dist-es/calendar/useCalendarSelection.js.map +1 -1
  368. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  369. package/dist-es/cascading-menu/CascadingMenuItem.css.js +1 -1
  370. package/dist-es/cascading-menu/CascadingMenuItem.js +3 -3
  371. package/dist-es/cascading-menu/CascadingMenuItem.js.map +1 -1
  372. package/dist-es/cascading-menu/CascadingMenuList.js +5 -5
  373. package/dist-es/cascading-menu/CascadingMenuList.js.map +1 -1
  374. package/dist-es/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  375. package/dist-es/color-chooser/AlphaInputField.js +2 -2
  376. package/dist-es/color-chooser/AlphaInputField.js.map +1 -1
  377. package/dist-es/color-chooser/ColorChooser.css.js +1 -1
  378. package/dist-es/color-chooser/ColorChooser.js +39 -41
  379. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  380. package/dist-es/color-chooser/ColorPicker.css.js +1 -1
  381. package/dist-es/color-chooser/ColorPicker.js +3 -3
  382. package/dist-es/color-chooser/ColorPicker.js.map +1 -1
  383. package/dist-es/color-chooser/DictTabs.js +2 -2
  384. package/dist-es/color-chooser/HexInput.css.js +1 -1
  385. package/dist-es/color-chooser/HexInput.js +2 -2
  386. package/dist-es/color-chooser/HexInput.js.map +1 -1
  387. package/dist-es/color-chooser/RGBAInput.css.js +1 -1
  388. package/dist-es/color-chooser/RGBAInput.js +3 -3
  389. package/dist-es/color-chooser/RGBAInput.js.map +1 -1
  390. package/dist-es/color-chooser/RGBAInputField.js +2 -2
  391. package/dist-es/color-chooser/RGBAInputField.js.map +1 -1
  392. package/dist-es/color-chooser/Swatch.css.js +1 -1
  393. package/dist-es/color-chooser/Swatches.js +3 -3
  394. package/dist-es/color-chooser/Swatches.js.map +1 -1
  395. package/dist-es/color-chooser/SwatchesPicker.js +3 -3
  396. package/dist-es/color-chooser/SwatchesPicker.js.map +1 -1
  397. package/dist-es/combo-box/ComboBox.js +6 -6
  398. package/dist-es/combo-box/ComboBox.js.map +1 -1
  399. package/dist-es/combo-box/useCombobox.js +1 -1
  400. package/dist-es/combo-box/useCombobox.js.map +1 -1
  401. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js +3 -3
  402. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  403. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js +2 -2
  404. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  405. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js +2 -2
  406. package/dist-es/combo-box-deprecated/internal/useComboBox.js +1 -1
  407. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js +1 -1
  408. package/dist-es/common-hooks/collectionProvider.js.map +1 -1
  409. package/dist-es/common-hooks/itemToString.js +1 -1
  410. package/dist-es/common-hooks/itemToString.js.map +1 -1
  411. package/dist-es/common-hooks/selectionTypes.js.map +1 -1
  412. package/dist-es/common-hooks/useCollapsibleGroups.js.map +1 -1
  413. package/dist-es/common-hooks/useCollectionItems.js +1 -1
  414. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  415. package/dist-es/common-hooks/useImperativeScrollingAPI.js +6 -10
  416. package/dist-es/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  417. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  418. package/dist-es/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  419. package/dist-es/common-hooks/useTypeahead.js.map +1 -1
  420. package/dist-es/common-hooks/utils/collection-item-utils.js +2 -2
  421. package/dist-es/common-hooks/utils/collection-item-utils.js.map +1 -1
  422. package/dist-es/contact-details/ContactActions.js +1 -1
  423. package/dist-es/contact-details/ContactActions.js.map +1 -1
  424. package/dist-es/contact-details/ContactAvatar.js +1 -1
  425. package/dist-es/contact-details/ContactDetails.js +4 -4
  426. package/dist-es/contact-details/ContactDetails.js.map +1 -1
  427. package/dist-es/contact-details/ContactFavoriteToggle.js +1 -1
  428. package/dist-es/contact-details/ContactMetadata.js +2 -2
  429. package/dist-es/contact-details/ContactMetadata.js.map +1 -1
  430. package/dist-es/contact-details/ContactMetadataItem.js.map +1 -1
  431. package/dist-es/contact-details/ContactPrimaryInfo.js +1 -1
  432. package/dist-es/contact-details/ContactPrimaryInfo.js.map +1 -1
  433. package/dist-es/contact-details/ContactSecondaryInfo.js +1 -1
  434. package/dist-es/contact-details/ContactSecondaryInfo.js.map +1 -1
  435. package/dist-es/contact-details/ContactTertiaryInfo.js +1 -1
  436. package/dist-es/contact-details/ContactTertiaryInfo.js.map +1 -1
  437. package/dist-es/contact-details/internal/FavoriteToggle.js.map +1 -1
  438. package/dist-es/contact-details/internal/StarIconContainer.js.map +1 -1
  439. package/dist-es/content-status/ContentStatus.js +3 -3
  440. package/dist-es/content-status/ContentStatus.js.map +1 -1
  441. package/dist-es/content-status/internal/StatusIndicator.js.map +1 -1
  442. package/dist-es/date-input/DateInput.css.js +1 -1
  443. package/dist-es/date-input/DateInputRange.js.map +1 -1
  444. package/dist-es/date-input/DateInputSingle.js.map +1 -1
  445. package/dist-es/date-picker/DatePicker.js.map +1 -1
  446. package/dist-es/date-picker/DatePickerActions.js.map +1 -1
  447. package/dist-es/date-picker/DatePickerContext.js +10 -10
  448. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  449. package/dist-es/date-picker/DatePickerOverlay.css.js +1 -1
  450. package/dist-es/date-picker/DatePickerOverlay.js.map +1 -1
  451. package/dist-es/date-picker/DatePickerOverlayProvider.js +4 -0
  452. package/dist-es/date-picker/DatePickerOverlayProvider.js.map +1 -1
  453. package/dist-es/date-picker/DatePickerPanel.css.js +1 -1
  454. package/dist-es/date-picker/DatePickerRangeGridPanel.js +3 -3
  455. package/dist-es/date-picker/DatePickerRangeGridPanel.js.map +1 -1
  456. package/dist-es/date-picker/DatePickerRangeInput.js +1 -1
  457. package/dist-es/date-picker/DatePickerRangeInput.js.map +1 -1
  458. package/dist-es/date-picker/DatePickerRangePanel.js +3 -3
  459. package/dist-es/date-picker/DatePickerRangePanel.js.map +1 -1
  460. package/dist-es/date-picker/DatePickerSingleGridPanel.js +3 -3
  461. package/dist-es/date-picker/DatePickerSingleGridPanel.js.map +1 -1
  462. package/dist-es/date-picker/DatePickerSingleInput.js +1 -1
  463. package/dist-es/date-picker/DatePickerSingleInput.js.map +1 -1
  464. package/dist-es/date-picker/DatePickerTrigger.js.map +1 -1
  465. package/dist-es/deck-item/DeckItem.js +2 -2
  466. package/dist-es/deck-item/DeckItem.js.map +1 -1
  467. package/dist-es/deck-layout/DeckLayout.js +3 -3
  468. package/dist-es/deck-layout/DeckLayout.js.map +1 -1
  469. package/dist-es/dropdown/Dropdown.js +1 -1
  470. package/dist-es/dropdown/Dropdown.js.map +1 -1
  471. package/dist-es/dropdown/DropdownBase.js +3 -3
  472. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  473. package/dist-es/dropdown/DropdownButton.js +2 -2
  474. package/dist-es/dropdown/DropdownButton.js.map +1 -1
  475. package/dist-es/dropdown/useDropdown.js +1 -1
  476. package/dist-es/dropdown/useDropdown.js.map +1 -1
  477. package/dist-es/dropdown/useDropdownBase.js.map +1 -1
  478. package/dist-es/editable-label/EditableLabel.js +2 -2
  479. package/dist-es/editable-label/EditableLabel.js.map +1 -1
  480. package/dist-es/form-field-legacy/FormActivationIndicator.js.map +1 -1
  481. package/dist-es/form-field-legacy/FormFieldLegacy.css.js +1 -1
  482. package/dist-es/form-field-legacy/FormFieldLegacy.js +4 -4
  483. package/dist-es/form-field-legacy/FormFieldLegacy.js.map +1 -1
  484. package/dist-es/form-field-legacy/FormHelperText.js.map +1 -1
  485. package/dist-es/form-field-legacy/FormLabel.css.js +1 -1
  486. package/dist-es/form-field-legacy/FormLabel.js +3 -3
  487. package/dist-es/form-field-legacy/FormLabel.js.map +1 -1
  488. package/dist-es/form-field-legacy/StatusIndicator.js.map +1 -1
  489. package/dist-es/form-group/FormGroup.js +2 -2
  490. package/dist-es/form-group/FormGroup.js.map +1 -1
  491. package/dist-es/formatted-input/FormattedInput.js +3 -3
  492. package/dist-es/formatted-input/FormattedInput.js.map +1 -1
  493. package/dist-es/formatted-input/internal/InputWithMask.js.map +1 -1
  494. package/dist-es/index.js +52 -56
  495. package/dist-es/index.js.map +1 -1
  496. package/dist-es/input-legacy/InputLegacy.css.js +1 -1
  497. package/dist-es/input-legacy/InputLegacy.js +3 -3
  498. package/dist-es/input-legacy/InputLegacy.js.map +1 -1
  499. package/dist-es/input-legacy/StaticInputAdornment.js +2 -2
  500. package/dist-es/input-legacy/StaticInputAdornment.js.map +1 -1
  501. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  502. package/dist-es/list/Highlighter.js +2 -2
  503. package/dist-es/list/Highlighter.js.map +1 -1
  504. package/dist-es/list/List.css.js +1 -1
  505. package/dist-es/list/List.js +3 -3
  506. package/dist-es/list/List.js.map +1 -1
  507. package/dist-es/list/ListItem.css.js +1 -1
  508. package/dist-es/list/ListItem.js +2 -2
  509. package/dist-es/list/ListItem.js.map +1 -1
  510. package/dist-es/list/VirtualizedList.js +4 -4
  511. package/dist-es/list/VirtualizedList.js.map +1 -1
  512. package/dist-es/list/useList.js +2 -2
  513. package/dist-es/list/useList.js.map +1 -1
  514. package/dist-es/list/useListHeight.js +1 -1
  515. package/dist-es/list-deprecated/List.css.js +1 -1
  516. package/dist-es/list-deprecated/List.js +2 -2
  517. package/dist-es/list-deprecated/List.js.map +1 -1
  518. package/dist-es/list-deprecated/ListBase.js +15 -19
  519. package/dist-es/list-deprecated/ListBase.js.map +1 -1
  520. package/dist-es/list-deprecated/ListItem.css.js +1 -1
  521. package/dist-es/list-deprecated/ListItem.js +1 -1
  522. package/dist-es/list-deprecated/ListItem.js.map +1 -1
  523. package/dist-es/list-deprecated/ListItemBase.js +2 -2
  524. package/dist-es/list-deprecated/ListItemBase.js.map +1 -1
  525. package/dist-es/list-deprecated/internal/DescendantContext.js +7 -4
  526. package/dist-es/list-deprecated/internal/DescendantContext.js.map +1 -1
  527. package/dist-es/list-deprecated/internal/Highlighter.js +2 -2
  528. package/dist-es/list-deprecated/internal/Highlighter.js.map +1 -1
  529. package/dist-es/list-deprecated/itemToString.js +1 -1
  530. package/dist-es/list-deprecated/itemToString.js.map +1 -1
  531. package/dist-es/list-deprecated/useList.js.map +1 -1
  532. package/dist-es/list-next/ListItemNext.css.js +1 -1
  533. package/dist-es/list-next/ListItemNext.js +2 -2
  534. package/dist-es/list-next/ListItemNext.js.map +1 -1
  535. package/dist-es/list-next/ListNext.css.js +1 -1
  536. package/dist-es/list-next/ListNext.js.map +1 -1
  537. package/dist-es/logo/Logo.js +2 -2
  538. package/dist-es/logo/Logo.js.map +1 -1
  539. package/dist-es/logo/LogoSeparator.css.js +1 -1
  540. package/dist-es/logo/LogoSeparator.js +2 -2
  541. package/dist-es/logo/LogoSeparator.js.map +1 -1
  542. package/dist-es/menu-button/MenuButton.js +1 -1
  543. package/dist-es/menu-button/MenuButton.js.map +1 -1
  544. package/dist-es/menu-button/MenuButtonTrigger.js +2 -2
  545. package/dist-es/menu-button/MenuButtonTrigger.js.map +1 -1
  546. package/dist-es/metric/Metric.js +2 -2
  547. package/dist-es/metric/Metric.js.map +1 -1
  548. package/dist-es/metric/MetricContent.css.js +1 -1
  549. package/dist-es/metric/MetricContent.js +2 -2
  550. package/dist-es/metric/MetricContent.js.map +1 -1
  551. package/dist-es/metric/MetricHeader.js +2 -2
  552. package/dist-es/metric/MetricHeader.js.map +1 -1
  553. package/dist-es/number-input/NumberInput.css.js +1 -1
  554. package/dist-es/number-input/NumberInput.js +149 -82
  555. package/dist-es/number-input/NumberInput.js.map +1 -1
  556. package/dist-es/number-input/internal/useCaret.js +32 -0
  557. package/dist-es/number-input/internal/useCaret.js.map +1 -0
  558. package/dist-es/number-input/internal/utils.js +52 -10
  559. package/dist-es/number-input/internal/utils.js.map +1 -1
  560. package/dist-es/number-input/useNumberInput.js +35 -27
  561. package/dist-es/number-input/useNumberInput.js.map +1 -1
  562. package/dist-es/portal/Portal.js.map +1 -1
  563. package/dist-es/query-input/QueryInput.css.js +1 -1
  564. package/dist-es/query-input/QueryInput.js +3 -3
  565. package/dist-es/query-input/QueryInput.js.map +1 -1
  566. package/dist-es/query-input/internal/CategoryList.js +1 -1
  567. package/dist-es/query-input/internal/CategoryListItem.js +1 -1
  568. package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
  569. package/dist-es/query-input/internal/SearchList.js +3 -3
  570. package/dist-es/query-input/internal/SearchList.js.map +1 -1
  571. package/dist-es/query-input/internal/ValueList.js +1 -1
  572. package/dist-es/query-input/internal/ValueSelector.js +1 -1
  573. package/dist-es/query-input/useQueryInput.js.map +1 -1
  574. package/dist-es/responsive/OverflowReducer.js.map +1 -1
  575. package/dist-es/responsive/useOverflowCollectionItems.js.map +1 -1
  576. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  577. package/dist-es/responsive/useWidth.js.map +1 -1
  578. package/dist-es/search-input/SearchInput.js +2 -2
  579. package/dist-es/search-input/SearchInput.js.map +1 -1
  580. package/dist-es/static-list/StaticList.js.map +1 -1
  581. package/dist-es/static-list/StaticListItemContent.js.map +1 -1
  582. package/dist-es/system-status/SystemStatus.css.js +1 -1
  583. package/dist-es/system-status/SystemStatus.js +2 -2
  584. package/dist-es/system-status/SystemStatus.js.map +1 -1
  585. package/dist-es/system-status/SystemStatusActions.js +2 -2
  586. package/dist-es/system-status/SystemStatusActions.js.map +1 -1
  587. package/dist-es/system-status/SystemStatusContent.js +2 -2
  588. package/dist-es/system-status/SystemStatusContent.js.map +1 -1
  589. package/dist-es/tabs/Tab.css.js +1 -1
  590. package/dist-es/tabs/Tab.js.map +1 -1
  591. package/dist-es/tabs/TabActivationIndicator.css.js +1 -1
  592. package/dist-es/tabs/TabActivationIndicator.js +2 -2
  593. package/dist-es/tabs/TabActivationIndicator.js.map +1 -1
  594. package/dist-es/tabs/TabPanel.js.map +1 -1
  595. package/dist-es/tabs/Tabs.js +3 -3
  596. package/dist-es/tabs/Tabs.js.map +1 -1
  597. package/dist-es/tabs/Tabstrip.css.js +1 -1
  598. package/dist-es/tabs/Tabstrip.js +5 -5
  599. package/dist-es/tabs/Tabstrip.js.map +1 -1
  600. package/dist-es/tabs/drag-drop/Draggable.css.js +1 -1
  601. package/dist-es/tabs/drag-drop/Draggable.js +2 -2
  602. package/dist-es/tabs/drag-drop/Draggable.js.map +1 -1
  603. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js +2 -2
  604. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  605. package/dist-es/tabs/useActivationIndicator.js +1 -1
  606. package/dist-es/tabs/useActivationIndicator.js.map +1 -1
  607. package/dist-es/tabs/useItemsWithIds.js.map +1 -1
  608. package/dist-es/tabs/useTabstrip.js +1 -1
  609. package/dist-es/tabs/useTabstrip.js.map +1 -1
  610. package/dist-es/tabs-next/TabBar.css.js +1 -1
  611. package/dist-es/tabs-next/TabBar.js +2 -2
  612. package/dist-es/tabs-next/TabBar.js.map +1 -1
  613. package/dist-es/tabs-next/TabListNext.js +2 -2
  614. package/dist-es/tabs-next/TabListNext.js.map +1 -1
  615. package/dist-es/tabs-next/TabNext.css.js +1 -1
  616. package/dist-es/tabs-next/TabNext.js.map +1 -1
  617. package/dist-es/tabs-next/TabNextTrigger.js.map +1 -1
  618. package/dist-es/tabs-next/TabOverflowList.css.js +1 -1
  619. package/dist-es/tabs-next/TabOverflowList.js +1 -1
  620. package/dist-es/tabs-next/TabOverflowList.js.map +1 -1
  621. package/dist-es/tabs-next/TabsNext.js +2 -2
  622. package/dist-es/tabs-next/TabsNext.js.map +1 -1
  623. package/dist-es/tokenized-input/TokenizedInput.css.js +1 -1
  624. package/dist-es/tokenized-input/TokenizedInputBase.js +2 -2
  625. package/dist-es/tokenized-input/TokenizedInputBase.js.map +1 -1
  626. package/dist-es/tokenized-input/internal/InputPill.js.map +1 -1
  627. package/dist-es/tokenized-input/internal/InputRuler.js.map +1 -1
  628. package/dist-es/tokenized-input/internal/calcFirstHiddenIndex.js.map +1 -1
  629. package/dist-es/tokenized-input/internal/defaultItemToString.js +1 -1
  630. package/dist-es/tokenized-input/internal/defaultItemToString.js.map +1 -1
  631. package/dist-es/tokenized-input/useTokenizedInput.js.map +1 -1
  632. package/dist-es/tokenized-input-next/TokenizedInputNext.css.js +1 -1
  633. package/dist-es/tokenized-input-next/TokenizedInputNext.js +1 -1
  634. package/dist-es/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  635. package/dist-es/tokenized-input-next/internal/InputPill.js.map +1 -1
  636. package/dist-es/tokenized-input-next/internal/calcFirstHiddenIndex.js.map +1 -1
  637. package/dist-es/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  638. package/dist-es/toolbar/Toolbar.css.js +1 -1
  639. package/dist-es/toolbar/Toolbar.js +6 -6
  640. package/dist-es/toolbar/Toolbar.js.map +1 -1
  641. package/dist-es/toolbar/ToolbarButton.js +1 -1
  642. package/dist-es/toolbar/ToolbarButton.js.map +1 -1
  643. package/dist-es/toolbar/Tooltray.js +3 -3
  644. package/dist-es/toolbar/Tooltray.js.map +1 -1
  645. package/dist-es/toolbar/internal/renderToolbarItems.js +3 -3
  646. package/dist-es/toolbar/internal/renderToolbarItems.js.map +1 -1
  647. package/dist-es/toolbar/internal/renderTrayTools.js.map +1 -1
  648. package/dist-es/toolbar/overflow-panel/OverflowPanel.css.js +1 -1
  649. package/dist-es/toolbar/overflow-panel/OverflowPanel.js +5 -5
  650. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  651. package/dist-es/toolbar/overflow-panel/OverflowSeparator.css.js +1 -1
  652. package/dist-es/toolbar/toolbar-field/ToolbarField.js +1 -1
  653. package/dist-es/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  654. package/dist-es/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  655. package/dist-es/tree/Tree.js +4 -4
  656. package/dist-es/tree/Tree.js.map +1 -1
  657. package/dist-es/tree/TreeNode.js +2 -2
  658. package/dist-es/tree/TreeNode.js.map +1 -1
  659. package/dist-es/tree/useTree.js +2 -2
  660. package/dist-es/tree/useTree.js.map +1 -1
  661. package/dist-es/utils/useEventCallback.js +1 -1
  662. package/dist-es/utils/useEventCallback.js.map +1 -1
  663. package/dist-es/window/ElectronWindow.js +4 -4
  664. package/dist-es/window/ElectronWindow.js.map +1 -1
  665. package/dist-types/app-header/AppHeader.d.ts +1 -1
  666. package/dist-types/button-bar/ButtonBar.d.ts +4 -4
  667. package/dist-types/calendar/Calendar.d.ts +43 -7
  668. package/dist-types/calendar/CalendarGrid.d.ts +2 -2
  669. package/dist-types/calendar/CalendarMonthHeader.d.ts +1 -1
  670. package/dist-types/calendar/CalendarWeekHeader.d.ts +1 -1
  671. package/dist-types/calendar/index.d.ts +3 -3
  672. package/dist-types/calendar/useCalendar.d.ts +23 -24
  673. package/dist-types/calendar/useCalendarDay.d.ts +2 -1
  674. package/dist-types/calendar/useCalendarSelection.d.ts +154 -60
  675. package/dist-types/cascading-menu/internal/CascadingMenuAction.d.ts +2 -2
  676. package/dist-types/cascading-menu/internal/menuPositioning.d.ts +1 -1
  677. package/dist-types/cascading-menu/internal/stateUtils.d.ts +2 -2
  678. package/dist-types/cascading-menu/internal/useClickAway.d.ts +1 -1
  679. package/dist-types/cascading-menu/internal/useRefsManager.d.ts +1 -1
  680. package/dist-types/cascading-menu/internal/useStateReducer.d.ts +2 -2
  681. package/dist-types/cascading-menu/stateChangeTypes.d.ts +1 -1
  682. package/dist-types/color-chooser/Color.d.ts +1 -1
  683. package/dist-types/color-chooser/DictTabs.d.ts +1 -1
  684. package/dist-types/color-chooser/color-utils.d.ts +1 -1
  685. package/dist-types/color-chooser/index.d.ts +4 -4
  686. package/dist-types/combo-box/ComboBox.d.ts +4 -4
  687. package/dist-types/combo-box/useCombobox.d.ts +1 -1
  688. package/dist-types/combo-box-deprecated/ComboBoxDeprecated.d.ts +3 -3
  689. package/dist-types/combo-box-deprecated/filterHelpers.d.ts +1 -1
  690. package/dist-types/combo-box-deprecated/internal/DefaultComboBox.d.ts +1 -1
  691. package/dist-types/combo-box-deprecated/internal/MultiSelectComboBox.d.ts +1 -1
  692. package/dist-types/combo-box-deprecated/internal/useComboBox.d.ts +98 -97
  693. package/dist-types/combo-box-deprecated/internal/useMultiSelectComboBox.d.ts +214 -212
  694. package/dist-types/combo-box-deprecated/internal/usePopperStatus.d.ts +3 -3
  695. package/dist-types/common-hooks/collectionTypes.d.ts +3 -3
  696. package/dist-types/common-hooks/index.d.ts +2 -2
  697. package/dist-types/common-hooks/itemToString.d.ts +1 -1
  698. package/dist-types/common-hooks/navigationTypes.d.ts +4 -4
  699. package/dist-types/common-hooks/selectionTypes.d.ts +10 -10
  700. package/dist-types/common-hooks/useKeyboardNavigation.d.ts +1 -1
  701. package/dist-types/common-hooks/useSelection.d.ts +2 -2
  702. package/dist-types/common-hooks/utils/collection-item-utils.d.ts +2 -2
  703. package/dist-types/common-hooks/utils/filter-utils.d.ts +2 -2
  704. package/dist-types/contact-details/ContactAction.d.ts +1 -1
  705. package/dist-types/contact-details/ContactAvatar.d.ts +1 -1
  706. package/dist-types/contact-details/ContactDetails.d.ts +1 -1
  707. package/dist-types/contact-details/index.d.ts +1 -1
  708. package/dist-types/contact-details/internal/index.d.ts +1 -1
  709. package/dist-types/content-status/internal/StatusIndicator.d.ts +1 -2
  710. package/dist-types/date-input/DateInputRange.d.ts +2 -2
  711. package/dist-types/date-input/DateInputSingle.d.ts +1 -1
  712. package/dist-types/date-input/index.d.ts +1 -1
  713. package/dist-types/date-picker/DatePicker.d.ts +1 -1
  714. package/dist-types/date-picker/DatePickerActions.d.ts +1 -1
  715. package/dist-types/date-picker/DatePickerContext.d.ts +1 -1
  716. package/dist-types/date-picker/DatePickerOverlayProvider.d.ts +1 -1
  717. package/dist-types/date-picker/DatePickerRangeGridPanel.d.ts +3 -4
  718. package/dist-types/date-picker/DatePickerSingleGridPanel.d.ts +2 -3
  719. package/dist-types/date-picker/DatePickerSinglePanel.d.ts +1 -1
  720. package/dist-types/date-picker/index.d.ts +3 -3
  721. package/dist-types/date-picker/useDatePicker.d.ts +1 -1
  722. package/dist-types/deck-layout/DeckLayout.d.ts +3 -3
  723. package/dist-types/dropdown/Dropdown.d.ts +3 -3
  724. package/dist-types/dropdown/DropdownBase.d.ts +1 -1
  725. package/dist-types/dropdown/dropdownTypes.d.ts +1 -1
  726. package/dist-types/dropdown/index.d.ts +1 -1
  727. package/dist-types/dropdown/useClickAway.d.ts +1 -1
  728. package/dist-types/dropdown/useDropdown.d.ts +1 -1
  729. package/dist-types/focus-manager/internal/findAllTabbableElements.d.ts +1 -1
  730. package/dist-types/form-field-legacy/FormFieldLegacy.d.ts +5 -5
  731. package/dist-types/form-field-legacy/NecessityIndicator.d.ts +1 -1
  732. package/dist-types/form-field-legacy/StatusIndicator.d.ts +1 -1
  733. package/dist-types/formatted-input/FormattedInput.d.ts +1 -1
  734. package/dist-types/index.d.ts +5 -6
  735. package/dist-types/input-legacy/StaticInputAdornment.d.ts +1 -1
  736. package/dist-types/layer-layout/LayerLayout.d.ts +1 -1
  737. package/dist-types/list/List.d.ts +3 -3
  738. package/dist-types/list/ListItem.d.ts +1 -1
  739. package/dist-types/list/VirtualizedList.d.ts +3 -3
  740. package/dist-types/list/index.d.ts +3 -3
  741. package/dist-types/list/listTypes.d.ts +2 -2
  742. package/dist-types/list/useList.d.ts +1 -1
  743. package/dist-types/list/useVirtualization.d.ts +1 -1
  744. package/dist-types/list-deprecated/List.d.ts +2 -2
  745. package/dist-types/list-deprecated/ListBase.d.ts +2 -2
  746. package/dist-types/list-deprecated/ListItem.d.ts +1 -1
  747. package/dist-types/list-deprecated/ListItemContext.d.ts +1 -1
  748. package/dist-types/list-deprecated/ListProps.d.ts +5 -5
  749. package/dist-types/list-deprecated/index.d.ts +3 -3
  750. package/dist-types/list-deprecated/internal/DescendantContext.d.ts +13 -6
  751. package/dist-types/list-deprecated/itemToString.d.ts +1 -1
  752. package/dist-types/list-deprecated/useListItem.d.ts +2 -2
  753. package/dist-types/list-next/index.d.ts +1 -1
  754. package/dist-types/localization-provider/LocalizationProvider.d.ts +3 -3
  755. package/dist-types/logo/Logo.d.ts +1 -1
  756. package/dist-types/logo/LogoSeparator.d.ts +1 -1
  757. package/dist-types/metric/index.d.ts +1 -1
  758. package/dist-types/metric/internal/index.d.ts +1 -1
  759. package/dist-types/number-input/NumberInput.d.ts +49 -27
  760. package/dist-types/number-input/index.d.ts +1 -1
  761. package/dist-types/number-input/internal/useCaret.d.ts +5 -0
  762. package/dist-types/number-input/internal/useInterval.d.ts +1 -1
  763. package/dist-types/number-input/internal/utils.d.ts +5 -5
  764. package/dist-types/number-input/useNumberInput.d.ts +11 -6
  765. package/dist-types/query-input/index.d.ts +1 -1
  766. package/dist-types/query-input/useQueryInput.d.ts +2 -2
  767. package/dist-types/responsive/OverflowReducer.d.ts +4 -4
  768. package/dist-types/responsive/index.d.ts +5 -5
  769. package/dist-types/responsive/overflowTypes.d.ts +20 -20
  770. package/dist-types/responsive/overflowUtils.d.ts +3 -3
  771. package/dist-types/responsive/useOverflowCollectionItems.d.ts +1 -1
  772. package/dist-types/responsive/useOverflowLayout.d.ts +1 -1
  773. package/dist-types/responsive/useResizeObserver.d.ts +2 -2
  774. package/dist-types/responsive/utils.d.ts +3 -3
  775. package/dist-types/system-status/index.d.ts +1 -1
  776. package/dist-types/tabs/Tab.d.ts +20 -19
  777. package/dist-types/tabs/Tabs.d.ts +1 -1
  778. package/dist-types/tabs/TabsTypes.d.ts +7 -7
  779. package/dist-types/tabs/drag-drop/Draggable.d.ts +2 -2
  780. package/dist-types/tabs/drag-drop/DropIndicator.d.ts +1 -1
  781. package/dist-types/tabs/drag-drop/drag-utils.d.ts +26 -22
  782. package/dist-types/tabs/drag-drop/dragDropTypes.d.ts +5 -5
  783. package/dist-types/tabs/drag-drop/useDragSpacers.d.ts +1 -1
  784. package/dist-types/tabs/index.d.ts +2 -2
  785. package/dist-types/tabs/useActivationIndicator.d.ts +1 -1
  786. package/dist-types/tabs/useEditableItem.d.ts +1 -1
  787. package/dist-types/tabs/useKeyboardNavigation.d.ts +1 -1
  788. package/dist-types/tabs/useSelection.d.ts +3 -3
  789. package/dist-types/tabs/useTabstrip.d.ts +1 -1
  790. package/dist-types/tabs-next/hooks/useCollection.d.ts +1 -1
  791. package/dist-types/tabs-next/index.d.ts +4 -4
  792. package/dist-types/tokenized-input/TokenizedInput.d.ts +2 -2
  793. package/dist-types/tokenized-input/TokenizedInputBase.d.ts +5 -5
  794. package/dist-types/tokenized-input/internal/InputPill.d.ts +1 -1
  795. package/dist-types/tokenized-input/internal/isPlainObject.d.ts +1 -1
  796. package/dist-types/tokenized-input/useTokenizedInput.d.ts +1 -1
  797. package/dist-types/tokenized-input-next/TokenizedInputNext.d.ts +2 -2
  798. package/dist-types/tokenized-input-next/internal/InputPill.d.ts +1 -1
  799. package/dist-types/toolbar/ToolbarButton.d.ts +3 -3
  800. package/dist-types/toolbar/ToolbarProps.d.ts +1 -1
  801. package/dist-types/toolbar/TooltrayProps.d.ts +2 -2
  802. package/dist-types/toolbar/index.d.ts +1 -1
  803. package/dist-types/toolbar/internal/ToolbarButtonRefsContext.d.ts +1 -1
  804. package/dist-types/toolbar/internal/renderTrayTools.d.ts +1 -1
  805. package/dist-types/tree/useTree.d.ts +1 -1
  806. package/dist-types/utils/forwardCallbackProps.d.ts +1 -1
  807. package/dist-types/utils/index.d.ts +1 -1
  808. package/dist-types/utils/isEmail.d.ts +1 -1
  809. package/dist-types/utils/useClickOutside.d.ts +1 -1
  810. package/dist-types/utils/useSlideSelection.d.ts +1 -1
  811. package/dist-types/window/ElectronWindow.d.ts +1 -1
  812. package/dist-types/window/WindowContext.d.ts +4 -4
  813. package/dist-types/window/index.d.ts +1 -1
  814. package/package.json +7 -6
  815. package/dist-cjs/carousel/Carousel.css.js +0 -6
  816. package/dist-cjs/carousel/Carousel.css.js.map +0 -1
  817. package/dist-cjs/carousel/Carousel.js +0 -62
  818. package/dist-cjs/carousel/Carousel.js.map +0 -1
  819. package/dist-cjs/carousel/CarouselContext.js +0 -62
  820. package/dist-cjs/carousel/CarouselContext.js.map +0 -1
  821. package/dist-cjs/carousel/CarouselControls.css.js +0 -6
  822. package/dist-cjs/carousel/CarouselControls.css.js.map +0 -1
  823. package/dist-cjs/carousel/CarouselControls.js +0 -122
  824. package/dist-cjs/carousel/CarouselControls.js.map +0 -1
  825. package/dist-cjs/carousel/CarouselReducer.js +0 -77
  826. package/dist-cjs/carousel/CarouselReducer.js.map +0 -1
  827. package/dist-cjs/carousel/CarouselSlide.css.js +0 -6
  828. package/dist-cjs/carousel/CarouselSlide.css.js.map +0 -1
  829. package/dist-cjs/carousel/CarouselSlide.js +0 -110
  830. package/dist-cjs/carousel/CarouselSlide.js.map +0 -1
  831. package/dist-cjs/carousel/CarouselSlider.css.js +0 -6
  832. package/dist-cjs/carousel/CarouselSlider.css.js.map +0 -1
  833. package/dist-cjs/carousel/CarouselSlider.js +0 -93
  834. package/dist-cjs/carousel/CarouselSlider.js.map +0 -1
  835. package/dist-es/carousel/Carousel.css.js +0 -4
  836. package/dist-es/carousel/Carousel.css.js.map +0 -1
  837. package/dist-es/carousel/Carousel.js +0 -60
  838. package/dist-es/carousel/Carousel.js.map +0 -1
  839. package/dist-es/carousel/CarouselContext.js +0 -58
  840. package/dist-es/carousel/CarouselContext.js.map +0 -1
  841. package/dist-es/carousel/CarouselControls.css.js +0 -4
  842. package/dist-es/carousel/CarouselControls.css.js.map +0 -1
  843. package/dist-es/carousel/CarouselControls.js +0 -120
  844. package/dist-es/carousel/CarouselControls.js.map +0 -1
  845. package/dist-es/carousel/CarouselReducer.js +0 -75
  846. package/dist-es/carousel/CarouselReducer.js.map +0 -1
  847. package/dist-es/carousel/CarouselSlide.css.js +0 -4
  848. package/dist-es/carousel/CarouselSlide.css.js.map +0 -1
  849. package/dist-es/carousel/CarouselSlide.js +0 -108
  850. package/dist-es/carousel/CarouselSlide.js.map +0 -1
  851. package/dist-es/carousel/CarouselSlider.css.js +0 -4
  852. package/dist-es/carousel/CarouselSlider.css.js.map +0 -1
  853. package/dist-es/carousel/CarouselSlider.js +0 -91
  854. package/dist-es/carousel/CarouselSlider.js.map +0 -1
  855. package/dist-types/carousel/Carousel.d.ts +0 -23
  856. package/dist-types/carousel/CarouselContext.d.ts +0 -11
  857. package/dist-types/carousel/CarouselControls.d.ts +0 -26
  858. package/dist-types/carousel/CarouselReducer.d.ts +0 -30
  859. package/dist-types/carousel/CarouselSlide.d.ts +0 -32
  860. package/dist-types/carousel/CarouselSlider.d.ts +0 -13
  861. package/dist-types/carousel/index.d.ts +0 -4
@@ -1 +1 @@
1
- {"version":3,"file":"LogoSeparator.js","sources":["../src/logo/LogoSeparator.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport logoSeparatorCss from \"./LogoSeparator.css\";\n\nexport type LogoSeparatorProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogoSeparator\");\n\nexport const LogoSeparator = forwardRef<HTMLImageElement, LogoSeparatorProps>(\n function LogoSeparator(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-separator\",\n css: logoSeparatorCss,\n window: targetWindow,\n });\n\n return (\n <span {...rest} className={clsx(withBaseName(), className)} ref={ref} />\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","LogoSeparator","useWindow","useComponentCssInjection","logoSeparatorCss","jsx","clsx"],"mappings":";;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,SAAA,EAAW,GAAG,IAAA,EAAS,GAAA,KAAA;AAE/B,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IACE,uBAAAC,cAAA,CAAC,MAAM,EAAA,EAAA,GAAG,IAAM,EAAA,SAAA,EAAWC,UAAK,YAAa,EAAA,EAAG,SAAS,CAAA,EAAG,GAAU,EAAA,CAAA;AAAA;AAG5E;;;;"}
1
+ {"version":3,"file":"LogoSeparator.js","sources":["../src/logo/LogoSeparator.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithoutRef, forwardRef } from \"react\";\n\nimport logoSeparatorCss from \"./LogoSeparator.css\";\n\nexport type LogoSeparatorProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogoSeparator\");\n\nexport const LogoSeparator = forwardRef<HTMLImageElement, LogoSeparatorProps>(\n function LogoSeparator(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-separator\",\n css: logoSeparatorCss,\n window: targetWindow,\n });\n\n return (\n <span {...rest} className={clsx(withBaseName(), className)} ref={ref} />\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","LogoSeparator","useWindow","useComponentCssInjection","logoSeparatorCss","jsx","clsx"],"mappings":";;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAA,MAAM,EAAE,SAAA,EAAW,GAAG,IAAA,EAAS,GAAA,KAAA;AAE/B,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IACE,uBAAAC,cAAA,CAAC,MAAM,EAAA,EAAA,GAAG,IAAM,EAAA,SAAA,EAAWC,UAAK,YAAa,EAAA,EAAG,SAAS,CAAA,EAAG,GAAU,EAAA,CAAA;AAAA;AAG5E;;;;"}
@@ -5,8 +5,8 @@ var styles = require('@salt-ds/styles');
5
5
  var window = require('@salt-ds/window');
6
6
  var react = require('react');
7
7
  var CascadingMenu = require('../cascading-menu/CascadingMenu.js');
8
- var MenuButtonTrigger = require('./MenuButtonTrigger.js');
9
8
  var MenuButton$1 = require('./MenuButton.css.js');
9
+ var MenuButtonTrigger = require('./MenuButtonTrigger.js');
10
10
 
11
11
  const MenuButton = react.forwardRef(
12
12
  function MenuButton2({ variant = "secondary", CascadingMenuProps = {}, children, ...restProps }, ref) {
@@ -1 +1 @@
1
- {"version":3,"file":"MenuButton.js","sources":["../src/menu-button/MenuButton.tsx"],"sourcesContent":["import type { ButtonProps } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { type ReactNode, forwardRef, useCallback, useState } from \"react\";\nimport { CascadingMenu, type CascadingMenuProps } from \"../cascading-menu\";\nimport { MenuButtonTrigger } from \"./MenuButtonTrigger\";\n\nimport menuButtonCss from \"./MenuButton.css\";\n\nexport interface MenuButtonProps extends ButtonProps {\n CascadingMenuProps: CascadingMenuProps;\n children: ReactNode;\n className?: string;\n hideCaret?: boolean;\n}\n\nexport const MenuButton = forwardRef<HTMLButtonElement, MenuButtonProps>(\n function MenuButton(\n { variant = \"secondary\", CascadingMenuProps = {}, children, ...restProps },\n ref,\n ) {\n const {\n initialSource = { menuItems: [] },\n onOpen,\n onClose,\n ...restMenuProps\n } = CascadingMenuProps;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-menu-button\",\n css: menuButtonCss,\n window: targetWindow,\n });\n\n const [isMenuOpen, setMenuOpen] = useState(false);\n\n const handleOpen = useCallback(() => {\n setMenuOpen(true);\n onOpen?.();\n }, [onOpen]);\n\n const handleClose = useCallback(() => {\n setMenuOpen(false);\n onClose?.();\n }, [onClose]);\n\n return (\n <CascadingMenu\n initialSource={initialSource}\n onClose={handleClose}\n onOpen={handleOpen}\n {...restMenuProps}\n >\n <MenuButtonTrigger\n aria-expanded={isMenuOpen}\n aria-haspopup\n isMenuOpen={isMenuOpen}\n ref={ref}\n variant={variant}\n {...restProps}\n >\n {children}\n </MenuButtonTrigger>\n </CascadingMenu>\n );\n },\n);\n"],"names":["forwardRef","MenuButton","useWindow","useComponentCssInjection","menuButtonCss","useState","useCallback","jsx","CascadingMenu","MenuButtonTrigger"],"mappings":";;;;;;;;;;AAgBO,MAAM,UAAa,GAAAA,gBAAA;AAAA,EACxB,SAASC,WAAAA,CACP,EAAE,OAAA,GAAU,WAAa,EAAA,kBAAA,GAAqB,EAAC,EAAG,QAAU,EAAA,GAAG,SAAU,EAAA,EACzE,GACA,EAAA;AACA,IAAM,MAAA;AAAA,MACJ,aAAgB,GAAA,EAAE,SAAW,EAAA,EAAG,EAAA;AAAA,MAChC,MAAA;AAAA,MACA,OAAA;AAAA,MACA,GAAG;AAAA,KACD,GAAA,kBAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,kBAAA;AAAA,MACR,GAAK,EAAAC,YAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,CAAC,UAAA,EAAY,WAAW,CAAA,GAAIC,eAAS,KAAK,CAAA;AAEhD,IAAM,MAAA,UAAA,GAAaC,kBAAY,MAAM;AACnC,MAAA,WAAA,CAAY,IAAI,CAAA;AAChB,MAAA,MAAA,IAAA,IAAA,GAAA,MAAA,GAAA,MAAA,EAAA;AAAA,KACF,EAAG,CAAC,MAAM,CAAC,CAAA;AAEX,IAAM,MAAA,WAAA,GAAcA,kBAAY,MAAM;AACpC,MAAA,WAAA,CAAY,KAAK,CAAA;AACjB,MAAA,OAAA,IAAA,IAAA,GAAA,MAAA,GAAA,OAAA,EAAA;AAAA,KACF,EAAG,CAAC,OAAO,CAAC,CAAA;AAEZ,IACE,uBAAAC,cAAA;AAAA,MAACC,2BAAA;AAAA,MAAA;AAAA,QACC,aAAA;AAAA,QACA,OAAS,EAAA,WAAA;AAAA,QACT,MAAQ,EAAA,UAAA;AAAA,QACP,GAAG,aAAA;AAAA,QAEJ,QAAA,kBAAAD,cAAA;AAAA,UAACE,mCAAA;AAAA,UAAA;AAAA,YACC,eAAe,EAAA,UAAA;AAAA,YACf,eAAa,EAAA,IAAA;AAAA,YACb,UAAA;AAAA,YACA,GAAA;AAAA,YACA,OAAA;AAAA,YACC,GAAG,SAAA;AAAA,YAEH;AAAA;AAAA;AACH;AAAA,KACF;AAAA;AAGN;;;;"}
1
+ {"version":3,"file":"MenuButton.js","sources":["../src/menu-button/MenuButton.tsx"],"sourcesContent":["import type { ButtonProps } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { forwardRef, type ReactNode, useCallback, useState } from \"react\";\nimport { CascadingMenu, type CascadingMenuProps } from \"../cascading-menu\";\nimport menuButtonCss from \"./MenuButton.css\";\nimport { MenuButtonTrigger } from \"./MenuButtonTrigger\";\n\nexport interface MenuButtonProps extends ButtonProps {\n CascadingMenuProps: CascadingMenuProps;\n children: ReactNode;\n className?: string;\n hideCaret?: boolean;\n}\n\nexport const MenuButton = forwardRef<HTMLButtonElement, MenuButtonProps>(\n function MenuButton(\n { variant = \"secondary\", CascadingMenuProps = {}, children, ...restProps },\n ref,\n ) {\n const {\n initialSource = { menuItems: [] },\n onOpen,\n onClose,\n ...restMenuProps\n } = CascadingMenuProps;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-menu-button\",\n css: menuButtonCss,\n window: targetWindow,\n });\n\n const [isMenuOpen, setMenuOpen] = useState(false);\n\n const handleOpen = useCallback(() => {\n setMenuOpen(true);\n onOpen?.();\n }, [onOpen]);\n\n const handleClose = useCallback(() => {\n setMenuOpen(false);\n onClose?.();\n }, [onClose]);\n\n return (\n <CascadingMenu\n initialSource={initialSource}\n onClose={handleClose}\n onOpen={handleOpen}\n {...restMenuProps}\n >\n <MenuButtonTrigger\n aria-expanded={isMenuOpen}\n aria-haspopup\n isMenuOpen={isMenuOpen}\n ref={ref}\n variant={variant}\n {...restProps}\n >\n {children}\n </MenuButtonTrigger>\n </CascadingMenu>\n );\n },\n);\n"],"names":["forwardRef","MenuButton","useWindow","useComponentCssInjection","menuButtonCss","useState","useCallback","jsx","CascadingMenu","MenuButtonTrigger"],"mappings":";;;;;;;;;;AAeO,MAAM,UAAa,GAAAA,gBAAA;AAAA,EACxB,SAASC,WAAAA,CACP,EAAE,OAAA,GAAU,WAAa,EAAA,kBAAA,GAAqB,EAAC,EAAG,QAAU,EAAA,GAAG,SAAU,EAAA,EACzE,GACA,EAAA;AACA,IAAM,MAAA;AAAA,MACJ,aAAgB,GAAA,EAAE,SAAW,EAAA,EAAG,EAAA;AAAA,MAChC,MAAA;AAAA,MACA,OAAA;AAAA,MACA,GAAG;AAAA,KACD,GAAA,kBAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,kBAAA;AAAA,MACR,GAAK,EAAAC,YAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,CAAC,UAAA,EAAY,WAAW,CAAA,GAAIC,eAAS,KAAK,CAAA;AAEhD,IAAM,MAAA,UAAA,GAAaC,kBAAY,MAAM;AACnC,MAAA,WAAA,CAAY,IAAI,CAAA;AAChB,MAAA,MAAA,IAAA,IAAA,GAAA,MAAA,GAAA,MAAA,EAAA;AAAA,KACF,EAAG,CAAC,MAAM,CAAC,CAAA;AAEX,IAAM,MAAA,WAAA,GAAcA,kBAAY,MAAM;AACpC,MAAA,WAAA,CAAY,KAAK,CAAA;AACjB,MAAA,OAAA,IAAA,IAAA,GAAA,MAAA,GAAA,OAAA,EAAA;AAAA,KACF,EAAG,CAAC,OAAO,CAAC,CAAA;AAEZ,IACE,uBAAAC,cAAA;AAAA,MAACC,2BAAA;AAAA,MAAA;AAAA,QACC,aAAA;AAAA,QACA,OAAS,EAAA,WAAA;AAAA,QACT,MAAQ,EAAA,UAAA;AAAA,QACP,GAAG,aAAA;AAAA,QAEJ,QAAA,kBAAAD,cAAA;AAAA,UAACE,mCAAA;AAAA,UAAA;AAAA,YACC,eAAe,EAAA,UAAA;AAAA,YACf,eAAa,EAAA,IAAA;AAAA,YACb,UAAA;AAAA,YACA,GAAA;AAAA,YACA,OAAA;AAAA,YACC,GAAG,SAAA;AAAA,YAEH;AAAA;AAAA;AACH;AAAA,KACF;AAAA;AAGN;;;;"}
@@ -2,10 +2,10 @@
2
2
 
3
3
  var jsxRuntime = require('react/jsx-runtime');
4
4
  var core = require('@salt-ds/core');
5
- var clsx = require('clsx');
6
- var react = require('react');
7
5
  var styles = require('@salt-ds/styles');
8
6
  var window = require('@salt-ds/window');
7
+ var clsx = require('clsx');
8
+ var react = require('react');
9
9
  var MenuButtonTrigger$1 = require('./MenuButtonTrigger.css.js');
10
10
 
11
11
  const withBaseName = core.makePrefixer("saltMenuButtonTrigger");
@@ -1 +1 @@
1
- {"version":3,"file":"MenuButtonTrigger.js","sources":["../src/menu-button/MenuButtonTrigger.tsx"],"sourcesContent":["import { Button, type ButtonProps, makePrefixer, useIcon } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ReactNode, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport menuButtonTrigger from \"./MenuButtonTrigger.css\";\n\nconst withBaseName = makePrefixer(\"saltMenuButtonTrigger\");\n\nexport interface MenuButtonTriggerProps extends ButtonProps {\n className?: string;\n hideCaret?: boolean;\n isMenuOpen?: boolean;\n children?: ReactNode;\n}\n\nexport const MenuButtonTrigger = forwardRef<\n HTMLButtonElement,\n MenuButtonTriggerProps\n>(function MenuButtonTrigger(\n { className, hideCaret, isMenuOpen, children, ...rest },\n ref,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-menu-button-trigger\",\n css: menuButtonTrigger,\n window: targetWindow,\n });\n const { ExpandIcon } = useIcon();\n\n return (\n <Button\n ref={ref}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"buttonOpen\")]: isMenuOpen,\n })}\n data-testid=\"menu-button-trigger\"\n {...rest}\n >\n {children}\n {!hideCaret && (\n <ExpandIcon\n className={withBaseName(\"caretIcon\")}\n data-testid=\"menu-button-trigger-caret\"\n />\n )}\n </Button>\n );\n});\n"],"names":["makePrefixer","forwardRef","MenuButtonTrigger","useWindow","useComponentCssInjection","menuButtonTrigger","useIcon","jsxs","Button","clsx","jsx"],"mappings":";;;;;;;;;;AASA,MAAM,YAAA,GAAeA,kBAAa,uBAAuB,CAAA;AASlD,MAAM,iBAAoB,GAAAC,gBAAA,CAG/B,SAASC,kBAAAA,CACT,EAAE,SAAA,EAAW,SAAW,EAAA,UAAA,EAAY,QAAU,EAAA,GAAG,IAAK,EAAA,EACtD,GACA,EAAA;AACA,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,0BAAA;AAAA,IACR,GAAK,EAAAC,mBAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AACD,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIC,YAAQ,EAAA;AAE/B,EACE,uBAAAC,eAAA;AAAA,IAACC,WAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAW,EAAA;AAAA,QACzC,CAAC,YAAA,CAAa,YAAY,CAAC,GAAG;AAAA,OAC/B,CAAA;AAAA,MACD,aAAY,EAAA,qBAAA;AAAA,MACX,GAAG,IAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,QAAA;AAAA,QACA,CAAC,SACA,oBAAAC,cAAA;AAAA,UAAC,UAAA;AAAA,UAAA;AAAA,YACC,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,YACnC,aAAY,EAAA;AAAA;AAAA;AACd;AAAA;AAAA,GAEJ;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"MenuButtonTrigger.js","sources":["../src/menu-button/MenuButtonTrigger.tsx"],"sourcesContent":["import { Button, type ButtonProps, makePrefixer, useIcon } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { forwardRef, type ReactNode } from \"react\";\n\nimport menuButtonTrigger from \"./MenuButtonTrigger.css\";\n\nconst withBaseName = makePrefixer(\"saltMenuButtonTrigger\");\n\nexport interface MenuButtonTriggerProps extends ButtonProps {\n className?: string;\n hideCaret?: boolean;\n isMenuOpen?: boolean;\n children?: ReactNode;\n}\n\nexport const MenuButtonTrigger = forwardRef<\n HTMLButtonElement,\n MenuButtonTriggerProps\n>(function MenuButtonTrigger(\n { className, hideCaret, isMenuOpen, children, ...rest },\n ref,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-menu-button-trigger\",\n css: menuButtonTrigger,\n window: targetWindow,\n });\n const { ExpandIcon } = useIcon();\n\n return (\n <Button\n ref={ref}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"buttonOpen\")]: isMenuOpen,\n })}\n data-testid=\"menu-button-trigger\"\n {...rest}\n >\n {children}\n {!hideCaret && (\n <ExpandIcon\n className={withBaseName(\"caretIcon\")}\n data-testid=\"menu-button-trigger-caret\"\n />\n )}\n </Button>\n );\n});\n"],"names":["makePrefixer","forwardRef","MenuButtonTrigger","useWindow","useComponentCssInjection","menuButtonTrigger","useIcon","jsxs","Button","clsx","jsx"],"mappings":";;;;;;;;;;AAQA,MAAM,YAAA,GAAeA,kBAAa,uBAAuB,CAAA;AASlD,MAAM,iBAAoB,GAAAC,gBAAA,CAG/B,SAASC,kBAAAA,CACT,EAAE,SAAA,EAAW,SAAW,EAAA,UAAA,EAAY,QAAU,EAAA,GAAG,IAAK,EAAA,EACtD,GACA,EAAA;AACA,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,0BAAA;AAAA,IACR,GAAK,EAAAC,mBAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AACD,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIC,YAAQ,EAAA;AAE/B,EACE,uBAAAC,eAAA;AAAA,IAACC,WAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAW,EAAA;AAAA,QACzC,CAAC,YAAA,CAAa,YAAY,CAAC,GAAG;AAAA,OAC/B,CAAA;AAAA,MACD,aAAY,EAAA,qBAAA;AAAA,MACX,GAAG,IAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,QAAA;AAAA,QACA,CAAC,SACA,oBAAAC,cAAA;AAAA,UAAC,UAAA;AAAA,UAAA;AAAA,YACC,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,YACnC,aAAY,EAAA;AAAA;AAAA;AACd;AAAA;AAAA,GAEJ;AAEJ,CAAC;;;;"}
@@ -2,11 +2,11 @@
2
2
 
3
3
  var jsxRuntime = require('react/jsx-runtime');
4
4
  var core = require('@salt-ds/core');
5
+ var styles = require('@salt-ds/styles');
6
+ var window = require('@salt-ds/window');
5
7
  var clsx = require('clsx');
6
8
  var react = require('react');
7
9
  var MetricContext = require('./internal/MetricContext.js');
8
- var styles = require('@salt-ds/styles');
9
- var window = require('@salt-ds/window');
10
10
  var Metric$1 = require('./Metric.css.js');
11
11
 
12
12
  const withBaseName = core.makePrefixer("saltMetric");
@@ -1 +1 @@
1
- {"version":3,"file":"Metric.js","sources":["../src/metric/Metric.tsx"],"sourcesContent":["import { makePrefixer, useId } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef, useMemo } from \"react\";\nimport { MetricContextProvider, type MetricContextValue } from \"./internal\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport metricCSS from \"./Metric.css\";\n\nconst withBaseName = makePrefixer(\"saltMetric\");\n\nexport interface MetricProps\n extends MetricContextValue,\n HTMLAttributes<HTMLDivElement> {\n /**\n * The aria-level attribute to be applied to the heading component. The default is 2.\n *\n * As an ADA requirement, the heading component should be the first valid component inside the Metric. It is the title\n * if <MetricHeader/> is placed before <MerticContent/>. It is the main value if <MerticContent/> is placed before <MetricHeader/>.\n */\n headingAriaLevel?: number;\n /**\n * This prop is used to help implement the accessibility logic.\n * If you don't provide this prop. It falls back to a randomly generated id.\n */\n id?: string;\n}\n\nexport const Metric = forwardRef<HTMLDivElement, MetricProps>(function Metric(\n {\n className,\n children,\n direction,\n showIndicator,\n align = \"left\",\n orientation = \"vertical\",\n indicatorPosition = \"end\",\n headingAriaLevel = 2,\n id: idProp,\n size = \"medium\",\n ...restProps\n },\n ref,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-metric\",\n css: metricCSS,\n window: targetWindow,\n });\n\n const id = useId(idProp);\n const titleId = `metric-title-${id}`;\n const subtitleId = `metric-subtitle-${id}`;\n const valueId = `metric-value-${id}`;\n\n const value = useMemo(\n () => ({\n align,\n direction,\n orientation,\n showIndicator,\n indicatorPosition,\n headingAriaLevel,\n size,\n titleId,\n subtitleId,\n valueId,\n }),\n [\n align,\n direction,\n orientation,\n showIndicator,\n indicatorPosition,\n headingAriaLevel,\n size,\n titleId,\n subtitleId,\n valueId,\n ],\n );\n\n return (\n <MetricContextProvider value={value}>\n <div\n {...restProps}\n className={clsx(\n withBaseName(),\n withBaseName(`size-${size}`),\n {\n [withBaseName(`direction-${direction}`)]: direction,\n [withBaseName(`orientation-${orientation}`)]: orientation,\n [withBaseName(`align-${align}`)]: align,\n },\n className,\n )}\n id={id}\n ref={ref}\n >\n {children}\n </div>\n </MetricContextProvider>\n );\n});\n"],"names":["makePrefixer","forwardRef","Metric","useWindow","useComponentCssInjection","metricCSS","useId","useMemo","jsx","MetricContextProvider","clsx"],"mappings":";;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,kBAAa,YAAY,CAAA;AAmBjC,MAAA,MAAA,GAASC,gBAAwC,CAAA,SAASC,OACrE,CAAA;AAAA,EACE,SAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,aAAA;AAAA,EACA,KAAQ,GAAA,MAAA;AAAA,EACR,WAAc,GAAA,UAAA;AAAA,EACd,iBAAoB,GAAA,KAAA;AAAA,EACpB,gBAAmB,GAAA,CAAA;AAAA,EACnB,EAAI,EAAA,MAAA;AAAA,EACJ,IAAO,GAAA,QAAA;AAAA,EACP,GAAG;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAM,MAAA,EAAA,GAAKC,WAAM,MAAM,CAAA;AACvB,EAAM,MAAA,OAAA,GAAU,gBAAgB,EAAE,CAAA,CAAA;AAClC,EAAM,MAAA,UAAA,GAAa,mBAAmB,EAAE,CAAA,CAAA;AACxC,EAAM,MAAA,OAAA,GAAU,gBAAgB,EAAE,CAAA,CAAA;AAElC,EAAA,MAAM,KAAQ,GAAAC,aAAA;AAAA,IACZ,OAAO;AAAA,MACL,KAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,aAAA;AAAA,MACA,iBAAA;AAAA,MACA,gBAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA,KACF,CAAA;AAAA,IACA;AAAA,MACE,KAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,aAAA;AAAA,MACA,iBAAA;AAAA,MACA,gBAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA;AACF,GACF;AAEA,EACE,uBAAAC,cAAA,CAACC,uCAAsB,KACrB,EAAA,QAAA,kBAAAD,cAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACE,GAAG,SAAA;AAAA,MACJ,SAAW,EAAAE,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,YAAA,CAAa,CAAQ,KAAA,EAAA,IAAI,CAAE,CAAA,CAAA;AAAA,QAC3B;AAAA,UACE,CAAC,YAAa,CAAA,CAAA,UAAA,EAAa,SAAS,CAAA,CAAE,CAAC,GAAG,SAAA;AAAA,UAC1C,CAAC,YAAa,CAAA,CAAA,YAAA,EAAe,WAAW,CAAA,CAAE,CAAC,GAAG,WAAA;AAAA,UAC9C,CAAC,YAAa,CAAA,CAAA,MAAA,EAAS,KAAK,CAAA,CAAE,CAAC,GAAG;AAAA,SACpC;AAAA,QACA;AAAA,OACF;AAAA,MACA,EAAA;AAAA,MACA,GAAA;AAAA,MAEC;AAAA;AAAA,GAEL,EAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"Metric.js","sources":["../src/metric/Metric.tsx"],"sourcesContent":["import { makePrefixer, useId } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { forwardRef, type HTMLAttributes, useMemo } from \"react\";\nimport { MetricContextProvider, type MetricContextValue } from \"./internal\";\n\nimport metricCSS from \"./Metric.css\";\n\nconst withBaseName = makePrefixer(\"saltMetric\");\n\nexport interface MetricProps\n extends MetricContextValue,\n HTMLAttributes<HTMLDivElement> {\n /**\n * The aria-level attribute to be applied to the heading component. The default is 2.\n *\n * As an ADA requirement, the heading component should be the first valid component inside the Metric. It is the title\n * if <MetricHeader/> is placed before <MerticContent/>. It is the main value if <MerticContent/> is placed before <MetricHeader/>.\n */\n headingAriaLevel?: number;\n /**\n * This prop is used to help implement the accessibility logic.\n * If you don't provide this prop. It falls back to a randomly generated id.\n */\n id?: string;\n}\n\nexport const Metric = forwardRef<HTMLDivElement, MetricProps>(function Metric(\n {\n className,\n children,\n direction,\n showIndicator,\n align = \"left\",\n orientation = \"vertical\",\n indicatorPosition = \"end\",\n headingAriaLevel = 2,\n id: idProp,\n size = \"medium\",\n ...restProps\n },\n ref,\n) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-metric\",\n css: metricCSS,\n window: targetWindow,\n });\n\n const id = useId(idProp);\n const titleId = `metric-title-${id}`;\n const subtitleId = `metric-subtitle-${id}`;\n const valueId = `metric-value-${id}`;\n\n const value = useMemo(\n () => ({\n align,\n direction,\n orientation,\n showIndicator,\n indicatorPosition,\n headingAriaLevel,\n size,\n titleId,\n subtitleId,\n valueId,\n }),\n [\n align,\n direction,\n orientation,\n showIndicator,\n indicatorPosition,\n headingAriaLevel,\n size,\n titleId,\n subtitleId,\n valueId,\n ],\n );\n\n return (\n <MetricContextProvider value={value}>\n <div\n {...restProps}\n className={clsx(\n withBaseName(),\n withBaseName(`size-${size}`),\n {\n [withBaseName(`direction-${direction}`)]: direction,\n [withBaseName(`orientation-${orientation}`)]: orientation,\n [withBaseName(`align-${align}`)]: align,\n },\n className,\n )}\n id={id}\n ref={ref}\n >\n {children}\n </div>\n </MetricContextProvider>\n );\n});\n"],"names":["makePrefixer","forwardRef","Metric","useWindow","useComponentCssInjection","metricCSS","useId","useMemo","jsx","MetricContextProvider","clsx"],"mappings":";;;;;;;;;;;AASA,MAAM,YAAA,GAAeA,kBAAa,YAAY,CAAA;AAmBjC,MAAA,MAAA,GAASC,gBAAwC,CAAA,SAASC,OACrE,CAAA;AAAA,EACE,SAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,aAAA;AAAA,EACA,KAAQ,GAAA,MAAA;AAAA,EACR,WAAc,GAAA,UAAA;AAAA,EACd,iBAAoB,GAAA,KAAA;AAAA,EACpB,gBAAmB,GAAA,CAAA;AAAA,EACnB,EAAI,EAAA,MAAA;AAAA,EACJ,IAAO,GAAA,QAAA;AAAA,EACP,GAAG;AACL,CAAA,EACA,GACA,EAAA;AACA,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,aAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAM,MAAA,EAAA,GAAKC,WAAM,MAAM,CAAA;AACvB,EAAM,MAAA,OAAA,GAAU,gBAAgB,EAAE,CAAA,CAAA;AAClC,EAAM,MAAA,UAAA,GAAa,mBAAmB,EAAE,CAAA,CAAA;AACxC,EAAM,MAAA,OAAA,GAAU,gBAAgB,EAAE,CAAA,CAAA;AAElC,EAAA,MAAM,KAAQ,GAAAC,aAAA;AAAA,IACZ,OAAO;AAAA,MACL,KAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,aAAA;AAAA,MACA,iBAAA;AAAA,MACA,gBAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA,KACF,CAAA;AAAA,IACA;AAAA,MACE,KAAA;AAAA,MACA,SAAA;AAAA,MACA,WAAA;AAAA,MACA,aAAA;AAAA,MACA,iBAAA;AAAA,MACA,gBAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA;AACF,GACF;AAEA,EACE,uBAAAC,cAAA,CAACC,uCAAsB,KACrB,EAAA,QAAA,kBAAAD,cAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACE,GAAG,SAAA;AAAA,MACJ,SAAW,EAAAE,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb,YAAA,CAAa,CAAQ,KAAA,EAAA,IAAI,CAAE,CAAA,CAAA;AAAA,QAC3B;AAAA,UACE,CAAC,YAAa,CAAA,CAAA,UAAA,EAAa,SAAS,CAAA,CAAE,CAAC,GAAG,SAAA;AAAA,UAC1C,CAAC,YAAa,CAAA,CAAA,YAAA,EAAe,WAAW,CAAA,CAAE,CAAC,GAAG,WAAA;AAAA,UAC9C,CAAC,YAAa,CAAA,CAAA,MAAA,EAAS,KAAK,CAAA,CAAE,CAAC,GAAG;AAAA,SACpC;AAAA,QACA;AAAA,OACF;AAAA,MACA,EAAA;AAAA,MACA,GAAA;AAAA,MAEC;AAAA;AAAA,GAEL,EAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var css_248z = ".saltMetricContent {\n display: flex;\n flex-direction: column;\n margin-top: var(--metric-content-marginTop, 0px);\n}\n\n.saltMetricContent-value-container {\n align-items: baseline;\n display: flex;\n flex-direction: row;\n gap: calc(var(--salt-size-unit) / 2);\n margin-top: var(--metric-content-valueContainer-marginTop, 0px);\n}\n\n.saltMetric-direction-up .saltMetricContent-indicator {\n fill: var(--salt-status-positive-foreground);\n}\n.saltMetric-direction-up .saltMetricContent-subvalue {\n color: var(--salt-status-positive-foreground);\n}\n\n.saltMetric-direction-down .saltMetricContent-indicator {\n fill: var(--salt-status-negative-foreground);\n}\n.saltMetric-direction-down .saltMetricContent-subvalue {\n color: var(--salt-status-negative-foreground);\n}\n\n.saltMetricContent-subvalue {\n margin-top: var(--metric-content-subvalue-marginTop, 0px);\n}\n\n.saltMetric-align-left .saltMetricContent {\n text-align: left;\n}\n\n.saltMetric-align-center .saltMetricContent {\n align-items: center;\n text-align: center;\n}\n\n.saltMetric-align-right .saltMetricContent {\n align-items: flex-end;\n text-align: right;\n}\n";
3
+ var css_248z = ".saltMetricContent {\n display: flex;\n flex-direction: column;\n margin-top: var(--metric-content-marginTop, 0px);\n}\n\n.saltMetricContent-value-container {\n align-items: baseline;\n display: flex;\n flex-direction: row;\n gap: calc(var(--salt-size-unit) / 2);\n margin-top: var(--metric-content-valueContainer-marginTop, 0px);\n}\n\n.saltMetric-direction-up .saltMetricContent-indicator {\n fill: var(--salt-sentiment-positive-foreground-decorative);\n}\n.saltMetric-direction-up .saltMetricContent-subvalue {\n color: var(--salt-sentiment-positive-foreground-informative);\n}\n\n.saltMetric-direction-down .saltMetricContent-indicator {\n fill: var(--salt-sentiment-negative-foreground-decorative);\n}\n.saltMetric-direction-down .saltMetricContent-subvalue {\n color: var(--salt-sentiment-negative-foreground-informative);\n}\n\n.saltMetricContent-subvalue {\n margin-top: var(--metric-content-subvalue-marginTop, 0px);\n}\n\n.saltMetric-align-left .saltMetricContent {\n text-align: left;\n}\n\n.saltMetric-align-center .saltMetricContent {\n align-items: center;\n text-align: center;\n}\n\n.saltMetric-align-right .saltMetricContent {\n align-items: flex-end;\n text-align: right;\n}\n";
4
4
 
5
5
  module.exports = css_248z;
6
6
  //# sourceMappingURL=MetricContent.css.js.map
@@ -3,11 +3,11 @@
3
3
  var jsxRuntime = require('react/jsx-runtime');
4
4
  var core = require('@salt-ds/core');
5
5
  var icons = require('@salt-ds/icons');
6
+ var styles = require('@salt-ds/styles');
7
+ var window = require('@salt-ds/window');
6
8
  var clsx = require('clsx');
7
9
  var react = require('react');
8
10
  var MetricContext = require('./internal/MetricContext.js');
9
- var styles = require('@salt-ds/styles');
10
- var window = require('@salt-ds/window');
11
11
  var MetricContent$1 = require('./MetricContent.css.js');
12
12
 
13
13
  const iconComponentMap = {
@@ -1 +1 @@
1
- {"version":3,"file":"MetricContent.js","sources":["../src/metric/MetricContent.tsx"],"sourcesContent":["import {\n Display1,\n Display2,\n Display3,\n Text,\n makePrefixer,\n} from \"@salt-ds/core\";\nimport { ArrowDownIcon, ArrowUpIcon, type IconProps } from \"@salt-ds/icons\";\nimport { clsx } from \"clsx\";\nimport { type ComponentType, type HTMLAttributes, forwardRef } from \"react\";\nimport { useMetricContext } from \"./internal\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport metricContentCss from \"./MetricContent.css\";\n\nexport interface MetricContentProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * These props will be passed to the indicator icon. Use this to render a\n * custom icon.\n *\n * @see `Icon` for a list of valid props.\n */\n IndicatorIconProps?: Partial<IconProps>;\n /**\n * Replace the default Icon component\n */\n IndicatorIconComponent?: ComponentType<IconProps>;\n\n /**\n * Other data that may serve as additional information to the main value\n */\n subvalue?: string | number;\n /**\n * The main value to display in the metric\n */\n value: string | number;\n}\n\nconst iconComponentMap = {\n down: ArrowDownIcon,\n up: ArrowUpIcon,\n};\n\nconst withBaseName = makePrefixer(\"saltMetricContent\");\n\nexport const MetricContent = forwardRef<HTMLDivElement, MetricContentProps>(\n function MetricContent(\n {\n IndicatorIconProps,\n IndicatorIconComponent,\n className,\n value,\n subvalue,\n ...restProps\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-metric-content\",\n css: metricContentCss,\n window: targetWindow,\n });\n\n const {\n direction,\n showIndicator,\n indicatorPosition,\n size = \"medium\",\n valueId,\n titleId,\n subtitleId,\n } = useMetricContext();\n\n const iconSize = size === \"large\" ? 2 : 1;\n\n const valueComponentMap = {\n small: Display3,\n medium: Display2,\n large: Display1,\n };\n const ValueComponent = valueComponentMap[size];\n\n const iconProps = {\n \"aria-label\": direction,\n className: withBaseName(\"indicator\"),\n name: direction ? `movement-${direction}` : \"\",\n size: iconSize,\n ...IndicatorIconProps,\n };\n\n const IconComponent =\n IndicatorIconComponent ??\n (direction ? iconComponentMap[direction] : undefined);\n\n const icon =\n showIndicator && IconComponent ? <IconComponent {...iconProps} /> : null;\n\n return (\n <div\n {...restProps}\n className={clsx(withBaseName(), className)}\n aria-labelledby={`${titleId || \"\"} ${subtitleId || \"\"}`}\n ref={ref}\n >\n <div className={withBaseName(\"value-container\")}>\n {indicatorPosition === \"start\" && icon}\n <ValueComponent\n data-testid=\"metric-value\"\n id={valueId}\n className={withBaseName(\"value\")}\n >\n {value}\n </ValueComponent>\n {indicatorPosition === \"end\" && icon}\n </div>\n {subvalue && (\n <Text\n className={withBaseName(\"subvalue\")}\n data-testid=\"metric-subvalue\"\n >\n {subvalue}\n </Text>\n )}\n </div>\n );\n },\n);\n"],"names":["ArrowDownIcon","ArrowUpIcon","makePrefixer","forwardRef","MetricContent","useWindow","useComponentCssInjection","metricContentCss","useMetricContext","Display3","Display2","Display1","jsxs","clsx","jsx","Text"],"mappings":";;;;;;;;;;;;AAwCA,MAAM,gBAAmB,GAAA;AAAA,EACvB,IAAM,EAAAA,mBAAA;AAAA,EACN,EAAI,EAAAC;AACN,CAAA;AAEA,MAAM,YAAA,GAAeC,kBAAa,mBAAmB,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cACP,CAAA;AAAA,IACE,kBAAA;AAAA,IACA,sBAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA;AAAA,IACA,GAAG;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,aAAA;AAAA,MACA,iBAAA;AAAA,MACA,IAAO,GAAA,QAAA;AAAA,MACP,OAAA;AAAA,MACA,OAAA;AAAA,MACA;AAAA,QACEC,8BAAiB,EAAA;AAErB,IAAM,MAAA,QAAA,GAAW,IAAS,KAAA,OAAA,GAAU,CAAI,GAAA,CAAA;AAExC,IAAA,MAAM,iBAAoB,GAAA;AAAA,MACxB,KAAO,EAAAC,aAAA;AAAA,MACP,MAAQ,EAAAC,aAAA;AAAA,MACR,KAAO,EAAAC;AAAA,KACT;AACA,IAAM,MAAA,cAAA,GAAiB,kBAAkB,IAAI,CAAA;AAE7C,IAAA,MAAM,SAAY,GAAA;AAAA,MAChB,YAAc,EAAA,SAAA;AAAA,MACd,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,MACnC,IAAM,EAAA,SAAA,GAAY,CAAY,SAAA,EAAA,SAAS,CAAK,CAAA,GAAA,EAAA;AAAA,MAC5C,IAAM,EAAA,QAAA;AAAA,MACN,GAAG;AAAA,KACL;AAEA,IAAA,MAAM,aACJ,GAAA,sBAAA,KACC,SAAY,GAAA,gBAAA,CAAiB,SAAS,CAAI,GAAA,MAAA,CAAA;AAE7C,IAAA,MAAM,OACJ,aAAiB,IAAA,aAAA,kCAAiB,aAAe,EAAA,EAAA,GAAG,WAAW,CAAK,GAAA,IAAA;AAEtE,IACE,uBAAAC,eAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACE,GAAG,SAAA;AAAA,QACJ,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,mBAAiB,CAAG,EAAA,OAAA,IAAW,EAAE,CAAA,CAAA,EAAI,cAAc,EAAE,CAAA,CAAA;AAAA,QACrD,GAAA;AAAA,QAEA,QAAA,EAAA;AAAA,0BAAAD,eAAA,CAAC,KAAI,EAAA,EAAA,SAAA,EAAW,YAAa,CAAA,iBAAiB,CAC3C,EAAA,QAAA,EAAA;AAAA,YAAA,iBAAA,KAAsB,OAAW,IAAA,IAAA;AAAA,4BAClCE,cAAA;AAAA,cAAC,cAAA;AAAA,cAAA;AAAA,gBACC,aAAY,EAAA,cAAA;AAAA,gBACZ,EAAI,EAAA,OAAA;AAAA,gBACJ,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,gBAE9B,QAAA,EAAA;AAAA;AAAA,aACH;AAAA,YACC,sBAAsB,KAAS,IAAA;AAAA,WAClC,EAAA,CAAA;AAAA,UACC,QACC,oBAAAA,cAAA;AAAA,YAACC,SAAA;AAAA,YAAA;AAAA,cACC,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,cAClC,aAAY,EAAA,iBAAA;AAAA,cAEX,QAAA,EAAA;AAAA;AAAA;AACH;AAAA;AAAA,KAEJ;AAAA;AAGN;;;;"}
1
+ {"version":3,"file":"MetricContent.js","sources":["../src/metric/MetricContent.tsx"],"sourcesContent":["import {\n Display1,\n Display2,\n Display3,\n makePrefixer,\n Text,\n} from \"@salt-ds/core\";\nimport { ArrowDownIcon, ArrowUpIcon, type IconProps } from \"@salt-ds/icons\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type ComponentType, forwardRef, type HTMLAttributes } from \"react\";\nimport { useMetricContext } from \"./internal\";\n\nimport metricContentCss from \"./MetricContent.css\";\n\nexport interface MetricContentProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * These props will be passed to the indicator icon. Use this to render a\n * custom icon.\n *\n * @see `Icon` for a list of valid props.\n */\n IndicatorIconProps?: Partial<IconProps>;\n /**\n * Replace the default Icon component\n */\n IndicatorIconComponent?: ComponentType<IconProps>;\n\n /**\n * Other data that may serve as additional information to the main value\n */\n subvalue?: string | number;\n /**\n * The main value to display in the metric\n */\n value: string | number;\n}\n\nconst iconComponentMap = {\n down: ArrowDownIcon,\n up: ArrowUpIcon,\n};\n\nconst withBaseName = makePrefixer(\"saltMetricContent\");\n\nexport const MetricContent = forwardRef<HTMLDivElement, MetricContentProps>(\n function MetricContent(\n {\n IndicatorIconProps,\n IndicatorIconComponent,\n className,\n value,\n subvalue,\n ...restProps\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-metric-content\",\n css: metricContentCss,\n window: targetWindow,\n });\n\n const {\n direction,\n showIndicator,\n indicatorPosition,\n size = \"medium\",\n valueId,\n titleId,\n subtitleId,\n } = useMetricContext();\n\n const iconSize = size === \"large\" ? 2 : 1;\n\n const valueComponentMap = {\n small: Display3,\n medium: Display2,\n large: Display1,\n };\n const ValueComponent = valueComponentMap[size];\n\n const iconProps = {\n \"aria-label\": direction,\n className: withBaseName(\"indicator\"),\n name: direction ? `movement-${direction}` : \"\",\n size: iconSize,\n ...IndicatorIconProps,\n };\n\n const IconComponent =\n IndicatorIconComponent ??\n (direction ? iconComponentMap[direction] : undefined);\n\n const icon =\n showIndicator && IconComponent ? <IconComponent {...iconProps} /> : null;\n\n return (\n <div\n {...restProps}\n className={clsx(withBaseName(), className)}\n aria-labelledby={`${titleId || \"\"} ${subtitleId || \"\"}`}\n ref={ref}\n >\n <div className={withBaseName(\"value-container\")}>\n {indicatorPosition === \"start\" && icon}\n <ValueComponent\n data-testid=\"metric-value\"\n id={valueId}\n className={withBaseName(\"value\")}\n >\n {value}\n </ValueComponent>\n {indicatorPosition === \"end\" && icon}\n </div>\n {subvalue && (\n <Text\n className={withBaseName(\"subvalue\")}\n data-testid=\"metric-subvalue\"\n >\n {subvalue}\n </Text>\n )}\n </div>\n );\n },\n);\n"],"names":["ArrowDownIcon","ArrowUpIcon","makePrefixer","forwardRef","MetricContent","useWindow","useComponentCssInjection","metricContentCss","useMetricContext","Display3","Display2","Display1","jsxs","clsx","jsx","Text"],"mappings":";;;;;;;;;;;;AAuCA,MAAM,gBAAmB,GAAA;AAAA,EACvB,IAAM,EAAAA,mBAAA;AAAA,EACN,EAAI,EAAAC;AACN,CAAA;AAEA,MAAM,YAAA,GAAeC,kBAAa,mBAAmB,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cACP,CAAA;AAAA,IACE,kBAAA;AAAA,IACA,sBAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA;AAAA,IACA,GAAG;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,aAAA;AAAA,MACA,iBAAA;AAAA,MACA,IAAO,GAAA,QAAA;AAAA,MACP,OAAA;AAAA,MACA,OAAA;AAAA,MACA;AAAA,QACEC,8BAAiB,EAAA;AAErB,IAAM,MAAA,QAAA,GAAW,IAAS,KAAA,OAAA,GAAU,CAAI,GAAA,CAAA;AAExC,IAAA,MAAM,iBAAoB,GAAA;AAAA,MACxB,KAAO,EAAAC,aAAA;AAAA,MACP,MAAQ,EAAAC,aAAA;AAAA,MACR,KAAO,EAAAC;AAAA,KACT;AACA,IAAM,MAAA,cAAA,GAAiB,kBAAkB,IAAI,CAAA;AAE7C,IAAA,MAAM,SAAY,GAAA;AAAA,MAChB,YAAc,EAAA,SAAA;AAAA,MACd,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,MACnC,IAAM,EAAA,SAAA,GAAY,CAAY,SAAA,EAAA,SAAS,CAAK,CAAA,GAAA,EAAA;AAAA,MAC5C,IAAM,EAAA,QAAA;AAAA,MACN,GAAG;AAAA,KACL;AAEA,IAAA,MAAM,aACJ,GAAA,sBAAA,KACC,SAAY,GAAA,gBAAA,CAAiB,SAAS,CAAI,GAAA,MAAA,CAAA;AAE7C,IAAA,MAAM,OACJ,aAAiB,IAAA,aAAA,kCAAiB,aAAe,EAAA,EAAA,GAAG,WAAW,CAAK,GAAA,IAAA;AAEtE,IACE,uBAAAC,eAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACE,GAAG,SAAA;AAAA,QACJ,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,mBAAiB,CAAG,EAAA,OAAA,IAAW,EAAE,CAAA,CAAA,EAAI,cAAc,EAAE,CAAA,CAAA;AAAA,QACrD,GAAA;AAAA,QAEA,QAAA,EAAA;AAAA,0BAAAD,eAAA,CAAC,KAAI,EAAA,EAAA,SAAA,EAAW,YAAa,CAAA,iBAAiB,CAC3C,EAAA,QAAA,EAAA;AAAA,YAAA,iBAAA,KAAsB,OAAW,IAAA,IAAA;AAAA,4BAClCE,cAAA;AAAA,cAAC,cAAA;AAAA,cAAA;AAAA,gBACC,aAAY,EAAA,cAAA;AAAA,gBACZ,EAAI,EAAA,OAAA;AAAA,gBACJ,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,gBAE9B,QAAA,EAAA;AAAA;AAAA,aACH;AAAA,YACC,sBAAsB,KAAS,IAAA;AAAA,WAClC,EAAA,CAAA;AAAA,UACC,QACC,oBAAAA,cAAA;AAAA,YAACC,SAAA;AAAA,YAAA;AAAA,cACC,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,cAClC,aAAY,EAAA,iBAAA;AAAA,cAEX,QAAA,EAAA;AAAA;AAAA;AACH;AAAA;AAAA,KAEJ;AAAA;AAGN;;;;"}
@@ -2,11 +2,11 @@
2
2
 
3
3
  var jsxRuntime = require('react/jsx-runtime');
4
4
  var core = require('@salt-ds/core');
5
+ var styles = require('@salt-ds/styles');
6
+ var window = require('@salt-ds/window');
5
7
  var clsx = require('clsx');
6
8
  var react = require('react');
7
9
  var MetricContext = require('./internal/MetricContext.js');
8
- var styles = require('@salt-ds/styles');
9
- var window = require('@salt-ds/window');
10
10
  var MetricHeader$1 = require('./MetricHeader.css.js');
11
11
 
12
12
  const withBaseName = core.makePrefixer("saltMetricHeader");
@@ -1 +1 @@
1
- {"version":3,"file":"MetricHeader.js","sources":["../src/metric/MetricHeader.tsx"],"sourcesContent":["import { Link, type LinkProps, Text, makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef, useCallback } from \"react\";\nimport { useMetricContext } from \"./internal\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport metricHeaderCss from \"./MetricHeader.css\";\n\nexport interface MetricHeaderProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * If provided, subtitle will be rendered as a `Link` element with these props.\n *\n * @see `Link` for a list of valid props.\n */\n SubtitleLinkProps?: Omit<Partial<LinkProps>, \"children\">;\n /**\n * Subtitle of the Metric Header\n */\n subtitle?: string;\n /**\n * Title of the Metric Header\n */\n title: string;\n}\n\nconst withBaseName = makePrefixer(\"saltMetricHeader\");\n\nexport const MetricHeader = forwardRef<HTMLDivElement, MetricHeaderProps>(\n function MetricHeader(\n { SubtitleLinkProps, className, title, subtitle, ...restProps },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-metric-header\",\n css: metricHeaderCss,\n window: targetWindow,\n });\n\n const { titleId, subtitleId, headingAriaLevel } = useMetricContext();\n\n const renderSubtitle = useCallback(() => {\n if (!subtitle) return null;\n\n const subtitleComponent = (\n <Text\n id={subtitleId}\n className={withBaseName(\"subtitle\")}\n data-testid=\"metric-subtitle\"\n variant=\"secondary\"\n >\n {subtitle}\n </Text>\n );\n\n if (SubtitleLinkProps) {\n const { href = \"\", ...restLinkProps } = SubtitleLinkProps;\n\n return (\n <Link href={href} {...restLinkProps}>\n {subtitleComponent}\n </Link>\n );\n }\n\n return subtitleComponent;\n }, [subtitle, subtitleId, SubtitleLinkProps]);\n\n return (\n <div {...restProps} className={clsx(withBaseName(), className)} ref={ref}>\n <Text\n styleAs=\"h4\"\n className={withBaseName(\"title\")}\n data-testid=\"metric-title\"\n id={titleId}\n role=\"heading\"\n aria-level={headingAriaLevel}\n >\n {title}\n </Text>\n {renderSubtitle()}\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","MetricHeader","useWindow","useComponentCssInjection","metricHeaderCss","useMetricContext","useCallback","jsx","Text","Link","jsxs","clsx"],"mappings":";;;;;;;;;;;AA2BA,MAAM,YAAA,GAAeA,kBAAa,kBAAkB,CAAA;AAE7C,MAAM,YAAe,GAAAC,gBAAA;AAAA,EAC1B,SAASC,aACP,CAAA,EAAE,iBAAmB,EAAA,SAAA,EAAW,OAAO,QAAU,EAAA,GAAG,SAAU,EAAA,EAC9D,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,oBAAA;AAAA,MACR,GAAK,EAAAC,cAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,EAAE,OAAA,EAAS,UAAY,EAAA,gBAAA,KAAqBC,8BAAiB,EAAA;AAEnE,IAAM,MAAA,cAAA,GAAiBC,kBAAY,MAAM;AACvC,MAAI,IAAA,CAAC,UAAiB,OAAA,IAAA;AAEtB,MAAA,MAAM,iBACJ,mBAAAC,cAAA;AAAA,QAACC,SAAA;AAAA,QAAA;AAAA,UACC,EAAI,EAAA,UAAA;AAAA,UACJ,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,UAClC,aAAY,EAAA,iBAAA;AAAA,UACZ,OAAQ,EAAA,WAAA;AAAA,UAEP,QAAA,EAAA;AAAA;AAAA,OACH;AAGF,MAAA,IAAI,iBAAmB,EAAA;AACrB,QAAA,MAAM,EAAE,IAAA,GAAO,EAAI,EAAA,GAAG,eAAkB,GAAA,iBAAA;AAExC,QAAA,uBACGD,cAAA,CAAAE,SAAA,EAAA,EAAK,IAAa,EAAA,GAAG,eACnB,QACH,EAAA,iBAAA,EAAA,CAAA;AAAA;AAIJ,MAAO,OAAA,iBAAA;AAAA,KACN,EAAA,CAAC,QAAU,EAAA,UAAA,EAAY,iBAAiB,CAAC,CAAA;AAE5C,IACE,uBAAAC,eAAA,CAAC,KAAK,EAAA,EAAA,GAAG,SAAW,EAAA,SAAA,EAAWC,UAAK,YAAa,EAAA,EAAG,SAAS,CAAA,EAAG,GAC9D,EAAA,QAAA,EAAA;AAAA,sBAAAJ,cAAA;AAAA,QAACC,SAAA;AAAA,QAAA;AAAA,UACC,OAAQ,EAAA,IAAA;AAAA,UACR,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAC/B,aAAY,EAAA,cAAA;AAAA,UACZ,EAAI,EAAA,OAAA;AAAA,UACJ,IAAK,EAAA,SAAA;AAAA,UACL,YAAY,EAAA,gBAAA;AAAA,UAEX,QAAA,EAAA;AAAA;AAAA,OACH;AAAA,MACC,cAAe;AAAA,KAClB,EAAA,CAAA;AAAA;AAGN;;;;"}
1
+ {"version":3,"file":"MetricHeader.js","sources":["../src/metric/MetricHeader.tsx"],"sourcesContent":["import { Link, type LinkProps, makePrefixer, Text } from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { forwardRef, type HTMLAttributes, useCallback } from \"react\";\nimport { useMetricContext } from \"./internal\";\n\nimport metricHeaderCss from \"./MetricHeader.css\";\n\nexport interface MetricHeaderProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * If provided, subtitle will be rendered as a `Link` element with these props.\n *\n * @see `Link` for a list of valid props.\n */\n SubtitleLinkProps?: Omit<Partial<LinkProps>, \"children\">;\n /**\n * Subtitle of the Metric Header\n */\n subtitle?: string;\n /**\n * Title of the Metric Header\n */\n title: string;\n}\n\nconst withBaseName = makePrefixer(\"saltMetricHeader\");\n\nexport const MetricHeader = forwardRef<HTMLDivElement, MetricHeaderProps>(\n function MetricHeader(\n { SubtitleLinkProps, className, title, subtitle, ...restProps },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-metric-header\",\n css: metricHeaderCss,\n window: targetWindow,\n });\n\n const { titleId, subtitleId, headingAriaLevel } = useMetricContext();\n\n const renderSubtitle = useCallback(() => {\n if (!subtitle) return null;\n\n const subtitleComponent = (\n <Text\n id={subtitleId}\n className={withBaseName(\"subtitle\")}\n data-testid=\"metric-subtitle\"\n variant=\"secondary\"\n >\n {subtitle}\n </Text>\n );\n\n if (SubtitleLinkProps) {\n const { href = \"\", ...restLinkProps } = SubtitleLinkProps;\n\n return (\n <Link href={href} {...restLinkProps}>\n {subtitleComponent}\n </Link>\n );\n }\n\n return subtitleComponent;\n }, [subtitle, subtitleId, SubtitleLinkProps]);\n\n return (\n <div {...restProps} className={clsx(withBaseName(), className)} ref={ref}>\n <Text\n styleAs=\"h4\"\n className={withBaseName(\"title\")}\n data-testid=\"metric-title\"\n id={titleId}\n role=\"heading\"\n aria-level={headingAriaLevel}\n >\n {title}\n </Text>\n {renderSubtitle()}\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","MetricHeader","useWindow","useComponentCssInjection","metricHeaderCss","useMetricContext","useCallback","jsx","Text","Link","jsxs","clsx"],"mappings":";;;;;;;;;;;AA0BA,MAAM,YAAA,GAAeA,kBAAa,kBAAkB,CAAA;AAE7C,MAAM,YAAe,GAAAC,gBAAA;AAAA,EAC1B,SAASC,aACP,CAAA,EAAE,iBAAmB,EAAA,SAAA,EAAW,OAAO,QAAU,EAAA,GAAG,SAAU,EAAA,EAC9D,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,oBAAA;AAAA,MACR,GAAK,EAAAC,cAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,EAAE,OAAA,EAAS,UAAY,EAAA,gBAAA,KAAqBC,8BAAiB,EAAA;AAEnE,IAAM,MAAA,cAAA,GAAiBC,kBAAY,MAAM;AACvC,MAAI,IAAA,CAAC,UAAiB,OAAA,IAAA;AAEtB,MAAA,MAAM,iBACJ,mBAAAC,cAAA;AAAA,QAACC,SAAA;AAAA,QAAA;AAAA,UACC,EAAI,EAAA,UAAA;AAAA,UACJ,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,UAClC,aAAY,EAAA,iBAAA;AAAA,UACZ,OAAQ,EAAA,WAAA;AAAA,UAEP,QAAA,EAAA;AAAA;AAAA,OACH;AAGF,MAAA,IAAI,iBAAmB,EAAA;AACrB,QAAA,MAAM,EAAE,IAAA,GAAO,EAAI,EAAA,GAAG,eAAkB,GAAA,iBAAA;AAExC,QAAA,uBACGD,cAAA,CAAAE,SAAA,EAAA,EAAK,IAAa,EAAA,GAAG,eACnB,QACH,EAAA,iBAAA,EAAA,CAAA;AAAA;AAIJ,MAAO,OAAA,iBAAA;AAAA,KACN,EAAA,CAAC,QAAU,EAAA,UAAA,EAAY,iBAAiB,CAAC,CAAA;AAE5C,IACE,uBAAAC,eAAA,CAAC,KAAK,EAAA,EAAA,GAAG,SAAW,EAAA,SAAA,EAAWC,UAAK,YAAa,EAAA,EAAG,SAAS,CAAA,EAAG,GAC9D,EAAA,QAAA,EAAA;AAAA,sBAAAJ,cAAA;AAAA,QAACC,SAAA;AAAA,QAAA;AAAA,UACC,OAAQ,EAAA,IAAA;AAAA,UACR,SAAA,EAAW,aAAa,OAAO,CAAA;AAAA,UAC/B,aAAY,EAAA,cAAA;AAAA,UACZ,EAAI,EAAA,OAAA;AAAA,UACJ,IAAK,EAAA,SAAA;AAAA,UACL,YAAY,EAAA,gBAAA;AAAA,UAEX,QAAA,EAAA;AAAA;AAAA,OACH;AAAA,MACC,cAAe;AAAA,KAClB,EAAA,CAAA;AAAA;AAGN;;;;"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var css_248z = "/* Styles applied to number container */\n.saltNumberInput {\n --numberInput-border: none;\n --numberInput-borderColor: var(--salt-editable-borderColor);\n --numberInput-borderStyle: var(--salt-editable-borderStyle);\n --numberInput-outlineColor: var(--salt-focused-outlineColor);\n --numberInput-borderWidth: var(--salt-size-border);\n\n align-items: center;\n color: var(--salt-content-primary-foreground);\n display: inline-flex;\n font-family: var(--salt-text-fontFamily);\n font-size: var(--salt-text-fontSize);\n height: var(--salt-size-base);\n line-height: var(--salt-text-lineHeight);\n min-height: var(--salt-size-base);\n min-width: 4em;\n width: 100%;\n box-sizing: border-box;\n\n gap: var(--salt-spacing-50);\n}\n\n.saltNumberInput:hover {\n --numberInput-borderStyle: var(--salt-editable-borderStyle-hover);\n --numberInput-borderColor: var(--salt-editable-borderColor-hover);\n\n background: var(--numberInput-background-hover);\n cursor: var(--salt-editable-cursor-hover);\n}\n\n.saltNumberInput:active {\n --numberInput-borderColor: var(--salt-editable-borderColor-active);\n --numberInput-borderStyle: var(--salt-editable-borderStyle-active);\n --numberInput-borderWidth: var(--salt-editable-borderWidth-active);\n\n background: var(--numberInput-background-active);\n cursor: var(--salt-editable-cursor-active);\n}\n\n/* Class applied if `variant=\"primary\"` */\n.saltNumberInput-primary {\n --numberInput-background: var(--salt-editable-primary-background);\n --numberInput-background-active: var(--salt-editable-primary-background-active);\n --numberInput-background-hover: var(--salt-editable-primary-background-hover);\n --numberInput-background-disabled: var(--salt-editable-primary-background-disabled);\n --numberInput-background-readonly: var(--salt-editable-primary-background-readonly);\n}\n\n/* Class applied if `variant=\"secondary\"` */\n.saltNumberInput-secondary {\n --numberInput-background: var(--salt-editable-secondary-background);\n --numberInput-background-active: var(--salt-editable-secondary-background-active);\n --numberInput-background-hover: var(--salt-editable-secondary-background-active);\n --numberInput-background-disabled: var(--salt-editable-secondary-background-disabled);\n --numberInput-background-readonly: var(--salt-editable-secondary-background-readonly);\n}\n\n/* Style applied to input if `validationState=\"error\"` */\n.saltNumberInput-error,\n.saltNumberInput-error:hover {\n --numberInput-background: var(--salt-status-error-background);\n --numberInput-background-active: var(--salt-status-error-background);\n --numberInput-background-hover: var(--salt-status-error-background);\n --numberInput-borderColor: var(--salt-status-error-borderColor);\n --numberInput-outlineColor: var(--salt-status-error-borderColor);\n --numberInput-background-readonly: var(--salt-status-error-background);\n}\n\n/* Style applied to input if `validationState=\"warning\"` */\n.saltNumberInput-warning,\n.saltNumberInput-warning:hover {\n --numberInput-background: var(--salt-status-warning-background);\n --numberInput-background-active: var(--salt-status-warning-background);\n --numberInput-background-hover: var(--salt-status-warning-background);\n --numberInput-borderColor: var(--salt-status-warning-borderColor);\n --numberInput-outlineColor: var(--salt-status-warning-borderColor);\n --numberInput-background-readonly: var(--salt-status-warning-background);\n}\n\n/* Style applied to input if `validationState=\"success\"` */\n.saltNumberInput-success,\n.saltNumberInput-success:hover {\n --numberInput-background: var(--salt-status-success-background);\n --numberInput-background-active: var(--salt-status-success-background);\n --numberInput-background-hover: var(--salt-status-success-background);\n --numberInput-borderColor: var(--salt-status-success-borderColor);\n --numberInput-outlineColor: var(--salt-status-success-borderColor);\n --numberInput-background-readonly: var(--salt-status-success-background);\n}\n\n.saltNumberInput-inputContainer {\n display: flex;\n background: var(--numberInput-background);\n border-radius: var(--salt-palette-corner-weak, 0);\n border: var(--numberInput-border);\n box-sizing: border-box;\n height: var(--salt-size-base);\n min-height: var(--salt-size-base);\n overflow: hidden;\n padding-left: var(--salt-spacing-100);\n padding-right: var(--salt-spacing-100);\n position: relative;\n flex-grow: 1;\n}\n\n/* Style applied to inner input component */\n.saltNumberInput-input {\n background: none;\n border: none;\n box-sizing: content-box;\n color: inherit;\n cursor: inherit;\n display: block;\n flex: 1;\n font: inherit;\n height: 100%;\n letter-spacing: var(--saltNumberInput-letterSpacing, 0);\n margin: 0;\n min-width: 0;\n overflow: hidden;\n padding: 0;\n text-align: var(--numberInput-textAlign);\n width: 100%;\n}\n\n.saltNumberInput-input:focus {\n outline: none;\n}\n\n/* Style applied to selected input */\n.saltNumberInput-input::selection {\n background: var(--salt-content-foreground-highlight);\n}\n\n/* Style applied to placeholder text */\n.saltNumberInput-input::placeholder {\n color: var(--salt-content-secondary-foreground);\n font-weight: var(--salt-text-fontWeight-small);\n}\n\n/* Styling when focused */\n.saltNumberInput-focused {\n --numberInput-borderColor: var(--numberInput-outlineColor);\n --numberInput-borderWidth: var(--salt-editable-borderWidth-active);\n\n outline: var(--saltNumberInput-outline, var(--salt-focused-outlineWidth) var(--salt-focused-outlineStyle) var(--numberInput-outlineColor));\n}\n\n/* Style applied if `readOnly={true}` */\n.saltNumberInput-readOnly {\n --numberInput-borderColor: var(--salt-editable-borderColor-readonly);\n --numberInput-borderStyle: var(--salt-editable-borderStyle-readonly);\n --numberInput-borderWidth: var(--salt-size-border);\n\n background: var(--numberInput-background-readonly);\n cursor: var(--salt-editable-cursor-readonly);\n}\n\n/* Styling when focused if `disabled={true}` */\n.saltNumberInput-focused.saltNumberInput-disabled {\n --numberInput-borderWidth: var(--salt-size-border);\n outline: none;\n}\n\n/* Styling when focused if `readOnly={true}` */\n.saltNumberInput-focused.saltNumberInput-readOnly {\n --numberInput-borderWidth: var(--salt-size-border);\n}\n\n/* Style applied to selected input if `disabled={true}` */\n.saltNumberInput-disabled .saltNumberInput-input::selection {\n background: none;\n}\n\n/* Style applied to input if `disabled={true}` */\n.saltNumberInput-disabled,\n.saltNumberInput-disabled:hover,\n.saltNumberInput-disabled:active {\n --numberInput-borderColor: var(--salt-editable-borderColor-disabled);\n --numberInput-borderStyle: var(--salt-editable-borderStyle-disabled);\n --numberInput-borderWidth: var(--salt-size-border);\n\n background: var(--numberInput-background-disabled);\n cursor: var(--salt-editable-cursor-disabled);\n color: var(--saltNumberInput-color-disabled, var(--salt-content-primary-foreground-disabled));\n}\n\n.saltNumberInput-activationIndicator {\n left: 0;\n bottom: 0;\n width: 100%;\n position: absolute;\n border-bottom: var(--numberInput-borderWidth) var(--numberInput-borderStyle) var(--numberInput-borderColor);\n}\n\n/* Style applied if `bordered={true}` */\n.saltNumberInput-bordered {\n --numberInput-border: var(--salt-size-border) var(--salt-container-borderStyle) var(--numberInput-borderColor);\n --numberInput-borderWidth: 0;\n}\n\n/* Style applied if focused or active when `bordered={true}` */\n.saltNumberInput-bordered.saltNumberInput-focused,\n.saltNumberInput-bordered:active {\n --numberInput-borderWidth: var(--salt-editable-borderWidth-active);\n}\n\n/* Styling when focused if `disabled={true}` or `readOnly={true}` when `bordered={true}` */\n.saltNumberInput-bordered.saltNumberInput-readOnly,\n.saltNumberInput-bordered.saltNumberInput-disabled:hover {\n --numberInput-borderWidth: 0;\n}\n\n/* Style applied to start adornments */\n.saltNumberInput-startAdornmentContainer {\n align-items: center;\n display: inline-flex;\n padding-right: var(--salt-spacing-100);\n column-gap: var(--salt-spacing-100);\n}\n\n/* Style applied to end adornments */\n.saltNumberInput-endAdornmentContainer {\n align-items: center;\n display: inline-flex;\n padding-left: var(--salt-spacing-100);\n column-gap: var(--salt-spacing-100);\n}\n\n.saltNumberInput-readOnly .saltNumberInput-startAdornmentContainer {\n margin-left: var(--salt-spacing-50);\n}\n\n.saltNumberInput-startAdornmentContainer .saltButton ~ .saltButton {\n margin-left: calc(-1 * var(--salt-spacing-50));\n}\n\n.saltNumberInput-endAdornmentContainer .saltButton ~ .saltButton {\n margin-left: calc(-1 * var(--salt-spacing-50));\n}\n\n.saltNumberInput-startAdornmentContainer .saltButton:first-child {\n margin-left: calc(var(--salt-spacing-50) * -1);\n}\n\n.saltNumberInput-endAdornmentContainer .saltButton:last-child {\n margin-right: calc(var(--salt-spacing-50) * -1);\n}\n\n.saltNumberInput-startAdornmentContainer > .saltButton,\n.saltNumberInput-endAdornmentContainer > .saltButton {\n --saltButton-padding: calc(var(--salt-spacing-50) - var(--salt-size-border));\n --saltButton-height: calc(var(--salt-size-base) - var(--salt-spacing-100));\n --saltButton-borderRadius: var(--salt-palette-corner-weaker);\n}\n\n.saltNumberInput-inputTextAlignLeft {\n text-align: left;\n}\n\n.saltNumberInput-inputTextAlignCenter {\n text-align: center;\n}\n\n.saltNumberInput-inputTextAlignRight {\n text-align: right;\n}\n\n/* --- Buttons --- */\n\n/* Styles applied to number buttons container */\n.saltNumberInput-buttonContainer {\n --numberInput-buttonGap: var(--salt-size-border-strong);\n display: flex;\n flex-direction: column;\n gap: var(--numberInput-buttonGap);\n}\n\n/* Styles applied to number buttons */\n.saltNumberInput-numberButton {\n --saltButton-height: calc((var(--salt-size-base) - var(--numberInput-buttonGap)) * 0.5);\n --saltButton-width: var(--salt-size-base);\n}\n\n.saltNumberInput-numberButtonIncrement {\n --saltButton-borderRadius: var(--salt-palette-corner-weak, 0) var(--salt-palette-corner-weak, 0) 0 0;\n}\n.saltNumberInput-numberButtonDecrement {\n --saltButton-borderRadius: 0 0 var(--salt-palette-corner-weak, 0) var(--salt-palette-corner-weak, 0);\n}\n";
3
+ var css_248z = "/* Styles applied to number container */\n.saltNumberInput {\n --numberInput-border: var(--salt-size-fixed-100) var(--salt-borderStyle-solid) var(--numberInput-borderColor);\n --numberInput-borderColor: var(--salt-editable-borderColor);\n --numberInput-borderStyle: var(--salt-borderStyle-solid);\n --numberInput-outlineColor: var(--salt-focused-outlineColor);\n --numberInput-borderWidth: var(--salt-size-fixed-100);\n --numberInput-outline: none;\n\n align-items: center;\n background: var(--numberInput-background);\n border-radius: var(--salt-palette-corner-weak, 0);\n box-sizing: border-box;\n color: var(--salt-content-primary-foreground);\n display: inline-flex;\n font-family: var(--salt-text-fontFamily);\n font-size: var(--salt-text-fontSize);\n gap: var(--salt-spacing-50);\n height: var(--salt-size-base);\n min-height: var(--salt-size-base);\n min-width: 4em;\n overflow: hidden;\n outline: var(--numberInput-outline);\n padding-left: var(--salt-spacing-100);\n padding-right: var(--salt-spacing-50);\n padding-top: var(--salt-spacing-50);\n padding-bottom: var(--salt-spacing-50);\n position: relative;\n width: 100%;\n}\n\n.saltNumberInput:hover {\n --numberInput-borderStyle: var(--salt-borderStyle-solid);\n --numberInput-borderColor: var(--salt-editable-borderColor-hover);\n\n background: var(--numberInput-background-hover);\n cursor: var(--salt-cursor-text);\n}\n\n.saltNumberInput:active {\n --numberInput-borderColor: var(--salt-editable-borderColor-active);\n --numberInput-borderStyle: var(--salt-borderStyle-solid);\n --numberInput-borderWidth: var(--salt-size-fixed-200);\n\n background: var(--numberInput-background-active);\n}\n\n/* Class applied if `variant=\"primary\"` */\n.saltNumberInput-primary {\n --numberInput-background: var(--salt-editable-primary-background);\n --numberInput-background-active: var(--salt-editable-primary-background-active);\n --numberInput-background-hover: var(--salt-editable-primary-background-hover);\n --numberInput-background-disabled: var(--salt-editable-primary-background-disabled);\n --numberInput-background-readonly: var(--salt-editable-primary-background-readonly);\n}\n\n/* Class applied if `variant=\"secondary\"` */\n.saltNumberInput-secondary {\n --numberInput-background: var(--salt-editable-secondary-background);\n --numberInput-background-active: var(--salt-editable-secondary-background-active);\n --numberInput-background-hover: var(--salt-editable-secondary-background-active);\n --numberInput-background-disabled: var(--salt-editable-secondary-background-disabled);\n --numberInput-background-readonly: var(--salt-editable-secondary-background-readonly);\n}\n\n/* Style applied to input if `validationState=\"error\"` */\n.saltNumberInput-error,\n.saltNumberInput-error:hover {\n --numberInput-background: var(--salt-status-error-background);\n --numberInput-background-active: var(--salt-status-error-background);\n --numberInput-background-hover: var(--salt-status-error-background);\n --numberInput-borderColor: var(--salt-status-error-borderColor);\n --numberInput-outlineColor: var(--salt-status-error-borderColor);\n --numberInput-background-readonly: var(--salt-status-error-background);\n}\n\n/* Style applied to input if `validationState=\"warning\"` */\n.saltNumberInput-warning,\n.saltNumberInput-warning:hover {\n --numberInput-background: var(--salt-status-warning-background);\n --numberInput-background-active: var(--salt-status-warning-background);\n --numberInput-background-hover: var(--salt-status-warning-background);\n --numberInput-borderColor: var(--salt-status-warning-borderColor);\n --numberInput-outlineColor: var(--salt-status-warning-borderColor);\n --numberInput-background-readonly: var(--salt-status-warning-background);\n}\n\n/* Style applied to input if `validationState=\"success\"` */\n.saltNumberInput-success,\n.saltNumberInput-success:hover {\n --numberInput-background: var(--salt-status-success-background);\n --numberInput-background-active: var(--salt-status-success-background);\n --numberInput-background-hover: var(--salt-status-success-background);\n --numberInput-borderColor: var(--salt-status-success-borderColor);\n --numberInput-outlineColor: var(--salt-status-success-borderColor);\n --numberInput-background-readonly: var(--salt-status-success-background);\n}\n\n/* Style applied to inner input component */\n.saltNumberInput-input {\n background: none;\n border: none;\n box-sizing: content-box;\n color: inherit;\n cursor: inherit;\n display: block;\n flex: 1;\n font: inherit;\n letter-spacing: var(--salt-text-letterSpacing);\n line-height: var(--salt-text-lineHeight);\n margin: 0;\n min-width: 0;\n padding: 0;\n text-align: var(--numberInput-textAlign);\n width: 100%;\n}\n\n.saltNumberInput-input:focus {\n outline: none;\n}\n\n/* Style applied to selected input */\n.saltNumberInput-input::selection {\n background: var(--salt-content-foreground-highlight);\n}\n\n/* Style applied to placeholder text */\n.saltNumberInput-input::placeholder {\n color: var(--salt-content-secondary-foreground);\n font-weight: var(--salt-text-fontWeight-small);\n}\n\n/* Styling when focused */\n.saltNumberInput-focused {\n --numberInput-borderColor: var(--numberInput-outlineColor);\n --numberInput-borderWidth: var(--salt-size-fixed-200);\n\n outline: var(--saltNumberInput-outline, var(--salt-focused-outlineWidth) var(--salt-focused-outlineStyle) var(--numberInput-outlineColor));\n}\n\n/* Style applied if `bordered={true}` */\n.saltNumberInput-bordered {\n --numberInput-border: var(--salt-size-fixed-100) var(--salt-borderStyle-solid) var(--numberInput-borderColor);\n --numberInput-borderWidth: 0;\n\n border: var(--numberInput-border);\n}\n\n/* Style applied if focused or active when `bordered={true}` */\n.saltNumberInput-bordered.saltNumberInput-focused,\n.saltNumberInput-bordered:active {\n --numberInput-borderWidth: var(--salt-size-fixed-200);\n}\n\n/* Styling when focused if `disabled={true}` or `readOnly={true}` when `bordered={true}` */\n.saltNumberInput-bordered.saltNumberInput-readOnly,\n.saltNumberInput-bordered.saltNumberInput-disabled:hover {\n --numberInput-borderWidth: 0;\n}\n\n/* Styling when focused and hovered when `bordered={true}` */\n.saltNumberInput-bordered.saltNumberInput-focused:hover {\n --numberInput-borderColor: var(--salt-editable-borderColor-active);\n}\n\n/* Style applied if `readOnly={true}` */\n.saltNumberInput-readOnly,\n.saltNumberInput-bordered.saltNumberInput-readOnly {\n --numberInput-borderColor: var(--salt-editable-borderColor-readonly);\n --numberInput-borderStyle: var(--salt-borderStyle-solid);\n --numberInput-borderWidth: var(--salt-size-fixed-100);\n\n background: var(--numberInput-background-readonly);\n cursor: var(--salt-cursor-readonly);\n}\n\n/* Styling when focused if `disabled={true}` */\n.saltNumberInput-focused.saltNumberInput-disabled {\n --numberInput-borderWidth: var(--salt-size-fixed-100);\n outline: none;\n}\n\n/* Styling when focused if `readOnly={true}` */\n.saltNumberInput-focused.saltNumberInput-readOnly {\n --numberInput-borderWidth: var(--salt-size-fixed-100);\n}\n\n.saltNumberInput:hover.saltNumberInput-readOnly {\n --numberInput-borderColor: var(--salt-editable-borderColor-readonly);\n}\n\n/* Style applied to selected input if `disabled={true}` */\n.saltNumberInput-disabled .saltNumberInput-input::selection {\n background: none;\n}\n\n/* Style applied to input if `disabled={true}` */\n.saltNumberInput-disabled,\n.saltNumberInput-disabled:hover,\n.saltNumberInput-disabled:active {\n --numberInput-borderColor: var(--salt-editable-borderColor-disabled);\n --numberInput-borderStyle: var(--salt-borderStyle-solid);\n --numberInput-borderWidth: var(--salt-size-fixed-100);\n\n background: var(--numberInput-background-disabled);\n cursor: var(--salt-cursor-disabled);\n color: var(--saltNumberInput-color-disabled, var(--salt-content-primary-foreground-disabled));\n}\n\n/* Style applied to start adornments */\n.saltNumberInput-startAdornmentContainer {\n align-items: center;\n display: inline-flex;\n padding-right: var(--salt-spacing-100);\n column-gap: var(--salt-spacing-100);\n}\n\n/* Style applied to end adornments */\n.saltNumberInput-endAdornmentContainer {\n align-items: center;\n display: inline-flex;\n padding-left: var(--salt-spacing-100);\n column-gap: var(--salt-spacing-100);\n}\n\n.saltNumberInput-startAdornmentContainer {\n margin-left: calc(var(--salt-spacing-50) * -1);\n}\n\n.saltNumberInput-startAdornmentContainer > .saltButton,\n.saltNumberInput-endAdornmentContainer > .saltButton {\n --saltButton-padding: calc(var(--salt-spacing-50) - var(--button-borderWidth));\n --saltButton-height: calc(var(--salt-size-base) - var(--salt-spacing-100));\n --saltButton-borderRadius: var(--salt-palette-corner-weaker);\n}\n\n.saltNumberInput-inputTextAlignLeft {\n --numberInput-textAlign: left;\n}\n\n.saltNumberInput-inputTextAlignCenter {\n --numberInput-textAlign: center;\n}\n\n.saltNumberInput-inputTextAlignRight {\n --numberInput-textAlign: right;\n}\n\n/* --- Buttons --- */\n\n/* Styles applied to number buttons container */\n.saltNumberInput-buttonContainer {\n --numberInput-buttonGap: var(--salt-spacing-fixed-200);\n display: flex;\n flex-direction: column;\n gap: var(--numberInput-buttonGap);\n justify-content: center;\n}\n\n.saltNumberInput-hiddenButtons .saltNumberInput-buttonContainer {\n display: none;\n}\n\n/* Styles applied to number buttons */\n.saltNumberInput-numberButton {\n --saltButton-height: calc((var(--salt-size-base) - (var(--salt-spacing-50) * 2) - var(--salt-size-fixed-200)) / 2);\n --saltButton-padding: calc(var(--salt-spacing-50) - var(--button-borderWidth));\n}\n\n.saltNumberInput-numberButtonIncrement {\n --saltButton-borderRadius: var(--salt-palette-corner-weaker, 0) var(--salt-palette-corner-weaker, 0) 0 0;\n}\n.saltNumberInput-numberButtonDecrement {\n --saltButton-borderRadius: 0 0 var(--salt-palette-corner-weaker, 0) var(--salt-palette-corner-weaker, 0);\n}\n\n.saltNumberInput-activationIndicator {\n left: 0;\n bottom: 0;\n width: 100%;\n position: absolute;\n border-bottom: var(--salt-size-fixed-100) var(--salt-borderStyle-solid) var(--numberInput-borderColor);\n}\n\n.saltNumberInput-focused .saltNumberInput-activationIndicator {\n border-bottom: var(--salt-size-fixed-200) var(--salt-borderStyle-solid) var(--salt-editable-borderColor-active);\n}\n\n.saltNumberInput-bordered.saltNumberInput-focused .saltNumberInput-activationIndicator {\n /* Activation indicator width minus the border from the number input. */\n border-bottom-width: var(--salt-size-fixed-100);\n}\n\n.saltNumberInput-bordered .saltNumberInput-activationIndicator,\n.saltNumberInput-readOnly.saltNumberInput-focused .saltNumberInput-activationIndicator {\n border-bottom-width: 0;\n}\n";
4
4
 
5
5
  module.exports = css_248z;
6
6
  //# sourceMappingURL=NumberInput.css.js.map
@@ -6,6 +6,7 @@ var styles = require('@salt-ds/styles');
6
6
  var window = require('@salt-ds/window');
7
7
  var clsx = require('clsx');
8
8
  var react = require('react');
9
+ var useCaret = require('./internal/useCaret.js');
9
10
  var utils = require('./internal/utils.js');
10
11
  var NumberInput$1 = require('./NumberInput.css.js');
11
12
  var useNumberInput = require('./useNumberInput.js');
@@ -13,28 +14,32 @@ var useNumberInput = require('./useNumberInput.js');
13
14
  const withBaseName = core.makePrefixer("saltNumberInput");
14
15
  const NumberInput = react.forwardRef(
15
16
  function NumberInput2({
16
- bordered,
17
+ bordered = false,
17
18
  className: classNameProp,
18
- decimalPlaces = 0,
19
- defaultValue: defaultValueProp,
19
+ clamp = false,
20
20
  disabled,
21
21
  emptyReadOnlyMarker = "\u2014",
22
22
  endAdornment,
23
+ format,
23
24
  hideButtons,
25
+ id: idProp,
24
26
  inputProps: inputPropsProp = {},
25
27
  inputRef: inputRefProp,
26
28
  max = Number.MAX_SAFE_INTEGER,
27
29
  min = Number.MIN_SAFE_INTEGER,
28
30
  onChange: onChangeProp,
31
+ parse,
29
32
  placeholder,
33
+ decimalScale: decimalScaleProp,
30
34
  readOnly: readOnlyProp,
31
35
  startAdornment,
32
36
  step = 1,
33
- stepBlock = 10,
37
+ stepMultiplier = 2,
34
38
  textAlign = "left",
35
39
  validationStatus: validationStatusProp,
36
40
  value: valueProp,
37
41
  variant = "primary",
42
+ defaultValue: defaultValueProp = "",
38
43
  ...restProps
39
44
  }, ref) {
40
45
  const targetWindow = window.useWindow();
@@ -43,7 +48,6 @@ const NumberInput = react.forwardRef(
43
48
  css: NumberInput$1,
44
49
  window: targetWindow
45
50
  });
46
- const { IncreaseIcon, DecreaseIcon } = core.useIcon();
47
51
  const {
48
52
  a11yProps: {
49
53
  "aria-describedby": formFieldDescribedBy,
@@ -57,6 +61,12 @@ const NumberInput = react.forwardRef(
57
61
  const isDisabled = disabled || formFieldDisabled;
58
62
  const isReadOnly = readOnlyProp || formFieldReadOnly;
59
63
  const validationStatus = formFieldValidationStatus ?? validationStatusProp;
64
+ const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;
65
+ const defaultValue = isEmptyReadOnly ? emptyReadOnlyMarker : defaultValueProp;
66
+ const validationStatusId = core.useId(idProp);
67
+ const inputRef = react.useRef(null);
68
+ const handleInputRef = core.useForkRef(inputRefProp, inputRef);
69
+ const { IncreaseIcon, DecreaseIcon } = core.useIcon();
60
70
  const {
61
71
  "aria-describedby": inputDescribedBy,
62
72
  "aria-labelledby": inputLabelledBy,
@@ -69,60 +79,112 @@ const NumberInput = react.forwardRef(
69
79
  ...restInputProps
70
80
  } = inputPropsProp;
71
81
  const isRequired = formFieldRequired ? ["required", "asterisk"].includes(formFieldRequired) : inputRequired;
82
+ const isAdjustingRef = react.useRef(false);
83
+ const [isEditing, setIsEditing] = react.useState(false);
84
+ const [isFocused, setIsFocused] = react.useState(false);
85
+ const [recordCaret, restoreCaret, resetCaret] = useCaret({
86
+ inputRef
87
+ });
72
88
  const [value, setValue] = core.useControlled({
73
89
  controlled: valueProp,
74
- default: typeof defaultValueProp === "number" ? utils.toFixedDecimalPlaces(defaultValueProp, decimalPlaces) : defaultValueProp,
90
+ default: defaultValue,
75
91
  name: "NumberInput",
76
92
  state: "value"
77
93
  });
78
- const [focused, setFocused] = react.useState(false);
79
- const inputRef = react.useRef(null);
80
- const forkedInputRef = core.useForkRef(inputRef, inputRefProp);
94
+ const decimalScale = decimalScaleProp || Math.max(utils.getNumberPrecision(value), utils.getNumberPrecision(step));
95
+ const [displayValue, setDisplayValue] = react.useState(value);
96
+ const clampAndFix = (value2) => {
97
+ const clampedValue = clamp ? utils.clampToRange(min, max, value2) : value2;
98
+ return !format ? clampedValue.toFixed(decimalScale) : clampedValue;
99
+ };
81
100
  const {
82
101
  decrementButtonProps,
83
102
  decrementValue,
84
103
  incrementButtonProps,
85
104
  incrementValue
86
105
  } = useNumberInput.useNumberInput({
87
- inputRef,
88
- setValue,
89
- decimalPlaces,
106
+ clampAndFix,
107
+ decimalScale,
90
108
  disabled,
109
+ format,
110
+ inputRef,
111
+ isAdjustingRef,
91
112
  max,
92
113
  min,
93
114
  onChange: onChangeProp,
115
+ parse,
94
116
  readOnly: isReadOnly,
117
+ setIsEditing,
118
+ setValue,
95
119
  step,
96
- stepBlock,
120
+ stepMultiplier,
97
121
  value
98
122
  });
123
+ react.useEffect(() => {
124
+ const formatValue = () => {
125
+ const sanitizedValue = utils.sanitizeInput(value);
126
+ const floatValue = utils.toFloat(sanitizedValue);
127
+ if (!isAdjustingRef.current && (isEditing || utils.isEmpty(value) || Number.isNaN(floatValue) || isReadOnly)) {
128
+ return value;
129
+ }
130
+ if (isAdjustingRef.current) {
131
+ return clampAndFix(utils.toFloat(value));
132
+ }
133
+ const clampedValue = clampAndFix(floatValue);
134
+ return format ? format(clampedValue) : clampedValue;
135
+ };
136
+ const updatedValue = formatValue();
137
+ setDisplayValue(updatedValue);
138
+ }, [value, isEditing, isReadOnly, format, clamp, decimalScale, min, max]);
139
+ react.useLayoutEffect(() => {
140
+ if (isAdjustingRef.current) {
141
+ resetCaret();
142
+ } else {
143
+ restoreCaret();
144
+ }
145
+ }, [displayValue, value]);
99
146
  const handleInputFocus = (event) => {
100
- setFocused(true);
147
+ setIsFocused(true);
148
+ if (isReadOnly) return;
149
+ const parsedValue = (parse == null ? void 0 : parse(value)) ?? value;
150
+ const updatedValue = !utils.isEmpty(parsedValue) ? clampAndFix(utils.toFloat(parsedValue)) : parsedValue;
151
+ setDisplayValue(updatedValue);
101
152
  inputOnFocus == null ? void 0 : inputOnFocus(event);
102
153
  };
103
154
  const handleInputBlur = (event) => {
104
- setFocused(false);
105
- if (value === void 0) return;
106
- const floatValue = utils.toFloat(value);
107
- if (Number.isNaN(floatValue)) {
108
- setValue(value);
109
- onChangeProp == null ? void 0 : onChangeProp(event, value);
110
- } else {
111
- const roundedValue = utils.toFixedDecimalPlaces(floatValue, decimalPlaces);
112
- if (value !== "" && !utils.isAllowedNonNumeric(value)) {
113
- setValue(roundedValue);
114
- }
115
- onChangeProp == null ? void 0 : onChangeProp(event, roundedValue);
155
+ setIsFocused(false);
156
+ if (isReadOnly) return;
157
+ setIsEditing(false);
158
+ isAdjustingRef.current = false;
159
+ resetCaret();
160
+ const inputValue = event.target.value;
161
+ if (utils.isEmpty(inputValue)) {
162
+ return;
116
163
  }
164
+ const sanitizedValue = utils.sanitizeInput(event.target.value);
165
+ const floatValue = utils.toFloat(sanitizedValue);
166
+ const clampedValue = clampAndFix(floatValue);
167
+ if (clampedValue.toString() !== value.toString()) {
168
+ setValue(clampedValue);
169
+ onChangeProp == null ? void 0 : onChangeProp(event, clampedValue);
170
+ }
171
+ const formattedValue = format ? format(clampedValue) : clampedValue;
172
+ setDisplayValue(formattedValue);
117
173
  inputOnBlur == null ? void 0 : inputOnBlur(event);
118
174
  };
119
175
  const handleInputChange = (event) => {
120
- const changedValue = event.target.value;
121
- setValue(utils.sanitizedInput(changedValue));
122
- onChangeProp == null ? void 0 : onChangeProp(event, utils.sanitizedInput(changedValue));
123
- inputOnChange == null ? void 0 : inputOnChange(event);
176
+ recordCaret();
177
+ const raw = utils.sanitizeInput(event.target.value);
178
+ if (raw.toString() === value.toString()) {
179
+ return;
180
+ }
181
+ const parsed = parse && !isEditing ? parse(raw) : raw;
182
+ setValue(parsed);
183
+ onChangeProp == null ? void 0 : onChangeProp(event, parsed);
124
184
  };
125
185
  const handleInputKeyDown = (event) => {
186
+ setIsEditing(true);
187
+ isAdjustingRef.current = false;
126
188
  switch (event.key) {
127
189
  case "ArrowUp": {
128
190
  event.preventDefault();
@@ -161,66 +223,69 @@ const NumberInput = react.forwardRef(
161
223
  }
162
224
  inputOnKeyDown == null ? void 0 : inputOnKeyDown(event);
163
225
  };
226
+ const handleBeforeInput = () => {
227
+ setIsEditing(true);
228
+ };
164
229
  return /* @__PURE__ */ jsxRuntime.jsxs(
165
230
  "div",
166
231
  {
167
- className: clsx.clsx(withBaseName(), classNameProp),
232
+ className: clsx.clsx(
233
+ withBaseName(),
234
+ withBaseName(variant),
235
+ {
236
+ [withBaseName("focused")]: isFocused,
237
+ [withBaseName("disabled")]: isDisabled,
238
+ [withBaseName("readOnly")]: isReadOnly,
239
+ [withBaseName("hiddenButtons")]: hideButtons,
240
+ [withBaseName(validationStatus || "")]: validationStatus,
241
+ [withBaseName("bordered")]: bordered
242
+ },
243
+ classNameProp
244
+ ),
168
245
  ...restProps,
169
246
  ref,
170
247
  children: [
171
- /* @__PURE__ */ jsxRuntime.jsxs(
172
- "div",
248
+ startAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("startAdornmentContainer"), children: startAdornment }),
249
+ /* @__PURE__ */ jsxRuntime.jsx(
250
+ "input",
173
251
  {
252
+ "aria-describedby": clsx.clsx(
253
+ validationStatusId,
254
+ formFieldDescribedBy,
255
+ inputDescribedBy
256
+ ),
257
+ "aria-labelledby": clsx.clsx(formFieldLabelledBy, inputLabelledBy),
258
+ "aria-invalid": !isReadOnly ? utils.isOutOfRange(value, min, max) || validationStatus === "error" : void 0,
259
+ "aria-valuemax": !isReadOnly ? max : void 0,
260
+ "aria-valuemin": !isReadOnly ? min : void 0,
261
+ "aria-valuenow": value && !Number.isNaN(utils.toFloat(value)) && !isReadOnly ? utils.toFloat((parse == null ? void 0 : parse(value)) || value) : void 0,
262
+ ...!isReadOnly && { "aria-valuetext": value.toString() },
174
263
  className: clsx.clsx(
175
- withBaseName("inputContainer"),
176
- withBaseName(variant),
177
- {
178
- [withBaseName("focused")]: !isDisabled && focused,
179
- [withBaseName("disabled")]: isDisabled,
180
- [withBaseName("readOnly")]: isReadOnly,
181
- [withBaseName(validationStatus || "")]: validationStatus,
182
- [withBaseName("bordered")]: bordered
183
- }
264
+ withBaseName("input"),
265
+ withBaseName(`inputTextAlign${core.capitalize(textAlign)}`),
266
+ inputClassName
184
267
  ),
185
- children: [
186
- startAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("startAdornmentContainer"), children: startAdornment }),
187
- /* @__PURE__ */ jsxRuntime.jsx(
188
- "input",
189
- {
190
- "aria-describedby": clsx.clsx(formFieldDescribedBy, inputDescribedBy),
191
- "aria-labelledby": clsx.clsx(formFieldLabelledBy, inputLabelledBy),
192
- "aria-invalid": !isReadOnly ? utils.isOutOfRange(value, min, max) : void 0,
193
- "aria-valuemax": !isReadOnly ? utils.toFloat(utils.toFixedDecimalPlaces(max, decimalPlaces)) : void 0,
194
- "aria-valuemin": !isReadOnly ? utils.toFloat(utils.toFixedDecimalPlaces(min, decimalPlaces)) : void 0,
195
- "aria-valuenow": value && !Number.isNaN(utils.toFloat(value)) && !isReadOnly ? utils.toFloat(utils.toFixedDecimalPlaces(utils.toFloat(value), decimalPlaces)) : void 0,
196
- className: clsx.clsx(
197
- withBaseName("input"),
198
- withBaseName(`inputTextAlign${core.capitalize(textAlign)}`),
199
- inputClassName
200
- ),
201
- disabled: isDisabled,
202
- onBlur: handleInputBlur,
203
- onChange: handleInputChange,
204
- onFocus: !isDisabled ? handleInputFocus : void 0,
205
- onKeyDown: handleInputKeyDown,
206
- placeholder,
207
- readOnly: isReadOnly,
208
- "aria-readonly": isReadOnly ? "true" : void 0,
209
- ref: forkedInputRef,
210
- required: isRequired,
211
- role: isReadOnly ? "textbox" : "spinbutton",
212
- tabIndex: isDisabled ? -1 : 0,
213
- value,
214
- ...restInputProps
215
- }
216
- ),
217
- !isDisabled && validationStatus && /* @__PURE__ */ jsxRuntime.jsx(core.StatusAdornment, { status: validationStatus }),
218
- endAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("endAdornmentContainer"), children: endAdornment }),
219
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("activationIndicator") })
220
- ]
268
+ disabled: isDisabled,
269
+ onBlur: handleInputBlur,
270
+ onChange: handleInputChange,
271
+ onFocus: handleInputFocus,
272
+ onKeyDown: handleInputKeyDown,
273
+ onBeforeInput: handleBeforeInput,
274
+ placeholder,
275
+ readOnly: isReadOnly,
276
+ "aria-readonly": isReadOnly ? "true" : void 0,
277
+ ref: handleInputRef,
278
+ required: isRequired,
279
+ role: isReadOnly ? "textbox" : "spinbutton",
280
+ tabIndex: isDisabled ? -1 : 0,
281
+ value: displayValue,
282
+ ...restInputProps
221
283
  }
222
284
  ),
223
- !hideButtons && !isReadOnly && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: withBaseName("buttonContainer"), children: [
285
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("activationIndicator") }),
286
+ !isDisabled && validationStatus && /* @__PURE__ */ jsxRuntime.jsx(core.StatusAdornment, { status: validationStatus, id: validationStatusId }),
287
+ endAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("endAdornmentContainer"), children: endAdornment }),
288
+ !isReadOnly && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: clsx.clsx(withBaseName("buttonContainer")), children: [
224
289
  /* @__PURE__ */ jsxRuntime.jsx(
225
290
  core.Button,
226
291
  {
@@ -228,6 +293,7 @@ const NumberInput = react.forwardRef(
228
293
  withBaseName("numberButton"),
229
294
  withBaseName("numberButtonIncrement")
230
295
  ),
296
+ appearance: "transparent",
231
297
  ...incrementButtonProps,
232
298
  children: /* @__PURE__ */ jsxRuntime.jsx(IncreaseIcon, { "aria-hidden": true })
233
299
  }
@@ -239,6 +305,7 @@ const NumberInput = react.forwardRef(
239
305
  withBaseName("numberButton"),
240
306
  withBaseName("numberButtonDecrement")
241
307
  ),
308
+ appearance: "transparent",
242
309
  ...decrementButtonProps,
243
310
  children: /* @__PURE__ */ jsxRuntime.jsx(DecreaseIcon, { "aria-hidden": true })
244
311
  }