@hitachivantara/uikit-react-core 5.60.0 → 5.62.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (898) hide show
  1. package/dist/cjs/Accordion/Accordion.cjs +1 -1
  2. package/dist/cjs/Accordion/Accordion.cjs.map +1 -1
  3. package/dist/cjs/Accordion/Accordion.styles.cjs +1 -1
  4. package/dist/cjs/Accordion/Accordion.styles.cjs.map +1 -1
  5. package/dist/cjs/ActionBar/ActionBar.cjs.map +1 -1
  6. package/dist/cjs/ActionsGeneric/ActionsGeneric.cjs.map +1 -1
  7. package/dist/cjs/AppSwitcher/Action/Action.cjs +1 -1
  8. package/dist/cjs/AppSwitcher/Action/Action.cjs.map +1 -1
  9. package/dist/cjs/AppSwitcher/Action/Action.styles.cjs.map +1 -1
  10. package/dist/cjs/AppSwitcher/AppSwitcher.cjs.map +1 -1
  11. package/dist/cjs/Avatar/Avatar.cjs +1 -1
  12. package/dist/cjs/Avatar/Avatar.cjs.map +1 -1
  13. package/dist/cjs/Avatar/Avatar.styles.cjs +1 -1
  14. package/dist/cjs/Avatar/Avatar.styles.cjs.map +1 -1
  15. package/dist/cjs/AvatarGroup/AvatarGroup.cjs +1 -1
  16. package/dist/cjs/AvatarGroup/AvatarGroup.cjs.map +1 -1
  17. package/dist/cjs/AvatarGroup/AvatarGroup.styles.cjs +1 -1
  18. package/dist/cjs/AvatarGroup/AvatarGroup.styles.cjs.map +1 -1
  19. package/dist/cjs/Badge/Badge.cjs.map +1 -1
  20. package/dist/cjs/Banner/Banner.cjs +1 -1
  21. package/dist/cjs/Banner/Banner.cjs.map +1 -1
  22. package/dist/cjs/Banner/BannerContent/ActionContainer/ActionContainer.cjs.map +1 -1
  23. package/dist/cjs/Banner/BannerContent/BannerContent.cjs.map +1 -1
  24. package/dist/cjs/Banner/BannerContent/MessageContainer/MessageContainer.cjs.map +1 -1
  25. package/dist/cjs/BaseCheckBox/BaseCheckBox.cjs +16 -13
  26. package/dist/cjs/BaseCheckBox/BaseCheckBox.cjs.map +1 -1
  27. package/dist/cjs/BaseCheckBox/BaseCheckBox.styles.cjs +55 -7
  28. package/dist/cjs/BaseCheckBox/BaseCheckBox.styles.cjs.map +1 -1
  29. package/dist/cjs/BaseCheckBox/icons.cjs +21 -0
  30. package/dist/cjs/BaseCheckBox/icons.cjs.map +1 -0
  31. package/dist/cjs/BaseDropdown/BaseDropdown.cjs +6 -6
  32. package/dist/cjs/BaseDropdown/BaseDropdown.cjs.map +1 -1
  33. package/dist/cjs/BaseDropdown/BaseDropdown.styles.cjs +1 -1
  34. package/dist/cjs/BaseDropdown/BaseDropdown.styles.cjs.map +1 -1
  35. package/dist/cjs/BaseInput/BaseInput.cjs +1 -1
  36. package/dist/cjs/BaseInput/BaseInput.cjs.map +1 -1
  37. package/dist/cjs/BaseInput/BaseInput.styles.cjs +1 -1
  38. package/dist/cjs/BaseInput/BaseInput.styles.cjs.map +1 -1
  39. package/dist/cjs/BaseInput/validations.cjs.map +1 -1
  40. package/dist/cjs/BaseRadio/BaseRadio.cjs +12 -11
  41. package/dist/cjs/BaseRadio/BaseRadio.cjs.map +1 -1
  42. package/dist/cjs/BaseRadio/BaseRadio.styles.cjs +40 -5
  43. package/dist/cjs/BaseRadio/BaseRadio.styles.cjs.map +1 -1
  44. package/dist/cjs/BaseRadio/icons.cjs +17 -0
  45. package/dist/cjs/BaseRadio/icons.cjs.map +1 -0
  46. package/dist/cjs/BaseSwitch/BaseSwitch.cjs.map +1 -1
  47. package/dist/cjs/BaseSwitch/BaseSwitch.styles.cjs +1 -1
  48. package/dist/cjs/BaseSwitch/BaseSwitch.styles.cjs.map +1 -1
  49. package/dist/cjs/Box/Box.cjs.map +1 -1
  50. package/dist/cjs/BreadCrumb/BreadCrumb.cjs.map +1 -1
  51. package/dist/cjs/BreadCrumb/Page/Page.cjs.map +1 -1
  52. package/dist/cjs/BreadCrumb/PathElement/PathElement.cjs.map +1 -1
  53. package/dist/cjs/BreadCrumb/utils.cjs.map +1 -1
  54. package/dist/cjs/BulkActions/BulkActions.cjs +1 -1
  55. package/dist/cjs/BulkActions/BulkActions.cjs.map +1 -1
  56. package/dist/cjs/BulkActions/BulkActions.styles.cjs.map +1 -1
  57. package/dist/cjs/Button/Button.cjs +1 -1
  58. package/dist/cjs/Button/Button.cjs.map +1 -1
  59. package/dist/cjs/Button/Button.styles.cjs +1 -1
  60. package/dist/cjs/Button/Button.styles.cjs.map +1 -1
  61. package/dist/cjs/Calendar/Calendar.cjs +1 -1
  62. package/dist/cjs/Calendar/Calendar.cjs.map +1 -1
  63. package/dist/cjs/Calendar/CalendarHeader/CalendarHeader.cjs +3 -3
  64. package/dist/cjs/Calendar/CalendarHeader/CalendarHeader.cjs.map +1 -1
  65. package/dist/cjs/Calendar/CalendarNavigation/ComposedNavigation/ComposedNavigation.cjs.map +1 -1
  66. package/dist/cjs/Calendar/CalendarNavigation/ComposedNavigation/ComposedNavigation.styles.cjs.map +1 -1
  67. package/dist/cjs/Calendar/CalendarNavigation/MonthSelector/MonthSelector.cjs.map +1 -1
  68. package/dist/cjs/Calendar/CalendarNavigation/MonthSelector/MonthSelector.styles.cjs +1 -1
  69. package/dist/cjs/Calendar/CalendarNavigation/MonthSelector/MonthSelector.styles.cjs.map +1 -1
  70. package/dist/cjs/Calendar/CalendarNavigation/Navigation/Navigation.cjs.map +1 -1
  71. package/dist/cjs/Calendar/SingleCalendar/CalendarCell.cjs.map +1 -1
  72. package/dist/cjs/Calendar/SingleCalendar/CalendarCell.styles.cjs +1 -1
  73. package/dist/cjs/Calendar/SingleCalendar/CalendarCell.styles.cjs.map +1 -1
  74. package/dist/cjs/Calendar/SingleCalendar/SingleCalendar.cjs +2 -2
  75. package/dist/cjs/Calendar/SingleCalendar/SingleCalendar.cjs.map +1 -1
  76. package/dist/cjs/Calendar/model.cjs.map +1 -1
  77. package/dist/cjs/Calendar/utils.cjs.map +1 -1
  78. package/dist/cjs/Card/Card.cjs.map +1 -1
  79. package/dist/cjs/Card/Card.styles.cjs +1 -1
  80. package/dist/cjs/Card/Card.styles.cjs.map +1 -1
  81. package/dist/cjs/Card/Content/Content.cjs.map +1 -1
  82. package/dist/cjs/Card/Header/Header.cjs.map +1 -1
  83. package/dist/cjs/Card/Media/Media.cjs.map +1 -1
  84. package/dist/cjs/Carousel/Carousel.cjs +1 -1
  85. package/dist/cjs/Carousel/Carousel.cjs.map +1 -1
  86. package/dist/cjs/Carousel/CarouselControls.cjs.map +1 -1
  87. package/dist/cjs/Carousel/CarouselSlide/CarouselSlide.cjs.map +1 -1
  88. package/dist/cjs/Carousel/CarouselThumbnails.cjs.map +1 -1
  89. package/dist/cjs/CheckBox/CheckBox.cjs +5 -2
  90. package/dist/cjs/CheckBox/CheckBox.cjs.map +1 -1
  91. package/dist/cjs/CheckBox/CheckBox.styles.cjs +5 -2
  92. package/dist/cjs/CheckBox/CheckBox.styles.cjs.map +1 -1
  93. package/dist/cjs/CheckBoxGroup/CheckBoxGroup.cjs +2 -2
  94. package/dist/cjs/CheckBoxGroup/CheckBoxGroup.cjs.map +1 -1
  95. package/dist/cjs/ColorPicker/ColorPicker.cjs +2 -2
  96. package/dist/cjs/ColorPicker/ColorPicker.cjs.map +1 -1
  97. package/dist/cjs/ColorPicker/Fields/Fields.cjs.map +1 -1
  98. package/dist/cjs/ColorPicker/Picker/Picker.cjs +2 -2
  99. package/dist/cjs/ColorPicker/Picker/Picker.cjs.map +1 -1
  100. package/dist/cjs/ColorPicker/PresetColors/PresetColors.cjs.map +1 -1
  101. package/dist/cjs/ColorPicker/SavedColors/SavedColors.cjs +1 -1
  102. package/dist/cjs/ColorPicker/SavedColors/SavedColors.cjs.map +1 -1
  103. package/dist/cjs/Container/Container.cjs +2 -2
  104. package/dist/cjs/Container/Container.cjs.map +1 -1
  105. package/dist/cjs/Controls/Controls.cjs +1 -1
  106. package/dist/cjs/Controls/Controls.cjs.map +1 -1
  107. package/dist/cjs/Controls/LeftControl/LeftControl.cjs +1 -1
  108. package/dist/cjs/Controls/LeftControl/LeftControl.cjs.map +1 -1
  109. package/dist/cjs/Controls/RightControl/RightControl.cjs +1 -1
  110. package/dist/cjs/Controls/RightControl/RightControl.cjs.map +1 -1
  111. package/dist/cjs/DatePicker/DatePicker.cjs +5 -5
  112. package/dist/cjs/DatePicker/DatePicker.cjs.map +1 -1
  113. package/dist/cjs/DatePicker/useVisibleDate.cjs +4 -1
  114. package/dist/cjs/DatePicker/useVisibleDate.cjs.map +1 -1
  115. package/dist/cjs/DatePicker/utils.cjs.map +1 -1
  116. package/dist/cjs/Dialog/Actions/Actions.cjs +1 -1
  117. package/dist/cjs/Dialog/Actions/Actions.cjs.map +1 -1
  118. package/dist/cjs/Dialog/Content/Content.cjs.map +1 -1
  119. package/dist/cjs/Dialog/Dialog.cjs +2 -2
  120. package/dist/cjs/Dialog/Dialog.cjs.map +1 -1
  121. package/dist/cjs/Dialog/Title/Title.cjs.map +1 -1
  122. package/dist/cjs/DotPagination/DotPagination.cjs +1 -1
  123. package/dist/cjs/DotPagination/DotPagination.cjs.map +1 -1
  124. package/dist/cjs/DotPagination/DotPagination.styles.cjs +11 -3
  125. package/dist/cjs/DotPagination/DotPagination.styles.cjs.map +1 -1
  126. package/dist/cjs/Drawer/Drawer.cjs.map +1 -1
  127. package/dist/cjs/DropDownMenu/DropDownMenu.cjs +2 -2
  128. package/dist/cjs/DropDownMenu/DropDownMenu.cjs.map +1 -1
  129. package/dist/cjs/Dropdown/Dropdown.cjs +3 -3
  130. package/dist/cjs/Dropdown/Dropdown.cjs.map +1 -1
  131. package/dist/cjs/Dropdown/List/List.cjs +2 -2
  132. package/dist/cjs/Dropdown/List/List.cjs.map +1 -1
  133. package/dist/cjs/Dropdown/utils.cjs.map +1 -1
  134. package/dist/cjs/DropdownButton/DropdownButton.cjs.map +1 -1
  135. package/dist/cjs/DropdownButton/DropdownButton.styles.cjs.map +1 -1
  136. package/dist/cjs/EmptyState/EmptyState.cjs.map +1 -1
  137. package/dist/cjs/FileUploader/DropZone/DropZone.cjs +2 -2
  138. package/dist/cjs/FileUploader/DropZone/DropZone.cjs.map +1 -1
  139. package/dist/cjs/FileUploader/File/File.cjs +1 -1
  140. package/dist/cjs/FileUploader/File/File.cjs.map +1 -1
  141. package/dist/cjs/FileUploader/FileList/FileList.cjs +1 -1
  142. package/dist/cjs/FileUploader/FileList/FileList.cjs.map +1 -1
  143. package/dist/cjs/FileUploader/FileUploader.cjs +1 -1
  144. package/dist/cjs/FileUploader/FileUploader.cjs.map +1 -1
  145. package/dist/cjs/FileUploader/Preview/Preview.cjs.map +1 -1
  146. package/dist/cjs/FileUploader/Preview/Preview.styles.cjs.map +1 -1
  147. package/dist/cjs/FilterGroup/Counter/Counter.cjs.map +1 -1
  148. package/dist/cjs/FilterGroup/FilterContent/FilterContent.cjs +2 -2
  149. package/dist/cjs/FilterGroup/FilterContent/FilterContent.cjs.map +1 -1
  150. package/dist/cjs/FilterGroup/FilterGroup.cjs +2 -2
  151. package/dist/cjs/FilterGroup/FilterGroup.cjs.map +1 -1
  152. package/dist/cjs/FilterGroup/FilterGroupContext.cjs +1 -1
  153. package/dist/cjs/FilterGroup/FilterGroupContext.cjs.map +1 -1
  154. package/dist/cjs/FilterGroup/RightPanel/RightPanel.cjs.map +1 -1
  155. package/dist/cjs/Focus/Focus.cjs +2 -2
  156. package/dist/cjs/Focus/Focus.cjs.map +1 -1
  157. package/dist/cjs/Focus/Focus.styles.cjs +1 -1
  158. package/dist/cjs/Focus/Focus.styles.cjs.map +1 -1
  159. package/dist/cjs/Footer/Footer.cjs.map +1 -1
  160. package/dist/cjs/Forms/Adornment/Adornment.cjs.map +1 -1
  161. package/dist/cjs/Forms/Adornment/Adornment.styles.cjs +1 -1
  162. package/dist/cjs/Forms/Adornment/Adornment.styles.cjs.map +1 -1
  163. package/dist/cjs/Forms/CharCounter/CharCounter.cjs.map +1 -1
  164. package/dist/cjs/Forms/FormElement/FormElement.cjs +2 -2
  165. package/dist/cjs/Forms/FormElement/FormElement.cjs.map +1 -1
  166. package/dist/cjs/Forms/FormElement/utils/FormUtils.cjs.map +1 -1
  167. package/dist/cjs/Forms/InfoMessage/InfoMessage.cjs.map +1 -1
  168. package/dist/cjs/Forms/Label/Label.cjs.map +1 -1
  169. package/dist/cjs/Forms/Suggestions/Suggestions.cjs +1 -1
  170. package/dist/cjs/Forms/Suggestions/Suggestions.cjs.map +1 -1
  171. package/dist/cjs/Forms/WarningText/WarningText.cjs.map +1 -1
  172. package/dist/cjs/GlobalActions/GlobalActions.cjs.map +1 -1
  173. package/dist/cjs/GlobalActions/GlobalActions.styles.cjs.map +1 -1
  174. package/dist/cjs/Grid/Grid.cjs.map +1 -1
  175. package/dist/cjs/Header/Actions/Actions.cjs.map +1 -1
  176. package/dist/cjs/Header/Brand/Brand.cjs.map +1 -1
  177. package/dist/cjs/Header/Header.cjs.map +1 -1
  178. package/dist/cjs/Header/Navigation/MenuBar/Bar.cjs.map +1 -1
  179. package/dist/cjs/Header/Navigation/MenuBar/MenuBar.cjs.map +1 -1
  180. package/dist/cjs/Header/Navigation/MenuItem/MenuItem.cjs +2 -2
  181. package/dist/cjs/Header/Navigation/MenuItem/MenuItem.cjs.map +1 -1
  182. package/dist/cjs/Header/Navigation/MenuItem/MenuItem.styles.cjs +1 -1
  183. package/dist/cjs/Header/Navigation/MenuItem/MenuItem.styles.cjs.map +1 -1
  184. package/dist/cjs/Header/Navigation/Navigation.cjs +1 -1
  185. package/dist/cjs/Header/Navigation/Navigation.cjs.map +1 -1
  186. package/dist/cjs/Header/Navigation/Navigation.styles.cjs.map +1 -1
  187. package/dist/cjs/Header/Navigation/useSelectionPath.cjs.map +1 -1
  188. package/dist/cjs/Header/Navigation/utils/FocusContext.cjs.map +1 -1
  189. package/dist/cjs/IconButton/IconButton.cjs +1 -1
  190. package/dist/cjs/IconButton/IconButton.cjs.map +1 -1
  191. package/dist/cjs/InlineEditor/InlineEditor.cjs +1 -1
  192. package/dist/cjs/InlineEditor/InlineEditor.cjs.map +1 -1
  193. package/dist/cjs/InlineEditor/InlineEditor.styles.cjs.map +1 -1
  194. package/dist/cjs/Input/Input.cjs +6 -6
  195. package/dist/cjs/Input/Input.cjs.map +1 -1
  196. package/dist/cjs/Kpi/Kpi.cjs.map +1 -1
  197. package/dist/cjs/Link/Link.cjs.map +1 -1
  198. package/dist/cjs/Link/Link.styles.cjs +1 -1
  199. package/dist/cjs/Link/Link.styles.cjs.map +1 -1
  200. package/dist/cjs/List/List.cjs.map +1 -1
  201. package/dist/cjs/List/List.styles.cjs +1 -1
  202. package/dist/cjs/List/List.styles.cjs.map +1 -1
  203. package/dist/cjs/List/useSelectableList.cjs.map +1 -1
  204. package/dist/cjs/List/utils.cjs.map +1 -1
  205. package/dist/cjs/ListContainer/ListContainer.cjs +1 -1
  206. package/dist/cjs/ListContainer/ListContainer.cjs.map +1 -1
  207. package/dist/cjs/ListContainer/ListItem/ListItem.cjs.map +1 -1
  208. package/dist/cjs/ListContainer/ListItem/ListItem.styles.cjs +1 -1
  209. package/dist/cjs/ListContainer/ListItem/ListItem.styles.cjs.map +1 -1
  210. package/dist/cjs/Loading/Loading.cjs +1 -1
  211. package/dist/cjs/Loading/Loading.cjs.map +1 -1
  212. package/dist/cjs/Loading/Loading.styles.cjs.map +1 -1
  213. package/dist/cjs/LoadingContainer/LoadingContainer.cjs +37 -0
  214. package/dist/cjs/LoadingContainer/LoadingContainer.cjs.map +1 -0
  215. package/dist/cjs/LoadingContainer/LoadingContainer.styles.cjs +20 -0
  216. package/dist/cjs/LoadingContainer/LoadingContainer.styles.cjs.map +1 -0
  217. package/dist/cjs/Login/Login.cjs.map +1 -1
  218. package/dist/cjs/MultiButton/MultiButton.cjs.map +1 -1
  219. package/dist/cjs/MultiButton/MultiButton.styles.cjs +1 -1
  220. package/dist/cjs/MultiButton/MultiButton.styles.cjs.map +1 -1
  221. package/dist/cjs/OverflowTooltip/OverflowTooltip.cjs.map +1 -1
  222. package/dist/cjs/OverflowTooltip/OverflowTooltip.styles.cjs.map +1 -1
  223. package/dist/cjs/Pagination/Pagination.cjs +3 -3
  224. package/dist/cjs/Pagination/Pagination.cjs.map +1 -1
  225. package/dist/cjs/Pagination/Pagination.styles.cjs.map +1 -1
  226. package/dist/cjs/Pagination/Select.cjs.map +1 -1
  227. package/dist/cjs/Pagination/utils.cjs.map +1 -1
  228. package/dist/cjs/Panel/Panel.cjs.map +1 -1
  229. package/dist/cjs/ProgressBar/ProgressBar.cjs.map +1 -1
  230. package/dist/cjs/QueryBuilder/ConfirmationDialog/ConfirmationDialog.cjs.map +1 -1
  231. package/dist/cjs/QueryBuilder/ConfirmationDialog/ConfirmationDialog.styles.cjs.map +1 -1
  232. package/dist/cjs/QueryBuilder/Context.cjs.map +1 -1
  233. package/dist/cjs/QueryBuilder/QueryBuilder.cjs +2 -2
  234. package/dist/cjs/QueryBuilder/QueryBuilder.cjs.map +1 -1
  235. package/dist/cjs/QueryBuilder/Rule/Attribute/Attribute.cjs +1 -1
  236. package/dist/cjs/QueryBuilder/Rule/Attribute/Attribute.cjs.map +1 -1
  237. package/dist/cjs/QueryBuilder/Rule/Operator/Operator.cjs.map +1 -1
  238. package/dist/cjs/QueryBuilder/Rule/Rule.cjs +1 -1
  239. package/dist/cjs/QueryBuilder/Rule/Rule.cjs.map +1 -1
  240. package/dist/cjs/QueryBuilder/Rule/Rule.styles.cjs.map +1 -1
  241. package/dist/cjs/QueryBuilder/Rule/Value/BooleanValue/BooleanValue.cjs.map +1 -1
  242. package/dist/cjs/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.cjs +3 -3
  243. package/dist/cjs/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.cjs.map +1 -1
  244. package/dist/cjs/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.cjs.map +1 -1
  245. package/dist/cjs/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.cjs.map +1 -1
  246. package/dist/cjs/QueryBuilder/Rule/Value/NumericValue/NumericValue.cjs.map +1 -1
  247. package/dist/cjs/QueryBuilder/Rule/Value/TextValue/TextValue.cjs.map +1 -1
  248. package/dist/cjs/QueryBuilder/Rule/Value/TextValue/TextValue.styles.cjs.map +1 -1
  249. package/dist/cjs/QueryBuilder/Rule/Value/Value.cjs.map +1 -1
  250. package/dist/cjs/QueryBuilder/RuleGroup/RuleGroup.cjs.map +1 -1
  251. package/dist/cjs/QueryBuilder/utils/index.cjs.map +1 -1
  252. package/dist/cjs/QueryBuilder/utils/reducer.cjs.map +1 -1
  253. package/dist/cjs/Radio/Radio.cjs +4 -2
  254. package/dist/cjs/Radio/Radio.cjs.map +1 -1
  255. package/dist/cjs/Radio/Radio.styles.cjs +4 -2
  256. package/dist/cjs/Radio/Radio.styles.cjs.map +1 -1
  257. package/dist/cjs/RadioGroup/RadioGroup.cjs +1 -1
  258. package/dist/cjs/RadioGroup/RadioGroup.cjs.map +1 -1
  259. package/dist/cjs/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.cjs +1 -1
  260. package/dist/cjs/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.cjs.map +1 -1
  261. package/dist/cjs/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.styles.cjs +1 -1
  262. package/dist/cjs/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.styles.cjs.map +1 -1
  263. package/dist/cjs/ScrollTo/Horizontal/ScrollToHorizontal.cjs +3 -3
  264. package/dist/cjs/ScrollTo/Horizontal/ScrollToHorizontal.cjs.map +1 -1
  265. package/dist/cjs/ScrollTo/Horizontal/ScrollToHorizontal.styles.cjs.map +1 -1
  266. package/dist/cjs/ScrollTo/Vertical/ScrollToVertical.cjs +1 -1
  267. package/dist/cjs/ScrollTo/Vertical/ScrollToVertical.cjs.map +1 -1
  268. package/dist/cjs/ScrollTo/Vertical/ScrollToVertical.styles.cjs.map +1 -1
  269. package/dist/cjs/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.cjs +1 -1
  270. package/dist/cjs/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.cjs.map +1 -1
  271. package/dist/cjs/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.styles.cjs +1 -1
  272. package/dist/cjs/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.styles.cjs.map +1 -1
  273. package/dist/cjs/ScrollTo/useScrollTo.cjs.map +1 -1
  274. package/dist/cjs/ScrollTo/utils.cjs.map +1 -1
  275. package/dist/cjs/ScrollTo/withTooltip.cjs.map +1 -1
  276. package/dist/cjs/Section/Section.cjs +1 -1
  277. package/dist/cjs/Section/Section.cjs.map +1 -1
  278. package/dist/cjs/Select/Option.cjs.map +1 -1
  279. package/dist/cjs/Select/OptionGroup.cjs +1 -1
  280. package/dist/cjs/Select/OptionGroup.cjs.map +1 -1
  281. package/dist/cjs/Select/Select.cjs +5 -5
  282. package/dist/cjs/Select/Select.cjs.map +1 -1
  283. package/dist/cjs/SelectionList/SelectionList.cjs +2 -2
  284. package/dist/cjs/SelectionList/SelectionList.cjs.map +1 -1
  285. package/dist/cjs/SimpleGrid/SimpleGrid.cjs.map +1 -1
  286. package/dist/cjs/SimpleGrid/SimpleGrid.styles.cjs.map +1 -1
  287. package/dist/cjs/Skeleton/Skeleton.cjs.map +1 -1
  288. package/dist/cjs/Slider/Slider.cjs +4 -4
  289. package/dist/cjs/Slider/Slider.cjs.map +1 -1
  290. package/dist/cjs/Slider/Slider.styles.cjs +1 -1
  291. package/dist/cjs/Slider/Slider.styles.cjs.map +1 -1
  292. package/dist/cjs/Slider/SliderInput/SliderInput.cjs.map +1 -1
  293. package/dist/cjs/Slider/utils.cjs.map +1 -1
  294. package/dist/cjs/Snackbar/Snackbar.cjs.map +1 -1
  295. package/dist/cjs/Snackbar/Snackbar.styles.cjs +1 -1
  296. package/dist/cjs/Snackbar/Snackbar.styles.cjs.map +1 -1
  297. package/dist/cjs/Snackbar/SnackbarContent/SnackbarContent.cjs +3 -3
  298. package/dist/cjs/Snackbar/SnackbarContent/SnackbarContent.cjs.map +1 -1
  299. package/dist/cjs/Snackbar/SnackbarContent/SnackbarContent.styles.cjs.map +1 -1
  300. package/dist/cjs/SnackbarProvider/SnackbarProvider.cjs.map +1 -1
  301. package/dist/cjs/SnackbarProvider/SnackbarProvider.styles.cjs.map +1 -1
  302. package/dist/cjs/Stack/Stack.cjs +2 -2
  303. package/dist/cjs/Stack/Stack.cjs.map +1 -1
  304. package/dist/cjs/Switch/Switch.cjs +2 -2
  305. package/dist/cjs/Switch/Switch.cjs.map +1 -1
  306. package/dist/cjs/Tab/Tab.cjs.map +1 -1
  307. package/dist/cjs/Table/Table.cjs +1 -1
  308. package/dist/cjs/Table/Table.cjs.map +1 -1
  309. package/dist/cjs/Table/TableBody/TableBody.cjs.map +1 -1
  310. package/dist/cjs/Table/TableCell/TableCell.cjs +1 -1
  311. package/dist/cjs/Table/TableCell/TableCell.cjs.map +1 -1
  312. package/dist/cjs/Table/TableContainer/TableContainer.cjs.map +1 -1
  313. package/dist/cjs/Table/TableHead/TableHead.cjs.map +1 -1
  314. package/dist/cjs/Table/TableHeader/TableHeader.cjs +2 -2
  315. package/dist/cjs/Table/TableHeader/TableHeader.cjs.map +1 -1
  316. package/dist/cjs/Table/TableHeader/utils.cjs.map +1 -1
  317. package/dist/cjs/Table/TableRow/TableRow.cjs.map +1 -1
  318. package/dist/cjs/Table/TableRow/TableRow.styles.cjs.map +1 -1
  319. package/dist/cjs/Table/hooks/useBulkActions.cjs.map +1 -1
  320. package/dist/cjs/Table/hooks/useFilters.cjs.map +1 -1
  321. package/dist/cjs/Table/hooks/useGlobalFilter.cjs.map +1 -1
  322. package/dist/cjs/Table/hooks/useHeaderGroups.cjs.map +1 -1
  323. package/dist/cjs/Table/hooks/usePagination.cjs.map +1 -1
  324. package/dist/cjs/Table/hooks/useResizeColumns.cjs.map +1 -1
  325. package/dist/cjs/Table/hooks/useRowExpand.cjs.map +1 -1
  326. package/dist/cjs/Table/hooks/useRowSelection.cjs.map +1 -1
  327. package/dist/cjs/Table/hooks/useRowState.cjs.map +1 -1
  328. package/dist/cjs/Table/hooks/useSortBy.cjs.map +1 -1
  329. package/dist/cjs/Table/hooks/useSticky.cjs.map +1 -1
  330. package/dist/cjs/Table/hooks/useTable.cjs.map +1 -1
  331. package/dist/cjs/Table/hooks/useTableStyles.cjs.map +1 -1
  332. package/dist/cjs/Table/renderers/DateColumnCell/DateColumnCell.cjs.map +1 -1
  333. package/dist/cjs/Table/renderers/DropdownColumnCell/DropdownColumnCell.cjs.map +1 -1
  334. package/dist/cjs/Table/renderers/ProgressColumnCell/ProgressColumnCell.styles.cjs.map +1 -1
  335. package/dist/cjs/Table/renderers/SwitchColumnCell/SwitchColumnCell.cjs.map +1 -1
  336. package/dist/cjs/Table/renderers/SwitchColumnCell/SwitchColumnCell.styles.cjs.map +1 -1
  337. package/dist/cjs/Table/renderers/renderers.cjs.map +1 -1
  338. package/dist/cjs/TableSection/TableSection.cjs.map +1 -1
  339. package/dist/cjs/TableSection/TableSection.styles.cjs.map +1 -1
  340. package/dist/cjs/Tabs/Tabs.cjs.map +1 -1
  341. package/dist/cjs/Tag/Tag.cjs +3 -3
  342. package/dist/cjs/Tag/Tag.cjs.map +1 -1
  343. package/dist/cjs/Tag/Tag.styles.cjs +2 -2
  344. package/dist/cjs/Tag/Tag.styles.cjs.map +1 -1
  345. package/dist/cjs/TagsInput/TagsInput.cjs +4 -4
  346. package/dist/cjs/TagsInput/TagsInput.cjs.map +1 -1
  347. package/dist/cjs/TagsInput/TagsInput.styles.cjs.map +1 -1
  348. package/dist/cjs/TextArea/TextArea.cjs +4 -4
  349. package/dist/cjs/TextArea/TextArea.cjs.map +1 -1
  350. package/dist/cjs/TimeAgo/TimeAgo.cjs.map +1 -1
  351. package/dist/cjs/TimeAgo/formatUtils.cjs.map +1 -1
  352. package/dist/cjs/TimeAgo/useTimeAgo.cjs +1 -1
  353. package/dist/cjs/TimeAgo/useTimeAgo.cjs.map +1 -1
  354. package/dist/cjs/TimePicker/Placeholder.cjs.map +1 -1
  355. package/dist/cjs/TimePicker/TimePicker.cjs +1 -1
  356. package/dist/cjs/TimePicker/TimePicker.cjs.map +1 -1
  357. package/dist/cjs/TimePicker/Unit/Unit.cjs.map +1 -1
  358. package/dist/cjs/ToggleButton/ToggleButton.cjs.map +1 -1
  359. package/dist/cjs/Tooltip/Tooltip.cjs +3 -3
  360. package/dist/cjs/Tooltip/Tooltip.cjs.map +1 -1
  361. package/dist/cjs/Tooltip/Tooltip.styles.cjs +1 -1
  362. package/dist/cjs/Tooltip/Tooltip.styles.cjs.map +1 -1
  363. package/dist/cjs/TreeView/TreeItem/DefaultContent.cjs.map +1 -1
  364. package/dist/cjs/TreeView/TreeItem/TreeItem.cjs +3 -3
  365. package/dist/cjs/TreeView/TreeItem/TreeItem.cjs.map +1 -1
  366. package/dist/cjs/TreeView/TreeItem/useHvTreeItem.cjs.map +1 -1
  367. package/dist/cjs/TreeView/TreeView.cjs +1 -1
  368. package/dist/cjs/TreeView/TreeView.cjs.map +1 -1
  369. package/dist/cjs/TreeView/internals/DescendantProvider.cjs.map +1 -1
  370. package/dist/cjs/TreeView/internals/TreeViewProvider.cjs.map +1 -1
  371. package/dist/cjs/TreeView/internals/hooks/plugins/defaultPlugins.cjs +3 -3
  372. package/dist/cjs/TreeView/internals/hooks/plugins/defaultPlugins.cjs.map +1 -1
  373. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewExpansion.cjs.map +1 -1
  374. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewFocus.cjs +1 -1
  375. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewFocus.cjs.map +1 -1
  376. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewKeyboardNavigation.cjs.map +1 -1
  377. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewNodes.cjs +1 -1
  378. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewNodes.cjs.map +1 -1
  379. package/dist/cjs/TreeView/internals/hooks/plugins/useTreeViewSelection.cjs.map +1 -1
  380. package/dist/cjs/TreeView/internals/hooks/useInstanceEventHandler.cjs +1 -1
  381. package/dist/cjs/TreeView/internals/hooks/useInstanceEventHandler.cjs.map +1 -1
  382. package/dist/cjs/TreeView/internals/hooks/useTreeView.cjs +1 -1
  383. package/dist/cjs/TreeView/internals/hooks/useTreeView.cjs.map +1 -1
  384. package/dist/cjs/TreeView/internals/hooks/useTreeViewInstanceEvents.cjs.map +1 -1
  385. package/dist/cjs/TreeView/internals/hooks/useTreeViewModels.cjs.map +1 -1
  386. package/dist/cjs/TreeView/internals/hooks/utils.cjs.map +1 -1
  387. package/dist/cjs/TreeView/internals/utils/EventManager.cjs.map +1 -1
  388. package/dist/cjs/TreeView/internals/utils/FinalizationRegistryBasedCleanupTracking.cjs.map +1 -1
  389. package/dist/cjs/TreeView/internals/utils/TimerBasedCleanupTracking.cjs.map +1 -1
  390. package/dist/cjs/TreeView/internals/utils/publishTreeViewEvent.cjs.map +1 -1
  391. package/dist/cjs/Typography/Typography.cjs +3 -3
  392. package/dist/cjs/Typography/Typography.cjs.map +1 -1
  393. package/dist/cjs/VerticalNavigation/Actions/Action.cjs.map +1 -1
  394. package/dist/cjs/VerticalNavigation/Actions/Action.styles.cjs +1 -1
  395. package/dist/cjs/VerticalNavigation/Actions/Action.styles.cjs.map +1 -1
  396. package/dist/cjs/VerticalNavigation/Actions/Actions.cjs.map +1 -1
  397. package/dist/cjs/VerticalNavigation/Actions/Actions.styles.cjs.map +1 -1
  398. package/dist/cjs/VerticalNavigation/Header/Header.cjs.map +1 -1
  399. package/dist/cjs/VerticalNavigation/Header/Header.styles.cjs.map +1 -1
  400. package/dist/cjs/VerticalNavigation/Navigation/Navigation.cjs +5 -5
  401. package/dist/cjs/VerticalNavigation/Navigation/Navigation.cjs.map +1 -1
  402. package/dist/cjs/VerticalNavigation/Navigation/Navigation.styles.cjs.map +1 -1
  403. package/dist/cjs/VerticalNavigation/NavigationPopup/NavigationPopup.styles.cjs +1 -1
  404. package/dist/cjs/VerticalNavigation/NavigationPopup/NavigationPopup.styles.cjs.map +1 -1
  405. package/dist/cjs/VerticalNavigation/NavigationPopup/NavigationPopupContainer.cjs.map +1 -1
  406. package/dist/cjs/VerticalNavigation/NavigationSlider/NavigationSlider.cjs.map +1 -1
  407. package/dist/cjs/VerticalNavigation/NavigationSlider/NavigationSlider.styles.cjs.map +1 -1
  408. package/dist/cjs/VerticalNavigation/NavigationSlider/utils/NavigationSlider.utils.cjs.map +1 -1
  409. package/dist/cjs/VerticalNavigation/TreeView/IconWrapper/IconWrapper.cjs.map +1 -1
  410. package/dist/cjs/VerticalNavigation/TreeView/IconWrapper/IconWrapper.styles.cjs.map +1 -1
  411. package/dist/cjs/VerticalNavigation/TreeView/TreeView.cjs +2 -2
  412. package/dist/cjs/VerticalNavigation/TreeView/TreeView.cjs.map +1 -1
  413. package/dist/cjs/VerticalNavigation/TreeView/TreeView.styles.cjs.map +1 -1
  414. package/dist/cjs/VerticalNavigation/TreeView/TreeViewItem.cjs +3 -3
  415. package/dist/cjs/VerticalNavigation/TreeView/TreeViewItem.cjs.map +1 -1
  416. package/dist/cjs/VerticalNavigation/TreeView/TreeViewItem.styles.cjs +1 -1
  417. package/dist/cjs/VerticalNavigation/TreeView/TreeViewItem.styles.cjs.map +1 -1
  418. package/dist/cjs/VerticalNavigation/TreeView/descendants.cjs.map +1 -1
  419. package/dist/cjs/VerticalNavigation/VerticalNavigation.cjs +1 -1
  420. package/dist/cjs/VerticalNavigation/VerticalNavigation.cjs.map +1 -1
  421. package/dist/cjs/VerticalNavigation/VerticalNavigation.styles.cjs.map +1 -1
  422. package/dist/cjs/VerticalNavigation/VerticalNavigationContext.cjs.map +1 -1
  423. package/dist/cjs/hocs/withTooltip.cjs.map +1 -1
  424. package/dist/cjs/hooks/useClickOutside.cjs.map +1 -1
  425. package/dist/cjs/hooks/useComputation.cjs.map +1 -1
  426. package/dist/cjs/hooks/useControlled.cjs.map +1 -1
  427. package/dist/cjs/hooks/useCss.cjs +1 -1
  428. package/dist/cjs/hooks/useCss.cjs.map +1 -1
  429. package/dist/cjs/hooks/useDefaultProps.cjs +19 -13
  430. package/dist/cjs/hooks/useDefaultProps.cjs.map +1 -1
  431. package/dist/cjs/hooks/useEmotionCache.cjs +2 -2
  432. package/dist/cjs/hooks/useTheme.cjs +2 -2
  433. package/dist/cjs/hooks/useWidth.cjs +1 -1
  434. package/dist/cjs/hooks/useWidth.cjs.map +1 -1
  435. package/dist/cjs/index.cjs +4 -0
  436. package/dist/cjs/index.cjs.map +1 -1
  437. package/dist/cjs/providers/Provider.cjs +1 -1
  438. package/dist/cjs/providers/Provider.cjs.map +1 -1
  439. package/dist/cjs/providers/ThemeProvider.cjs +2 -2
  440. package/dist/cjs/providers/ThemeProvider.cjs.map +1 -1
  441. package/dist/cjs/types/generic.cjs.map +1 -1
  442. package/dist/cjs/utils/classes.cjs.map +1 -1
  443. package/dist/cjs/utils/hexToRgbA.cjs.map +1 -1
  444. package/dist/cjs/utils/iconVariant.cjs.map +1 -1
  445. package/dist/cjs/utils/multiSelectionEventHandler.cjs.map +1 -1
  446. package/dist/cjs/utils/theme.cjs.map +1 -1
  447. package/dist/cjs/utils/useSavedState.cjs.map +1 -1
  448. package/dist/cjs/utils/wrapperTooltip.cjs.map +1 -1
  449. package/dist/esm/Accordion/Accordion.js +1 -1
  450. package/dist/esm/Accordion/Accordion.js.map +1 -1
  451. package/dist/esm/Accordion/Accordion.styles.js +1 -1
  452. package/dist/esm/Accordion/Accordion.styles.js.map +1 -1
  453. package/dist/esm/ActionBar/ActionBar.js.map +1 -1
  454. package/dist/esm/ActionsGeneric/ActionsGeneric.js.map +1 -1
  455. package/dist/esm/AppSwitcher/Action/Action.js +1 -1
  456. package/dist/esm/AppSwitcher/Action/Action.js.map +1 -1
  457. package/dist/esm/AppSwitcher/Action/Action.styles.js.map +1 -1
  458. package/dist/esm/AppSwitcher/AppSwitcher.js.map +1 -1
  459. package/dist/esm/Avatar/Avatar.js +1 -1
  460. package/dist/esm/Avatar/Avatar.js.map +1 -1
  461. package/dist/esm/Avatar/Avatar.styles.js +1 -1
  462. package/dist/esm/Avatar/Avatar.styles.js.map +1 -1
  463. package/dist/esm/AvatarGroup/AvatarGroup.js +1 -1
  464. package/dist/esm/AvatarGroup/AvatarGroup.js.map +1 -1
  465. package/dist/esm/AvatarGroup/AvatarGroup.styles.js +1 -1
  466. package/dist/esm/AvatarGroup/AvatarGroup.styles.js.map +1 -1
  467. package/dist/esm/Badge/Badge.js.map +1 -1
  468. package/dist/esm/Banner/Banner.js +1 -1
  469. package/dist/esm/Banner/Banner.js.map +1 -1
  470. package/dist/esm/Banner/BannerContent/ActionContainer/ActionContainer.js.map +1 -1
  471. package/dist/esm/Banner/BannerContent/BannerContent.js.map +1 -1
  472. package/dist/esm/Banner/BannerContent/MessageContainer/MessageContainer.js.map +1 -1
  473. package/dist/esm/BaseCheckBox/BaseCheckBox.js +13 -10
  474. package/dist/esm/BaseCheckBox/BaseCheckBox.js.map +1 -1
  475. package/dist/esm/BaseCheckBox/BaseCheckBox.styles.js +55 -7
  476. package/dist/esm/BaseCheckBox/BaseCheckBox.styles.js.map +1 -1
  477. package/dist/esm/BaseCheckBox/icons.js +21 -0
  478. package/dist/esm/BaseCheckBox/icons.js.map +1 -0
  479. package/dist/esm/BaseDropdown/BaseDropdown.js +6 -6
  480. package/dist/esm/BaseDropdown/BaseDropdown.js.map +1 -1
  481. package/dist/esm/BaseDropdown/BaseDropdown.styles.js +1 -1
  482. package/dist/esm/BaseDropdown/BaseDropdown.styles.js.map +1 -1
  483. package/dist/esm/BaseInput/BaseInput.js +1 -1
  484. package/dist/esm/BaseInput/BaseInput.js.map +1 -1
  485. package/dist/esm/BaseInput/BaseInput.styles.js +1 -1
  486. package/dist/esm/BaseInput/BaseInput.styles.js.map +1 -1
  487. package/dist/esm/BaseInput/validations.js.map +1 -1
  488. package/dist/esm/BaseRadio/BaseRadio.js +12 -11
  489. package/dist/esm/BaseRadio/BaseRadio.js.map +1 -1
  490. package/dist/esm/BaseRadio/BaseRadio.styles.js +40 -5
  491. package/dist/esm/BaseRadio/BaseRadio.styles.js.map +1 -1
  492. package/dist/esm/BaseRadio/icons.js +17 -0
  493. package/dist/esm/BaseRadio/icons.js.map +1 -0
  494. package/dist/esm/BaseSwitch/BaseSwitch.js.map +1 -1
  495. package/dist/esm/BaseSwitch/BaseSwitch.styles.js +1 -1
  496. package/dist/esm/BaseSwitch/BaseSwitch.styles.js.map +1 -1
  497. package/dist/esm/Box/Box.js.map +1 -1
  498. package/dist/esm/BreadCrumb/BreadCrumb.js.map +1 -1
  499. package/dist/esm/BreadCrumb/Page/Page.js.map +1 -1
  500. package/dist/esm/BreadCrumb/PathElement/PathElement.js.map +1 -1
  501. package/dist/esm/BreadCrumb/utils.js.map +1 -1
  502. package/dist/esm/BulkActions/BulkActions.js +1 -1
  503. package/dist/esm/BulkActions/BulkActions.js.map +1 -1
  504. package/dist/esm/BulkActions/BulkActions.styles.js.map +1 -1
  505. package/dist/esm/Button/Button.js +1 -1
  506. package/dist/esm/Button/Button.js.map +1 -1
  507. package/dist/esm/Button/Button.styles.js +1 -1
  508. package/dist/esm/Button/Button.styles.js.map +1 -1
  509. package/dist/esm/Calendar/Calendar.js +1 -1
  510. package/dist/esm/Calendar/Calendar.js.map +1 -1
  511. package/dist/esm/Calendar/CalendarHeader/CalendarHeader.js +2 -2
  512. package/dist/esm/Calendar/CalendarHeader/CalendarHeader.js.map +1 -1
  513. package/dist/esm/Calendar/CalendarNavigation/ComposedNavigation/ComposedNavigation.js.map +1 -1
  514. package/dist/esm/Calendar/CalendarNavigation/ComposedNavigation/ComposedNavigation.styles.js.map +1 -1
  515. package/dist/esm/Calendar/CalendarNavigation/MonthSelector/MonthSelector.js.map +1 -1
  516. package/dist/esm/Calendar/CalendarNavigation/MonthSelector/MonthSelector.styles.js +1 -1
  517. package/dist/esm/Calendar/CalendarNavigation/MonthSelector/MonthSelector.styles.js.map +1 -1
  518. package/dist/esm/Calendar/CalendarNavigation/Navigation/Navigation.js.map +1 -1
  519. package/dist/esm/Calendar/SingleCalendar/CalendarCell.js.map +1 -1
  520. package/dist/esm/Calendar/SingleCalendar/CalendarCell.styles.js +1 -1
  521. package/dist/esm/Calendar/SingleCalendar/CalendarCell.styles.js.map +1 -1
  522. package/dist/esm/Calendar/SingleCalendar/SingleCalendar.js +2 -2
  523. package/dist/esm/Calendar/SingleCalendar/SingleCalendar.js.map +1 -1
  524. package/dist/esm/Calendar/model.js.map +1 -1
  525. package/dist/esm/Calendar/utils.js.map +1 -1
  526. package/dist/esm/Card/Card.js.map +1 -1
  527. package/dist/esm/Card/Card.styles.js +1 -1
  528. package/dist/esm/Card/Card.styles.js.map +1 -1
  529. package/dist/esm/Card/Content/Content.js.map +1 -1
  530. package/dist/esm/Card/Header/Header.js.map +1 -1
  531. package/dist/esm/Card/Media/Media.js.map +1 -1
  532. package/dist/esm/Carousel/Carousel.js +2 -2
  533. package/dist/esm/Carousel/Carousel.js.map +1 -1
  534. package/dist/esm/Carousel/CarouselControls.js.map +1 -1
  535. package/dist/esm/Carousel/CarouselSlide/CarouselSlide.js.map +1 -1
  536. package/dist/esm/Carousel/CarouselThumbnails.js.map +1 -1
  537. package/dist/esm/CheckBox/CheckBox.js +5 -2
  538. package/dist/esm/CheckBox/CheckBox.js.map +1 -1
  539. package/dist/esm/CheckBox/CheckBox.styles.js +5 -2
  540. package/dist/esm/CheckBox/CheckBox.styles.js.map +1 -1
  541. package/dist/esm/CheckBoxGroup/CheckBoxGroup.js +2 -2
  542. package/dist/esm/CheckBoxGroup/CheckBoxGroup.js.map +1 -1
  543. package/dist/esm/ColorPicker/ColorPicker.js +2 -2
  544. package/dist/esm/ColorPicker/ColorPicker.js.map +1 -1
  545. package/dist/esm/ColorPicker/Fields/Fields.js.map +1 -1
  546. package/dist/esm/ColorPicker/Picker/Picker.js +2 -2
  547. package/dist/esm/ColorPicker/Picker/Picker.js.map +1 -1
  548. package/dist/esm/ColorPicker/PresetColors/PresetColors.js.map +1 -1
  549. package/dist/esm/ColorPicker/SavedColors/SavedColors.js +1 -1
  550. package/dist/esm/ColorPicker/SavedColors/SavedColors.js.map +1 -1
  551. package/dist/esm/Container/Container.js +2 -2
  552. package/dist/esm/Container/Container.js.map +1 -1
  553. package/dist/esm/Controls/Controls.js +1 -1
  554. package/dist/esm/Controls/Controls.js.map +1 -1
  555. package/dist/esm/Controls/LeftControl/LeftControl.js +1 -1
  556. package/dist/esm/Controls/LeftControl/LeftControl.js.map +1 -1
  557. package/dist/esm/Controls/RightControl/RightControl.js +1 -1
  558. package/dist/esm/Controls/RightControl/RightControl.js.map +1 -1
  559. package/dist/esm/DatePicker/DatePicker.js +5 -5
  560. package/dist/esm/DatePicker/DatePicker.js.map +1 -1
  561. package/dist/esm/DatePicker/useVisibleDate.js +4 -1
  562. package/dist/esm/DatePicker/useVisibleDate.js.map +1 -1
  563. package/dist/esm/DatePicker/utils.js.map +1 -1
  564. package/dist/esm/Dialog/Actions/Actions.js +1 -1
  565. package/dist/esm/Dialog/Actions/Actions.js.map +1 -1
  566. package/dist/esm/Dialog/Content/Content.js.map +1 -1
  567. package/dist/esm/Dialog/Dialog.js +2 -2
  568. package/dist/esm/Dialog/Dialog.js.map +1 -1
  569. package/dist/esm/Dialog/Title/Title.js.map +1 -1
  570. package/dist/esm/DotPagination/DotPagination.js +1 -1
  571. package/dist/esm/DotPagination/DotPagination.js.map +1 -1
  572. package/dist/esm/DotPagination/DotPagination.styles.js +11 -3
  573. package/dist/esm/DotPagination/DotPagination.styles.js.map +1 -1
  574. package/dist/esm/Drawer/Drawer.js.map +1 -1
  575. package/dist/esm/DropDownMenu/DropDownMenu.js +2 -2
  576. package/dist/esm/DropDownMenu/DropDownMenu.js.map +1 -1
  577. package/dist/esm/Dropdown/Dropdown.js +3 -3
  578. package/dist/esm/Dropdown/Dropdown.js.map +1 -1
  579. package/dist/esm/Dropdown/List/List.js +2 -2
  580. package/dist/esm/Dropdown/List/List.js.map +1 -1
  581. package/dist/esm/Dropdown/utils.js.map +1 -1
  582. package/dist/esm/DropdownButton/DropdownButton.js.map +1 -1
  583. package/dist/esm/DropdownButton/DropdownButton.styles.js.map +1 -1
  584. package/dist/esm/EmptyState/EmptyState.js.map +1 -1
  585. package/dist/esm/FileUploader/DropZone/DropZone.js +2 -2
  586. package/dist/esm/FileUploader/DropZone/DropZone.js.map +1 -1
  587. package/dist/esm/FileUploader/File/File.js +1 -1
  588. package/dist/esm/FileUploader/File/File.js.map +1 -1
  589. package/dist/esm/FileUploader/FileList/FileList.js +1 -1
  590. package/dist/esm/FileUploader/FileList/FileList.js.map +1 -1
  591. package/dist/esm/FileUploader/FileUploader.js +1 -1
  592. package/dist/esm/FileUploader/FileUploader.js.map +1 -1
  593. package/dist/esm/FileUploader/Preview/Preview.js.map +1 -1
  594. package/dist/esm/FileUploader/Preview/Preview.styles.js.map +1 -1
  595. package/dist/esm/FilterGroup/Counter/Counter.js.map +1 -1
  596. package/dist/esm/FilterGroup/FilterContent/FilterContent.js +2 -2
  597. package/dist/esm/FilterGroup/FilterContent/FilterContent.js.map +1 -1
  598. package/dist/esm/FilterGroup/FilterGroup.js +2 -2
  599. package/dist/esm/FilterGroup/FilterGroup.js.map +1 -1
  600. package/dist/esm/FilterGroup/FilterGroupContext.js +1 -1
  601. package/dist/esm/FilterGroup/FilterGroupContext.js.map +1 -1
  602. package/dist/esm/FilterGroup/RightPanel/RightPanel.js.map +1 -1
  603. package/dist/esm/Focus/Focus.js +2 -2
  604. package/dist/esm/Focus/Focus.js.map +1 -1
  605. package/dist/esm/Focus/Focus.styles.js +1 -1
  606. package/dist/esm/Focus/Focus.styles.js.map +1 -1
  607. package/dist/esm/Footer/Footer.js.map +1 -1
  608. package/dist/esm/Forms/Adornment/Adornment.js.map +1 -1
  609. package/dist/esm/Forms/Adornment/Adornment.styles.js +1 -1
  610. package/dist/esm/Forms/Adornment/Adornment.styles.js.map +1 -1
  611. package/dist/esm/Forms/CharCounter/CharCounter.js.map +1 -1
  612. package/dist/esm/Forms/FormElement/FormElement.js +2 -2
  613. package/dist/esm/Forms/FormElement/FormElement.js.map +1 -1
  614. package/dist/esm/Forms/FormElement/utils/FormUtils.js.map +1 -1
  615. package/dist/esm/Forms/InfoMessage/InfoMessage.js.map +1 -1
  616. package/dist/esm/Forms/Label/Label.js.map +1 -1
  617. package/dist/esm/Forms/Suggestions/Suggestions.js +1 -1
  618. package/dist/esm/Forms/Suggestions/Suggestions.js.map +1 -1
  619. package/dist/esm/Forms/WarningText/WarningText.js.map +1 -1
  620. package/dist/esm/GlobalActions/GlobalActions.js.map +1 -1
  621. package/dist/esm/GlobalActions/GlobalActions.styles.js.map +1 -1
  622. package/dist/esm/Grid/Grid.js.map +1 -1
  623. package/dist/esm/Header/Actions/Actions.js.map +1 -1
  624. package/dist/esm/Header/Brand/Brand.js.map +1 -1
  625. package/dist/esm/Header/Header.js.map +1 -1
  626. package/dist/esm/Header/Navigation/MenuBar/Bar.js.map +1 -1
  627. package/dist/esm/Header/Navigation/MenuBar/MenuBar.js.map +1 -1
  628. package/dist/esm/Header/Navigation/MenuItem/MenuItem.js +2 -2
  629. package/dist/esm/Header/Navigation/MenuItem/MenuItem.js.map +1 -1
  630. package/dist/esm/Header/Navigation/MenuItem/MenuItem.styles.js +1 -1
  631. package/dist/esm/Header/Navigation/MenuItem/MenuItem.styles.js.map +1 -1
  632. package/dist/esm/Header/Navigation/Navigation.js +1 -1
  633. package/dist/esm/Header/Navigation/Navigation.js.map +1 -1
  634. package/dist/esm/Header/Navigation/Navigation.styles.js.map +1 -1
  635. package/dist/esm/Header/Navigation/useSelectionPath.js.map +1 -1
  636. package/dist/esm/Header/Navigation/utils/FocusContext.js.map +1 -1
  637. package/dist/esm/IconButton/IconButton.js +1 -1
  638. package/dist/esm/IconButton/IconButton.js.map +1 -1
  639. package/dist/esm/InlineEditor/InlineEditor.js +1 -1
  640. package/dist/esm/InlineEditor/InlineEditor.js.map +1 -1
  641. package/dist/esm/InlineEditor/InlineEditor.styles.js.map +1 -1
  642. package/dist/esm/Input/Input.js +6 -6
  643. package/dist/esm/Input/Input.js.map +1 -1
  644. package/dist/esm/Kpi/Kpi.js.map +1 -1
  645. package/dist/esm/Link/Link.js.map +1 -1
  646. package/dist/esm/Link/Link.styles.js +1 -1
  647. package/dist/esm/Link/Link.styles.js.map +1 -1
  648. package/dist/esm/List/List.js.map +1 -1
  649. package/dist/esm/List/List.styles.js +1 -1
  650. package/dist/esm/List/List.styles.js.map +1 -1
  651. package/dist/esm/List/useSelectableList.js.map +1 -1
  652. package/dist/esm/List/utils.js.map +1 -1
  653. package/dist/esm/ListContainer/ListContainer.js +1 -1
  654. package/dist/esm/ListContainer/ListContainer.js.map +1 -1
  655. package/dist/esm/ListContainer/ListItem/ListItem.js.map +1 -1
  656. package/dist/esm/ListContainer/ListItem/ListItem.styles.js +1 -1
  657. package/dist/esm/ListContainer/ListItem/ListItem.styles.js.map +1 -1
  658. package/dist/esm/Loading/Loading.js +1 -1
  659. package/dist/esm/Loading/Loading.js.map +1 -1
  660. package/dist/esm/Loading/Loading.styles.js.map +1 -1
  661. package/dist/esm/LoadingContainer/LoadingContainer.js +38 -0
  662. package/dist/esm/LoadingContainer/LoadingContainer.js.map +1 -0
  663. package/dist/esm/LoadingContainer/LoadingContainer.styles.js +20 -0
  664. package/dist/esm/LoadingContainer/LoadingContainer.styles.js.map +1 -0
  665. package/dist/esm/Login/Login.js.map +1 -1
  666. package/dist/esm/MultiButton/MultiButton.js.map +1 -1
  667. package/dist/esm/MultiButton/MultiButton.styles.js +1 -1
  668. package/dist/esm/MultiButton/MultiButton.styles.js.map +1 -1
  669. package/dist/esm/OverflowTooltip/OverflowTooltip.js.map +1 -1
  670. package/dist/esm/OverflowTooltip/OverflowTooltip.styles.js.map +1 -1
  671. package/dist/esm/Pagination/Pagination.js +3 -3
  672. package/dist/esm/Pagination/Pagination.js.map +1 -1
  673. package/dist/esm/Pagination/Pagination.styles.js.map +1 -1
  674. package/dist/esm/Pagination/Select.js.map +1 -1
  675. package/dist/esm/Pagination/utils.js.map +1 -1
  676. package/dist/esm/Panel/Panel.js.map +1 -1
  677. package/dist/esm/ProgressBar/ProgressBar.js.map +1 -1
  678. package/dist/esm/QueryBuilder/ConfirmationDialog/ConfirmationDialog.js.map +1 -1
  679. package/dist/esm/QueryBuilder/ConfirmationDialog/ConfirmationDialog.styles.js.map +1 -1
  680. package/dist/esm/QueryBuilder/Context.js.map +1 -1
  681. package/dist/esm/QueryBuilder/QueryBuilder.js +3 -3
  682. package/dist/esm/QueryBuilder/QueryBuilder.js.map +1 -1
  683. package/dist/esm/QueryBuilder/Rule/Attribute/Attribute.js +1 -1
  684. package/dist/esm/QueryBuilder/Rule/Attribute/Attribute.js.map +1 -1
  685. package/dist/esm/QueryBuilder/Rule/Operator/Operator.js.map +1 -1
  686. package/dist/esm/QueryBuilder/Rule/Rule.js +1 -1
  687. package/dist/esm/QueryBuilder/Rule/Rule.js.map +1 -1
  688. package/dist/esm/QueryBuilder/Rule/Rule.styles.js.map +1 -1
  689. package/dist/esm/QueryBuilder/Rule/Value/BooleanValue/BooleanValue.js.map +1 -1
  690. package/dist/esm/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.js +2 -2
  691. package/dist/esm/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.js.map +1 -1
  692. package/dist/esm/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.js.map +1 -1
  693. package/dist/esm/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.js.map +1 -1
  694. package/dist/esm/QueryBuilder/Rule/Value/NumericValue/NumericValue.js.map +1 -1
  695. package/dist/esm/QueryBuilder/Rule/Value/TextValue/TextValue.js.map +1 -1
  696. package/dist/esm/QueryBuilder/Rule/Value/TextValue/TextValue.styles.js.map +1 -1
  697. package/dist/esm/QueryBuilder/Rule/Value/Value.js.map +1 -1
  698. package/dist/esm/QueryBuilder/RuleGroup/RuleGroup.js.map +1 -1
  699. package/dist/esm/QueryBuilder/utils/index.js.map +1 -1
  700. package/dist/esm/QueryBuilder/utils/reducer.js.map +1 -1
  701. package/dist/esm/Radio/Radio.js +4 -2
  702. package/dist/esm/Radio/Radio.js.map +1 -1
  703. package/dist/esm/Radio/Radio.styles.js +4 -2
  704. package/dist/esm/Radio/Radio.styles.js.map +1 -1
  705. package/dist/esm/RadioGroup/RadioGroup.js +1 -1
  706. package/dist/esm/RadioGroup/RadioGroup.js.map +1 -1
  707. package/dist/esm/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.js +1 -1
  708. package/dist/esm/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.js.map +1 -1
  709. package/dist/esm/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.styles.js +1 -1
  710. package/dist/esm/ScrollTo/Horizontal/HorizontalScrollListItem/HorizontalScrollListItem.styles.js.map +1 -1
  711. package/dist/esm/ScrollTo/Horizontal/ScrollToHorizontal.js +3 -3
  712. package/dist/esm/ScrollTo/Horizontal/ScrollToHorizontal.js.map +1 -1
  713. package/dist/esm/ScrollTo/Horizontal/ScrollToHorizontal.styles.js.map +1 -1
  714. package/dist/esm/ScrollTo/Vertical/ScrollToVertical.js +1 -1
  715. package/dist/esm/ScrollTo/Vertical/ScrollToVertical.js.map +1 -1
  716. package/dist/esm/ScrollTo/Vertical/ScrollToVertical.styles.js.map +1 -1
  717. package/dist/esm/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.js +1 -1
  718. package/dist/esm/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.js.map +1 -1
  719. package/dist/esm/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.styles.js +1 -1
  720. package/dist/esm/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.styles.js.map +1 -1
  721. package/dist/esm/ScrollTo/useScrollTo.js.map +1 -1
  722. package/dist/esm/ScrollTo/utils.js.map +1 -1
  723. package/dist/esm/ScrollTo/withTooltip.js.map +1 -1
  724. package/dist/esm/Section/Section.js +1 -1
  725. package/dist/esm/Section/Section.js.map +1 -1
  726. package/dist/esm/Select/Option.js.map +1 -1
  727. package/dist/esm/Select/OptionGroup.js +1 -1
  728. package/dist/esm/Select/OptionGroup.js.map +1 -1
  729. package/dist/esm/Select/Select.js +5 -5
  730. package/dist/esm/Select/Select.js.map +1 -1
  731. package/dist/esm/SelectionList/SelectionList.js +2 -2
  732. package/dist/esm/SelectionList/SelectionList.js.map +1 -1
  733. package/dist/esm/SimpleGrid/SimpleGrid.js.map +1 -1
  734. package/dist/esm/SimpleGrid/SimpleGrid.styles.js.map +1 -1
  735. package/dist/esm/Skeleton/Skeleton.js.map +1 -1
  736. package/dist/esm/Slider/Slider.js +4 -4
  737. package/dist/esm/Slider/Slider.js.map +1 -1
  738. package/dist/esm/Slider/Slider.styles.js +1 -1
  739. package/dist/esm/Slider/Slider.styles.js.map +1 -1
  740. package/dist/esm/Slider/SliderInput/SliderInput.js.map +1 -1
  741. package/dist/esm/Slider/utils.js.map +1 -1
  742. package/dist/esm/Snackbar/Snackbar.js.map +1 -1
  743. package/dist/esm/Snackbar/Snackbar.styles.js +1 -1
  744. package/dist/esm/Snackbar/Snackbar.styles.js.map +1 -1
  745. package/dist/esm/Snackbar/SnackbarContent/SnackbarContent.js +3 -3
  746. package/dist/esm/Snackbar/SnackbarContent/SnackbarContent.js.map +1 -1
  747. package/dist/esm/Snackbar/SnackbarContent/SnackbarContent.styles.js.map +1 -1
  748. package/dist/esm/SnackbarProvider/SnackbarProvider.js.map +1 -1
  749. package/dist/esm/SnackbarProvider/SnackbarProvider.styles.js.map +1 -1
  750. package/dist/esm/Stack/Stack.js +2 -2
  751. package/dist/esm/Stack/Stack.js.map +1 -1
  752. package/dist/esm/Switch/Switch.js +2 -2
  753. package/dist/esm/Switch/Switch.js.map +1 -1
  754. package/dist/esm/Tab/Tab.js.map +1 -1
  755. package/dist/esm/Table/Table.js +1 -1
  756. package/dist/esm/Table/Table.js.map +1 -1
  757. package/dist/esm/Table/TableBody/TableBody.js.map +1 -1
  758. package/dist/esm/Table/TableCell/TableCell.js +1 -1
  759. package/dist/esm/Table/TableCell/TableCell.js.map +1 -1
  760. package/dist/esm/Table/TableContainer/TableContainer.js.map +1 -1
  761. package/dist/esm/Table/TableHead/TableHead.js.map +1 -1
  762. package/dist/esm/Table/TableHeader/TableHeader.js +2 -2
  763. package/dist/esm/Table/TableHeader/TableHeader.js.map +1 -1
  764. package/dist/esm/Table/TableHeader/utils.js.map +1 -1
  765. package/dist/esm/Table/TableRow/TableRow.js.map +1 -1
  766. package/dist/esm/Table/TableRow/TableRow.styles.js.map +1 -1
  767. package/dist/esm/Table/hooks/useBulkActions.js.map +1 -1
  768. package/dist/esm/Table/hooks/useFilters.js.map +1 -1
  769. package/dist/esm/Table/hooks/useGlobalFilter.js.map +1 -1
  770. package/dist/esm/Table/hooks/useHeaderGroups.js.map +1 -1
  771. package/dist/esm/Table/hooks/usePagination.js.map +1 -1
  772. package/dist/esm/Table/hooks/useResizeColumns.js.map +1 -1
  773. package/dist/esm/Table/hooks/useRowExpand.js.map +1 -1
  774. package/dist/esm/Table/hooks/useRowSelection.js.map +1 -1
  775. package/dist/esm/Table/hooks/useRowState.js.map +1 -1
  776. package/dist/esm/Table/hooks/useSortBy.js.map +1 -1
  777. package/dist/esm/Table/hooks/useSticky.js.map +1 -1
  778. package/dist/esm/Table/hooks/useTable.js.map +1 -1
  779. package/dist/esm/Table/hooks/useTableStyles.js.map +1 -1
  780. package/dist/esm/Table/renderers/DateColumnCell/DateColumnCell.js.map +1 -1
  781. package/dist/esm/Table/renderers/DropdownColumnCell/DropdownColumnCell.js.map +1 -1
  782. package/dist/esm/Table/renderers/ProgressColumnCell/ProgressColumnCell.styles.js.map +1 -1
  783. package/dist/esm/Table/renderers/SwitchColumnCell/SwitchColumnCell.js.map +1 -1
  784. package/dist/esm/Table/renderers/SwitchColumnCell/SwitchColumnCell.styles.js.map +1 -1
  785. package/dist/esm/Table/renderers/renderers.js.map +1 -1
  786. package/dist/esm/TableSection/TableSection.js.map +1 -1
  787. package/dist/esm/TableSection/TableSection.styles.js.map +1 -1
  788. package/dist/esm/Tabs/Tabs.js.map +1 -1
  789. package/dist/esm/Tag/Tag.js +3 -3
  790. package/dist/esm/Tag/Tag.js.map +1 -1
  791. package/dist/esm/Tag/Tag.styles.js +2 -2
  792. package/dist/esm/Tag/Tag.styles.js.map +1 -1
  793. package/dist/esm/TagsInput/TagsInput.js +4 -4
  794. package/dist/esm/TagsInput/TagsInput.js.map +1 -1
  795. package/dist/esm/TagsInput/TagsInput.styles.js.map +1 -1
  796. package/dist/esm/TextArea/TextArea.js +4 -4
  797. package/dist/esm/TextArea/TextArea.js.map +1 -1
  798. package/dist/esm/TimeAgo/TimeAgo.js.map +1 -1
  799. package/dist/esm/TimeAgo/formatUtils.js.map +1 -1
  800. package/dist/esm/TimeAgo/useTimeAgo.js +1 -1
  801. package/dist/esm/TimeAgo/useTimeAgo.js.map +1 -1
  802. package/dist/esm/TimePicker/Placeholder.js.map +1 -1
  803. package/dist/esm/TimePicker/TimePicker.js +1 -1
  804. package/dist/esm/TimePicker/TimePicker.js.map +1 -1
  805. package/dist/esm/TimePicker/Unit/Unit.js.map +1 -1
  806. package/dist/esm/ToggleButton/ToggleButton.js.map +1 -1
  807. package/dist/esm/Tooltip/Tooltip.js +2 -2
  808. package/dist/esm/Tooltip/Tooltip.js.map +1 -1
  809. package/dist/esm/Tooltip/Tooltip.styles.js +1 -1
  810. package/dist/esm/Tooltip/Tooltip.styles.js.map +1 -1
  811. package/dist/esm/TreeView/TreeItem/DefaultContent.js.map +1 -1
  812. package/dist/esm/TreeView/TreeItem/TreeItem.js +3 -3
  813. package/dist/esm/TreeView/TreeItem/TreeItem.js.map +1 -1
  814. package/dist/esm/TreeView/TreeItem/useHvTreeItem.js.map +1 -1
  815. package/dist/esm/TreeView/TreeView.js +1 -1
  816. package/dist/esm/TreeView/TreeView.js.map +1 -1
  817. package/dist/esm/TreeView/internals/DescendantProvider.js.map +1 -1
  818. package/dist/esm/TreeView/internals/TreeViewProvider.js.map +1 -1
  819. package/dist/esm/TreeView/internals/hooks/plugins/defaultPlugins.js +3 -3
  820. package/dist/esm/TreeView/internals/hooks/plugins/defaultPlugins.js.map +1 -1
  821. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewExpansion.js.map +1 -1
  822. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewFocus.js +1 -1
  823. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewFocus.js.map +1 -1
  824. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewKeyboardNavigation.js.map +1 -1
  825. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewNodes.js +1 -1
  826. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewNodes.js.map +1 -1
  827. package/dist/esm/TreeView/internals/hooks/plugins/useTreeViewSelection.js.map +1 -1
  828. package/dist/esm/TreeView/internals/hooks/useInstanceEventHandler.js +1 -1
  829. package/dist/esm/TreeView/internals/hooks/useInstanceEventHandler.js.map +1 -1
  830. package/dist/esm/TreeView/internals/hooks/useTreeView.js +1 -1
  831. package/dist/esm/TreeView/internals/hooks/useTreeView.js.map +1 -1
  832. package/dist/esm/TreeView/internals/hooks/useTreeViewInstanceEvents.js.map +1 -1
  833. package/dist/esm/TreeView/internals/hooks/useTreeViewModels.js.map +1 -1
  834. package/dist/esm/TreeView/internals/hooks/utils.js.map +1 -1
  835. package/dist/esm/TreeView/internals/utils/EventManager.js.map +1 -1
  836. package/dist/esm/TreeView/internals/utils/FinalizationRegistryBasedCleanupTracking.js.map +1 -1
  837. package/dist/esm/TreeView/internals/utils/TimerBasedCleanupTracking.js.map +1 -1
  838. package/dist/esm/TreeView/internals/utils/publishTreeViewEvent.js.map +1 -1
  839. package/dist/esm/Typography/Typography.js +3 -3
  840. package/dist/esm/Typography/Typography.js.map +1 -1
  841. package/dist/esm/VerticalNavigation/Actions/Action.js.map +1 -1
  842. package/dist/esm/VerticalNavigation/Actions/Action.styles.js +1 -1
  843. package/dist/esm/VerticalNavigation/Actions/Action.styles.js.map +1 -1
  844. package/dist/esm/VerticalNavigation/Actions/Actions.js.map +1 -1
  845. package/dist/esm/VerticalNavigation/Actions/Actions.styles.js.map +1 -1
  846. package/dist/esm/VerticalNavigation/Header/Header.js.map +1 -1
  847. package/dist/esm/VerticalNavigation/Header/Header.styles.js.map +1 -1
  848. package/dist/esm/VerticalNavigation/Navigation/Navigation.js +5 -5
  849. package/dist/esm/VerticalNavigation/Navigation/Navigation.js.map +1 -1
  850. package/dist/esm/VerticalNavigation/Navigation/Navigation.styles.js.map +1 -1
  851. package/dist/esm/VerticalNavigation/NavigationPopup/NavigationPopup.styles.js +1 -1
  852. package/dist/esm/VerticalNavigation/NavigationPopup/NavigationPopup.styles.js.map +1 -1
  853. package/dist/esm/VerticalNavigation/NavigationPopup/NavigationPopupContainer.js.map +1 -1
  854. package/dist/esm/VerticalNavigation/NavigationSlider/NavigationSlider.js.map +1 -1
  855. package/dist/esm/VerticalNavigation/NavigationSlider/NavigationSlider.styles.js.map +1 -1
  856. package/dist/esm/VerticalNavigation/NavigationSlider/utils/NavigationSlider.utils.js.map +1 -1
  857. package/dist/esm/VerticalNavigation/TreeView/IconWrapper/IconWrapper.js.map +1 -1
  858. package/dist/esm/VerticalNavigation/TreeView/IconWrapper/IconWrapper.styles.js.map +1 -1
  859. package/dist/esm/VerticalNavigation/TreeView/TreeView.js +2 -2
  860. package/dist/esm/VerticalNavigation/TreeView/TreeView.js.map +1 -1
  861. package/dist/esm/VerticalNavigation/TreeView/TreeView.styles.js.map +1 -1
  862. package/dist/esm/VerticalNavigation/TreeView/TreeViewItem.js +4 -4
  863. package/dist/esm/VerticalNavigation/TreeView/TreeViewItem.js.map +1 -1
  864. package/dist/esm/VerticalNavigation/TreeView/TreeViewItem.styles.js +1 -1
  865. package/dist/esm/VerticalNavigation/TreeView/TreeViewItem.styles.js.map +1 -1
  866. package/dist/esm/VerticalNavigation/TreeView/descendants.js.map +1 -1
  867. package/dist/esm/VerticalNavigation/VerticalNavigation.js +1 -1
  868. package/dist/esm/VerticalNavigation/VerticalNavigation.js.map +1 -1
  869. package/dist/esm/VerticalNavigation/VerticalNavigation.styles.js.map +1 -1
  870. package/dist/esm/VerticalNavigation/VerticalNavigationContext.js.map +1 -1
  871. package/dist/esm/hocs/withTooltip.js.map +1 -1
  872. package/dist/esm/hooks/useClickOutside.js.map +1 -1
  873. package/dist/esm/hooks/useComputation.js.map +1 -1
  874. package/dist/esm/hooks/useControlled.js.map +1 -1
  875. package/dist/esm/hooks/useCss.js +1 -1
  876. package/dist/esm/hooks/useCss.js.map +1 -1
  877. package/dist/esm/hooks/useDefaultProps.js +19 -13
  878. package/dist/esm/hooks/useDefaultProps.js.map +1 -1
  879. package/dist/esm/hooks/useEmotionCache.js +2 -2
  880. package/dist/esm/hooks/useTheme.js +2 -2
  881. package/dist/esm/hooks/useWidth.js +1 -1
  882. package/dist/esm/hooks/useWidth.js.map +1 -1
  883. package/dist/esm/index.js +100 -96
  884. package/dist/esm/index.js.map +1 -1
  885. package/dist/esm/providers/Provider.js +1 -1
  886. package/dist/esm/providers/Provider.js.map +1 -1
  887. package/dist/esm/providers/ThemeProvider.js +2 -2
  888. package/dist/esm/providers/ThemeProvider.js.map +1 -1
  889. package/dist/esm/types/generic.js.map +1 -1
  890. package/dist/esm/utils/classes.js.map +1 -1
  891. package/dist/esm/utils/hexToRgbA.js.map +1 -1
  892. package/dist/esm/utils/iconVariant.js.map +1 -1
  893. package/dist/esm/utils/multiSelectionEventHandler.js.map +1 -1
  894. package/dist/esm/utils/theme.js.map +1 -1
  895. package/dist/esm/utils/useSavedState.js.map +1 -1
  896. package/dist/esm/utils/wrapperTooltip.js.map +1 -1
  897. package/dist/types/index.d.ts +234 -182
  898. package/package.json +5 -5
@@ -1,8 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const uikitStyles = require("@hitachivantara/uikit-styles");
4
- const focusUtils = require("../../../utils/focusUtils.cjs");
5
4
  const classes = require("../../../utils/classes.cjs");
5
+ const focusUtils = require("../../../utils/focusUtils.cjs");
6
6
  const name = "HvVerticalScrollListItem";
7
7
  const { staticClasses, useClasses } = classes.createClasses(name, {
8
8
  root: {
@@ -1 +1 @@
1
- {"version":3,"file":"VerticalScrollListItem.styles.cjs","sources":["../../../../../src/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.styles.ts"],"sourcesContent":["import { theme } from \"@hitachivantara/uikit-styles\";\n\nimport { outlineStyles } from \"../../../utils/focusUtils\";\n\nimport { createClasses } from \"../../../utils/classes\";\n\nconst name = \"HvVerticalScrollListItem\";\n\nexport const { staticClasses, useClasses } = createClasses(name, {\n root: {\n padding: \"0\",\n height: \"32px\",\n width: \"32px\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n },\n notSelected: {\n height: \"4px\",\n width: \"4px\",\n borderRadius: \"50%\",\n display: \"inline-block\",\n backgroundColor: theme.colors.secondary_60,\n },\n // TODO: remove in v6 (use classes.button)\n text: {},\n button: {\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n height: \"16px\",\n width: \"16px\",\n borderRadius: \"50%\",\n cursor: \"pointer\",\n \"&:hover\": {\n backgroundColor: theme.colors.containerBackgroundHover,\n\n \"& $notSelected\": {\n height: \"6px\",\n width: \"6px\",\n backgroundColor: theme.colors.secondary,\n },\n },\n \"&:focus\": {\n outline: \"none\",\n },\n \"&:focus-visible\": {\n ...outlineStyles,\n },\n },\n});\n"],"names":["createClasses","theme","outlineStyles"],"mappings":";;;;;AAMA,MAAM,OAAO;AAEN,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,MAAM;AAAA,EAC/D,MAAM;AAAA,IACJ,SAAS;AAAA,IACT,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,YAAY;AAAA,EACd;AAAA,EACA,aAAa;AAAA,IACX,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,cAAc;AAAA,IACd,SAAS;AAAA,IACT,iBAAiBC,YAAAA,MAAM,OAAO;AAAA,EAChC;AAAA;AAAA,EAEA,MAAM,CAAC;AAAA,EACP,QAAQ;AAAA,IACN,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,cAAc;AAAA,IACd,QAAQ;AAAA,IACR,WAAW;AAAA,MACT,iBAAiBA,YAAAA,MAAM,OAAO;AAAA,MAE9B,kBAAkB;AAAA,QAChB,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,iBAAiBA,YAAAA,MAAM,OAAO;AAAA,MAChC;AAAA,IACF;AAAA,IACA,WAAW;AAAA,MACT,SAAS;AAAA,IACX;AAAA,IACA,mBAAmB;AAAA,MACjB,GAAGC,WAAA;AAAA,IACL;AAAA,EACF;AACF,CAAC;;;"}
1
+ {"version":3,"file":"VerticalScrollListItem.styles.cjs","sources":["../../../../../src/ScrollTo/Vertical/VerticalScrollListItem/VerticalScrollListItem.styles.ts"],"sourcesContent":["import { theme } from \"@hitachivantara/uikit-styles\";\n\nimport { createClasses } from \"../../../utils/classes\";\nimport { outlineStyles } from \"../../../utils/focusUtils\";\n\nconst name = \"HvVerticalScrollListItem\";\n\nexport const { staticClasses, useClasses } = createClasses(name, {\n root: {\n padding: \"0\",\n height: \"32px\",\n width: \"32px\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n },\n notSelected: {\n height: \"4px\",\n width: \"4px\",\n borderRadius: \"50%\",\n display: \"inline-block\",\n backgroundColor: theme.colors.secondary_60,\n },\n // TODO: remove in v6 (use classes.button)\n text: {},\n button: {\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n height: \"16px\",\n width: \"16px\",\n borderRadius: \"50%\",\n cursor: \"pointer\",\n \"&:hover\": {\n backgroundColor: theme.colors.containerBackgroundHover,\n\n \"& $notSelected\": {\n height: \"6px\",\n width: \"6px\",\n backgroundColor: theme.colors.secondary,\n },\n },\n \"&:focus\": {\n outline: \"none\",\n },\n \"&:focus-visible\": {\n ...outlineStyles,\n },\n },\n});\n"],"names":["createClasses","theme","outlineStyles"],"mappings":";;;;;AAKA,MAAM,OAAO;AAEN,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,MAAM;AAAA,EAC/D,MAAM;AAAA,IACJ,SAAS;AAAA,IACT,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,YAAY;AAAA,EACd;AAAA,EACA,aAAa;AAAA,IACX,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,cAAc;AAAA,IACd,SAAS;AAAA,IACT,iBAAiBC,YAAAA,MAAM,OAAO;AAAA,EAChC;AAAA;AAAA,EAEA,MAAM,CAAC;AAAA,EACP,QAAQ;AAAA,IACN,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,cAAc;AAAA,IACd,QAAQ;AAAA,IACR,WAAW;AAAA,MACT,iBAAiBA,YAAAA,MAAM,OAAO;AAAA,MAE9B,kBAAkB;AAAA,QAChB,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,iBAAiBA,YAAAA,MAAM,OAAO;AAAA,MAChC;AAAA,IACF;AAAA,IACA,WAAW;AAAA,MACT,SAAS;AAAA,IACX;AAAA,IACA,mBAAmB;AAAA,MACjB,GAAGC,WAAA;AAAA,IACL;AAAA,EACF;AACF,CAAC;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useScrollTo.cjs","sources":["../../../src/ScrollTo/useScrollTo.ts"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\n\nimport {\n findFirstVisibleElement,\n getScrollTop,\n isScrolledToTheBottom,\n scrollElement,\n verticalScrollOffset,\n} from \"./utils\";\nimport { HvScrollToOption } from \"./types\";\n\ninterface HvScrollToOptionWithLink extends HvScrollToOption {\n href: string;\n}\n\nexport const useScrollTo = (\n selectedIndexProp: number = 0,\n scrollElementId: string | undefined = undefined,\n navigationMode: \"push\" | \"replace\" | \"none\" = \"push\",\n relativeLinks: boolean = false,\n offset: number = 0,\n options: HvScrollToOption[] = [],\n onChange:\n | ((\n event:\n | Event\n | React.MouseEvent<HTMLDivElement | HTMLAnchorElement>\n | React.KeyboardEvent<HTMLDivElement | HTMLAnchorElement>,\n index: number\n ) => void)\n | undefined = undefined,\n direction: \"column\" | \"row\" = \"column\"\n): [\n number,\n (\n event:\n | React.MouseEvent<HTMLDivElement | HTMLAnchorElement>\n | React.KeyboardEvent<HTMLDivElement | HTMLAnchorElement>,\n id: string,\n index: number,\n wrappedOnChange?: (index: number) => void\n ) => void,\n HvScrollToOptionWithLink[]\n] => {\n const RETRY_MAX: number = 5;\n const [selectedIndex, setSelectedIndex] = useState<number>(selectedIndexProp);\n\n const scrollEle = useRef<HTMLElement | (Window & typeof globalThis)>(window);\n const requestedAnimationFrame = useRef(0);\n const lastContainerScrollTop = useRef<number>(0);\n\n // Ref to use a often-changing value in useCallback, as recommended in\n // https://reactjs.org/docs/hooks-faq.html#how-to-read-an-often-changing-value-from-usecallback\n const selectedIndexRef = useRef(selectedIndex);\n\n useEffect(() => {\n selectedIndexRef.current = selectedIndex;\n }, [selectedIndex]);\n\n useEffect(() => {\n scrollEle.current =\n (scrollElementId && document.getElementById(scrollElementId)) || window;\n\n lastContainerScrollTop.current = verticalScrollOffset(scrollEle.current);\n }, [scrollElementId]);\n\n const checkScroll = useCallback(\n (\n event:\n | Event\n | React.MouseEvent<HTMLDivElement>\n | React.KeyboardEvent<HTMLDivElement>\n ) => {\n if (\n requestedAnimationFrame.current === 0 &&\n window?.requestAnimationFrame\n ) {\n requestedAnimationFrame.current = window.requestAnimationFrame(() => {\n requestedAnimationFrame.current = 0;\n\n const firstVisibleElementIndex = findFirstVisibleElement(\n scrollEle.current,\n options,\n offset\n );\n\n let newSelectedIndex = firstVisibleElementIndex;\n\n // select the first element when all elements are bellow the container's top\n if (firstVisibleElementIndex < 0) {\n newSelectedIndex = 0;\n }\n\n // if the user has reached the bottom of the container, select the first nav item still visible\n // (usually this selects the last nav item, when it can't reach the top the container)\n // in theory only needed when scrolling down, but no... because of the Safari bouncing behaviour\n if (\n newSelectedIndex < options.length - 1 &&\n isScrolledToTheBottom(scrollEle.current)\n ) {\n newSelectedIndex += 1;\n }\n\n const containerScrollTop = getScrollTop(scrollEle.current);\n const isScrollingDown =\n containerScrollTop > lastContainerScrollTop.current;\n lastContainerScrollTop.current = containerScrollTop;\n\n // only update the selected item if the scroll direction is moving away from it\n if (isScrollingDown) {\n if (newSelectedIndex < selectedIndexRef.current) {\n newSelectedIndex = selectedIndexRef.current;\n }\n } else if (newSelectedIndex > selectedIndexRef.current) {\n newSelectedIndex = selectedIndexRef.current;\n }\n\n setSelectedIndex(newSelectedIndex);\n onChange?.(event, newSelectedIndex);\n });\n }\n },\n [offset, options, onChange]\n );\n\n // Registers and unregisters the scroll listener\n useEffect(() => {\n if (scrollEle.current) {\n scrollEle.current.addEventListener(\"scroll\", checkScroll, false);\n }\n\n return () => {\n if (scrollEle.current) {\n scrollEle.current.removeEventListener(\"scroll\", checkScroll);\n }\n\n if (requestedAnimationFrame.current !== 0) {\n window.cancelAnimationFrame(requestedAnimationFrame.current);\n requestedAnimationFrame.current = 0;\n }\n };\n }, [checkScroll]);\n\n // Waits for the elements to be rendered and scrolls to the one referenced in the URL hash, if any\n useEffect(() => {\n let checkRenderedInterval: any;\n\n if (navigationMode !== \"none\") {\n const hashValue = document.location.hash.split(\"#\")[1] || \"\";\n\n const option = options.find((o) => o.value === hashValue);\n\n if (option) {\n let retry = 0;\n checkRenderedInterval = setInterval(() => {\n const ele = document.getElementById(option.value);\n\n if (ele) {\n scrollElement(ele, scrollEle.current, option.offset || offset);\n clearInterval(checkRenderedInterval);\n } else {\n retry += 1;\n if (retry === RETRY_MAX) {\n clearInterval(checkRenderedInterval);\n }\n }\n }, 1000);\n }\n }\n\n return () => {\n clearInterval(checkRenderedInterval);\n };\n\n // We really want to run this just in the first load\n // in fact this doesn't even belong here, the logic should be external\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const baseUrl =\n relativeLinks || window == null ? \"\" : window.location.href.split(\"#\")[0];\n\n const elements = useMemo(\n () =>\n options.map((o) => ({\n ...o,\n href: `${baseUrl}#${o.value}`,\n })),\n [options, baseUrl]\n );\n\n const setScrollTo = useCallback(\n (\n event:\n | React.MouseEvent<HTMLDivElement | HTMLAnchorElement>\n | React.KeyboardEvent<HTMLDivElement | HTMLAnchorElement>,\n id: string,\n index: number,\n wrappedOnChange?: (index: number) => void\n ) => {\n const option = elements.find((o) => o.value === id);\n\n if (option) {\n const ele = document.getElementById(id);\n if (ele) {\n scrollElement(\n ele,\n scrollEle.current,\n option.offset || offset,\n direction\n );\n }\n\n if (navigationMode === \"push\") {\n window.history.pushState({}, \"\", option.href);\n } else if (navigationMode === \"replace\") {\n window.history.replaceState({}, \"\", option.href);\n }\n\n setSelectedIndex(index);\n wrappedOnChange?.(index);\n\n // Safari scrolls immediately (no smooth scroll support),\n // so this ref value must be updated asap\n selectedIndexRef.current = index;\n }\n },\n [elements, navigationMode, direction, offset]\n );\n\n return [selectedIndex, setScrollTo, elements];\n};\n"],"names":["useState","useRef","useEffect","verticalScrollOffset","useCallback","findFirstVisibleElement","isScrolledToTheBottom","getScrollTop","scrollElement","useMemo"],"mappings":"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"}
1
+ {"version":3,"file":"useScrollTo.cjs","sources":["../../../src/ScrollTo/useScrollTo.ts"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\n\nimport { HvScrollToOption } from \"./types\";\nimport {\n findFirstVisibleElement,\n getScrollTop,\n isScrolledToTheBottom,\n scrollElement,\n verticalScrollOffset,\n} from \"./utils\";\n\ninterface HvScrollToOptionWithLink extends HvScrollToOption {\n href: string;\n}\n\nexport const useScrollTo = (\n selectedIndexProp: number = 0,\n scrollElementId: string | undefined = undefined,\n navigationMode: \"push\" | \"replace\" | \"none\" = \"push\",\n relativeLinks: boolean = false,\n offset: number = 0,\n options: HvScrollToOption[] = [],\n onChange:\n | ((\n event:\n | Event\n | React.MouseEvent<HTMLDivElement | HTMLAnchorElement>\n | React.KeyboardEvent<HTMLDivElement | HTMLAnchorElement>,\n index: number,\n ) => void)\n | undefined = undefined,\n direction: \"column\" | \"row\" = \"column\",\n): [\n number,\n (\n event:\n | React.MouseEvent<HTMLDivElement | HTMLAnchorElement>\n | React.KeyboardEvent<HTMLDivElement | HTMLAnchorElement>,\n id: string,\n index: number,\n wrappedOnChange?: (index: number) => void,\n ) => void,\n HvScrollToOptionWithLink[],\n] => {\n const RETRY_MAX: number = 5;\n const [selectedIndex, setSelectedIndex] = useState<number>(selectedIndexProp);\n\n const scrollEle = useRef<HTMLElement | (Window & typeof globalThis)>(window);\n const requestedAnimationFrame = useRef(0);\n const lastContainerScrollTop = useRef<number>(0);\n\n // Ref to use a often-changing value in useCallback, as recommended in\n // https://reactjs.org/docs/hooks-faq.html#how-to-read-an-often-changing-value-from-usecallback\n const selectedIndexRef = useRef(selectedIndex);\n\n useEffect(() => {\n selectedIndexRef.current = selectedIndex;\n }, [selectedIndex]);\n\n useEffect(() => {\n scrollEle.current =\n (scrollElementId && document.getElementById(scrollElementId)) || window;\n\n lastContainerScrollTop.current = verticalScrollOffset(scrollEle.current);\n }, [scrollElementId]);\n\n const checkScroll = useCallback(\n (\n event:\n | Event\n | React.MouseEvent<HTMLDivElement>\n | React.KeyboardEvent<HTMLDivElement>,\n ) => {\n if (\n requestedAnimationFrame.current === 0 &&\n window?.requestAnimationFrame\n ) {\n requestedAnimationFrame.current = window.requestAnimationFrame(() => {\n requestedAnimationFrame.current = 0;\n\n const firstVisibleElementIndex = findFirstVisibleElement(\n scrollEle.current,\n options,\n offset,\n );\n\n let newSelectedIndex = firstVisibleElementIndex;\n\n // select the first element when all elements are bellow the container's top\n if (firstVisibleElementIndex < 0) {\n newSelectedIndex = 0;\n }\n\n // if the user has reached the bottom of the container, select the first nav item still visible\n // (usually this selects the last nav item, when it can't reach the top the container)\n // in theory only needed when scrolling down, but no... because of the Safari bouncing behaviour\n if (\n newSelectedIndex < options.length - 1 &&\n isScrolledToTheBottom(scrollEle.current)\n ) {\n newSelectedIndex += 1;\n }\n\n const containerScrollTop = getScrollTop(scrollEle.current);\n const isScrollingDown =\n containerScrollTop > lastContainerScrollTop.current;\n lastContainerScrollTop.current = containerScrollTop;\n\n // only update the selected item if the scroll direction is moving away from it\n if (isScrollingDown) {\n if (newSelectedIndex < selectedIndexRef.current) {\n newSelectedIndex = selectedIndexRef.current;\n }\n } else if (newSelectedIndex > selectedIndexRef.current) {\n newSelectedIndex = selectedIndexRef.current;\n }\n\n setSelectedIndex(newSelectedIndex);\n onChange?.(event, newSelectedIndex);\n });\n }\n },\n [offset, options, onChange],\n );\n\n // Registers and unregisters the scroll listener\n useEffect(() => {\n if (scrollEle.current) {\n scrollEle.current.addEventListener(\"scroll\", checkScroll, false);\n }\n\n return () => {\n if (scrollEle.current) {\n scrollEle.current.removeEventListener(\"scroll\", checkScroll);\n }\n\n if (requestedAnimationFrame.current !== 0) {\n window.cancelAnimationFrame(requestedAnimationFrame.current);\n requestedAnimationFrame.current = 0;\n }\n };\n }, [checkScroll]);\n\n // Waits for the elements to be rendered and scrolls to the one referenced in the URL hash, if any\n useEffect(() => {\n let checkRenderedInterval: any;\n\n if (navigationMode !== \"none\") {\n const hashValue = document.location.hash.split(\"#\")[1] || \"\";\n\n const option = options.find((o) => o.value === hashValue);\n\n if (option) {\n let retry = 0;\n checkRenderedInterval = setInterval(() => {\n const ele = document.getElementById(option.value);\n\n if (ele) {\n scrollElement(ele, scrollEle.current, option.offset || offset);\n clearInterval(checkRenderedInterval);\n } else {\n retry += 1;\n if (retry === RETRY_MAX) {\n clearInterval(checkRenderedInterval);\n }\n }\n }, 1000);\n }\n }\n\n return () => {\n clearInterval(checkRenderedInterval);\n };\n\n // We really want to run this just in the first load\n // in fact this doesn't even belong here, the logic should be external\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const baseUrl =\n relativeLinks || window == null ? \"\" : window.location.href.split(\"#\")[0];\n\n const elements = useMemo(\n () =>\n options.map((o) => ({\n ...o,\n href: `${baseUrl}#${o.value}`,\n })),\n [options, baseUrl],\n );\n\n const setScrollTo = useCallback(\n (\n event:\n | React.MouseEvent<HTMLDivElement | HTMLAnchorElement>\n | React.KeyboardEvent<HTMLDivElement | HTMLAnchorElement>,\n id: string,\n index: number,\n wrappedOnChange?: (index: number) => void,\n ) => {\n const option = elements.find((o) => o.value === id);\n\n if (option) {\n const ele = document.getElementById(id);\n if (ele) {\n scrollElement(\n ele,\n scrollEle.current,\n option.offset || offset,\n direction,\n );\n }\n\n if (navigationMode === \"push\") {\n window.history.pushState({}, \"\", option.href);\n } else if (navigationMode === \"replace\") {\n window.history.replaceState({}, \"\", option.href);\n }\n\n setSelectedIndex(index);\n wrappedOnChange?.(index);\n\n // Safari scrolls immediately (no smooth scroll support),\n // so this ref value must be updated asap\n selectedIndexRef.current = index;\n }\n },\n [elements, navigationMode, direction, offset],\n );\n\n return [selectedIndex, setScrollTo, elements];\n};\n"],"names":["useState","useRef","useEffect","verticalScrollOffset","useCallback","findFirstVisibleElement","isScrolledToTheBottom","getScrollTop","scrollElement","useMemo"],"mappings":";;;;AAeO,MAAM,cAAc,CACzB,oBAA4B,GAC5B,kBAAsC,QACtC,iBAA8C,QAC9C,gBAAyB,OACzB,SAAiB,GACjB,UAA8B,IAC9B,WAQgB,QAChB,YAA8B,aAY3B;AACH,QAAM,YAAoB;AAC1B,QAAM,CAAC,eAAe,gBAAgB,IAAIA,eAAiB,iBAAiB;AAEtE,QAAA,YAAYC,aAAmD,MAAM;AACrE,QAAA,0BAA0BA,aAAO,CAAC;AAClC,QAAA,yBAAyBA,aAAe,CAAC;AAIzC,QAAA,mBAAmBA,aAAO,aAAa;AAE7CC,QAAAA,UAAU,MAAM;AACd,qBAAiB,UAAU;AAAA,EAAA,GAC1B,CAAC,aAAa,CAAC;AAElBA,QAAAA,UAAU,MAAM;AACd,cAAU,UACP,mBAAmB,SAAS,eAAe,eAAe,KAAM;AAE5C,2BAAA,UAAUC,MAAAA,qBAAqB,UAAU,OAAO;AAAA,EAAA,GACtE,CAAC,eAAe,CAAC;AAEpB,QAAM,cAAcC,MAAA;AAAA,IAClB,CACE,UAIG;AACH,UACE,wBAAwB,YAAY,KACpC,QAAQ,uBACR;AACwB,gCAAA,UAAU,OAAO,sBAAsB,MAAM;AACnE,kCAAwB,UAAU;AAElC,gBAAM,2BAA2BC,MAAA;AAAA,YAC/B,UAAU;AAAA,YACV;AAAA,YACA;AAAA,UAAA;AAGF,cAAI,mBAAmB;AAGvB,cAAI,2BAA2B,GAAG;AACb,+BAAA;AAAA,UACrB;AAKA,cACE,mBAAmB,QAAQ,SAAS,KACpCC,4BAAsB,UAAU,OAAO,GACvC;AACoB,gCAAA;AAAA,UACtB;AAEM,gBAAA,qBAAqBC,MAAAA,aAAa,UAAU,OAAO;AACnD,gBAAA,kBACJ,qBAAqB,uBAAuB;AAC9C,iCAAuB,UAAU;AAGjC,cAAI,iBAAiB;AACf,gBAAA,mBAAmB,iBAAiB,SAAS;AAC/C,iCAAmB,iBAAiB;AAAA,YACtC;AAAA,UAAA,WACS,mBAAmB,iBAAiB,SAAS;AACtD,+BAAmB,iBAAiB;AAAA,UACtC;AAEA,2BAAiB,gBAAgB;AACjC,qBAAW,OAAO,gBAAgB;AAAA,QAAA,CACnC;AAAA,MACH;AAAA,IACF;AAAA,IACA,CAAC,QAAQ,SAAS,QAAQ;AAAA,EAAA;AAI5BL,QAAAA,UAAU,MAAM;AACd,QAAI,UAAU,SAAS;AACrB,gBAAU,QAAQ,iBAAiB,UAAU,aAAa,KAAK;AAAA,IACjE;AAEA,WAAO,MAAM;AACX,UAAI,UAAU,SAAS;AACX,kBAAA,QAAQ,oBAAoB,UAAU,WAAW;AAAA,MAC7D;AAEI,UAAA,wBAAwB,YAAY,GAAG;AAClC,eAAA,qBAAqB,wBAAwB,OAAO;AAC3D,gCAAwB,UAAU;AAAA,MACpC;AAAA,IAAA;AAAA,EACF,GACC,CAAC,WAAW,CAAC;AAGhBA,QAAAA,UAAU,MAAM;AACV,QAAA;AAEJ,QAAI,mBAAmB,QAAQ;AACvB,YAAA,YAAY,SAAS,SAAS,KAAK,MAAM,GAAG,EAAE,CAAC,KAAK;AAE1D,YAAM,SAAS,QAAQ,KAAK,CAAC,MAAM,EAAE,UAAU,SAAS;AAExD,UAAI,QAAQ;AACV,YAAI,QAAQ;AACZ,gCAAwB,YAAY,MAAM;AACxC,gBAAM,MAAM,SAAS,eAAe,OAAO,KAAK;AAEhD,cAAI,KAAK;AACPM,kBAAA,cAAc,KAAK,UAAU,SAAS,OAAO,UAAU,MAAM;AAC7D,0BAAc,qBAAqB;AAAA,UAAA,OAC9B;AACI,qBAAA;AACT,gBAAI,UAAU,WAAW;AACvB,4BAAc,qBAAqB;AAAA,YACrC;AAAA,UACF;AAAA,WACC,GAAI;AAAA,MACT;AAAA,IACF;AAEA,WAAO,MAAM;AACX,oBAAc,qBAAqB;AAAA,IAAA;AAAA,EAMvC,GAAG,CAAE,CAAA;AAEC,QAAA,UACJ,iBAAiB,UAAU,OAAO,KAAK,OAAO,SAAS,KAAK,MAAM,GAAG,EAAE,CAAC;AAE1E,QAAM,WAAWC,MAAA;AAAA,IACf,MACE,QAAQ,IAAI,CAAC,OAAO;AAAA,MAClB,GAAG;AAAA,MACH,MAAM,GAAG,OAAO,IAAI,EAAE,KAAK;AAAA,IAAA,EAC3B;AAAA,IACJ,CAAC,SAAS,OAAO;AAAA,EAAA;AAGnB,QAAM,cAAcL,MAAA;AAAA,IAClB,CACE,OAGA,IACA,OACA,oBACG;AACH,YAAM,SAAS,SAAS,KAAK,CAAC,MAAM,EAAE,UAAU,EAAE;AAElD,UAAI,QAAQ;AACJ,cAAA,MAAM,SAAS,eAAe,EAAE;AACtC,YAAI,KAAK;AACPI,gBAAA;AAAA,YACE;AAAA,YACA,UAAU;AAAA,YACV,OAAO,UAAU;AAAA,YACjB;AAAA,UAAA;AAAA,QAEJ;AAEA,YAAI,mBAAmB,QAAQ;AAC7B,iBAAO,QAAQ,UAAU,CAAA,GAAI,IAAI,OAAO,IAAI;AAAA,QAAA,WACnC,mBAAmB,WAAW;AACvC,iBAAO,QAAQ,aAAa,CAAA,GAAI,IAAI,OAAO,IAAI;AAAA,QACjD;AAEA,yBAAiB,KAAK;AACtB,0BAAkB,KAAK;AAIvB,yBAAiB,UAAU;AAAA,MAC7B;AAAA,IACF;AAAA,IACA,CAAC,UAAU,gBAAgB,WAAW,MAAM;AAAA,EAAA;AAGvC,SAAA,CAAC,eAAe,aAAa,QAAQ;AAC9C;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"utils.cjs","sources":["../../../src/ScrollTo/utils.ts"],"sourcesContent":["import { HvScrollToOption } from \"./types\";\n\ntype ExtendedWindow = Window & typeof globalThis & HTMLElement;\n\nexport const getScrollTop = (\n c: HTMLElement | (Window & typeof globalThis) = window\n) => {\n if (c === window) {\n return (\n window.scrollY ||\n window.pageYOffset ||\n (document.documentElement && document.documentElement.scrollTop) ||\n document.body.scrollTop\n );\n }\n\n return (c as ExtendedWindow).scrollTop;\n};\n\nexport const verticalScrollOffset = (\n t: HTMLElement | (Window & typeof globalThis),\n c: HTMLElement | (Window & typeof globalThis) = window\n) => {\n if (c === window) {\n return (\n ((t as ExtendedWindow)?.getBoundingClientRect?.().top || 0) +\n (window.scrollY || window.pageYOffset)\n );\n }\n if (getComputedStyle(c as ExtendedWindow).position !== \"static\") {\n return (t as ExtendedWindow).offsetTop;\n }\n\n return (t as ExtendedWindow).offsetTop - (c as ExtendedWindow).offsetTop;\n};\n\nexport const horizontalScrollOffset = (\n t: HTMLElement,\n c: HTMLElement | (Window & typeof globalThis) = window\n) => {\n if (c === window) {\n return (\n (t?.getBoundingClientRect?.().left || 0) +\n (window.scrollX || window.pageXOffset)\n );\n }\n if (getComputedStyle(c as ExtendedWindow).position !== \"static\") {\n return t.offsetLeft;\n }\n\n return t.offsetLeft - (c as ExtendedWindow).offsetLeft;\n};\n\nexport const scrollElement = (\n element: HTMLElement,\n container: HTMLElement | (Window & typeof globalThis),\n offset: number = 0,\n direction?: \"row\" | \"column\"\n) => {\n if (direction === \"row\") {\n const elemLeft = horizontalScrollOffset(element, container);\n container?.scrollTo?.({\n left: elemLeft - offset,\n behavior: \"smooth\",\n });\n } else {\n const elemTop = verticalScrollOffset(element, container);\n container?.scrollTo?.({\n top: elemTop - offset,\n behavior: \"smooth\",\n });\n }\n element.focus({ preventScroll: true });\n};\n\nexport const isScrolledToTheBottom = (\n container: HTMLElement | (Window & typeof globalThis)\n) => {\n const containerScrollTop = getScrollTop(container);\n\n if (container === window) {\n // Accounting for cases where html/body are set to height:100%\n const scrollHeight =\n (document.documentElement && document.documentElement.scrollHeight) ||\n document.body.scrollHeight;\n\n return containerScrollTop + window.innerHeight >= scrollHeight;\n }\n\n return (\n containerScrollTop + (container as ExtendedWindow).offsetHeight >=\n (container as ExtendedWindow).scrollHeight\n );\n};\n\nexport const findFirstVisibleElement = (\n container: HTMLElement | (Window & typeof globalThis),\n options: HvScrollToOption[],\n offset: number\n) => {\n const boundsTop = verticalScrollOffset(container);\n\n let i = 0;\n\n // Find index of first element whose top is still visible inside the container\n for (; i < options.length; i += 1) {\n const ele = document.getElementById(options[i].value);\n\n if (ele) {\n const elemTop = verticalScrollOffset(ele) - (options[i].offset || offset);\n\n if (elemTop > boundsTop) {\n break;\n }\n }\n }\n\n // Return the previous index, the element that last scrolled past the top\n return i - 1;\n};\n"],"names":[],"mappings":";;AAIa,MAAA,eAAe,CAC1B,IAAgD,WAC7C;AACH,MAAI,MAAM,QAAQ;AAEd,WAAA,OAAO,WACP,OAAO,eACN,SAAS,mBAAmB,SAAS,gBAAgB,aACtD,SAAS,KAAK;AAAA,EAElB;AAEA,SAAQ,EAAqB;AAC/B;AAEO,MAAM,uBAAuB,CAClC,GACA,IAAgD,WAC7C;AACH,MAAI,MAAM,QAAQ;AAChB,YACI,GAAsB,wBAAwB,EAAE,OAAO,MACxD,OAAO,WAAW,OAAO;AAAA,EAE9B;AACA,MAAI,iBAAiB,CAAmB,EAAE,aAAa,UAAU;AAC/D,WAAQ,EAAqB;AAAA,EAC/B;AAEQ,SAAA,EAAqB,YAAa,EAAqB;AACjE;AAEO,MAAM,yBAAyB,CACpC,GACA,IAAgD,WAC7C;AACH,MAAI,MAAM,QAAQ;AAChB,YACG,GAAG,wBAAwB,EAAE,QAAQ,MACrC,OAAO,WAAW,OAAO;AAAA,EAE9B;AACA,MAAI,iBAAiB,CAAmB,EAAE,aAAa,UAAU;AAC/D,WAAO,EAAE;AAAA,EACX;AAEO,SAAA,EAAE,aAAc,EAAqB;AAC9C;AAEO,MAAM,gBAAgB,CAC3B,SACA,WACA,SAAiB,GACjB,cACG;AACH,MAAI,cAAc,OAAO;AACjB,UAAA,WAAW,uBAAuB,SAAS,SAAS;AAC1D,eAAW,WAAW;AAAA,MACpB,MAAM,WAAW;AAAA,MACjB,UAAU;AAAA,IAAA,CACX;AAAA,EAAA,OACI;AACC,UAAA,UAAU,qBAAqB,SAAS,SAAS;AACvD,eAAW,WAAW;AAAA,MACpB,KAAK,UAAU;AAAA,MACf,UAAU;AAAA,IAAA,CACX;AAAA,EACH;AACA,UAAQ,MAAM,EAAE,eAAe,KAAM,CAAA;AACvC;AAEa,MAAA,wBAAwB,CACnC,cACG;AACG,QAAA,qBAAqB,aAAa,SAAS;AAEjD,MAAI,cAAc,QAAQ;AAExB,UAAM,eACH,SAAS,mBAAmB,SAAS,gBAAgB,gBACtD,SAAS,KAAK;AAET,WAAA,qBAAqB,OAAO,eAAe;AAAA,EACpD;AAGE,SAAA,qBAAsB,UAA6B,gBAClD,UAA6B;AAElC;AAEO,MAAM,0BAA0B,CACrC,WACA,SACA,WACG;AACG,QAAA,YAAY,qBAAqB,SAAS;AAEhD,MAAI,IAAI;AAGR,SAAO,IAAI,QAAQ,QAAQ,KAAK,GAAG;AACjC,UAAM,MAAM,SAAS,eAAe,QAAQ,CAAC,EAAE,KAAK;AAEpD,QAAI,KAAK;AACP,YAAM,UAAU,qBAAqB,GAAG,KAAK,QAAQ,CAAC,EAAE,UAAU;AAElE,UAAI,UAAU,WAAW;AACvB;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAGA,SAAO,IAAI;AACb;;;;;;;"}
1
+ {"version":3,"file":"utils.cjs","sources":["../../../src/ScrollTo/utils.ts"],"sourcesContent":["import { HvScrollToOption } from \"./types\";\n\ntype ExtendedWindow = Window & typeof globalThis & HTMLElement;\n\nexport const getScrollTop = (\n c: HTMLElement | (Window & typeof globalThis) = window,\n) => {\n if (c === window) {\n return (\n window.scrollY ||\n window.pageYOffset ||\n (document.documentElement && document.documentElement.scrollTop) ||\n document.body.scrollTop\n );\n }\n\n return (c as ExtendedWindow).scrollTop;\n};\n\nexport const verticalScrollOffset = (\n t: HTMLElement | (Window & typeof globalThis),\n c: HTMLElement | (Window & typeof globalThis) = window,\n) => {\n if (c === window) {\n return (\n ((t as ExtendedWindow)?.getBoundingClientRect?.().top || 0) +\n (window.scrollY || window.pageYOffset)\n );\n }\n if (getComputedStyle(c as ExtendedWindow).position !== \"static\") {\n return (t as ExtendedWindow).offsetTop;\n }\n\n return (t as ExtendedWindow).offsetTop - (c as ExtendedWindow).offsetTop;\n};\n\nexport const horizontalScrollOffset = (\n t: HTMLElement,\n c: HTMLElement | (Window & typeof globalThis) = window,\n) => {\n if (c === window) {\n return (\n (t?.getBoundingClientRect?.().left || 0) +\n (window.scrollX || window.pageXOffset)\n );\n }\n if (getComputedStyle(c as ExtendedWindow).position !== \"static\") {\n return t.offsetLeft;\n }\n\n return t.offsetLeft - (c as ExtendedWindow).offsetLeft;\n};\n\nexport const scrollElement = (\n element: HTMLElement,\n container: HTMLElement | (Window & typeof globalThis),\n offset: number = 0,\n direction?: \"row\" | \"column\",\n) => {\n if (direction === \"row\") {\n const elemLeft = horizontalScrollOffset(element, container);\n container?.scrollTo?.({\n left: elemLeft - offset,\n behavior: \"smooth\",\n });\n } else {\n const elemTop = verticalScrollOffset(element, container);\n container?.scrollTo?.({\n top: elemTop - offset,\n behavior: \"smooth\",\n });\n }\n element.focus({ preventScroll: true });\n};\n\nexport const isScrolledToTheBottom = (\n container: HTMLElement | (Window & typeof globalThis),\n) => {\n const containerScrollTop = getScrollTop(container);\n\n if (container === window) {\n // Accounting for cases where html/body are set to height:100%\n const scrollHeight =\n (document.documentElement && document.documentElement.scrollHeight) ||\n document.body.scrollHeight;\n\n return containerScrollTop + window.innerHeight >= scrollHeight;\n }\n\n return (\n containerScrollTop + (container as ExtendedWindow).offsetHeight >=\n (container as ExtendedWindow).scrollHeight\n );\n};\n\nexport const findFirstVisibleElement = (\n container: HTMLElement | (Window & typeof globalThis),\n options: HvScrollToOption[],\n offset: number,\n) => {\n const boundsTop = verticalScrollOffset(container);\n\n let i = 0;\n\n // Find index of first element whose top is still visible inside the container\n for (; i < options.length; i += 1) {\n const ele = document.getElementById(options[i].value);\n\n if (ele) {\n const elemTop = verticalScrollOffset(ele) - (options[i].offset || offset);\n\n if (elemTop > boundsTop) {\n break;\n }\n }\n }\n\n // Return the previous index, the element that last scrolled past the top\n return i - 1;\n};\n"],"names":[],"mappings":";;AAIa,MAAA,eAAe,CAC1B,IAAgD,WAC7C;AACH,MAAI,MAAM,QAAQ;AAEd,WAAA,OAAO,WACP,OAAO,eACN,SAAS,mBAAmB,SAAS,gBAAgB,aACtD,SAAS,KAAK;AAAA,EAElB;AAEA,SAAQ,EAAqB;AAC/B;AAEO,MAAM,uBAAuB,CAClC,GACA,IAAgD,WAC7C;AACH,MAAI,MAAM,QAAQ;AAChB,YACI,GAAsB,wBAAwB,EAAE,OAAO,MACxD,OAAO,WAAW,OAAO;AAAA,EAE9B;AACA,MAAI,iBAAiB,CAAmB,EAAE,aAAa,UAAU;AAC/D,WAAQ,EAAqB;AAAA,EAC/B;AAEQ,SAAA,EAAqB,YAAa,EAAqB;AACjE;AAEO,MAAM,yBAAyB,CACpC,GACA,IAAgD,WAC7C;AACH,MAAI,MAAM,QAAQ;AAChB,YACG,GAAG,wBAAwB,EAAE,QAAQ,MACrC,OAAO,WAAW,OAAO;AAAA,EAE9B;AACA,MAAI,iBAAiB,CAAmB,EAAE,aAAa,UAAU;AAC/D,WAAO,EAAE;AAAA,EACX;AAEO,SAAA,EAAE,aAAc,EAAqB;AAC9C;AAEO,MAAM,gBAAgB,CAC3B,SACA,WACA,SAAiB,GACjB,cACG;AACH,MAAI,cAAc,OAAO;AACjB,UAAA,WAAW,uBAAuB,SAAS,SAAS;AAC1D,eAAW,WAAW;AAAA,MACpB,MAAM,WAAW;AAAA,MACjB,UAAU;AAAA,IAAA,CACX;AAAA,EAAA,OACI;AACC,UAAA,UAAU,qBAAqB,SAAS,SAAS;AACvD,eAAW,WAAW;AAAA,MACpB,KAAK,UAAU;AAAA,MACf,UAAU;AAAA,IAAA,CACX;AAAA,EACH;AACA,UAAQ,MAAM,EAAE,eAAe,KAAM,CAAA;AACvC;AAEa,MAAA,wBAAwB,CACnC,cACG;AACG,QAAA,qBAAqB,aAAa,SAAS;AAEjD,MAAI,cAAc,QAAQ;AAExB,UAAM,eACH,SAAS,mBAAmB,SAAS,gBAAgB,gBACtD,SAAS,KAAK;AAET,WAAA,qBAAqB,OAAO,eAAe;AAAA,EACpD;AAGE,SAAA,qBAAsB,UAA6B,gBAClD,UAA6B;AAElC;AAEO,MAAM,0BAA0B,CACrC,WACA,SACA,WACG;AACG,QAAA,YAAY,qBAAqB,SAAS;AAEhD,MAAI,IAAI;AAGR,SAAO,IAAI,QAAQ,QAAQ,KAAK,GAAG;AACjC,UAAM,MAAM,SAAS,eAAe,QAAQ,CAAC,EAAE,KAAK;AAEpD,QAAI,KAAK;AACP,YAAM,UAAU,qBAAqB,GAAG,KAAK,QAAQ,CAAC,EAAE,UAAU;AAElE,UAAI,UAAU,WAAW;AACvB;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAGA,SAAO,IAAI;AACb;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"withTooltip.cjs","sources":["../../../src/ScrollTo/withTooltip.tsx"],"sourcesContent":["import { HvTypography, HvTypographyProps } from \"../Typography\";\nimport { withTooltip as withTooltipUtil } from \"../hocs/withTooltip\";\n\nimport { HvScrollToTooltipPositions } from \"./types\";\n\nconst hideTooltip = (event: React.MouseEvent<HTMLDivElement>) => {\n const isOverFlow =\n (event.target as HTMLDivElement).children.length > 1\n ? Array.from(event.currentTarget.children).some(\n (child) => child.scrollWidth > child.clientWidth\n )\n : (event.target as HTMLDivElement).scrollWidth >\n (event.target as HTMLDivElement).clientWidth;\n return !isOverFlow;\n};\n\nexport const withTooltip = (\n label: string,\n componentType: React.ElementType,\n tooltipPosition: HvScrollToTooltipPositions = \"top\",\n hideOnOverflow: boolean = true\n) => {\n const component = (props: HvTypographyProps) => (\n <HvTypography component={componentType} {...props}>\n {props.children}\n </HvTypography>\n );\n\n const hideTooltipFunc = hideOnOverflow ? hideTooltip : undefined;\n\n return withTooltipUtil(component, label, tooltipPosition, hideTooltipFunc);\n};\n"],"names":["jsx","HvTypography","withTooltipUtil"],"mappings":";;;;;AAKA,MAAM,cAAc,CAAC,UAA4C;AACzD,QAAA,aACH,MAAM,OAA0B,SAAS,SAAS,IAC/C,MAAM,KAAK,MAAM,cAAc,QAAQ,EAAE;AAAA,IACvC,CAAC,UAAU,MAAM,cAAc,MAAM;AAAA,EAAA,IAEtC,MAAM,OAA0B,cAChC,MAAM,OAA0B;AACvC,SAAO,CAAC;AACV;AAEO,MAAM,cAAc,CACzB,OACA,eACA,kBAA8C,OAC9C,iBAA0B,SACvB;AACG,QAAA,YAAY,CAAC,UAChBA,2BAAA,IAAAC,WAAA,cAAA,EAAa,WAAW,eAAgB,GAAG,OACzC,UAAA,MAAM,SACT,CAAA;AAGI,QAAA,kBAAkB,iBAAiB,cAAc;AAEvD,SAAOC,cAAgB,YAAA,WAAW,OAAO,iBAAiB,eAAe;AAC3E;;"}
1
+ {"version":3,"file":"withTooltip.cjs","sources":["../../../src/ScrollTo/withTooltip.tsx"],"sourcesContent":["import { withTooltip as withTooltipUtil } from \"../hocs/withTooltip\";\nimport { HvTypography, HvTypographyProps } from \"../Typography\";\nimport { HvScrollToTooltipPositions } from \"./types\";\n\nconst hideTooltip = (event: React.MouseEvent<HTMLDivElement>) => {\n const isOverFlow =\n (event.target as HTMLDivElement).children.length > 1\n ? Array.from(event.currentTarget.children).some(\n (child) => child.scrollWidth > child.clientWidth,\n )\n : (event.target as HTMLDivElement).scrollWidth >\n (event.target as HTMLDivElement).clientWidth;\n return !isOverFlow;\n};\n\nexport const withTooltip = (\n label: string,\n componentType: React.ElementType,\n tooltipPosition: HvScrollToTooltipPositions = \"top\",\n hideOnOverflow: boolean = true,\n) => {\n const component = (props: HvTypographyProps) => (\n <HvTypography component={componentType} {...props}>\n {props.children}\n </HvTypography>\n );\n\n const hideTooltipFunc = hideOnOverflow ? hideTooltip : undefined;\n\n return withTooltipUtil(component, label, tooltipPosition, hideTooltipFunc);\n};\n"],"names":["jsx","HvTypography","withTooltipUtil"],"mappings":";;;;;AAIA,MAAM,cAAc,CAAC,UAA4C;AACzD,QAAA,aACH,MAAM,OAA0B,SAAS,SAAS,IAC/C,MAAM,KAAK,MAAM,cAAc,QAAQ,EAAE;AAAA,IACvC,CAAC,UAAU,MAAM,cAAc,MAAM;AAAA,EAAA,IAEtC,MAAM,OAA0B,cAChC,MAAM,OAA0B;AACvC,SAAO,CAAC;AACV;AAEO,MAAM,cAAc,CACzB,OACA,eACA,kBAA8C,OAC9C,iBAA0B,SACvB;AACG,QAAA,YAAY,CAAC,UAChBA,2BAAA,IAAAC,WAAA,cAAA,EAAa,WAAW,eAAgB,GAAG,OACzC,UAAA,MAAM,SACT,CAAA;AAGI,QAAA,kBAAkB,iBAAiB,cAAc;AAEvD,SAAOC,cAAgB,YAAA,WAAW,OAAO,iBAAiB,eAAe;AAC3E;;"}
@@ -3,8 +3,8 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const React = require("react");
5
5
  const uikitReactIcons = require("@hitachivantara/uikit-react-icons");
6
- const useDefaultProps = require("../hooks/useDefaultProps.cjs");
7
6
  const useControlled = require("../hooks/useControlled.cjs");
7
+ const useDefaultProps = require("../hooks/useDefaultProps.cjs");
8
8
  const useUniqueId = require("../hooks/useUniqueId.cjs");
9
9
  const setId = require("../utils/setId.cjs");
10
10
  const Section_styles = require("./Section.styles.cjs");
@@ -1 +1 @@
1
- {"version":3,"file":"Section.cjs","sources":["../../../src/Section/Section.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Down, Up } from \"@hitachivantara/uikit-react-icons\";\n\nimport { HvBaseProps } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { HvButton, HvButtonProps } from \"../Button\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { useControlled } from \"../hooks/useControlled\";\nimport { useUniqueId } from \"../hooks/useUniqueId\";\nimport { setId } from \"../utils/setId\";\n\nimport { staticClasses, useClasses } from \"./Section.styles\";\n\nexport { staticClasses as sectionClasses };\n\nexport type HvSectionClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSectionProps\n extends Omit<HvBaseProps<HTMLDivElement>, \"title\"> {\n /** The title of the section */\n title?: React.ReactNode;\n /** Whether or not the section is expandable. */\n expandable?: boolean;\n /** Whether the section is open or not, if this property is defined the accordion must be fully controlled. */\n expanded?: boolean;\n /** When uncontrolled, defines the initial expanded state. */\n defaultExpanded?: boolean;\n /** Section actions */\n actions?: React.ReactNode;\n /** Section onExpand callback */\n onToggle?: (\n event: React.MouseEvent<HTMLButtonElement>,\n open: boolean\n ) => void;\n /** Props to be passed to the expand button */\n expandButtonProps?: HvButtonProps;\n /** Determines whether or not the header has a shadow on the bottom border. */\n raisedHeader?: boolean;\n /** A Jss Object used to override or extend the styles applied to the empty state component. */\n classes?: HvSectionClasses;\n /** Content container ref. */\n contentRef?: React.Ref<HTMLDivElement>;\n}\n\n/**\n * Sections allow grouping information on a page under the same topic.\n */\nexport const HvSection = forwardRef<HTMLDivElement, HvSectionProps>(\n (props, ref) => {\n const {\n id,\n classes: classesProp,\n className,\n title,\n expandable,\n expanded,\n defaultExpanded = true,\n actions,\n onToggle,\n expandButtonProps,\n raisedHeader,\n contentRef,\n children,\n ...others\n } = useDefaultProps(\"HvSection\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const [isOpen, setIsOpen] = useControlled(\n expanded,\n Boolean(defaultExpanded)\n );\n\n const elementId = useUniqueId(id);\n const contentId = setId(elementId, \"content\");\n\n const showContent = expandable ? !!isOpen : true;\n\n return (\n <div\n ref={ref}\n id={elementId}\n className={cx(classes.root, className)}\n {...others}\n >\n {(title || actions || expandable) && (\n <div\n className={cx(classes.header, {\n [classes.raisedHeader]: raisedHeader && isOpen,\n })}\n >\n {expandable && (\n <HvButton\n icon\n onClick={(event) => {\n setIsOpen((o) => !o);\n onToggle?.(event, !isOpen);\n }}\n aria-expanded={isOpen}\n aria-controls={contentId}\n aria-label={isOpen ? \"Collapse\" : \"Expand\"}\n {...expandButtonProps}\n >\n {isOpen ? <Up /> : <Down />}\n </HvButton>\n )}\n {title}\n <div className={classes.actions}>{actions}</div>\n </div>\n )}\n <div\n ref={contentRef}\n id={contentId}\n hidden={!isOpen}\n className={cx(classes.content, {\n [classes.hidden]: !showContent,\n [classes.spaceTop]: !(title || actions || expandable),\n })}\n >\n {children}\n </div>\n </div>\n );\n }\n);\n"],"names":["forwardRef","useDefaultProps","useClasses","useControlled","useUniqueId","setId","jsxs","jsx","HvButton","Up","Down"],"mappings":";;;;;;;;;;;AA+CO,MAAM,YAAYA,MAAA;AAAA,EACvB,CAAC,OAAO,QAAQ;AACR,UAAA;AAAA,MACJ;AAAA,MACA,SAAS;AAAA,MACT;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,kBAAkB;AAAA,MAClB;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IAAA,IACDC,gBAAgB,gBAAA,aAAa,KAAK;AAEtC,UAAM,EAAE,SAAS,GAAG,IAAIC,0BAAW,WAAW;AAExC,UAAA,CAAC,QAAQ,SAAS,IAAIC,cAAA;AAAA,MAC1B;AAAA,MACA,QAAQ,eAAe;AAAA,IAAA;AAGnB,UAAA,YAAYC,wBAAY,EAAE;AAC1B,UAAA,YAAYC,MAAAA,MAAM,WAAW,SAAS;AAE5C,UAAM,cAAc,aAAa,CAAC,CAAC,SAAS;AAG1C,WAAAC,2BAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,IAAI;AAAA,QACJ,WAAW,GAAG,QAAQ,MAAM,SAAS;AAAA,QACpC,GAAG;AAAA,QAEF,UAAA;AAAA,WAAA,SAAS,WAAW,eACpBA,2BAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAW,GAAG,QAAQ,QAAQ;AAAA,gBAC5B,CAAC,QAAQ,YAAY,GAAG,gBAAgB;AAAA,cAAA,CACzC;AAAA,cAEA,UAAA;AAAA,gBACC,cAAAC,2BAAA;AAAA,kBAACC,OAAA;AAAA,kBAAA;AAAA,oBACC,MAAI;AAAA,oBACJ,SAAS,CAAC,UAAU;AACR,gCAAA,CAAC,MAAM,CAAC,CAAC;AACR,iCAAA,OAAO,CAAC,MAAM;AAAA,oBAC3B;AAAA,oBACA,iBAAe;AAAA,oBACf,iBAAe;AAAA,oBACf,cAAY,SAAS,aAAa;AAAA,oBACjC,GAAG;AAAA,oBAEH,UAAS,SAAAD,2BAAAA,IAACE,gBAAG,IAAA,CAAA,CAAA,mCAAMC,gBAAK,MAAA,EAAA;AAAA,kBAAA;AAAA,gBAC3B;AAAA,gBAED;AAAA,gBACAH,2BAAA,IAAA,OAAA,EAAI,WAAW,QAAQ,SAAU,UAAQ,SAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UAC5C;AAAA,UAEFA,2BAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,KAAK;AAAA,cACL,IAAI;AAAA,cACJ,QAAQ,CAAC;AAAA,cACT,WAAW,GAAG,QAAQ,SAAS;AAAA,gBAC7B,CAAC,QAAQ,MAAM,GAAG,CAAC;AAAA,gBACnB,CAAC,QAAQ,QAAQ,GAAG,EAAE,SAAS,WAAW;AAAA,cAAA,CAC3C;AAAA,cAEA;AAAA,YAAA;AAAA,UACH;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;;;"}
1
+ {"version":3,"file":"Section.cjs","sources":["../../../src/Section/Section.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Down, Up } from \"@hitachivantara/uikit-react-icons\";\n\nimport { HvButton, HvButtonProps } from \"../Button\";\nimport { useControlled } from \"../hooks/useControlled\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { useUniqueId } from \"../hooks/useUniqueId\";\nimport { HvBaseProps } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { setId } from \"../utils/setId\";\nimport { staticClasses, useClasses } from \"./Section.styles\";\n\nexport { staticClasses as sectionClasses };\n\nexport type HvSectionClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSectionProps\n extends Omit<HvBaseProps<HTMLDivElement>, \"title\"> {\n /** The title of the section */\n title?: React.ReactNode;\n /** Whether or not the section is expandable. */\n expandable?: boolean;\n /** Whether the section is open or not, if this property is defined the accordion must be fully controlled. */\n expanded?: boolean;\n /** When uncontrolled, defines the initial expanded state. */\n defaultExpanded?: boolean;\n /** Section actions */\n actions?: React.ReactNode;\n /** Section onExpand callback */\n onToggle?: (\n event: React.MouseEvent<HTMLButtonElement>,\n open: boolean,\n ) => void;\n /** Props to be passed to the expand button */\n expandButtonProps?: HvButtonProps;\n /** Determines whether or not the header has a shadow on the bottom border. */\n raisedHeader?: boolean;\n /** A Jss Object used to override or extend the styles applied to the empty state component. */\n classes?: HvSectionClasses;\n /** Content container ref. */\n contentRef?: React.Ref<HTMLDivElement>;\n}\n\n/**\n * Sections allow grouping information on a page under the same topic.\n */\nexport const HvSection = forwardRef<HTMLDivElement, HvSectionProps>(\n (props, ref) => {\n const {\n id,\n classes: classesProp,\n className,\n title,\n expandable,\n expanded,\n defaultExpanded = true,\n actions,\n onToggle,\n expandButtonProps,\n raisedHeader,\n contentRef,\n children,\n ...others\n } = useDefaultProps(\"HvSection\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const [isOpen, setIsOpen] = useControlled(\n expanded,\n Boolean(defaultExpanded),\n );\n\n const elementId = useUniqueId(id);\n const contentId = setId(elementId, \"content\");\n\n const showContent = expandable ? !!isOpen : true;\n\n return (\n <div\n ref={ref}\n id={elementId}\n className={cx(classes.root, className)}\n {...others}\n >\n {(title || actions || expandable) && (\n <div\n className={cx(classes.header, {\n [classes.raisedHeader]: raisedHeader && isOpen,\n })}\n >\n {expandable && (\n <HvButton\n icon\n onClick={(event) => {\n setIsOpen((o) => !o);\n onToggle?.(event, !isOpen);\n }}\n aria-expanded={isOpen}\n aria-controls={contentId}\n aria-label={isOpen ? \"Collapse\" : \"Expand\"}\n {...expandButtonProps}\n >\n {isOpen ? <Up /> : <Down />}\n </HvButton>\n )}\n {title}\n <div className={classes.actions}>{actions}</div>\n </div>\n )}\n <div\n ref={contentRef}\n id={contentId}\n hidden={!isOpen}\n className={cx(classes.content, {\n [classes.hidden]: !showContent,\n [classes.spaceTop]: !(title || actions || expandable),\n })}\n >\n {children}\n </div>\n </div>\n );\n },\n);\n"],"names":["forwardRef","useDefaultProps","useClasses","useControlled","useUniqueId","setId","jsxs","jsx","HvButton","Up","Down"],"mappings":";;;;;;;;;;;AA8CO,MAAM,YAAYA,MAAA;AAAA,EACvB,CAAC,OAAO,QAAQ;AACR,UAAA;AAAA,MACJ;AAAA,MACA,SAAS;AAAA,MACT;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,kBAAkB;AAAA,MAClB;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IAAA,IACDC,gBAAgB,gBAAA,aAAa,KAAK;AAEtC,UAAM,EAAE,SAAS,GAAG,IAAIC,0BAAW,WAAW;AAExC,UAAA,CAAC,QAAQ,SAAS,IAAIC,cAAA;AAAA,MAC1B;AAAA,MACA,QAAQ,eAAe;AAAA,IAAA;AAGnB,UAAA,YAAYC,wBAAY,EAAE;AAC1B,UAAA,YAAYC,MAAAA,MAAM,WAAW,SAAS;AAE5C,UAAM,cAAc,aAAa,CAAC,CAAC,SAAS;AAG1C,WAAAC,2BAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,IAAI;AAAA,QACJ,WAAW,GAAG,QAAQ,MAAM,SAAS;AAAA,QACpC,GAAG;AAAA,QAEF,UAAA;AAAA,WAAA,SAAS,WAAW,eACpBA,2BAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAW,GAAG,QAAQ,QAAQ;AAAA,gBAC5B,CAAC,QAAQ,YAAY,GAAG,gBAAgB;AAAA,cAAA,CACzC;AAAA,cAEA,UAAA;AAAA,gBACC,cAAAC,2BAAA;AAAA,kBAACC,OAAA;AAAA,kBAAA;AAAA,oBACC,MAAI;AAAA,oBACJ,SAAS,CAAC,UAAU;AACR,gCAAA,CAAC,MAAM,CAAC,CAAC;AACR,iCAAA,OAAO,CAAC,MAAM;AAAA,oBAC3B;AAAA,oBACA,iBAAe;AAAA,oBACf,iBAAe;AAAA,oBACf,cAAY,SAAS,aAAa;AAAA,oBACjC,GAAG;AAAA,oBAEH,UAAS,SAAAD,2BAAAA,IAACE,gBAAG,IAAA,CAAA,CAAA,mCAAMC,gBAAK,MAAA,EAAA;AAAA,kBAAA;AAAA,gBAC3B;AAAA,gBAED;AAAA,gBACAH,2BAAA,IAAA,OAAA,EAAI,WAAW,QAAQ,SAAU,UAAQ,SAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UAC5C;AAAA,UAEFA,2BAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,KAAK;AAAA,cACL,IAAI;AAAA,cACJ,QAAQ,CAAC;AAAA,cACT,WAAW,GAAG,QAAQ,SAAS;AAAA,gBAC7B,CAAC,QAAQ,MAAM,GAAG,CAAC;AAAA,gBACnB,CAAC,QAAQ,QAAQ,GAAG,EAAE,SAAS,WAAW;AAAA,cAAA,CAC3C;AAAA,cAEA;AAAA,YAAA;AAAA,UACH;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"Option.cjs","sources":["../../../src/Select/Option.tsx"],"sourcesContent":["import { useRef } from \"react\";\nimport { useOption } from \"@mui/base/useOption\";\nimport { OptionOwnProps } from \"@mui/base/Option\";\nimport { useForkRef } from \"@mui/material/utils\";\n\nimport { HvListItem, HvListItemProps } from \"../ListContainer\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { fixedForwardRef } from \"../types/generic\";\nimport { ExtractNames, createClasses } from \"../utils/classes\";\nimport { outlineStyles } from \"../utils/focusUtils\";\n\nconst { staticClasses, useClasses } = createClasses(\"HvOption\", {\n root: {},\n highlighted: {\n ...outlineStyles,\n },\n});\n\nexport { staticClasses as optionClasses };\n\nexport type HvOptionClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvOptionProps<OptionValue extends {}>\n extends Omit<HvListItemProps, \"value\" | \"disabled\">,\n Pick<OptionOwnProps<OptionValue>, \"disabled\" | \"label\" | \"value\"> {\n classes?: HvOptionClasses;\n}\n\nexport const HvOption = fixedForwardRef(function HvOption<\n OptionValue extends {}\n>(props: HvOptionProps<OptionValue>, ref: React.Ref<HTMLLIElement>) {\n const {\n classes: classesProp,\n className,\n disabled = false,\n label,\n value,\n children,\n ...others\n } = useDefaultProps(\"HvOption\", props);\n const { classes, cx } = useClasses(classesProp);\n\n const optionRef = useRef<HTMLElement>(null);\n const rootRef = useForkRef(optionRef, ref);\n\n const computedLabel =\n label ??\n (typeof children === \"string\"\n ? children\n : optionRef.current?.textContent?.trim());\n\n const { getRootProps, selected, highlighted } = useOption({\n disabled,\n label: computedLabel,\n rootRef,\n value,\n });\n\n return (\n <HvListItem\n ref={ref}\n selected={selected}\n className={cx(classes.root, className, {\n [classes.highlighted]: highlighted,\n })}\n {...getRootProps()}\n {...others}\n >\n {children}\n </HvListItem>\n );\n});\n"],"names":["createClasses","outlineStyles","fixedForwardRef","HvOption","useDefaultProps","classes","useRef","useForkRef","useOption","jsx","HvListItem"],"mappings":";;;;;;;;;;;AAWA,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,YAAY;AAAA,EAC9D,MAAM,CAAC;AAAA,EACP,aAAa;AAAA,IACX,GAAGC,WAAA;AAAA,EACL;AACF,CAAC;AAYM,MAAM,WAAWC,QAAAA,gBAAgB,SAASC,UAE/C,OAAmC,KAA+B;AAC5D,QAAA;AAAA,IACJ,SAAS;AAAA,IACT;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EAAA,IACDC,gBAAgB,gBAAA,YAAY,KAAK;AACrC,QAAM,EAAE,SAAAC,UAAS,GAAG,IAAI,WAAW,WAAW;AAExC,QAAA,YAAYC,aAAoB,IAAI;AACpC,QAAA,UAAUC,MAAAA,WAAW,WAAW,GAAG;AAEnC,QAAA,gBACJ,UACC,OAAO,aAAa,WACjB,WACA,UAAU,SAAS,aAAa,KAAK;AAE3C,QAAM,EAAE,cAAc,UAAU,YAAA,IAAgBC,UAAAA,UAAU;AAAA,IACxD;AAAA,IACA,OAAO;AAAA,IACP;AAAA,IACA;AAAA,EAAA,CACD;AAGC,SAAAC,2BAAA;AAAA,IAACC,SAAA;AAAA,IAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA,WAAW,GAAGL,SAAQ,MAAM,WAAW;AAAA,QACrC,CAACA,SAAQ,WAAW,GAAG;AAAA,MAAA,CACxB;AAAA,MACA,GAAG,aAAa;AAAA,MAChB,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA;AAGP,CAAC;;;"}
1
+ {"version":3,"file":"Option.cjs","sources":["../../../src/Select/Option.tsx"],"sourcesContent":["import { useRef } from \"react\";\nimport { OptionOwnProps } from \"@mui/base/Option\";\nimport { useOption } from \"@mui/base/useOption\";\nimport { useForkRef } from \"@mui/material/utils\";\n\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { HvListItem, HvListItemProps } from \"../ListContainer\";\nimport { fixedForwardRef } from \"../types/generic\";\nimport { createClasses, ExtractNames } from \"../utils/classes\";\nimport { outlineStyles } from \"../utils/focusUtils\";\n\nconst { staticClasses, useClasses } = createClasses(\"HvOption\", {\n root: {},\n highlighted: {\n ...outlineStyles,\n },\n});\n\nexport { staticClasses as optionClasses };\n\nexport type HvOptionClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvOptionProps<OptionValue extends {}>\n extends Omit<HvListItemProps, \"value\" | \"disabled\">,\n Pick<OptionOwnProps<OptionValue>, \"disabled\" | \"label\" | \"value\"> {\n classes?: HvOptionClasses;\n}\n\nexport const HvOption = fixedForwardRef(function HvOption<\n OptionValue extends {},\n>(props: HvOptionProps<OptionValue>, ref: React.Ref<HTMLLIElement>) {\n const {\n classes: classesProp,\n className,\n disabled = false,\n label,\n value,\n children,\n ...others\n } = useDefaultProps(\"HvOption\", props);\n const { classes, cx } = useClasses(classesProp);\n\n const optionRef = useRef<HTMLElement>(null);\n const rootRef = useForkRef(optionRef, ref);\n\n const computedLabel =\n label ??\n (typeof children === \"string\"\n ? children\n : optionRef.current?.textContent?.trim());\n\n const { getRootProps, selected, highlighted } = useOption({\n disabled,\n label: computedLabel,\n rootRef,\n value,\n });\n\n return (\n <HvListItem\n ref={ref}\n selected={selected}\n className={cx(classes.root, className, {\n [classes.highlighted]: highlighted,\n })}\n {...getRootProps()}\n {...others}\n >\n {children}\n </HvListItem>\n );\n});\n"],"names":["createClasses","outlineStyles","fixedForwardRef","HvOption","useDefaultProps","classes","useRef","useForkRef","useOption","jsx","HvListItem"],"mappings":";;;;;;;;;;;AAWA,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,YAAY;AAAA,EAC9D,MAAM,CAAC;AAAA,EACP,aAAa;AAAA,IACX,GAAGC,WAAA;AAAA,EACL;AACF,CAAC;AAYM,MAAM,WAAWC,QAAAA,gBAAgB,SAASC,UAE/C,OAAmC,KAA+B;AAC5D,QAAA;AAAA,IACJ,SAAS;AAAA,IACT;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EAAA,IACDC,gBAAgB,gBAAA,YAAY,KAAK;AACrC,QAAM,EAAE,SAAAC,UAAS,GAAG,IAAI,WAAW,WAAW;AAExC,QAAA,YAAYC,aAAoB,IAAI;AACpC,QAAA,UAAUC,MAAAA,WAAW,WAAW,GAAG;AAEnC,QAAA,gBACJ,UACC,OAAO,aAAa,WACjB,WACA,UAAU,SAAS,aAAa,KAAK;AAE3C,QAAM,EAAE,cAAc,UAAU,YAAA,IAAgBC,UAAAA,UAAU;AAAA,IACxD;AAAA,IACA,OAAO;AAAA,IACP;AAAA,IACA;AAAA,EAAA,CACD;AAGC,SAAAC,2BAAA;AAAA,IAACC,SAAA;AAAA,IAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA,WAAW,GAAGL,SAAQ,MAAM,WAAW;AAAA,QACrC,CAACA,SAAQ,WAAW,GAAG;AAAA,MAAA,CACxB;AAAA,MACA,GAAG,aAAa;AAAA,MAChB,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA;AAGP,CAAC;;;"}
@@ -4,8 +4,8 @@ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const React = require("react");
5
5
  const OptionGroup = require("@mui/base/OptionGroup");
6
6
  const uikitStyles = require("@hitachivantara/uikit-styles");
7
- const classes = require("../utils/classes.cjs");
8
7
  const useDefaultProps = require("../hooks/useDefaultProps.cjs");
8
+ const classes = require("../utils/classes.cjs");
9
9
  const { staticClasses, useClasses } = classes.createClasses("HvOptionGroup", {
10
10
  root: {
11
11
  listStyle: "none",
@@ -1 +1 @@
1
- {"version":3,"file":"OptionGroup.cjs","sources":["../../../src/Select/OptionGroup.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { OptionGroup, OptionGroupProps } from \"@mui/base/OptionGroup\";\nimport { theme } from \"@hitachivantara/uikit-styles\";\n\nimport { ExtractNames, createClasses } from \"../utils/classes\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\n\nconst { staticClasses, useClasses } = createClasses(\"HvOptionGroup\", {\n root: {\n listStyle: \"none\",\n ...theme.typography.label,\n },\n});\n\nexport { staticClasses as optionGroupClasses };\n\nexport type HvOptionGroupClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvOptionGroupProps extends OptionGroupProps {\n classes?: HvOptionGroupClasses;\n}\n\nexport const HvOptionGroup = forwardRef<HTMLLIElement, HvOptionGroupProps>(\n (props, ref) => {\n const {\n className,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvOptionGroup\", props);\n const { classes, cx } = useClasses(classesProp);\n\n return (\n <OptionGroup\n ref={ref}\n className={cx(classes.root, className)}\n {...others}\n />\n );\n }\n);\n"],"names":["createClasses","theme","forwardRef","useDefaultProps","classes","jsx","OptionGroup"],"mappings":";;;;;;;;AAOA,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,iBAAiB;AAAA,EACnE,MAAM;AAAA,IACJ,WAAW;AAAA,IACX,GAAGC,YAAAA,MAAM,WAAW;AAAA,EACtB;AACF,CAAC;AAUM,MAAM,gBAAgBC,MAAA;AAAA,EAC3B,CAAC,OAAO,QAAQ;AACR,UAAA;AAAA,MACJ;AAAA,MACA,SAAS;AAAA,MACT,GAAG;AAAA,IAAA,IACDC,gBAAgB,gBAAA,iBAAiB,KAAK;AAC1C,UAAM,EAAE,SAAAC,UAAS,GAAG,IAAI,WAAW,WAAW;AAG5C,WAAAC,2BAAA;AAAA,MAACC,YAAA;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAW,GAAGF,SAAQ,MAAM,SAAS;AAAA,QACpC,GAAG;AAAA,MAAA;AAAA,IAAA;AAAA,EAGV;AACF;;;"}
1
+ {"version":3,"file":"OptionGroup.cjs","sources":["../../../src/Select/OptionGroup.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { OptionGroup, OptionGroupProps } from \"@mui/base/OptionGroup\";\nimport { theme } from \"@hitachivantara/uikit-styles\";\n\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { createClasses, ExtractNames } from \"../utils/classes\";\n\nconst { staticClasses, useClasses } = createClasses(\"HvOptionGroup\", {\n root: {\n listStyle: \"none\",\n ...theme.typography.label,\n },\n});\n\nexport { staticClasses as optionGroupClasses };\n\nexport type HvOptionGroupClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvOptionGroupProps extends OptionGroupProps {\n classes?: HvOptionGroupClasses;\n}\n\nexport const HvOptionGroup = forwardRef<HTMLLIElement, HvOptionGroupProps>(\n (props, ref) => {\n const {\n className,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvOptionGroup\", props);\n const { classes, cx } = useClasses(classesProp);\n\n return (\n <OptionGroup\n ref={ref}\n className={cx(classes.root, className)}\n {...others}\n />\n );\n },\n);\n"],"names":["createClasses","theme","forwardRef","useDefaultProps","classes","jsx","OptionGroup"],"mappings":";;;;;;;;AAOA,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,iBAAiB;AAAA,EACnE,MAAM;AAAA,IACJ,WAAW;AAAA,IACX,GAAGC,YAAAA,MAAM,WAAW;AAAA,EACtB;AACF,CAAC;AAUM,MAAM,gBAAgBC,MAAA;AAAA,EAC3B,CAAC,OAAO,QAAQ;AACR,UAAA;AAAA,MACJ;AAAA,MACA,SAAS;AAAA,MACT,GAAG;AAAA,IAAA,IACDC,gBAAgB,gBAAA,iBAAiB,KAAK;AAC1C,UAAM,EAAE,SAAAC,UAAS,GAAG,IAAI,WAAW,WAAW;AAG5C,WAAAC,2BAAA;AAAA,MAACC,YAAA;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAW,GAAGF,SAAQ,MAAM,SAAS;AAAA,QACpC,GAAG;AAAA,MAAA;AAAA,IAAA;AAAA,EAGV;AACF;;;"}
@@ -2,15 +2,15 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const React = require("react");
5
- const clsx = require("clsx");
5
+ const Popper = require("@mui/base/Popper");
6
6
  const useSelect = require("@mui/base/useSelect");
7
7
  const utils = require("@mui/material/utils");
8
- const Popper = require("@mui/base/Popper");
9
- const generic = require("../types/generic.cjs");
8
+ const clsx = require("clsx");
10
9
  const useDefaultProps = require("../hooks/useDefaultProps.cjs");
11
- const Select_styles = require("./Select.styles.cjs");
12
- const setId = require("../utils/setId.cjs");
13
10
  const useUniqueId = require("../hooks/useUniqueId.cjs");
11
+ const generic = require("../types/generic.cjs");
12
+ const setId = require("../utils/setId.cjs");
13
+ const Select_styles = require("./Select.styles.cjs");
14
14
  const DropdownButton = require("../DropdownButton/DropdownButton.cjs");
15
15
  const Panel = require("../Panel/Panel.cjs");
16
16
  const FormElement = require("../Forms/FormElement/FormElement.cjs");
@@ -1 +1 @@
1
- {"version":3,"file":"Select.cjs","sources":["../../../src/Select/Select.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-use-before-define */\nimport { useRef, useState } from \"react\";\nimport type { Placement } from \"@popperjs/core\";\nimport clsx from \"clsx\";\n\nimport {\n SelectProvider,\n UseSelectParameters,\n useSelect,\n} from \"@mui/base/useSelect\";\nimport { useControlled, useForkRef } from \"@mui/material/utils\";\nimport { Popper } from \"@mui/base/Popper\";\nimport { SelectOption } from \"@mui/base/useOption\";\n\nimport {\n HvFormElement,\n HvFormElementProps,\n HvFormStatus,\n HvInfoMessage,\n HvLabel,\n HvWarningText,\n} from \"../Forms\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { fixedForwardRef } from \"../types/generic\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { staticClasses, useClasses } from \"./Select.styles\";\nimport { setId } from \"../utils/setId\";\nimport { useUniqueId } from \"../hooks/useUniqueId\";\nimport { HvPanel } from \"../Panel\";\nimport { HvListContainer } from \"../ListContainer\";\nimport { HvButtonProps } from \"../Button\";\nimport { HvDropdownButton } from \"../DropdownButton\";\n\nfunction defaultRenderValue<Value>(\n options: SelectOption<Value> | SelectOption<Value>[] | null\n) {\n if (Array.isArray(options)) {\n if (options.length === 0) return null;\n return <>{options.map((o) => o.label).join(\", \")}</>;\n }\n\n return options?.label ?? null;\n}\n\nconst mergeIds = (...ids: clsx.ClassValue[]) => clsx(ids) || undefined;\n\nexport { staticClasses as selectClasses };\n\nexport type HvSelectClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSelectProps<\n OptionValue extends {},\n Multiple extends boolean = false\n> extends Omit<HvFormElementProps, \"value\" | \"defaultValue\" | \"onChange\">,\n Pick<\n UseSelectParameters<OptionValue, Multiple>,\n | \"name\"\n | \"required\"\n | \"disabled\"\n | \"multiple\"\n | \"open\"\n | \"defaultOpen\"\n | \"value\"\n | \"defaultValue\"\n | \"buttonRef\"\n | \"options\"\n | \"getSerializedValue\"\n | \"onChange\"\n | \"onOpenChange\"\n >,\n Pick<HvButtonProps, \"size\" | \"variant\"> {\n classes?: HvSelectClasses;\n placeholder?: React.ReactNode;\n autoComplete?: string;\n /** Whether the width of the select panel can vary independently. */\n variableWidth?: boolean;\n}\n\n/**\n * The `HvSelect` component is a form control element that allows selection from a list of options.\n *\n * It aims to be aligned with the native HTML `<select>` and `<option>` APIs and be easily integrated with forms.\n *\n * @example\n * <HvSelect name=\"pets\">\n * <HvOption value=\"dog\">Dog</HvOption>\n * <HvOption value=\"cat\">Cat</HvOption>\n * </HvSelect>\n * */\nexport const HvSelect = fixedForwardRef(function HvSelect<\n OptionValue extends {},\n Multiple extends boolean\n>(\n props: HvSelectProps<OptionValue, Multiple>,\n ref: React.Ref<HTMLButtonElement>\n) {\n const {\n children,\n classes: classesProp,\n className,\n id: idProp,\n size,\n variant = \"secondarySubtle\",\n name,\n required,\n disabled: disabledProp,\n readOnly,\n label,\n open: openProp,\n defaultOpen,\n multiple,\n autoComplete,\n options: optionsProp,\n variableWidth,\n value: valueProp,\n defaultValue,\n placeholder,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n description,\n \"aria-describedby\": ariaDescribedBy,\n status,\n statusMessage,\n \"aria-errormessage\": ariaErrorMessage,\n getSerializedValue,\n onClick,\n onChange,\n onOpenChange,\n ...others\n } = useDefaultProps(\"HvSelect\", props);\n const { classes, cx } = useClasses(classesProp);\n\n const [placement, setPlacement] = useState<Placement>(\"bottom-start\");\n\n const buttonRef = useRef<HTMLButtonElement>(null);\n const handleButtonRef = useForkRef(ref, buttonRef);\n\n const {\n contextValue,\n disabled,\n getButtonProps,\n getListboxProps,\n getHiddenInputProps,\n getOptionMetadata,\n value,\n open,\n } = useSelect<OptionValue, Multiple>({\n componentName: \"HvSelect\",\n name,\n required,\n disabled: disabledProp,\n multiple,\n open: openProp,\n defaultOpen,\n value: valueProp,\n defaultValue,\n options: optionsProp,\n buttonRef: handleButtonRef,\n getSerializedValue,\n onChange,\n onOpenChange: handleOpenChange,\n });\n\n const id = useUniqueId(idProp);\n const labelId = useUniqueId(setId(idProp, \"label\"));\n const descriptionId = useUniqueId(setId(idProp, \"description\"));\n const errorMessageId = useUniqueId(setId(idProp, \"error\"));\n\n const [validationMessage] = useControlled({\n name: \"HvSelect.statusMessage\",\n controlled: statusMessage,\n default: \"Required\",\n });\n const [validationState, setValidationState] = useControlled<HvFormStatus>({\n name: \"HvSelect.status\",\n controlled: status,\n default: \"standBy\",\n });\n\n function handleOpenChange(newOpen: boolean) {\n if (!newOpen) {\n const hasValue = multiple ? (value as OptionValue[]).length > 0 : !!value;\n setValidationState(required && !hasValue ? \"invalid\" : \"valid\");\n }\n onOpenChange?.(newOpen);\n }\n\n // the error message area will only be created if:\n // - an external element that provides an error message isn't identified via aria-errormessage AND\n // - both status and statusMessage properties are being controlled OR\n // - status is uncontrolled and required is true\n const canShowError =\n ariaErrorMessage == null &&\n ((status !== undefined && statusMessage !== undefined) ||\n (status === undefined && required));\n\n const isInvalid = validationState === \"invalid\";\n\n const actualValue = multiple\n ? (value as OptionValue[])\n .map((v) => getOptionMetadata(v))\n .filter((v): v is SelectOption<OptionValue> => v !== undefined)\n : getOptionMetadata(value as OptionValue) ?? null;\n\n const isOpen = open && !!children;\n\n return (\n <HvFormElement\n name={name}\n required={required}\n disabled={disabled}\n readOnly={readOnly}\n status={validationState}\n className={cx(classes.root, className, {\n [classes.disabled]: disabled,\n [classes.readOnly]: readOnly,\n })}\n {...others}\n >\n {(label || description) && (\n <div className={classes.labelContainer}>\n {label && (\n <HvLabel\n id={labelId}\n htmlFor={id}\n label={label}\n className={classes.label}\n />\n )}\n {description && (\n <HvInfoMessage id={descriptionId} className={classes.description}>\n {description}\n </HvInfoMessage>\n )}\n </div>\n )}\n <HvDropdownButton\n id={id}\n open={isOpen}\n disabled={disabled}\n readOnly={readOnly}\n className={cx(classes.select, {\n [classes.invalid]: validationState === \"invalid\",\n })}\n placement={placement}\n size={size}\n variant={variant}\n aria-label={ariaLabel}\n aria-labelledby={mergeIds(label && labelId, ariaLabelledBy)}\n aria-invalid={isInvalid ? true : undefined}\n aria-errormessage={errorMessageId}\n aria-describedby={mergeIds(\n description && descriptionId,\n ariaDescribedBy\n )}\n {...getButtonProps()}\n >\n {defaultRenderValue(actualValue) ?? placeholder}\n </HvDropdownButton>\n <Popper\n open={isOpen}\n keepMounted\n disablePortal\n anchorEl={buttonRef.current}\n className={classes.popper}\n placement={placement}\n modifiers={[\n {\n enabled: true,\n phase: \"main\",\n fn: ({ state }) => setPlacement(state.placement),\n },\n ]}\n >\n <HvPanel\n style={{\n width: variableWidth\n ? \"auto\"\n : (buttonRef.current?.clientWidth || 0) + 2,\n }}\n className={cx(classes.panel, className, {\n [classes.panelOpenedUp]: placement.includes(\"top\"),\n [classes.panelOpenedDown]: placement.includes(\"bottom\"),\n })}\n >\n <SelectProvider value={contextValue}>\n <HvListContainer condensed selectable {...getListboxProps()}>\n {children}\n </HvListContainer>\n </SelectProvider>\n </HvPanel>\n </Popper>\n\n <input {...getHiddenInputProps()} autoComplete={autoComplete} />\n\n {canShowError && (\n <HvWarningText\n id={errorMessageId}\n disableBorder\n className={classes.error}\n >\n {validationMessage}\n </HvWarningText>\n )}\n </HvFormElement>\n );\n});\n"],"names":["jsx","Fragment","clsx","fixedForwardRef","HvSelect","useDefaultProps","useClasses","useState","useRef","useForkRef","useSelect","useUniqueId","setId","useControlled","jsxs","HvFormElement","HvLabel","HvInfoMessage","HvDropdownButton","Popper","HvPanel","SelectProvider","HvListContainer","HvWarningText"],"mappings":"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"}
1
+ {"version":3,"file":"Select.cjs","sources":["../../../src/Select/Select.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-use-before-define */\nimport { useRef, useState } from \"react\";\nimport { Popper } from \"@mui/base/Popper\";\nimport { SelectOption } from \"@mui/base/useOption\";\nimport {\n SelectProvider,\n useSelect,\n UseSelectParameters,\n} from \"@mui/base/useSelect\";\nimport { useControlled, useForkRef } from \"@mui/material/utils\";\nimport type { Placement } from \"@popperjs/core\";\nimport clsx from \"clsx\";\n\nimport { HvButtonProps } from \"../Button\";\nimport { HvDropdownButton } from \"../DropdownButton\";\nimport {\n HvFormElement,\n HvFormElementProps,\n HvFormStatus,\n HvInfoMessage,\n HvLabel,\n HvWarningText,\n} from \"../Forms\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { useUniqueId } from \"../hooks/useUniqueId\";\nimport { HvListContainer } from \"../ListContainer\";\nimport { HvPanel } from \"../Panel\";\nimport { fixedForwardRef } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { setId } from \"../utils/setId\";\nimport { staticClasses, useClasses } from \"./Select.styles\";\n\nfunction defaultRenderValue<Value>(\n options: SelectOption<Value> | SelectOption<Value>[] | null,\n) {\n if (Array.isArray(options)) {\n if (options.length === 0) return null;\n return <>{options.map((o) => o.label).join(\", \")}</>;\n }\n\n return options?.label ?? null;\n}\n\nconst mergeIds = (...ids: clsx.ClassValue[]) => clsx(ids) || undefined;\n\nexport { staticClasses as selectClasses };\n\nexport type HvSelectClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSelectProps<\n OptionValue extends {},\n Multiple extends boolean = false,\n> extends Omit<HvFormElementProps, \"value\" | \"defaultValue\" | \"onChange\">,\n Pick<\n UseSelectParameters<OptionValue, Multiple>,\n | \"name\"\n | \"required\"\n | \"disabled\"\n | \"multiple\"\n | \"open\"\n | \"defaultOpen\"\n | \"value\"\n | \"defaultValue\"\n | \"buttonRef\"\n | \"options\"\n | \"getSerializedValue\"\n | \"onChange\"\n | \"onOpenChange\"\n >,\n Pick<HvButtonProps, \"size\" | \"variant\"> {\n classes?: HvSelectClasses;\n placeholder?: React.ReactNode;\n autoComplete?: string;\n /** Whether the width of the select panel can vary independently. */\n variableWidth?: boolean;\n}\n\n/**\n * The `HvSelect` component is a form control element that allows selection from a list of options.\n *\n * It aims to be aligned with the native HTML `<select>` and `<option>` APIs and be easily integrated with forms.\n *\n * @example\n * <HvSelect name=\"pets\">\n * <HvOption value=\"dog\">Dog</HvOption>\n * <HvOption value=\"cat\">Cat</HvOption>\n * </HvSelect>\n * */\nexport const HvSelect = fixedForwardRef(function HvSelect<\n OptionValue extends {},\n Multiple extends boolean,\n>(\n props: HvSelectProps<OptionValue, Multiple>,\n ref: React.Ref<HTMLButtonElement>,\n) {\n const {\n children,\n classes: classesProp,\n className,\n id: idProp,\n size,\n variant = \"secondarySubtle\",\n name,\n required,\n disabled: disabledProp,\n readOnly,\n label,\n open: openProp,\n defaultOpen,\n multiple,\n autoComplete,\n options: optionsProp,\n variableWidth,\n value: valueProp,\n defaultValue,\n placeholder,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n description,\n \"aria-describedby\": ariaDescribedBy,\n status,\n statusMessage,\n \"aria-errormessage\": ariaErrorMessage,\n getSerializedValue,\n onClick,\n onChange,\n onOpenChange,\n ...others\n } = useDefaultProps(\"HvSelect\", props);\n const { classes, cx } = useClasses(classesProp);\n\n const [placement, setPlacement] = useState<Placement>(\"bottom-start\");\n\n const buttonRef = useRef<HTMLButtonElement>(null);\n const handleButtonRef = useForkRef(ref, buttonRef);\n\n const {\n contextValue,\n disabled,\n getButtonProps,\n getListboxProps,\n getHiddenInputProps,\n getOptionMetadata,\n value,\n open,\n } = useSelect<OptionValue, Multiple>({\n componentName: \"HvSelect\",\n name,\n required,\n disabled: disabledProp,\n multiple,\n open: openProp,\n defaultOpen,\n value: valueProp,\n defaultValue,\n options: optionsProp,\n buttonRef: handleButtonRef,\n getSerializedValue,\n onChange,\n onOpenChange: handleOpenChange,\n });\n\n const id = useUniqueId(idProp);\n const labelId = useUniqueId(setId(idProp, \"label\"));\n const descriptionId = useUniqueId(setId(idProp, \"description\"));\n const errorMessageId = useUniqueId(setId(idProp, \"error\"));\n\n const [validationMessage] = useControlled({\n name: \"HvSelect.statusMessage\",\n controlled: statusMessage,\n default: \"Required\",\n });\n const [validationState, setValidationState] = useControlled<HvFormStatus>({\n name: \"HvSelect.status\",\n controlled: status,\n default: \"standBy\",\n });\n\n function handleOpenChange(newOpen: boolean) {\n if (!newOpen) {\n const hasValue = multiple ? (value as OptionValue[]).length > 0 : !!value;\n setValidationState(required && !hasValue ? \"invalid\" : \"valid\");\n }\n onOpenChange?.(newOpen);\n }\n\n // the error message area will only be created if:\n // - an external element that provides an error message isn't identified via aria-errormessage AND\n // - both status and statusMessage properties are being controlled OR\n // - status is uncontrolled and required is true\n const canShowError =\n ariaErrorMessage == null &&\n ((status !== undefined && statusMessage !== undefined) ||\n (status === undefined && required));\n\n const isInvalid = validationState === \"invalid\";\n\n const actualValue = multiple\n ? (value as OptionValue[])\n .map((v) => getOptionMetadata(v))\n .filter((v): v is SelectOption<OptionValue> => v !== undefined)\n : getOptionMetadata(value as OptionValue) ?? null;\n\n const isOpen = open && !!children;\n\n return (\n <HvFormElement\n name={name}\n required={required}\n disabled={disabled}\n readOnly={readOnly}\n status={validationState}\n className={cx(classes.root, className, {\n [classes.disabled]: disabled,\n [classes.readOnly]: readOnly,\n })}\n {...others}\n >\n {(label || description) && (\n <div className={classes.labelContainer}>\n {label && (\n <HvLabel\n id={labelId}\n htmlFor={id}\n label={label}\n className={classes.label}\n />\n )}\n {description && (\n <HvInfoMessage id={descriptionId} className={classes.description}>\n {description}\n </HvInfoMessage>\n )}\n </div>\n )}\n <HvDropdownButton\n id={id}\n open={isOpen}\n disabled={disabled}\n readOnly={readOnly}\n className={cx(classes.select, {\n [classes.invalid]: validationState === \"invalid\",\n })}\n placement={placement}\n size={size}\n variant={variant}\n aria-label={ariaLabel}\n aria-labelledby={mergeIds(label && labelId, ariaLabelledBy)}\n aria-invalid={isInvalid ? true : undefined}\n aria-errormessage={errorMessageId}\n aria-describedby={mergeIds(\n description && descriptionId,\n ariaDescribedBy,\n )}\n {...getButtonProps()}\n >\n {defaultRenderValue(actualValue) ?? placeholder}\n </HvDropdownButton>\n <Popper\n open={isOpen}\n keepMounted\n disablePortal\n anchorEl={buttonRef.current}\n className={classes.popper}\n placement={placement}\n modifiers={[\n {\n enabled: true,\n phase: \"main\",\n fn: ({ state }) => setPlacement(state.placement),\n },\n ]}\n >\n <HvPanel\n style={{\n width: variableWidth\n ? \"auto\"\n : (buttonRef.current?.clientWidth || 0) + 2,\n }}\n className={cx(classes.panel, className, {\n [classes.panelOpenedUp]: placement.includes(\"top\"),\n [classes.panelOpenedDown]: placement.includes(\"bottom\"),\n })}\n >\n <SelectProvider value={contextValue}>\n <HvListContainer condensed selectable {...getListboxProps()}>\n {children}\n </HvListContainer>\n </SelectProvider>\n </HvPanel>\n </Popper>\n\n <input {...getHiddenInputProps()} autoComplete={autoComplete} />\n\n {canShowError && (\n <HvWarningText\n id={errorMessageId}\n disableBorder\n className={classes.error}\n >\n {validationMessage}\n </HvWarningText>\n )}\n </HvFormElement>\n );\n});\n"],"names":["jsx","Fragment","clsx","fixedForwardRef","HvSelect","useDefaultProps","useClasses","useState","useRef","useForkRef","useSelect","useUniqueId","setId","useControlled","jsxs","HvFormElement","HvLabel","HvInfoMessage","HvDropdownButton","Popper","HvPanel","SelectProvider","HvListContainer","HvWarningText"],"mappings":"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"}
@@ -3,11 +3,11 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const React = require("react");
5
5
  const utils = require("@mui/material/utils");
6
+ const useControlled = require("../hooks/useControlled.cjs");
6
7
  const useDefaultProps = require("../hooks/useDefaultProps.cjs");
7
8
  const useUniqueId = require("../hooks/useUniqueId.cjs");
8
- const useControlled = require("../hooks/useControlled.cjs");
9
- const multiSelectionEventHandler = require("../utils/multiSelectionEventHandler.cjs");
10
9
  const keyboardUtils = require("../utils/keyboardUtils.cjs");
10
+ const multiSelectionEventHandler = require("../utils/multiSelectionEventHandler.cjs");
11
11
  const setId = require("../utils/setId.cjs");
12
12
  const SelectionList_styles = require("./SelectionList.styles.cjs");
13
13
  const FormElement = require("../Forms/FormElement/FormElement.cjs");
@@ -1 +1 @@
1
- {"version":3,"file":"SelectionList.cjs","sources":["../../../src/SelectionList/SelectionList.tsx"],"sourcesContent":["import {\n useCallback,\n useMemo,\n useRef,\n useEffect,\n forwardRef,\n Children,\n cloneElement,\n} from \"react\";\nimport { useForkRef } from \"@mui/material/utils\";\n\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { HvBaseProps } from \"../types/generic\";\nimport { useUniqueId } from \"../hooks/useUniqueId\";\nimport { useControlled } from \"../hooks/useControlled\";\nimport { multiSelectionEventHandler } from \"../utils/multiSelectionEventHandler\";\nimport { isKey } from \"../utils/keyboardUtils\";\nimport { setId } from \"../utils/setId\";\nimport { HvFormElement, HvFormStatus } from \"../Forms/FormElement\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { HvLabel } from \"../Forms/Label\";\nimport { HvInfoMessage } from \"../Forms/InfoMessage\";\nimport { HvWarningText } from \"../Forms/WarningText\";\nimport { HvListContainer } from \"../ListContainer\";\n\nimport { staticClasses, useClasses } from \"./SelectionList.styles\";\n\nexport { staticClasses as selectionListClasses };\n\nexport type HvSelectionListClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSelectionListProps\n extends HvBaseProps<HTMLUListElement, \"onChange\"> {\n /** The form element name. */\n name?: string;\n /**\n * The value of the form element. It must be represented in the child list items.\n *\n * Can either be a single value (when multiple = false) or an\n * array of values (when multiple = true).\n *\n * When defined the selection list state becomes controlled.\n */\n value?: any | any[];\n /** When uncontrolled, defines the initial value. */\n defaultValue?: any | any[];\n /**\n * The label of the form element.\n *\n * The form element must be labeled for accessibility reasons.\n * If not provided, an aria-label or aria-labelledby must be provided instead.\n */\n label?: React.ReactNode;\n /** Provide additional descriptive text for the form element. */\n description?: React.ReactNode;\n /** Indicates that the form element is disabled. If `true` the state is propagated to the children list items. */\n disabled?: boolean;\n /** Indicates that the form element is not editable. */\n readOnly?: boolean;\n /** Indicates that user input is required on the form element. */\n required?: boolean;\n /**\n * The status of the form element.\n *\n * Valid is correct, invalid is incorrect and standBy means no validations have run.\n *\n * When uncontrolled and unspecified it will default to \"standBy\" and change to either \"valid\"\n * or \"invalid\" after any change to the state.\n */\n status?: HvFormStatus;\n /**\n * The error message to show when the validation status is \"invalid\".\n *\n * Defaults to \"Required\" when the status is uncontrolled and no `aria-errormessage` is provided.\n */\n statusMessage?: string;\n /** Indicates that the user may select more than one item from the current selectable list items. */\n multiple?: boolean;\n /** If `true`, selection can be toggled when single selection. */\n singleSelectionToggle?: boolean;\n /** Indicates whether the list orientation is horizontal or vertical. Defaults to vertical. */\n orientation?: \"vertical\" | \"horizontal\";\n /** The callback fired when the value changes. */\n onChange?: (event: React.MouseEvent, value: any) => void;\n /** A Jss Object used to override or extend the styles applied to the component. */\n classes?: HvSelectionListClasses;\n}\n\nconst getValueFromSelectedChildren = (\n children: React.ReactNode,\n multiple: boolean\n) => {\n const selectedValues = Children.toArray(children)\n .map((child: any) => {\n const childIsControlled = child?.props?.selected !== undefined;\n const childIsSelected =\n child && childIsControlled\n ? child.props?.selected\n : child.props?.defaultSelected;\n\n return childIsSelected ? child?.props.value : undefined;\n })\n .filter((v) => v !== undefined);\n\n return multiple ? selectedValues : selectedValues?.[0];\n};\n\n/**\n * Allows the user to select one or more items from a list of choices.\n *\n * Although it supports multi-selection, DS recommends the use of a selection list\n * when it’s clear that the user can only select just one option from the range provided.\n */\nexport const HvSelectionList = forwardRef<\n HTMLUListElement,\n HvSelectionListProps\n>((props, ref) => {\n const {\n id,\n classes: classesProp,\n className,\n children,\n name,\n value: valueProp,\n defaultValue,\n required = false,\n readOnly = false,\n disabled = false,\n label,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n description,\n \"aria-describedby\": ariaDescribedBy,\n onChange,\n status,\n statusMessage,\n \"aria-errormessage\": ariaErrorMessage,\n orientation = \"vertical\",\n multiple = false,\n singleSelectionToggle = false,\n ...others\n } = useDefaultProps(\"HvSelectionList\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const elementId = useUniqueId(id);\n\n const [value, setValue] = useControlled(\n valueProp,\n defaultValue !== undefined\n ? defaultValue\n : // when uncontrolled and no default value is given,\n // extract the initial selected values from the children own state\n () => getValueFromSelectedChildren(children, multiple)\n );\n\n const [validationState, setValidationState] = useControlled(\n status,\n \"standBy\"\n );\n\n const [validationMessage] = useControlled(statusMessage, \"Required\");\n\n const [allValues, selectedState] = useMemo(() => {\n const childValues: any[] = [];\n const childSelectedState: boolean[] = [];\n\n Children.toArray(children).forEach((child: any, i: number) => {\n const childValue = child?.props?.value;\n const childIsSelected = multiple\n ? value.indexOf(childValue) !== -1\n : value === childValue;\n\n childValues[i] = childValue;\n childSelectedState[i] = childIsSelected;\n });\n\n return [childValues, childSelectedState];\n }, [children, multiple, value]);\n\n const selectionAnchor = useRef(undefined);\n\n const listRef = useRef<any>(null);\n const listForkedRef = useForkRef(ref, listRef);\n\n useEffect(() => {\n const handleMeta = (event: KeyboardEvent) => {\n const tempArray: any[] = [];\n if (\n (isKey(event, \"ArrowUp\") &&\n event.shiftKey &&\n listRef.current.contains(event.target)) ||\n (isKey(event, \"ArrowDown\") &&\n event.shiftKey &&\n listRef.current.contains(event.target))\n ) {\n selectedState.forEach((isSelected, i) => {\n if (i === (event.target as any).value - 1) {\n if (!isSelected) {\n tempArray.push(allValues[i]);\n }\n } else if (isSelected) {\n tempArray.push(allValues[i]);\n }\n });\n setValue(tempArray);\n }\n };\n window.addEventListener(\"keyup\", handleMeta);\n\n return () => {\n window.removeEventListener(\"keyup\", handleMeta);\n };\n }, [allValues, selectedState, setValue]);\n\n const onChildChangeInterceptor = useCallback(\n (\n index: number,\n childOnClick: (e: React.MouseEvent) => void,\n evt: React.MouseEvent\n ) => {\n childOnClick?.(evt);\n\n if (!readOnly && !disabled) {\n let newValue: any;\n if (multiple) {\n newValue = multiSelectionEventHandler(\n evt,\n index,\n selectionAnchor,\n allValues,\n selectedState,\n undefined\n );\n } else {\n newValue =\n singleSelectionToggle && selectedState[index]\n ? null\n : allValues[index];\n }\n\n onChange?.(evt, newValue);\n\n setValue(() => {\n // This will only run if uncontrolled\n\n if (required && newValue.length === 0) {\n setValidationState(\"invalid\");\n } else {\n setValidationState(\"valid\");\n }\n\n return newValue;\n });\n }\n },\n [\n allValues,\n disabled,\n multiple,\n onChange,\n readOnly,\n required,\n selectedState,\n setValidationState,\n setValue,\n singleSelectionToggle,\n selectionAnchor,\n ]\n );\n\n const modifiedChildren = useMemo(() => {\n return Children.map(children, (child: any, i: number) => {\n const childIsSelected = selectedState[i];\n\n return cloneElement(child, {\n role: \"option\",\n selected: childIsSelected,\n onClick: (evt) =>\n onChildChangeInterceptor(i, child?.props?.onClick, evt),\n disabled: disabled || child?.props?.disabled,\n });\n });\n }, [children, disabled, onChildChangeInterceptor, selectedState]);\n\n // The error message area will only be created if:\n // - an external element that provides an error message isn't identified via aria-errormessage AND\n // - both status and statusMessage properties are being controlled OR\n // - status is uncontrolled and required is true\n const canShowError =\n ariaErrorMessage == null &&\n ((status !== undefined && statusMessage !== undefined) ||\n (status === undefined && required));\n\n const errorMessageId = canShowError\n ? setId(elementId, \"error\")\n : ariaErrorMessage;\n\n const listId = (label && setId(elementId, \"listbox\")) || \"\";\n\n return (\n <HvFormElement\n id={id}\n name={name}\n status={validationState}\n disabled={disabled}\n required={required}\n readOnly={readOnly}\n className={cx(classes.root, className)}\n >\n {label && (\n <HvLabel\n id={setId(elementId, \"label\")}\n label={label}\n className={classes.label}\n />\n )}\n {description && (\n <HvInfoMessage\n id={setId(elementId, \"description\")}\n className={classes.description}\n >\n {description}\n </HvInfoMessage>\n )}\n\n <HvListContainer\n id={listId}\n interactive\n condensed\n role=\"listbox\"\n aria-multiselectable={multiple || undefined}\n aria-label={ariaLabel}\n aria-labelledby={\n [label && setId(elementId, \"label\"), ariaLabelledBy]\n .join(\" \")\n .trim() || undefined\n }\n aria-invalid={validationState === \"invalid\" ? true : undefined}\n aria-errormessage={\n validationState === \"invalid\" ? errorMessageId : undefined\n }\n aria-describedby={\n [description && setId(elementId, \"description\"), ariaDescribedBy]\n .join(\" \")\n .trim() || undefined\n }\n className={cx(classes.listbox, {\n [classes.vertical]: orientation === \"vertical\",\n [classes.horizontal]: orientation === \"horizontal\",\n [classes.invalid]: validationState === \"invalid\",\n })}\n ref={listForkedRef}\n {...others}\n >\n {modifiedChildren}\n </HvListContainer>\n\n {canShowError && (\n <HvWarningText\n id={setId(elementId, \"error\")}\n disableBorder\n className={classes.error}\n >\n {validationMessage}\n </HvWarningText>\n )}\n </HvFormElement>\n );\n});\n"],"names":["Children","forwardRef","useDefaultProps","useClasses","useUniqueId","useControlled","useMemo","useRef","useForkRef","useEffect","isKey","useCallback","multiSelectionEventHandler","cloneElement","setId","jsxs","HvFormElement","jsx","HvLabel","HvInfoMessage","HvListContainer","HvWarningText"],"mappings":"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"}
1
+ {"version":3,"file":"SelectionList.cjs","sources":["../../../src/SelectionList/SelectionList.tsx"],"sourcesContent":["import {\n Children,\n cloneElement,\n forwardRef,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from \"react\";\nimport { useForkRef } from \"@mui/material/utils\";\n\nimport { HvFormElement, HvFormStatus } from \"../Forms/FormElement\";\nimport { HvInfoMessage } from \"../Forms/InfoMessage\";\nimport { HvLabel } from \"../Forms/Label\";\nimport { HvWarningText } from \"../Forms/WarningText\";\nimport { useControlled } from \"../hooks/useControlled\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { useUniqueId } from \"../hooks/useUniqueId\";\nimport { HvListContainer } from \"../ListContainer\";\nimport { HvBaseProps } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { isKey } from \"../utils/keyboardUtils\";\nimport { multiSelectionEventHandler } from \"../utils/multiSelectionEventHandler\";\nimport { setId } from \"../utils/setId\";\nimport { staticClasses, useClasses } from \"./SelectionList.styles\";\n\nexport { staticClasses as selectionListClasses };\n\nexport type HvSelectionListClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSelectionListProps\n extends HvBaseProps<HTMLUListElement, \"onChange\"> {\n /** The form element name. */\n name?: string;\n /**\n * The value of the form element. It must be represented in the child list items.\n *\n * Can either be a single value (when multiple = false) or an\n * array of values (when multiple = true).\n *\n * When defined the selection list state becomes controlled.\n */\n value?: any | any[];\n /** When uncontrolled, defines the initial value. */\n defaultValue?: any | any[];\n /**\n * The label of the form element.\n *\n * The form element must be labeled for accessibility reasons.\n * If not provided, an aria-label or aria-labelledby must be provided instead.\n */\n label?: React.ReactNode;\n /** Provide additional descriptive text for the form element. */\n description?: React.ReactNode;\n /** Indicates that the form element is disabled. If `true` the state is propagated to the children list items. */\n disabled?: boolean;\n /** Indicates that the form element is not editable. */\n readOnly?: boolean;\n /** Indicates that user input is required on the form element. */\n required?: boolean;\n /**\n * The status of the form element.\n *\n * Valid is correct, invalid is incorrect and standBy means no validations have run.\n *\n * When uncontrolled and unspecified it will default to \"standBy\" and change to either \"valid\"\n * or \"invalid\" after any change to the state.\n */\n status?: HvFormStatus;\n /**\n * The error message to show when the validation status is \"invalid\".\n *\n * Defaults to \"Required\" when the status is uncontrolled and no `aria-errormessage` is provided.\n */\n statusMessage?: string;\n /** Indicates that the user may select more than one item from the current selectable list items. */\n multiple?: boolean;\n /** If `true`, selection can be toggled when single selection. */\n singleSelectionToggle?: boolean;\n /** Indicates whether the list orientation is horizontal or vertical. Defaults to vertical. */\n orientation?: \"vertical\" | \"horizontal\";\n /** The callback fired when the value changes. */\n onChange?: (event: React.MouseEvent, value: any) => void;\n /** A Jss Object used to override or extend the styles applied to the component. */\n classes?: HvSelectionListClasses;\n}\n\nconst getValueFromSelectedChildren = (\n children: React.ReactNode,\n multiple: boolean,\n) => {\n const selectedValues = Children.toArray(children)\n .map((child: any) => {\n const childIsControlled = child?.props?.selected !== undefined;\n const childIsSelected =\n child && childIsControlled\n ? child.props?.selected\n : child.props?.defaultSelected;\n\n return childIsSelected ? child?.props.value : undefined;\n })\n .filter((v) => v !== undefined);\n\n return multiple ? selectedValues : selectedValues?.[0];\n};\n\n/**\n * Allows the user to select one or more items from a list of choices.\n *\n * Although it supports multi-selection, DS recommends the use of a selection list\n * when it’s clear that the user can only select just one option from the range provided.\n */\nexport const HvSelectionList = forwardRef<\n HTMLUListElement,\n HvSelectionListProps\n>((props, ref) => {\n const {\n id,\n classes: classesProp,\n className,\n children,\n name,\n value: valueProp,\n defaultValue,\n required = false,\n readOnly = false,\n disabled = false,\n label,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n description,\n \"aria-describedby\": ariaDescribedBy,\n onChange,\n status,\n statusMessage,\n \"aria-errormessage\": ariaErrorMessage,\n orientation = \"vertical\",\n multiple = false,\n singleSelectionToggle = false,\n ...others\n } = useDefaultProps(\"HvSelectionList\", props);\n\n const { classes, cx } = useClasses(classesProp);\n\n const elementId = useUniqueId(id);\n\n const [value, setValue] = useControlled(\n valueProp,\n defaultValue !== undefined\n ? defaultValue\n : // when uncontrolled and no default value is given,\n // extract the initial selected values from the children own state\n () => getValueFromSelectedChildren(children, multiple),\n );\n\n const [validationState, setValidationState] = useControlled(\n status,\n \"standBy\",\n );\n\n const [validationMessage] = useControlled(statusMessage, \"Required\");\n\n const [allValues, selectedState] = useMemo(() => {\n const childValues: any[] = [];\n const childSelectedState: boolean[] = [];\n\n Children.toArray(children).forEach((child: any, i: number) => {\n const childValue = child?.props?.value;\n const childIsSelected = multiple\n ? value.indexOf(childValue) !== -1\n : value === childValue;\n\n childValues[i] = childValue;\n childSelectedState[i] = childIsSelected;\n });\n\n return [childValues, childSelectedState];\n }, [children, multiple, value]);\n\n const selectionAnchor = useRef(undefined);\n\n const listRef = useRef<any>(null);\n const listForkedRef = useForkRef(ref, listRef);\n\n useEffect(() => {\n const handleMeta = (event: KeyboardEvent) => {\n const tempArray: any[] = [];\n if (\n (isKey(event, \"ArrowUp\") &&\n event.shiftKey &&\n listRef.current.contains(event.target)) ||\n (isKey(event, \"ArrowDown\") &&\n event.shiftKey &&\n listRef.current.contains(event.target))\n ) {\n selectedState.forEach((isSelected, i) => {\n if (i === (event.target as any).value - 1) {\n if (!isSelected) {\n tempArray.push(allValues[i]);\n }\n } else if (isSelected) {\n tempArray.push(allValues[i]);\n }\n });\n setValue(tempArray);\n }\n };\n window.addEventListener(\"keyup\", handleMeta);\n\n return () => {\n window.removeEventListener(\"keyup\", handleMeta);\n };\n }, [allValues, selectedState, setValue]);\n\n const onChildChangeInterceptor = useCallback(\n (\n index: number,\n childOnClick: (e: React.MouseEvent) => void,\n evt: React.MouseEvent,\n ) => {\n childOnClick?.(evt);\n\n if (!readOnly && !disabled) {\n let newValue: any;\n if (multiple) {\n newValue = multiSelectionEventHandler(\n evt,\n index,\n selectionAnchor,\n allValues,\n selectedState,\n undefined,\n );\n } else {\n newValue =\n singleSelectionToggle && selectedState[index]\n ? null\n : allValues[index];\n }\n\n onChange?.(evt, newValue);\n\n setValue(() => {\n // This will only run if uncontrolled\n\n if (required && newValue.length === 0) {\n setValidationState(\"invalid\");\n } else {\n setValidationState(\"valid\");\n }\n\n return newValue;\n });\n }\n },\n [\n allValues,\n disabled,\n multiple,\n onChange,\n readOnly,\n required,\n selectedState,\n setValidationState,\n setValue,\n singleSelectionToggle,\n selectionAnchor,\n ],\n );\n\n const modifiedChildren = useMemo(() => {\n return Children.map(children, (child: any, i: number) => {\n const childIsSelected = selectedState[i];\n\n return cloneElement(child, {\n role: \"option\",\n selected: childIsSelected,\n onClick: (evt) =>\n onChildChangeInterceptor(i, child?.props?.onClick, evt),\n disabled: disabled || child?.props?.disabled,\n });\n });\n }, [children, disabled, onChildChangeInterceptor, selectedState]);\n\n // The error message area will only be created if:\n // - an external element that provides an error message isn't identified via aria-errormessage AND\n // - both status and statusMessage properties are being controlled OR\n // - status is uncontrolled and required is true\n const canShowError =\n ariaErrorMessage == null &&\n ((status !== undefined && statusMessage !== undefined) ||\n (status === undefined && required));\n\n const errorMessageId = canShowError\n ? setId(elementId, \"error\")\n : ariaErrorMessage;\n\n const listId = (label && setId(elementId, \"listbox\")) || \"\";\n\n return (\n <HvFormElement\n id={id}\n name={name}\n status={validationState}\n disabled={disabled}\n required={required}\n readOnly={readOnly}\n className={cx(classes.root, className)}\n >\n {label && (\n <HvLabel\n id={setId(elementId, \"label\")}\n label={label}\n className={classes.label}\n />\n )}\n {description && (\n <HvInfoMessage\n id={setId(elementId, \"description\")}\n className={classes.description}\n >\n {description}\n </HvInfoMessage>\n )}\n\n <HvListContainer\n id={listId}\n interactive\n condensed\n role=\"listbox\"\n aria-multiselectable={multiple || undefined}\n aria-label={ariaLabel}\n aria-labelledby={\n [label && setId(elementId, \"label\"), ariaLabelledBy]\n .join(\" \")\n .trim() || undefined\n }\n aria-invalid={validationState === \"invalid\" ? true : undefined}\n aria-errormessage={\n validationState === \"invalid\" ? errorMessageId : undefined\n }\n aria-describedby={\n [description && setId(elementId, \"description\"), ariaDescribedBy]\n .join(\" \")\n .trim() || undefined\n }\n className={cx(classes.listbox, {\n [classes.vertical]: orientation === \"vertical\",\n [classes.horizontal]: orientation === \"horizontal\",\n [classes.invalid]: validationState === \"invalid\",\n })}\n ref={listForkedRef}\n {...others}\n >\n {modifiedChildren}\n </HvListContainer>\n\n {canShowError && (\n <HvWarningText\n id={setId(elementId, \"error\")}\n disableBorder\n className={classes.error}\n >\n {validationMessage}\n </HvWarningText>\n )}\n </HvFormElement>\n );\n});\n"],"names":["Children","forwardRef","useDefaultProps","useClasses","useUniqueId","useControlled","useMemo","useRef","useForkRef","useEffect","isKey","useCallback","multiSelectionEventHandler","cloneElement","setId","jsxs","HvFormElement","jsx","HvLabel","HvInfoMessage","HvListContainer","HvWarningText"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"SimpleGrid.cjs","sources":["../../../src/SimpleGrid/SimpleGrid.tsx"],"sourcesContent":["import { HvBaseProps } from \"../types/generic\";\nimport { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { ExtractNames } from \"../utils/classes\";\n\nimport { Breakpoint, Spacing } from \"./types\";\nimport {\n getContainerStyle,\n staticClasses,\n useClasses,\n} from \"./SimpleGrid.styles\";\n\nexport { staticClasses as simpleGridClasses };\n\nexport type HvSimpleGridClasses = ExtractNames<typeof useClasses>;\n\n/** Grid component that enables you to create columns of equal width and define your own breakpoints and responsive behavior. */\nexport interface HvSimpleGridProps extends HvBaseProps {\n /**\n * Spacing with pre-defined values according the values defined in the theme\n */\n spacing?: Spacing;\n /**\n * Provide an array to define responsive behavior:\n *\n * maxWidth or minWidth: max-width or min-width at which media query will work\n *\n * cols: number of columns per row at given max-width\n *\n * spacing: optional spacing at given max-width, if not provided spacing from component prop will be used instead\n */\n breakpoints?: Breakpoint[];\n /**\n * Number of how many columns the content will be displayed\n */\n cols?: number;\n /** A Jss Object used to override or extend the styles applied to the component. */\n classes?: HvSimpleGridClasses;\n}\n\nexport const HvSimpleGrid = (props: HvSimpleGridProps) => {\n const {\n children,\n breakpoints,\n spacing = \"sm\",\n cols,\n className,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvSimpleGrid\", props);\n\n const { classes, cx, css } = useClasses(classesProp);\n\n const containerStyle = getContainerStyle({ breakpoints, spacing, cols });\n\n return (\n <div\n className={cx(css(containerStyle), classes.root, className)}\n {...others}\n >\n {children}\n </div>\n );\n};\n"],"names":["useDefaultProps","useClasses","getContainerStyle","jsx"],"mappings":";;;;;AAuCa,MAAA,eAAe,CAAC,UAA6B;AAClD,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,IACDA,gBAAgB,gBAAA,gBAAgB,KAAK;AAEzC,QAAM,EAAE,SAAS,IAAI,IAAI,IAAIC,kBAAAA,WAAW,WAAW;AAEnD,QAAM,iBAAiBC,kBAAAA,kBAAkB,EAAE,aAAa,SAAS,MAAM;AAGrE,SAAAC,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,GAAG,IAAI,cAAc,GAAG,QAAQ,MAAM,SAAS;AAAA,MACzD,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA;AAGP;;;"}
1
+ {"version":3,"file":"SimpleGrid.cjs","sources":["../../../src/SimpleGrid/SimpleGrid.tsx"],"sourcesContent":["import { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { HvBaseProps } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\nimport {\n getContainerStyle,\n staticClasses,\n useClasses,\n} from \"./SimpleGrid.styles\";\nimport { Breakpoint, Spacing } from \"./types\";\n\nexport { staticClasses as simpleGridClasses };\n\nexport type HvSimpleGridClasses = ExtractNames<typeof useClasses>;\n\n/** Grid component that enables you to create columns of equal width and define your own breakpoints and responsive behavior. */\nexport interface HvSimpleGridProps extends HvBaseProps {\n /**\n * Spacing with pre-defined values according the values defined in the theme\n */\n spacing?: Spacing;\n /**\n * Provide an array to define responsive behavior:\n *\n * maxWidth or minWidth: max-width or min-width at which media query will work\n *\n * cols: number of columns per row at given max-width\n *\n * spacing: optional spacing at given max-width, if not provided spacing from component prop will be used instead\n */\n breakpoints?: Breakpoint[];\n /**\n * Number of how many columns the content will be displayed\n */\n cols?: number;\n /** A Jss Object used to override or extend the styles applied to the component. */\n classes?: HvSimpleGridClasses;\n}\n\nexport const HvSimpleGrid = (props: HvSimpleGridProps) => {\n const {\n children,\n breakpoints,\n spacing = \"sm\",\n cols,\n className,\n classes: classesProp,\n ...others\n } = useDefaultProps(\"HvSimpleGrid\", props);\n\n const { classes, cx, css } = useClasses(classesProp);\n\n const containerStyle = getContainerStyle({ breakpoints, spacing, cols });\n\n return (\n <div\n className={cx(css(containerStyle), classes.root, className)}\n {...others}\n >\n {children}\n </div>\n );\n};\n"],"names":["useDefaultProps","useClasses","getContainerStyle","jsx"],"mappings":";;;;;AAsCa,MAAA,eAAe,CAAC,UAA6B;AAClD,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,IACDA,gBAAgB,gBAAA,gBAAgB,KAAK;AAEzC,QAAM,EAAE,SAAS,IAAI,IAAI,IAAIC,kBAAAA,WAAW,WAAW;AAEnD,QAAM,iBAAiBC,kBAAAA,kBAAkB,EAAE,aAAa,SAAS,MAAM;AAGrE,SAAAC,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,GAAG,IAAI,cAAc,GAAG,QAAQ,MAAM,SAAS;AAAA,MACzD,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA;AAGP;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"SimpleGrid.styles.cjs","sources":["../../../src/SimpleGrid/SimpleGrid.styles.tsx"],"sourcesContent":["import { CSSObject } from \"@emotion/serialize\";\n\nimport { theme } from \"@hitachivantara/uikit-styles\";\n\nimport { createClasses } from \"../utils/classes\";\n\nimport { Spacing, Breakpoint } from \"./types\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvSimpleGrid\", {\n root: {},\n});\n\nfunction size(props: { size: any; sizes: any }) {\n if (typeof props.size === \"number\") {\n return props.size;\n }\n\n return props.sizes[props.size] || props.size || props.sizes.md;\n}\n\nfunction getSortedBreakpoints(breakpoints: Breakpoint[]) {\n if (breakpoints.length === 0) {\n return breakpoints;\n }\n\n const property = \"maxWidth\" in breakpoints[0] ? \"maxWidth\" : \"minWidth\";\n const sorted = [...breakpoints].sort(\n (a, b) =>\n size({ size: b[property], sizes: theme.breakpoints }) -\n size({ size: a[property], sizes: theme.breakpoints })\n );\n\n return property === \"minWidth\" ? sorted.reverse() : sorted;\n}\n\nexport const getContainerStyle = ({\n breakpoints,\n spacing,\n cols,\n}: {\n breakpoints?: Breakpoint[];\n spacing: Spacing;\n cols?: number;\n}): CSSObject => {\n return {\n boxSizing: \"border-box\",\n display: \"grid\",\n gridTemplateColumns: `repeat(${cols}, minmax(0, 1fr))`,\n gap: theme.space[spacing],\n ...(breakpoints &&\n getSortedBreakpoints(breakpoints).reduce((acc, breakpoint) => {\n const property = \"maxWidth\" in breakpoint ? \"max-width\" : \"min-width\";\n const breakpointSize = size({\n size:\n property === \"max-width\"\n ? breakpoint.maxWidth\n : breakpoint.minWidth,\n sizes: theme.breakpoints,\n });\n\n acc[\n `@media (${property}: ${\n breakpointSize + (property === \"max-width\" ? 0 : 1)\n }px)`\n ] = {\n gridTemplateColumns: `repeat(${breakpoint.cols}, minmax(0, 1fr))`,\n gap: theme.space[spacing],\n };\n\n return acc;\n }, {})),\n };\n};\n"],"names":["createClasses","theme"],"mappings":";;;;AAQO,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,gBAAgB;AAAA,EACzE,MAAM,CAAC;AACT,CAAC;AAED,SAAS,KAAK,OAAkC;AAC1C,MAAA,OAAO,MAAM,SAAS,UAAU;AAClC,WAAO,MAAM;AAAA,EACf;AAEO,SAAA,MAAM,MAAM,MAAM,IAAI,KAAK,MAAM,QAAQ,MAAM,MAAM;AAC9D;AAEA,SAAS,qBAAqB,aAA2B;AACnD,MAAA,YAAY,WAAW,GAAG;AACrB,WAAA;AAAA,EACT;AAEA,QAAM,WAAW,cAAc,YAAY,CAAC,IAAI,aAAa;AAC7D,QAAM,SAAS,CAAC,GAAG,WAAW,EAAE;AAAA,IAC9B,CAAC,GAAG,MACF,KAAK,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAOC,YAAA,MAAM,aAAa,IACpD,KAAK,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAOA,kBAAM,aAAa;AAAA,EAAA;AAGxD,SAAO,aAAa,aAAa,OAAO,QAAA,IAAY;AACtD;AAEO,MAAM,oBAAoB,CAAC;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AACF,MAIiB;AACR,SAAA;AAAA,IACL,WAAW;AAAA,IACX,SAAS;AAAA,IACT,qBAAqB,UAAU,IAAI;AAAA,IACnC,KAAKA,YAAAA,MAAM,MAAM,OAAO;AAAA,IACxB,GAAI,eACF,qBAAqB,WAAW,EAAE,OAAO,CAAC,KAAK,eAAe;AACtD,YAAA,WAAW,cAAc,aAAa,cAAc;AAC1D,YAAM,iBAAiB,KAAK;AAAA,QAC1B,MACE,aAAa,cACT,WAAW,WACX,WAAW;AAAA,QACjB,OAAOA,YAAM,MAAA;AAAA,MAAA,CACd;AAGC,UAAA,WAAW,QAAQ,KACjB,kBAAkB,aAAa,cAAc,IAAI,EACnD,KACF,IAAI;AAAA,QACF,qBAAqB,UAAU,WAAW,IAAI;AAAA,QAC9C,KAAKA,YAAAA,MAAM,MAAM,OAAO;AAAA,MAAA;AAGnB,aAAA;AAAA,IACT,GAAG,EAAE;AAAA,EAAA;AAEX;;;;"}
1
+ {"version":3,"file":"SimpleGrid.styles.cjs","sources":["../../../src/SimpleGrid/SimpleGrid.styles.tsx"],"sourcesContent":["import { CSSObject } from \"@emotion/serialize\";\nimport { theme } from \"@hitachivantara/uikit-styles\";\n\nimport { createClasses } from \"../utils/classes\";\nimport { Breakpoint, Spacing } from \"./types\";\n\nexport const { staticClasses, useClasses } = createClasses(\"HvSimpleGrid\", {\n root: {},\n});\n\nfunction size(props: { size: any; sizes: any }) {\n if (typeof props.size === \"number\") {\n return props.size;\n }\n\n return props.sizes[props.size] || props.size || props.sizes.md;\n}\n\nfunction getSortedBreakpoints(breakpoints: Breakpoint[]) {\n if (breakpoints.length === 0) {\n return breakpoints;\n }\n\n const property = \"maxWidth\" in breakpoints[0] ? \"maxWidth\" : \"minWidth\";\n const sorted = [...breakpoints].sort(\n (a, b) =>\n size({ size: b[property], sizes: theme.breakpoints }) -\n size({ size: a[property], sizes: theme.breakpoints }),\n );\n\n return property === \"minWidth\" ? sorted.reverse() : sorted;\n}\n\nexport const getContainerStyle = ({\n breakpoints,\n spacing,\n cols,\n}: {\n breakpoints?: Breakpoint[];\n spacing: Spacing;\n cols?: number;\n}): CSSObject => {\n return {\n boxSizing: \"border-box\",\n display: \"grid\",\n gridTemplateColumns: `repeat(${cols}, minmax(0, 1fr))`,\n gap: theme.space[spacing],\n ...(breakpoints &&\n getSortedBreakpoints(breakpoints).reduce((acc, breakpoint) => {\n const property = \"maxWidth\" in breakpoint ? \"max-width\" : \"min-width\";\n const breakpointSize = size({\n size:\n property === \"max-width\"\n ? breakpoint.maxWidth\n : breakpoint.minWidth,\n sizes: theme.breakpoints,\n });\n\n acc[\n `@media (${property}: ${\n breakpointSize + (property === \"max-width\" ? 0 : 1)\n }px)`\n ] = {\n gridTemplateColumns: `repeat(${breakpoint.cols}, minmax(0, 1fr))`,\n gap: theme.space[spacing],\n };\n\n return acc;\n }, {})),\n };\n};\n"],"names":["createClasses","theme"],"mappings":";;;;AAMO,MAAM,EAAE,eAAe,eAAeA,QAAAA,cAAc,gBAAgB;AAAA,EACzE,MAAM,CAAC;AACT,CAAC;AAED,SAAS,KAAK,OAAkC;AAC1C,MAAA,OAAO,MAAM,SAAS,UAAU;AAClC,WAAO,MAAM;AAAA,EACf;AAEO,SAAA,MAAM,MAAM,MAAM,IAAI,KAAK,MAAM,QAAQ,MAAM,MAAM;AAC9D;AAEA,SAAS,qBAAqB,aAA2B;AACnD,MAAA,YAAY,WAAW,GAAG;AACrB,WAAA;AAAA,EACT;AAEA,QAAM,WAAW,cAAc,YAAY,CAAC,IAAI,aAAa;AAC7D,QAAM,SAAS,CAAC,GAAG,WAAW,EAAE;AAAA,IAC9B,CAAC,GAAG,MACF,KAAK,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAOC,YAAA,MAAM,aAAa,IACpD,KAAK,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAOA,kBAAM,aAAa;AAAA,EAAA;AAGxD,SAAO,aAAa,aAAa,OAAO,QAAA,IAAY;AACtD;AAEO,MAAM,oBAAoB,CAAC;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AACF,MAIiB;AACR,SAAA;AAAA,IACL,WAAW;AAAA,IACX,SAAS;AAAA,IACT,qBAAqB,UAAU,IAAI;AAAA,IACnC,KAAKA,YAAAA,MAAM,MAAM,OAAO;AAAA,IACxB,GAAI,eACF,qBAAqB,WAAW,EAAE,OAAO,CAAC,KAAK,eAAe;AACtD,YAAA,WAAW,cAAc,aAAa,cAAc;AAC1D,YAAM,iBAAiB,KAAK;AAAA,QAC1B,MACE,aAAa,cACT,WAAW,WACX,WAAW;AAAA,QACjB,OAAOA,YAAM,MAAA;AAAA,MAAA,CACd;AAGC,UAAA,WAAW,QAAQ,KACjB,kBAAkB,aAAa,cAAc,IAAI,EACnD,KACF,IAAI;AAAA,QACF,qBAAqB,UAAU,WAAW,IAAI;AAAA,QAC9C,KAAKA,YAAAA,MAAM,MAAM,OAAO;AAAA,MAAA;AAGnB,aAAA;AAAA,IACT,GAAG,EAAE;AAAA,EAAA;AAEX;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"Skeleton.cjs","sources":["../../../src/Skeleton/Skeleton.tsx"],"sourcesContent":["import { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { HvBaseProps } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\n\nimport { useClasses, staticClasses } from \"./Skeleton.styles\";\n\nexport { staticClasses as skeletonClasses };\n\nexport type HvSkeletonClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSkeletonProps extends HvBaseProps {\n /** Whether the skeleton element is hidden or not. */\n hidden?: boolean;\n /** The type of skeleton element. @default \"text\" */\n variant?: \"circle\" | \"square\" | \"text\";\n /** The animation the skeleton element will display. @default \"pulse\" */\n animation?: \"pulse\" | \"wave\";\n /** The width of the skeleton element. */\n width?: React.CSSProperties[\"width\"];\n /** The height of the skeleton element. */\n height?: React.CSSProperties[\"height\"];\n /** The url for a placeholder image to use on the skeleton element. */\n backgroundImage?: string;\n /** A Jss Object used to override or extend the styles applied to the component. */\n classes?: HvSkeletonClasses;\n}\n\n/**\n * The `HvSkeleton` component is used to create a placeholder element that represents the shape and size of the content that will be loaded.\n */\nexport const HvSkeleton = (props: HvSkeletonProps) => {\n const {\n classes: classesProp,\n className,\n children,\n hidden = false,\n variant = \"text\",\n animation = \"pulse\",\n backgroundImage,\n width,\n height,\n style,\n ...others\n } = useDefaultProps(\"HvSkeleton\", props);\n const { classes, cx } = useClasses(classesProp);\n\n if (hidden) return <div className={classes.content}>{children}</div>;\n\n return (\n <div\n className={cx(\n classes.root,\n classes[variant],\n animation && classes[animation],\n className\n )}\n style={{\n width,\n height,\n ...(backgroundImage && {\n backgroundImage: `url(${backgroundImage})`,\n backgroundSize: \"contain\",\n backgroundPosition: \"center\",\n backgroundRepeat: \"no-repeat\",\n }),\n ...style,\n }}\n {...others}\n >\n {children}\n </div>\n );\n};\n"],"names":["useDefaultProps","useClasses","jsx"],"mappings":";;;;;AA8Ba,MAAA,aAAa,CAAC,UAA2B;AAC9C,QAAA;AAAA,IACJ,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,UAAU;AAAA,IACV,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EAAA,IACDA,gBAAgB,gBAAA,cAAc,KAAK;AACvC,QAAM,EAAE,SAAS,GAAG,IAAIC,2BAAW,WAAW;AAE1C,MAAA;AAAQ,WAAQC,2BAAAA,IAAA,OAAA,EAAI,WAAW,QAAQ,SAAU,SAAS,CAAA;AAG5D,SAAAA,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW;AAAA,QACT,QAAQ;AAAA,QACR,QAAQ,OAAO;AAAA,QACf,aAAa,QAAQ,SAAS;AAAA,QAC9B;AAAA,MACF;AAAA,MACA,OAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA,GAAI,mBAAmB;AAAA,UACrB,iBAAiB,OAAO,eAAe;AAAA,UACvC,gBAAgB;AAAA,UAChB,oBAAoB;AAAA,UACpB,kBAAkB;AAAA,QACpB;AAAA,QACA,GAAG;AAAA,MACL;AAAA,MACC,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA;AAGP;;;"}
1
+ {"version":3,"file":"Skeleton.cjs","sources":["../../../src/Skeleton/Skeleton.tsx"],"sourcesContent":["import { useDefaultProps } from \"../hooks/useDefaultProps\";\nimport { HvBaseProps } from \"../types/generic\";\nimport { ExtractNames } from \"../utils/classes\";\nimport { staticClasses, useClasses } from \"./Skeleton.styles\";\n\nexport { staticClasses as skeletonClasses };\n\nexport type HvSkeletonClasses = ExtractNames<typeof useClasses>;\n\nexport interface HvSkeletonProps extends HvBaseProps {\n /** Whether the skeleton element is hidden or not. */\n hidden?: boolean;\n /** The type of skeleton element. @default \"text\" */\n variant?: \"circle\" | \"square\" | \"text\";\n /** The animation the skeleton element will display. @default \"pulse\" */\n animation?: \"pulse\" | \"wave\";\n /** The width of the skeleton element. */\n width?: React.CSSProperties[\"width\"];\n /** The height of the skeleton element. */\n height?: React.CSSProperties[\"height\"];\n /** The url for a placeholder image to use on the skeleton element. */\n backgroundImage?: string;\n /** A Jss Object used to override or extend the styles applied to the component. */\n classes?: HvSkeletonClasses;\n}\n\n/**\n * The `HvSkeleton` component is used to create a placeholder element that represents the shape and size of the content that will be loaded.\n */\nexport const HvSkeleton = (props: HvSkeletonProps) => {\n const {\n classes: classesProp,\n className,\n children,\n hidden = false,\n variant = \"text\",\n animation = \"pulse\",\n backgroundImage,\n width,\n height,\n style,\n ...others\n } = useDefaultProps(\"HvSkeleton\", props);\n const { classes, cx } = useClasses(classesProp);\n\n if (hidden) return <div className={classes.content}>{children}</div>;\n\n return (\n <div\n className={cx(\n classes.root,\n classes[variant],\n animation && classes[animation],\n className,\n )}\n style={{\n width,\n height,\n ...(backgroundImage && {\n backgroundImage: `url(${backgroundImage})`,\n backgroundSize: \"contain\",\n backgroundPosition: \"center\",\n backgroundRepeat: \"no-repeat\",\n }),\n ...style,\n }}\n {...others}\n >\n {children}\n </div>\n );\n};\n"],"names":["useDefaultProps","useClasses","jsx"],"mappings":";;;;;AA6Ba,MAAA,aAAa,CAAC,UAA2B;AAC9C,QAAA;AAAA,IACJ,SAAS;AAAA,IACT;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,UAAU;AAAA,IACV,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG;AAAA,EAAA,IACDA,gBAAgB,gBAAA,cAAc,KAAK;AACvC,QAAM,EAAE,SAAS,GAAG,IAAIC,2BAAW,WAAW;AAE1C,MAAA;AAAQ,WAAQC,2BAAAA,IAAA,OAAA,EAAI,WAAW,QAAQ,SAAU,SAAS,CAAA;AAG5D,SAAAA,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW;AAAA,QACT,QAAQ;AAAA,QACR,QAAQ,OAAO;AAAA,QACf,aAAa,QAAQ,SAAS;AAAA,QAC9B;AAAA,MACF;AAAA,MACA,OAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA,GAAI,mBAAmB;AAAA,UACrB,iBAAiB,OAAO,eAAe;AAAA,UACvC,gBAAgB;AAAA,UAChB,oBAAoB;AAAA,UACpB,kBAAkB;AAAA,QACpB;AAAA,QACA,GAAG;AAAA,MACL;AAAA,MACC,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA;AAGP;;;"}
@@ -4,14 +4,14 @@ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const React = require("react");
5
5
  const Slider = require("rc-slider");
6
6
  const Tooltip = require("rc-tooltip");
7
- const setId = require("../utils/setId.cjs");
8
- const useUniqueId = require("../hooks/useUniqueId.cjs");
9
- const useControlled = require("../hooks/useControlled.cjs");
10
7
  const validationStates = require("../Forms/FormElement/validationStates.cjs");
8
+ const useControlled = require("../hooks/useControlled.cjs");
11
9
  const useDefaultProps = require("../hooks/useDefaultProps.cjs");
10
+ const useUniqueId = require("../hooks/useUniqueId.cjs");
11
+ const setId = require("../utils/setId.cjs");
12
12
  const Slider_styles = require("./Slider.styles.cjs");
13
- const utils = require("./utils.cjs");
14
13
  const SliderInput = require("./SliderInput/SliderInput.cjs");
14
+ const utils = require("./utils.cjs");
15
15
  const FormElement = require("../Forms/FormElement/FormElement.cjs");
16
16
  const Label = require("../Forms/Label/Label.cjs");
17
17
  const WarningText = require("../Forms/WarningText/WarningText.cjs");