@salt-ds/lab 1.0.0-alpha.53 → 1.0.0-alpha.55

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 (1218) hide show
  1. package/CHANGELOG.md +1895 -0
  2. package/css/salt-lab.css +212 -51
  3. package/dist-cjs/app-header/AppHeader.js +9 -8
  4. package/dist-cjs/app-header/AppHeader.js.map +1 -1
  5. package/dist-cjs/breadcrumbs/Breadcrumb.js +43 -43
  6. package/dist-cjs/breadcrumbs/Breadcrumb.js.map +1 -1
  7. package/dist-cjs/breadcrumbs/Breadcrumbs.js +28 -33
  8. package/dist-cjs/breadcrumbs/Breadcrumbs.js.map +1 -1
  9. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js +19 -16
  10. package/dist-cjs/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  11. package/dist-cjs/breadcrumbs/internal/BreadcrumbsContext.js +0 -2
  12. package/dist-cjs/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  13. package/dist-cjs/breadcrumbs/internal/BreadcrumbsSeparator.js +1 -5
  14. package/dist-cjs/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  15. package/dist-cjs/breadcrumbs/internal/useFocusMenuRemount.js +0 -2
  16. package/dist-cjs/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  17. package/dist-cjs/button-bar/ButtonBar.js +20 -27
  18. package/dist-cjs/button-bar/ButtonBar.js.map +1 -1
  19. package/dist-cjs/button-bar/OrderedButton.js +16 -15
  20. package/dist-cjs/button-bar/OrderedButton.js.map +1 -1
  21. package/dist-cjs/button-bar/internal/ButtonBarContext.js +0 -2
  22. package/dist-cjs/button-bar/internal/ButtonBarContext.js.map +1 -1
  23. package/dist-cjs/button-bar/internal/DescendantContext.js +1 -6
  24. package/dist-cjs/button-bar/internal/DescendantContext.js.map +1 -1
  25. package/dist-cjs/button-bar/internal/useDescendant.js +0 -2
  26. package/dist-cjs/button-bar/internal/useDescendant.js.map +1 -1
  27. package/dist-cjs/button-bar/internal/useDescendants.js +0 -2
  28. package/dist-cjs/button-bar/internal/useDescendants.js.map +1 -1
  29. package/dist-cjs/calendar/Calendar.js +20 -16
  30. package/dist-cjs/calendar/Calendar.js.map +1 -1
  31. package/dist-cjs/calendar/CalendarDateGrid.js +34 -29
  32. package/dist-cjs/calendar/CalendarDateGrid.js.map +1 -1
  33. package/dist-cjs/calendar/CalendarNavigation.js +103 -96
  34. package/dist-cjs/calendar/CalendarNavigation.js.map +1 -1
  35. package/dist-cjs/calendar/CalendarWeekHeader.js +18 -13
  36. package/dist-cjs/calendar/CalendarWeekHeader.js.map +1 -1
  37. package/dist-cjs/calendar/formatDate.js +3 -8
  38. package/dist-cjs/calendar/formatDate.js.map +1 -1
  39. package/dist-cjs/calendar/internal/CalendarContext.js +0 -2
  40. package/dist-cjs/calendar/internal/CalendarContext.js.map +1 -1
  41. package/dist-cjs/calendar/internal/CalendarDay.js +48 -41
  42. package/dist-cjs/calendar/internal/CalendarDay.js.map +1 -1
  43. package/dist-cjs/calendar/internal/CalendarMonth.js +28 -20
  44. package/dist-cjs/calendar/internal/CalendarMonth.js.map +1 -1
  45. package/dist-cjs/calendar/internal/useFocusManagement.js +0 -2
  46. package/dist-cjs/calendar/internal/useFocusManagement.js.map +1 -1
  47. package/dist-cjs/calendar/internal/utils.js +0 -2
  48. package/dist-cjs/calendar/internal/utils.js.map +1 -1
  49. package/dist-cjs/calendar/useCalendar.js +3 -4
  50. package/dist-cjs/calendar/useCalendar.js.map +1 -1
  51. package/dist-cjs/calendar/useCalendarDay.js +0 -2
  52. package/dist-cjs/calendar/useCalendarDay.js.map +1 -1
  53. package/dist-cjs/calendar/useCalendarSelection.js +2 -2
  54. package/dist-cjs/calendar/useCalendarSelection.js.map +1 -1
  55. package/dist-cjs/carousel/Carousel.js +59 -56
  56. package/dist-cjs/carousel/Carousel.js.map +1 -1
  57. package/dist-cjs/carousel/CarouselSlide.js +35 -38
  58. package/dist-cjs/carousel/CarouselSlide.js.map +1 -1
  59. package/dist-cjs/cascading-menu/CascadingMenu.js +15 -15
  60. package/dist-cjs/cascading-menu/CascadingMenu.js.map +1 -1
  61. package/dist-cjs/cascading-menu/CascadingMenuItem.js +72 -61
  62. package/dist-cjs/cascading-menu/CascadingMenuItem.js.map +1 -1
  63. package/dist-cjs/cascading-menu/CascadingMenuList.js +50 -43
  64. package/dist-cjs/cascading-menu/CascadingMenuList.js.map +1 -1
  65. package/dist-cjs/cascading-menu/internal/CascadingMenuAction.js +0 -2
  66. package/dist-cjs/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  67. package/dist-cjs/cascading-menu/internal/keydownHandlers.js +0 -2
  68. package/dist-cjs/cascading-menu/internal/keydownHandlers.js.map +1 -1
  69. package/dist-cjs/cascading-menu/internal/menuPositioning.js +0 -2
  70. package/dist-cjs/cascading-menu/internal/menuPositioning.js.map +1 -1
  71. package/dist-cjs/cascading-menu/internal/stateUtils.js +1 -2
  72. package/dist-cjs/cascading-menu/internal/stateUtils.js.map +1 -1
  73. package/dist-cjs/cascading-menu/internal/useClickAway.js +4 -3
  74. package/dist-cjs/cascading-menu/internal/useClickAway.js.map +1 -1
  75. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js +0 -2
  76. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  77. package/dist-cjs/cascading-menu/internal/useMountedRef.js +0 -2
  78. package/dist-cjs/cascading-menu/internal/useMountedRef.js.map +1 -1
  79. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js +2 -5
  80. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  81. package/dist-cjs/cascading-menu/internal/useRefsManager.js +0 -2
  82. package/dist-cjs/cascading-menu/internal/useRefsManager.js.map +1 -1
  83. package/dist-cjs/cascading-menu/internal/useStateReducer.js +0 -2
  84. package/dist-cjs/cascading-menu/internal/useStateReducer.js.map +1 -1
  85. package/dist-cjs/cascading-menu/stateChangeTypes.js +0 -2
  86. package/dist-cjs/cascading-menu/stateChangeTypes.js.map +1 -1
  87. package/dist-cjs/color-chooser/AlphaInputField.js +17 -15
  88. package/dist-cjs/color-chooser/AlphaInputField.js.map +1 -1
  89. package/dist-cjs/color-chooser/Color.js +4 -9
  90. package/dist-cjs/color-chooser/Color.js.map +1 -1
  91. package/dist-cjs/color-chooser/ColorChooser.js +58 -60
  92. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  93. package/dist-cjs/color-chooser/ColorHelpers.js +5 -11
  94. package/dist-cjs/color-chooser/ColorHelpers.js.map +1 -1
  95. package/dist-cjs/color-chooser/ColorPicker.js +33 -49
  96. package/dist-cjs/color-chooser/ColorPicker.js.map +1 -1
  97. package/dist-cjs/color-chooser/DictTabs.js +24 -23
  98. package/dist-cjs/color-chooser/DictTabs.js.map +1 -1
  99. package/dist-cjs/color-chooser/GetColorPalettes.js +1 -3
  100. package/dist-cjs/color-chooser/GetColorPalettes.js.map +1 -1
  101. package/dist-cjs/color-chooser/HexInput.js +9 -15
  102. package/dist-cjs/color-chooser/HexInput.js.map +1 -1
  103. package/dist-cjs/color-chooser/RGBAInput.js +24 -39
  104. package/dist-cjs/color-chooser/RGBAInput.js.map +1 -1
  105. package/dist-cjs/color-chooser/RGBAInputField.js +14 -12
  106. package/dist-cjs/color-chooser/RGBAInputField.js.map +1 -1
  107. package/dist-cjs/color-chooser/Swatch.js +19 -18
  108. package/dist-cjs/color-chooser/Swatch.js.map +1 -1
  109. package/dist-cjs/color-chooser/Swatches.js +27 -43
  110. package/dist-cjs/color-chooser/Swatches.js.map +1 -1
  111. package/dist-cjs/color-chooser/SwatchesPicker.js +26 -20
  112. package/dist-cjs/color-chooser/SwatchesPicker.js.map +1 -1
  113. package/dist-cjs/color-chooser/color-utils.js +0 -2
  114. package/dist-cjs/color-chooser/color-utils.js.map +1 -1
  115. package/dist-cjs/color-chooser/colorMap.js +1 -2
  116. package/dist-cjs/color-chooser/colorMap.js.map +1 -1
  117. package/dist-cjs/color-chooser/createTabsMapping.js +0 -2
  118. package/dist-cjs/color-chooser/createTabsMapping.js.map +1 -1
  119. package/dist-cjs/combo-box/ComboBox.js +29 -25
  120. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  121. package/dist-cjs/combo-box/useCombobox.js +16 -15
  122. package/dist-cjs/combo-box/useCombobox.js.map +1 -1
  123. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js +37 -33
  124. package/dist-cjs/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  125. package/dist-cjs/combo-box-deprecated/filterHelpers.js +0 -2
  126. package/dist-cjs/combo-box-deprecated/filterHelpers.js.map +1 -1
  127. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js +37 -37
  128. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  129. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js +37 -37
  130. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  131. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js +1 -3
  132. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  133. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js +0 -2
  134. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  135. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js +0 -2
  136. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  137. package/dist-cjs/combo-box-deprecated/internal/usePopperStatus.js +0 -2
  138. package/dist-cjs/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  139. package/dist-cjs/common-hooks/calcPreferredHeight.js +2 -3
  140. package/dist-cjs/common-hooks/calcPreferredHeight.js.map +1 -1
  141. package/dist-cjs/common-hooks/collectionProvider.js +1 -6
  142. package/dist-cjs/common-hooks/collectionProvider.js.map +1 -1
  143. package/dist-cjs/common-hooks/itemToString.js +0 -2
  144. package/dist-cjs/common-hooks/itemToString.js.map +1 -1
  145. package/dist-cjs/common-hooks/keyUtils.js +0 -2
  146. package/dist-cjs/common-hooks/keyUtils.js.map +1 -1
  147. package/dist-cjs/common-hooks/list-dom-utils.js +0 -2
  148. package/dist-cjs/common-hooks/list-dom-utils.js.map +1 -1
  149. package/dist-cjs/common-hooks/selectionTypes.js +0 -2
  150. package/dist-cjs/common-hooks/selectionTypes.js.map +1 -1
  151. package/dist-cjs/common-hooks/useAutoSizer.js +0 -2
  152. package/dist-cjs/common-hooks/useAutoSizer.js.map +1 -1
  153. package/dist-cjs/common-hooks/useCollapsibleGroups.js +0 -2
  154. package/dist-cjs/common-hooks/useCollapsibleGroups.js.map +1 -1
  155. package/dist-cjs/common-hooks/useCollectionItems.js +21 -12
  156. package/dist-cjs/common-hooks/useCollectionItems.js.map +1 -1
  157. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js +0 -2
  158. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  159. package/dist-cjs/common-hooks/useKeyboardNavigation.js +2 -3
  160. package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
  161. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js +3 -2
  162. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  163. package/dist-cjs/common-hooks/useSelection.js +3 -7
  164. package/dist-cjs/common-hooks/useSelection.js.map +1 -1
  165. package/dist-cjs/common-hooks/useTypeahead.js +0 -2
  166. package/dist-cjs/common-hooks/useTypeahead.js.map +1 -1
  167. package/dist-cjs/common-hooks/useViewportTracking.js +0 -2
  168. package/dist-cjs/common-hooks/useViewportTracking.js.map +1 -1
  169. package/dist-cjs/common-hooks/utils/collection-item-utils.js +2 -4
  170. package/dist-cjs/common-hooks/utils/collection-item-utils.js.map +1 -1
  171. package/dist-cjs/common-hooks/utils/filter-utils.js +0 -2
  172. package/dist-cjs/common-hooks/utils/filter-utils.js.map +1 -1
  173. package/dist-cjs/common-hooks/utils/isSelected.js +0 -2
  174. package/dist-cjs/common-hooks/utils/isSelected.js.map +1 -1
  175. package/dist-cjs/contact-details/ContactAction.js +9 -13
  176. package/dist-cjs/contact-details/ContactAction.js.map +1 -1
  177. package/dist-cjs/contact-details/ContactActions.js +1 -8
  178. package/dist-cjs/contact-details/ContactActions.js.map +1 -1
  179. package/dist-cjs/contact-details/ContactAvatar.js +17 -16
  180. package/dist-cjs/contact-details/ContactAvatar.js.map +1 -1
  181. package/dist-cjs/contact-details/ContactDetails.js +6 -10
  182. package/dist-cjs/contact-details/ContactDetails.js.map +1 -1
  183. package/dist-cjs/contact-details/ContactFavoriteToggle.js +13 -12
  184. package/dist-cjs/contact-details/ContactFavoriteToggle.js.map +1 -1
  185. package/dist-cjs/contact-details/ContactMetadata.js +13 -13
  186. package/dist-cjs/contact-details/ContactMetadata.js.map +1 -1
  187. package/dist-cjs/contact-details/ContactMetadataItem.js +5 -23
  188. package/dist-cjs/contact-details/ContactMetadataItem.js.map +1 -1
  189. package/dist-cjs/contact-details/ContactPrimaryInfo.js +16 -15
  190. package/dist-cjs/contact-details/ContactPrimaryInfo.js.map +1 -1
  191. package/dist-cjs/contact-details/ContactSecondaryInfo.js +16 -17
  192. package/dist-cjs/contact-details/ContactSecondaryInfo.js.map +1 -1
  193. package/dist-cjs/contact-details/ContactTertiaryInfo.js +16 -17
  194. package/dist-cjs/contact-details/ContactTertiaryInfo.js.map +1 -1
  195. package/dist-cjs/contact-details/MailLinkComponent.js +1 -12
  196. package/dist-cjs/contact-details/MailLinkComponent.js.map +1 -1
  197. package/dist-cjs/contact-details/internal/ContactDetailsContext.js +0 -2
  198. package/dist-cjs/contact-details/internal/ContactDetailsContext.js.map +1 -1
  199. package/dist-cjs/contact-details/internal/FavoriteToggle.js +18 -17
  200. package/dist-cjs/contact-details/internal/FavoriteToggle.js.map +1 -1
  201. package/dist-cjs/contact-details/internal/FavoriteToggleWithTooltip.js +1 -11
  202. package/dist-cjs/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  203. package/dist-cjs/contact-details/internal/StarIcon.js +10 -14
  204. package/dist-cjs/contact-details/internal/StarIcon.js.map +1 -1
  205. package/dist-cjs/contact-details/internal/StarIconContainer.js +28 -24
  206. package/dist-cjs/contact-details/internal/StarIconContainer.js.map +1 -1
  207. package/dist-cjs/contact-details/internal/useComponentSize.js +0 -2
  208. package/dist-cjs/contact-details/internal/useComponentSize.js.map +1 -1
  209. package/dist-cjs/content-status/ContentStatus.js +16 -31
  210. package/dist-cjs/content-status/ContentStatus.js.map +1 -1
  211. package/dist-cjs/content-status/internal/StatusIndicator.js +30 -23
  212. package/dist-cjs/content-status/internal/StatusIndicator.js.map +1 -1
  213. package/dist-cjs/date-input/DateInputRange.js +91 -96
  214. package/dist-cjs/date-input/DateInputRange.js.map +1 -1
  215. package/dist-cjs/date-input/DateInputSingle.js +55 -58
  216. package/dist-cjs/date-input/DateInputSingle.js.map +1 -1
  217. package/dist-cjs/date-input/utils.js +0 -2
  218. package/dist-cjs/date-input/utils.js.map +1 -1
  219. package/dist-cjs/date-picker/DatePicker.js +3 -26
  220. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  221. package/dist-cjs/date-picker/DatePickerActions.js +13 -23
  222. package/dist-cjs/date-picker/DatePickerActions.js.map +1 -1
  223. package/dist-cjs/date-picker/DatePickerContext.js +0 -2
  224. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  225. package/dist-cjs/date-picker/DatePickerOverlay.js +18 -17
  226. package/dist-cjs/date-picker/DatePickerOverlay.js.map +1 -1
  227. package/dist-cjs/date-picker/DatePickerOverlayProvider.js +3 -8
  228. package/dist-cjs/date-picker/DatePickerOverlayProvider.js.map +1 -1
  229. package/dist-cjs/date-picker/DatePickerRangeInput.js +29 -25
  230. package/dist-cjs/date-picker/DatePickerRangeInput.js.map +1 -1
  231. package/dist-cjs/date-picker/DatePickerRangePanel.js +25 -59
  232. package/dist-cjs/date-picker/DatePickerRangePanel.js.map +1 -1
  233. package/dist-cjs/date-picker/DatePickerSingleInput.js +32 -28
  234. package/dist-cjs/date-picker/DatePickerSingleInput.js.map +1 -1
  235. package/dist-cjs/date-picker/DatePickerSinglePanel.js +19 -49
  236. package/dist-cjs/date-picker/DatePickerSinglePanel.js.map +1 -1
  237. package/dist-cjs/date-picker/useDatePicker.js +2 -4
  238. package/dist-cjs/date-picker/useDatePicker.js.map +1 -1
  239. package/dist-cjs/deck-item/DeckItem.js +21 -18
  240. package/dist-cjs/deck-item/DeckItem.js.map +1 -1
  241. package/dist-cjs/deck-layout/DeckLayout.js +34 -27
  242. package/dist-cjs/deck-layout/DeckLayout.js.map +1 -1
  243. package/dist-cjs/dialog/DialogHeader.css.js +6 -0
  244. package/dist-cjs/dialog/DialogHeader.css.js.map +1 -0
  245. package/dist-cjs/dialog/DialogHeader.js +63 -0
  246. package/dist-cjs/dialog/DialogHeader.js.map +1 -0
  247. package/dist-cjs/dropdown/Dropdown.js +28 -24
  248. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  249. package/dist-cjs/dropdown/DropdownBase.js +29 -29
  250. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  251. package/dist-cjs/dropdown/DropdownButton.js +40 -36
  252. package/dist-cjs/dropdown/DropdownButton.js.map +1 -1
  253. package/dist-cjs/dropdown/useClickAway.js +0 -2
  254. package/dist-cjs/dropdown/useClickAway.js.map +1 -1
  255. package/dist-cjs/dropdown/useDropdown.js +2 -4
  256. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  257. package/dist-cjs/dropdown/useDropdownBase.js +3 -5
  258. package/dist-cjs/dropdown/useDropdownBase.js.map +1 -1
  259. package/dist-cjs/editable-label/EditableLabel.js +23 -19
  260. package/dist-cjs/editable-label/EditableLabel.js.map +1 -1
  261. package/dist-cjs/form-field-context-legacy/FormFieldLegacyContext.js +0 -2
  262. package/dist-cjs/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  263. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js +0 -2
  264. package/dist-cjs/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  265. package/dist-cjs/form-field-legacy/FormActivationIndicator.js +29 -38
  266. package/dist-cjs/form-field-legacy/FormActivationIndicator.js.map +1 -1
  267. package/dist-cjs/form-field-legacy/FormFieldLegacy.js +53 -44
  268. package/dist-cjs/form-field-legacy/FormFieldLegacy.js.map +1 -1
  269. package/dist-cjs/form-field-legacy/FormHelperText.js +1 -7
  270. package/dist-cjs/form-field-legacy/FormHelperText.js.map +1 -1
  271. package/dist-cjs/form-field-legacy/FormLabel.js +34 -24
  272. package/dist-cjs/form-field-legacy/FormLabel.js.map +1 -1
  273. package/dist-cjs/form-field-legacy/NecessityIndicator.js +9 -8
  274. package/dist-cjs/form-field-legacy/NecessityIndicator.js.map +1 -1
  275. package/dist-cjs/form-field-legacy/StatusIndicator.js +22 -18
  276. package/dist-cjs/form-field-legacy/StatusIndicator.js.map +1 -1
  277. package/dist-cjs/form-field-legacy/constant.js +0 -2
  278. package/dist-cjs/form-field-legacy/constant.js.map +1 -1
  279. package/dist-cjs/form-group/FormGroup.js +8 -7
  280. package/dist-cjs/form-group/FormGroup.js.map +1 -1
  281. package/dist-cjs/formatted-input/FormattedInput.js +13 -12
  282. package/dist-cjs/formatted-input/FormattedInput.js.map +1 -1
  283. package/dist-cjs/formatted-input/internal/InputWithMask.js +13 -14
  284. package/dist-cjs/formatted-input/internal/InputWithMask.js.map +1 -1
  285. package/dist-cjs/index.js +14 -4
  286. package/dist-cjs/index.js.map +1 -1
  287. package/dist-cjs/input-legacy/InputLegacy.js +48 -47
  288. package/dist-cjs/input-legacy/InputLegacy.js.map +1 -1
  289. package/dist-cjs/input-legacy/StaticInputAdornment.js +1 -8
  290. package/dist-cjs/input-legacy/StaticInputAdornment.js.map +1 -1
  291. package/dist-cjs/input-legacy/useCursorOnFocus.js +0 -2
  292. package/dist-cjs/input-legacy/useCursorOnFocus.js.map +1 -1
  293. package/dist-cjs/layer-layout/LayerLayout.js +34 -30
  294. package/dist-cjs/layer-layout/LayerLayout.js.map +1 -1
  295. package/dist-cjs/list/Highlighter.js +9 -11
  296. package/dist-cjs/list/Highlighter.js.map +1 -1
  297. package/dist-cjs/list/List.js +61 -63
  298. package/dist-cjs/list/List.js.map +1 -1
  299. package/dist-cjs/list/ListItem.js +29 -28
  300. package/dist-cjs/list/ListItem.js.map +1 -1
  301. package/dist-cjs/list/ListItemGroup.js +0 -2
  302. package/dist-cjs/list/ListItemGroup.js.map +1 -1
  303. package/dist-cjs/list/ListItemHeader.js +0 -2
  304. package/dist-cjs/list/ListItemHeader.js.map +1 -1
  305. package/dist-cjs/list/VirtualizedList.js +52 -48
  306. package/dist-cjs/list/VirtualizedList.js.map +1 -1
  307. package/dist-cjs/list/keyset.js +0 -2
  308. package/dist-cjs/list/keyset.js.map +1 -1
  309. package/dist-cjs/list/useList.js +3 -2
  310. package/dist-cjs/list/useList.js.map +1 -1
  311. package/dist-cjs/list/useListHeight.js +4 -4
  312. package/dist-cjs/list/useListHeight.js.map +1 -1
  313. package/dist-cjs/list/useVirtualization.js +0 -2
  314. package/dist-cjs/list/useVirtualization.js.map +1 -1
  315. package/dist-cjs/list-deprecated/List.js +6 -14
  316. package/dist-cjs/list-deprecated/List.js.map +1 -1
  317. package/dist-cjs/list-deprecated/ListBase.js +99 -87
  318. package/dist-cjs/list-deprecated/ListBase.js.map +1 -1
  319. package/dist-cjs/list-deprecated/ListItem.js +1 -8
  320. package/dist-cjs/list-deprecated/ListItem.js.map +1 -1
  321. package/dist-cjs/list-deprecated/ListItemBase.js +10 -14
  322. package/dist-cjs/list-deprecated/ListItemBase.js.map +1 -1
  323. package/dist-cjs/list-deprecated/ListItemContext.js +0 -2
  324. package/dist-cjs/list-deprecated/ListItemContext.js.map +1 -1
  325. package/dist-cjs/list-deprecated/ListStateContext.js +0 -2
  326. package/dist-cjs/list-deprecated/ListStateContext.js.map +1 -1
  327. package/dist-cjs/list-deprecated/internal/DescendantContext.js +1 -6
  328. package/dist-cjs/list-deprecated/internal/DescendantContext.js.map +1 -1
  329. package/dist-cjs/list-deprecated/internal/Highlighter.js +4 -11
  330. package/dist-cjs/list-deprecated/internal/Highlighter.js.map +1 -1
  331. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js +2 -3
  332. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  333. package/dist-cjs/list-deprecated/internal/helpers.js +0 -2
  334. package/dist-cjs/list-deprecated/internal/helpers.js.map +1 -1
  335. package/dist-cjs/list-deprecated/internal/scrollIntoView.js +0 -2
  336. package/dist-cjs/list-deprecated/internal/scrollIntoView.js.map +1 -1
  337. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js +0 -2
  338. package/dist-cjs/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  339. package/dist-cjs/list-deprecated/internal/useWidth.js +0 -2
  340. package/dist-cjs/list-deprecated/internal/useWidth.js.map +1 -1
  341. package/dist-cjs/list-deprecated/itemToString.js +0 -2
  342. package/dist-cjs/list-deprecated/itemToString.js.map +1 -1
  343. package/dist-cjs/list-deprecated/useList.js +7 -9
  344. package/dist-cjs/list-deprecated/useList.js.map +1 -1
  345. package/dist-cjs/list-deprecated/useListItem.js +5 -2
  346. package/dist-cjs/list-deprecated/useListItem.js.map +1 -1
  347. package/dist-cjs/list-deprecated/useTypeSelect.js +2 -2
  348. package/dist-cjs/list-deprecated/useTypeSelect.js.map +1 -1
  349. package/dist-cjs/list-next/ListItemNext.js +25 -25
  350. package/dist-cjs/list-next/ListItemNext.js.map +1 -1
  351. package/dist-cjs/list-next/ListNext.js +5 -7
  352. package/dist-cjs/list-next/ListNext.js.map +1 -1
  353. package/dist-cjs/list-next/ListNextContext.js +0 -2
  354. package/dist-cjs/list-next/ListNextContext.js.map +1 -1
  355. package/dist-cjs/list-next/useList.js +3 -6
  356. package/dist-cjs/list-next/useList.js.map +1 -1
  357. package/dist-cjs/logo/Logo.js +1 -7
  358. package/dist-cjs/logo/Logo.js.map +1 -1
  359. package/dist-cjs/logo/LogoImage.js +9 -8
  360. package/dist-cjs/logo/LogoImage.js.map +1 -1
  361. package/dist-cjs/logo/LogoSeparator.js +1 -7
  362. package/dist-cjs/logo/LogoSeparator.js.map +1 -1
  363. package/dist-cjs/menu-button/MenuButton.js +21 -17
  364. package/dist-cjs/menu-button/MenuButton.js.map +1 -1
  365. package/dist-cjs/menu-button/MenuButtonTrigger.js +21 -17
  366. package/dist-cjs/menu-button/MenuButtonTrigger.js.map +1 -1
  367. package/dist-cjs/metric/Metric.js +5 -7
  368. package/dist-cjs/metric/Metric.js.map +1 -1
  369. package/dist-cjs/metric/MetricContent.js +32 -30
  370. package/dist-cjs/metric/MetricContent.js.map +1 -1
  371. package/dist-cjs/metric/MetricHeader.js +20 -26
  372. package/dist-cjs/metric/MetricHeader.js.map +1 -1
  373. package/dist-cjs/metric/internal/MetricContext.js +0 -2
  374. package/dist-cjs/metric/internal/MetricContext.js.map +1 -1
  375. package/dist-cjs/portal/Portal.js +3 -10
  376. package/dist-cjs/portal/Portal.js.map +1 -1
  377. package/dist-cjs/query-input/QueryInput.js +21 -19
  378. package/dist-cjs/query-input/QueryInput.js.map +1 -1
  379. package/dist-cjs/query-input/internal/CategoryList.js +8 -17
  380. package/dist-cjs/query-input/internal/CategoryList.js.map +1 -1
  381. package/dist-cjs/query-input/internal/CategoryListContext.js +0 -2
  382. package/dist-cjs/query-input/internal/CategoryListContext.js.map +1 -1
  383. package/dist-cjs/query-input/internal/CategoryListItem.js +9 -32
  384. package/dist-cjs/query-input/internal/CategoryListItem.js.map +1 -1
  385. package/dist-cjs/query-input/internal/QueryInputBody.js +16 -24
  386. package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
  387. package/dist-cjs/query-input/internal/SearchList.js +21 -28
  388. package/dist-cjs/query-input/internal/SearchList.js.map +1 -1
  389. package/dist-cjs/query-input/internal/ValueList.js +18 -25
  390. package/dist-cjs/query-input/internal/ValueList.js.map +1 -1
  391. package/dist-cjs/query-input/internal/ValueSelector.js +42 -37
  392. package/dist-cjs/query-input/internal/ValueSelector.js.map +1 -1
  393. package/dist-cjs/query-input/internal/usePopperStatus.js +0 -2
  394. package/dist-cjs/query-input/internal/usePopperStatus.js.map +1 -1
  395. package/dist-cjs/query-input/useQueryInput.js +0 -2
  396. package/dist-cjs/query-input/useQueryInput.js.map +1 -1
  397. package/dist-cjs/responsive/OverflowReducer.js +7 -9
  398. package/dist-cjs/responsive/OverflowReducer.js.map +1 -1
  399. package/dist-cjs/responsive/overflowUtils.js +0 -2
  400. package/dist-cjs/responsive/overflowUtils.js.map +1 -1
  401. package/dist-cjs/responsive/useDynamicCollapse.js +0 -2
  402. package/dist-cjs/responsive/useDynamicCollapse.js.map +1 -1
  403. package/dist-cjs/responsive/useInstantCollapse.js +1 -4
  404. package/dist-cjs/responsive/useInstantCollapse.js.map +1 -1
  405. package/dist-cjs/responsive/useOverflow.js +0 -2
  406. package/dist-cjs/responsive/useOverflow.js.map +1 -1
  407. package/dist-cjs/responsive/useOverflowCollectionItems.js +1 -4
  408. package/dist-cjs/responsive/useOverflowCollectionItems.js.map +1 -1
  409. package/dist-cjs/responsive/useOverflowLayout.js +4 -7
  410. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  411. package/dist-cjs/responsive/useReclaimSpace.js +1 -4
  412. package/dist-cjs/responsive/useReclaimSpace.js.map +1 -1
  413. package/dist-cjs/responsive/useResizeObserver.js +0 -2
  414. package/dist-cjs/responsive/useResizeObserver.js.map +1 -1
  415. package/dist-cjs/responsive/useWidth.js +0 -2
  416. package/dist-cjs/responsive/useWidth.js.map +1 -1
  417. package/dist-cjs/responsive/utils.js +2 -10
  418. package/dist-cjs/responsive/utils.js.map +1 -1
  419. package/dist-cjs/search-input/SearchInput.js +27 -24
  420. package/dist-cjs/search-input/SearchInput.js.map +1 -1
  421. package/dist-cjs/skip-link/SkipLink.js +5 -6
  422. package/dist-cjs/skip-link/SkipLink.js.map +1 -1
  423. package/dist-cjs/skip-link/SkipLinks.js +1 -8
  424. package/dist-cjs/skip-link/SkipLinks.js.map +1 -1
  425. package/dist-cjs/skip-link/internal/useManageFocusOnTarget.js +0 -2
  426. package/dist-cjs/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  427. package/dist-cjs/slider/Slider.js +47 -41
  428. package/dist-cjs/slider/Slider.js.map +1 -1
  429. package/dist-cjs/slider/internal/SliderContext.js +0 -2
  430. package/dist-cjs/slider/internal/SliderContext.js.map +1 -1
  431. package/dist-cjs/slider/internal/SliderMarks.js +8 -10
  432. package/dist-cjs/slider/internal/SliderMarks.js.map +1 -1
  433. package/dist-cjs/slider/internal/SliderSelection.js +13 -12
  434. package/dist-cjs/slider/internal/SliderSelection.js.map +1 -1
  435. package/dist-cjs/slider/internal/SliderThumb.js +49 -45
  436. package/dist-cjs/slider/internal/SliderThumb.js.map +1 -1
  437. package/dist-cjs/slider/internal/SliderTrack.js +26 -24
  438. package/dist-cjs/slider/internal/SliderTrack.js.map +1 -1
  439. package/dist-cjs/slider/internal/useKeyDownThumb.js +1 -4
  440. package/dist-cjs/slider/internal/useKeyDownThumb.js.map +1 -1
  441. package/dist-cjs/slider/internal/utils.js +5 -12
  442. package/dist-cjs/slider/internal/utils.js.map +1 -1
  443. package/dist-cjs/static-list/StaticList.css.js +1 -1
  444. package/dist-cjs/static-list/StaticList.js +1 -8
  445. package/dist-cjs/static-list/StaticList.js.map +1 -1
  446. package/dist-cjs/static-list/StaticListItem.js +1 -8
  447. package/dist-cjs/static-list/StaticListItem.js.map +1 -1
  448. package/dist-cjs/static-list/StaticListItemContent.js +1 -8
  449. package/dist-cjs/static-list/StaticListItemContent.js.map +1 -1
  450. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js +1 -10
  451. package/dist-cjs/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  452. package/dist-cjs/stepped-tracker/SteppedTracker.js +6 -12
  453. package/dist-cjs/stepped-tracker/SteppedTracker.js.map +1 -1
  454. package/dist-cjs/stepped-tracker/SteppedTrackerContext.js +2 -10
  455. package/dist-cjs/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  456. package/dist-cjs/stepped-tracker/TrackerConnector/TrackerConnector.js +1 -5
  457. package/dist-cjs/stepped-tracker/TrackerConnector/TrackerConnector.js.map +1 -1
  458. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js +24 -31
  459. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  460. package/dist-cjs/stepper-input/StepperInput.js +84 -89
  461. package/dist-cjs/stepper-input/StepperInput.js.map +1 -1
  462. package/dist-cjs/stepper-input/internal/useActivateWhileMouseDown.js +2 -6
  463. package/dist-cjs/stepper-input/internal/useActivateWhileMouseDown.js.map +1 -1
  464. package/dist-cjs/stepper-input/internal/useInterval.js +0 -2
  465. package/dist-cjs/stepper-input/internal/useInterval.js.map +1 -1
  466. package/dist-cjs/stepper-input/internal/utils.js +5 -12
  467. package/dist-cjs/stepper-input/internal/utils.js.map +1 -1
  468. package/dist-cjs/stepper-input/useStepperInput.js +6 -14
  469. package/dist-cjs/stepper-input/useStepperInput.js.map +1 -1
  470. package/dist-cjs/system-status/SystemStatus.js +13 -15
  471. package/dist-cjs/system-status/SystemStatus.js.map +1 -1
  472. package/dist-cjs/system-status/SystemStatusActions.js +1 -7
  473. package/dist-cjs/system-status/SystemStatusActions.js.map +1 -1
  474. package/dist-cjs/system-status/SystemStatusContent.js +1 -7
  475. package/dist-cjs/system-status/SystemStatusContent.js.map +1 -1
  476. package/dist-cjs/tabs/Tab.js +74 -57
  477. package/dist-cjs/tabs/Tab.js.map +1 -1
  478. package/dist-cjs/tabs/TabActivationIndicator.js +1 -10
  479. package/dist-cjs/tabs/TabActivationIndicator.js.map +1 -1
  480. package/dist-cjs/tabs/TabPanel.js +11 -10
  481. package/dist-cjs/tabs/TabPanel.js.map +1 -1
  482. package/dist-cjs/tabs/Tabs.js +21 -17
  483. package/dist-cjs/tabs/Tabs.js.map +1 -1
  484. package/dist-cjs/tabs/Tabstrip.js +86 -72
  485. package/dist-cjs/tabs/Tabstrip.js.map +1 -1
  486. package/dist-cjs/tabs/drag-drop/Draggable.js +5 -6
  487. package/dist-cjs/tabs/drag-drop/Draggable.js.map +1 -1
  488. package/dist-cjs/tabs/drag-drop/drag-utils.js +1 -4
  489. package/dist-cjs/tabs/drag-drop/drag-utils.js.map +1 -1
  490. package/dist-cjs/tabs/drag-drop/dragDropTypes.js +0 -2
  491. package/dist-cjs/tabs/drag-drop/dragDropTypes.js.map +1 -1
  492. package/dist-cjs/tabs/drag-drop/useDragDrop.js +0 -2
  493. package/dist-cjs/tabs/drag-drop/useDragDrop.js.map +1 -1
  494. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js +9 -8
  495. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  496. package/dist-cjs/tabs/drag-drop/useDragSpacers.js +1 -2
  497. package/dist-cjs/tabs/drag-drop/useDragSpacers.js.map +1 -1
  498. package/dist-cjs/tabs/useActivationIndicator.js +0 -2
  499. package/dist-cjs/tabs/useActivationIndicator.js.map +1 -1
  500. package/dist-cjs/tabs/useEditableItem.js +0 -2
  501. package/dist-cjs/tabs/useEditableItem.js.map +1 -1
  502. package/dist-cjs/tabs/useItemsWithIds.js +1 -7
  503. package/dist-cjs/tabs/useItemsWithIds.js.map +1 -1
  504. package/dist-cjs/tabs/useKeyboardNavigation.js +0 -2
  505. package/dist-cjs/tabs/useKeyboardNavigation.js.map +1 -1
  506. package/dist-cjs/tabs/useSelection.js +1 -3
  507. package/dist-cjs/tabs/useSelection.js.map +1 -1
  508. package/dist-cjs/tabs/useTabs.js +3 -5
  509. package/dist-cjs/tabs/useTabs.js.map +1 -1
  510. package/dist-cjs/tabs/useTabstrip.js +3 -3
  511. package/dist-cjs/tabs/useTabstrip.js.map +1 -1
  512. package/dist-cjs/tabs-next/TabBar.css.js +6 -0
  513. package/dist-cjs/tabs-next/TabBar.css.js.map +1 -0
  514. package/dist-cjs/tabs-next/TabBar.js +41 -0
  515. package/dist-cjs/tabs-next/TabBar.js.map +1 -0
  516. package/dist-cjs/tabs-next/TabListNext.css.js +6 -0
  517. package/dist-cjs/tabs-next/TabListNext.css.js.map +1 -0
  518. package/dist-cjs/tabs-next/TabListNext.js +127 -0
  519. package/dist-cjs/tabs-next/TabListNext.js.map +1 -0
  520. package/dist-cjs/tabs-next/TabNext.css.js +1 -1
  521. package/dist-cjs/tabs-next/TabNext.js +74 -58
  522. package/dist-cjs/tabs-next/TabNext.js.map +1 -1
  523. package/dist-cjs/tabs-next/TabNextAction.js +35 -0
  524. package/dist-cjs/tabs-next/TabNextAction.js.map +1 -0
  525. package/dist-cjs/tabs-next/TabNextContext.js +15 -17
  526. package/dist-cjs/tabs-next/TabNextContext.js.map +1 -1
  527. package/dist-cjs/tabs-next/TabNextPanel.css.js +6 -0
  528. package/dist-cjs/tabs-next/TabNextPanel.css.js.map +1 -0
  529. package/dist-cjs/tabs-next/TabNextPanel.js +77 -0
  530. package/dist-cjs/tabs-next/TabNextPanel.js.map +1 -0
  531. package/dist-cjs/tabs-next/TabNextTrigger.css.js +6 -0
  532. package/dist-cjs/tabs-next/TabNextTrigger.css.js.map +1 -0
  533. package/dist-cjs/tabs-next/TabNextTrigger.js +77 -0
  534. package/dist-cjs/tabs-next/TabNextTrigger.js.map +1 -0
  535. package/dist-cjs/tabs-next/TabOverflowList.css.js +6 -0
  536. package/dist-cjs/tabs-next/TabOverflowList.css.js.map +1 -0
  537. package/dist-cjs/tabs-next/TabOverflowList.js +132 -0
  538. package/dist-cjs/tabs-next/TabOverflowList.js.map +1 -0
  539. package/dist-cjs/tabs-next/TabsNext.js +176 -0
  540. package/dist-cjs/tabs-next/TabsNext.js.map +1 -0
  541. package/dist-cjs/tabs-next/TabsNextContext.js +33 -0
  542. package/dist-cjs/tabs-next/TabsNextContext.js.map +1 -0
  543. package/dist-cjs/tabs-next/hooks/useCollection.js +91 -0
  544. package/dist-cjs/tabs-next/hooks/useCollection.js.map +1 -0
  545. package/dist-cjs/tabs-next/hooks/useFocusOutside.js +25 -0
  546. package/dist-cjs/tabs-next/hooks/useFocusOutside.js.map +1 -0
  547. package/dist-cjs/tabs-next/hooks/useOverflow.js +141 -0
  548. package/dist-cjs/tabs-next/hooks/useOverflow.js.map +1 -0
  549. package/dist-cjs/toast-group/ToastGroup.js +8 -7
  550. package/dist-cjs/toast-group/ToastGroup.js.map +1 -1
  551. package/dist-cjs/tokenized-input/TokenizedInput.js +9 -8
  552. package/dist-cjs/tokenized-input/TokenizedInput.js.map +1 -1
  553. package/dist-cjs/tokenized-input/TokenizedInputBase.js +105 -96
  554. package/dist-cjs/tokenized-input/TokenizedInputBase.js.map +1 -1
  555. package/dist-cjs/tokenized-input/internal/InputPill.js +24 -26
  556. package/dist-cjs/tokenized-input/internal/InputPill.js.map +1 -1
  557. package/dist-cjs/tokenized-input/internal/InputRuler.js +1 -7
  558. package/dist-cjs/tokenized-input/internal/InputRuler.js.map +1 -1
  559. package/dist-cjs/tokenized-input/internal/calcFirstHiddenIndex.js +0 -2
  560. package/dist-cjs/tokenized-input/internal/calcFirstHiddenIndex.js.map +1 -1
  561. package/dist-cjs/tokenized-input/internal/defaultItemToString.js +0 -2
  562. package/dist-cjs/tokenized-input/internal/defaultItemToString.js.map +1 -1
  563. package/dist-cjs/tokenized-input/internal/getCursorPosition.js +0 -2
  564. package/dist-cjs/tokenized-input/internal/getCursorPosition.js.map +1 -1
  565. package/dist-cjs/tokenized-input/internal/isPlainObject.js +0 -2
  566. package/dist-cjs/tokenized-input/internal/isPlainObject.js.map +1 -1
  567. package/dist-cjs/tokenized-input/internal/useResizeObserver.js +0 -2
  568. package/dist-cjs/tokenized-input/internal/useResizeObserver.js.map +1 -1
  569. package/dist-cjs/tokenized-input/internal/useWidth.js +0 -2
  570. package/dist-cjs/tokenized-input/internal/useWidth.js.map +1 -1
  571. package/dist-cjs/tokenized-input/useTokenizedInput.js +11 -7
  572. package/dist-cjs/tokenized-input/useTokenizedInput.js.map +1 -1
  573. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js +68 -58
  574. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  575. package/dist-cjs/tokenized-input-next/internal/InputPill.js +6 -12
  576. package/dist-cjs/tokenized-input-next/internal/InputPill.js.map +1 -1
  577. package/dist-cjs/tokenized-input-next/internal/calcFirstHiddenIndex.js +0 -2
  578. package/dist-cjs/tokenized-input-next/internal/calcFirstHiddenIndex.js.map +1 -1
  579. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js +0 -2
  580. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  581. package/dist-cjs/tokenized-input-next/internal/useWidth.js +1 -3
  582. package/dist-cjs/tokenized-input-next/internal/useWidth.js.map +1 -1
  583. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js +9 -10
  584. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  585. package/dist-cjs/toolbar/Toolbar.js +43 -35
  586. package/dist-cjs/toolbar/Toolbar.js.map +1 -1
  587. package/dist-cjs/toolbar/ToolbarButton.js +10 -9
  588. package/dist-cjs/toolbar/ToolbarButton.js.map +1 -1
  589. package/dist-cjs/toolbar/Tooltray.js +23 -29
  590. package/dist-cjs/toolbar/Tooltray.js.map +1 -1
  591. package/dist-cjs/toolbar/internal/renderToolbarItems.js +7 -12
  592. package/dist-cjs/toolbar/internal/renderToolbarItems.js.map +1 -1
  593. package/dist-cjs/toolbar/internal/renderTrayTools.js +23 -18
  594. package/dist-cjs/toolbar/internal/renderTrayTools.js.map +1 -1
  595. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js +40 -43
  596. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  597. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js +1 -6
  598. package/dist-cjs/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  599. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js +1 -6
  600. package/dist-cjs/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  601. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js +2 -4
  602. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  603. package/dist-cjs/tree/Tree.js +57 -48
  604. package/dist-cjs/tree/Tree.js.map +1 -1
  605. package/dist-cjs/tree/TreeNode.js +11 -25
  606. package/dist-cjs/tree/TreeNode.js.map +1 -1
  607. package/dist-cjs/tree/use-tree-keyboard-navigation.js +0 -2
  608. package/dist-cjs/tree/use-tree-keyboard-navigation.js.map +1 -1
  609. package/dist-cjs/tree/useTree.js +11 -6
  610. package/dist-cjs/tree/useTree.js.map +1 -1
  611. package/dist-cjs/utils/escapeRegExp.js +0 -2
  612. package/dist-cjs/utils/escapeRegExp.js.map +1 -1
  613. package/dist-cjs/utils/forwardCallbackProps.js +0 -2
  614. package/dist-cjs/utils/forwardCallbackProps.js.map +1 -1
  615. package/dist-cjs/utils/isEmail.js +0 -2
  616. package/dist-cjs/utils/isEmail.js.map +1 -1
  617. package/dist-cjs/utils/isPlainObject.js +0 -2
  618. package/dist-cjs/utils/isPlainObject.js.map +1 -1
  619. package/dist-cjs/utils/partition.js +0 -2
  620. package/dist-cjs/utils/partition.js.map +1 -1
  621. package/dist-cjs/utils/useClickOutside.js +1 -3
  622. package/dist-cjs/utils/useClickOutside.js.map +1 -1
  623. package/dist-cjs/utils/useEventCallback.js +4 -3
  624. package/dist-cjs/utils/useEventCallback.js.map +1 -1
  625. package/dist-cjs/utils/useIsViewportLargerThanBreakpoint.js +0 -2
  626. package/dist-cjs/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  627. package/dist-cjs/utils/useLayoutEffectOnce.js +0 -2
  628. package/dist-cjs/utils/useLayoutEffectOnce.js.map +1 -1
  629. package/dist-cjs/utils/useLayoutEffectSkipFirst.js +0 -2
  630. package/dist-cjs/utils/useLayoutEffectSkipFirst.js.map +1 -1
  631. package/dist-cjs/utils/useOverflowDetection.js +0 -2
  632. package/dist-cjs/utils/useOverflowDetection.js.map +1 -1
  633. package/dist-cjs/utils/useSlideSelection.js +0 -2
  634. package/dist-cjs/utils/useSlideSelection.js.map +1 -1
  635. package/dist-cjs/window/ElectronWindow.js +7 -21
  636. package/dist-cjs/window/ElectronWindow.js.map +1 -1
  637. package/dist-cjs/window/WindowContext.js +1 -7
  638. package/dist-cjs/window/WindowContext.js.map +1 -1
  639. package/dist-cjs/window/desktop-utils.js +0 -2
  640. package/dist-cjs/window/desktop-utils.js.map +1 -1
  641. package/dist-es/app-header/AppHeader.js +9 -6
  642. package/dist-es/app-header/AppHeader.js.map +1 -1
  643. package/dist-es/breadcrumbs/Breadcrumb.js +43 -41
  644. package/dist-es/breadcrumbs/Breadcrumb.js.map +1 -1
  645. package/dist-es/breadcrumbs/Breadcrumbs.js +28 -31
  646. package/dist-es/breadcrumbs/Breadcrumbs.js.map +1 -1
  647. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js +19 -14
  648. package/dist-es/breadcrumbs/internal/BreadcrumbsCollapsed.js.map +1 -1
  649. package/dist-es/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  650. package/dist-es/breadcrumbs/internal/BreadcrumbsSeparator.js +1 -3
  651. package/dist-es/breadcrumbs/internal/BreadcrumbsSeparator.js.map +1 -1
  652. package/dist-es/breadcrumbs/internal/useFocusMenuRemount.js.map +1 -1
  653. package/dist-es/button-bar/ButtonBar.js +20 -25
  654. package/dist-es/button-bar/ButtonBar.js.map +1 -1
  655. package/dist-es/button-bar/OrderedButton.js +16 -13
  656. package/dist-es/button-bar/OrderedButton.js.map +1 -1
  657. package/dist-es/button-bar/internal/ButtonBarContext.js.map +1 -1
  658. package/dist-es/button-bar/internal/DescendantContext.js +1 -4
  659. package/dist-es/button-bar/internal/DescendantContext.js.map +1 -1
  660. package/dist-es/button-bar/internal/useDescendant.js.map +1 -1
  661. package/dist-es/button-bar/internal/useDescendants.js.map +1 -1
  662. package/dist-es/calendar/Calendar.js +20 -14
  663. package/dist-es/calendar/Calendar.js.map +1 -1
  664. package/dist-es/calendar/CalendarDateGrid.js +34 -27
  665. package/dist-es/calendar/CalendarDateGrid.js.map +1 -1
  666. package/dist-es/calendar/CalendarNavigation.js +103 -94
  667. package/dist-es/calendar/CalendarNavigation.js.map +1 -1
  668. package/dist-es/calendar/CalendarWeekHeader.js +18 -11
  669. package/dist-es/calendar/CalendarWeekHeader.js.map +1 -1
  670. package/dist-es/calendar/formatDate.js +3 -6
  671. package/dist-es/calendar/formatDate.js.map +1 -1
  672. package/dist-es/calendar/internal/CalendarContext.js.map +1 -1
  673. package/dist-es/calendar/internal/CalendarDay.js +48 -39
  674. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  675. package/dist-es/calendar/internal/CalendarMonth.js +28 -18
  676. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  677. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  678. package/dist-es/calendar/internal/utils.js.map +1 -1
  679. package/dist-es/calendar/useCalendar.js +3 -2
  680. package/dist-es/calendar/useCalendar.js.map +1 -1
  681. package/dist-es/calendar/useCalendarDay.js.map +1 -1
  682. package/dist-es/calendar/useCalendarSelection.js +2 -0
  683. package/dist-es/calendar/useCalendarSelection.js.map +1 -1
  684. package/dist-es/carousel/Carousel.js +59 -54
  685. package/dist-es/carousel/Carousel.js.map +1 -1
  686. package/dist-es/carousel/CarouselSlide.js +35 -36
  687. package/dist-es/carousel/CarouselSlide.js.map +1 -1
  688. package/dist-es/cascading-menu/CascadingMenu.js +15 -13
  689. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  690. package/dist-es/cascading-menu/CascadingMenuItem.js +72 -59
  691. package/dist-es/cascading-menu/CascadingMenuItem.js.map +1 -1
  692. package/dist-es/cascading-menu/CascadingMenuList.js +50 -41
  693. package/dist-es/cascading-menu/CascadingMenuList.js.map +1 -1
  694. package/dist-es/cascading-menu/internal/CascadingMenuAction.js.map +1 -1
  695. package/dist-es/cascading-menu/internal/keydownHandlers.js.map +1 -1
  696. package/dist-es/cascading-menu/internal/menuPositioning.js.map +1 -1
  697. package/dist-es/cascading-menu/internal/stateUtils.js +1 -0
  698. package/dist-es/cascading-menu/internal/stateUtils.js.map +1 -1
  699. package/dist-es/cascading-menu/internal/useClickAway.js +4 -1
  700. package/dist-es/cascading-menu/internal/useClickAway.js.map +1 -1
  701. package/dist-es/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  702. package/dist-es/cascading-menu/internal/useMountedRef.js.map +1 -1
  703. package/dist-es/cascading-menu/internal/useMouseHandlers.js +2 -3
  704. package/dist-es/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  705. package/dist-es/cascading-menu/internal/useRefsManager.js.map +1 -1
  706. package/dist-es/cascading-menu/internal/useStateReducer.js.map +1 -1
  707. package/dist-es/cascading-menu/stateChangeTypes.js.map +1 -1
  708. package/dist-es/color-chooser/AlphaInputField.js +17 -13
  709. package/dist-es/color-chooser/AlphaInputField.js.map +1 -1
  710. package/dist-es/color-chooser/Color.js +1 -0
  711. package/dist-es/color-chooser/Color.js.map +1 -1
  712. package/dist-es/color-chooser/ColorChooser.js +58 -58
  713. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  714. package/dist-es/color-chooser/ColorHelpers.js +5 -9
  715. package/dist-es/color-chooser/ColorHelpers.js.map +1 -1
  716. package/dist-es/color-chooser/ColorPicker.js +33 -47
  717. package/dist-es/color-chooser/ColorPicker.js.map +1 -1
  718. package/dist-es/color-chooser/DictTabs.js +24 -21
  719. package/dist-es/color-chooser/DictTabs.js.map +1 -1
  720. package/dist-es/color-chooser/GetColorPalettes.js +1 -1
  721. package/dist-es/color-chooser/GetColorPalettes.js.map +1 -1
  722. package/dist-es/color-chooser/HexInput.js +9 -13
  723. package/dist-es/color-chooser/HexInput.js.map +1 -1
  724. package/dist-es/color-chooser/RGBAInput.js +24 -37
  725. package/dist-es/color-chooser/RGBAInput.js.map +1 -1
  726. package/dist-es/color-chooser/RGBAInputField.js +14 -10
  727. package/dist-es/color-chooser/RGBAInputField.js.map +1 -1
  728. package/dist-es/color-chooser/Swatch.js +19 -16
  729. package/dist-es/color-chooser/Swatch.js.map +1 -1
  730. package/dist-es/color-chooser/Swatches.js +27 -41
  731. package/dist-es/color-chooser/Swatches.js.map +1 -1
  732. package/dist-es/color-chooser/SwatchesPicker.js +26 -18
  733. package/dist-es/color-chooser/SwatchesPicker.js.map +1 -1
  734. package/dist-es/color-chooser/color-utils.js.map +1 -1
  735. package/dist-es/color-chooser/colorMap.js +1 -0
  736. package/dist-es/color-chooser/colorMap.js.map +1 -1
  737. package/dist-es/color-chooser/createTabsMapping.js.map +1 -1
  738. package/dist-es/combo-box/ComboBox.js +29 -23
  739. package/dist-es/combo-box/ComboBox.js.map +1 -1
  740. package/dist-es/combo-box/useCombobox.js +16 -13
  741. package/dist-es/combo-box/useCombobox.js.map +1 -1
  742. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js +37 -31
  743. package/dist-es/combo-box-deprecated/ComboBoxDeprecated.js.map +1 -1
  744. package/dist-es/combo-box-deprecated/filterHelpers.js.map +1 -1
  745. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js +37 -35
  746. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  747. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js +37 -35
  748. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  749. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js +1 -1
  750. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js.map +1 -1
  751. package/dist-es/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  752. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  753. package/dist-es/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  754. package/dist-es/common-hooks/calcPreferredHeight.js +2 -1
  755. package/dist-es/common-hooks/calcPreferredHeight.js.map +1 -1
  756. package/dist-es/common-hooks/collectionProvider.js +1 -4
  757. package/dist-es/common-hooks/collectionProvider.js.map +1 -1
  758. package/dist-es/common-hooks/itemToString.js.map +1 -1
  759. package/dist-es/common-hooks/keyUtils.js.map +1 -1
  760. package/dist-es/common-hooks/list-dom-utils.js.map +1 -1
  761. package/dist-es/common-hooks/selectionTypes.js.map +1 -1
  762. package/dist-es/common-hooks/useAutoSizer.js.map +1 -1
  763. package/dist-es/common-hooks/useCollapsibleGroups.js.map +1 -1
  764. package/dist-es/common-hooks/useCollectionItems.js +21 -10
  765. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  766. package/dist-es/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  767. package/dist-es/common-hooks/useKeyboardNavigation.js +2 -1
  768. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  769. package/dist-es/common-hooks/useKeyboardNavigationPanel.js +3 -0
  770. package/dist-es/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  771. package/dist-es/common-hooks/useSelection.js +3 -5
  772. package/dist-es/common-hooks/useSelection.js.map +1 -1
  773. package/dist-es/common-hooks/useTypeahead.js.map +1 -1
  774. package/dist-es/common-hooks/useViewportTracking.js.map +1 -1
  775. package/dist-es/common-hooks/utils/collection-item-utils.js +2 -2
  776. package/dist-es/common-hooks/utils/collection-item-utils.js.map +1 -1
  777. package/dist-es/common-hooks/utils/filter-utils.js.map +1 -1
  778. package/dist-es/common-hooks/utils/isSelected.js.map +1 -1
  779. package/dist-es/contact-details/ContactAction.js +9 -11
  780. package/dist-es/contact-details/ContactAction.js.map +1 -1
  781. package/dist-es/contact-details/ContactActions.js +1 -6
  782. package/dist-es/contact-details/ContactActions.js.map +1 -1
  783. package/dist-es/contact-details/ContactAvatar.js +17 -14
  784. package/dist-es/contact-details/ContactAvatar.js.map +1 -1
  785. package/dist-es/contact-details/ContactDetails.js +6 -8
  786. package/dist-es/contact-details/ContactDetails.js.map +1 -1
  787. package/dist-es/contact-details/ContactFavoriteToggle.js +13 -10
  788. package/dist-es/contact-details/ContactFavoriteToggle.js.map +1 -1
  789. package/dist-es/contact-details/ContactMetadata.js +13 -11
  790. package/dist-es/contact-details/ContactMetadata.js.map +1 -1
  791. package/dist-es/contact-details/ContactMetadataItem.js +5 -21
  792. package/dist-es/contact-details/ContactMetadataItem.js.map +1 -1
  793. package/dist-es/contact-details/ContactPrimaryInfo.js +16 -13
  794. package/dist-es/contact-details/ContactPrimaryInfo.js.map +1 -1
  795. package/dist-es/contact-details/ContactSecondaryInfo.js +16 -15
  796. package/dist-es/contact-details/ContactSecondaryInfo.js.map +1 -1
  797. package/dist-es/contact-details/ContactTertiaryInfo.js +16 -15
  798. package/dist-es/contact-details/ContactTertiaryInfo.js.map +1 -1
  799. package/dist-es/contact-details/MailLinkComponent.js +1 -10
  800. package/dist-es/contact-details/MailLinkComponent.js.map +1 -1
  801. package/dist-es/contact-details/internal/ContactDetailsContext.js.map +1 -1
  802. package/dist-es/contact-details/internal/FavoriteToggle.js +18 -15
  803. package/dist-es/contact-details/internal/FavoriteToggle.js.map +1 -1
  804. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js +1 -9
  805. package/dist-es/contact-details/internal/FavoriteToggleWithTooltip.js.map +1 -1
  806. package/dist-es/contact-details/internal/StarIcon.js +10 -12
  807. package/dist-es/contact-details/internal/StarIcon.js.map +1 -1
  808. package/dist-es/contact-details/internal/StarIconContainer.js +28 -22
  809. package/dist-es/contact-details/internal/StarIconContainer.js.map +1 -1
  810. package/dist-es/contact-details/internal/useComponentSize.js.map +1 -1
  811. package/dist-es/content-status/ContentStatus.js +16 -29
  812. package/dist-es/content-status/ContentStatus.js.map +1 -1
  813. package/dist-es/content-status/internal/StatusIndicator.js +30 -21
  814. package/dist-es/content-status/internal/StatusIndicator.js.map +1 -1
  815. package/dist-es/date-input/DateInputRange.js +91 -94
  816. package/dist-es/date-input/DateInputRange.js.map +1 -1
  817. package/dist-es/date-input/DateInputSingle.js +55 -56
  818. package/dist-es/date-input/DateInputSingle.js.map +1 -1
  819. package/dist-es/date-input/utils.js.map +1 -1
  820. package/dist-es/date-picker/DatePicker.js +3 -24
  821. package/dist-es/date-picker/DatePicker.js.map +1 -1
  822. package/dist-es/date-picker/DatePickerActions.js +13 -21
  823. package/dist-es/date-picker/DatePickerActions.js.map +1 -1
  824. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  825. package/dist-es/date-picker/DatePickerOverlay.js +18 -15
  826. package/dist-es/date-picker/DatePickerOverlay.js.map +1 -1
  827. package/dist-es/date-picker/DatePickerOverlayProvider.js +3 -6
  828. package/dist-es/date-picker/DatePickerOverlayProvider.js.map +1 -1
  829. package/dist-es/date-picker/DatePickerRangeInput.js +29 -23
  830. package/dist-es/date-picker/DatePickerRangeInput.js.map +1 -1
  831. package/dist-es/date-picker/DatePickerRangePanel.js +25 -53
  832. package/dist-es/date-picker/DatePickerRangePanel.js.map +1 -1
  833. package/dist-es/date-picker/DatePickerSingleInput.js +32 -26
  834. package/dist-es/date-picker/DatePickerSingleInput.js.map +1 -1
  835. package/dist-es/date-picker/DatePickerSinglePanel.js +19 -43
  836. package/dist-es/date-picker/DatePickerSinglePanel.js.map +1 -1
  837. package/dist-es/date-picker/useDatePicker.js +2 -2
  838. package/dist-es/date-picker/useDatePicker.js.map +1 -1
  839. package/dist-es/deck-item/DeckItem.js +21 -16
  840. package/dist-es/deck-item/DeckItem.js.map +1 -1
  841. package/dist-es/deck-layout/DeckLayout.js +34 -25
  842. package/dist-es/deck-layout/DeckLayout.js.map +1 -1
  843. package/dist-es/dialog/DialogHeader.css.js +4 -0
  844. package/dist-es/dialog/DialogHeader.css.js.map +1 -0
  845. package/dist-es/dialog/DialogHeader.js +61 -0
  846. package/dist-es/dialog/DialogHeader.js.map +1 -0
  847. package/dist-es/dropdown/Dropdown.js +28 -22
  848. package/dist-es/dropdown/Dropdown.js.map +1 -1
  849. package/dist-es/dropdown/DropdownBase.js +29 -27
  850. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  851. package/dist-es/dropdown/DropdownButton.js +40 -34
  852. package/dist-es/dropdown/DropdownButton.js.map +1 -1
  853. package/dist-es/dropdown/useClickAway.js.map +1 -1
  854. package/dist-es/dropdown/useDropdown.js +2 -2
  855. package/dist-es/dropdown/useDropdown.js.map +1 -1
  856. package/dist-es/dropdown/useDropdownBase.js +3 -3
  857. package/dist-es/dropdown/useDropdownBase.js.map +1 -1
  858. package/dist-es/editable-label/EditableLabel.js +23 -17
  859. package/dist-es/editable-label/EditableLabel.js.map +1 -1
  860. package/dist-es/form-field-context-legacy/FormFieldLegacyContext.js.map +1 -1
  861. package/dist-es/form-field-context-legacy/useFormFieldLegacyProps.js.map +1 -1
  862. package/dist-es/form-field-legacy/FormActivationIndicator.js +29 -36
  863. package/dist-es/form-field-legacy/FormActivationIndicator.js.map +1 -1
  864. package/dist-es/form-field-legacy/FormFieldLegacy.js +53 -42
  865. package/dist-es/form-field-legacy/FormFieldLegacy.js.map +1 -1
  866. package/dist-es/form-field-legacy/FormHelperText.js +1 -5
  867. package/dist-es/form-field-legacy/FormHelperText.js.map +1 -1
  868. package/dist-es/form-field-legacy/FormLabel.js +34 -22
  869. package/dist-es/form-field-legacy/FormLabel.js.map +1 -1
  870. package/dist-es/form-field-legacy/NecessityIndicator.js +9 -6
  871. package/dist-es/form-field-legacy/NecessityIndicator.js.map +1 -1
  872. package/dist-es/form-field-legacy/StatusIndicator.js +22 -16
  873. package/dist-es/form-field-legacy/StatusIndicator.js.map +1 -1
  874. package/dist-es/form-group/FormGroup.js +8 -5
  875. package/dist-es/form-group/FormGroup.js.map +1 -1
  876. package/dist-es/formatted-input/FormattedInput.js +13 -10
  877. package/dist-es/formatted-input/FormattedInput.js.map +1 -1
  878. package/dist-es/formatted-input/internal/InputWithMask.js +13 -12
  879. package/dist-es/formatted-input/internal/InputWithMask.js.map +1 -1
  880. package/dist-es/index.js +7 -1
  881. package/dist-es/index.js.map +1 -1
  882. package/dist-es/input-legacy/InputLegacy.js +48 -45
  883. package/dist-es/input-legacy/InputLegacy.js.map +1 -1
  884. package/dist-es/input-legacy/StaticInputAdornment.js +1 -6
  885. package/dist-es/input-legacy/StaticInputAdornment.js.map +1 -1
  886. package/dist-es/input-legacy/useCursorOnFocus.js.map +1 -1
  887. package/dist-es/layer-layout/LayerLayout.js +34 -28
  888. package/dist-es/layer-layout/LayerLayout.js.map +1 -1
  889. package/dist-es/list/Highlighter.js +9 -9
  890. package/dist-es/list/Highlighter.js.map +1 -1
  891. package/dist-es/list/List.js +61 -61
  892. package/dist-es/list/List.js.map +1 -1
  893. package/dist-es/list/ListItem.js +29 -26
  894. package/dist-es/list/ListItem.js.map +1 -1
  895. package/dist-es/list/VirtualizedList.js +52 -46
  896. package/dist-es/list/VirtualizedList.js.map +1 -1
  897. package/dist-es/list/keyset.js.map +1 -1
  898. package/dist-es/list/useList.js +3 -0
  899. package/dist-es/list/useList.js.map +1 -1
  900. package/dist-es/list/useListHeight.js +4 -2
  901. package/dist-es/list/useListHeight.js.map +1 -1
  902. package/dist-es/list/useVirtualization.js.map +1 -1
  903. package/dist-es/list-deprecated/List.js +6 -12
  904. package/dist-es/list-deprecated/List.js.map +1 -1
  905. package/dist-es/list-deprecated/ListBase.js +99 -85
  906. package/dist-es/list-deprecated/ListBase.js.map +1 -1
  907. package/dist-es/list-deprecated/ListItem.js +1 -6
  908. package/dist-es/list-deprecated/ListItem.js.map +1 -1
  909. package/dist-es/list-deprecated/ListItemBase.js +10 -12
  910. package/dist-es/list-deprecated/ListItemBase.js.map +1 -1
  911. package/dist-es/list-deprecated/ListItemContext.js.map +1 -1
  912. package/dist-es/list-deprecated/ListStateContext.js.map +1 -1
  913. package/dist-es/list-deprecated/internal/DescendantContext.js +1 -4
  914. package/dist-es/list-deprecated/internal/DescendantContext.js.map +1 -1
  915. package/dist-es/list-deprecated/internal/Highlighter.js +4 -9
  916. package/dist-es/list-deprecated/internal/Highlighter.js.map +1 -1
  917. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js +2 -1
  918. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  919. package/dist-es/list-deprecated/internal/scrollIntoView.js.map +1 -1
  920. package/dist-es/list-deprecated/internal/useListAutoSizer.js.map +1 -1
  921. package/dist-es/list-deprecated/internal/useWidth.js.map +1 -1
  922. package/dist-es/list-deprecated/itemToString.js.map +1 -1
  923. package/dist-es/list-deprecated/useList.js +7 -7
  924. package/dist-es/list-deprecated/useList.js.map +1 -1
  925. package/dist-es/list-deprecated/useListItem.js +5 -0
  926. package/dist-es/list-deprecated/useListItem.js.map +1 -1
  927. package/dist-es/list-deprecated/useTypeSelect.js +2 -0
  928. package/dist-es/list-deprecated/useTypeSelect.js.map +1 -1
  929. package/dist-es/list-next/ListItemNext.js +25 -23
  930. package/dist-es/list-next/ListItemNext.js.map +1 -1
  931. package/dist-es/list-next/ListNext.js +5 -5
  932. package/dist-es/list-next/ListNext.js.map +1 -1
  933. package/dist-es/list-next/ListNextContext.js.map +1 -1
  934. package/dist-es/list-next/useList.js +3 -4
  935. package/dist-es/list-next/useList.js.map +1 -1
  936. package/dist-es/logo/Logo.js +1 -5
  937. package/dist-es/logo/Logo.js.map +1 -1
  938. package/dist-es/logo/LogoImage.js +9 -6
  939. package/dist-es/logo/LogoImage.js.map +1 -1
  940. package/dist-es/logo/LogoSeparator.js +1 -5
  941. package/dist-es/logo/LogoSeparator.js.map +1 -1
  942. package/dist-es/menu-button/MenuButton.js +21 -15
  943. package/dist-es/menu-button/MenuButton.js.map +1 -1
  944. package/dist-es/menu-button/MenuButtonTrigger.js +21 -15
  945. package/dist-es/menu-button/MenuButtonTrigger.js.map +1 -1
  946. package/dist-es/metric/Metric.js +5 -5
  947. package/dist-es/metric/Metric.js.map +1 -1
  948. package/dist-es/metric/MetricContent.js +32 -28
  949. package/dist-es/metric/MetricContent.js.map +1 -1
  950. package/dist-es/metric/MetricHeader.js +20 -24
  951. package/dist-es/metric/MetricHeader.js.map +1 -1
  952. package/dist-es/metric/internal/MetricContext.js.map +1 -1
  953. package/dist-es/portal/Portal.js +3 -8
  954. package/dist-es/portal/Portal.js.map +1 -1
  955. package/dist-es/query-input/QueryInput.js +21 -17
  956. package/dist-es/query-input/QueryInput.js.map +1 -1
  957. package/dist-es/query-input/internal/CategoryList.js +8 -15
  958. package/dist-es/query-input/internal/CategoryList.js.map +1 -1
  959. package/dist-es/query-input/internal/CategoryListContext.js.map +1 -1
  960. package/dist-es/query-input/internal/CategoryListItem.js +9 -30
  961. package/dist-es/query-input/internal/CategoryListItem.js.map +1 -1
  962. package/dist-es/query-input/internal/QueryInputBody.js +16 -22
  963. package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
  964. package/dist-es/query-input/internal/SearchList.js +21 -26
  965. package/dist-es/query-input/internal/SearchList.js.map +1 -1
  966. package/dist-es/query-input/internal/ValueList.js +18 -23
  967. package/dist-es/query-input/internal/ValueList.js.map +1 -1
  968. package/dist-es/query-input/internal/ValueSelector.js +42 -35
  969. package/dist-es/query-input/internal/ValueSelector.js.map +1 -1
  970. package/dist-es/query-input/internal/usePopperStatus.js.map +1 -1
  971. package/dist-es/query-input/useQueryInput.js.map +1 -1
  972. package/dist-es/responsive/OverflowReducer.js +7 -7
  973. package/dist-es/responsive/OverflowReducer.js.map +1 -1
  974. package/dist-es/responsive/overflowUtils.js.map +1 -1
  975. package/dist-es/responsive/useDynamicCollapse.js.map +1 -1
  976. package/dist-es/responsive/useInstantCollapse.js +1 -2
  977. package/dist-es/responsive/useInstantCollapse.js.map +1 -1
  978. package/dist-es/responsive/useOverflow.js.map +1 -1
  979. package/dist-es/responsive/useOverflowCollectionItems.js +1 -2
  980. package/dist-es/responsive/useOverflowCollectionItems.js.map +1 -1
  981. package/dist-es/responsive/useOverflowLayout.js +4 -5
  982. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  983. package/dist-es/responsive/useReclaimSpace.js +1 -2
  984. package/dist-es/responsive/useReclaimSpace.js.map +1 -1
  985. package/dist-es/responsive/useResizeObserver.js.map +1 -1
  986. package/dist-es/responsive/useWidth.js.map +1 -1
  987. package/dist-es/responsive/utils.js +2 -8
  988. package/dist-es/responsive/utils.js.map +1 -1
  989. package/dist-es/search-input/SearchInput.js +27 -22
  990. package/dist-es/search-input/SearchInput.js.map +1 -1
  991. package/dist-es/skip-link/SkipLink.js +5 -4
  992. package/dist-es/skip-link/SkipLink.js.map +1 -1
  993. package/dist-es/skip-link/SkipLinks.js +1 -6
  994. package/dist-es/skip-link/SkipLinks.js.map +1 -1
  995. package/dist-es/skip-link/internal/useManageFocusOnTarget.js.map +1 -1
  996. package/dist-es/slider/Slider.js +47 -39
  997. package/dist-es/slider/Slider.js.map +1 -1
  998. package/dist-es/slider/internal/SliderContext.js.map +1 -1
  999. package/dist-es/slider/internal/SliderMarks.js +8 -8
  1000. package/dist-es/slider/internal/SliderMarks.js.map +1 -1
  1001. package/dist-es/slider/internal/SliderSelection.js +13 -10
  1002. package/dist-es/slider/internal/SliderSelection.js.map +1 -1
  1003. package/dist-es/slider/internal/SliderThumb.js +49 -43
  1004. package/dist-es/slider/internal/SliderThumb.js.map +1 -1
  1005. package/dist-es/slider/internal/SliderTrack.js +26 -22
  1006. package/dist-es/slider/internal/SliderTrack.js.map +1 -1
  1007. package/dist-es/slider/internal/useKeyDownThumb.js +1 -2
  1008. package/dist-es/slider/internal/useKeyDownThumb.js.map +1 -1
  1009. package/dist-es/slider/internal/utils.js +5 -10
  1010. package/dist-es/slider/internal/utils.js.map +1 -1
  1011. package/dist-es/static-list/StaticList.css.js +1 -1
  1012. package/dist-es/static-list/StaticList.js +1 -6
  1013. package/dist-es/static-list/StaticList.js.map +1 -1
  1014. package/dist-es/static-list/StaticListItem.js +1 -6
  1015. package/dist-es/static-list/StaticListItem.js.map +1 -1
  1016. package/dist-es/static-list/StaticListItemContent.js +1 -6
  1017. package/dist-es/static-list/StaticListItemContent.js.map +1 -1
  1018. package/dist-es/stepped-tracker/StepLabel/StepLabel.js +1 -8
  1019. package/dist-es/stepped-tracker/StepLabel/StepLabel.js.map +1 -1
  1020. package/dist-es/stepped-tracker/SteppedTracker.js +6 -10
  1021. package/dist-es/stepped-tracker/SteppedTracker.js.map +1 -1
  1022. package/dist-es/stepped-tracker/SteppedTrackerContext.js +2 -8
  1023. package/dist-es/stepped-tracker/SteppedTrackerContext.js.map +1 -1
  1024. package/dist-es/stepped-tracker/TrackerConnector/TrackerConnector.js +1 -3
  1025. package/dist-es/stepped-tracker/TrackerConnector/TrackerConnector.js.map +1 -1
  1026. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js +24 -29
  1027. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  1028. package/dist-es/stepper-input/StepperInput.js +84 -87
  1029. package/dist-es/stepper-input/StepperInput.js.map +1 -1
  1030. package/dist-es/stepper-input/internal/useActivateWhileMouseDown.js +2 -4
  1031. package/dist-es/stepper-input/internal/useActivateWhileMouseDown.js.map +1 -1
  1032. package/dist-es/stepper-input/internal/useInterval.js.map +1 -1
  1033. package/dist-es/stepper-input/internal/utils.js +5 -10
  1034. package/dist-es/stepper-input/internal/utils.js.map +1 -1
  1035. package/dist-es/stepper-input/useStepperInput.js +6 -12
  1036. package/dist-es/stepper-input/useStepperInput.js.map +1 -1
  1037. package/dist-es/system-status/SystemStatus.js +13 -13
  1038. package/dist-es/system-status/SystemStatus.js.map +1 -1
  1039. package/dist-es/system-status/SystemStatusActions.js +1 -5
  1040. package/dist-es/system-status/SystemStatusActions.js.map +1 -1
  1041. package/dist-es/system-status/SystemStatusContent.js +1 -5
  1042. package/dist-es/system-status/SystemStatusContent.js.map +1 -1
  1043. package/dist-es/tabs/Tab.js +74 -55
  1044. package/dist-es/tabs/Tab.js.map +1 -1
  1045. package/dist-es/tabs/TabActivationIndicator.js +1 -8
  1046. package/dist-es/tabs/TabActivationIndicator.js.map +1 -1
  1047. package/dist-es/tabs/TabPanel.js +11 -8
  1048. package/dist-es/tabs/TabPanel.js.map +1 -1
  1049. package/dist-es/tabs/Tabs.js +21 -15
  1050. package/dist-es/tabs/Tabs.js.map +1 -1
  1051. package/dist-es/tabs/Tabstrip.js +86 -70
  1052. package/dist-es/tabs/Tabstrip.js.map +1 -1
  1053. package/dist-es/tabs/drag-drop/Draggable.js +5 -4
  1054. package/dist-es/tabs/drag-drop/Draggable.js.map +1 -1
  1055. package/dist-es/tabs/drag-drop/drag-utils.js +1 -2
  1056. package/dist-es/tabs/drag-drop/drag-utils.js.map +1 -1
  1057. package/dist-es/tabs/drag-drop/useDragDrop.js.map +1 -1
  1058. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js +9 -6
  1059. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  1060. package/dist-es/tabs/drag-drop/useDragSpacers.js +1 -0
  1061. package/dist-es/tabs/drag-drop/useDragSpacers.js.map +1 -1
  1062. package/dist-es/tabs/useActivationIndicator.js.map +1 -1
  1063. package/dist-es/tabs/useEditableItem.js.map +1 -1
  1064. package/dist-es/tabs/useItemsWithIds.js +1 -5
  1065. package/dist-es/tabs/useItemsWithIds.js.map +1 -1
  1066. package/dist-es/tabs/useKeyboardNavigation.js.map +1 -1
  1067. package/dist-es/tabs/useSelection.js +1 -1
  1068. package/dist-es/tabs/useSelection.js.map +1 -1
  1069. package/dist-es/tabs/useTabs.js +3 -3
  1070. package/dist-es/tabs/useTabs.js.map +1 -1
  1071. package/dist-es/tabs/useTabstrip.js +3 -1
  1072. package/dist-es/tabs/useTabstrip.js.map +1 -1
  1073. package/dist-es/tabs-next/TabBar.css.js +4 -0
  1074. package/dist-es/tabs-next/TabBar.css.js.map +1 -0
  1075. package/dist-es/tabs-next/TabBar.js +39 -0
  1076. package/dist-es/tabs-next/TabBar.js.map +1 -0
  1077. package/dist-es/tabs-next/TabListNext.css.js +4 -0
  1078. package/dist-es/tabs-next/TabListNext.css.js.map +1 -0
  1079. package/dist-es/tabs-next/TabListNext.js +125 -0
  1080. package/dist-es/tabs-next/TabListNext.js.map +1 -0
  1081. package/dist-es/tabs-next/TabNext.css.js +1 -1
  1082. package/dist-es/tabs-next/TabNext.js +77 -55
  1083. package/dist-es/tabs-next/TabNext.js.map +1 -1
  1084. package/dist-es/tabs-next/TabNextAction.js +33 -0
  1085. package/dist-es/tabs-next/TabNextAction.js.map +1 -0
  1086. package/dist-es/tabs-next/TabNextContext.js +14 -14
  1087. package/dist-es/tabs-next/TabNextContext.js.map +1 -1
  1088. package/dist-es/tabs-next/TabNextPanel.css.js +4 -0
  1089. package/dist-es/tabs-next/TabNextPanel.css.js.map +1 -0
  1090. package/dist-es/tabs-next/TabNextPanel.js +75 -0
  1091. package/dist-es/tabs-next/TabNextPanel.js.map +1 -0
  1092. package/dist-es/tabs-next/TabNextTrigger.css.js +4 -0
  1093. package/dist-es/tabs-next/TabNextTrigger.css.js.map +1 -0
  1094. package/dist-es/tabs-next/TabNextTrigger.js +75 -0
  1095. package/dist-es/tabs-next/TabNextTrigger.js.map +1 -0
  1096. package/dist-es/tabs-next/TabOverflowList.css.js +4 -0
  1097. package/dist-es/tabs-next/TabOverflowList.css.js.map +1 -0
  1098. package/dist-es/tabs-next/TabOverflowList.js +130 -0
  1099. package/dist-es/tabs-next/TabOverflowList.js.map +1 -0
  1100. package/dist-es/tabs-next/TabsNext.js +174 -0
  1101. package/dist-es/tabs-next/TabsNext.js.map +1 -0
  1102. package/dist-es/tabs-next/TabsNextContext.js +30 -0
  1103. package/dist-es/tabs-next/TabsNextContext.js.map +1 -0
  1104. package/dist-es/tabs-next/hooks/useCollection.js +89 -0
  1105. package/dist-es/tabs-next/hooks/useCollection.js.map +1 -0
  1106. package/dist-es/tabs-next/hooks/useFocusOutside.js +23 -0
  1107. package/dist-es/tabs-next/hooks/useFocusOutside.js.map +1 -0
  1108. package/dist-es/tabs-next/hooks/useOverflow.js +139 -0
  1109. package/dist-es/tabs-next/hooks/useOverflow.js.map +1 -0
  1110. package/dist-es/toast-group/ToastGroup.js +8 -5
  1111. package/dist-es/toast-group/ToastGroup.js.map +1 -1
  1112. package/dist-es/tokenized-input/TokenizedInput.js +9 -6
  1113. package/dist-es/tokenized-input/TokenizedInput.js.map +1 -1
  1114. package/dist-es/tokenized-input/TokenizedInputBase.js +104 -89
  1115. package/dist-es/tokenized-input/TokenizedInputBase.js.map +1 -1
  1116. package/dist-es/tokenized-input/internal/InputPill.js +24 -24
  1117. package/dist-es/tokenized-input/internal/InputPill.js.map +1 -1
  1118. package/dist-es/tokenized-input/internal/InputRuler.js +1 -5
  1119. package/dist-es/tokenized-input/internal/InputRuler.js.map +1 -1
  1120. package/dist-es/tokenized-input/internal/calcFirstHiddenIndex.js.map +1 -1
  1121. package/dist-es/tokenized-input/internal/defaultItemToString.js.map +1 -1
  1122. package/dist-es/tokenized-input/internal/getCursorPosition.js.map +1 -1
  1123. package/dist-es/tokenized-input/internal/useResizeObserver.js.map +1 -1
  1124. package/dist-es/tokenized-input/internal/useWidth.js.map +1 -1
  1125. package/dist-es/tokenized-input/useTokenizedInput.js +10 -0
  1126. package/dist-es/tokenized-input/useTokenizedInput.js.map +1 -1
  1127. package/dist-es/tokenized-input-next/TokenizedInputNext.js +68 -56
  1128. package/dist-es/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  1129. package/dist-es/tokenized-input-next/internal/InputPill.js +6 -10
  1130. package/dist-es/tokenized-input-next/internal/InputPill.js.map +1 -1
  1131. package/dist-es/tokenized-input-next/internal/calcFirstHiddenIndex.js.map +1 -1
  1132. package/dist-es/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  1133. package/dist-es/tokenized-input-next/internal/useWidth.js +1 -1
  1134. package/dist-es/tokenized-input-next/internal/useWidth.js.map +1 -1
  1135. package/dist-es/tokenized-input-next/useTokenizedInputNext.js +8 -3
  1136. package/dist-es/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  1137. package/dist-es/toolbar/Toolbar.js +43 -33
  1138. package/dist-es/toolbar/Toolbar.js.map +1 -1
  1139. package/dist-es/toolbar/ToolbarButton.js +10 -7
  1140. package/dist-es/toolbar/ToolbarButton.js.map +1 -1
  1141. package/dist-es/toolbar/Tooltray.js +23 -27
  1142. package/dist-es/toolbar/Tooltray.js.map +1 -1
  1143. package/dist-es/toolbar/internal/renderToolbarItems.js +7 -10
  1144. package/dist-es/toolbar/internal/renderToolbarItems.js.map +1 -1
  1145. package/dist-es/toolbar/internal/renderTrayTools.js +23 -16
  1146. package/dist-es/toolbar/internal/renderTrayTools.js.map +1 -1
  1147. package/dist-es/toolbar/overflow-panel/OverflowPanel.js +40 -41
  1148. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  1149. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js +1 -4
  1150. package/dist-es/toolbar/overflow-panel/OverflowSeparator.js.map +1 -1
  1151. package/dist-es/toolbar/toolbar-field/ToolbarField.js +1 -4
  1152. package/dist-es/toolbar/toolbar-field/ToolbarField.js.map +1 -1
  1153. package/dist-es/toolbar/toolbar-field/useToolbarField.js +2 -2
  1154. package/dist-es/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  1155. package/dist-es/tree/Tree.js +57 -46
  1156. package/dist-es/tree/Tree.js.map +1 -1
  1157. package/dist-es/tree/TreeNode.js +11 -23
  1158. package/dist-es/tree/TreeNode.js.map +1 -1
  1159. package/dist-es/tree/use-tree-keyboard-navigation.js.map +1 -1
  1160. package/dist-es/tree/useTree.js +11 -4
  1161. package/dist-es/tree/useTree.js.map +1 -1
  1162. package/dist-es/utils/escapeRegExp.js.map +1 -1
  1163. package/dist-es/utils/forwardCallbackProps.js.map +1 -1
  1164. package/dist-es/utils/isEmail.js.map +1 -1
  1165. package/dist-es/utils/partition.js.map +1 -1
  1166. package/dist-es/utils/useClickOutside.js +1 -1
  1167. package/dist-es/utils/useClickOutside.js.map +1 -1
  1168. package/dist-es/utils/useEventCallback.js +4 -1
  1169. package/dist-es/utils/useEventCallback.js.map +1 -1
  1170. package/dist-es/utils/useIsViewportLargerThanBreakpoint.js.map +1 -1
  1171. package/dist-es/utils/useLayoutEffectOnce.js.map +1 -1
  1172. package/dist-es/utils/useLayoutEffectSkipFirst.js.map +1 -1
  1173. package/dist-es/utils/useOverflowDetection.js.map +1 -1
  1174. package/dist-es/utils/useSlideSelection.js.map +1 -1
  1175. package/dist-es/window/ElectronWindow.js +6 -14
  1176. package/dist-es/window/ElectronWindow.js.map +1 -1
  1177. package/dist-es/window/WindowContext.js +1 -5
  1178. package/dist-es/window/WindowContext.js.map +1 -1
  1179. package/dist-es/window/desktop-utils.js.map +1 -1
  1180. package/dist-types/contact-details/internal/StarIcon.d.ts +1 -2
  1181. package/dist-types/contact-details/internal/StarIconContainer.d.ts +2 -2
  1182. package/dist-types/date-picker/DatePickerActions.d.ts +3 -3
  1183. package/dist-types/dialog/DialogHeader.d.ts +28 -0
  1184. package/dist-types/dialog/index.d.ts +1 -0
  1185. package/dist-types/editable-label/EditableLabel.d.ts +1 -2
  1186. package/dist-types/index.d.ts +1 -0
  1187. package/dist-types/list-deprecated/internal/DescendantContext.d.ts +1 -2
  1188. package/dist-types/responsive/overflowUtils.d.ts +1 -1
  1189. package/dist-types/tabs/drag-drop/drag-utils.d.ts +6 -6
  1190. package/dist-types/tabs-next/TabBar.d.ts +12 -0
  1191. package/dist-types/tabs-next/TabListNext.d.ts +12 -0
  1192. package/dist-types/tabs-next/TabNext.d.ts +9 -2
  1193. package/dist-types/tabs-next/TabNextAction.d.ts +4 -0
  1194. package/dist-types/tabs-next/TabNextContext.d.ts +9 -16
  1195. package/dist-types/tabs-next/TabNextPanel.d.ts +8 -0
  1196. package/dist-types/tabs-next/TabNextTrigger.d.ts +4 -0
  1197. package/dist-types/tabs-next/TabOverflowList.d.ts +11 -0
  1198. package/dist-types/tabs-next/TabsNext.d.ts +17 -0
  1199. package/dist-types/tabs-next/TabsNextContext.d.ts +21 -0
  1200. package/dist-types/tabs-next/hooks/useCollection.d.ts +18 -0
  1201. package/dist-types/tabs-next/hooks/useFocusOutside.d.ts +2 -0
  1202. package/dist-types/tabs-next/hooks/useOverflow.d.ts +11 -0
  1203. package/dist-types/tabs-next/index.d.ts +6 -1
  1204. package/package.json +9 -8
  1205. package/dist-cjs/tabs-next/OverflowMenu.js +0 -48
  1206. package/dist-cjs/tabs-next/OverflowMenu.js.map +0 -1
  1207. package/dist-cjs/tabs-next/TabstripNext.css.js +0 -6
  1208. package/dist-cjs/tabs-next/TabstripNext.css.js.map +0 -1
  1209. package/dist-cjs/tabs-next/TabstripNext.js +0 -193
  1210. package/dist-cjs/tabs-next/TabstripNext.js.map +0 -1
  1211. package/dist-es/tabs-next/OverflowMenu.js +0 -44
  1212. package/dist-es/tabs-next/OverflowMenu.js.map +0 -1
  1213. package/dist-es/tabs-next/TabstripNext.css.js +0 -4
  1214. package/dist-es/tabs-next/TabstripNext.css.js.map +0 -1
  1215. package/dist-es/tabs-next/TabstripNext.js +0 -185
  1216. package/dist-es/tabs-next/TabstripNext.js.map +0 -1
  1217. package/dist-types/tabs-next/OverflowMenu.d.ts +0 -11
  1218. package/dist-types/tabs-next/TabstripNext.d.ts +0 -12
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var clsx = require('clsx');
@@ -56,16 +54,19 @@ const FormattedInput = react.forwardRef(
56
54
  value: valueState || "",
57
55
  onChange: handleChange
58
56
  });
59
- return /* @__PURE__ */ jsxRuntime.jsx(InputLegacy.InputLegacy, {
60
- className: clsx.clsx(InputWithMask.baseName, className),
61
- inputComponent: InputWithMask.InputWithMask,
62
- inputProps: { mask, textAlign, ...inputProps },
63
- onChange: rifm$1.onChange,
64
- textAlign,
65
- value: rifm$1.value,
66
- ...other,
67
- ref
68
- });
57
+ return /* @__PURE__ */ jsxRuntime.jsx(
58
+ InputLegacy.InputLegacy,
59
+ {
60
+ className: clsx.clsx(InputWithMask.baseName, className),
61
+ inputComponent: InputWithMask.InputWithMask,
62
+ inputProps: { mask, textAlign, ...inputProps },
63
+ onChange: rifm$1.onChange,
64
+ textAlign,
65
+ value: rifm$1.value,
66
+ ...other,
67
+ ref
68
+ }
69
+ );
69
70
  }
70
71
  );
71
72
 
@@ -1 +1 @@
1
- {"version":3,"file":"FormattedInput.js","sources":["../src/formatted-input/FormattedInput.tsx"],"sourcesContent":["import { useControlled } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { forwardRef } from \"react\";\nimport { useRifm } from \"rifm\";\nimport {\n InputLegacy as Input,\n type InputLegacyProps as InputProps,\n} from \"../input-legacy\";\nimport {\n InputWithMask,\n type InputWithMaskProps,\n baseName,\n} from \"./internal/InputWithMask\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport formattedInputCss from \"./FormattedInput.css\";\n\nexport type MaskFunction = (value: string | undefined) => boolean;\n\nexport interface RifmOptions {\n format?: (str: string) => string;\n replace?: (str: string) => string;\n append?: (str: string) => string;\n mask?: boolean | MaskFunction;\n accept?: RegExp;\n}\n\nexport interface FormattedInputProps extends Omit<InputProps, \"onChange\"> {\n mask?: string;\n onChange?: (value: string) => void;\n rifmOptions?: RifmOptions;\n value?: string;\n defaultValue?: string;\n}\n\nconst defaultFormatter = (string: string): string => string;\nconst defaultRifmOptions: RifmOptions = {};\n\nexport const FormattedInput = forwardRef<HTMLInputElement, FormattedInputProps>(\n function FormattedInput(\n {\n defaultValue = \"\",\n className,\n inputProps,\n mask,\n onChange,\n rifmOptions = defaultRifmOptions,\n value: valueProp,\n textAlign,\n ...other\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-formatted-input\",\n css: formattedInputCss,\n window: targetWindow,\n });\n\n const [valueState, setValueState] = useControlled<string | undefined>({\n default: defaultValue,\n controlled: valueProp,\n name: \"FormattedInput\",\n state: \"value\",\n });\n\n const handleChange = (value: string) => {\n setValueState(value);\n onChange?.(value);\n };\n\n let rifmMask = false;\n\n if (rifmOptions.mask) {\n rifmMask =\n typeof rifmOptions.mask === \"function\"\n ? rifmOptions.mask(valueState)\n : rifmOptions.mask;\n }\n\n const rifm = useRifm({\n format: defaultFormatter,\n accept: /.*/,\n ...rifmOptions,\n mask: rifmMask,\n value: valueState || \"\",\n onChange: handleChange,\n });\n\n return (\n <Input\n className={clsx(baseName, className)}\n inputComponent={InputWithMask}\n inputProps={{ mask, textAlign, ...inputProps } as InputWithMaskProps}\n onChange={rifm.onChange}\n textAlign={textAlign}\n value={rifm.value}\n {...other}\n ref={ref}\n />\n );\n },\n);\n"],"names":["forwardRef","FormattedInput","useWindow","useComponentCssInjection","formattedInputCss","useControlled","rifm","useRifm","jsx","Input","clsx","baseName","InputWithMask"],"mappings":";;;;;;;;;;;;;;;;AAqCA,MAAM,gBAAA,GAAmB,CAAC,MAA2B,KAAA,MAAA,CAAA;AACrD,MAAM,qBAAkC,EAAC,CAAA;AAElC,MAAM,cAAiB,GAAAA,gBAAA;AAAA,EAC5B,SAASC,eACP,CAAA;AAAA,IACE,YAAe,GAAA,EAAA;AAAA,IACf,SAAA;AAAA,IACA,UAAA;AAAA,IACA,IAAA;AAAA,IACA,QAAA;AAAA,IACA,WAAc,GAAA,kBAAA;AAAA,IACd,KAAO,EAAA,SAAA;AAAA,IACP,SAAA;AAAA,IACG,GAAA,KAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,sBAAA;AAAA,MACR,GAAK,EAAAC,gBAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,MAAM,CAAC,UAAA,EAAY,aAAa,CAAA,GAAIC,kBAAkC,CAAA;AAAA,MACpE,OAAS,EAAA,YAAA;AAAA,MACT,UAAY,EAAA,SAAA;AAAA,MACZ,IAAM,EAAA,gBAAA;AAAA,MACN,KAAO,EAAA,OAAA;AAAA,KACR,CAAA,CAAA;AAED,IAAM,MAAA,YAAA,GAAe,CAAC,KAAkB,KAAA;AACtC,MAAA,aAAA,CAAc,KAAK,CAAA,CAAA;AACnB,MAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACb,CAAA;AAEA,IAAA,IAAI,QAAW,GAAA,KAAA,CAAA;AAEf,IAAA,IAAI,YAAY,IAAM,EAAA;AACpB,MACE,QAAA,GAAA,OAAO,YAAY,IAAS,KAAA,UAAA,GACxB,YAAY,IAAK,CAAA,UAAU,IAC3B,WAAY,CAAA,IAAA,CAAA;AAAA,KACpB;AAEA,IAAA,MAAMC,SAAOC,YAAQ,CAAA;AAAA,MACnB,MAAQ,EAAA,gBAAA;AAAA,MACR,MAAQ,EAAA,IAAA;AAAA,MACR,GAAG,WAAA;AAAA,MACH,IAAM,EAAA,QAAA;AAAA,MACN,OAAO,UAAc,IAAA,EAAA;AAAA,MACrB,QAAU,EAAA,YAAA;AAAA,KACX,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAAC,uBAAA,EAAA;AAAA,MACC,SAAA,EAAWC,SAAK,CAAAC,sBAAA,EAAU,SAAS,CAAA;AAAA,MACnC,cAAgB,EAAAC,2BAAA;AAAA,MAChB,UAAY,EAAA,EAAE,IAAM,EAAA,SAAA,EAAW,GAAG,UAAW,EAAA;AAAA,MAC7C,UAAUN,MAAK,CAAA,QAAA;AAAA,MACf,SAAA;AAAA,MACA,OAAOA,MAAK,CAAA,KAAA;AAAA,MACX,GAAG,KAAA;AAAA,MACJ,GAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"FormattedInput.js","sources":["../src/formatted-input/FormattedInput.tsx"],"sourcesContent":["import { useControlled } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { forwardRef } from \"react\";\nimport { useRifm } from \"rifm\";\nimport {\n InputLegacy as Input,\n type InputLegacyProps as InputProps,\n} from \"../input-legacy\";\nimport {\n InputWithMask,\n type InputWithMaskProps,\n baseName,\n} from \"./internal/InputWithMask\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport formattedInputCss from \"./FormattedInput.css\";\n\nexport type MaskFunction = (value: string | undefined) => boolean;\n\nexport interface RifmOptions {\n format?: (str: string) => string;\n replace?: (str: string) => string;\n append?: (str: string) => string;\n mask?: boolean | MaskFunction;\n accept?: RegExp;\n}\n\nexport interface FormattedInputProps extends Omit<InputProps, \"onChange\"> {\n mask?: string;\n onChange?: (value: string) => void;\n rifmOptions?: RifmOptions;\n value?: string;\n defaultValue?: string;\n}\n\nconst defaultFormatter = (string: string): string => string;\nconst defaultRifmOptions: RifmOptions = {};\n\nexport const FormattedInput = forwardRef<HTMLInputElement, FormattedInputProps>(\n function FormattedInput(\n {\n defaultValue = \"\",\n className,\n inputProps,\n mask,\n onChange,\n rifmOptions = defaultRifmOptions,\n value: valueProp,\n textAlign,\n ...other\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-formatted-input\",\n css: formattedInputCss,\n window: targetWindow,\n });\n\n const [valueState, setValueState] = useControlled<string | undefined>({\n default: defaultValue,\n controlled: valueProp,\n name: \"FormattedInput\",\n state: \"value\",\n });\n\n const handleChange = (value: string) => {\n setValueState(value);\n onChange?.(value);\n };\n\n let rifmMask = false;\n\n if (rifmOptions.mask) {\n rifmMask =\n typeof rifmOptions.mask === \"function\"\n ? rifmOptions.mask(valueState)\n : rifmOptions.mask;\n }\n\n const rifm = useRifm({\n format: defaultFormatter,\n accept: /.*/,\n ...rifmOptions,\n mask: rifmMask,\n value: valueState || \"\",\n onChange: handleChange,\n });\n\n return (\n <Input\n className={clsx(baseName, className)}\n inputComponent={InputWithMask}\n inputProps={{ mask, textAlign, ...inputProps } as InputWithMaskProps}\n onChange={rifm.onChange}\n textAlign={textAlign}\n value={rifm.value}\n {...other}\n ref={ref}\n />\n );\n },\n);\n"],"names":["forwardRef","FormattedInput","useWindow","useComponentCssInjection","formattedInputCss","useControlled","rifm","useRifm","jsx","Input","clsx","baseName","InputWithMask"],"mappings":";;;;;;;;;;;;;;AAqCA,MAAM,gBAAA,GAAmB,CAAC,MAA2B,KAAA,MAAA;AACrD,MAAM,qBAAkC,EAAC;AAElC,MAAM,cAAiB,GAAAA,gBAAA;AAAA,EAC5B,SAASC,eACP,CAAA;AAAA,IACE,YAAe,GAAA,EAAA;AAAA,IACf,SAAA;AAAA,IACA,UAAA;AAAA,IACA,IAAA;AAAA,IACA,QAAA;AAAA,IACA,WAAc,GAAA,kBAAA;AAAA,IACd,KAAO,EAAA,SAAA;AAAA,IACP,SAAA;AAAA,IACA,GAAG;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,sBAAA;AAAA,MACR,GAAK,EAAAC,gBAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,CAAC,UAAA,EAAY,aAAa,CAAA,GAAIC,kBAAkC,CAAA;AAAA,MACpE,OAAS,EAAA,YAAA;AAAA,MACT,UAAY,EAAA,SAAA;AAAA,MACZ,IAAM,EAAA,gBAAA;AAAA,MACN,KAAO,EAAA;AAAA,KACR,CAAA;AAED,IAAM,MAAA,YAAA,GAAe,CAAC,KAAkB,KAAA;AACtC,MAAA,aAAA,CAAc,KAAK,CAAA;AACnB,MAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA;AAAA,KACb;AAEA,IAAA,IAAI,QAAW,GAAA,KAAA;AAEf,IAAA,IAAI,YAAY,IAAM,EAAA;AACpB,MACE,QAAA,GAAA,OAAO,YAAY,IAAS,KAAA,UAAA,GACxB,YAAY,IAAK,CAAA,UAAU,IAC3B,WAAY,CAAA,IAAA;AAAA;AAGpB,IAAA,MAAMC,SAAOC,YAAQ,CAAA;AAAA,MACnB,MAAQ,EAAA,gBAAA;AAAA,MACR,MAAQ,EAAA,IAAA;AAAA,MACR,GAAG,WAAA;AAAA,MACH,IAAM,EAAA,QAAA;AAAA,MACN,OAAO,UAAc,IAAA,EAAA;AAAA,MACrB,QAAU,EAAA;AAAA,KACX,CAAA;AAED,IACE,uBAAAC,cAAA;AAAA,MAACC,uBAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAWC,SAAK,CAAAC,sBAAA,EAAU,SAAS,CAAA;AAAA,QACnC,cAAgB,EAAAC,2BAAA;AAAA,QAChB,UAAY,EAAA,EAAE,IAAM,EAAA,SAAA,EAAW,GAAG,UAAW,EAAA;AAAA,QAC7C,UAAUN,MAAK,CAAA,QAAA;AAAA,QACf,SAAA;AAAA,QACA,OAAOA,MAAK,CAAA,KAAA;AAAA,QACX,GAAG,KAAA;AAAA,QACJ;AAAA;AAAA,KACF;AAAA;AAGN;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var clsx = require('clsx');
@@ -33,15 +31,13 @@ const InputWithMask = react.forwardRef(
33
31
  }, ref) {
34
32
  const id = core.useId(idProp);
35
33
  const spacerAndMask = [
36
- /* @__PURE__ */ jsxRuntime.jsx("i", {
37
- children: value
38
- }, value),
34
+ /* @__PURE__ */ jsxRuntime.jsx("i", { children: value }, value),
39
35
  getClippedMask(mask, value, textAlign)
40
36
  ];
41
- return /* @__PURE__ */ jsxRuntime.jsxs("div", {
42
- className: `${baseName}-inputWrapper`,
43
- children: [
44
- /* @__PURE__ */ jsxRuntime.jsx("input", {
37
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `${baseName}-inputWrapper`, children: [
38
+ /* @__PURE__ */ jsxRuntime.jsx(
39
+ "input",
40
+ {
45
41
  className,
46
42
  ...other,
47
43
  "aria-label": mask,
@@ -50,15 +46,18 @@ const InputWithMask = react.forwardRef(
50
46
  ref,
51
47
  style,
52
48
  value
53
- }),
54
- /* @__PURE__ */ jsxRuntime.jsx("span", {
49
+ }
50
+ ),
51
+ /* @__PURE__ */ jsxRuntime.jsx(
52
+ "span",
53
+ {
55
54
  "aria-hidden": "true",
56
55
  className: clsx.clsx(`${baseName}-mask`, className),
57
56
  style,
58
57
  children: textAlign !== "right" ? spacerAndMask : spacerAndMask.reverse()
59
- })
60
- ]
61
- });
58
+ }
59
+ )
60
+ ] });
62
61
  }
63
62
  );
64
63
 
@@ -1 +1 @@
1
- {"version":3,"file":"InputWithMask.js","sources":["../src/formatted-input/internal/InputWithMask.tsx"],"sourcesContent":["import { useId } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type InputHTMLAttributes, forwardRef } from \"react\";\nimport type { FormattedInputProps } from \"../FormattedInput\";\n\nexport const baseName = \"saltFormattedInput\";\n\nfunction getClippedMask(\n mask: FormattedInputProps[\"mask\"],\n value: FormattedInputProps[\"value\"],\n textAlign: FormattedInputProps[\"textAlign\"],\n) {\n if (mask) {\n if (textAlign === \"right\") {\n return mask.substring(\n 0,\n value ? mask.length - value.length : mask.length,\n );\n }\n\n return mask.substring(value ? value.length : 0);\n }\n return \"\";\n}\n\nexport interface InputWithMaskProps\n extends InputHTMLAttributes<HTMLInputElement> {\n mask?: FormattedInputProps[\"mask\"];\n textAlign?: FormattedInputProps[\"textAlign\"];\n value?: FormattedInputProps[\"value\"];\n}\n\nexport const InputWithMask = forwardRef<HTMLInputElement, InputWithMaskProps>(\n function InputWithMask(\n {\n \"aria-labelledby\": ariaLabelledBy,\n className,\n mask = \"\",\n value,\n id: idProp,\n style,\n textAlign,\n ...other\n },\n ref,\n ) {\n const id = useId(idProp);\n\n const spacerAndMask = [\n <i key={value}>{value}</i>,\n getClippedMask(mask, value, textAlign),\n ];\n\n return (\n <div className={`${baseName}-inputWrapper`}>\n <input\n className={className}\n {...other}\n aria-label={mask}\n aria-labelledby={[ariaLabelledBy, id]\n .filter((label) => label != null)\n .join(\" \")}\n id={id}\n ref={ref}\n style={style}\n value={value}\n />\n <span\n aria-hidden=\"true\"\n className={clsx(`${baseName}-mask`, className)}\n style={style}\n >\n {textAlign !== \"right\" ? spacerAndMask : spacerAndMask.reverse()}\n </span>\n </div>\n );\n },\n);\n"],"names":["forwardRef","InputWithMask","useId","jsx","jsxs","clsx"],"mappings":";;;;;;;;;AAKO,MAAM,QAAW,GAAA,qBAAA;AAExB,SAAS,cAAA,CACP,IACA,EAAA,KAAA,EACA,SACA,EAAA;AACA,EAAA,IAAI,IAAM,EAAA;AACR,IAAA,IAAI,cAAc,OAAS,EAAA;AACzB,MAAA,OAAO,IAAK,CAAA,SAAA;AAAA,QACV,CAAA;AAAA,QACA,KAAQ,GAAA,IAAA,CAAK,MAAS,GAAA,KAAA,CAAM,SAAS,IAAK,CAAA,MAAA;AAAA,OAC5C,CAAA;AAAA,KACF;AAEA,IAAA,OAAO,IAAK,CAAA,SAAA,CAAU,KAAQ,GAAA,KAAA,CAAM,SAAS,CAAC,CAAA,CAAA;AAAA,GAChD;AACA,EAAO,OAAA,EAAA,CAAA;AACT,CAAA;AASO,MAAM,aAAgB,GAAAA,gBAAA;AAAA,EAC3B,SAASC,cACP,CAAA;AAAA,IACE,iBAAmB,EAAA,cAAA;AAAA,IACnB,SAAA;AAAA,IACA,IAAO,GAAA,EAAA;AAAA,IACP,KAAA;AAAA,IACA,EAAI,EAAA,MAAA;AAAA,IACJ,KAAA;AAAA,IACA,SAAA;AAAA,IACG,GAAA,KAAA;AAAA,KAEL,GACA,EAAA;AACA,IAAM,MAAA,EAAA,GAAKC,WAAM,MAAM,CAAA,CAAA;AAEvB,IAAA,MAAM,aAAgB,GAAA;AAAA,sBACnBC,cAAA,CAAA,GAAA,EAAA;AAAA,QAAe,QAAA,EAAA,KAAA;AAAA,OAAA,EAAR,KAAc,CAAA;AAAA,MACtB,cAAA,CAAe,IAAM,EAAA,KAAA,EAAO,SAAS,CAAA;AAAA,KACvC,CAAA;AAEA,IAAA,uBACGC,eAAA,CAAA,KAAA,EAAA;AAAA,MAAI,WAAW,CAAG,EAAA,QAAA,CAAA,aAAA,CAAA;AAAA,MACjB,QAAA,EAAA;AAAA,wBAACD,cAAA,CAAA,OAAA,EAAA;AAAA,UACC,SAAA;AAAA,UACC,GAAG,KAAA;AAAA,UACJ,YAAY,EAAA,IAAA;AAAA,UACZ,iBAAiB,EAAA,CAAC,cAAgB,EAAA,EAAE,CACjC,CAAA,MAAA,CAAO,CAAC,KAAA,KAAU,KAAS,IAAA,IAAI,CAC/B,CAAA,IAAA,CAAK,GAAG,CAAA;AAAA,UACX,EAAA;AAAA,UACA,GAAA;AAAA,UACA,KAAA;AAAA,UACA,KAAA;AAAA,SACF,CAAA;AAAA,wBACCA,cAAA,CAAA,MAAA,EAAA;AAAA,UACC,aAAY,EAAA,MAAA;AAAA,UACZ,SAAW,EAAAE,SAAA,CAAK,CAAG,EAAA,QAAA,CAAA,KAAA,CAAA,EAAiB,SAAS,CAAA;AAAA,UAC7C,KAAA;AAAA,UAEC,QAAc,EAAA,SAAA,KAAA,OAAA,GAAU,aAAgB,GAAA,aAAA,CAAc,OAAQ,EAAA;AAAA,SACjE,CAAA;AAAA,OAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;;"}
1
+ {"version":3,"file":"InputWithMask.js","sources":["../src/formatted-input/internal/InputWithMask.tsx"],"sourcesContent":["import { useId } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type InputHTMLAttributes, forwardRef } from \"react\";\nimport type { FormattedInputProps } from \"../FormattedInput\";\n\nexport const baseName = \"saltFormattedInput\";\n\nfunction getClippedMask(\n mask: FormattedInputProps[\"mask\"],\n value: FormattedInputProps[\"value\"],\n textAlign: FormattedInputProps[\"textAlign\"],\n) {\n if (mask) {\n if (textAlign === \"right\") {\n return mask.substring(\n 0,\n value ? mask.length - value.length : mask.length,\n );\n }\n\n return mask.substring(value ? value.length : 0);\n }\n return \"\";\n}\n\nexport interface InputWithMaskProps\n extends InputHTMLAttributes<HTMLInputElement> {\n mask?: FormattedInputProps[\"mask\"];\n textAlign?: FormattedInputProps[\"textAlign\"];\n value?: FormattedInputProps[\"value\"];\n}\n\nexport const InputWithMask = forwardRef<HTMLInputElement, InputWithMaskProps>(\n function InputWithMask(\n {\n \"aria-labelledby\": ariaLabelledBy,\n className,\n mask = \"\",\n value,\n id: idProp,\n style,\n textAlign,\n ...other\n },\n ref,\n ) {\n const id = useId(idProp);\n\n const spacerAndMask = [\n <i key={value}>{value}</i>,\n getClippedMask(mask, value, textAlign),\n ];\n\n return (\n <div className={`${baseName}-inputWrapper`}>\n <input\n className={className}\n {...other}\n aria-label={mask}\n aria-labelledby={[ariaLabelledBy, id]\n .filter((label) => label != null)\n .join(\" \")}\n id={id}\n ref={ref}\n style={style}\n value={value}\n />\n <span\n aria-hidden=\"true\"\n className={clsx(`${baseName}-mask`, className)}\n style={style}\n >\n {textAlign !== \"right\" ? spacerAndMask : spacerAndMask.reverse()}\n </span>\n </div>\n );\n },\n);\n"],"names":["forwardRef","InputWithMask","useId","jsx","jsxs","clsx"],"mappings":";;;;;;;AAKO,MAAM,QAAW,GAAA;AAExB,SAAS,cAAA,CACP,IACA,EAAA,KAAA,EACA,SACA,EAAA;AACA,EAAA,IAAI,IAAM,EAAA;AACR,IAAA,IAAI,cAAc,OAAS,EAAA;AACzB,MAAA,OAAO,IAAK,CAAA,SAAA;AAAA,QACV,CAAA;AAAA,QACA,KAAQ,GAAA,IAAA,CAAK,MAAS,GAAA,KAAA,CAAM,SAAS,IAAK,CAAA;AAAA,OAC5C;AAAA;AAGF,IAAA,OAAO,IAAK,CAAA,SAAA,CAAU,KAAQ,GAAA,KAAA,CAAM,SAAS,CAAC,CAAA;AAAA;AAEhD,EAAO,OAAA,EAAA;AACT;AASO,MAAM,aAAgB,GAAAA,gBAAA;AAAA,EAC3B,SAASC,cACP,CAAA;AAAA,IACE,iBAAmB,EAAA,cAAA;AAAA,IACnB,SAAA;AAAA,IACA,IAAO,GAAA,EAAA;AAAA,IACP,KAAA;AAAA,IACA,EAAI,EAAA,MAAA;AAAA,IACJ,KAAA;AAAA,IACA,SAAA;AAAA,IACA,GAAG;AAAA,KAEL,GACA,EAAA;AACA,IAAM,MAAA,EAAA,GAAKC,WAAM,MAAM,CAAA;AAEvB,IAAA,MAAM,aAAgB,GAAA;AAAA,sBACpBC,cAAA,CAAC,GAAe,EAAA,EAAA,QAAA,EAAA,KAAA,EAAA,EAAR,KAAc,CAAA;AAAA,MACtB,cAAA,CAAe,IAAM,EAAA,KAAA,EAAO,SAAS;AAAA,KACvC;AAEA,IAAA,uBACGC,eAAA,CAAA,KAAA,EAAA,EAAI,SAAW,EAAA,CAAA,EAAG,QAAQ,CACzB,aAAA,CAAA,EAAA,QAAA,EAAA;AAAA,sBAAAD,cAAA;AAAA,QAAC,OAAA;AAAA,QAAA;AAAA,UACC,SAAA;AAAA,UACC,GAAG,KAAA;AAAA,UACJ,YAAY,EAAA,IAAA;AAAA,UACZ,iBAAiB,EAAA,CAAC,cAAgB,EAAA,EAAE,CACjC,CAAA,MAAA,CAAO,CAAC,KAAA,KAAU,KAAS,IAAA,IAAI,CAC/B,CAAA,IAAA,CAAK,GAAG,CAAA;AAAA,UACX,EAAA;AAAA,UACA,GAAA;AAAA,UACA,KAAA;AAAA,UACA;AAAA;AAAA,OACF;AAAA,sBACAA,cAAA;AAAA,QAAC,MAAA;AAAA,QAAA;AAAA,UACC,aAAY,EAAA,MAAA;AAAA,UACZ,SAAW,EAAAE,SAAA,CAAK,CAAG,EAAA,QAAQ,SAAS,SAAS,CAAA;AAAA,UAC7C,KAAA;AAAA,UAEC,QAAc,EAAA,SAAA,KAAA,OAAA,GAAU,aAAgB,GAAA,aAAA,CAAc,OAAQ;AAAA;AAAA;AACjE,KACF,EAAA,CAAA;AAAA;AAGN;;;;;"}
package/dist-cjs/index.js CHANGED
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  require('./list-deprecated/List.js');
6
4
  require('./list-deprecated/ListBase.js');
7
5
  var ListItemBase = require('./list-deprecated/ListItemBase.js');
@@ -75,6 +73,7 @@ var DatePickerRangeInput = require('./date-picker/DatePickerRangeInput.js');
75
73
  var DatePickerRangePanel = require('./date-picker/DatePickerRangePanel.js');
76
74
  var DeckItem = require('./deck-item/DeckItem.js');
77
75
  var DeckLayout = require('./deck-layout/DeckLayout.js');
76
+ var DialogHeader = require('./dialog/DialogHeader.js');
78
77
  var DropdownBase = require('./dropdown/DropdownBase.js');
79
78
  var DropdownButton = require('./dropdown/DropdownButton.js');
80
79
  var Dropdown = require('./dropdown/Dropdown.js');
@@ -139,7 +138,12 @@ var Tab = require('./tabs/Tab.js');
139
138
  var TabPanel = require('./tabs/TabPanel.js');
140
139
  var Tabs = require('./tabs/Tabs.js');
141
140
  var TabNext = require('./tabs-next/TabNext.js');
142
- var TabstripNext = require('./tabs-next/TabstripNext.js');
141
+ var TabListNext = require('./tabs-next/TabListNext.js');
142
+ var TabsNext = require('./tabs-next/TabsNext.js');
143
+ var TabNextPanel = require('./tabs-next/TabNextPanel.js');
144
+ var TabBar = require('./tabs-next/TabBar.js');
145
+ var TabNextTrigger = require('./tabs-next/TabNextTrigger.js');
146
+ var TabNextAction = require('./tabs-next/TabNextAction.js');
143
147
  var ToastGroup = require('./toast-group/ToastGroup.js');
144
148
  var TokenizedInput = require('./tokenized-input/TokenizedInput.js');
145
149
  var TokenizedInputBase = require('./tokenized-input/TokenizedInputBase.js');
@@ -244,6 +248,7 @@ exports.DatePickerRangeInput = DatePickerRangeInput.DatePickerRangeInput;
244
248
  exports.DatePickerRangePanel = DatePickerRangePanel.DatePickerRangePanel;
245
249
  exports.DeckItem = DeckItem.DeckItem;
246
250
  exports.DeckLayout = DeckLayout.DeckLayout;
251
+ exports.DialogHeader = DialogHeader.DialogHeader;
247
252
  exports.DropdownBase = DropdownBase.DropdownBase;
248
253
  exports.DropdownButton = DropdownButton.DropdownButton;
249
254
  exports.Dropdown = Dropdown.Dropdown;
@@ -335,7 +340,12 @@ exports.Tab = Tab.Tab;
335
340
  exports.TabPanel = TabPanel.TabPanel;
336
341
  exports.Tabs = Tabs.Tabs;
337
342
  exports.TabNext = TabNext.TabNext;
338
- exports.TabstripNext = TabstripNext.TabstripNext;
343
+ exports.TabListNext = TabListNext.TabListNext;
344
+ exports.TabsNext = TabsNext.TabsNext;
345
+ exports.TabNextPanel = TabNextPanel.TabNextPanel;
346
+ exports.TabBar = TabBar.TabBar;
347
+ exports.TabNextTrigger = TabNextTrigger.TabNextTrigger;
348
+ exports.TabNextAction = TabNextAction.TabNextAction;
339
349
  exports.ToastGroup = ToastGroup.ToastGroup;
340
350
  exports.TokenizedInput = TokenizedInput.TokenizedInput;
341
351
  exports.TokenizedInputBase = TokenizedInputBase.TokenizedInputBase;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var clsx = require('clsx');
@@ -23,6 +21,7 @@ function mergeA11yProps(a11yProps, inputProps, misplacedAriaProps) {
23
21
  ...misplacedAriaProps,
24
22
  ...a11yProps,
25
23
  ...inputProps,
24
+ // The weird filtering is due to TokenizedInputBase
26
25
  "aria-labelledby": ariaLabelledBy ? Array.from(new Set(ariaLabelledBy.split(" "))).join(" ") : null
27
26
  };
28
27
  }
@@ -43,6 +42,8 @@ const InputLegacy = react.forwardRef(
43
42
  role,
44
43
  style,
45
44
  value: valueProp,
45
+ // If we leave both value and defaultValue undefined, we will get a React warning on first edit
46
+ // (uncontrolled to controlled warning) from the React input
46
47
  defaultValue: defaultValueProp = valueProp === void 0 ? "" : void 0,
47
48
  onBlur,
48
49
  onChange,
@@ -129,51 +130,51 @@ const InputLegacy = react.forwardRef(
129
130
  cursorOnFocusHelpers.handleMouseDown();
130
131
  onMouseDown == null ? void 0 : onMouseDown(event);
131
132
  };
132
- return /* @__PURE__ */ jsxRuntime.jsxs("div", {
133
- className: clsx.clsx(
134
- withBaseName(),
135
- {
136
- [withBaseName(`${textAlign}TextAlign`)]: textAlign,
137
- [withBaseName("formField")]: inFormField,
138
- [withBaseName("focused")]: focused && !inFormField,
139
- [withBaseName("disabled")]: isDisabled,
140
- [withBaseName("inputAdornedStart")]: startAdornment,
141
- [withBaseName("inputAdornedEnd")]: endAdornment
142
- },
143
- classNameProp
144
- ),
145
- style,
146
- ...other,
147
- children: [
148
- startAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", {
149
- className: withBaseName("prefixContainer"),
150
- children: startAdornment
151
- }),
152
- /* @__PURE__ */ jsxRuntime.jsx(InputComponent, {
153
- type,
154
- id,
155
- ...inputProps,
156
- className: clsx.clsx(withBaseName("input"), inputProps == null ? void 0 : inputProps.className),
157
- disabled: isDisabled,
158
- ref: handleRef,
159
- value,
160
- onBlur: handleBlur,
161
- onChange: handleChange,
162
- onKeyDown,
163
- onKeyUp,
164
- onFocus: handleFocus,
165
- onMouseDown: handleMouseDown,
166
- onMouseUp: handleMouseUp,
167
- onMouseMove: handleMouseMove,
168
- readOnly: isReadOnly
169
- }),
170
- endAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", {
171
- className: withBaseName("suffixContainer"),
172
- children: endAdornment
173
- }),
174
- renderSuffix == null ? void 0 : renderSuffix({ disabled, focused })
175
- ]
176
- });
133
+ return /* @__PURE__ */ jsxRuntime.jsxs(
134
+ "div",
135
+ {
136
+ className: clsx.clsx(
137
+ withBaseName(),
138
+ {
139
+ [withBaseName(`${textAlign}TextAlign`)]: textAlign,
140
+ [withBaseName("formField")]: inFormField,
141
+ [withBaseName("focused")]: focused && !inFormField,
142
+ [withBaseName("disabled")]: isDisabled,
143
+ [withBaseName("inputAdornedStart")]: startAdornment,
144
+ [withBaseName("inputAdornedEnd")]: endAdornment
145
+ },
146
+ classNameProp
147
+ ),
148
+ style,
149
+ ...other,
150
+ children: [
151
+ startAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("prefixContainer"), children: startAdornment }),
152
+ /* @__PURE__ */ jsxRuntime.jsx(
153
+ InputComponent,
154
+ {
155
+ type,
156
+ id,
157
+ ...inputProps,
158
+ className: clsx.clsx(withBaseName("input"), inputProps == null ? void 0 : inputProps.className),
159
+ disabled: isDisabled,
160
+ ref: handleRef,
161
+ value,
162
+ onBlur: handleBlur,
163
+ onChange: handleChange,
164
+ onKeyDown,
165
+ onKeyUp,
166
+ onFocus: handleFocus,
167
+ onMouseDown: handleMouseDown,
168
+ onMouseUp: handleMouseUp,
169
+ onMouseMove: handleMouseMove,
170
+ readOnly: isReadOnly
171
+ }
172
+ ),
173
+ endAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", { className: withBaseName("suffixContainer"), children: endAdornment }),
174
+ renderSuffix == null ? void 0 : renderSuffix({ disabled, focused })
175
+ ]
176
+ }
177
+ );
177
178
  }
178
179
  );
179
180
 
@@ -1 +1 @@
1
- {"version":3,"file":"InputLegacy.js","sources":["../src/input-legacy/InputLegacy.tsx"],"sourcesContent":["import { makePrefixer, useControlled, useForkRef } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type AriaAttributes,\n type ChangeEvent,\n type ElementType,\n type FocusEvent,\n type FocusEventHandler,\n type HTMLAttributes,\n type InputHTMLAttributes,\n type KeyboardEventHandler,\n type MouseEvent,\n type MouseEventHandler,\n type ReactNode,\n forwardRef,\n useRef,\n useState,\n} from \"react\";\nimport { useFormFieldLegacyProps } from \"../form-field-context-legacy\";\nimport { useCursorOnFocus } from \"./useCursorOnFocus\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport inputLegacyCss from \"./InputLegacy.css\";\n\nconst withBaseName = makePrefixer(\"saltInputLegacy\");\n\n// TODO: Double confirm whether this should be extending DivElement given root is `<div>`.\n// And forwarded ref is not assigned to the root like other components.\nexport interface InputLegacyProps\n extends Omit<HTMLAttributes<HTMLDivElement>, \"onChange\" | \"defaultValue\"> {\n /**\n * Determines the position of the text cursor on focus of the input.\n *\n * start = place cursor at the beginning<br>\n * end = place cursor at the end<br>\n * \\# = index to place the cursor<br>\n */\n cursorPositionOnFocus?: \"start\" | \"end\" | number;\n /**\n * The value of the `input` element, required for an uncontrolled component.\n */\n defaultValue?: HTMLInputElement[\"defaultValue\"];\n /**\n * If `true`, the component is disabled.\n */\n disabled?: HTMLInputElement[\"disabled\"];\n /**\n * The marker to use in an empty read only Input.\n * Use `''` to disable this feature. Defaults to '—'.\n */\n emptyReadOnlyMarker?: string;\n /**\n * Determines what gets highlighted on focus of the input.\n *\n * If `true` all text will be highlighted.\n * If an array text between those indices will be highlighted\n * e.g. [0,1] will highlight the first character.\n */\n highlightOnFocus?: boolean | number[];\n /**\n * The HTML element to render the Input, e.g. 'input', a custom React component.\n */\n inputComponent?: ElementType;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement>;\n onBlur?: FocusEventHandler<HTMLInputElement>;\n /**\n * Callback for change event.\n */\n onChange?: (event: ChangeEvent<HTMLInputElement>, value: string) => void;\n onFocus?: FocusEventHandler<HTMLInputElement>;\n onKeyDown?: KeyboardEventHandler<HTMLInputElement>;\n onKeyUp?: KeyboardEventHandler<HTMLInputElement>;\n onMouseUp?: MouseEventHandler<HTMLInputElement>;\n onMouseMove?: MouseEventHandler<HTMLInputElement>;\n onMouseDown?: MouseEventHandler<HTMLInputElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n *\n * Determines the alignment of the input text.\n */\n textAlign?: \"left\" | \"right\" | \"center\";\n type?: HTMLInputElement[\"type\"];\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value?: HTMLInputElement[\"value\"];\n renderSuffix?: (state: {\n disabled?: boolean;\n error?: boolean;\n focused?: boolean;\n margin?: \"dense\" | \"none\" | \"normal\";\n required?: boolean;\n startAdornment?: ReactNode;\n }) => ReactNode;\n endAdornment?: ReactNode;\n startAdornment?: ReactNode;\n}\n\nfunction mergeA11yProps(\n a11yProps: Partial<ReturnType<typeof useFormFieldLegacyProps>[\"a11yProps\"]>,\n inputProps: InputLegacyProps[\"inputProps\"],\n misplacedAriaProps: AriaAttributes,\n) {\n const ariaLabelledBy = clsx(\n a11yProps?.[\"aria-labelledby\"],\n inputProps?.[\"aria-labelledby\"],\n );\n\n return {\n ...misplacedAriaProps,\n ...a11yProps,\n ...inputProps,\n // The weird filtering is due to TokenizedInputBase\n \"aria-labelledby\": ariaLabelledBy\n ? Array.from(new Set(ariaLabelledBy.split(\" \"))).join(\" \")\n : null,\n };\n}\n\nexport const InputLegacy = forwardRef<HTMLInputElement, InputLegacyProps>(\n function Input(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n cursorPositionOnFocus,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n highlightOnFocus,\n id,\n inputComponent: InputComponent = \"input\",\n inputProps: inputPropsProp,\n role,\n style,\n value: valueProp,\n // If we leave both value and defaultValue undefined, we will get a React warning on first edit\n // (uncontrolled to controlled warning) from the React input\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n onBlur,\n onChange,\n onFocus,\n onKeyDown,\n onKeyUp,\n onMouseUp,\n onMouseMove,\n onMouseDown,\n readOnly: readOnlyProp,\n renderSuffix,\n startAdornment,\n textAlign = \"left\",\n type = \"text\",\n ...other\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-input-legacy\",\n css: inputLegacyCss,\n window: targetWindow,\n });\n\n const {\n a11yProps: {\n readOnly: a11yReadOnly,\n disabled: a11yDisabled,\n ...restA11y\n } = {},\n setFocused: setFormFieldFocused,\n inFormField,\n } = useFormFieldLegacyProps();\n\n const [focused, setFocused] = useState(false);\n const inputRef = useRef(null);\n const handleRef = useForkRef(inputRef, ref);\n const cursorOnFocusHelpers = useCursorOnFocus(inputRef, {\n cursorPositionOnFocus,\n highlightOnFocus,\n });\n\n const isDisabled = disabled || a11yDisabled;\n const isReadOnly = readOnlyProp || a11yReadOnly;\n const misplacedAriaProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n role,\n };\n const inputProps = mergeA11yProps(\n restA11y,\n inputPropsProp,\n misplacedAriaProps,\n );\n const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;\n const defaultValue = isEmptyReadOnly\n ? emptyReadOnlyMarker\n : defaultValueProp;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"Input\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event, value);\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n setFormFieldFocused?.(true);\n setFocused(true);\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n setFormFieldFocused?.(false);\n setFocused(false);\n };\n\n const handleMouseMove = (event: MouseEvent<HTMLInputElement>) => {\n cursorOnFocusHelpers.handleMouseMove(event);\n\n onMouseMove?.(event);\n };\n\n const handleMouseUp = (event: MouseEvent<HTMLInputElement>) => {\n cursorOnFocusHelpers.handleMouseUp();\n\n onMouseUp?.(event);\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLInputElement>) => {\n cursorOnFocusHelpers.handleMouseDown();\n\n onMouseDown?.(event);\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n {\n [withBaseName(`${textAlign}TextAlign`)]: textAlign,\n [withBaseName(\"formField\")]: inFormField,\n [withBaseName(\"focused\")]: focused && !inFormField,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"inputAdornedStart\")]: startAdornment,\n [withBaseName(\"inputAdornedEnd\")]: endAdornment,\n },\n classNameProp,\n )}\n style={style}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"prefixContainer\")}>\n {startAdornment}\n </div>\n )}\n <InputComponent\n type={type}\n id={id}\n {...inputProps}\n className={clsx(withBaseName(\"input\"), inputProps?.className)}\n disabled={isDisabled}\n ref={handleRef}\n value={value}\n onBlur={handleBlur}\n onChange={handleChange}\n onKeyDown={onKeyDown}\n onKeyUp={onKeyUp}\n onFocus={handleFocus}\n onMouseDown={handleMouseDown}\n onMouseUp={handleMouseUp}\n onMouseMove={handleMouseMove}\n readOnly={isReadOnly}\n />\n {endAdornment && (\n <div className={withBaseName(\"suffixContainer\")}>{endAdornment}</div>\n )}\n {/* TODO: Confirm implementation of suffix */}\n {renderSuffix?.({ disabled, focused })}\n </div>\n );\n },\n);\n"],"names":["makePrefixer","clsx","forwardRef","useWindow","useComponentCssInjection","inputLegacyCss","useFormFieldLegacyProps","useState","useRef","useForkRef","useCursorOnFocus","useControlled","value","jsxs","jsx"],"mappings":"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"}
1
+ {"version":3,"file":"InputLegacy.js","sources":["../src/input-legacy/InputLegacy.tsx"],"sourcesContent":["import { makePrefixer, useControlled, useForkRef } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type AriaAttributes,\n type ChangeEvent,\n type ElementType,\n type FocusEvent,\n type FocusEventHandler,\n type HTMLAttributes,\n type InputHTMLAttributes,\n type KeyboardEventHandler,\n type MouseEvent,\n type MouseEventHandler,\n type ReactNode,\n forwardRef,\n useRef,\n useState,\n} from \"react\";\nimport { useFormFieldLegacyProps } from \"../form-field-context-legacy\";\nimport { useCursorOnFocus } from \"./useCursorOnFocus\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport inputLegacyCss from \"./InputLegacy.css\";\n\nconst withBaseName = makePrefixer(\"saltInputLegacy\");\n\n// TODO: Double confirm whether this should be extending DivElement given root is `<div>`.\n// And forwarded ref is not assigned to the root like other components.\nexport interface InputLegacyProps\n extends Omit<HTMLAttributes<HTMLDivElement>, \"onChange\" | \"defaultValue\"> {\n /**\n * Determines the position of the text cursor on focus of the input.\n *\n * start = place cursor at the beginning<br>\n * end = place cursor at the end<br>\n * \\# = index to place the cursor<br>\n */\n cursorPositionOnFocus?: \"start\" | \"end\" | number;\n /**\n * The value of the `input` element, required for an uncontrolled component.\n */\n defaultValue?: HTMLInputElement[\"defaultValue\"];\n /**\n * If `true`, the component is disabled.\n */\n disabled?: HTMLInputElement[\"disabled\"];\n /**\n * The marker to use in an empty read only Input.\n * Use `''` to disable this feature. Defaults to '—'.\n */\n emptyReadOnlyMarker?: string;\n /**\n * Determines what gets highlighted on focus of the input.\n *\n * If `true` all text will be highlighted.\n * If an array text between those indices will be highlighted\n * e.g. [0,1] will highlight the first character.\n */\n highlightOnFocus?: boolean | number[];\n /**\n * The HTML element to render the Input, e.g. 'input', a custom React component.\n */\n inputComponent?: ElementType;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes) applied to the `input` element.\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement>;\n onBlur?: FocusEventHandler<HTMLInputElement>;\n /**\n * Callback for change event.\n */\n onChange?: (event: ChangeEvent<HTMLInputElement>, value: string) => void;\n onFocus?: FocusEventHandler<HTMLInputElement>;\n onKeyDown?: KeyboardEventHandler<HTMLInputElement>;\n onKeyUp?: KeyboardEventHandler<HTMLInputElement>;\n onMouseUp?: MouseEventHandler<HTMLInputElement>;\n onMouseMove?: MouseEventHandler<HTMLInputElement>;\n onMouseDown?: MouseEventHandler<HTMLInputElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n *\n * Determines the alignment of the input text.\n */\n textAlign?: \"left\" | \"right\" | \"center\";\n type?: HTMLInputElement[\"type\"];\n /**\n * The value of the `input` element, required for a controlled component.\n */\n value?: HTMLInputElement[\"value\"];\n renderSuffix?: (state: {\n disabled?: boolean;\n error?: boolean;\n focused?: boolean;\n margin?: \"dense\" | \"none\" | \"normal\";\n required?: boolean;\n startAdornment?: ReactNode;\n }) => ReactNode;\n endAdornment?: ReactNode;\n startAdornment?: ReactNode;\n}\n\nfunction mergeA11yProps(\n a11yProps: Partial<ReturnType<typeof useFormFieldLegacyProps>[\"a11yProps\"]>,\n inputProps: InputLegacyProps[\"inputProps\"],\n misplacedAriaProps: AriaAttributes,\n) {\n const ariaLabelledBy = clsx(\n a11yProps?.[\"aria-labelledby\"],\n inputProps?.[\"aria-labelledby\"],\n );\n\n return {\n ...misplacedAriaProps,\n ...a11yProps,\n ...inputProps,\n // The weird filtering is due to TokenizedInputBase\n \"aria-labelledby\": ariaLabelledBy\n ? Array.from(new Set(ariaLabelledBy.split(\" \"))).join(\" \")\n : null,\n };\n}\n\nexport const InputLegacy = forwardRef<HTMLInputElement, InputLegacyProps>(\n function Input(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n cursorPositionOnFocus,\n disabled,\n emptyReadOnlyMarker = \"—\",\n endAdornment,\n highlightOnFocus,\n id,\n inputComponent: InputComponent = \"input\",\n inputProps: inputPropsProp,\n role,\n style,\n value: valueProp,\n // If we leave both value and defaultValue undefined, we will get a React warning on first edit\n // (uncontrolled to controlled warning) from the React input\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n onBlur,\n onChange,\n onFocus,\n onKeyDown,\n onKeyUp,\n onMouseUp,\n onMouseMove,\n onMouseDown,\n readOnly: readOnlyProp,\n renderSuffix,\n startAdornment,\n textAlign = \"left\",\n type = \"text\",\n ...other\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-input-legacy\",\n css: inputLegacyCss,\n window: targetWindow,\n });\n\n const {\n a11yProps: {\n readOnly: a11yReadOnly,\n disabled: a11yDisabled,\n ...restA11y\n } = {},\n setFocused: setFormFieldFocused,\n inFormField,\n } = useFormFieldLegacyProps();\n\n const [focused, setFocused] = useState(false);\n const inputRef = useRef(null);\n const handleRef = useForkRef(inputRef, ref);\n const cursorOnFocusHelpers = useCursorOnFocus(inputRef, {\n cursorPositionOnFocus,\n highlightOnFocus,\n });\n\n const isDisabled = disabled || a11yDisabled;\n const isReadOnly = readOnlyProp || a11yReadOnly;\n const misplacedAriaProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n role,\n };\n const inputProps = mergeA11yProps(\n restA11y,\n inputPropsProp,\n misplacedAriaProps,\n );\n const isEmptyReadOnly = isReadOnly && !defaultValueProp && !valueProp;\n const defaultValue = isEmptyReadOnly\n ? emptyReadOnlyMarker\n : defaultValueProp;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: \"Input\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event, value);\n };\n\n const handleFocus = (event: FocusEvent<HTMLInputElement>) => {\n onFocus?.(event);\n setFormFieldFocused?.(true);\n setFocused(true);\n };\n\n const handleBlur = (event: FocusEvent<HTMLInputElement>) => {\n onBlur?.(event);\n setFormFieldFocused?.(false);\n setFocused(false);\n };\n\n const handleMouseMove = (event: MouseEvent<HTMLInputElement>) => {\n cursorOnFocusHelpers.handleMouseMove(event);\n\n onMouseMove?.(event);\n };\n\n const handleMouseUp = (event: MouseEvent<HTMLInputElement>) => {\n cursorOnFocusHelpers.handleMouseUp();\n\n onMouseUp?.(event);\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLInputElement>) => {\n cursorOnFocusHelpers.handleMouseDown();\n\n onMouseDown?.(event);\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n {\n [withBaseName(`${textAlign}TextAlign`)]: textAlign,\n [withBaseName(\"formField\")]: inFormField,\n [withBaseName(\"focused\")]: focused && !inFormField,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"inputAdornedStart\")]: startAdornment,\n [withBaseName(\"inputAdornedEnd\")]: endAdornment,\n },\n classNameProp,\n )}\n style={style}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"prefixContainer\")}>\n {startAdornment}\n </div>\n )}\n <InputComponent\n type={type}\n id={id}\n {...inputProps}\n className={clsx(withBaseName(\"input\"), inputProps?.className)}\n disabled={isDisabled}\n ref={handleRef}\n value={value}\n onBlur={handleBlur}\n onChange={handleChange}\n onKeyDown={onKeyDown}\n onKeyUp={onKeyUp}\n onFocus={handleFocus}\n onMouseDown={handleMouseDown}\n onMouseUp={handleMouseUp}\n onMouseMove={handleMouseMove}\n readOnly={isReadOnly}\n />\n {endAdornment && (\n <div className={withBaseName(\"suffixContainer\")}>{endAdornment}</div>\n )}\n {/* TODO: Confirm implementation of suffix */}\n {renderSuffix?.({ disabled, focused })}\n </div>\n );\n },\n);\n"],"names":["makePrefixer","clsx","forwardRef","useWindow","useComponentCssInjection","inputLegacyCss","useFormFieldLegacyProps","useState","useRef","useForkRef","useCursorOnFocus","useControlled","value","jsxs","jsx"],"mappings":"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"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var clsx = require('clsx');
@@ -19,12 +17,7 @@ const StaticInputAdornment = react.forwardRef(function StaticInputAdornment2(pro
19
17
  css: StaticInputAdornment$1,
20
18
  window: targetWindow
21
19
  });
22
- return /* @__PURE__ */ jsxRuntime.jsx("div", {
23
- className: clsx.clsx(withBaseName(), className),
24
- ref,
25
- ...other,
26
- children
27
- });
20
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: clsx.clsx(withBaseName(), className), ref, ...other, children });
28
21
  });
29
22
 
30
23
  exports.StaticInputAdornment = StaticInputAdornment;
@@ -1 +1 @@
1
- {"version":3,"file":"StaticInputAdornment.js","sources":["../src/input-legacy/StaticInputAdornment.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport staticInputAdornmentCss from \"./StaticInputAdornment.css\";\n\nexport type StaticInputAdornmentProps = HTMLAttributes<HTMLDivElement>;\n\nconst withBaseName = makePrefixer(\"saltStaticInputAdornment\");\n\nexport const StaticInputAdornment = forwardRef<\n HTMLDivElement,\n StaticInputAdornmentProps\n>(function StaticInputAdornment(props, ref) {\n const { children, className, ...other } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-static-input-adornments\",\n css: staticInputAdornmentCss,\n window: targetWindow,\n });\n\n return (\n <div className={clsx(withBaseName(), className)} ref={ref} {...other}>\n {children}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","StaticInputAdornment","useWindow","useComponentCssInjection","staticInputAdornmentCss","jsx","clsx"],"mappings":";;;;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,kBAAa,0BAA0B,CAAA,CAAA;AAErD,MAAM,oBAAuB,GAAAC,gBAAA,CAGlC,SAASC,qBAAAA,CAAqB,OAAO,GAAK,EAAA;AAC1C,EAAA,MAAM,EAAE,QAAA,EAAU,SAAc,EAAA,GAAA,KAAA,EAAU,GAAA,KAAA,CAAA;AAE1C,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,8BAAA;AAAA,IACR,GAAK,EAAAC,sBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IAAG,GAAA;AAAA,IAAW,GAAG,KAAA;AAAA,IAC5D,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"StaticInputAdornment.js","sources":["../src/input-legacy/StaticInputAdornment.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef } from \"react\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport staticInputAdornmentCss from \"./StaticInputAdornment.css\";\n\nexport type StaticInputAdornmentProps = HTMLAttributes<HTMLDivElement>;\n\nconst withBaseName = makePrefixer(\"saltStaticInputAdornment\");\n\nexport const StaticInputAdornment = forwardRef<\n HTMLDivElement,\n StaticInputAdornmentProps\n>(function StaticInputAdornment(props, ref) {\n const { children, className, ...other } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-static-input-adornments\",\n css: staticInputAdornmentCss,\n window: targetWindow,\n });\n\n return (\n <div className={clsx(withBaseName(), className)} ref={ref} {...other}>\n {children}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","StaticInputAdornment","useWindow","useComponentCssInjection","staticInputAdornmentCss","jsx","clsx"],"mappings":";;;;;;;;;;AAUA,MAAM,YAAA,GAAeA,kBAAa,0BAA0B,CAAA;AAErD,MAAM,oBAAuB,GAAAC,gBAAA,CAGlC,SAASC,qBAAAA,CAAqB,OAAO,GAAK,EAAA;AAC1C,EAAA,MAAM,EAAE,QAAA,EAAU,SAAW,EAAA,GAAG,OAAU,GAAA,KAAA;AAE1C,EAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,8BAAA;AAAA,IACR,GAAK,EAAAC,sBAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EACE,uBAAAC,cAAA,CAAC,KAAI,EAAA,EAAA,SAAA,EAAWC,SAAK,CAAA,YAAA,EAAgB,EAAA,SAAS,CAAG,EAAA,GAAA,EAAW,GAAG,KAAA,EAC5D,QACH,EAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var core = require('@salt-ds/core');
6
4
  var react = require('react');
7
5
 
@@ -1 +1 @@
1
- {"version":3,"file":"useCursorOnFocus.js","sources":["../src/input-legacy/useCursorOnFocus.ts"],"sourcesContent":["import { ownerDocument } from \"@salt-ds/core\";\nimport {\n type MouseEvent,\n type MutableRefObject,\n useEffect,\n useRef,\n} from \"react\";\n\nfunction getSelectionRange(\n input: HTMLInputElement,\n { highlightOnFocus, cursorPositionOnFocus }: useCursorOnFocusProps,\n): [number | null, number | null] {\n // highlightOnFocus highlight first so it takes priority over position on focus\n if (highlightOnFocus === true) {\n return [0, input.value.length];\n }\n if (Array.isArray(highlightOnFocus) && highlightOnFocus.length > 1) {\n return [highlightOnFocus[0], highlightOnFocus[1]];\n }\n\n if (cursorPositionOnFocus === \"start\") {\n return [0, 0];\n }\n\n if (cursorPositionOnFocus === \"end\") {\n return [input.value.length, input.value.length];\n }\n\n if (cursorPositionOnFocus != null && !Number.isNaN(cursorPositionOnFocus)) {\n return [cursorPositionOnFocus, cursorPositionOnFocus];\n }\n return [null, null];\n}\n\nfunction isSafari() {\n return (\n navigator.userAgent.toLowerCase().includes(\"safari\") &&\n !navigator.userAgent.toLowerCase().includes(\"chrome\")\n );\n}\n\nfunction isFirefox() {\n return navigator.userAgent.toLowerCase().includes(\"firefox\");\n}\n\nexport interface useCursorOnFocusProps {\n /**\n * Determines the position of the text cursor on focus of the input.\n *\n * start = place cursor at the beginning\n * end = place cursor at the end\n * \\# = index to place the cursor\n */\n cursorPositionOnFocus?: \"start\" | \"end\" | number;\n /**\n * Determines what gets highlighted on focus of the input.\n *\n * If `true` all text will be highlighted.\n * If an array text between those indices will be highlighted\n * e.g. [0,1] will highlight the first character.\n */\n highlightOnFocus?: boolean | number[];\n}\n\nexport function useCursorOnFocus(\n inputRef: MutableRefObject<HTMLInputElement | null>,\n { cursorPositionOnFocus, highlightOnFocus }: useCursorOnFocusProps,\n) {\n const wasClick = useRef(false);\n const timeoutRef = useRef<number>(-1);\n const originalCursorPosition = useRef<number | null | undefined>(-1);\n const selectionInProgress = useRef(false);\n const mouseMovement = useRef(0);\n\n const selection = useRef<[number | null, number | null]>([null, null]);\n const wasWindowFocus = useRef(false);\n\n const handleMouseDown = () => {\n wasClick.current = true;\n };\n\n const handleMouseMove = (event: MouseEvent) => {\n if (selectionInProgress.current) {\n mouseMovement.current +=\n Math.abs(event.movementX) + Math.abs(event.movementY);\n\n //Prevents the slightest mouse movement triggering the cursor to be repositioned.\n if (mouseMovement.current < 3) {\n event.preventDefault();\n\n return;\n }\n\n if (typeof originalCursorPosition.current === \"number\") {\n // Allows continued highlighted if the mouse down is part of a selection.\n inputRef.current?.setSelectionRange(\n originalCursorPosition.current,\n originalCursorPosition.current,\n );\n }\n\n //Reset so originalCursorPosition is only set once.\n selectionInProgress.current = false;\n }\n };\n\n const handleMouseUp = () => {\n const isValidBrowser = isFirefox() || isSafari();\n if (\n selectionInProgress.current &&\n mouseMovement.current < 3 &&\n isValidBrowser &&\n Array.isArray(selection.current)\n ) {\n const [start, end] = selection.current;\n setTimeout(() => {\n if (\n (inputRef.current?.selectionStart !== start ||\n inputRef.current?.selectionEnd !== end) &&\n typeof start === \"number\" &&\n typeof end === \"number\"\n ) {\n inputRef.current?.setSelectionRange(start, end);\n }\n }, 0);\n }\n\n wasClick.current = false;\n selectionInProgress.current = false;\n mouseMovement.current = 0;\n };\n\n useEffect(() => {\n if (cursorPositionOnFocus != null || highlightOnFocus != null) {\n const handleFocusBehaviour = () => {\n if (!inputRef.current) {\n return;\n }\n\n const [start, end] = getSelectionRange(inputRef.current, {\n highlightOnFocus,\n cursorPositionOnFocus,\n });\n if (start !== null && end !== null) {\n window.clearTimeout(timeoutRef.current);\n const needsTimeout = isSafari() || wasClick.current;\n\n if (wasClick.current) {\n selectionInProgress.current = true;\n mouseMovement.current = 0;\n }\n\n selection.current = [start, end];\n // Keyboard focus needs to be outside setTimeout otherwise a flash of selected text appears.\n if (needsTimeout) {\n // Make's sure setSelectionRange is run after browser has set cursor position.\n timeoutRef.current = window.setTimeout(() => {\n if (wasClick.current) {\n originalCursorPosition.current =\n inputRef.current?.selectionStart;\n }\n inputRef.current?.setSelectionRange(start, end);\n }, 0);\n } else {\n inputRef.current?.setSelectionRange(start, end);\n }\n }\n };\n\n const handleFocusIn = () => {\n // Ignore focus of input on window focus\n if (wasWindowFocus.current) {\n wasWindowFocus.current = false;\n return;\n }\n\n if (cursorPositionOnFocus != null || highlightOnFocus != null) {\n handleFocusBehaviour();\n }\n };\n\n //Reset everything on window re-focus\n const handleWindowFocus = () => {\n const doc = ownerDocument(inputRef.current);\n if (\n doc.visibilityState === \"visible\" &&\n doc.activeElement === inputRef.current\n ) {\n wasClick.current = false;\n selectionInProgress.current = false;\n mouseMovement.current = 0;\n wasWindowFocus.current = true;\n }\n };\n\n const eventName = isSafari() || isFirefox() ? \"focusIn\" : \"focus\";\n const input = inputRef.current;\n const doc = ownerDocument(inputRef.current);\n input?.addEventListener(eventName, handleFocusIn);\n doc.addEventListener(\"visibilitychange\", handleWindowFocus);\n\n return () => {\n input?.removeEventListener(eventName, handleFocusIn);\n doc?.removeEventListener(\"visibilitychange\", handleWindowFocus);\n };\n }\n\n return undefined;\n }, [cursorPositionOnFocus, highlightOnFocus, inputRef]);\n\n return { handleMouseDown, handleMouseMove, handleMouseUp };\n}\n"],"names":["useRef","useEffect","_a","doc","ownerDocument"],"mappings":"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"}
1
+ {"version":3,"file":"useCursorOnFocus.js","sources":["../src/input-legacy/useCursorOnFocus.ts"],"sourcesContent":["import { ownerDocument } from \"@salt-ds/core\";\nimport {\n type MouseEvent,\n type MutableRefObject,\n useEffect,\n useRef,\n} from \"react\";\n\nfunction getSelectionRange(\n input: HTMLInputElement,\n { highlightOnFocus, cursorPositionOnFocus }: useCursorOnFocusProps,\n): [number | null, number | null] {\n // highlightOnFocus highlight first so it takes priority over position on focus\n if (highlightOnFocus === true) {\n return [0, input.value.length];\n }\n if (Array.isArray(highlightOnFocus) && highlightOnFocus.length > 1) {\n return [highlightOnFocus[0], highlightOnFocus[1]];\n }\n\n if (cursorPositionOnFocus === \"start\") {\n return [0, 0];\n }\n\n if (cursorPositionOnFocus === \"end\") {\n return [input.value.length, input.value.length];\n }\n\n if (cursorPositionOnFocus != null && !Number.isNaN(cursorPositionOnFocus)) {\n return [cursorPositionOnFocus, cursorPositionOnFocus];\n }\n return [null, null];\n}\n\nfunction isSafari() {\n return (\n navigator.userAgent.toLowerCase().includes(\"safari\") &&\n !navigator.userAgent.toLowerCase().includes(\"chrome\")\n );\n}\n\nfunction isFirefox() {\n return navigator.userAgent.toLowerCase().includes(\"firefox\");\n}\n\nexport interface useCursorOnFocusProps {\n /**\n * Determines the position of the text cursor on focus of the input.\n *\n * start = place cursor at the beginning\n * end = place cursor at the end\n * \\# = index to place the cursor\n */\n cursorPositionOnFocus?: \"start\" | \"end\" | number;\n /**\n * Determines what gets highlighted on focus of the input.\n *\n * If `true` all text will be highlighted.\n * If an array text between those indices will be highlighted\n * e.g. [0,1] will highlight the first character.\n */\n highlightOnFocus?: boolean | number[];\n}\n\nexport function useCursorOnFocus(\n inputRef: MutableRefObject<HTMLInputElement | null>,\n { cursorPositionOnFocus, highlightOnFocus }: useCursorOnFocusProps,\n) {\n const wasClick = useRef(false);\n const timeoutRef = useRef<number>(-1);\n const originalCursorPosition = useRef<number | null | undefined>(-1);\n const selectionInProgress = useRef(false);\n const mouseMovement = useRef(0);\n\n const selection = useRef<[number | null, number | null]>([null, null]);\n const wasWindowFocus = useRef(false);\n\n const handleMouseDown = () => {\n wasClick.current = true;\n };\n\n const handleMouseMove = (event: MouseEvent) => {\n if (selectionInProgress.current) {\n mouseMovement.current +=\n Math.abs(event.movementX) + Math.abs(event.movementY);\n\n //Prevents the slightest mouse movement triggering the cursor to be repositioned.\n if (mouseMovement.current < 3) {\n event.preventDefault();\n\n return;\n }\n\n if (typeof originalCursorPosition.current === \"number\") {\n // Allows continued highlighted if the mouse down is part of a selection.\n inputRef.current?.setSelectionRange(\n originalCursorPosition.current,\n originalCursorPosition.current,\n );\n }\n\n //Reset so originalCursorPosition is only set once.\n selectionInProgress.current = false;\n }\n };\n\n const handleMouseUp = () => {\n const isValidBrowser = isFirefox() || isSafari();\n if (\n selectionInProgress.current &&\n mouseMovement.current < 3 &&\n isValidBrowser &&\n Array.isArray(selection.current)\n ) {\n const [start, end] = selection.current;\n setTimeout(() => {\n if (\n (inputRef.current?.selectionStart !== start ||\n inputRef.current?.selectionEnd !== end) &&\n typeof start === \"number\" &&\n typeof end === \"number\"\n ) {\n inputRef.current?.setSelectionRange(start, end);\n }\n }, 0);\n }\n\n wasClick.current = false;\n selectionInProgress.current = false;\n mouseMovement.current = 0;\n };\n\n useEffect(() => {\n if (cursorPositionOnFocus != null || highlightOnFocus != null) {\n const handleFocusBehaviour = () => {\n if (!inputRef.current) {\n return;\n }\n\n const [start, end] = getSelectionRange(inputRef.current, {\n highlightOnFocus,\n cursorPositionOnFocus,\n });\n if (start !== null && end !== null) {\n window.clearTimeout(timeoutRef.current);\n const needsTimeout = isSafari() || wasClick.current;\n\n if (wasClick.current) {\n selectionInProgress.current = true;\n mouseMovement.current = 0;\n }\n\n selection.current = [start, end];\n // Keyboard focus needs to be outside setTimeout otherwise a flash of selected text appears.\n if (needsTimeout) {\n // Make's sure setSelectionRange is run after browser has set cursor position.\n timeoutRef.current = window.setTimeout(() => {\n if (wasClick.current) {\n originalCursorPosition.current =\n inputRef.current?.selectionStart;\n }\n inputRef.current?.setSelectionRange(start, end);\n }, 0);\n } else {\n inputRef.current?.setSelectionRange(start, end);\n }\n }\n };\n\n const handleFocusIn = () => {\n // Ignore focus of input on window focus\n if (wasWindowFocus.current) {\n wasWindowFocus.current = false;\n return;\n }\n\n if (cursorPositionOnFocus != null || highlightOnFocus != null) {\n handleFocusBehaviour();\n }\n };\n\n //Reset everything on window re-focus\n const handleWindowFocus = () => {\n const doc = ownerDocument(inputRef.current);\n if (\n doc.visibilityState === \"visible\" &&\n doc.activeElement === inputRef.current\n ) {\n wasClick.current = false;\n selectionInProgress.current = false;\n mouseMovement.current = 0;\n wasWindowFocus.current = true;\n }\n };\n\n const eventName = isSafari() || isFirefox() ? \"focusIn\" : \"focus\";\n const input = inputRef.current;\n const doc = ownerDocument(inputRef.current);\n input?.addEventListener(eventName, handleFocusIn);\n doc.addEventListener(\"visibilitychange\", handleWindowFocus);\n\n return () => {\n input?.removeEventListener(eventName, handleFocusIn);\n doc?.removeEventListener(\"visibilitychange\", handleWindowFocus);\n };\n }\n\n return undefined;\n }, [cursorPositionOnFocus, highlightOnFocus, inputRef]);\n\n return { handleMouseDown, handleMouseMove, handleMouseUp };\n}\n"],"names":["useRef","useEffect","_a","doc","ownerDocument"],"mappings":"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"}
@@ -1,7 +1,5 @@
1
1
  'use strict';
2
2
 
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
3
  var jsxRuntime = require('react/jsx-runtime');
6
4
  var core = require('@salt-ds/core');
7
5
  var styles = require('@salt-ds/styles');
@@ -60,34 +58,40 @@ const LayerLayout = react.forwardRef(
60
58
  const anchored = position !== "center" && !fullScreen;
61
59
  const enterAnimation = !disableAnimations && isOpen && !previousDisableAnimationsProp;
62
60
  const exitAnimation = !disableAnimations && !isOpen;
63
- const layerLayout = showComponent ? /* @__PURE__ */ jsxRuntime.jsx("div", {
64
- ref,
65
- className: clsx.clsx(withBaseName(), className, {
66
- [withBaseName("anchor")]: anchored,
67
- [withBaseName("fullScreen")]: fullScreen,
68
- [withBaseName(position)]: !fullScreen,
69
- [withBaseName("enter-animation")]: enterAnimation,
70
- [withBaseName("exit-animation")]: exitAnimation
71
- }),
72
- onAnimationStart: () => setIsAnimating(true),
73
- onAnimationEnd: () => {
74
- if (!isOpen && showComponent) {
75
- setShowComponent(false);
76
- }
77
- },
78
- ...disableScrim && ariaAttributes,
79
- ...rest,
80
- children
81
- }) : null;
82
- return disableScrim ? layerLayout : /* @__PURE__ */ jsxRuntime.jsx(core.Scrim, {
83
- open: showComponent,
84
- className: clsx.clsx({
85
- [withBaseName("enter-animation")]: enterAnimation,
86
- [withBaseName("exit-animation")]: exitAnimation
87
- }),
88
- ...scrimProps,
89
- children: layerLayout
90
- });
61
+ const layerLayout = showComponent ? /* @__PURE__ */ jsxRuntime.jsx(
62
+ "div",
63
+ {
64
+ ref,
65
+ className: clsx.clsx(withBaseName(), className, {
66
+ [withBaseName("anchor")]: anchored,
67
+ [withBaseName("fullScreen")]: fullScreen,
68
+ [withBaseName(position)]: !fullScreen,
69
+ [withBaseName("enter-animation")]: enterAnimation,
70
+ [withBaseName("exit-animation")]: exitAnimation
71
+ }),
72
+ onAnimationStart: () => setIsAnimating(true),
73
+ onAnimationEnd: () => {
74
+ if (!isOpen && showComponent) {
75
+ setShowComponent(false);
76
+ }
77
+ },
78
+ ...disableScrim && ariaAttributes,
79
+ ...rest,
80
+ children
81
+ }
82
+ ) : null;
83
+ return disableScrim ? layerLayout : /* @__PURE__ */ jsxRuntime.jsx(
84
+ core.Scrim,
85
+ {
86
+ open: showComponent,
87
+ className: clsx.clsx({
88
+ [withBaseName("enter-animation")]: enterAnimation,
89
+ [withBaseName("exit-animation")]: exitAnimation
90
+ }),
91
+ ...scrimProps,
92
+ children: layerLayout
93
+ }
94
+ );
91
95
  }
92
96
  );
93
97
 
@@ -1 +1 @@
1
- {"version":3,"file":"LayerLayout.js","sources":["../src/layer-layout/LayerLayout.tsx"],"sourcesContent":["import {\n type Breakpoints,\n Scrim,\n type ScrimProps,\n makePrefixer,\n usePrevious,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef, useEffect, useState } from \"react\";\nimport { useIsViewportLargerThanBreakpoint } from \"../utils\";\n\nimport layerLayoutCss from \"./LayerLayout.css\";\n\nexport const LAYER_POSITIONS = [\n \"center\",\n \"left\",\n \"top\",\n \"right\",\n \"bottom\",\n] as const;\n\nexport type LayerPositions = (typeof LAYER_POSITIONS)[number];\n\nexport interface LayerLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Disable the scrim.\n */\n disableScrim?: boolean;\n /**\n * Defines the layer position within the screen.\n */\n position?: LayerPositions;\n /**\n * Breakpoint at which the layer will become fullscreen.\n */\n fullScreenAtBreakpoint?: keyof Breakpoints;\n /**\n * Disable all animations.\n */\n disableAnimations?: boolean;\n /**\n * Display or hide the component.\n */\n isOpen?: boolean;\n /**\n * Props to be passed to the Scrim component.\n */\n scrimProps?: Partial<ScrimProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltLayerLayout\");\n\nconst ariaAttributes = { role: \"dialog\", \"aria-modal\": true };\n\nexport const LayerLayout = forwardRef<HTMLDivElement, LayerLayoutProps>(\n function LayerLayout(props, ref) {\n const {\n children,\n className,\n disableScrim = false,\n position = \"center\",\n fullScreenAtBreakpoint = \"sm\",\n disableAnimations = false,\n scrimProps,\n isOpen = true,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-layer-layout\",\n css: layerLayoutCss,\n window: targetWindow,\n });\n\n const previousDisableAnimationsProp = usePrevious(\n disableAnimations,\n [disableAnimations],\n false,\n ); // we check the previous value for this prop to prevent the animations from triggering again when it changes\n\n const [showComponent, setShowComponent] = useState(false);\n\n const [isAnimating, setIsAnimating] = useState(false);\n\n useEffect(() => {\n if ((!isOpen && disableAnimations) || (!isOpen && !isAnimating)) {\n setShowComponent(false);\n }\n\n if (isOpen && !showComponent) {\n setShowComponent(true);\n }\n }, [isOpen, showComponent, disableAnimations, isAnimating]);\n\n const fullScreen = useIsViewportLargerThanBreakpoint(\n fullScreenAtBreakpoint,\n );\n\n const anchored = position !== \"center\" && !fullScreen;\n\n const enterAnimation =\n !disableAnimations && isOpen && !previousDisableAnimationsProp;\n\n const exitAnimation = !disableAnimations && !isOpen;\n\n const layerLayout = showComponent ? (\n <div\n ref={ref}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"anchor\")]: anchored,\n [withBaseName(\"fullScreen\")]: fullScreen,\n [withBaseName(position)]: !fullScreen,\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n onAnimationStart={() => setIsAnimating(true)}\n onAnimationEnd={() => {\n if (!isOpen && showComponent) {\n setShowComponent(false);\n }\n }}\n {...(disableScrim && ariaAttributes)}\n {...rest}\n >\n {children}\n </div>\n ) : null;\n\n return disableScrim ? (\n layerLayout\n ) : (\n <Scrim\n open={showComponent}\n className={clsx({\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n {...scrimProps}\n >\n {layerLayout}\n </Scrim>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","LayerLayout","useWindow","useComponentCssInjection","layerLayoutCss","usePrevious","useState","useEffect","useIsViewportLargerThanBreakpoint","jsx","clsx","Scrim"],"mappings":"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"}
1
+ {"version":3,"file":"LayerLayout.js","sources":["../src/layer-layout/LayerLayout.tsx"],"sourcesContent":["import {\n type Breakpoints,\n Scrim,\n type ScrimProps,\n makePrefixer,\n usePrevious,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport { type HTMLAttributes, forwardRef, useEffect, useState } from \"react\";\nimport { useIsViewportLargerThanBreakpoint } from \"../utils\";\n\nimport layerLayoutCss from \"./LayerLayout.css\";\n\nexport const LAYER_POSITIONS = [\n \"center\",\n \"left\",\n \"top\",\n \"right\",\n \"bottom\",\n] as const;\n\nexport type LayerPositions = (typeof LAYER_POSITIONS)[number];\n\nexport interface LayerLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Disable the scrim.\n */\n disableScrim?: boolean;\n /**\n * Defines the layer position within the screen.\n */\n position?: LayerPositions;\n /**\n * Breakpoint at which the layer will become fullscreen.\n */\n fullScreenAtBreakpoint?: keyof Breakpoints;\n /**\n * Disable all animations.\n */\n disableAnimations?: boolean;\n /**\n * Display or hide the component.\n */\n isOpen?: boolean;\n /**\n * Props to be passed to the Scrim component.\n */\n scrimProps?: Partial<ScrimProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltLayerLayout\");\n\nconst ariaAttributes = { role: \"dialog\", \"aria-modal\": true };\n\nexport const LayerLayout = forwardRef<HTMLDivElement, LayerLayoutProps>(\n function LayerLayout(props, ref) {\n const {\n children,\n className,\n disableScrim = false,\n position = \"center\",\n fullScreenAtBreakpoint = \"sm\",\n disableAnimations = false,\n scrimProps,\n isOpen = true,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-layer-layout\",\n css: layerLayoutCss,\n window: targetWindow,\n });\n\n const previousDisableAnimationsProp = usePrevious(\n disableAnimations,\n [disableAnimations],\n false,\n ); // we check the previous value for this prop to prevent the animations from triggering again when it changes\n\n const [showComponent, setShowComponent] = useState(false);\n\n const [isAnimating, setIsAnimating] = useState(false);\n\n useEffect(() => {\n if ((!isOpen && disableAnimations) || (!isOpen && !isAnimating)) {\n setShowComponent(false);\n }\n\n if (isOpen && !showComponent) {\n setShowComponent(true);\n }\n }, [isOpen, showComponent, disableAnimations, isAnimating]);\n\n const fullScreen = useIsViewportLargerThanBreakpoint(\n fullScreenAtBreakpoint,\n );\n\n const anchored = position !== \"center\" && !fullScreen;\n\n const enterAnimation =\n !disableAnimations && isOpen && !previousDisableAnimationsProp;\n\n const exitAnimation = !disableAnimations && !isOpen;\n\n const layerLayout = showComponent ? (\n <div\n ref={ref}\n className={clsx(withBaseName(), className, {\n [withBaseName(\"anchor\")]: anchored,\n [withBaseName(\"fullScreen\")]: fullScreen,\n [withBaseName(position)]: !fullScreen,\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n onAnimationStart={() => setIsAnimating(true)}\n onAnimationEnd={() => {\n if (!isOpen && showComponent) {\n setShowComponent(false);\n }\n }}\n {...(disableScrim && ariaAttributes)}\n {...rest}\n >\n {children}\n </div>\n ) : null;\n\n return disableScrim ? (\n layerLayout\n ) : (\n <Scrim\n open={showComponent}\n className={clsx({\n [withBaseName(\"enter-animation\")]: enterAnimation,\n [withBaseName(\"exit-animation\")]: exitAnimation,\n })}\n {...scrimProps}\n >\n {layerLayout}\n </Scrim>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","LayerLayout","useWindow","useComponentCssInjection","layerLayoutCss","usePrevious","useState","useEffect","useIsViewportLargerThanBreakpoint","jsx","clsx","Scrim"],"mappings":"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"}