@carbon/react 1.27.0-rc.0 → 1.28.0-rc.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 (591) hide show
  1. package/es/_virtual/_rollupPluginBabelHelpers.js +1 -313
  2. package/es/components/Accordion/Accordion.Skeleton.js +28 -30
  3. package/es/components/Accordion/Accordion.js +18 -21
  4. package/es/components/Accordion/AccordionItem.js +37 -49
  5. package/es/components/AspectRatio/AspectRatio.js +10 -12
  6. package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +10 -11
  7. package/es/components/Breadcrumb/Breadcrumb.js +14 -13
  8. package/es/components/Breadcrumb/BreadcrumbItem.js +24 -22
  9. package/es/components/Button/Button.Skeleton.js +25 -23
  10. package/es/components/Button/Button.js +77 -72
  11. package/es/components/ButtonSet/ButtonSet.js +12 -10
  12. package/es/components/Checkbox/Checkbox.Skeleton.js +10 -11
  13. package/es/components/Checkbox/Checkbox.js +55 -52
  14. package/es/components/CheckboxGroup/CheckboxGroup.js +33 -31
  15. package/es/components/ClassPrefix/index.js +4 -2
  16. package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +15 -14
  17. package/es/components/CodeSnippet/CodeSnippet.js +199 -102
  18. package/es/components/ComboBox/ComboBox.js +349 -178
  19. package/es/components/ComboBox/tools/filter.js +6 -4
  20. package/es/components/ComboButton/index.js +38 -43
  21. package/es/components/ComposedModal/ComposedModal.js +187 -85
  22. package/es/components/ComposedModal/ModalFooter.js +54 -49
  23. package/es/components/ComposedModal/ModalHeader.js +39 -26
  24. package/es/components/ContainedList/ContainedList.js +18 -17
  25. package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +20 -18
  26. package/es/components/ContentSwitcher/ContentSwitcher.js +83 -98
  27. package/es/components/ContentSwitcher/index.js +1 -1
  28. package/es/components/ContextMenu/useContextMenu.js +12 -21
  29. package/es/components/Copy/Copy.js +24 -29
  30. package/es/components/CopyButton/CopyButton.js +10 -10
  31. package/es/components/DangerButton/DangerButton.js +3 -5
  32. package/es/components/DataTable/DataTable.js +334 -361
  33. package/es/components/DataTable/Table.js +29 -26
  34. package/es/components/DataTable/TableActionList.js +2 -4
  35. package/es/components/DataTable/TableBatchAction.js +2 -4
  36. package/es/components/DataTable/TableBatchActions.js +29 -30
  37. package/es/components/DataTable/TableBody.js +7 -8
  38. package/es/components/DataTable/TableCell.js +1 -1
  39. package/es/components/DataTable/TableContainer.js +23 -23
  40. package/es/components/DataTable/TableContext.js +1 -1
  41. package/es/components/DataTable/TableExpandHeader.js +19 -21
  42. package/es/components/DataTable/TableExpandRow.js +23 -23
  43. package/es/components/DataTable/TableExpandedRow.js +18 -23
  44. package/es/components/DataTable/TableHead.js +1 -1
  45. package/es/components/DataTable/TableHeader.js +45 -41
  46. package/es/components/DataTable/TableRow.js +7 -8
  47. package/es/components/DataTable/TableSelectAll.js +13 -11
  48. package/es/components/DataTable/TableSelectRow.js +29 -21
  49. package/es/components/DataTable/TableToolbar.js +19 -14
  50. package/es/components/DataTable/TableToolbarAction.js +6 -6
  51. package/es/components/DataTable/TableToolbarContent.js +2 -4
  52. package/es/components/DataTable/TableToolbarMenu.js +11 -12
  53. package/es/components/DataTable/TableToolbarSearch.js +52 -71
  54. package/es/components/DataTable/state/getDerivedStateFromProps.js +15 -15
  55. package/es/components/DataTable/state/sortStates.js +1 -1
  56. package/es/components/DataTable/state/sorting.js +28 -20
  57. package/es/components/DataTable/tools/cells.js +1 -3
  58. package/es/components/DataTable/tools/denormalize.js +4 -17
  59. package/es/components/DataTable/tools/filter.js +18 -16
  60. package/es/components/DataTable/tools/instanceId.js +2 -2
  61. package/es/components/DataTable/tools/normalize.js +28 -25
  62. package/es/components/DataTable/tools/sorting.js +28 -25
  63. package/es/components/DataTableSkeleton/DataTableSkeleton.js +36 -38
  64. package/es/components/DatePicker/DatePicker.Skeleton.js +17 -18
  65. package/es/components/DatePicker/DatePicker.js +206 -195
  66. package/es/components/DatePicker/plugins/appendToPlugin.js +45 -43
  67. package/es/components/DatePicker/plugins/fixEventsPlugin.js +117 -107
  68. package/es/components/DatePicker/plugins/rangePlugin.js +19 -11
  69. package/es/components/DatePickerInput/DatePickerInput.js +83 -74
  70. package/es/components/Dropdown/Dropdown.Skeleton.js +13 -12
  71. package/es/components/Dropdown/Dropdown.js +266 -109
  72. package/es/components/ErrorBoundary/ErrorBoundary.js +27 -48
  73. package/es/components/ErrorBoundary/ErrorBoundaryContext.js +3 -2
  74. package/es/components/ExpandableSearch/ExpandableSearch.d.ts +13 -0
  75. package/es/components/ExpandableSearch/ExpandableSearch.js +18 -25
  76. package/es/components/FeatureFlags/index.js +25 -43
  77. package/es/components/FileUploader/FileUploader.Skeleton.js +8 -9
  78. package/es/components/FileUploader/FileUploader.js +120 -147
  79. package/es/components/FileUploader/FileUploaderButton.js +36 -48
  80. package/es/components/FileUploader/FileUploaderDropContainer.js +49 -53
  81. package/es/components/FileUploader/FileUploaderItem.js +30 -30
  82. package/es/components/FileUploader/Filename.js +13 -14
  83. package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +11 -12
  84. package/es/components/FluidComboBox/FluidComboBox.js +11 -9
  85. package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +18 -18
  86. package/es/components/FluidDatePicker/FluidDatePicker.js +19 -16
  87. package/es/components/FluidDatePickerInput/FluidDatePickerInput.js +3 -3
  88. package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +11 -12
  89. package/es/components/FluidDropdown/FluidDropdown.js +11 -9
  90. package/es/components/FluidForm/FluidForm.js +9 -10
  91. package/es/components/FluidForm/FormContext.js +1 -1
  92. package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +11 -12
  93. package/es/components/FluidMultiSelect/FluidMultiSelect.js +12 -10
  94. package/es/components/FluidSelect/FluidSelect.Skeleton.js +11 -12
  95. package/es/components/FluidSelect/FluidSelect.js +9 -9
  96. package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +9 -10
  97. package/es/components/FluidTextArea/FluidTextArea.js +7 -8
  98. package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +9 -10
  99. package/es/components/FluidTextInput/FluidTextInput.js +10 -9
  100. package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +11 -10
  101. package/es/components/FluidTimePicker/FluidTimePicker.js +30 -26
  102. package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +7 -7
  103. package/es/components/Form/Form.js +9 -10
  104. package/es/components/FormGroup/FormGroup.js +16 -17
  105. package/es/components/FormItem/FormItem.js +8 -9
  106. package/es/components/FormLabel/FormLabel.js +11 -10
  107. package/es/components/Grid/CSSGrid.js +38 -39
  108. package/es/components/Grid/Column.js +86 -79
  109. package/es/components/Grid/ColumnHang.js +12 -14
  110. package/es/components/Grid/FlexGrid.js +19 -21
  111. package/es/components/Grid/Grid.js +2 -2
  112. package/es/components/Grid/GridContext.js +12 -11
  113. package/es/components/Grid/Row.js +16 -18
  114. package/es/components/Heading/index.js +11 -13
  115. package/es/components/Icon/Icon.Skeleton.js +10 -12
  116. package/es/components/IconButton/index.js +19 -22
  117. package/es/components/IdPrefix/index.js +4 -2
  118. package/es/components/InlineCheckbox/InlineCheckbox.js +89 -36
  119. package/es/components/InlineLoading/InlineLoading.js +23 -25
  120. package/es/components/Layer/LayerContext.js +1 -1
  121. package/es/components/Layer/index.js +17 -18
  122. package/es/components/Layout/LayoutDirection.js +8 -10
  123. package/es/components/Layout/LayoutDirectionContext.js +1 -1
  124. package/es/components/Link/Link.js +25 -25
  125. package/es/components/ListBox/ListBox.js +38 -31
  126. package/es/components/ListBox/ListBoxField.js +9 -10
  127. package/es/components/ListBox/ListBoxMenu.js +9 -10
  128. package/es/components/ListBox/ListBoxMenuIcon.js +16 -14
  129. package/es/components/ListBox/ListBoxMenuItem.js +23 -26
  130. package/es/components/ListBox/ListBoxPropTypes.js +4 -4
  131. package/es/components/ListBox/ListBoxSelection.js +30 -25
  132. package/es/components/ListBox/index.js +1 -1
  133. package/es/components/ListBox/next/ListBoxSelection.js +27 -24
  134. package/es/components/ListBox/next/ListBoxTrigger.js +20 -19
  135. package/es/components/ListItem/ListItem.js +9 -10
  136. package/es/components/Loading/Loading.js +24 -24
  137. package/es/components/Menu/Menu.js +67 -80
  138. package/es/components/Menu/MenuContext.js +9 -12
  139. package/es/components/Menu/MenuItem.js +104 -128
  140. package/es/components/MenuButton/index.js +37 -41
  141. package/es/components/Modal/Modal.js +281 -120
  142. package/es/components/ModalWrapper/ModalWrapper.js +72 -96
  143. package/es/components/MultiSelect/FilterableMultiSelect.js +299 -163
  144. package/es/components/MultiSelect/MultiSelect.js +162 -174
  145. package/es/components/MultiSelect/MultiSelectPropTypes.js +1 -1
  146. package/es/components/MultiSelect/tools/itemToString.js +3 -4
  147. package/es/components/MultiSelect/tools/sorting.js +15 -13
  148. package/es/components/Notification/Notification.js +436 -164
  149. package/es/components/NumberInput/NumberInput.Skeleton.js +10 -11
  150. package/es/components/NumberInput/NumberInput.js +140 -139
  151. package/es/components/OrderedList/OrderedList.js +17 -15
  152. package/es/components/OverflowMenu/OverflowMenu.js +359 -227
  153. package/es/components/OverflowMenu/index.js +1 -1
  154. package/es/components/OverflowMenuItem/OverflowMenuItem.js +32 -37
  155. package/es/components/OverflowMenuV2/index.js +26 -28
  156. package/es/components/Pagination/Pagination.Skeleton.js +9 -10
  157. package/es/components/Pagination/Pagination.js +98 -140
  158. package/es/components/Pagination/experimental/PageSelector.js +16 -16
  159. package/es/components/Pagination/experimental/Pagination.js +73 -94
  160. package/es/components/PaginationNav/PaginationNav.js +98 -117
  161. package/es/components/Popover/index.js +74 -80
  162. package/es/components/PrimaryButton/PrimaryButton.js +3 -5
  163. package/es/components/ProgressBar/ProgressBar.js +39 -37
  164. package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +15 -14
  165. package/es/components/ProgressIndicator/ProgressIndicator.js +71 -71
  166. package/es/components/RadioButton/RadioButton.Skeleton.js +9 -10
  167. package/es/components/RadioButton/RadioButton.js +27 -27
  168. package/es/components/RadioButtonGroup/RadioButtonGroup.js +55 -65
  169. package/es/components/RadioTile/RadioTile.js +28 -26
  170. package/es/components/Search/Search.Skeleton.js +16 -16
  171. package/es/components/Search/Search.d.ts +83 -0
  172. package/es/components/Search/Search.js +65 -72
  173. package/es/components/Search/index.d.ts +11 -0
  174. package/es/components/SecondaryButton/SecondaryButton.js +3 -5
  175. package/es/components/Select/Select.Skeleton.js +12 -13
  176. package/es/components/Select/Select.js +79 -73
  177. package/es/components/SelectItem/SelectItem.js +17 -13
  178. package/es/components/SelectItemGroup/SelectItemGroup.js +11 -12
  179. package/es/components/SkeletonIcon/SkeletonIcon.js +11 -11
  180. package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +11 -11
  181. package/es/components/SkeletonText/SkeletonText.js +29 -29
  182. package/es/components/Slider/Slider.Skeleton.js +17 -18
  183. package/es/components/Slider/Slider.js +306 -329
  184. package/es/components/Slider/index.js +1 -1
  185. package/es/components/Stack/Stack.js +19 -20
  186. package/es/components/Stack/index.js +2 -2
  187. package/es/components/StructuredList/StructuredList.Skeleton.js +25 -24
  188. package/es/components/StructuredList/StructuredList.js +134 -106
  189. package/es/components/Switch/IconSwitch.js +48 -54
  190. package/es/components/Switch/Switch.js +33 -31
  191. package/es/components/Tab/Tab.js +77 -83
  192. package/es/components/Tab/index.js +1 -1
  193. package/es/components/TabContent/TabContent.js +16 -18
  194. package/es/components/Tabs/Tabs.Skeleton.js +14 -13
  195. package/es/components/Tabs/Tabs.js +211 -210
  196. package/es/components/Tabs/usePressable.js +27 -36
  197. package/es/components/Tag/Tag.Skeleton.js +10 -9
  198. package/es/components/Tag/Tag.js +34 -31
  199. package/es/components/Text/Text.js +20 -20
  200. package/es/components/Text/TextDirection.js +8 -7
  201. package/es/components/Text/TextDirectionContext.js +1 -1
  202. package/es/components/Text/index.js +1 -1
  203. package/es/components/TextArea/TextArea.Skeleton.js +11 -12
  204. package/es/components/TextArea/TextArea.js +89 -83
  205. package/es/components/TextInput/ControlledPasswordInput.js +79 -73
  206. package/es/components/TextInput/PasswordInput.js +101 -91
  207. package/es/components/TextInput/TextInput.Skeleton.js +11 -12
  208. package/es/components/TextInput/TextInput.js +104 -92
  209. package/es/components/TextInput/util.js +26 -28
  210. package/es/components/Theme/index.js +25 -20
  211. package/es/components/Tile/Tile.js +135 -176
  212. package/es/components/TileGroup/TileGroup.js +55 -70
  213. package/es/components/TileGroup/index.js +1 -1
  214. package/es/components/TimePicker/TimePicker.js +60 -67
  215. package/es/components/TimePickerSelect/TimePickerSelect.js +20 -18
  216. package/es/components/TimePickerSelect/index.js +1 -1
  217. package/es/components/Toggle/Toggle.Skeleton.js +63 -52
  218. package/es/components/Toggle/Toggle.js +44 -48
  219. package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +56 -50
  220. package/es/components/Toggletip/index.js +52 -48
  221. package/es/components/Tooltip/DefinitionTooltip.js +24 -31
  222. package/es/components/Tooltip/Tooltip.js +35 -50
  223. package/es/components/TreeView/TreeNode.js +94 -74
  224. package/es/components/TreeView/TreeView.js +72 -83
  225. package/es/components/UIShell/Content.js +12 -14
  226. package/es/components/UIShell/Header.js +16 -12
  227. package/es/components/UIShell/HeaderContainer.js +8 -14
  228. package/es/components/UIShell/HeaderGlobalAction.js +26 -19
  229. package/es/components/UIShell/HeaderGlobalBar.js +1 -3
  230. package/es/components/UIShell/HeaderMenu.js +114 -129
  231. package/es/components/UIShell/HeaderMenuButton.js +31 -22
  232. package/es/components/UIShell/HeaderMenuItem.js +28 -20
  233. package/es/components/UIShell/HeaderName.js +19 -14
  234. package/es/components/UIShell/HeaderNavigation.js +19 -15
  235. package/es/components/UIShell/HeaderPanel.js +23 -17
  236. package/es/components/UIShell/HeaderSideNavItems.js +11 -9
  237. package/es/components/UIShell/Link.js +11 -11
  238. package/es/components/UIShell/SideNav.js +66 -62
  239. package/es/components/UIShell/SideNavDetails.js +11 -12
  240. package/es/components/UIShell/SideNavDivider.js +5 -3
  241. package/es/components/UIShell/SideNavFooter.js +12 -12
  242. package/es/components/UIShell/SideNavHeader.js +8 -6
  243. package/es/components/UIShell/SideNavIcon.js +11 -8
  244. package/es/components/UIShell/SideNavItem.js +11 -9
  245. package/es/components/UIShell/SideNavItems.js +13 -11
  246. package/es/components/UIShell/SideNavLink.js +19 -17
  247. package/es/components/UIShell/SideNavLinkText.js +8 -9
  248. package/es/components/UIShell/SideNavMenu.js +28 -35
  249. package/es/components/UIShell/SideNavMenuItem.js +14 -14
  250. package/es/components/UIShell/SideNavSwitcher.js +19 -19
  251. package/es/components/UIShell/SkipToContent.js +10 -11
  252. package/es/components/UIShell/Switcher.js +20 -11
  253. package/es/components/UIShell/SwitcherDivider.js +10 -9
  254. package/es/components/UIShell/SwitcherItem.js +26 -19
  255. package/es/components/UIShell/_utils.js +1 -1
  256. package/es/components/UnorderedList/UnorderedList.js +14 -14
  257. package/es/index.js +5 -5
  258. package/es/internal/ClickListener.js +49 -65
  259. package/es/internal/FloatingMenu.js +193 -200
  260. package/es/internal/OptimizedResize.js +9 -8
  261. package/es/internal/Selection.js +92 -111
  262. package/es/internal/createClassWrapper.js +2 -2
  263. package/es/internal/deprecateFieldOnObject.js +5 -3
  264. package/es/internal/environment.js +1 -1
  265. package/es/internal/focus/index.js +1 -1
  266. package/es/internal/keyboard/keys.js +11 -11
  267. package/es/internal/keyboard/match.js +7 -6
  268. package/es/internal/keyboard/navigation.js +15 -5
  269. package/es/internal/useAnnouncer.js +2 -2
  270. package/es/internal/useAttachedMenu.js +12 -20
  271. package/es/internal/useControllableState.js +11 -16
  272. package/es/internal/useDelayedState.js +9 -18
  273. package/es/internal/useEffectOnce.js +4 -4
  274. package/es/internal/useEvent.js +4 -4
  275. package/es/internal/useId.js +15 -19
  276. package/es/internal/useIdPrefix.js +1 -1
  277. package/es/internal/useIsomorphicEffect.js +1 -1
  278. package/es/internal/useMergedRefs.js +3 -3
  279. package/es/internal/useNoInteractiveChildren.js +8 -19
  280. package/es/internal/useNormalizedInputProps.js +16 -14
  281. package/es/internal/usePrefix.js +1 -1
  282. package/es/internal/useSavedCallback.js +3 -3
  283. package/es/internal/warning.js +4 -4
  284. package/es/internal/wrapFocus.js +16 -21
  285. package/es/prop-types/AriaPropTypes.js +1 -1
  286. package/es/prop-types/deprecate.js +6 -5
  287. package/es/prop-types/isRequiredOneOf.js +12 -25
  288. package/es/prop-types/requiredIfGivenPropIsTruthy.js +2 -2
  289. package/es/prop-types/types.js +1 -1
  290. package/es/tools/array.js +1 -1
  291. package/es/tools/events.js +21 -14
  292. package/es/tools/mergeRefs.js +3 -3
  293. package/es/tools/setupGetInstanceId.js +1 -1
  294. package/es/tools/uniqueId.js +3 -3
  295. package/es/tools/wrapComponent.js +14 -13
  296. package/lib/_virtual/_rollupPluginBabelHelpers.js +0 -336
  297. package/lib/components/Accordion/Accordion.Skeleton.js +27 -29
  298. package/lib/components/Accordion/Accordion.js +17 -20
  299. package/lib/components/Accordion/AccordionItem.js +36 -48
  300. package/lib/components/AspectRatio/AspectRatio.js +9 -11
  301. package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +9 -10
  302. package/lib/components/Breadcrumb/Breadcrumb.js +13 -12
  303. package/lib/components/Breadcrumb/BreadcrumbItem.js +23 -21
  304. package/lib/components/Button/Button.Skeleton.js +24 -22
  305. package/lib/components/Button/Button.js +76 -71
  306. package/lib/components/ButtonSet/ButtonSet.js +11 -9
  307. package/lib/components/Checkbox/Checkbox.Skeleton.js +9 -10
  308. package/lib/components/Checkbox/Checkbox.js +54 -51
  309. package/lib/components/CheckboxGroup/CheckboxGroup.js +32 -30
  310. package/lib/components/ClassPrefix/index.js +4 -2
  311. package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +14 -13
  312. package/lib/components/CodeSnippet/CodeSnippet.js +198 -101
  313. package/lib/components/ComboBox/ComboBox.js +348 -177
  314. package/lib/components/ComboBox/tools/filter.js +6 -4
  315. package/lib/components/ComboButton/index.js +37 -42
  316. package/lib/components/ComposedModal/ComposedModal.js +187 -85
  317. package/lib/components/ComposedModal/ModalFooter.js +53 -48
  318. package/lib/components/ComposedModal/ModalHeader.js +38 -25
  319. package/lib/components/ContainedList/ContainedList.js +18 -17
  320. package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +20 -18
  321. package/lib/components/ContentSwitcher/ContentSwitcher.js +82 -97
  322. package/lib/components/ContentSwitcher/index.js +1 -1
  323. package/lib/components/ContextMenu/useContextMenu.js +12 -21
  324. package/lib/components/Copy/Copy.js +23 -28
  325. package/lib/components/CopyButton/CopyButton.js +9 -9
  326. package/lib/components/DangerButton/DangerButton.js +3 -5
  327. package/lib/components/DataTable/DataTable.js +332 -359
  328. package/lib/components/DataTable/Table.js +28 -25
  329. package/lib/components/DataTable/TableActionList.js +2 -4
  330. package/lib/components/DataTable/TableBatchAction.js +2 -4
  331. package/lib/components/DataTable/TableBatchActions.js +28 -29
  332. package/lib/components/DataTable/TableBody.js +6 -7
  333. package/lib/components/DataTable/TableCell.js +1 -1
  334. package/lib/components/DataTable/TableContainer.js +22 -22
  335. package/lib/components/DataTable/TableContext.js +1 -1
  336. package/lib/components/DataTable/TableExpandHeader.js +18 -20
  337. package/lib/components/DataTable/TableExpandRow.js +22 -22
  338. package/lib/components/DataTable/TableExpandedRow.js +17 -22
  339. package/lib/components/DataTable/TableHead.js +1 -1
  340. package/lib/components/DataTable/TableHeader.js +43 -39
  341. package/lib/components/DataTable/TableRow.js +7 -8
  342. package/lib/components/DataTable/TableSelectAll.js +13 -11
  343. package/lib/components/DataTable/TableSelectRow.js +28 -20
  344. package/lib/components/DataTable/TableToolbar.js +18 -13
  345. package/lib/components/DataTable/TableToolbarAction.js +5 -5
  346. package/lib/components/DataTable/TableToolbarContent.js +2 -4
  347. package/lib/components/DataTable/TableToolbarMenu.js +10 -11
  348. package/lib/components/DataTable/TableToolbarSearch.js +51 -70
  349. package/lib/components/DataTable/state/getDerivedStateFromProps.js +15 -15
  350. package/lib/components/DataTable/state/sortStates.js +1 -1
  351. package/lib/components/DataTable/state/sorting.js +28 -20
  352. package/lib/components/DataTable/tools/cells.js +1 -3
  353. package/lib/components/DataTable/tools/denormalize.js +4 -17
  354. package/lib/components/DataTable/tools/filter.js +18 -16
  355. package/lib/components/DataTable/tools/instanceId.js +2 -2
  356. package/lib/components/DataTable/tools/normalize.js +28 -25
  357. package/lib/components/DataTable/tools/sorting.js +27 -24
  358. package/lib/components/DataTableSkeleton/DataTableSkeleton.js +35 -37
  359. package/lib/components/DatePicker/DatePicker.Skeleton.js +16 -17
  360. package/lib/components/DatePicker/DatePicker.js +205 -194
  361. package/lib/components/DatePicker/plugins/appendToPlugin.js +45 -43
  362. package/lib/components/DatePicker/plugins/fixEventsPlugin.js +117 -107
  363. package/lib/components/DatePicker/plugins/rangePlugin.js +19 -11
  364. package/lib/components/DatePickerInput/DatePickerInput.js +83 -74
  365. package/lib/components/Dropdown/Dropdown.Skeleton.js +12 -11
  366. package/lib/components/Dropdown/Dropdown.js +265 -108
  367. package/lib/components/ErrorBoundary/ErrorBoundary.js +27 -48
  368. package/lib/components/ErrorBoundary/ErrorBoundaryContext.js +3 -2
  369. package/lib/components/ExpandableSearch/ExpandableSearch.d.ts +13 -0
  370. package/lib/components/ExpandableSearch/ExpandableSearch.js +17 -24
  371. package/lib/components/FeatureFlags/index.js +25 -43
  372. package/lib/components/FileUploader/FileUploader.Skeleton.js +7 -8
  373. package/lib/components/FileUploader/FileUploader.js +119 -146
  374. package/lib/components/FileUploader/FileUploaderButton.js +35 -47
  375. package/lib/components/FileUploader/FileUploaderDropContainer.js +48 -52
  376. package/lib/components/FileUploader/FileUploaderItem.js +29 -29
  377. package/lib/components/FileUploader/Filename.js +12 -13
  378. package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +10 -11
  379. package/lib/components/FluidComboBox/FluidComboBox.js +10 -8
  380. package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +17 -17
  381. package/lib/components/FluidDatePicker/FluidDatePicker.js +18 -15
  382. package/lib/components/FluidDatePickerInput/FluidDatePickerInput.js +3 -3
  383. package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +10 -11
  384. package/lib/components/FluidDropdown/FluidDropdown.js +10 -8
  385. package/lib/components/FluidForm/FluidForm.js +8 -9
  386. package/lib/components/FluidForm/FormContext.js +1 -1
  387. package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +10 -11
  388. package/lib/components/FluidMultiSelect/FluidMultiSelect.js +11 -9
  389. package/lib/components/FluidSelect/FluidSelect.Skeleton.js +10 -11
  390. package/lib/components/FluidSelect/FluidSelect.js +8 -8
  391. package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +8 -9
  392. package/lib/components/FluidTextArea/FluidTextArea.js +6 -7
  393. package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +8 -9
  394. package/lib/components/FluidTextInput/FluidTextInput.js +9 -8
  395. package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +10 -9
  396. package/lib/components/FluidTimePicker/FluidTimePicker.js +30 -26
  397. package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +6 -6
  398. package/lib/components/Form/Form.js +8 -9
  399. package/lib/components/FormGroup/FormGroup.js +15 -16
  400. package/lib/components/FormItem/FormItem.js +7 -8
  401. package/lib/components/FormLabel/FormLabel.js +10 -9
  402. package/lib/components/Grid/CSSGrid.js +37 -38
  403. package/lib/components/Grid/Column.js +85 -78
  404. package/lib/components/Grid/ColumnHang.js +11 -13
  405. package/lib/components/Grid/FlexGrid.js +19 -21
  406. package/lib/components/Grid/Grid.js +2 -2
  407. package/lib/components/Grid/GridContext.js +12 -11
  408. package/lib/components/Grid/Row.js +16 -18
  409. package/lib/components/Heading/index.js +11 -13
  410. package/lib/components/Icon/Icon.Skeleton.js +9 -11
  411. package/lib/components/IconButton/index.js +18 -21
  412. package/lib/components/IdPrefix/index.js +4 -2
  413. package/lib/components/InlineCheckbox/InlineCheckbox.js +89 -36
  414. package/lib/components/InlineLoading/InlineLoading.js +22 -24
  415. package/lib/components/Layer/LayerContext.js +1 -1
  416. package/lib/components/Layer/index.js +16 -17
  417. package/lib/components/Layout/LayoutDirection.js +7 -9
  418. package/lib/components/Layout/LayoutDirectionContext.js +1 -1
  419. package/lib/components/Link/Link.js +24 -24
  420. package/lib/components/ListBox/ListBox.js +37 -30
  421. package/lib/components/ListBox/ListBoxField.js +8 -9
  422. package/lib/components/ListBox/ListBoxMenu.js +8 -9
  423. package/lib/components/ListBox/ListBoxMenuIcon.js +16 -14
  424. package/lib/components/ListBox/ListBoxMenuItem.js +22 -25
  425. package/lib/components/ListBox/ListBoxPropTypes.js +4 -4
  426. package/lib/components/ListBox/ListBoxSelection.js +30 -25
  427. package/lib/components/ListBox/index.js +1 -1
  428. package/lib/components/ListBox/next/ListBoxSelection.js +26 -23
  429. package/lib/components/ListBox/next/ListBoxTrigger.js +19 -18
  430. package/lib/components/ListItem/ListItem.js +8 -9
  431. package/lib/components/Loading/Loading.js +23 -23
  432. package/lib/components/Menu/Menu.js +66 -79
  433. package/lib/components/Menu/MenuContext.js +9 -12
  434. package/lib/components/Menu/MenuItem.js +103 -127
  435. package/lib/components/MenuButton/index.js +36 -40
  436. package/lib/components/Modal/Modal.js +280 -119
  437. package/lib/components/ModalWrapper/ModalWrapper.js +71 -95
  438. package/lib/components/MultiSelect/FilterableMultiSelect.js +298 -162
  439. package/lib/components/MultiSelect/MultiSelect.js +163 -175
  440. package/lib/components/MultiSelect/MultiSelectPropTypes.js +1 -1
  441. package/lib/components/MultiSelect/tools/itemToString.js +3 -4
  442. package/lib/components/MultiSelect/tools/sorting.js +15 -13
  443. package/lib/components/Notification/Notification.js +434 -162
  444. package/lib/components/NumberInput/NumberInput.Skeleton.js +9 -10
  445. package/lib/components/NumberInput/NumberInput.js +139 -138
  446. package/lib/components/OrderedList/OrderedList.js +16 -14
  447. package/lib/components/OverflowMenu/OverflowMenu.js +358 -226
  448. package/lib/components/OverflowMenu/index.js +1 -1
  449. package/lib/components/OverflowMenuItem/OverflowMenuItem.js +31 -36
  450. package/lib/components/OverflowMenuV2/index.js +25 -27
  451. package/lib/components/Pagination/Pagination.Skeleton.js +8 -9
  452. package/lib/components/Pagination/Pagination.js +97 -139
  453. package/lib/components/Pagination/experimental/PageSelector.js +17 -17
  454. package/lib/components/Pagination/experimental/Pagination.js +72 -93
  455. package/lib/components/PaginationNav/PaginationNav.js +97 -116
  456. package/lib/components/Popover/index.js +73 -79
  457. package/lib/components/PrimaryButton/PrimaryButton.js +3 -5
  458. package/lib/components/ProgressBar/ProgressBar.js +38 -36
  459. package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +14 -13
  460. package/lib/components/ProgressIndicator/ProgressIndicator.js +70 -70
  461. package/lib/components/RadioButton/RadioButton.Skeleton.js +8 -9
  462. package/lib/components/RadioButton/RadioButton.js +26 -26
  463. package/lib/components/RadioButtonGroup/RadioButtonGroup.js +54 -64
  464. package/lib/components/RadioTile/RadioTile.js +27 -25
  465. package/lib/components/Search/Search.Skeleton.js +15 -15
  466. package/lib/components/Search/Search.d.ts +83 -0
  467. package/lib/components/Search/Search.js +62 -69
  468. package/lib/components/Search/index.d.ts +11 -0
  469. package/lib/components/SecondaryButton/SecondaryButton.js +3 -5
  470. package/lib/components/Select/Select.Skeleton.js +11 -12
  471. package/lib/components/Select/Select.js +78 -72
  472. package/lib/components/SelectItem/SelectItem.js +16 -12
  473. package/lib/components/SelectItemGroup/SelectItemGroup.js +10 -11
  474. package/lib/components/SkeletonIcon/SkeletonIcon.js +10 -10
  475. package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +10 -10
  476. package/lib/components/SkeletonText/SkeletonText.js +28 -28
  477. package/lib/components/Slider/Slider.Skeleton.js +16 -17
  478. package/lib/components/Slider/Slider.js +305 -328
  479. package/lib/components/Slider/index.js +1 -1
  480. package/lib/components/Stack/Stack.js +18 -19
  481. package/lib/components/Stack/index.js +2 -2
  482. package/lib/components/StructuredList/StructuredList.Skeleton.js +24 -23
  483. package/lib/components/StructuredList/StructuredList.js +133 -105
  484. package/lib/components/Switch/IconSwitch.js +45 -51
  485. package/lib/components/Switch/Switch.js +33 -31
  486. package/lib/components/Tab/Tab.js +76 -82
  487. package/lib/components/Tab/index.js +1 -1
  488. package/lib/components/TabContent/TabContent.js +15 -17
  489. package/lib/components/Tabs/Tabs.Skeleton.js +13 -12
  490. package/lib/components/Tabs/Tabs.js +210 -209
  491. package/lib/components/Tabs/usePressable.js +27 -36
  492. package/lib/components/Tag/Tag.Skeleton.js +9 -8
  493. package/lib/components/Tag/Tag.js +33 -30
  494. package/lib/components/Text/Text.js +19 -19
  495. package/lib/components/Text/TextDirection.js +8 -7
  496. package/lib/components/Text/TextDirectionContext.js +1 -1
  497. package/lib/components/Text/index.js +1 -1
  498. package/lib/components/TextArea/TextArea.Skeleton.js +10 -11
  499. package/lib/components/TextArea/TextArea.js +88 -82
  500. package/lib/components/TextInput/ControlledPasswordInput.js +78 -72
  501. package/lib/components/TextInput/PasswordInput.js +100 -90
  502. package/lib/components/TextInput/TextInput.Skeleton.js +10 -11
  503. package/lib/components/TextInput/TextInput.js +104 -92
  504. package/lib/components/TextInput/util.js +28 -30
  505. package/lib/components/Theme/index.js +24 -19
  506. package/lib/components/Tile/Tile.js +134 -175
  507. package/lib/components/TileGroup/TileGroup.js +54 -69
  508. package/lib/components/TileGroup/index.js +1 -1
  509. package/lib/components/TimePicker/TimePicker.js +59 -66
  510. package/lib/components/TimePickerSelect/TimePickerSelect.js +19 -17
  511. package/lib/components/TimePickerSelect/index.js +1 -1
  512. package/lib/components/Toggle/Toggle.Skeleton.js +68 -57
  513. package/lib/components/Toggle/Toggle.js +43 -47
  514. package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +60 -54
  515. package/lib/components/Toggletip/index.js +51 -47
  516. package/lib/components/Tooltip/DefinitionTooltip.js +23 -30
  517. package/lib/components/Tooltip/Tooltip.js +34 -49
  518. package/lib/components/TreeView/TreeNode.js +93 -73
  519. package/lib/components/TreeView/TreeView.js +71 -82
  520. package/lib/components/UIShell/Content.js +12 -14
  521. package/lib/components/UIShell/Header.js +15 -11
  522. package/lib/components/UIShell/HeaderContainer.js +8 -14
  523. package/lib/components/UIShell/HeaderGlobalAction.js +25 -18
  524. package/lib/components/UIShell/HeaderGlobalBar.js +1 -3
  525. package/lib/components/UIShell/HeaderMenu.js +113 -128
  526. package/lib/components/UIShell/HeaderMenuButton.js +30 -21
  527. package/lib/components/UIShell/HeaderMenuItem.js +27 -19
  528. package/lib/components/UIShell/HeaderName.js +18 -13
  529. package/lib/components/UIShell/HeaderNavigation.js +18 -14
  530. package/lib/components/UIShell/HeaderPanel.js +22 -16
  531. package/lib/components/UIShell/HeaderSideNavItems.js +11 -9
  532. package/lib/components/UIShell/Link.js +11 -11
  533. package/lib/components/UIShell/SideNav.js +65 -61
  534. package/lib/components/UIShell/SideNavDetails.js +10 -11
  535. package/lib/components/UIShell/SideNavDivider.js +5 -3
  536. package/lib/components/UIShell/SideNavFooter.js +12 -12
  537. package/lib/components/UIShell/SideNavHeader.js +8 -6
  538. package/lib/components/UIShell/SideNavIcon.js +11 -8
  539. package/lib/components/UIShell/SideNavItem.js +11 -9
  540. package/lib/components/UIShell/SideNavItems.js +13 -11
  541. package/lib/components/UIShell/SideNavLink.js +18 -16
  542. package/lib/components/UIShell/SideNavLinkText.js +7 -8
  543. package/lib/components/UIShell/SideNavMenu.js +28 -35
  544. package/lib/components/UIShell/SideNavMenuItem.js +13 -13
  545. package/lib/components/UIShell/SideNavSwitcher.js +19 -19
  546. package/lib/components/UIShell/SkipToContent.js +9 -10
  547. package/lib/components/UIShell/Switcher.js +19 -10
  548. package/lib/components/UIShell/SwitcherDivider.js +9 -8
  549. package/lib/components/UIShell/SwitcherItem.js +25 -18
  550. package/lib/components/UIShell/_utils.js +1 -1
  551. package/lib/components/UnorderedList/UnorderedList.js +13 -13
  552. package/lib/index.js +10 -10
  553. package/lib/internal/ClickListener.js +49 -65
  554. package/lib/internal/FloatingMenu.js +192 -199
  555. package/lib/internal/OptimizedResize.js +9 -8
  556. package/lib/internal/Selection.js +91 -110
  557. package/lib/internal/createClassWrapper.js +2 -2
  558. package/lib/internal/deprecateFieldOnObject.js +5 -3
  559. package/lib/internal/environment.js +1 -1
  560. package/lib/internal/focus/index.js +1 -1
  561. package/lib/internal/keyboard/keys.js +11 -11
  562. package/lib/internal/keyboard/match.js +7 -6
  563. package/lib/internal/keyboard/navigation.js +15 -5
  564. package/lib/internal/useAnnouncer.js +2 -2
  565. package/lib/internal/useAttachedMenu.js +12 -20
  566. package/lib/internal/useControllableState.js +11 -16
  567. package/lib/internal/useDelayedState.js +9 -18
  568. package/lib/internal/useEffectOnce.js +4 -4
  569. package/lib/internal/useEvent.js +4 -4
  570. package/lib/internal/useId.js +14 -18
  571. package/lib/internal/useIdPrefix.js +1 -1
  572. package/lib/internal/useIsomorphicEffect.js +1 -1
  573. package/lib/internal/useMergedRefs.js +3 -3
  574. package/lib/internal/useNoInteractiveChildren.js +8 -19
  575. package/lib/internal/useNormalizedInputProps.js +16 -14
  576. package/lib/internal/usePrefix.js +1 -1
  577. package/lib/internal/useSavedCallback.js +3 -3
  578. package/lib/internal/warning.js +4 -4
  579. package/lib/internal/wrapFocus.js +16 -21
  580. package/lib/prop-types/AriaPropTypes.js +1 -1
  581. package/lib/prop-types/deprecate.js +6 -5
  582. package/lib/prop-types/isRequiredOneOf.js +15 -28
  583. package/lib/prop-types/requiredIfGivenPropIsTruthy.js +2 -2
  584. package/lib/prop-types/types.js +1 -1
  585. package/lib/tools/array.js +1 -1
  586. package/lib/tools/events.js +21 -14
  587. package/lib/tools/mergeRefs.js +3 -3
  588. package/lib/tools/setupGetInstanceId.js +1 -1
  589. package/lib/tools/uniqueId.js +3 -3
  590. package/lib/tools/wrapComponent.js +14 -13
  591. package/package.json +9 -9
@@ -5,7 +5,7 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
7
 
8
- import { objectWithoutProperties as _objectWithoutProperties, slicedToArray as _slicedToArray, defineProperty as _defineProperty, typeof as _typeof, objectSpread2 as _objectSpread2, extends as _extends, toConsumableArray as _toConsumableArray } from '../../_virtual/_rollupPluginBabelHelpers.js';
8
+ import { extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
9
9
  import PropTypes from 'prop-types';
10
10
  import React__default, { useContext, useState, useCallback, useRef, useEffect, useImperativeHandle } from 'react';
11
11
  import cx from 'classnames';
@@ -24,10 +24,8 @@ import { WarningFilled, WarningAltFilled } from '@carbon/icons-react';
24
24
  import { match } from '../../internal/keyboard/match.js';
25
25
  import { Escape, ArrowDown } from '../../internal/keyboard/keys.js';
26
26
 
27
- var _excluded = ["allowInput", "appendTo", "children", "className", "closeOnSelect", "dateFormat", "datePickerType", "disable", "enable", "inline", "invalid", "invalidText", "warn", "warnText", "light", "locale", "maxDate", "minDate", "onChange", "onClose", "onOpen", "readOnly", "short", "value"];
28
-
29
- l10n.en.weekdays.shorthand.forEach(function (_day, index) {
30
- var currentDay = l10n.en.weekdays.shorthand;
27
+ l10n.en.weekdays.shorthand.forEach((_day, index) => {
28
+ const currentDay = l10n.en.weekdays.shorthand;
31
29
 
32
30
  if (currentDay[index] === 'Thu' || currentDay[index] === 'Th') {
33
31
  currentDay[index] = 'Th';
@@ -35,7 +33,7 @@ l10n.en.weekdays.shorthand.forEach(function (_day, index) {
35
33
  currentDay[index] = currentDay[index].charAt(0);
36
34
  }
37
35
  });
38
- var forEach = Array.prototype.forEach;
36
+ const forEach = Array.prototype.forEach;
39
37
  /**
40
38
  * @param {number} monthNumber The month number.
41
39
  * @param {boolean} shorthand `true` to use shorthand month.
@@ -43,9 +41,7 @@ var forEach = Array.prototype.forEach;
43
41
  * @returns {string} The month string.
44
42
  */
45
43
 
46
- var monthToStr = function monthToStr(monthNumber, shorthand, locale) {
47
- return locale.months[shorthand ? 'shorthand' : 'longhand'][monthNumber];
48
- };
44
+ const monthToStr = (monthNumber, shorthand, locale) => locale.months[shorthand ? 'shorthand' : 'longhand'][monthNumber];
49
45
  /**
50
46
  * @param {object} config Plugin configuration.
51
47
  * @param {boolean} [config.shorthand] `true` to use shorthand month.
@@ -57,55 +53,50 @@ var monthToStr = function monthToStr(monthNumber, shorthand, locale) {
57
53
  */
58
54
 
59
55
 
60
- var carbonFlatpickrMonthSelectPlugin = function carbonFlatpickrMonthSelectPlugin(config) {
61
- return function (fp) {
62
- var setupElements = function setupElements() {
63
- var _fp$monthElements;
56
+ const carbonFlatpickrMonthSelectPlugin = config => fp => {
57
+ const setupElements = () => {
58
+ if (!fp.monthElements) {
59
+ return;
60
+ }
64
61
 
65
- if (!fp.monthElements) {
62
+ fp.monthElements.forEach(elem => {
63
+ if (!elem.parentNode) {
66
64
  return;
67
65
  }
68
66
 
69
- fp.monthElements.forEach(function (elem) {
70
- if (!elem.parentNode) {
71
- return;
72
- }
73
-
74
- elem.parentNode.removeChild(elem);
75
- });
76
-
77
- (_fp$monthElements = fp.monthElements).splice.apply(_fp$monthElements, [0, fp.monthElements.length].concat(_toConsumableArray(fp.monthElements.map(function () {
78
- // eslint-disable-next-line no-underscore-dangle
79
- var monthElement = fp._createElement('span', config.classFlatpickrCurrentMonth);
80
-
81
- monthElement.textContent = monthToStr(fp.currentMonth, config.shorthand === true, fp.l10n);
82
- fp.yearElements[0].closest(config.selectorFlatpickrMonthYearContainer).insertBefore(monthElement, fp.yearElements[0].closest(config.selectorFlatpickrYearContainer));
83
- return monthElement;
84
- }))));
85
- };
67
+ elem.parentNode.removeChild(elem);
68
+ });
69
+ fp.monthElements.splice(0, fp.monthElements.length, ...fp.monthElements.map(() => {
70
+ // eslint-disable-next-line no-underscore-dangle
71
+ const monthElement = fp._createElement('span', config.classFlatpickrCurrentMonth);
72
+
73
+ monthElement.textContent = monthToStr(fp.currentMonth, config.shorthand === true, fp.l10n);
74
+ fp.yearElements[0].closest(config.selectorFlatpickrMonthYearContainer).insertBefore(monthElement, fp.yearElements[0].closest(config.selectorFlatpickrYearContainer));
75
+ return monthElement;
76
+ }));
77
+ };
86
78
 
87
- var updateCurrentMonth = function updateCurrentMonth() {
88
- if (fp.monthElements) {
89
- var monthStr = monthToStr(fp.currentMonth, config.shorthand === true, fp.l10n);
90
- fp.yearElements.forEach(function (elem) {
91
- var currentMonthContainer = elem.closest(config.selectorFlatpickrMonthYearContainer);
92
- Array.prototype.forEach.call(currentMonthContainer.querySelectorAll('.cur-month'), function (monthElement) {
93
- monthElement.textContent = monthStr;
94
- });
79
+ const updateCurrentMonth = () => {
80
+ if (fp.monthElements) {
81
+ const monthStr = monthToStr(fp.currentMonth, config.shorthand === true, fp.l10n);
82
+ fp.yearElements.forEach(elem => {
83
+ const currentMonthContainer = elem.closest(config.selectorFlatpickrMonthYearContainer);
84
+ Array.prototype.forEach.call(currentMonthContainer.querySelectorAll('.cur-month'), monthElement => {
85
+ monthElement.textContent = monthStr;
95
86
  });
96
- }
97
- };
87
+ });
88
+ }
89
+ };
98
90
 
99
- var register = function register() {
100
- fp.loadedPlugins.push('carbonFlatpickrMonthSelectPlugin');
101
- };
91
+ const register = () => {
92
+ fp.loadedPlugins.push('carbonFlatpickrMonthSelectPlugin');
93
+ };
102
94
 
103
- return {
104
- onMonthChange: updateCurrentMonth,
105
- onValueUpdate: updateCurrentMonth,
106
- onOpen: updateCurrentMonth,
107
- onReady: [setupElements, updateCurrentMonth, register]
108
- };
95
+ return {
96
+ onMonthChange: updateCurrentMonth,
97
+ onValueUpdate: updateCurrentMonth,
98
+ onOpen: updateCurrentMonth,
99
+ onReady: [setupElements, updateCurrentMonth, register]
109
100
  };
110
101
  };
111
102
  /**
@@ -116,31 +107,33 @@ var carbonFlatpickrMonthSelectPlugin = function carbonFlatpickrMonthSelectPlugin
116
107
 
117
108
 
118
109
  function isLabelTextEmpty(children) {
119
- return children.every(function (child) {
120
- return !child.props.labelText;
121
- });
110
+ return children.every(child => !child.props.labelText);
122
111
  }
123
112
 
124
- var rightArrowHTML = "<svg width=\"16px\" height=\"16px\" viewBox=\"0 0 16 16\">\n <polygon points=\"11,8 6,13 5.3,12.3 9.6,8 5.3,3.7 6,3 \"/>\n</svg>";
125
- var leftArrowHTML = "<svg width=\"16px\" height=\"16px\" viewBox=\"0 0 16 16\">\n <polygon points=\"5,8 10,3 10.7,3.7 6.4,8 10.7,12.3 10,13 \"/>\n</svg>";
113
+ const rightArrowHTML = `<svg width="16px" height="16px" viewBox="0 0 16 16">
114
+ <polygon points="11,8 6,13 5.3,12.3 9.6,8 5.3,3.7 6,3 "/>
115
+ </svg>`;
116
+ const leftArrowHTML = `<svg width="16px" height="16px" viewBox="0 0 16 16">
117
+ <polygon points="5,8 10,3 10.7,3.7 6.4,8 10.7,12.3 10,13 "/>
118
+ </svg>`;
126
119
 
127
120
  function updateClassNames(calendar, prefix) {
128
- var calendarContainer = calendar.calendarContainer;
129
- var daysContainer = calendar.days;
121
+ const calendarContainer = calendar.calendarContainer;
122
+ const daysContainer = calendar.days;
130
123
 
131
124
  if (calendarContainer && daysContainer) {
132
125
  // calendarContainer and daysContainer are undefined if flatpickr detects a mobile device
133
- calendarContainer.classList.add("".concat(prefix, "--date-picker__calendar"));
134
- calendarContainer.querySelector('.flatpickr-month').classList.add("".concat(prefix, "--date-picker__month"));
135
- calendarContainer.querySelector('.flatpickr-weekdays').classList.add("".concat(prefix, "--date-picker__weekdays"));
136
- calendarContainer.querySelector('.flatpickr-days').classList.add("".concat(prefix, "--date-picker__days"));
137
- forEach.call(calendarContainer.querySelectorAll('.flatpickr-weekday'), function (item) {
138
- var currentItem = item;
126
+ calendarContainer.classList.add(`${prefix}--date-picker__calendar`);
127
+ calendarContainer.querySelector('.flatpickr-month').classList.add(`${prefix}--date-picker__month`);
128
+ calendarContainer.querySelector('.flatpickr-weekdays').classList.add(`${prefix}--date-picker__weekdays`);
129
+ calendarContainer.querySelector('.flatpickr-days').classList.add(`${prefix}--date-picker__days`);
130
+ forEach.call(calendarContainer.querySelectorAll('.flatpickr-weekday'), item => {
131
+ const currentItem = item;
139
132
  currentItem.innerHTML = currentItem.innerHTML.replace(/\s+/g, '');
140
- currentItem.classList.add("".concat(prefix, "--date-picker__weekday"));
133
+ currentItem.classList.add(`${prefix}--date-picker__weekday`);
141
134
  });
142
- forEach.call(daysContainer.querySelectorAll('.flatpickr-day'), function (item) {
143
- item.classList.add("".concat(prefix, "--date-picker__day"));
135
+ forEach.call(daysContainer.querySelectorAll('.flatpickr-day'), item => {
136
+ item.classList.add(`${prefix}--date-picker__day`);
144
137
 
145
138
  if (item.classList.contains('today') && calendar.selectedDates.length > 0) {
146
139
  item.classList.add('no-border');
@@ -151,62 +144,50 @@ function updateClassNames(calendar, prefix) {
151
144
  }
152
145
  }
153
146
 
154
- var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref, ref) {
155
- var _cx;
156
-
157
- var allowInput = _ref.allowInput,
158
- appendTo = _ref.appendTo,
159
- children = _ref.children,
160
- className = _ref.className,
161
- _ref$closeOnSelect = _ref.closeOnSelect,
162
- closeOnSelect = _ref$closeOnSelect === void 0 ? true : _ref$closeOnSelect,
163
- _ref$dateFormat = _ref.dateFormat,
164
- dateFormat = _ref$dateFormat === void 0 ? 'm/d/Y' : _ref$dateFormat,
165
- datePickerType = _ref.datePickerType,
166
- disable = _ref.disable,
167
- enable = _ref.enable,
168
- inline = _ref.inline,
169
- invalid = _ref.invalid,
170
- invalidText = _ref.invalidText,
171
- warn = _ref.warn,
172
- warnText = _ref.warnText,
173
- _ref$light = _ref.light,
174
- light = _ref$light === void 0 ? false : _ref$light,
175
- _ref$locale = _ref.locale,
176
- locale = _ref$locale === void 0 ? 'en' : _ref$locale,
177
- maxDate = _ref.maxDate,
178
- minDate = _ref.minDate,
179
- onChange = _ref.onChange,
180
- onClose = _ref.onClose,
181
- onOpen = _ref.onOpen,
182
- _ref$readOnly = _ref.readOnly,
183
- readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
184
- _ref$short = _ref.short,
185
- short = _ref$short === void 0 ? false : _ref$short,
186
- value = _ref.value,
187
- rest = _objectWithoutProperties(_ref, _excluded);
188
-
189
- var prefix = usePrefix();
190
-
191
- var _useContext = useContext(FormContext),
192
- isFluid = _useContext.isFluid;
193
-
194
- var _useState = useState(false),
195
- _useState2 = _slicedToArray(_useState, 2),
196
- hasInput = _useState2[0],
197
- setHasInput = _useState2[1];
198
-
199
- var startInputField = useCallback(function (node) {
147
+ const DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref, ref) {
148
+ let {
149
+ allowInput,
150
+ appendTo,
151
+ children,
152
+ className,
153
+ closeOnSelect = true,
154
+ dateFormat = 'm/d/Y',
155
+ datePickerType,
156
+ disable,
157
+ enable,
158
+ inline,
159
+ invalid,
160
+ invalidText,
161
+ warn,
162
+ warnText,
163
+ light = false,
164
+ locale = 'en',
165
+ maxDate,
166
+ minDate,
167
+ onChange,
168
+ onClose,
169
+ onOpen,
170
+ readOnly = false,
171
+ short = false,
172
+ value,
173
+ ...rest
174
+ } = _ref;
175
+ const prefix = usePrefix();
176
+ const {
177
+ isFluid
178
+ } = useContext(FormContext);
179
+ const [hasInput, setHasInput] = useState(false);
180
+ const startInputField = useCallback(node => {
200
181
  if (node !== null) {
201
182
  startInputField.current = node;
202
183
  setHasInput(true);
203
184
  }
204
185
  }, []);
205
- var endInputField = useRef(null);
206
- var lastStartValue = useRef(''); // fix datepicker deleting the selectedDate when the calendar closes
186
+ const endInputField = useRef(null);
187
+ const lastStartValue = useRef(''); // fix datepicker deleting the selectedDate when the calendar closes
207
188
 
208
- var onCalendarClose = function onCalendarClose(selectedDates, dateStr) {
209
- setTimeout(function () {
189
+ const onCalendarClose = (selectedDates, dateStr) => {
190
+ setTimeout(() => {
210
191
  if (lastStartValue.current && selectedDates[0] && !startInputField.current.value) {
211
192
  startInputField.current.value = lastStartValue.current;
212
193
  calendarRef.current.setDate([startInputField.current.value, endInputField.current.value], true, calendarRef.current.config.dateFormat);
@@ -218,46 +199,53 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
218
199
  });
219
200
  };
220
201
 
221
- var calendarRef = useRef(null);
222
- var savedOnChange = useSavedCallback(onChange);
223
- var savedOnClose = useSavedCallback(datePickerType === 'range' ? onCalendarClose : onClose);
224
- var savedOnOpen = useSavedCallback(onOpen);
225
- var datePickerClasses = cx("".concat(prefix, "--date-picker"), (_cx = {}, _defineProperty(_cx, "".concat(prefix, "--date-picker--short"), short), _defineProperty(_cx, "".concat(prefix, "--date-picker--light"), light), _defineProperty(_cx, "".concat(prefix, "--date-picker--simple"), datePickerType === 'simple'), _defineProperty(_cx, "".concat(prefix, "--date-picker--single"), datePickerType === 'single'), _defineProperty(_cx, "".concat(prefix, "--date-picker--range"), datePickerType === 'range'), _defineProperty(_cx, "".concat(prefix, "--date-picker--nolabel"), datePickerType === 'range' && isLabelTextEmpty(children)), _cx));
226
- var wrapperClasses = cx("".concat(prefix, "--form-item"), _defineProperty({}, className, className));
227
- var childrenWithProps = React__default.Children.toArray(children).map(function (child, index) {
202
+ const calendarRef = useRef(null);
203
+ const savedOnChange = useSavedCallback(onChange);
204
+ const savedOnClose = useSavedCallback(datePickerType === 'range' ? onCalendarClose : onClose);
205
+ const savedOnOpen = useSavedCallback(onOpen);
206
+ const datePickerClasses = cx(`${prefix}--date-picker`, {
207
+ [`${prefix}--date-picker--short`]: short,
208
+ [`${prefix}--date-picker--light`]: light,
209
+ [`${prefix}--date-picker--simple`]: datePickerType === 'simple',
210
+ [`${prefix}--date-picker--single`]: datePickerType === 'single',
211
+ [`${prefix}--date-picker--range`]: datePickerType === 'range',
212
+ [`${prefix}--date-picker--nolabel`]: datePickerType === 'range' && isLabelTextEmpty(children)
213
+ });
214
+ const wrapperClasses = cx(`${prefix}--form-item`, {
215
+ [className]: className
216
+ });
217
+ const childrenWithProps = React__default.Children.toArray(children).map((child, index) => {
228
218
  if (index === 0 && child.type === React__default.createElement(DatePickerInput, child.props).type) {
229
219
  return /*#__PURE__*/React__default.cloneElement(child, {
230
- datePickerType: datePickerType,
220
+ datePickerType,
231
221
  ref: startInputField,
232
- readOnly: readOnly
222
+ readOnly
233
223
  });
234
224
  }
235
225
 
236
226
  if (index === 1 && child.type === React__default.createElement(DatePickerInput, child.props).type) {
237
227
  return /*#__PURE__*/React__default.cloneElement(child, {
238
- datePickerType: datePickerType,
228
+ datePickerType,
239
229
  ref: endInputField,
240
- readOnly: readOnly
230
+ readOnly
241
231
  });
242
232
  }
243
233
 
244
234
  if (index === 0) {
245
235
  return /*#__PURE__*/React__default.cloneElement(child, {
246
236
  ref: startInputField,
247
- readOnly: readOnly
237
+ readOnly
248
238
  });
249
239
  }
250
240
 
251
241
  if (index === 1) {
252
242
  return /*#__PURE__*/React__default.cloneElement(child, {
253
243
  ref: endInputField,
254
- readOnly: readOnly
244
+ readOnly
255
245
  });
256
246
  }
257
247
  });
258
- useEffect(function () {
259
- var _flatpickr;
260
-
248
+ useEffect(() => {
261
249
  if (datePickerType !== 'single' && datePickerType !== 'range') {
262
250
  return;
263
251
  }
@@ -266,7 +254,7 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
266
254
  return;
267
255
  }
268
256
 
269
- var onHook = function onHook(_electedDates, _dateStr, instance, prefix) {
257
+ const onHook = (_electedDates, _dateStr, instance, prefix) => {
270
258
  updateClassNames(instance, prefix);
271
259
 
272
260
  if (startInputField !== null && startInputField !== void 0 && startInputField.current) {
@@ -280,8 +268,8 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
280
268
  // is provided, we return the default empty disabled array, allowing all dates.
281
269
 
282
270
 
283
- var enableOrDisable = enable ? 'enable' : 'disable';
284
- var enableOrDisableArr;
271
+ let enableOrDisable = enable ? 'enable' : 'disable';
272
+ let enableOrDisableArr;
285
273
 
286
274
  if (!enable && !disable) {
287
275
  enableOrDisableArr = [];
@@ -291,47 +279,68 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
291
279
  enableOrDisableArr = disable;
292
280
  }
293
281
 
294
- var localeData;
282
+ let localeData;
295
283
 
296
- if (_typeof(locale) === 'object') {
297
- var location = locale.locale ? locale.locale : 'en';
298
- localeData = _objectSpread2(_objectSpread2({}, l10n[location]), locale);
284
+ if (typeof locale === 'object') {
285
+ let location = locale.locale ? locale.locale : 'en';
286
+ localeData = { ...l10n[location],
287
+ ...locale
288
+ };
299
289
  } else {
300
290
  localeData = l10n[locale];
301
291
  }
302
292
 
303
- var start = startInputField.current;
304
- var end = endInputField.current;
305
- var calendar = new flatpickr(start, (_flatpickr = {
306
- inline: inline !== null && inline !== void 0 ? inline : false,
293
+ const {
294
+ current: start
295
+ } = startInputField;
296
+ const {
297
+ current: end
298
+ } = endInputField;
299
+ const calendar = new flatpickr(start, {
300
+ inline: inline ?? false,
307
301
  disableMobile: true,
308
302
  defaultDate: value,
309
303
  closeOnSelect: closeOnSelect,
310
304
  mode: datePickerType,
311
- allowInput: allowInput !== null && allowInput !== void 0 ? allowInput : true,
305
+ allowInput: allowInput ?? true,
312
306
  dateFormat: dateFormat,
313
- locale: localeData
314
- }, _defineProperty(_flatpickr, enableOrDisable, enableOrDisableArr), _defineProperty(_flatpickr, "minDate", minDate), _defineProperty(_flatpickr, "maxDate", maxDate), _defineProperty(_flatpickr, "plugins", [datePickerType === 'range' ? new carbonFlatpickrRangePlugin({
315
- input: endInputField.current
316
- }) : function () {}, appendTo ? carbonFlatpickrAppendToPlugin({
317
- appendTo: appendTo
318
- }) : function () {}, carbonFlatpickrMonthSelectPlugin({
319
- selectorFlatpickrMonthYearContainer: '.flatpickr-current-month',
320
- selectorFlatpickrYearContainer: '.numInputWrapper',
321
- selectorFlatpickrCurrentMonth: '.cur-month',
322
- classFlatpickrCurrentMonth: 'cur-month'
323
- }), carbonFlatpickrFixEventsPlugin({
324
- inputFrom: startInputField.current,
325
- inputTo: endInputField.current,
326
- lastStartValue: lastStartValue
327
- })]), _defineProperty(_flatpickr, "clickOpens", !readOnly), _defineProperty(_flatpickr, "noCalendar", readOnly), _defineProperty(_flatpickr, "nextArrow", rightArrowHTML), _defineProperty(_flatpickr, "prevArrow", leftArrowHTML), _defineProperty(_flatpickr, "onChange", function onChange() {
328
- if (savedOnChange && !readOnly) {
329
- savedOnChange.apply(void 0, arguments);
330
- }
331
- }), _defineProperty(_flatpickr, "onClose", savedOnClose), _defineProperty(_flatpickr, "onReady", onHook), _defineProperty(_flatpickr, "onMonthChange", onHook), _defineProperty(_flatpickr, "onYearChange", onHook), _defineProperty(_flatpickr, "onOpen", function onOpen() {
332
- onHook.apply(void 0, arguments);
333
- savedOnOpen.apply(void 0, arguments);
334
- }), _defineProperty(_flatpickr, "onValueUpdate", onHook), _flatpickr));
307
+ locale: localeData,
308
+ [enableOrDisable]: enableOrDisableArr,
309
+ minDate: minDate,
310
+ maxDate: maxDate,
311
+ plugins: [datePickerType === 'range' ? carbonFlatpickrRangePlugin({
312
+ input: endInputField.current
313
+ }) : () => {}, appendTo ? carbonFlatpickrAppendToPlugin({
314
+ appendTo
315
+ }) : () => {}, carbonFlatpickrMonthSelectPlugin({
316
+ selectorFlatpickrMonthYearContainer: '.flatpickr-current-month',
317
+ selectorFlatpickrYearContainer: '.numInputWrapper',
318
+ selectorFlatpickrCurrentMonth: '.cur-month',
319
+ classFlatpickrCurrentMonth: 'cur-month'
320
+ }), carbonFlatpickrFixEventsPlugin({
321
+ inputFrom: startInputField.current,
322
+ inputTo: endInputField.current,
323
+ lastStartValue
324
+ })],
325
+ clickOpens: !readOnly,
326
+ noCalendar: readOnly,
327
+ nextArrow: rightArrowHTML,
328
+ prevArrow: leftArrowHTML,
329
+ onChange: function () {
330
+ if (savedOnChange && !readOnly) {
331
+ savedOnChange(...arguments);
332
+ }
333
+ },
334
+ onClose: savedOnClose,
335
+ onReady: onHook,
336
+ onMonthChange: onHook,
337
+ onYearChange: onHook,
338
+ onOpen: function () {
339
+ onHook(...arguments);
340
+ savedOnOpen(...arguments);
341
+ },
342
+ onValueUpdate: onHook
343
+ });
335
344
  calendarRef.current = calendar;
336
345
 
337
346
  function handleArrowDown(event) {
@@ -340,11 +349,13 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
340
349
  }
341
350
 
342
351
  if (match(event, ArrowDown)) {
343
- var calendarContainer = calendar.calendarContainer,
344
- fpSelectedDateElem = calendar.selectedDateElem,
345
- fptodayDateElem = calendar.todayDateElem;
346
- var selectedDateElem = calendarContainer.querySelector('.selected') && fpSelectedDateElem;
347
- var todayDateElem = calendarContainer.querySelector('.today') && fptodayDateElem;
352
+ const {
353
+ calendarContainer,
354
+ selectedDateElem: fpSelectedDateElem,
355
+ todayDateElem: fptodayDateElem
356
+ } = calendar;
357
+ const selectedDateElem = calendarContainer.querySelector('.selected') && fpSelectedDateElem;
358
+ const todayDateElem = calendarContainer.querySelector('.today') && fptodayDateElem;
348
359
  (selectedDateElem || todayDateElem || calendarContainer.querySelector('.flatpickr-day[tabindex]') || calendarContainer).focus();
349
360
  }
350
361
  }
@@ -354,7 +365,9 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
354
365
  calendar.calendarContainer.classList.remove('open');
355
366
  }
356
367
 
357
- var target = event.target;
368
+ const {
369
+ target
370
+ } = event;
358
371
 
359
372
  if (target === start) {
360
373
  lastStartValue.current = start.value;
@@ -396,7 +409,7 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
396
409
  } //component did unmount equivalent
397
410
 
398
411
 
399
- return function () {
412
+ return () => {
400
413
  // Note: if the `startInputField` ref is undefined then calendar will be
401
414
  // of type: Array and `destroy` will not be defined
402
415
  if (calendar && calendar.destroy) {
@@ -430,59 +443,57 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
430
443
  // instance for cases where functions like open() or close()
431
444
  // need to be imperatively called on the calendar
432
445
 
433
- useImperativeHandle(ref, function () {
434
- return {
435
- get calendar() {
436
- return calendarRef.current;
437
- }
446
+ useImperativeHandle(ref, () => ({
447
+ get calendar() {
448
+ return calendarRef.current;
449
+ }
438
450
 
439
- };
440
- });
441
- useEffect(function () {
451
+ }));
452
+ useEffect(() => {
442
453
  var _calendarRef$current;
443
454
 
444
455
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current = calendarRef.current) !== null && _calendarRef$current !== void 0 && _calendarRef$current.set) {
445
456
  calendarRef.current.set({
446
- dateFormat: dateFormat
457
+ dateFormat
447
458
  });
448
459
  }
449
460
  }, [dateFormat]);
450
- useEffect(function () {
461
+ useEffect(() => {
451
462
  var _calendarRef$current2;
452
463
 
453
464
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current2 = calendarRef.current) !== null && _calendarRef$current2 !== void 0 && _calendarRef$current2.set) {
454
465
  calendarRef.current.set('minDate', minDate);
455
466
  }
456
467
  }, [minDate]);
457
- useEffect(function () {
468
+ useEffect(() => {
458
469
  var _calendarRef$current3;
459
470
 
460
471
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current3 = calendarRef.current) !== null && _calendarRef$current3 !== void 0 && _calendarRef$current3.set) {
461
472
  calendarRef.current.set('maxDate', maxDate);
462
473
  }
463
474
  }, [maxDate]);
464
- useEffect(function () {
475
+ useEffect(() => {
465
476
  var _calendarRef$current4;
466
477
 
467
478
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current4 = calendarRef.current) !== null && _calendarRef$current4 !== void 0 && _calendarRef$current4.set && disable) {
468
479
  calendarRef.current.set('disable', disable);
469
480
  }
470
481
  }, [disable]);
471
- useEffect(function () {
482
+ useEffect(() => {
472
483
  var _calendarRef$current5;
473
484
 
474
485
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current5 = calendarRef.current) !== null && _calendarRef$current5 !== void 0 && _calendarRef$current5.set && enable) {
475
486
  calendarRef.current.set('enable', enable);
476
487
  }
477
488
  }, [enable]);
478
- useEffect(function () {
489
+ useEffect(() => {
479
490
  var _calendarRef$current6;
480
491
 
481
492
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current6 = calendarRef.current) !== null && _calendarRef$current6 !== void 0 && _calendarRef$current6.set && inline) {
482
493
  calendarRef.current.set('inline', inline);
483
494
  }
484
495
  }, [inline]);
485
- useEffect(function () {
496
+ useEffect(() => {
486
497
  var _calendarRef$current7;
487
498
 
488
499
  if (calendarRef !== null && calendarRef !== void 0 && (_calendarRef$current7 = calendarRef.current) !== null && _calendarRef$current7 !== void 0 && _calendarRef$current7.set) {
@@ -496,26 +507,26 @@ var DatePicker = /*#__PURE__*/React__default.forwardRef(function DatePicker(_ref
496
507
  }
497
508
  }, [value, prefix]); //eslint-disable-line react-hooks/exhaustive-deps
498
509
 
499
- var fluidError;
510
+ let fluidError;
500
511
 
501
512
  if (isFluid) {
502
513
  if (invalid) {
503
514
  fluidError = /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(WarningFilled, {
504
- className: "".concat(prefix, "--date-picker__icon ").concat(prefix, "--date-picker__icon--invalid")
515
+ className: `${prefix}--date-picker__icon ${prefix}--date-picker__icon--invalid`
505
516
  }), /*#__PURE__*/React__default.createElement("hr", {
506
- className: "".concat(prefix, "--date-picker__divider")
517
+ className: `${prefix}--date-picker__divider`
507
518
  }), /*#__PURE__*/React__default.createElement("div", {
508
- className: "".concat(prefix, "--form-requirement")
519
+ className: `${prefix}--form-requirement`
509
520
  }, invalidText));
510
521
  }
511
522
 
512
523
  if (warn && !invalid) {
513
524
  fluidError = /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(WarningAltFilled, {
514
- className: "".concat(prefix, "--date-picker__icon ").concat(prefix, "--date-picker__icon--warn")
525
+ className: `${prefix}--date-picker__icon ${prefix}--date-picker__icon--warn`
515
526
  }), /*#__PURE__*/React__default.createElement("hr", {
516
- className: "".concat(prefix, "--date-picker__divider")
527
+ className: `${prefix}--date-picker__divider`
517
528
  }), /*#__PURE__*/React__default.createElement("div", {
518
- className: "".concat(prefix, "--form-requirement")
529
+ className: `${prefix}--form-requirement`
519
530
  }, warnText));
520
531
  }
521
532
  }