@salt-ds/lab 1.0.0-alpha.66 → 1.0.0-alpha.68

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 (645) hide show
  1. package/CHANGELOG.md +184 -0
  2. package/css/salt-lab.css +24 -388
  3. package/dist-cjs/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  4. package/dist-cjs/button-bar/ButtonBar.js.map +1 -1
  5. package/dist-cjs/button-bar/OrderedButton.js.map +1 -1
  6. package/dist-cjs/button-bar/internal/useDescendant.js.map +1 -1
  7. package/dist-cjs/calendar/Calendar.js +23 -8
  8. package/dist-cjs/calendar/Calendar.js.map +1 -1
  9. package/dist-cjs/calendar/CalendarGrid.js +56 -80
  10. package/dist-cjs/calendar/CalendarGrid.js.map +1 -1
  11. package/dist-cjs/calendar/CalendarMonthHeader.css.js +6 -0
  12. package/dist-cjs/calendar/CalendarMonthHeader.css.js.map +1 -0
  13. package/dist-cjs/calendar/CalendarMonthHeader.js +48 -0
  14. package/dist-cjs/calendar/CalendarMonthHeader.js.map +1 -0
  15. package/dist-cjs/calendar/CalendarNavigation.js +30 -39
  16. package/dist-cjs/calendar/CalendarNavigation.js.map +1 -1
  17. package/dist-cjs/calendar/CalendarWeekHeader.js +2 -6
  18. package/dist-cjs/calendar/CalendarWeekHeader.js.map +1 -1
  19. package/dist-cjs/calendar/internal/CalendarContext.js +3 -1
  20. package/dist-cjs/calendar/internal/CalendarContext.js.map +1 -1
  21. package/dist-cjs/calendar/internal/CalendarDay.css.js +1 -1
  22. package/dist-cjs/calendar/internal/CalendarDay.js +88 -76
  23. package/dist-cjs/calendar/internal/CalendarDay.js.map +1 -1
  24. package/dist-cjs/calendar/internal/CalendarMonth.js +13 -23
  25. package/dist-cjs/calendar/internal/CalendarMonth.js.map +1 -1
  26. package/dist-cjs/calendar/internal/useFocusManagement.js +5 -6
  27. package/dist-cjs/calendar/internal/useFocusManagement.js.map +1 -1
  28. package/dist-cjs/calendar/internal/utils.js +8 -12
  29. package/dist-cjs/calendar/internal/utils.js.map +1 -1
  30. package/dist-cjs/calendar/useCalendar.js +69 -109
  31. package/dist-cjs/calendar/useCalendar.js.map +1 -1
  32. package/dist-cjs/calendar/useCalendarDay.js +21 -18
  33. package/dist-cjs/calendar/useCalendarDay.js.map +1 -1
  34. package/dist-cjs/calendar/useCalendarSelection.js +146 -34
  35. package/dist-cjs/calendar/useCalendarSelection.js.map +1 -1
  36. package/dist-cjs/carousel/CarouselContext.js.map +1 -1
  37. package/dist-cjs/carousel/CarouselControls.js.map +1 -1
  38. package/dist-cjs/carousel/CarouselReducer.js.map +1 -1
  39. package/dist-cjs/carousel/CarouselSlide.js.map +1 -1
  40. package/dist-cjs/carousel/CarouselSlider.js.map +1 -1
  41. package/dist-cjs/cascading-menu/CascadingMenu.js.map +1 -1
  42. package/dist-cjs/cascading-menu/CascadingMenuItem.js.map +1 -1
  43. package/dist-cjs/cascading-menu/CascadingMenuList.js.map +1 -1
  44. package/dist-cjs/cascading-menu/internal/keydownHandlers.js.map +1 -1
  45. package/dist-cjs/cascading-menu/internal/useClickAway.js.map +1 -1
  46. package/dist-cjs/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  47. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  48. package/dist-cjs/cascading-menu/internal/useStateReducer.js.map +1 -1
  49. package/dist-cjs/cascading-menu/stateChangeTypes.js +0 -1
  50. package/dist-cjs/cascading-menu/stateChangeTypes.js.map +1 -1
  51. package/dist-cjs/color-chooser/Color.js.map +1 -1
  52. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  53. package/dist-cjs/color-chooser/ColorHelpers.js.map +1 -1
  54. package/dist-cjs/color-chooser/ColorPicker.js.map +1 -1
  55. package/dist-cjs/color-chooser/DictTabs.js.map +1 -1
  56. package/dist-cjs/color-chooser/HexInput.js.map +1 -1
  57. package/dist-cjs/color-chooser/Swatch.js.map +1 -1
  58. package/dist-cjs/color-chooser/Swatches.js.map +1 -1
  59. package/dist-cjs/color-chooser/SwatchesPicker.js.map +1 -1
  60. package/dist-cjs/combo-box/ComboBox.js +0 -2
  61. package/dist-cjs/combo-box/ComboBox.js.map +1 -1
  62. package/dist-cjs/combo-box/useCombobox.js.map +1 -1
  63. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js +0 -4
  64. package/dist-cjs/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  65. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js +0 -4
  66. package/dist-cjs/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  67. package/dist-cjs/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  68. package/dist-cjs/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  69. package/dist-cjs/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  70. package/dist-cjs/common-hooks/calcPreferredHeight.js.map +1 -1
  71. package/dist-cjs/common-hooks/collectionProvider.js.map +1 -1
  72. package/dist-cjs/common-hooks/list-dom-utils.js.map +1 -1
  73. package/dist-cjs/common-hooks/selectionTypes.js.map +1 -1
  74. package/dist-cjs/common-hooks/useCollapsibleGroups.js.map +1 -1
  75. package/dist-cjs/common-hooks/useCollectionItems.js.map +1 -1
  76. package/dist-cjs/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  77. package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
  78. package/dist-cjs/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  79. package/dist-cjs/common-hooks/useSelection.js.map +1 -1
  80. package/dist-cjs/common-hooks/useTypeahead.js +1 -1
  81. package/dist-cjs/common-hooks/useTypeahead.js.map +1 -1
  82. package/dist-cjs/common-hooks/useViewportTracking.js.map +1 -1
  83. package/dist-cjs/common-hooks/utils/collection-item-utils.js.map +1 -1
  84. package/dist-cjs/contact-details/ContactPrimaryInfo.js.map +1 -1
  85. package/dist-cjs/contact-details/ContactSecondaryInfo.js.map +1 -1
  86. package/dist-cjs/contact-details/ContactTertiaryInfo.js.map +1 -1
  87. package/dist-cjs/contact-details/internal/ContactDetailsContext.js.map +1 -1
  88. package/dist-cjs/content-status/internal/StatusIndicator.js.map +1 -1
  89. package/dist-cjs/date-input/DateInputRange.js +61 -51
  90. package/dist-cjs/date-input/DateInputRange.js.map +1 -1
  91. package/dist-cjs/date-input/DateInputSingle.js +33 -18
  92. package/dist-cjs/date-input/DateInputSingle.js.map +1 -1
  93. package/dist-cjs/date-picker/DatePicker.js +9 -1
  94. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  95. package/dist-cjs/date-picker/DatePickerActions.js.map +1 -1
  96. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  97. package/dist-cjs/date-picker/DatePickerHelperText.css.js +6 -0
  98. package/dist-cjs/date-picker/DatePickerHelperText.css.js.map +1 -0
  99. package/dist-cjs/date-picker/DatePickerHelperText.js +36 -0
  100. package/dist-cjs/date-picker/DatePickerHelperText.js.map +1 -0
  101. package/dist-cjs/date-picker/DatePickerOverlay.js.map +1 -1
  102. package/dist-cjs/date-picker/DatePickerOverlayProvider.js +40 -16
  103. package/dist-cjs/date-picker/DatePickerOverlayProvider.js.map +1 -1
  104. package/dist-cjs/date-picker/DatePickerPanel.css.js +1 -1
  105. package/dist-cjs/date-picker/DatePickerRangeGridPanel.js +247 -0
  106. package/dist-cjs/date-picker/DatePickerRangeGridPanel.js.map +1 -0
  107. package/dist-cjs/date-picker/DatePickerRangeInput.js +38 -6
  108. package/dist-cjs/date-picker/DatePickerRangeInput.js.map +1 -1
  109. package/dist-cjs/date-picker/DatePickerRangePanel.js +188 -32
  110. package/dist-cjs/date-picker/DatePickerRangePanel.js.map +1 -1
  111. package/dist-cjs/date-picker/DatePickerSingleGridPanel.js +255 -0
  112. package/dist-cjs/date-picker/DatePickerSingleGridPanel.js.map +1 -0
  113. package/dist-cjs/date-picker/DatePickerSingleInput.js +13 -5
  114. package/dist-cjs/date-picker/DatePickerSingleInput.js.map +1 -1
  115. package/dist-cjs/date-picker/DatePickerSinglePanel.js +6 -105
  116. package/dist-cjs/date-picker/DatePickerSinglePanel.js.map +1 -1
  117. package/dist-cjs/date-picker/DatePickerTrigger.js.map +1 -1
  118. package/dist-cjs/date-picker/useDatePicker.js +71 -11
  119. package/dist-cjs/date-picker/useDatePicker.js.map +1 -1
  120. package/dist-cjs/date-picker/useFocusOut.js +43 -0
  121. package/dist-cjs/date-picker/useFocusOut.js.map +1 -0
  122. package/dist-cjs/date-picker/useKeyboard.js +4 -5
  123. package/dist-cjs/date-picker/useKeyboard.js.map +1 -1
  124. package/dist-cjs/deck-item/DeckItem.js.map +1 -1
  125. package/dist-cjs/deck-layout/DeckLayout.js.map +1 -1
  126. package/dist-cjs/dropdown/Dropdown.js +0 -1
  127. package/dist-cjs/dropdown/Dropdown.js.map +1 -1
  128. package/dist-cjs/dropdown/DropdownBase.js +0 -1
  129. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  130. package/dist-cjs/dropdown/DropdownButton.js.map +1 -1
  131. package/dist-cjs/dropdown/useClickAway.js.map +1 -1
  132. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  133. package/dist-cjs/dropdown/useDropdownBase.js.map +1 -1
  134. package/dist-cjs/editable-label/EditableLabel.js.map +1 -1
  135. package/dist-cjs/form-field-legacy/FormFieldLegacy.js.map +1 -1
  136. package/dist-cjs/form-field-legacy/StatusIndicator.js.map +1 -1
  137. package/dist-cjs/formatted-input/FormattedInput.js.map +1 -1
  138. package/dist-cjs/index.js +8 -14
  139. package/dist-cjs/index.js.map +1 -1
  140. package/dist-cjs/input-legacy/InputLegacy.js.map +1 -1
  141. package/dist-cjs/input-legacy/useCursorOnFocus.js.map +1 -1
  142. package/dist-cjs/list/Highlighter.js.map +1 -1
  143. package/dist-cjs/list/List.js.map +1 -1
  144. package/dist-cjs/list/ListItem.js.map +1 -1
  145. package/dist-cjs/list/VirtualizedList.js.map +1 -1
  146. package/dist-cjs/list/useList.js +0 -1
  147. package/dist-cjs/list/useList.js.map +1 -1
  148. package/dist-cjs/list/useListHeight.js.map +1 -1
  149. package/dist-cjs/list-deprecated/ListBase.js +1 -3
  150. package/dist-cjs/list-deprecated/ListBase.js.map +1 -1
  151. package/dist-cjs/list-deprecated/ListItem.js.map +1 -1
  152. package/dist-cjs/list-deprecated/ListItemBase.js.map +1 -1
  153. package/dist-cjs/list-deprecated/ListItemContext.js.map +1 -1
  154. package/dist-cjs/list-deprecated/internal/DescendantContext.js.map +1 -1
  155. package/dist-cjs/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  156. package/dist-cjs/list-deprecated/internal/useWidth.js.map +1 -1
  157. package/dist-cjs/list-deprecated/useList.js.map +1 -1
  158. package/dist-cjs/list-deprecated/useListItem.js.map +1 -1
  159. package/dist-cjs/list-deprecated/useTypeSelect.js.map +1 -1
  160. package/dist-cjs/list-next/ListItemNext.js.map +1 -1
  161. package/dist-cjs/list-next/ListNext.js.map +1 -1
  162. package/dist-cjs/list-next/ListNextContext.js.map +1 -1
  163. package/dist-cjs/list-next/useList.js.map +1 -1
  164. package/dist-cjs/localization-provider/LocalizationProvider.js +5 -2
  165. package/dist-cjs/localization-provider/LocalizationProvider.js.map +1 -1
  166. package/dist-cjs/menu-button/MenuButton.js.map +1 -1
  167. package/dist-cjs/metric/MetricContent.js.map +1 -1
  168. package/dist-cjs/number-input/NumberInput.js.map +1 -1
  169. package/dist-cjs/number-input/useNumberInput.js.map +1 -1
  170. package/dist-cjs/query-input/internal/CategoryListContext.js.map +1 -1
  171. package/dist-cjs/query-input/internal/CategoryListItem.js.map +1 -1
  172. package/dist-cjs/query-input/internal/usePopperStatus.js +2 -2
  173. package/dist-cjs/query-input/internal/usePopperStatus.js.map +1 -1
  174. package/dist-cjs/query-input/useQueryInput.js +0 -1
  175. package/dist-cjs/query-input/useQueryInput.js.map +1 -1
  176. package/dist-cjs/responsive/OverflowReducer.js +1 -3
  177. package/dist-cjs/responsive/OverflowReducer.js.map +1 -1
  178. package/dist-cjs/responsive/useDynamicCollapse.js.map +1 -1
  179. package/dist-cjs/responsive/useInstantCollapse.js.map +1 -1
  180. package/dist-cjs/responsive/useOverflow.js.map +1 -1
  181. package/dist-cjs/responsive/useOverflowCollectionItems.js.map +1 -1
  182. package/dist-cjs/responsive/useOverflowLayout.js +0 -3
  183. package/dist-cjs/responsive/useOverflowLayout.js.map +1 -1
  184. package/dist-cjs/responsive/useReclaimSpace.js.map +1 -1
  185. package/dist-cjs/responsive/useResizeObserver.js.map +1 -1
  186. package/dist-cjs/responsive/useWidth.js.map +1 -1
  187. package/dist-cjs/responsive/utils.js.map +1 -1
  188. package/dist-cjs/search-input/SearchInput.js.map +1 -1
  189. package/dist-cjs/tabs/Tab.js.map +1 -1
  190. package/dist-cjs/tabs/Tabs.js.map +1 -1
  191. package/dist-cjs/tabs/Tabstrip.js +0 -1
  192. package/dist-cjs/tabs/Tabstrip.js.map +1 -1
  193. package/dist-cjs/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  194. package/dist-cjs/tabs/drag-drop/useDragSpacers.js.map +1 -1
  195. package/dist-cjs/tabs/useEditableItem.js.map +1 -1
  196. package/dist-cjs/tabs/useKeyboardNavigation.js.map +1 -1
  197. package/dist-cjs/tabs/useSelection.js.map +1 -1
  198. package/dist-cjs/tabs/useTabs.js.map +1 -1
  199. package/dist-cjs/tabs/useTabstrip.js.map +1 -1
  200. package/dist-cjs/tabs-next/TabListNext.js.map +1 -1
  201. package/dist-cjs/tabs-next/TabNext.js.map +1 -1
  202. package/dist-cjs/tabs-next/TabNextAction.js.map +1 -1
  203. package/dist-cjs/tabs-next/TabNextContext.js.map +1 -1
  204. package/dist-cjs/tabs-next/TabNextPanel.js.map +1 -1
  205. package/dist-cjs/tabs-next/TabNextTrigger.js.map +1 -1
  206. package/dist-cjs/tabs-next/TabOverflowList.js.map +1 -1
  207. package/dist-cjs/tabs-next/TabsNext.js.map +1 -1
  208. package/dist-cjs/tabs-next/TabsNextContext.js.map +1 -1
  209. package/dist-cjs/tabs-next/hooks/useCollection.js +2 -2
  210. package/dist-cjs/tabs-next/hooks/useCollection.js.map +1 -1
  211. package/dist-cjs/tabs-next/hooks/useFocusOutside.js.map +1 -1
  212. package/dist-cjs/tabs-next/hooks/useOverflow.js.map +1 -1
  213. package/dist-cjs/tabs-next/hooks/useRestoreActiveTab.js.map +1 -1
  214. package/dist-cjs/tokenized-input/TokenizedInputBase.js.map +1 -1
  215. package/dist-cjs/tokenized-input/internal/InputPill.js.map +1 -1
  216. package/dist-cjs/tokenized-input/internal/getCursorPosition.js.map +1 -1
  217. package/dist-cjs/tokenized-input/internal/useResizeObserver.js.map +1 -1
  218. package/dist-cjs/tokenized-input/useTokenizedInput.js.map +1 -1
  219. package/dist-cjs/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  220. package/dist-cjs/tokenized-input-next/internal/InputPill.js.map +1 -1
  221. package/dist-cjs/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  222. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js +1 -1
  223. package/dist-cjs/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  224. package/dist-cjs/toolbar/Tooltray.js.map +1 -1
  225. package/dist-cjs/toolbar/internal/renderToolbarItems.js.map +1 -1
  226. package/dist-cjs/toolbar/internal/renderTrayTools.js.map +1 -1
  227. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  228. package/dist-cjs/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  229. package/dist-cjs/tree/Tree.js +2 -6
  230. package/dist-cjs/tree/Tree.js.map +1 -1
  231. package/dist-cjs/tree/TreeNode.js.map +1 -1
  232. package/dist-cjs/tree/use-tree-keyboard-navigation.js.map +1 -1
  233. package/dist-cjs/tree/useTree.js.map +1 -1
  234. package/dist-cjs/utils/useClickOutside.js.map +1 -1
  235. package/dist-cjs/utils/useSlideSelection.js.map +1 -1
  236. package/dist-cjs/window/ElectronWindow.js.map +1 -1
  237. package/dist-es/breadcrumbs/internal/BreadcrumbsContext.js.map +1 -1
  238. package/dist-es/button-bar/ButtonBar.js.map +1 -1
  239. package/dist-es/button-bar/OrderedButton.js.map +1 -1
  240. package/dist-es/button-bar/internal/useDescendant.js.map +1 -1
  241. package/dist-es/calendar/Calendar.js +24 -9
  242. package/dist-es/calendar/Calendar.js.map +1 -1
  243. package/dist-es/calendar/CalendarGrid.js +59 -83
  244. package/dist-es/calendar/CalendarGrid.js.map +1 -1
  245. package/dist-es/calendar/CalendarMonthHeader.css.js +4 -0
  246. package/dist-es/calendar/CalendarMonthHeader.css.js.map +1 -0
  247. package/dist-es/calendar/CalendarMonthHeader.js +46 -0
  248. package/dist-es/calendar/CalendarMonthHeader.js.map +1 -0
  249. package/dist-es/calendar/CalendarNavigation.js +30 -39
  250. package/dist-es/calendar/CalendarNavigation.js.map +1 -1
  251. package/dist-es/calendar/CalendarWeekHeader.js +2 -6
  252. package/dist-es/calendar/CalendarWeekHeader.js.map +1 -1
  253. package/dist-es/calendar/internal/CalendarContext.js +3 -1
  254. package/dist-es/calendar/internal/CalendarContext.js.map +1 -1
  255. package/dist-es/calendar/internal/CalendarDay.css.js +1 -1
  256. package/dist-es/calendar/internal/CalendarDay.js +90 -78
  257. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  258. package/dist-es/calendar/internal/CalendarMonth.js +13 -23
  259. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  260. package/dist-es/calendar/internal/useFocusManagement.js +5 -6
  261. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  262. package/dist-es/calendar/internal/utils.js +8 -12
  263. package/dist-es/calendar/internal/utils.js.map +1 -1
  264. package/dist-es/calendar/useCalendar.js +72 -112
  265. package/dist-es/calendar/useCalendar.js.map +1 -1
  266. package/dist-es/calendar/useCalendarDay.js +21 -18
  267. package/dist-es/calendar/useCalendarDay.js.map +1 -1
  268. package/dist-es/calendar/useCalendarSelection.js +146 -34
  269. package/dist-es/calendar/useCalendarSelection.js.map +1 -1
  270. package/dist-es/carousel/CarouselContext.js.map +1 -1
  271. package/dist-es/carousel/CarouselControls.js.map +1 -1
  272. package/dist-es/carousel/CarouselReducer.js.map +1 -1
  273. package/dist-es/carousel/CarouselSlide.js.map +1 -1
  274. package/dist-es/carousel/CarouselSlider.js.map +1 -1
  275. package/dist-es/cascading-menu/CascadingMenu.js.map +1 -1
  276. package/dist-es/cascading-menu/CascadingMenuItem.js.map +1 -1
  277. package/dist-es/cascading-menu/CascadingMenuList.js.map +1 -1
  278. package/dist-es/cascading-menu/internal/keydownHandlers.js.map +1 -1
  279. package/dist-es/cascading-menu/internal/useClickAway.js.map +1 -1
  280. package/dist-es/cascading-menu/internal/useMenuTriggerHandlers.js.map +1 -1
  281. package/dist-es/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  282. package/dist-es/cascading-menu/internal/useStateReducer.js.map +1 -1
  283. package/dist-es/cascading-menu/stateChangeTypes.js +0 -1
  284. package/dist-es/cascading-menu/stateChangeTypes.js.map +1 -1
  285. package/dist-es/color-chooser/Color.js.map +1 -1
  286. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  287. package/dist-es/color-chooser/ColorHelpers.js.map +1 -1
  288. package/dist-es/color-chooser/ColorPicker.js.map +1 -1
  289. package/dist-es/color-chooser/DictTabs.js.map +1 -1
  290. package/dist-es/color-chooser/HexInput.js.map +1 -1
  291. package/dist-es/color-chooser/Swatch.js.map +1 -1
  292. package/dist-es/color-chooser/Swatches.js.map +1 -1
  293. package/dist-es/color-chooser/SwatchesPicker.js.map +1 -1
  294. package/dist-es/combo-box/ComboBox.js +0 -2
  295. package/dist-es/combo-box/ComboBox.js.map +1 -1
  296. package/dist-es/combo-box/useCombobox.js.map +1 -1
  297. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js +1 -5
  298. package/dist-es/combo-box-deprecated/internal/DefaultComboBox.js.map +1 -1
  299. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js +1 -5
  300. package/dist-es/combo-box-deprecated/internal/MultiSelectComboBox.js.map +1 -1
  301. package/dist-es/combo-box-deprecated/internal/useComboBox.js +1 -1
  302. package/dist-es/combo-box-deprecated/internal/useComboBox.js.map +1 -1
  303. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js +1 -1
  304. package/dist-es/combo-box-deprecated/internal/useMultiSelectComboBox.js.map +1 -1
  305. package/dist-es/combo-box-deprecated/internal/usePopperStatus.js.map +1 -1
  306. package/dist-es/common-hooks/calcPreferredHeight.js.map +1 -1
  307. package/dist-es/common-hooks/collectionProvider.js +1 -1
  308. package/dist-es/common-hooks/collectionProvider.js.map +1 -1
  309. package/dist-es/common-hooks/list-dom-utils.js.map +1 -1
  310. package/dist-es/common-hooks/selectionTypes.js.map +1 -1
  311. package/dist-es/common-hooks/useCollapsibleGroups.js.map +1 -1
  312. package/dist-es/common-hooks/useCollectionItems.js +1 -1
  313. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  314. package/dist-es/common-hooks/useImperativeScrollingAPI.js.map +1 -1
  315. package/dist-es/common-hooks/useKeyboardNavigation.js +1 -1
  316. package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
  317. package/dist-es/common-hooks/useKeyboardNavigationPanel.js.map +1 -1
  318. package/dist-es/common-hooks/useSelection.js.map +1 -1
  319. package/dist-es/common-hooks/useTypeahead.js +1 -1
  320. package/dist-es/common-hooks/useTypeahead.js.map +1 -1
  321. package/dist-es/common-hooks/useViewportTracking.js.map +1 -1
  322. package/dist-es/common-hooks/utils/collection-item-utils.js.map +1 -1
  323. package/dist-es/contact-details/ContactPrimaryInfo.js.map +1 -1
  324. package/dist-es/contact-details/ContactSecondaryInfo.js.map +1 -1
  325. package/dist-es/contact-details/ContactTertiaryInfo.js.map +1 -1
  326. package/dist-es/contact-details/internal/ContactDetailsContext.js.map +1 -1
  327. package/dist-es/content-status/internal/StatusIndicator.js.map +1 -1
  328. package/dist-es/date-input/DateInputRange.js +61 -51
  329. package/dist-es/date-input/DateInputRange.js.map +1 -1
  330. package/dist-es/date-input/DateInputSingle.js +34 -19
  331. package/dist-es/date-input/DateInputSingle.js.map +1 -1
  332. package/dist-es/date-picker/DatePicker.js +9 -1
  333. package/dist-es/date-picker/DatePicker.js.map +1 -1
  334. package/dist-es/date-picker/DatePickerActions.js.map +1 -1
  335. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  336. package/dist-es/date-picker/DatePickerHelperText.css.js +4 -0
  337. package/dist-es/date-picker/DatePickerHelperText.css.js.map +1 -0
  338. package/dist-es/date-picker/DatePickerHelperText.js +34 -0
  339. package/dist-es/date-picker/DatePickerHelperText.js.map +1 -0
  340. package/dist-es/date-picker/DatePickerOverlay.js.map +1 -1
  341. package/dist-es/date-picker/DatePickerOverlayProvider.js +41 -17
  342. package/dist-es/date-picker/DatePickerOverlayProvider.js.map +1 -1
  343. package/dist-es/date-picker/DatePickerPanel.css.js +1 -1
  344. package/dist-es/date-picker/DatePickerRangeGridPanel.js +245 -0
  345. package/dist-es/date-picker/DatePickerRangeGridPanel.js.map +1 -0
  346. package/dist-es/date-picker/DatePickerRangeInput.js +39 -7
  347. package/dist-es/date-picker/DatePickerRangeInput.js.map +1 -1
  348. package/dist-es/date-picker/DatePickerRangePanel.js +190 -34
  349. package/dist-es/date-picker/DatePickerRangePanel.js.map +1 -1
  350. package/dist-es/date-picker/DatePickerSingleGridPanel.js +253 -0
  351. package/dist-es/date-picker/DatePickerSingleGridPanel.js.map +1 -0
  352. package/dist-es/date-picker/DatePickerSingleInput.js +13 -5
  353. package/dist-es/date-picker/DatePickerSingleInput.js.map +1 -1
  354. package/dist-es/date-picker/DatePickerSinglePanel.js +8 -107
  355. package/dist-es/date-picker/DatePickerSinglePanel.js.map +1 -1
  356. package/dist-es/date-picker/DatePickerTrigger.js.map +1 -1
  357. package/dist-es/date-picker/useDatePicker.js +71 -11
  358. package/dist-es/date-picker/useDatePicker.js.map +1 -1
  359. package/dist-es/date-picker/useFocusOut.js +41 -0
  360. package/dist-es/date-picker/useFocusOut.js.map +1 -0
  361. package/dist-es/date-picker/useKeyboard.js +4 -5
  362. package/dist-es/date-picker/useKeyboard.js.map +1 -1
  363. package/dist-es/deck-item/DeckItem.js.map +1 -1
  364. package/dist-es/deck-layout/DeckLayout.js.map +1 -1
  365. package/dist-es/dropdown/Dropdown.js +0 -1
  366. package/dist-es/dropdown/Dropdown.js.map +1 -1
  367. package/dist-es/dropdown/DropdownBase.js +1 -2
  368. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  369. package/dist-es/dropdown/DropdownButton.js.map +1 -1
  370. package/dist-es/dropdown/useClickAway.js.map +1 -1
  371. package/dist-es/dropdown/useDropdown.js.map +1 -1
  372. package/dist-es/dropdown/useDropdownBase.js.map +1 -1
  373. package/dist-es/editable-label/EditableLabel.js.map +1 -1
  374. package/dist-es/form-field-legacy/FormFieldLegacy.js.map +1 -1
  375. package/dist-es/form-field-legacy/StatusIndicator.js +1 -1
  376. package/dist-es/form-field-legacy/StatusIndicator.js.map +1 -1
  377. package/dist-es/formatted-input/FormattedInput.js +1 -1
  378. package/dist-es/formatted-input/FormattedInput.js.map +1 -1
  379. package/dist-es/index.js +4 -7
  380. package/dist-es/index.js.map +1 -1
  381. package/dist-es/input-legacy/InputLegacy.js.map +1 -1
  382. package/dist-es/input-legacy/useCursorOnFocus.js.map +1 -1
  383. package/dist-es/list/Highlighter.js.map +1 -1
  384. package/dist-es/list/List.js.map +1 -1
  385. package/dist-es/list/ListItem.js.map +1 -1
  386. package/dist-es/list/VirtualizedList.js.map +1 -1
  387. package/dist-es/list/useList.js +0 -1
  388. package/dist-es/list/useList.js.map +1 -1
  389. package/dist-es/list/useListHeight.js.map +1 -1
  390. package/dist-es/list-deprecated/ListBase.js +1 -3
  391. package/dist-es/list-deprecated/ListBase.js.map +1 -1
  392. package/dist-es/list-deprecated/ListItem.js.map +1 -1
  393. package/dist-es/list-deprecated/ListItemBase.js.map +1 -1
  394. package/dist-es/list-deprecated/ListItemContext.js.map +1 -1
  395. package/dist-es/list-deprecated/internal/DescendantContext.js.map +1 -1
  396. package/dist-es/list-deprecated/internal/calcPreferredListHeight.js.map +1 -1
  397. package/dist-es/list-deprecated/internal/useWidth.js.map +1 -1
  398. package/dist-es/list-deprecated/useList.js.map +1 -1
  399. package/dist-es/list-deprecated/useListItem.js.map +1 -1
  400. package/dist-es/list-deprecated/useTypeSelect.js.map +1 -1
  401. package/dist-es/list-next/ListItemNext.js.map +1 -1
  402. package/dist-es/list-next/ListNext.js.map +1 -1
  403. package/dist-es/list-next/ListNextContext.js.map +1 -1
  404. package/dist-es/list-next/useList.js.map +1 -1
  405. package/dist-es/localization-provider/LocalizationProvider.js +6 -3
  406. package/dist-es/localization-provider/LocalizationProvider.js.map +1 -1
  407. package/dist-es/menu-button/MenuButton.js.map +1 -1
  408. package/dist-es/metric/MetricContent.js +2 -2
  409. package/dist-es/metric/MetricContent.js.map +1 -1
  410. package/dist-es/number-input/NumberInput.js +1 -1
  411. package/dist-es/number-input/NumberInput.js.map +1 -1
  412. package/dist-es/number-input/useNumberInput.js.map +1 -1
  413. package/dist-es/query-input/internal/CategoryListContext.js.map +1 -1
  414. package/dist-es/query-input/internal/CategoryListItem.js.map +1 -1
  415. package/dist-es/query-input/internal/usePopperStatus.js +2 -2
  416. package/dist-es/query-input/internal/usePopperStatus.js.map +1 -1
  417. package/dist-es/query-input/useQueryInput.js +0 -1
  418. package/dist-es/query-input/useQueryInput.js.map +1 -1
  419. package/dist-es/responsive/OverflowReducer.js +1 -3
  420. package/dist-es/responsive/OverflowReducer.js.map +1 -1
  421. package/dist-es/responsive/useDynamicCollapse.js.map +1 -1
  422. package/dist-es/responsive/useInstantCollapse.js.map +1 -1
  423. package/dist-es/responsive/useOverflow.js +1 -1
  424. package/dist-es/responsive/useOverflow.js.map +1 -1
  425. package/dist-es/responsive/useOverflowCollectionItems.js.map +1 -1
  426. package/dist-es/responsive/useOverflowLayout.js +0 -3
  427. package/dist-es/responsive/useOverflowLayout.js.map +1 -1
  428. package/dist-es/responsive/useReclaimSpace.js.map +1 -1
  429. package/dist-es/responsive/useResizeObserver.js.map +1 -1
  430. package/dist-es/responsive/useWidth.js.map +1 -1
  431. package/dist-es/responsive/utils.js.map +1 -1
  432. package/dist-es/search-input/SearchInput.js.map +1 -1
  433. package/dist-es/tabs/Tab.js.map +1 -1
  434. package/dist-es/tabs/Tabs.js.map +1 -1
  435. package/dist-es/tabs/Tabstrip.js +0 -1
  436. package/dist-es/tabs/Tabstrip.js.map +1 -1
  437. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js +1 -1
  438. package/dist-es/tabs/drag-drop/useDragDropNaturalMovement.js.map +1 -1
  439. package/dist-es/tabs/drag-drop/useDragSpacers.js.map +1 -1
  440. package/dist-es/tabs/useEditableItem.js.map +1 -1
  441. package/dist-es/tabs/useKeyboardNavigation.js +1 -1
  442. package/dist-es/tabs/useKeyboardNavigation.js.map +1 -1
  443. package/dist-es/tabs/useSelection.js.map +1 -1
  444. package/dist-es/tabs/useTabs.js.map +1 -1
  445. package/dist-es/tabs/useTabstrip.js.map +1 -1
  446. package/dist-es/tabs-next/TabListNext.js.map +1 -1
  447. package/dist-es/tabs-next/TabNext.js.map +1 -1
  448. package/dist-es/tabs-next/TabNextAction.js.map +1 -1
  449. package/dist-es/tabs-next/TabNextContext.js.map +1 -1
  450. package/dist-es/tabs-next/TabNextPanel.js.map +1 -1
  451. package/dist-es/tabs-next/TabNextTrigger.js.map +1 -1
  452. package/dist-es/tabs-next/TabOverflowList.js.map +1 -1
  453. package/dist-es/tabs-next/TabsNext.js.map +1 -1
  454. package/dist-es/tabs-next/TabsNextContext.js.map +1 -1
  455. package/dist-es/tabs-next/hooks/useCollection.js +2 -2
  456. package/dist-es/tabs-next/hooks/useCollection.js.map +1 -1
  457. package/dist-es/tabs-next/hooks/useFocusOutside.js.map +1 -1
  458. package/dist-es/tabs-next/hooks/useOverflow.js.map +1 -1
  459. package/dist-es/tabs-next/hooks/useRestoreActiveTab.js.map +1 -1
  460. package/dist-es/tokenized-input/TokenizedInputBase.js.map +1 -1
  461. package/dist-es/tokenized-input/internal/InputPill.js.map +1 -1
  462. package/dist-es/tokenized-input/internal/getCursorPosition.js.map +1 -1
  463. package/dist-es/tokenized-input/internal/useResizeObserver.js.map +1 -1
  464. package/dist-es/tokenized-input/useTokenizedInput.js.map +1 -1
  465. package/dist-es/tokenized-input-next/TokenizedInputNext.js.map +1 -1
  466. package/dist-es/tokenized-input-next/internal/InputPill.js.map +1 -1
  467. package/dist-es/tokenized-input-next/internal/useResizeObserver.js.map +1 -1
  468. package/dist-es/tokenized-input-next/useTokenizedInputNext.js +1 -1
  469. package/dist-es/tokenized-input-next/useTokenizedInputNext.js.map +1 -1
  470. package/dist-es/toolbar/Tooltray.js.map +1 -1
  471. package/dist-es/toolbar/internal/renderToolbarItems.js.map +1 -1
  472. package/dist-es/toolbar/internal/renderTrayTools.js.map +1 -1
  473. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  474. package/dist-es/toolbar/toolbar-field/useToolbarField.js.map +1 -1
  475. package/dist-es/tree/Tree.js +2 -6
  476. package/dist-es/tree/Tree.js.map +1 -1
  477. package/dist-es/tree/TreeNode.js.map +1 -1
  478. package/dist-es/tree/use-tree-keyboard-navigation.js.map +1 -1
  479. package/dist-es/tree/useTree.js.map +1 -1
  480. package/dist-es/utils/useClickOutside.js.map +1 -1
  481. package/dist-es/utils/useSlideSelection.js.map +1 -1
  482. package/dist-es/window/ElectronWindow.js +1 -1
  483. package/dist-es/window/ElectronWindow.js.map +1 -1
  484. package/dist-types/calendar/Calendar.d.ts +22 -3
  485. package/dist-types/calendar/CalendarGrid.d.ts +19 -3
  486. package/dist-types/calendar/CalendarMonthHeader.d.ts +18 -0
  487. package/dist-types/calendar/CalendarNavigation.d.ts +9 -0
  488. package/dist-types/calendar/index.d.ts +1 -0
  489. package/dist-types/calendar/internal/CalendarDay.d.ts +25 -6
  490. package/dist-types/calendar/internal/CalendarMonth.d.ts +2 -6
  491. package/dist-types/calendar/internal/utils.d.ts +3 -7
  492. package/dist-types/calendar/useCalendar.d.ts +34 -30
  493. package/dist-types/calendar/useCalendarDay.d.ts +3 -2
  494. package/dist-types/calendar/useCalendarSelection.d.ts +60 -8
  495. package/dist-types/date-input/DateInputRange.d.ts +12 -8
  496. package/dist-types/date-input/DateInputSingle.d.ts +12 -8
  497. package/dist-types/date-picker/DatePicker.d.ts +14 -6
  498. package/dist-types/date-picker/DatePickerContext.d.ts +29 -1
  499. package/dist-types/date-picker/DatePickerHelperText.d.ts +4 -0
  500. package/dist-types/date-picker/DatePickerOverlayProvider.d.ts +9 -2
  501. package/dist-types/date-picker/DatePickerRangeGridPanel.d.ts +17 -0
  502. package/dist-types/date-picker/DatePickerRangeInput.d.ts +1 -0
  503. package/dist-types/date-picker/DatePickerRangePanel.d.ts +24 -20
  504. package/dist-types/date-picker/DatePickerSingleGridPanel.d.ts +65 -0
  505. package/dist-types/date-picker/DatePickerSingleInput.d.ts +1 -0
  506. package/dist-types/date-picker/DatePickerSinglePanel.d.ts +6 -48
  507. package/dist-types/date-picker/index.d.ts +4 -1
  508. package/dist-types/date-picker/useDatePicker.d.ts +29 -9
  509. package/dist-types/date-picker/useFocusOut.d.ts +9 -0
  510. package/dist-types/date-picker/useKeyboard.d.ts +7 -1
  511. package/dist-types/index.d.ts +0 -2
  512. package/package.json +3 -4
  513. package/dist-cjs/calendar/CalendarGrid.css.js +0 -6
  514. package/dist-cjs/calendar/CalendarGrid.css.js.map +0 -1
  515. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js +0 -8
  516. package/dist-cjs/combo-box-deprecated/internal/getAnnouncement.js.map +0 -1
  517. package/dist-cjs/splitter/SplitHandle.css.js +0 -6
  518. package/dist-cjs/splitter/SplitHandle.css.js.map +0 -1
  519. package/dist-cjs/splitter/SplitHandle.js +0 -60
  520. package/dist-cjs/splitter/SplitHandle.js.map +0 -1
  521. package/dist-cjs/splitter/SplitPanel.css.js +0 -6
  522. package/dist-cjs/splitter/SplitPanel.css.js.map +0 -1
  523. package/dist-cjs/splitter/SplitPanel.js +0 -37
  524. package/dist-cjs/splitter/SplitPanel.js.map +0 -1
  525. package/dist-cjs/splitter/Splitter.js +0 -31
  526. package/dist-cjs/splitter/Splitter.js.map +0 -1
  527. package/dist-cjs/splitter/utils.js +0 -18
  528. package/dist-cjs/splitter/utils.js.map +0 -1
  529. package/dist-cjs/stepped-tracker/Step.Connector.css.js +0 -6
  530. package/dist-cjs/stepped-tracker/Step.Connector.css.js.map +0 -1
  531. package/dist-cjs/stepped-tracker/Step.Connector.js +0 -21
  532. package/dist-cjs/stepped-tracker/Step.Connector.js.map +0 -1
  533. package/dist-cjs/stepped-tracker/Step.Description.css.js +0 -6
  534. package/dist-cjs/stepped-tracker/Step.Description.css.js.map +0 -1
  535. package/dist-cjs/stepped-tracker/Step.Description.js +0 -35
  536. package/dist-cjs/stepped-tracker/Step.Description.js.map +0 -1
  537. package/dist-cjs/stepped-tracker/Step.ExpandTrigger.css.js +0 -6
  538. package/dist-cjs/stepped-tracker/Step.ExpandTrigger.css.js.map +0 -1
  539. package/dist-cjs/stepped-tracker/Step.ExpandTrigger.js +0 -38
  540. package/dist-cjs/stepped-tracker/Step.ExpandTrigger.js.map +0 -1
  541. package/dist-cjs/stepped-tracker/Step.Icon.css.js +0 -6
  542. package/dist-cjs/stepped-tracker/Step.Icon.css.js.map +0 -1
  543. package/dist-cjs/stepped-tracker/Step.Icon.js +0 -57
  544. package/dist-cjs/stepped-tracker/Step.Icon.js.map +0 -1
  545. package/dist-cjs/stepped-tracker/Step.Label.css.js +0 -6
  546. package/dist-cjs/stepped-tracker/Step.Label.css.js.map +0 -1
  547. package/dist-cjs/stepped-tracker/Step.Label.js +0 -37
  548. package/dist-cjs/stepped-tracker/Step.Label.js.map +0 -1
  549. package/dist-cjs/stepped-tracker/Step.SROnly.css.js +0 -6
  550. package/dist-cjs/stepped-tracker/Step.SROnly.css.js.map +0 -1
  551. package/dist-cjs/stepped-tracker/Step.SROnly.js +0 -21
  552. package/dist-cjs/stepped-tracker/Step.SROnly.js.map +0 -1
  553. package/dist-cjs/stepped-tracker/Step.css.js +0 -6
  554. package/dist-cjs/stepped-tracker/Step.css.js.map +0 -1
  555. package/dist-cjs/stepped-tracker/Step.js +0 -161
  556. package/dist-cjs/stepped-tracker/Step.js.map +0 -1
  557. package/dist-cjs/stepped-tracker/SteppedTracker.Provider.js +0 -19
  558. package/dist-cjs/stepped-tracker/SteppedTracker.Provider.js.map +0 -1
  559. package/dist-cjs/stepped-tracker/SteppedTracker.css.js +0 -6
  560. package/dist-cjs/stepped-tracker/SteppedTracker.css.js.map +0 -1
  561. package/dist-cjs/stepped-tracker/SteppedTracker.js +0 -36
  562. package/dist-cjs/stepped-tracker/SteppedTracker.js.map +0 -1
  563. package/dist-cjs/stepped-tracker/stepReducer.js +0 -155
  564. package/dist-cjs/stepped-tracker/stepReducer.js.map +0 -1
  565. package/dist-cjs/stepped-tracker/useStepReducer.js +0 -18
  566. package/dist-cjs/stepped-tracker/useStepReducer.js.map +0 -1
  567. package/dist-cjs/stepped-tracker/utils.js +0 -121
  568. package/dist-cjs/stepped-tracker/utils.js.map +0 -1
  569. package/dist-es/calendar/CalendarGrid.css.js +0 -4
  570. package/dist-es/calendar/CalendarGrid.css.js.map +0 -1
  571. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js +0 -6
  572. package/dist-es/combo-box-deprecated/internal/getAnnouncement.js.map +0 -1
  573. package/dist-es/splitter/SplitHandle.css.js +0 -4
  574. package/dist-es/splitter/SplitHandle.css.js.map +0 -1
  575. package/dist-es/splitter/SplitHandle.js +0 -58
  576. package/dist-es/splitter/SplitHandle.js.map +0 -1
  577. package/dist-es/splitter/SplitPanel.css.js +0 -4
  578. package/dist-es/splitter/SplitPanel.css.js.map +0 -1
  579. package/dist-es/splitter/SplitPanel.js +0 -35
  580. package/dist-es/splitter/SplitPanel.js.map +0 -1
  581. package/dist-es/splitter/Splitter.js +0 -27
  582. package/dist-es/splitter/Splitter.js.map +0 -1
  583. package/dist-es/splitter/utils.js +0 -15
  584. package/dist-es/splitter/utils.js.map +0 -1
  585. package/dist-es/stepped-tracker/Step.Connector.css.js +0 -4
  586. package/dist-es/stepped-tracker/Step.Connector.css.js.map +0 -1
  587. package/dist-es/stepped-tracker/Step.Connector.js +0 -19
  588. package/dist-es/stepped-tracker/Step.Connector.js.map +0 -1
  589. package/dist-es/stepped-tracker/Step.Description.css.js +0 -4
  590. package/dist-es/stepped-tracker/Step.Description.css.js.map +0 -1
  591. package/dist-es/stepped-tracker/Step.Description.js +0 -33
  592. package/dist-es/stepped-tracker/Step.Description.js.map +0 -1
  593. package/dist-es/stepped-tracker/Step.ExpandTrigger.css.js +0 -4
  594. package/dist-es/stepped-tracker/Step.ExpandTrigger.css.js.map +0 -1
  595. package/dist-es/stepped-tracker/Step.ExpandTrigger.js +0 -36
  596. package/dist-es/stepped-tracker/Step.ExpandTrigger.js.map +0 -1
  597. package/dist-es/stepped-tracker/Step.Icon.css.js +0 -4
  598. package/dist-es/stepped-tracker/Step.Icon.css.js.map +0 -1
  599. package/dist-es/stepped-tracker/Step.Icon.js +0 -55
  600. package/dist-es/stepped-tracker/Step.Icon.js.map +0 -1
  601. package/dist-es/stepped-tracker/Step.Label.css.js +0 -4
  602. package/dist-es/stepped-tracker/Step.Label.css.js.map +0 -1
  603. package/dist-es/stepped-tracker/Step.Label.js +0 -35
  604. package/dist-es/stepped-tracker/Step.Label.js.map +0 -1
  605. package/dist-es/stepped-tracker/Step.SROnly.css.js +0 -4
  606. package/dist-es/stepped-tracker/Step.SROnly.css.js.map +0 -1
  607. package/dist-es/stepped-tracker/Step.SROnly.js +0 -19
  608. package/dist-es/stepped-tracker/Step.SROnly.js.map +0 -1
  609. package/dist-es/stepped-tracker/Step.css.js +0 -4
  610. package/dist-es/stepped-tracker/Step.css.js.map +0 -1
  611. package/dist-es/stepped-tracker/Step.js +0 -159
  612. package/dist-es/stepped-tracker/Step.js.map +0 -1
  613. package/dist-es/stepped-tracker/SteppedTracker.Provider.js +0 -15
  614. package/dist-es/stepped-tracker/SteppedTracker.Provider.js.map +0 -1
  615. package/dist-es/stepped-tracker/SteppedTracker.css.js +0 -4
  616. package/dist-es/stepped-tracker/SteppedTracker.css.js.map +0 -1
  617. package/dist-es/stepped-tracker/SteppedTracker.js +0 -34
  618. package/dist-es/stepped-tracker/SteppedTracker.js.map +0 -1
  619. package/dist-es/stepped-tracker/stepReducer.js +0 -153
  620. package/dist-es/stepped-tracker/stepReducer.js.map +0 -1
  621. package/dist-es/stepped-tracker/useStepReducer.js +0 -16
  622. package/dist-es/stepped-tracker/useStepReducer.js.map +0 -1
  623. package/dist-es/stepped-tracker/utils.js +0 -114
  624. package/dist-es/stepped-tracker/utils.js.map +0 -1
  625. package/dist-types/splitter/SplitHandle.d.ts +0 -21
  626. package/dist-types/splitter/SplitPanel.d.ts +0 -10
  627. package/dist-types/splitter/Splitter.d.ts +0 -22
  628. package/dist-types/splitter/index.d.ts +0 -4
  629. package/dist-types/splitter/utils.d.ts +0 -4
  630. package/dist-types/stepped-tracker/Step.Connector.d.ts +0 -1
  631. package/dist-types/stepped-tracker/Step.Description.d.ts +0 -4
  632. package/dist-types/stepped-tracker/Step.ExpandTrigger.d.ts +0 -5
  633. package/dist-types/stepped-tracker/Step.Icon.d.ts +0 -8
  634. package/dist-types/stepped-tracker/Step.Label.d.ts +0 -4
  635. package/dist-types/stepped-tracker/Step.SROnly.d.ts +0 -5
  636. package/dist-types/stepped-tracker/Step.d.ts +0 -2
  637. package/dist-types/stepped-tracker/Step.types.d.ts +0 -19
  638. package/dist-types/stepped-tracker/SteppedTracker.Provider.d.ts +0 -9
  639. package/dist-types/stepped-tracker/SteppedTracker.d.ts +0 -2
  640. package/dist-types/stepped-tracker/SteppedTracker.types.d.ts +0 -6
  641. package/dist-types/stepped-tracker/index.d.ts +0 -6
  642. package/dist-types/stepped-tracker/stepReducer.d.ts +0 -2
  643. package/dist-types/stepped-tracker/stepReducer.types.d.ts +0 -27
  644. package/dist-types/stepped-tracker/useStepReducer.d.ts +0 -3
  645. package/dist-types/stepped-tracker/utils.d.ts +0 -10
@@ -1 +1 @@
1
- {"version":3,"file":"ButtonBar.js","sources":["../src/button-bar/ButtonBar.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n Children,\n type HTMLAttributes,\n type ReactNode,\n forwardRef,\n useMemo,\n} from \"react\";\n\nimport { type ButtonVariant, makePrefixer } from \"@salt-ds/core\";\nimport { ButtonBarContext } from \"./internal/ButtonBarContext\";\nimport { DescendantProvider } from \"./internal/DescendantContext\";\nimport { useDescendants } from \"./internal/useDescendants\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport buttonBarCss from \"./ButtonBar.css\";\n\nexport type PartialRecord<K extends keyof any, T> = Partial<Record<K, T>>;\n\ntype ButtonBarOrderKey = \"order\" | \"alignLeftOrder\" | \"stackOrder\";\nexport type ButtonBarSortOrder = \"asc\" | \"desc\";\n\nexport const DefaultButtonsOrderByVariant: Record<\n ButtonVariant,\n Record<ButtonBarOrderKey, number>\n> = {\n cta: {\n order: 0,\n alignLeftOrder: 1,\n stackOrder: 2,\n },\n primary: {\n order: 1,\n alignLeftOrder: 2,\n stackOrder: 1,\n },\n secondary: {\n order: 2,\n alignLeftOrder: 0,\n stackOrder: 0,\n },\n};\n\ntype OrderedButtonData = { variant?: ButtonVariant } & PartialRecord<\n ButtonBarOrderKey,\n number\n>;\n\nfunction getPriorityForButton(\n item: OrderedButtonData,\n field: ButtonBarOrderKey,\n) {\n const variant = item?.variant || \"primary\";\n return item?.[field] ?? DefaultButtonsOrderByVariant[variant][field];\n}\nconst createComparatorForField = (\n field: ButtonBarOrderKey,\n sort: ButtonBarSortOrder,\n alignLeft: boolean,\n childrenData: Array<OrderedButtonData>,\n) => {\n let equalityResult: number;\n if (field === \"order\" || field === \"stackOrder\") {\n equalityResult = sort === \"asc\" ? 1 : 0;\n } else {\n equalityResult = alignLeft ? 1 : -1;\n }\n\n function createDescComparator(indexA: number, indexB: number) {\n const priorityA = getPriorityForButton(childrenData[indexA], field);\n const priorityB = getPriorityForButton(childrenData[indexB], field);\n if (priorityA == null && priorityB == null) {\n return 0;\n }\n if (priorityA == null) {\n return 1;\n }\n if (priorityB == null) {\n return -1;\n }\n if (priorityA === priorityB) {\n return equalityResult;\n }\n return priorityB - priorityA;\n }\n\n function createAscComparator(indexA: number, indexB: number) {\n return createDescComparator(indexA, indexB) * -1;\n }\n\n return sort === \"asc\" ? createAscComparator : createDescComparator;\n};\n\nfunction alignSecondaryChild(\n orderedChildrenData: Array<OrderedButtonData & { index: number }>,\n sortOrder: ButtonBarSortOrder,\n alignLeft: boolean,\n): { index?: number; align?: \"left\" | \"right\" } {\n const noSecondaryChildren = { index: undefined, align: undefined };\n if (sortOrder === \"asc\" || alignLeft) {\n const firstSecondaryChildIndex = orderedChildrenData.findIndex(\n (childData) => childData.variant === \"secondary\",\n );\n\n if (firstSecondaryChildIndex !== -1) {\n const originalChildIndex =\n orderedChildrenData[firstSecondaryChildIndex].index;\n return { index: originalChildIndex, align: \"right\" };\n }\n return noSecondaryChildren;\n }\n let index = orderedChildrenData.length;\n while (index--) {\n if (orderedChildrenData[index].variant === \"secondary\") {\n return { index: orderedChildrenData[index].index, align: \"left\" };\n }\n }\n return noSecondaryChildren;\n}\n\nexport interface ButtonBarProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * By default ButtonBar lays buttons from right to left horizontally ordering action buttons by order prop.\n * Use this prop to lay button from left to right instead.\n * Actions buttons will be ordered by alignLeftOrder prop.\n */\n alignLeft?: boolean;\n /**\n * A list of OrderButtons. Required to have some children.\n */\n children: ReactNode;\n /**\n * The className(s) of the component\n */\n className?: string;\n /**\n * By default ButtonBar aligns secondary buttons to the left while displayed horizontally\n * and to the right while aligned left or sorting ascending.\n * Use this prop to disable this behavior.\n */\n disableAutoAlignment?: boolean;\n /**\n * By default ButtonBar sorts buttons in descending order.\n * Use this prop to change that when the button bar is NOT stacked and aligned left.\n */\n sortAlignLeft?: ButtonBarSortOrder;\n /**\n * By default ButtonBar sorts buttons in descending order.\n * Use this prop to change that when the button bar is NOT stacked and NOT aligned left.\n */\n sortOrder?: ButtonBarSortOrder;\n /**\n * By default ButtonBar sorts buttons in descending order.\n * Use this prop to change that when the button bar is stacked.\n */\n sortStackOrder?: ButtonBarSortOrder;\n /**\n * When the viewport is equal to or smaller than the breakpoint the buttons will be stacked vertically.\n * Alternatively pass a screen width number in pixels.\n * Use `0` to disable this feature. Defaults to 'xs'.\n * Actions buttons will be ordered by stackOrder prop.\n */\n stackAtBreakpoint?: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | number;\n}\n\nconst withBaseName = makePrefixer(\"saltButtonBar\");\n\nexport const ButtonBar = forwardRef<HTMLDivElement, ButtonBarProps>(\n function ButtonBar(\n {\n alignLeft = false,\n children: childrenProp,\n className,\n disableAutoAlignment,\n sortAlignLeft = \"desc\",\n sortOrder = \"desc\",\n sortStackOrder = \"desc\",\n stackAtBreakpoint = \"xs\",\n ...rest\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-button-bar\",\n css: buttonBarCss,\n window: targetWindow,\n });\n\n const [childrenData, setChildrenData] = useDescendants<OrderedButtonData>();\n // TODO: we need a mechanism to work with breakpoints.\n const matches = false;\n\n const childrenArray = Children.toArray(childrenProp);\n const childrenIndexes = childrenArray.map((_, index) => index);\n const stackOrderComparator = createComparatorForField(\n \"stackOrder\",\n sortStackOrder,\n alignLeft,\n childrenData,\n );\n const orderComparator = createComparatorForField(\n \"order\",\n sortOrder,\n alignLeft,\n childrenData,\n );\n const alignLeftComparator = createComparatorForField(\n \"alignLeftOrder\",\n sortAlignLeft,\n alignLeft,\n childrenData,\n );\n\n let orderedChildrenIndexes: number[];\n\n if (childrenData.length !== childrenIndexes.length) {\n orderedChildrenIndexes = childrenIndexes;\n } else {\n orderedChildrenIndexes = matches\n ? childrenIndexes.sort(stackOrderComparator)\n : childrenIndexes.sort(\n alignLeft ? alignLeftComparator : orderComparator,\n );\n }\n\n let secondaryChildAlignment: { index?: number; align?: \"left\" | \"right\" } =\n {\n index: undefined,\n align: undefined,\n };\n if (!disableAutoAlignment) {\n secondaryChildAlignment = alignSecondaryChild(\n orderedChildrenIndexes.map((index) => ({\n index,\n ...childrenData[index],\n })),\n sortOrder,\n alignLeft,\n );\n }\n\n const hasSecondaryButtons = childrenData.some(\n (buttonData) => buttonData.variant === \"secondary\",\n );\n\n const orderedChildren = orderedChildrenIndexes.map(\n (index) => childrenArray[index],\n );\n\n const buttonBarContextValue = useMemo(\n () => ({\n matches,\n alignedIndex: secondaryChildAlignment.index,\n align: secondaryChildAlignment.align,\n }),\n [matches, secondaryChildAlignment.align, secondaryChildAlignment.index],\n );\n\n return (\n <ButtonBarContext.Provider value={buttonBarContextValue}>\n <DescendantProvider items={childrenData} setItems={setChildrenData}>\n <div\n aria-label=\"button bar\"\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"stacked\")]: matches,\n [withBaseName(\"alignLeft\")]: alignLeft,\n [withBaseName(\"autoAligning\")]:\n hasSecondaryButtons && !disableAutoAlignment,\n },\n className,\n )}\n ref={ref}\n role=\"region\"\n {...rest}\n >\n {orderedChildren}\n </div>\n </DescendantProvider>\n </ButtonBarContext.Provider>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","ButtonBar","useWindow","useComponentCssInjection","buttonBarCss","useDescendants","Children","useMemo","jsx","ButtonBarContext","DescendantProvider","clsx"],"mappings":"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"}
1
+ {"version":3,"file":"ButtonBar.js","sources":["../src/button-bar/ButtonBar.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n Children,\n type HTMLAttributes,\n type ReactNode,\n forwardRef,\n useMemo,\n} from \"react\";\n\nimport { type ButtonVariant, makePrefixer } from \"@salt-ds/core\";\nimport { ButtonBarContext } from \"./internal/ButtonBarContext\";\nimport { DescendantProvider } from \"./internal/DescendantContext\";\nimport { useDescendants } from \"./internal/useDescendants\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport buttonBarCss from \"./ButtonBar.css\";\n\nexport type PartialRecord<K extends keyof any, T> = Partial<Record<K, T>>;\n\ntype ButtonBarOrderKey = \"order\" | \"alignLeftOrder\" | \"stackOrder\";\nexport type ButtonBarSortOrder = \"asc\" | \"desc\";\n\nexport const DefaultButtonsOrderByVariant: Record<\n ButtonVariant,\n Record<ButtonBarOrderKey, number>\n> = {\n cta: {\n order: 0,\n alignLeftOrder: 1,\n stackOrder: 2,\n },\n primary: {\n order: 1,\n alignLeftOrder: 2,\n stackOrder: 1,\n },\n secondary: {\n order: 2,\n alignLeftOrder: 0,\n stackOrder: 0,\n },\n};\n\ntype OrderedButtonData = { variant?: ButtonVariant } & PartialRecord<\n ButtonBarOrderKey,\n number\n>;\n\nfunction getPriorityForButton(\n item: OrderedButtonData,\n field: ButtonBarOrderKey,\n) {\n const variant = item?.variant || \"primary\";\n return item?.[field] ?? DefaultButtonsOrderByVariant[variant][field];\n}\nconst createComparatorForField = (\n field: ButtonBarOrderKey,\n sort: ButtonBarSortOrder,\n alignLeft: boolean,\n childrenData: Array<OrderedButtonData>,\n) => {\n let equalityResult: number;\n if (field === \"order\" || field === \"stackOrder\") {\n equalityResult = sort === \"asc\" ? 1 : 0;\n } else {\n equalityResult = alignLeft ? 1 : -1;\n }\n\n function createDescComparator(indexA: number, indexB: number) {\n const priorityA = getPriorityForButton(childrenData[indexA], field);\n const priorityB = getPriorityForButton(childrenData[indexB], field);\n if (priorityA == null && priorityB == null) {\n return 0;\n }\n if (priorityA == null) {\n return 1;\n }\n if (priorityB == null) {\n return -1;\n }\n if (priorityA === priorityB) {\n return equalityResult;\n }\n return priorityB - priorityA;\n }\n\n function createAscComparator(indexA: number, indexB: number) {\n return createDescComparator(indexA, indexB) * -1;\n }\n\n return sort === \"asc\" ? createAscComparator : createDescComparator;\n};\n\nfunction alignSecondaryChild(\n orderedChildrenData: Array<OrderedButtonData & { index: number }>,\n sortOrder: ButtonBarSortOrder,\n alignLeft: boolean,\n): { index?: number; align?: \"left\" | \"right\" } {\n const noSecondaryChildren = { index: undefined, align: undefined };\n if (sortOrder === \"asc\" || alignLeft) {\n const firstSecondaryChildIndex = orderedChildrenData.findIndex(\n (childData) => childData.variant === \"secondary\",\n );\n\n if (firstSecondaryChildIndex !== -1) {\n const originalChildIndex =\n orderedChildrenData[firstSecondaryChildIndex].index;\n return { index: originalChildIndex, align: \"right\" };\n }\n return noSecondaryChildren;\n }\n let index = orderedChildrenData.length;\n while (index--) {\n if (orderedChildrenData[index].variant === \"secondary\") {\n return { index: orderedChildrenData[index].index, align: \"left\" };\n }\n }\n return noSecondaryChildren;\n}\n\nexport interface ButtonBarProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * By default ButtonBar lays buttons from right to left horizontally ordering action buttons by order prop.\n * Use this prop to lay button from left to right instead.\n * Actions buttons will be ordered by alignLeftOrder prop.\n */\n alignLeft?: boolean;\n /**\n * A list of OrderButtons. Required to have some children.\n */\n children: ReactNode;\n /**\n * The className(s) of the component\n */\n className?: string;\n /**\n * By default ButtonBar aligns secondary buttons to the left while displayed horizontally\n * and to the right while aligned left or sorting ascending.\n * Use this prop to disable this behavior.\n */\n disableAutoAlignment?: boolean;\n /**\n * By default ButtonBar sorts buttons in descending order.\n * Use this prop to change that when the button bar is NOT stacked and aligned left.\n */\n sortAlignLeft?: ButtonBarSortOrder;\n /**\n * By default ButtonBar sorts buttons in descending order.\n * Use this prop to change that when the button bar is NOT stacked and NOT aligned left.\n */\n sortOrder?: ButtonBarSortOrder;\n /**\n * By default ButtonBar sorts buttons in descending order.\n * Use this prop to change that when the button bar is stacked.\n */\n sortStackOrder?: ButtonBarSortOrder;\n /**\n * When the viewport is equal to or smaller than the breakpoint the buttons will be stacked vertically.\n * Alternatively pass a screen width number in pixels.\n * Use `0` to disable this feature. Defaults to 'xs'.\n * Actions buttons will be ordered by stackOrder prop.\n */\n stackAtBreakpoint?: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | number;\n}\n\nconst withBaseName = makePrefixer(\"saltButtonBar\");\n\nexport const ButtonBar = forwardRef<HTMLDivElement, ButtonBarProps>(\n function ButtonBar(\n {\n alignLeft = false,\n children: childrenProp,\n className,\n disableAutoAlignment,\n sortAlignLeft = \"desc\",\n sortOrder = \"desc\",\n sortStackOrder = \"desc\",\n stackAtBreakpoint = \"xs\",\n ...rest\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-button-bar\",\n css: buttonBarCss,\n window: targetWindow,\n });\n\n const [childrenData, setChildrenData] = useDescendants<OrderedButtonData>();\n // TODO: we need a mechanism to work with breakpoints.\n const matches = false;\n\n const childrenArray = Children.toArray(childrenProp);\n const childrenIndexes = childrenArray.map((_, index) => index);\n const stackOrderComparator = createComparatorForField(\n \"stackOrder\",\n sortStackOrder,\n alignLeft,\n childrenData,\n );\n const orderComparator = createComparatorForField(\n \"order\",\n sortOrder,\n alignLeft,\n childrenData,\n );\n const alignLeftComparator = createComparatorForField(\n \"alignLeftOrder\",\n sortAlignLeft,\n alignLeft,\n childrenData,\n );\n\n let orderedChildrenIndexes: number[];\n\n if (childrenData.length !== childrenIndexes.length) {\n orderedChildrenIndexes = childrenIndexes;\n } else {\n orderedChildrenIndexes = matches\n ? childrenIndexes.sort(stackOrderComparator)\n : childrenIndexes.sort(\n alignLeft ? alignLeftComparator : orderComparator,\n );\n }\n\n let secondaryChildAlignment: { index?: number; align?: \"left\" | \"right\" } =\n {\n index: undefined,\n align: undefined,\n };\n if (!disableAutoAlignment) {\n secondaryChildAlignment = alignSecondaryChild(\n orderedChildrenIndexes.map((index) => ({\n index,\n ...childrenData[index],\n })),\n sortOrder,\n alignLeft,\n );\n }\n\n const hasSecondaryButtons = childrenData.some(\n (buttonData) => buttonData.variant === \"secondary\",\n );\n\n const orderedChildren = orderedChildrenIndexes.map(\n (index) => childrenArray[index],\n );\n\n const buttonBarContextValue = useMemo(\n () => ({\n matches,\n alignedIndex: secondaryChildAlignment.index,\n align: secondaryChildAlignment.align,\n }),\n [matches, secondaryChildAlignment.align, secondaryChildAlignment.index],\n );\n\n return (\n <ButtonBarContext.Provider value={buttonBarContextValue}>\n <DescendantProvider items={childrenData} setItems={setChildrenData}>\n <div\n aria-label=\"button bar\"\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"stacked\")]: matches,\n [withBaseName(\"alignLeft\")]: alignLeft,\n [withBaseName(\"autoAligning\")]:\n hasSecondaryButtons && !disableAutoAlignment,\n },\n className,\n )}\n ref={ref}\n role=\"region\"\n {...rest}\n >\n {orderedChildren}\n </div>\n </DescendantProvider>\n </ButtonBarContext.Provider>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","ButtonBar","useWindow","useComponentCssInjection","buttonBarCss","useDescendants","Children","useMemo","jsx","ButtonBarContext","DescendantProvider","clsx"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"OrderedButton.js","sources":["../src/button-bar/OrderedButton.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { forwardRef, useContext } from \"react\";\n\nimport {\n Button,\n type ButtonProps,\n capitalize,\n makePrefixer,\n} from \"@salt-ds/core\";\nimport { ButtonBarContext } from \"./internal/ButtonBarContext\";\nimport { useDescendant } from \"./internal/useDescendant\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport orderedButtonCss from \"./OrderedButton.css\";\n\nexport interface OrderedButtonProps extends ButtonProps {\n /**\n * Aligns the button (and any buttons before/after) it on the left/right\n * of the container\n */\n align?: \"left\" | \"right\";\n /**\n * The order the button will be rendered when NOT stacked and the button bar is aligned left order.\n * Buttons are ordered in descending order by default and then by their source order.\n * This defaults to 1 for `CTA`, 2 for `regular` and 0 for `secondary`\n */\n alignLeftOrder?: number;\n /**\n * The className(s) of the component\n */\n className?: string;\n /**\n * The order the button will be rendered when NOT stacked. Buttons are ordered\n * in descending order by default and then by their source order.\n * This defaults to 0 for `CTA`, 1 for `regular` and 2 for `secondary`\n */\n order?: number;\n /**\n * The order the button will be rendered when stacked. Buttons are ordered\n * in descending order by default and then by their source order.\n * This defaults to 2 for `CTA`, 1 for `regular` and 0 for `secondary`\n */\n stackOrder?: number;\n}\n\nconst withBasename = makePrefixer(\"saltOrderedButton\");\n\nexport const OrderedButton = forwardRef<HTMLButtonElement, OrderedButtonProps>(\n function OrderedButton(\n {\n className,\n align: alignProp,\n order,\n alignLeftOrder,\n stackOrder,\n variant,\n ...restProps\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-ordered-button\",\n css: orderedButtonCss,\n window: targetWindow,\n });\n\n const index = useDescendant({ order, stackOrder, alignLeftOrder, variant });\n const {\n matches,\n align: alignContext,\n alignedIndex,\n } = useContext(ButtonBarContext);\n\n const alignFromParent = index === alignedIndex ? alignContext : undefined;\n const align = alignProp || alignFromParent;\n\n return (\n <Button\n className={clsx(\n withBasename(),\n {\n [withBasename(`align${align ? capitalize(align) : \"\"}`)]:\n align && !matches,\n [withBasename(\"stacked\")]: matches,\n },\n className,\n )}\n ref={ref}\n variant={variant}\n {...restProps}\n />\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","OrderedButton","useWindow","useComponentCssInjection","orderedButtonCss","useDescendant","useContext","ButtonBarContext","jsx","Button","clsx","capitalize"],"mappings":";;;;;;;;;;;;AA+CA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cACP,CAAA;AAAA,IACE,SAAA;AAAA,IACA,KAAO,EAAA,SAAA;AAAA,IACP,KAAA;AAAA,IACA,cAAA;AAAA,IACA,UAAA;AAAA,IACA,OAAA;AAAA,IACA,GAAG;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,QAAQC,2BAAc,CAAA,EAAE,OAAO,UAAY,EAAA,cAAA,EAAgB,SAAS,CAAA;AAC1E,IAAM,MAAA;AAAA,MACJ,OAAA;AAAA,MACA,KAAO,EAAA,YAAA;AAAA,MACP;AAAA,KACF,GAAIC,iBAAWC,iCAAgB,CAAA;AAE/B,IAAM,MAAA,eAAA,GAAkB,KAAU,KAAA,YAAA,GAAe,YAAe,GAAA,KAAA,CAAA;AAChE,IAAA,MAAM,QAAQ,SAAa,IAAA,eAAA;AAE3B,IACE,uBAAAC,cAAA;AAAA,MAACC,WAAA;AAAA,MAAA;AAAA,QACC,SAAW,EAAAC,SAAA;AAAA,UACT,YAAa,EAAA;AAAA,UACb;AAAA,YACE,CAAC,YAAA,CAAa,CAAQ,KAAA,EAAA,KAAA,GAAQC,eAAW,CAAA,KAAK,CAAI,GAAA,EAAE,CAAE,CAAA,CAAC,GACrD,KAAA,IAAS,CAAC,OAAA;AAAA,YACZ,CAAC,YAAA,CAAa,SAAS,CAAC,GAAG;AAAA,WAC7B;AAAA,UACA;AAAA,SACF;AAAA,QACA,GAAA;AAAA,QACA,OAAA;AAAA,QACC,GAAG;AAAA;AAAA,KACN;AAAA;AAGN;;;;"}
1
+ {"version":3,"file":"OrderedButton.js","sources":["../src/button-bar/OrderedButton.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport { forwardRef, useContext } from \"react\";\n\nimport {\n Button,\n type ButtonProps,\n capitalize,\n makePrefixer,\n} from \"@salt-ds/core\";\nimport { ButtonBarContext } from \"./internal/ButtonBarContext\";\nimport { useDescendant } from \"./internal/useDescendant\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport orderedButtonCss from \"./OrderedButton.css\";\n\nexport interface OrderedButtonProps extends ButtonProps {\n /**\n * Aligns the button (and any buttons before/after) it on the left/right\n * of the container\n */\n align?: \"left\" | \"right\";\n /**\n * The order the button will be rendered when NOT stacked and the button bar is aligned left order.\n * Buttons are ordered in descending order by default and then by their source order.\n * This defaults to 1 for `CTA`, 2 for `regular` and 0 for `secondary`\n */\n alignLeftOrder?: number;\n /**\n * The className(s) of the component\n */\n className?: string;\n /**\n * The order the button will be rendered when NOT stacked. Buttons are ordered\n * in descending order by default and then by their source order.\n * This defaults to 0 for `CTA`, 1 for `regular` and 2 for `secondary`\n */\n order?: number;\n /**\n * The order the button will be rendered when stacked. Buttons are ordered\n * in descending order by default and then by their source order.\n * This defaults to 2 for `CTA`, 1 for `regular` and 0 for `secondary`\n */\n stackOrder?: number;\n}\n\nconst withBasename = makePrefixer(\"saltOrderedButton\");\n\nexport const OrderedButton = forwardRef<HTMLButtonElement, OrderedButtonProps>(\n function OrderedButton(\n {\n className,\n align: alignProp,\n order,\n alignLeftOrder,\n stackOrder,\n variant,\n ...restProps\n },\n ref,\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-ordered-button\",\n css: orderedButtonCss,\n window: targetWindow,\n });\n\n const index = useDescendant({ order, stackOrder, alignLeftOrder, variant });\n const {\n matches,\n align: alignContext,\n alignedIndex,\n } = useContext(ButtonBarContext);\n\n const alignFromParent = index === alignedIndex ? alignContext : undefined;\n const align = alignProp || alignFromParent;\n\n return (\n <Button\n className={clsx(\n withBasename(),\n {\n [withBasename(`align${align ? capitalize(align) : \"\"}`)]:\n align && !matches,\n [withBasename(\"stacked\")]: matches,\n },\n className,\n )}\n ref={ref}\n variant={variant}\n {...restProps}\n />\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","OrderedButton","useWindow","useComponentCssInjection","orderedButtonCss","useDescendant","useContext","ButtonBarContext","jsx","Button","clsx","capitalize"],"mappings":";;;;;;;;;;;;AA+CA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cACP,CAAA;AAAA,IACE,SAAA;AAAA,IACA,KAAO,EAAA,SAAA;AAAA,IACP,KAAA;AAAA,IACA,cAAA;AAAA,IACA,UAAA;AAAA,IACA,OAAA;AAAA,IACA,GAAG;AAAA,KAEL,GACA,EAAA;AACA,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,QAAQC,2BAAc,CAAA,EAAE,OAAO,UAAY,EAAA,cAAA,EAAgB,SAAS,CAAA;AAC1E,IAAM,MAAA;AAAA,MACJ,OAAA;AAAA,MACA,KAAO,EAAA,YAAA;AAAA,MACP;AAAA,KACF,GAAIC,iBAAWC,iCAAgB,CAAA;AAE/B,IAAM,MAAA,eAAA,GAAkB,KAAU,KAAA,YAAA,GAAe,YAAe,GAAA,MAAA;AAChE,IAAA,MAAM,QAAQ,SAAa,IAAA,eAAA;AAE3B,IACE,uBAAAC,cAAA;AAAA,MAACC,WAAA;AAAA,MAAA;AAAA,QACC,SAAW,EAAAC,SAAA;AAAA,UACT,YAAa,EAAA;AAAA,UACb;AAAA,YACE,CAAC,YAAA,CAAa,CAAQ,KAAA,EAAA,KAAA,GAAQC,eAAW,CAAA,KAAK,CAAI,GAAA,EAAE,CAAE,CAAA,CAAC,GACrD,KAAA,IAAS,CAAC,OAAA;AAAA,YACZ,CAAC,YAAA,CAAa,SAAS,CAAC,GAAG;AAAA,WAC7B;AAAA,UACA;AAAA,SACF;AAAA,QACA,GAAA;AAAA,QACA,OAAA;AAAA,QACC,GAAG;AAAA;AAAA,KACN;AAAA;AAGN;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDescendant.js","sources":["../src/button-bar/internal/useDescendant.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\n// Copied from https://gist.github.com/ryanflorence/10e9387f633f9d2e6f444a9bddaabf6e\nimport { useContext, useRef } from \"react\";\n\nimport { DescendantContext } from \"./DescendantContext\";\n\nexport function useDescendant(descendant: Record<string, any>): number {\n const { assigning, setItems } = useContext(DescendantContext);\n const index = useRef(-1);\n\n useIsomorphicLayoutEffect(() => {\n if (assigning?.current && setItems) {\n setItems((old) => {\n index.current = old.length;\n return old.concat(descendant);\n });\n }\n });\n\n // first render its wrong, after a forceUpdate in parent useIsomorphicLayoutEffect it's\n // right, and its all synchronous so we don't get any flashing\n return index.current;\n}\n"],"names":["useContext","DescendantContext","useRef","useIsomorphicLayoutEffect"],"mappings":";;;;;;AAMO,SAAS,cAAc,UAAyC,EAAA;AACrE,EAAA,MAAM,EAAE,SAAA,EAAW,QAAS,EAAA,GAAIA,iBAAWC,mCAAiB,CAAA;AAC5D,EAAM,MAAA,KAAA,GAAQC,aAAO,CAAE,CAAA,CAAA;AAEvB,EAAAC,8BAAA,CAA0B,MAAM;AAC9B,IAAI,IAAA,CAAA,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAW,YAAW,QAAU,EAAA;AAClC,MAAA,QAAA,CAAS,CAAC,GAAQ,KAAA;AAChB,QAAA,KAAA,CAAM,UAAU,GAAI,CAAA,MAAA;AACpB,QAAO,OAAA,GAAA,CAAI,OAAO,UAAU,CAAA;AAAA,OAC7B,CAAA;AAAA;AACH,GACD,CAAA;AAID,EAAA,OAAO,KAAM,CAAA,OAAA;AACf;;;;"}
1
+ {"version":3,"file":"useDescendant.js","sources":["../src/button-bar/internal/useDescendant.ts"],"sourcesContent":["import { useIsomorphicLayoutEffect } from \"@salt-ds/core\";\n// Copied from https://gist.github.com/ryanflorence/10e9387f633f9d2e6f444a9bddaabf6e\nimport { useContext, useRef } from \"react\";\n\nimport { DescendantContext } from \"./DescendantContext\";\n\nexport function useDescendant(descendant: Record<string, any>): number {\n const { assigning, setItems } = useContext(DescendantContext);\n const index = useRef(-1);\n\n useIsomorphicLayoutEffect(() => {\n if (assigning?.current && setItems) {\n setItems((old) => {\n index.current = old.length;\n return old.concat(descendant);\n });\n }\n });\n\n // first render its wrong, after a forceUpdate in parent useIsomorphicLayoutEffect it's\n // right, and its all synchronous so we don't get any flashing\n return index.current;\n}\n"],"names":["useContext","DescendantContext","useRef","useIsomorphicLayoutEffect"],"mappings":";;;;;;AAMO,SAAS,cAAc,UAAyC,EAAA;AACrE,EAAA,MAAM,EAAE,SAAA,EAAW,QAAS,EAAA,GAAIA,iBAAWC,mCAAiB,CAAA;AAC5D,EAAM,MAAA,KAAA,GAAQC,aAAO,EAAE,CAAA;AAEvB,EAAAC,8BAAA,CAA0B,MAAM;AAC9B,IAAI,IAAA,CAAA,SAAA,IAAA,IAAA,GAAA,MAAA,GAAA,SAAA,CAAW,YAAW,QAAU,EAAA;AAClC,MAAA,QAAA,CAAS,CAAC,GAAQ,KAAA;AAChB,QAAA,KAAA,CAAM,UAAU,GAAI,CAAA,MAAA;AACpB,QAAO,OAAA,GAAA,CAAI,OAAO,UAAU,CAAA;AAAA,OAC7B,CAAA;AAAA;AACH,GACD,CAAA;AAID,EAAA,OAAO,KAAM,CAAA,OAAA;AACf;;;;"}
@@ -28,20 +28,34 @@ const Calendar = react.forwardRef(
28
28
  defaultSelectedDate,
29
29
  visibleMonth: visibleMonthProp,
30
30
  defaultVisibleMonth,
31
+ onFocusedDateChange,
31
32
  onSelectionChange,
32
33
  onVisibleMonthChange,
33
34
  hideOutOfRangeDates,
35
+ focusedDate,
36
+ focusedDateRef,
34
37
  isDayUnselectable,
35
38
  isDayHighlighted,
36
39
  isDayDisabled,
37
- locale,
38
40
  minDate,
39
41
  maxDate,
42
+ numberOfVisibleMonths = 1,
40
43
  selectionVariant,
41
44
  onHoveredDateChange,
42
45
  hoveredDate,
46
+ timezone: timezoneProp,
43
47
  ...propsRest
44
48
  } = props;
49
+ let timezone = "default";
50
+ if (timezoneProp) {
51
+ timezone = timezoneProp;
52
+ } else if (selectionVariant === "range") {
53
+ const defaultRangeTimezoneDate = (selectedDate == null ? void 0 : selectedDate.startDate) ?? (selectedDate == null ? void 0 : selectedDate.endDate) ?? (defaultSelectedDate == null ? void 0 : defaultSelectedDate.startDate) ?? (defaultSelectedDate == null ? void 0 : defaultSelectedDate.endDate);
54
+ timezone = defaultRangeTimezoneDate ? dateAdapter.getTimezone(defaultRangeTimezoneDate) : "default";
55
+ } else if (selectionVariant === "single") {
56
+ const defaultSingleTimezoneDate = selectedDate ?? defaultSelectedDate;
57
+ timezone = defaultSingleTimezoneDate ? dateAdapter.getTimezone(defaultSingleTimezoneDate) : "default";
58
+ }
45
59
  let startDateOffset;
46
60
  let endDateOffset;
47
61
  let rest;
@@ -50,6 +64,7 @@ const Calendar = react.forwardRef(
50
64
  } else {
51
65
  rest = propsRest;
52
66
  }
67
+ const defaultFocusedDateRef = react.useRef(null);
53
68
  const useCalendarProps = {
54
69
  selectedDate,
55
70
  defaultSelectedDate,
@@ -57,25 +72,25 @@ const Calendar = react.forwardRef(
57
72
  defaultVisibleMonth,
58
73
  onSelectionChange,
59
74
  onVisibleMonthChange,
75
+ focusedDate,
76
+ focusedDateRef: focusedDateRef !== void 0 ? focusedDateRef : defaultFocusedDateRef,
60
77
  isDayUnselectable,
61
78
  isDayHighlighted,
62
79
  isDayDisabled,
63
- locale,
64
80
  minDate,
65
81
  maxDate,
82
+ numberOfVisibleMonths,
66
83
  selectionVariant,
84
+ onFocusedDateChange,
67
85
  onHoveredDateChange,
68
86
  hideOutOfRangeDates,
69
87
  hoveredDate,
70
88
  startDateOffset,
71
- endDateOffset
89
+ endDateOffset,
90
+ timezone
72
91
  };
73
92
  const { state, helpers } = useCalendar.useCalendar(useCalendarProps);
74
- const calendarLabel = dateAdapter.format(
75
- state.visibleMonth,
76
- "MMMM YYYY",
77
- locale
78
- );
93
+ const calendarLabel = dateAdapter.format(state.visibleMonth, "MMMM YYYY");
79
94
  return /* @__PURE__ */ jsxRuntime.jsx(
80
95
  CalendarContext.CalendarContext.Provider,
81
96
  {
@@ -1 +1 @@
1
- {"version":3,"file":"Calendar.js","sources":["../src/calendar/Calendar.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type ReactNode,\n forwardRef,\n} from \"react\";\nimport { CalendarContext } from \"./internal/CalendarContext\";\nimport {\n type UseCalendarMultiSelectProps,\n type UseCalendarOffsetProps,\n type UseCalendarRangeProps,\n type UseCalendarSingleProps,\n useCalendar,\n} from \"./useCalendar\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport type { DateFrameworkType } from \"@salt-ds/date-adapters\";\nimport { useLocalization } from \"../localization-provider\";\nimport calendarCss from \"./Calendar.css\";\n\n/**\n * Base props for the Calendar component.\n */\nexport interface CalendarBaseProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * The content to be rendered inside the Calendar.\n */\n children: ReactNode;\n /**\n * If `true`, hides dates that are out of the selectable range.\n */\n hideOutOfRangeDates?: boolean;\n /**\n * Locale for date formatting\n */\n locale?: any;\n}\n\n/**\n * Props for the Calendar component with single date selection.\n */\nexport interface CalendarSingleProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarSingleProps<TDate> {\n /**\n * The selection variant, set to \"single\".\n */\n selectionVariant: \"single\";\n}\n\n/**\n * Props for the Calendar component with date range selection.\n */\nexport interface CalendarRangeProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarRangeProps<TDate> {\n /**\n * The selection variant, set to \"range\".\n */\n selectionVariant: \"range\";\n}\n\n/**\n * Props for the Calendar component with multi-select date selection.\n */\nexport interface CalendarMultiSelectProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarMultiSelectProps<TDate> {\n /**\n * The selection variant, set to \"multiselect\".\n */\n selectionVariant: \"multiselect\";\n}\n\n/**\n * Props for the Calendar component with offset date selection.\n */\nexport interface CalendarOffsetProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarOffsetProps<TDate> {\n /**\n * The selection variant, set to \"offset\".\n */\n selectionVariant: \"offset\";\n}\n\n/**\n * Type representing the props for the Calendar component with various selection variants.\n */\nexport type CalendarProps<TDate extends DateFrameworkType> =\n | CalendarSingleProps<TDate>\n | CalendarRangeProps<TDate>\n | CalendarMultiSelectProps<TDate>\n | CalendarOffsetProps<TDate>;\n\nconst withBaseName = makePrefixer(\"saltCalendar\");\n\nexport const Calendar = forwardRef<HTMLDivElement, CalendarProps<any>>(\n <TDate extends DateFrameworkType>(\n props: CalendarProps<TDate>,\n ref: React.Ref<HTMLDivElement>,\n ) => {\n const targetWindow = useWindow();\n const { dateAdapter } = useLocalization<TDate>();\n useComponentCssInjection({\n testId: \"salt-calendar\",\n css: calendarCss,\n window: targetWindow,\n });\n const {\n children,\n className,\n selectedDate,\n defaultSelectedDate,\n visibleMonth: visibleMonthProp,\n defaultVisibleMonth,\n onSelectionChange,\n onVisibleMonthChange,\n hideOutOfRangeDates,\n isDayUnselectable,\n isDayHighlighted,\n isDayDisabled,\n locale,\n minDate,\n maxDate,\n selectionVariant,\n onHoveredDateChange,\n hoveredDate,\n ...propsRest\n } = props;\n let startDateOffset: CalendarOffsetProps<TDate>[\"startDateOffset\"];\n let endDateOffset: CalendarOffsetProps<TDate>[\"startDateOffset\"];\n let rest: Partial<typeof props>;\n if (selectionVariant === \"offset\") {\n ({ startDateOffset, endDateOffset, ...rest } =\n propsRest as CalendarOffsetProps<TDate>);\n } else {\n rest = propsRest;\n }\n // biome-ignore lint/suspicious/noExplicitAny: type guard\n const useCalendarProps: any = {\n selectedDate,\n defaultSelectedDate,\n visibleMonth: visibleMonthProp,\n defaultVisibleMonth,\n onSelectionChange,\n onVisibleMonthChange,\n isDayUnselectable,\n isDayHighlighted,\n isDayDisabled,\n locale,\n minDate,\n maxDate,\n selectionVariant,\n onHoveredDateChange,\n hideOutOfRangeDates,\n hoveredDate,\n startDateOffset,\n endDateOffset,\n };\n const { state, helpers } = useCalendar<TDate>(useCalendarProps);\n const calendarLabel = dateAdapter.format(\n state.visibleMonth,\n \"MMMM YYYY\",\n locale,\n );\n\n return (\n <CalendarContext.Provider\n value={{\n state,\n helpers,\n }}\n >\n <div\n className={clsx(withBaseName(), className)}\n role=\"application\"\n aria-label={calendarLabel}\n ref={ref}\n {...rest}\n >\n {children}\n </div>\n </CalendarContext.Provider>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","useWindow","useLocalization","useComponentCssInjection","calendarCss","useCalendar","jsx","CalendarContext","clsx"],"mappings":";;;;;;;;;;;;;AAkGA,MAAM,YAAA,GAAeA,kBAAa,cAAc,CAAA;AAEzC,MAAM,QAAW,GAAAC,gBAAA;AAAA,EACtB,CACE,OACA,GACG,KAAA;AACH,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAM,MAAA,EAAE,WAAY,EAAA,GAAIC,oCAAuB,EAAA;AAC/C,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,eAAA;AAAA,MACR,GAAK,EAAAC,UAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AACD,IAAM,MAAA;AAAA,MACJ,QAAA;AAAA,MACA,SAAA;AAAA,MACA,YAAA;AAAA,MACA,mBAAA;AAAA,MACA,YAAc,EAAA,gBAAA;AAAA,MACd,mBAAA;AAAA,MACA,iBAAA;AAAA,MACA,oBAAA;AAAA,MACA,mBAAA;AAAA,MACA,iBAAA;AAAA,MACA,gBAAA;AAAA,MACA,aAAA;AAAA,MACA,MAAA;AAAA,MACA,OAAA;AAAA,MACA,OAAA;AAAA,MACA,gBAAA;AAAA,MACA,mBAAA;AAAA,MACA,WAAA;AAAA,MACA,GAAG;AAAA,KACD,GAAA,KAAA;AACJ,IAAI,IAAA,eAAA;AACJ,IAAI,IAAA,aAAA;AACJ,IAAI,IAAA,IAAA;AACJ,IAAA,IAAI,qBAAqB,QAAU,EAAA;AACjC,MAAA,CAAC,EAAE,eAAA,EAAiB,aAAe,EAAA,GAAG,MACpC,GAAA,SAAA;AAAA,KACG,MAAA;AACL,MAAO,IAAA,GAAA,SAAA;AAAA;AAGT,IAAA,MAAM,gBAAwB,GAAA;AAAA,MAC5B,YAAA;AAAA,MACA,mBAAA;AAAA,MACA,YAAc,EAAA,gBAAA;AAAA,MACd,mBAAA;AAAA,MACA,iBAAA;AAAA,MACA,oBAAA;AAAA,MACA,iBAAA;AAAA,MACA,gBAAA;AAAA,MACA,aAAA;AAAA,MACA,MAAA;AAAA,MACA,OAAA;AAAA,MACA,OAAA;AAAA,MACA,gBAAA;AAAA,MACA,mBAAA;AAAA,MACA,mBAAA;AAAA,MACA,WAAA;AAAA,MACA,eAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,MAAM,EAAE,KAAA,EAAO,OAAQ,EAAA,GAAIC,wBAAmB,gBAAgB,CAAA;AAC9D,IAAA,MAAM,gBAAgB,WAAY,CAAA,MAAA;AAAA,MAChC,KAAM,CAAA,YAAA;AAAA,MACN,WAAA;AAAA,MACA;AAAA,KACF;AAEA,IACE,uBAAAC,cAAA;AAAA,MAACC,+BAAgB,CAAA,QAAA;AAAA,MAAhB;AAAA,QACC,KAAO,EAAA;AAAA,UACL,KAAA;AAAA,UACA;AAAA,SACF;AAAA,QAEA,QAAA,kBAAAD,cAAA;AAAA,UAAC,KAAA;AAAA,UAAA;AAAA,YACC,SAAW,EAAAE,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,YACzC,IAAK,EAAA,aAAA;AAAA,YACL,YAAY,EAAA,aAAA;AAAA,YACZ,GAAA;AAAA,YACC,GAAG,IAAA;AAAA,YAEH;AAAA;AAAA;AACH;AAAA,KACF;AAAA;AAGN;;;;"}
1
+ {"version":3,"file":"Calendar.js","sources":["../src/calendar/Calendar.tsx"],"sourcesContent":["import { type ResponsiveProp, makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithoutRef,\n type ReactNode,\n forwardRef,\n useRef,\n} from \"react\";\nimport { CalendarContext } from \"./internal/CalendarContext\";\nimport {\n type UseCalendarMultiSelectProps,\n type UseCalendarOffsetProps,\n type UseCalendarRangeProps,\n type UseCalendarSingleProps,\n useCalendar,\n} from \"./useCalendar\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport type { DateFrameworkType, Timezone } from \"@salt-ds/date-adapters\";\nimport { useLocalization } from \"../localization-provider\";\nimport calendarCss from \"./Calendar.css\";\n\n/**\n * Base props for the Calendar component.\n */\nexport interface CalendarBaseProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * The content to be rendered inside the Calendar.\n */\n children: ReactNode;\n /**\n * If `true`, hides dates that are out of the selectable range.\n */\n hideOutOfRangeDates?: boolean;\n /**\n * Ref to attach to the focused element,enabling focus to be controlled.\n */\n focusedDateRef?: React.MutableRefObject<HTMLElement | null>;\n /**\n * Number of visible months, maximum 12, defaults to 1\n */\n numberOfVisibleMonths?: ResponsiveProp<\n 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12\n >;\n /**\n * Specifies the timezone behavior:\n * - If undefined, the timezone will be derived from the passed date, or from `defaultSelectedDate`/`selectedDate`.\n * - If set to \"default\", the default timezone of the date library will be used.\n * - If set to \"system\", the local system's timezone will be applied.\n * - If set to \"UTC\", the time will be returned in UTC.\n * - If set to a valid IANA timezone identifier, the time will be returned for that specific timezone.\n */\n timezone?: Timezone;\n}\n\n/**\n * Props for the Calendar component with single date selection.\n * @template TDate - The type of the date object.\n */\nexport interface CalendarSingleProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarSingleProps<TDate> {\n /**\n * The selection variant, set to \"single\".\n */\n selectionVariant: \"single\";\n}\n\n/**\n * Props for the Calendar component with date range selection.\n * @template TDate - The type of the date object.\n */\nexport interface CalendarRangeProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarRangeProps<TDate> {\n /**\n * The selection variant, set to \"range\".\n */\n selectionVariant: \"range\";\n}\n\n/**\n * Props for the Calendar component with multi-select date selection.\n * @template TDate - The type of the date object.\n */\nexport interface CalendarMultiSelectProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarMultiSelectProps<TDate> {\n /**\n * The selection variant, set to \"multiselect\".\n */\n selectionVariant: \"multiselect\";\n}\n\n/**\n * Props for the Calendar component with offset date selection.\n * @template TDate - The type of the date object.\n */\nexport interface CalendarOffsetProps<TDate extends DateFrameworkType>\n extends CalendarBaseProps,\n UseCalendarOffsetProps<TDate> {\n /**\n * The selection variant, set to \"offset\".\n */\n selectionVariant: \"offset\";\n}\n\n/**\n * Type representing the props for the Calendar component with various selection variants.\n * @template TDate - The type of the date object.\n */\nexport type CalendarProps<TDate extends DateFrameworkType> =\n | CalendarSingleProps<TDate>\n | CalendarRangeProps<TDate>\n | CalendarMultiSelectProps<TDate>\n | CalendarOffsetProps<TDate>;\n\nconst withBaseName = makePrefixer(\"saltCalendar\");\n\nexport const Calendar = forwardRef<\n HTMLDivElement,\n CalendarProps<DateFrameworkType>\n>(\n <TDate extends DateFrameworkType>(\n props: CalendarProps<TDate>,\n ref: React.Ref<HTMLDivElement>,\n ) => {\n const targetWindow = useWindow();\n const { dateAdapter } = useLocalization<TDate>();\n useComponentCssInjection({\n testId: \"salt-calendar\",\n css: calendarCss,\n window: targetWindow,\n });\n const {\n children,\n className,\n selectedDate,\n defaultSelectedDate,\n visibleMonth: visibleMonthProp,\n defaultVisibleMonth,\n onFocusedDateChange,\n onSelectionChange,\n onVisibleMonthChange,\n hideOutOfRangeDates,\n focusedDate,\n focusedDateRef,\n isDayUnselectable,\n isDayHighlighted,\n isDayDisabled,\n minDate,\n maxDate,\n numberOfVisibleMonths = 1,\n selectionVariant,\n onHoveredDateChange,\n hoveredDate,\n timezone: timezoneProp,\n ...propsRest\n } = props;\n\n let timezone: Timezone = \"default\";\n if (timezoneProp) {\n timezone = timezoneProp;\n } else if (selectionVariant === \"range\") {\n const defaultRangeTimezoneDate =\n selectedDate?.startDate ??\n selectedDate?.endDate ??\n defaultSelectedDate?.startDate ??\n defaultSelectedDate?.endDate;\n timezone = defaultRangeTimezoneDate\n ? dateAdapter.getTimezone(defaultRangeTimezoneDate)\n : \"default\";\n } else if (selectionVariant === \"single\") {\n const defaultSingleTimezoneDate = selectedDate ?? defaultSelectedDate;\n timezone = defaultSingleTimezoneDate\n ? dateAdapter.getTimezone(defaultSingleTimezoneDate)\n : \"default\";\n }\n\n let startDateOffset: CalendarOffsetProps<TDate>[\"startDateOffset\"];\n let endDateOffset: CalendarOffsetProps<TDate>[\"startDateOffset\"];\n let rest: Partial<typeof props>;\n if (selectionVariant === \"offset\") {\n ({ startDateOffset, endDateOffset, ...rest } =\n propsRest as CalendarOffsetProps<TDate>);\n } else {\n rest = propsRest;\n }\n const defaultFocusedDateRef = useRef(null);\n\n // biome-ignore lint/suspicious/noExplicitAny: type guard\n const useCalendarProps: any = {\n selectedDate,\n defaultSelectedDate,\n visibleMonth: visibleMonthProp,\n defaultVisibleMonth,\n onSelectionChange,\n onVisibleMonthChange,\n focusedDate,\n focusedDateRef:\n focusedDateRef !== undefined ? focusedDateRef : defaultFocusedDateRef,\n isDayUnselectable,\n isDayHighlighted,\n isDayDisabled,\n minDate,\n maxDate,\n numberOfVisibleMonths,\n selectionVariant,\n onFocusedDateChange,\n onHoveredDateChange,\n hideOutOfRangeDates,\n hoveredDate,\n startDateOffset,\n endDateOffset,\n timezone,\n };\n const { state, helpers } = useCalendar<TDate>(useCalendarProps);\n const calendarLabel = dateAdapter.format(state.visibleMonth, \"MMMM YYYY\");\n\n return (\n <CalendarContext.Provider\n value={{\n state,\n helpers,\n }}\n >\n <div\n className={clsx(withBaseName(), className)}\n role=\"application\"\n aria-label={calendarLabel}\n ref={ref}\n {...rest}\n >\n {children}\n </div>\n </CalendarContext.Provider>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","useWindow","useLocalization","useComponentCssInjection","calendarCss","useRef","useCalendar","jsx","CalendarContext","clsx"],"mappings":"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"}
@@ -5,99 +5,75 @@ var core = require('@salt-ds/core');
5
5
  var react = require('react');
6
6
  var CalendarContext = require('./internal/CalendarContext.js');
7
7
  var CalendarMonth = require('./internal/CalendarMonth.js');
8
- var styles = require('@salt-ds/styles');
9
- var window = require('@salt-ds/window');
10
8
  var LocalizationProvider = require('../localization-provider/LocalizationProvider.js');
11
- var CalendarGrid$1 = require('./CalendarGrid.css.js');
12
- var utils = require('./internal/utils.js');
9
+ var CalendarMonthHeader = require('./CalendarMonthHeader.js');
10
+ var CalendarWeekHeader = require('./CalendarWeekHeader.js');
13
11
 
14
- const withBaseName = core.makePrefixer("saltCalendarGrid");
15
12
  const CalendarGrid = react.forwardRef(
16
13
  (props, ref) => {
17
14
  const {
18
- onFocus,
15
+ CalendarDayProps,
16
+ CalendarWeekHeaderProps,
17
+ CalendarMonthHeaderProps,
18
+ columns = 1,
19
19
  onBlur,
20
- getCalendarMonthProps = () => void 0,
21
20
  ...rest
22
21
  } = props;
23
22
  const { dateAdapter } = LocalizationProvider.useLocalization();
24
- const targetWindow = window.useWindow();
25
- styles.useComponentCssInjection({
26
- testId: "salt-calendar-grid",
27
- css: CalendarGrid$1,
28
- window: targetWindow
29
- });
30
23
  const {
31
- state: { visibleMonth, locale },
32
- helpers: { setCalendarFocused }
24
+ helpers: { setFocusedDate, setHoveredDate },
25
+ state: { visibleMonth, numberOfVisibleMonths = 1 }
33
26
  } = CalendarContext.useCalendarContext();
34
- const containerRef = react.useRef(null);
35
- const diffIndex = (a, b) => utils.monthDiff(dateAdapter, a, b);
36
- const { current: baseIndex } = react.useRef(visibleMonth);
37
- core.useIsomorphicLayoutEffect(() => {
38
- if (containerRef.current) {
39
- containerRef.current.style.transform = `translate3d(${diffIndex(baseIndex, visibleMonth) * -101}%, 0, 0)`;
40
- }
41
- });
42
- const getMonths = react.useCallback(
43
- (month) => {
44
- return [
45
- dateAdapter.subtract(month, { months: 1 }),
46
- month,
47
- dateAdapter.add(month, { months: 1 })
48
- ];
49
- },
50
- [dateAdapter.subtract]
51
- );
52
- const handleFocus = react.useCallback(
53
- (event) => {
54
- setCalendarFocused(true);
55
- onFocus == null ? void 0 : onFocus(event);
56
- },
57
- [setCalendarFocused, onFocus]
58
- );
59
- const handleBlur = react.useCallback(
60
- (event) => {
61
- setCalendarFocused(false);
62
- onBlur == null ? void 0 : onBlur(event);
63
- },
64
- [setCalendarFocused, onBlur]
65
- );
66
- const months = react.useMemo(() => {
67
- return getMonths(visibleMonth);
68
- }, [dateAdapter.format(visibleMonth)]);
27
+ const calendarGridRef = react.useRef(null);
28
+ const containerRef = core.useForkRef(ref, calendarGridRef);
29
+ const handleCalendarGridBlur = (event) => {
30
+ event.stopPropagation();
31
+ setTimeout(() => {
32
+ var _a;
33
+ if ((_a = calendarGridRef == null ? void 0 : calendarGridRef.current) == null ? void 0 : _a.contains(document.activeElement)) {
34
+ return;
35
+ }
36
+ setFocusedDate(event, null);
37
+ setHoveredDate(event, null);
38
+ }, 0);
39
+ onBlur == null ? void 0 : onBlur(event);
40
+ };
69
41
  return /* @__PURE__ */ jsxRuntime.jsx(
70
- "div",
42
+ core.GridLayout,
71
43
  {
72
- className: withBaseName(),
73
- tabIndex: -1,
74
- style: {
75
- overflowX: "hidden",
76
- position: "relative"
77
- },
78
- ref,
79
- children: /* @__PURE__ */ jsxRuntime.jsx(
80
- "div",
81
- {
82
- className: withBaseName("grid"),
83
- ref: containerRef,
84
- onBlur: handleBlur,
85
- onFocus: handleFocus,
86
- ...rest,
87
- children: months.map((date, index) => /* @__PURE__ */ jsxRuntime.jsx(
88
- "div",
89
- {
90
- className: withBaseName("slide"),
91
- style: {
92
- transform: `translateX(${diffIndex(date, baseIndex) * -101}%)`
93
- },
94
- "aria-hidden": index !== 1 ? "true" : void 0,
95
- children: /* @__PURE__ */ jsxRuntime.jsx(CalendarMonth.CalendarMonth, { ...getCalendarMonthProps(date), date })
96
- },
97
- dateAdapter.format(date, locale)
98
- ))
99
- }
100
- )
44
+ columns,
45
+ gap: 1,
46
+ ref: containerRef,
47
+ onBlur: handleCalendarGridBlur,
48
+ ...rest,
49
+ children: Array.from({ length: numberOfVisibleMonths }, (_value, index) => {
50
+ const gridItemVisibleMonth = dateAdapter.add(visibleMonth, {
51
+ months: index
52
+ });
53
+ return /* @__PURE__ */ jsxRuntime.jsxs(
54
+ core.GridItem,
55
+ {
56
+ children: [
57
+ numberOfVisibleMonths > 1 ? /* @__PURE__ */ jsxRuntime.jsx(
58
+ CalendarMonthHeader.CalendarMonthHeader,
59
+ {
60
+ ...CalendarMonthHeaderProps,
61
+ month: gridItemVisibleMonth
62
+ }
63
+ ) : null,
64
+ /* @__PURE__ */ jsxRuntime.jsx(CalendarWeekHeader.CalendarWeekHeader, { ...CalendarWeekHeaderProps }),
65
+ /* @__PURE__ */ jsxRuntime.jsx(
66
+ CalendarMonth.CalendarMonth,
67
+ {
68
+ date: gridItemVisibleMonth,
69
+ CalendarDayProps
70
+ }
71
+ )
72
+ ]
73
+ },
74
+ `calendar-grid-item-${dateAdapter.format(gridItemVisibleMonth, "MMMM YYYY")}`
75
+ );
76
+ })
101
77
  }
102
78
  );
103
79
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CalendarGrid.js","sources":["../src/calendar/CalendarGrid.tsx"],"sourcesContent":["import { makePrefixer, useIsomorphicLayoutEffect } from \"@salt-ds/core\";\nimport {\n type ComponentPropsWithoutRef,\n type FocusEventHandler,\n forwardRef,\n useCallback,\n useMemo,\n useRef,\n} from \"react\";\nimport { useCalendarContext } from \"./internal/CalendarContext\";\nimport {\n CalendarMonth,\n type CalendarMonthProps,\n} from \"./internal/CalendarMonth\";\n\nimport type { DateFrameworkType } from \"@salt-ds/date-adapters\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useLocalization } from \"../localization-provider\";\nimport calendarGridCss from \"./CalendarGrid.css\";\nimport { monthDiff } from \"./internal/utils\";\n\n/**\n * Props for the CalendarGrid component.\n */\nexport interface CalendarGridProps<TDate extends DateFrameworkType>\n extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Props getter to pass to each CalendarMonth element\n */\n getCalendarMonthProps?: (\n date: TDate,\n ) => Omit<CalendarMonthProps<TDate>, \"date\">;\n}\n\nconst withBaseName = makePrefixer(\"saltCalendarGrid\");\n\nexport const CalendarGrid = forwardRef<HTMLDivElement, CalendarGridProps<any>>(\n <TDate extends DateFrameworkType>(\n props: CalendarGridProps<TDate>,\n ref: React.Ref<HTMLDivElement>,\n ) => {\n const {\n onFocus,\n onBlur,\n getCalendarMonthProps = () => undefined,\n ...rest\n } = props;\n\n const { dateAdapter } = useLocalization<TDate>();\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar-grid\",\n css: calendarGridCss,\n window: targetWindow,\n });\n\n const {\n state: { visibleMonth, locale },\n helpers: { setCalendarFocused },\n } = useCalendarContext<TDate>();\n const containerRef = useRef<HTMLDivElement>(null);\n const diffIndex = (a: TDate, b: TDate) =>\n monthDiff<TDate>(dateAdapter, a, b);\n\n const { current: baseIndex } = useRef(visibleMonth);\n\n useIsomorphicLayoutEffect(() => {\n if (containerRef.current) {\n containerRef.current.style.transform = `translate3d(${\n diffIndex(baseIndex, visibleMonth) * -101 // needs to be higher than 100% so the next month doesn't show on the edges\n }%, 0, 0)`;\n }\n });\n\n const getMonths = useCallback(\n (month: TDate) => {\n return [\n dateAdapter.subtract(month, { months: 1 }),\n month,\n dateAdapter.add(month, { months: 1 }),\n ];\n },\n [dateAdapter.subtract],\n );\n\n const handleFocus: FocusEventHandler<HTMLDivElement> = useCallback(\n (event) => {\n setCalendarFocused(true);\n onFocus?.(event);\n },\n [setCalendarFocused, onFocus],\n );\n\n const handleBlur: FocusEventHandler<HTMLDivElement> = useCallback(\n (event) => {\n setCalendarFocused(false);\n onBlur?.(event);\n },\n [setCalendarFocused, onBlur],\n );\n\n const months = useMemo(() => {\n return getMonths(visibleMonth);\n }, [dateAdapter.format(visibleMonth)]);\n\n return (\n <div\n className={withBaseName()}\n tabIndex={-1} // https://bugzilla.mozilla.org/show_bug.cgi?id=1069739\n style={{\n overflowX: \"hidden\",\n position: \"relative\",\n }}\n ref={ref}\n >\n <div\n className={withBaseName(\"grid\")}\n ref={containerRef}\n onBlur={handleBlur}\n onFocus={handleFocus}\n {...rest}\n >\n {months.map((date, index) => (\n <div\n key={dateAdapter.format(date, locale)}\n className={withBaseName(\"slide\")}\n style={{\n transform: `translateX(${diffIndex(date, baseIndex) * -101}%)`,\n }}\n aria-hidden={index !== 1 ? \"true\" : undefined}\n >\n <CalendarMonth {...getCalendarMonthProps(date)} date={date} />\n </div>\n ))}\n </div>\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","useLocalization","useWindow","useComponentCssInjection","calendarGridCss","useCalendarContext","useRef","monthDiff","useIsomorphicLayoutEffect","useCallback","useMemo","jsx","CalendarMonth"],"mappings":"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"}
1
+ {"version":3,"file":"CalendarGrid.js","sources":["../src/calendar/CalendarGrid.tsx"],"sourcesContent":["import {\n GridItem,\n GridLayout,\n type ResponsiveProp,\n useForkRef,\n} from \"@salt-ds/core\";\nimport {\n type ComponentPropsWithoutRef,\n type FocusEventHandler,\n forwardRef,\n useRef,\n} from \"react\";\nimport { useCalendarContext } from \"./internal/CalendarContext\";\nimport type { CalendarDayProps } from \"./internal/CalendarDay\";\nimport { CalendarMonth } from \"./internal/CalendarMonth\";\n\nimport type { DateFrameworkType } from \"@salt-ds/date-adapters\";\nimport { useLocalization } from \"../localization-provider\";\nimport {\n CalendarMonthHeader,\n type CalendarMonthHeaderProps,\n} from \"./CalendarMonthHeader\";\nimport {\n CalendarWeekHeader,\n type CalendarWeekHeaderProps,\n} from \"./CalendarWeekHeader\";\n\n/**\n * Props for the CalendarGrid component.\n * @template TDate - The type of the date object.\n */\nexport interface CalendarGridProps<TDate extends DateFrameworkType>\n extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * Number of columns\n */\n columns?: ResponsiveProp<number | string>;\n /**\n * Props for `CalendarWeekHeader`\n */\n CalendarWeekHeaderProps?: Partial<CalendarWeekHeaderProps>;\n /**\n * Props for `CalendarMonthHeader`\n */\n CalendarMonthHeaderProps?: Partial<CalendarMonthHeaderProps<TDate>>;\n /**\n * Props for `CalendarDay`\n */\n CalendarDayProps?: Partial<CalendarDayProps<TDate>>;\n}\n\nexport const CalendarGrid = forwardRef<\n HTMLDivElement,\n CalendarGridProps<DateFrameworkType>\n>(\n <TDate extends DateFrameworkType>(\n props: CalendarGridProps<TDate>,\n ref: React.Ref<HTMLDivElement>,\n ) => {\n const {\n CalendarDayProps,\n CalendarWeekHeaderProps,\n CalendarMonthHeaderProps,\n columns = 1,\n onBlur,\n ...rest\n } = props;\n\n const { dateAdapter } = useLocalization<TDate>();\n\n const {\n helpers: { setFocusedDate, setHoveredDate },\n state: { visibleMonth, numberOfVisibleMonths = 1 },\n } = useCalendarContext<TDate>();\n const calendarGridRef = useRef<HTMLDivElement>(null);\n const containerRef = useForkRef(ref, calendarGridRef);\n\n const handleCalendarGridBlur: FocusEventHandler<HTMLDivElement> = (\n event,\n ) => {\n event.stopPropagation();\n setTimeout(() => {\n if (calendarGridRef?.current?.contains(document.activeElement)) {\n return;\n }\n setFocusedDate(event, null);\n setHoveredDate(event, null);\n }, 0);\n onBlur?.(event);\n };\n\n return (\n <GridLayout\n columns={columns}\n gap={1}\n ref={containerRef}\n onBlur={handleCalendarGridBlur}\n {...rest}\n >\n {Array.from({ length: numberOfVisibleMonths }, (_value, index) => {\n const gridItemVisibleMonth: TDate = dateAdapter.add(visibleMonth, {\n months: index,\n });\n return (\n <GridItem\n key={`calendar-grid-item-${dateAdapter.format(gridItemVisibleMonth, \"MMMM YYYY\")}`}\n >\n {numberOfVisibleMonths > 1 ? (\n <CalendarMonthHeader\n {...CalendarMonthHeaderProps}\n month={gridItemVisibleMonth}\n />\n ) : null}\n <CalendarWeekHeader {...CalendarWeekHeaderProps} />\n <CalendarMonth\n date={gridItemVisibleMonth}\n CalendarDayProps={CalendarDayProps}\n />\n </GridItem>\n );\n })}\n </GridLayout>\n );\n },\n);\n"],"names":["forwardRef","useLocalization","useCalendarContext","useRef","useForkRef","jsx","GridLayout","jsxs","GridItem","CalendarMonthHeader","CalendarWeekHeader","CalendarMonth"],"mappings":";;;;;;;;;;;AAmDO,MAAM,YAAe,GAAAA,gBAAA;AAAA,EAI1B,CACE,OACA,GACG,KAAA;AACH,IAAM,MAAA;AAAA,MACJ,gBAAA;AAAA,MACA,uBAAA;AAAA,MACA,wBAAA;AAAA,MACA,OAAU,GAAA,CAAA;AAAA,MACV,MAAA;AAAA,MACA,GAAG;AAAA,KACD,GAAA,KAAA;AAEJ,IAAM,MAAA,EAAE,WAAY,EAAA,GAAIC,oCAAuB,EAAA;AAE/C,IAAM,MAAA;AAAA,MACJ,OAAA,EAAS,EAAE,cAAA,EAAgB,cAAe,EAAA;AAAA,MAC1C,KAAO,EAAA,EAAE,YAAc,EAAA,qBAAA,GAAwB,CAAE;AAAA,QAC/CC,kCAA0B,EAAA;AAC9B,IAAM,MAAA,eAAA,GAAkBC,aAAuB,IAAI,CAAA;AACnD,IAAM,MAAA,YAAA,GAAeC,eAAW,CAAA,GAAA,EAAK,eAAe,CAAA;AAEpD,IAAM,MAAA,sBAAA,GAA4D,CAChE,KACG,KAAA;AACH,MAAA,KAAA,CAAM,eAAgB,EAAA;AACtB,MAAA,UAAA,CAAW,MAAM;AAjFvB,QAAA,IAAA,EAAA;AAkFQ,QAAA,IAAA,CAAI,EAAiB,GAAA,eAAA,IAAA,IAAA,GAAA,MAAA,GAAA,eAAA,CAAA,OAAA,KAAjB,IAA0B,GAAA,MAAA,GAAA,EAAA,CAAA,QAAA,CAAS,SAAS,aAAgB,CAAA,EAAA;AAC9D,UAAA;AAAA;AAEF,QAAA,cAAA,CAAe,OAAO,IAAI,CAAA;AAC1B,QAAA,cAAA,CAAe,OAAO,IAAI,CAAA;AAAA,SACzB,CAAC,CAAA;AACJ,MAAS,MAAA,IAAA,IAAA,GAAA,MAAA,GAAA,MAAA,CAAA,KAAA,CAAA;AAAA,KACX;AAEA,IACE,uBAAAC,cAAA;AAAA,MAACC,eAAA;AAAA,MAAA;AAAA,QACC,OAAA;AAAA,QACA,GAAK,EAAA,CAAA;AAAA,QACL,GAAK,EAAA,YAAA;AAAA,QACL,MAAQ,EAAA,sBAAA;AAAA,QACP,GAAG,IAAA;AAAA,QAEH,QAAA,EAAA,KAAA,CAAM,KAAK,EAAE,MAAA,EAAQ,uBAAyB,EAAA,CAAC,QAAQ,KAAU,KAAA;AAChE,UAAM,MAAA,oBAAA,GAA8B,WAAY,CAAA,GAAA,CAAI,YAAc,EAAA;AAAA,YAChE,MAAQ,EAAA;AAAA,WACT,CAAA;AACD,UACE,uBAAAC,eAAA;AAAA,YAACC,aAAA;AAAA,YAAA;AAAA,cAGE,QAAA,EAAA;AAAA,gBAAA,qBAAA,GAAwB,CACvB,mBAAAH,cAAA;AAAA,kBAACI,uCAAA;AAAA,kBAAA;AAAA,oBACE,GAAG,wBAAA;AAAA,oBACJ,KAAO,EAAA;AAAA;AAAA,iBAEP,GAAA,IAAA;AAAA,gCACJJ,cAAA,CAACK,qCAAoB,EAAA,EAAA,GAAG,uBAAyB,EAAA,CAAA;AAAA,gCACjDL,cAAA;AAAA,kBAACM,2BAAA;AAAA,kBAAA;AAAA,oBACC,IAAM,EAAA,oBAAA;AAAA,oBACN;AAAA;AAAA;AACF;AAAA,aAAA;AAAA,YAZK,CAAsB,mBAAA,EAAA,WAAA,CAAY,MAAO,CAAA,oBAAA,EAAsB,WAAW,CAAC,CAAA;AAAA,WAalF;AAAA,SAEH;AAAA;AAAA,KACH;AAAA;AAGN;;;;"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltCalendarMonthHeader {\n width: 100%;\n text-align: center;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=CalendarMonthHeader.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CalendarMonthHeader.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,48 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var core = require('@salt-ds/core');
5
+ var clsx = require('clsx');
6
+ var react = require('react');
7
+ var styles = require('@salt-ds/styles');
8
+ var window = require('@salt-ds/window');
9
+ var LocalizationProvider = require('../localization-provider/LocalizationProvider.js');
10
+ var CalendarMonthHeader$1 = require('./CalendarMonthHeader.css.js');
11
+
12
+ const withBaseName = core.makePrefixer("saltCalendarMonthHeader");
13
+ const CalendarMonthHeader = react.forwardRef(
14
+ (props, ref) => {
15
+ const {
16
+ className,
17
+ format: formatMonthProp = "MMMM",
18
+ month,
19
+ ...rest
20
+ } = props;
21
+ const { dateAdapter } = LocalizationProvider.useLocalization();
22
+ const targetWindow = window.useWindow();
23
+ styles.useComponentCssInjection({
24
+ testId: "salt-calendar-month-header",
25
+ css: CalendarMonthHeader$1,
26
+ window: targetWindow
27
+ });
28
+ const formatMonth = react.useCallback(
29
+ (date) => {
30
+ return dateAdapter.format(date, formatMonthProp);
31
+ },
32
+ [dateAdapter, formatMonthProp]
33
+ );
34
+ return /* @__PURE__ */ jsxRuntime.jsx(
35
+ "div",
36
+ {
37
+ "data-testid": "CalendarMonthHeader",
38
+ className: clsx.clsx(withBaseName(), className),
39
+ ref,
40
+ ...rest,
41
+ children: /* @__PURE__ */ jsxRuntime.jsx(core.Text, { children: /* @__PURE__ */ jsxRuntime.jsx("small", { children: formatMonth(month) }) })
42
+ }
43
+ );
44
+ }
45
+ );
46
+
47
+ exports.CalendarMonthHeader = CalendarMonthHeader;
48
+ //# sourceMappingURL=CalendarMonthHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CalendarMonthHeader.js","sources":["../src/calendar/CalendarMonthHeader.tsx"],"sourcesContent":["import { Text, makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithRef, forwardRef, useCallback } from \"react\";\n\nimport type { DateFrameworkType } from \"@salt-ds/date-adapters\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useLocalization } from \"../localization-provider\";\nimport calendarMonthHeaderCss from \"./CalendarMonthHeader.css\";\n\n/**\n * Props for the CalendarMonthHeader component.\n * @template TDate - The type of the date object.\n */\nexport interface CalendarMonthHeaderProps<TDate extends DateFrameworkType>\n extends ComponentPropsWithRef<\"div\"> {\n /**\n * Month value\n */\n month: TDate;\n /**\n * Format the month value\n * @param date\n */\n format?: string;\n}\n\nconst withBaseName = makePrefixer(\"saltCalendarMonthHeader\");\n\nexport const CalendarMonthHeader = forwardRef<\n HTMLDivElement,\n CalendarMonthHeaderProps<DateFrameworkType>\n>(\n <TDate extends DateFrameworkType>(\n props: CalendarMonthHeaderProps<TDate>,\n ref: React.Ref<HTMLDivElement>,\n ) => {\n const {\n className,\n format: formatMonthProp = \"MMMM\",\n month,\n ...rest\n } = props;\n const { dateAdapter } = useLocalization<TDate>();\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar-month-header\",\n css: calendarMonthHeaderCss,\n window: targetWindow,\n });\n\n const formatMonth = useCallback(\n (date?: TDate) => {\n return dateAdapter.format(date, formatMonthProp);\n },\n [dateAdapter, formatMonthProp],\n );\n\n return (\n <div\n data-testid=\"CalendarMonthHeader\"\n className={clsx(withBaseName(), className)}\n ref={ref}\n {...rest}\n >\n <Text>\n <small>{formatMonth(month)}</small>\n </Text>\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","useLocalization","useWindow","useComponentCssInjection","calendarMonthHeaderCss","useCallback","jsx","clsx","Text"],"mappings":";;;;;;;;;;;AA2BA,MAAM,YAAA,GAAeA,kBAAa,yBAAyB,CAAA;AAEpD,MAAM,mBAAsB,GAAAC,gBAAA;AAAA,EAIjC,CACE,OACA,GACG,KAAA;AACH,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,QAAQ,eAAkB,GAAA,MAAA;AAAA,MAC1B,KAAA;AAAA,MACA,GAAG;AAAA,KACD,GAAA,KAAA;AACJ,IAAM,MAAA,EAAE,WAAY,EAAA,GAAIC,oCAAuB,EAAA;AAE/C,IAAA,MAAM,eAAeC,gBAAU,EAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,4BAAA;AAAA,MACR,GAAK,EAAAC,qBAAA;AAAA,MACL,MAAQ,EAAA;AAAA,KACT,CAAA;AAED,IAAA,MAAM,WAAc,GAAAC,iBAAA;AAAA,MAClB,CAAC,IAAiB,KAAA;AAChB,QAAO,OAAA,WAAA,CAAY,MAAO,CAAA,IAAA,EAAM,eAAe,CAAA;AAAA,OACjD;AAAA,MACA,CAAC,aAAa,eAAe;AAAA,KAC/B;AAEA,IACE,uBAAAC,cAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,aAAY,EAAA,qBAAA;AAAA,QACZ,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QACzC,GAAA;AAAA,QACC,GAAG,IAAA;AAAA,QAEJ,yCAACC,SACC,EAAA,EAAA,QAAA,kBAAAF,cAAA,CAAC,WAAO,QAAY,EAAA,WAAA,CAAA,KAAK,GAAE,CAC7B,EAAA;AAAA;AAAA,KACF;AAAA;AAGN;;;;"}