@carbon/ibm-products 2.43.2-canary.12 → 2.43.2-canary.122

Sign up to get free protection for your applications and to get access to all the features.
Files changed (424) hide show
  1. package/css/config-dev.css +6 -1
  2. package/css/config-dev.css.map +1 -1
  3. package/css/config.css +6 -1
  4. package/css/config.css.map +1 -1
  5. package/css/index-full-carbon.css +1854 -499
  6. package/css/index-full-carbon.css.map +1 -1
  7. package/css/index-full-carbon.min.css +1 -1
  8. package/css/index-full-carbon.min.css.map +1 -1
  9. package/css/index-without-carbon-released-only.css +267 -65
  10. package/css/index-without-carbon-released-only.css.map +1 -1
  11. package/css/index-without-carbon-released-only.min.css +1 -1
  12. package/css/index-without-carbon-released-only.min.css.map +1 -1
  13. package/css/index-without-carbon.css +1463 -250
  14. package/css/index-without-carbon.css.map +1 -1
  15. package/css/index-without-carbon.min.css +1 -1
  16. package/css/index-without-carbon.min.css.map +1 -1
  17. package/css/index.css +1659 -369
  18. package/css/index.css.map +1 -1
  19. package/css/index.min.css +1 -1
  20. package/css/index.min.css.map +1 -1
  21. package/es/components/APIKeyModal/APIKeyModal.types.d.ts +6 -0
  22. package/es/components/ActionBar/ActionBar.d.ts +58 -2
  23. package/es/components/ActionBar/ActionBar.js +14 -9
  24. package/es/components/ActionBar/ActionBarItem.d.ts +36 -2
  25. package/es/components/ActionBar/ActionBarItem.js +8 -5
  26. package/es/components/ActionBar/ActionBarOverflowItems.d.ts +55 -16
  27. package/es/components/ActionBar/ActionBarOverflowItems.js +8 -4
  28. package/es/components/AddSelect/types/index.d.ts +6 -0
  29. package/es/components/Card/Card.d.ts +68 -2
  30. package/es/components/Card/Card.js +28 -35
  31. package/es/components/Card/CardFooter.d.ts +51 -48
  32. package/es/components/Card/CardFooter.js +4 -2
  33. package/es/components/Card/CardHeader.d.ts +67 -49
  34. package/es/components/Card/CardHeader.js +4 -2
  35. package/es/components/Coachmark/Coachmark.d.ts +6 -1
  36. package/es/components/Coachmark/Coachmark.js +47 -11
  37. package/es/components/Coachmark/CoachmarkOverlay.js +2 -4
  38. package/es/components/Coachmark/utils/enums.d.ts +6 -0
  39. package/es/components/CoachmarkBeacon/CoachmarkBeacon.js +1 -7
  40. package/es/components/CoachmarkFixed/CoachmarkFixed.js +13 -11
  41. package/es/components/CoachmarkOverlayElements/CoachmarkOverlayElements.js +2 -1
  42. package/es/components/CoachmarkStack/CoachmarkStack.d.ts +67 -2
  43. package/es/components/CoachmarkStack/CoachmarkStack.js +22 -11
  44. package/es/components/CoachmarkStack/CoachmarkStackHome.d.ts +71 -2
  45. package/es/components/CoachmarkStack/CoachmarkStackHome.js +25 -23
  46. package/es/components/ConditionBuilder/ConditionBlock/ConditionBlock.js +100 -58
  47. package/es/components/ConditionBuilder/ConditionBuilder.js +82 -25
  48. package/es/components/ConditionBuilder/ConditionBuilderActions/ConditionBuilderActions.d.ts +15 -0
  49. package/es/components/ConditionBuilder/ConditionBuilderActions/ConditionBuilderActions.js +154 -0
  50. package/es/components/ConditionBuilder/ConditionBuilderAdd/ConditionBuilderAdd.d.ts +3 -1
  51. package/es/components/ConditionBuilder/ConditionBuilderAdd/ConditionBuilderAdd.js +30 -27
  52. package/es/components/ConditionBuilder/ConditionBuilderButton/ConditionBuilderButton.d.ts +8 -1
  53. package/es/components/ConditionBuilder/ConditionBuilderButton/ConditionBuilderButton.js +35 -11
  54. package/es/components/ConditionBuilder/ConditionBuilderConnector/ConditionConnector.js +18 -10
  55. package/es/components/ConditionBuilder/ConditionBuilderConnector/GroupConnector.js +19 -11
  56. package/es/components/ConditionBuilder/ConditionBuilderContent/ConditionBuilderContent.d.ts +9 -13
  57. package/es/components/ConditionBuilder/ConditionBuilderContent/ConditionBuilderContent.js +83 -64
  58. package/es/components/ConditionBuilder/ConditionBuilderContext/ConditionBuilderProvider.d.ts +13 -7
  59. package/es/components/ConditionBuilder/ConditionBuilderContext/ConditionBuilderProvider.js +31 -8
  60. package/es/components/ConditionBuilder/ConditionBuilderContext/DataConfigs.d.ts +8 -2
  61. package/es/components/ConditionBuilder/ConditionBuilderContext/DataConfigs.js +35 -24
  62. package/es/components/ConditionBuilder/ConditionBuilderContext/translationObject.d.ts +43 -36
  63. package/es/components/ConditionBuilder/ConditionBuilderContext/translationObject.js +43 -36
  64. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItem.d.ts +6 -2
  65. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItem.js +114 -40
  66. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemDate/ConditionBuilderItemDate.d.ts +3 -1
  67. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemDate/ConditionBuilderItemDate.js +24 -9
  68. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemNumber/ConditionBuilderItemNumber.js +27 -9
  69. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/ItemOption.d.ts +13 -0
  70. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/ItemOption.js +114 -0
  71. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/{ConditionBuilderItemOption.d.ts → ItemOptionForValueField.d.ts} +2 -2
  72. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/{ConditionBuilderItemOption.js → ItemOptionForValueField.js} +71 -38
  73. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemText/ConditionBuilderItemText.d.ts +5 -1
  74. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemText/ConditionBuilderItemText.js +22 -9
  75. package/es/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemTime/ConditionBuilderItemTime.js +1 -1
  76. package/es/components/ConditionBuilder/ConditionGroupBuilder/ConditionGroupBuilder.d.ts +1 -3
  77. package/es/components/ConditionBuilder/ConditionGroupBuilder/ConditionGroupBuilder.js +122 -40
  78. package/es/components/ConditionBuilder/ConditionPreview/ConditionPreview.d.ts +5 -1
  79. package/es/components/ConditionBuilder/ConditionPreview/ConditionPreview.js +51 -19
  80. package/es/components/ConditionBuilder/utils/handleKeyboardEvents.d.ts +2 -1
  81. package/es/components/ConditionBuilder/utils/handleKeyboardEvents.js +152 -42
  82. package/es/components/ConditionBuilder/utils/useTranslations.d.ts +1 -0
  83. package/es/components/ConditionBuilder/utils/useTranslations.js +26 -0
  84. package/es/components/ConditionBuilder/utils/util.d.ts +6 -4
  85. package/es/components/ConditionBuilder/utils/util.js +42 -17
  86. package/es/components/CreateFullPage/CreateFullPage.js +2 -2
  87. package/es/components/DataSpreadsheet/DataSpreadsheet.d.ts +26 -0
  88. package/es/components/DataSpreadsheet/DataSpreadsheet.js +129 -53
  89. package/es/components/DataSpreadsheet/DataSpreadsheetBody.d.ts +16 -0
  90. package/es/components/DataSpreadsheet/DataSpreadsheetBody.js +32 -7
  91. package/es/components/DataSpreadsheet/DataSpreadsheetHeader.d.ts +8 -0
  92. package/es/components/DataSpreadsheet/DataSpreadsheetHeader.js +16 -3
  93. package/es/components/DataSpreadsheet/types/index.d.ts +7 -0
  94. package/es/components/Datagrid/Datagrid/Datagrid.d.ts +0 -4
  95. package/es/components/Datagrid/Datagrid/Datagrid.js +4 -9
  96. package/es/components/Datagrid/Datagrid/DatagridBody.d.ts +6 -0
  97. package/es/components/Datagrid/Datagrid/DatagridContent.js +4 -3
  98. package/es/components/Datagrid/Datagrid/DatagridHeaderRow.js +23 -8
  99. package/es/components/Datagrid/Datagrid/DatagridRefBody.d.ts +6 -0
  100. package/es/components/Datagrid/Datagrid/DatagridRow.js +21 -8
  101. package/es/components/Datagrid/Datagrid/DatagridSelectAll.js +6 -6
  102. package/es/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +3 -2
  103. package/es/components/Datagrid/Datagrid/DatagridSimpleBody.d.ts +6 -0
  104. package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +3 -1
  105. package/es/components/Datagrid/Datagrid/DraggableElement.d.ts +6 -0
  106. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +34 -10
  107. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +6 -1
  108. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +6 -1
  109. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.d.ts +6 -3
  110. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +20 -12
  111. package/es/components/Datagrid/Datagrid/addons/Filtering/handleCheckboxChange.js +7 -0
  112. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.d.ts +1 -1
  113. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +54 -17
  114. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +2 -3
  115. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +75 -12
  116. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +10 -2
  117. package/es/components/Datagrid/common-column-ids.d.ts +6 -0
  118. package/es/components/Datagrid/types/index.d.ts +60 -9
  119. package/es/components/Datagrid/useActionsColumn.d.ts +8 -1
  120. package/es/components/Datagrid/useActionsColumn.js +7 -6
  121. package/es/components/Datagrid/useCustomizeColumns.d.ts +8 -1
  122. package/es/components/Datagrid/useCustomizeColumns.js +4 -3
  123. package/es/components/Datagrid/useDatagrid.d.ts +6 -0
  124. package/es/components/Datagrid/useDefaultStringRenderer.js +0 -1
  125. package/es/components/Datagrid/useDisableSelectRows.d.ts +8 -1
  126. package/es/components/Datagrid/useDisableSelectRows.js +27 -22
  127. package/es/components/Datagrid/useInitialColumnSort.js +4 -0
  128. package/es/components/Datagrid/useInlineEdit.js +12 -2
  129. package/es/components/Datagrid/useNestedRowExpander.js +1 -3
  130. package/es/components/Datagrid/useNestedRows.js +5 -4
  131. package/es/components/Datagrid/useRowExpander.js +1 -3
  132. package/es/components/Datagrid/useRowIsMouseOver.d.ts +6 -0
  133. package/es/components/Datagrid/useSelectRows.js +2 -1
  134. package/es/components/Datagrid/useSortableColumns.d.ts +5 -4
  135. package/es/components/Datagrid/useSortableColumns.js +18 -13
  136. package/es/components/Datagrid/useStickyColumn.d.ts +8 -1
  137. package/es/components/Datagrid/useStickyColumn.js +12 -9
  138. package/es/components/EditInPlace/EditInPlace.d.ts +4 -0
  139. package/es/components/EditInPlace/EditInPlace.js +21 -10
  140. package/es/components/EditTearsheet/EditTearsheet.d.ts +7 -2
  141. package/es/components/EditTearsheet/EditTearsheet.js +44 -10
  142. package/es/components/EditTearsheet/EditTearsheetForm.d.ts +45 -2
  143. package/es/components/EditTearsheet/EditTearsheetForm.js +3 -0
  144. package/es/components/EmptyStates/EmptyState.d.ts +72 -5
  145. package/es/components/EmptyStates/EmptyState.js +8 -5
  146. package/es/components/EmptyStates/EmptyStateV2.d.ts +63 -2
  147. package/es/components/EmptyStates/EmptyStateV2.js +3 -2
  148. package/es/components/FullPageError/FullPageError.d.ts +36 -2
  149. package/es/components/FullPageError/FullPageError.js +0 -3
  150. package/es/components/GetStartedCard/GetStartedCard.d.ts +60 -2
  151. package/es/components/GetStartedCard/GetStartedCard.js +11 -10
  152. package/es/components/HTTPErrors/HTTPError403/HTTPError403.js +6 -0
  153. package/es/components/HTTPErrors/HTTPError404/HTTPError404.js +6 -0
  154. package/es/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +6 -0
  155. package/es/components/HTTPErrors/assets/HTTPErrorSvg403.js +204 -200
  156. package/es/components/HTTPErrors/assets/HTTPErrorSvg404.js +116 -112
  157. package/es/components/HTTPErrors/assets/HTTPErrorSvgOther.js +110 -106
  158. package/es/components/Nav/NavItem.js +12 -3
  159. package/es/components/OptionsTile/OptionsTile.js +11 -6
  160. package/es/components/PageHeader/PageHeader.js +1 -0
  161. package/es/components/PageHeader/PageHeaderUtils.js +1 -1
  162. package/es/components/RemoveModal/RemoveModal.d.ts +4 -0
  163. package/es/components/RemoveModal/RemoveModal.js +7 -1
  164. package/es/components/SearchBar/SearchBar.d.ts +1 -1
  165. package/es/components/SearchBar/SearchBar.js +2 -2
  166. package/es/components/SidePanel/SidePanel.js +17 -21
  167. package/es/components/SidePanel/motion/variants.d.ts +4 -6
  168. package/es/components/SidePanel/motion/variants.js +10 -11
  169. package/es/components/StatusIndicator/StatusIndicatorStep.js +87 -0
  170. package/es/components/StringFormatter/StringFormatter.js +14 -3
  171. package/es/components/StringFormatter/utils/enums.d.ts +20 -1
  172. package/es/components/StringFormatter/utils/enums.js +29 -2
  173. package/es/components/TagOverflow/TagOverflow.d.ts +35 -4
  174. package/es/components/TagOverflow/TagOverflow.js +47 -64
  175. package/es/components/TagOverflow/TagOverflowModal.js +4 -6
  176. package/es/components/TagOverflow/TagOverflowPopover.d.ts +13 -1
  177. package/es/components/TagOverflow/TagOverflowPopover.js +38 -41
  178. package/es/components/Tearsheet/Tearsheet.d.ts +8 -1
  179. package/es/components/Tearsheet/Tearsheet.js +9 -1
  180. package/es/components/Tearsheet/TearsheetNarrow.d.ts +11 -0
  181. package/es/components/Tearsheet/TearsheetNarrow.js +12 -0
  182. package/es/components/Tearsheet/TearsheetShell.d.ts +11 -1
  183. package/es/components/Tearsheet/TearsheetShell.js +28 -7
  184. package/es/components/Toolbar/ToolbarButton.js +1 -1
  185. package/es/components/UserAvatar/UserAvatar.d.ts +59 -1
  186. package/es/components/UserAvatar/UserAvatar.js +7 -23
  187. package/es/components/WebTerminal/WebTerminal.js +10 -12
  188. package/es/components/index.d.ts +1 -1
  189. package/es/global/js/hooks/useFocus.d.ts +1 -0
  190. package/es/global/js/hooks/useFocus.js +5 -2
  191. package/es/global/js/hooks/usePrefersReducedMotion.js +14 -8
  192. package/es/global/js/package-settings.d.ts +1 -1
  193. package/es/global/js/package-settings.js +1 -1
  194. package/es/global/js/utils/scrollableAncestor.js +7 -0
  195. package/es/global/js/utils/uuidv4.d.ts +6 -0
  196. package/es/global/js/utils/uuidv4.js +2 -0
  197. package/es/global/js/utils/wait.d.ts +6 -0
  198. package/es/global/js/utils/wait.js +2 -0
  199. package/es/index.js +1 -0
  200. package/es/node_modules/@carbon/icon-helpers/es/index.js +49 -62
  201. package/es/node_modules/@carbon/icons-react/es/generated/bucket-2.js +1020 -1058
  202. package/es/node_modules/@carbon/icons-react/es/generated/bucket-9.js +881 -758
  203. package/es/settings.d.ts +1 -1
  204. package/flags.js +7 -0
  205. package/lib/components/APIKeyModal/APIKeyModal.types.d.ts +6 -0
  206. package/lib/components/ActionBar/ActionBar.d.ts +58 -2
  207. package/lib/components/ActionBar/ActionBar.js +14 -9
  208. package/lib/components/ActionBar/ActionBarItem.d.ts +36 -2
  209. package/lib/components/ActionBar/ActionBarItem.js +7 -4
  210. package/lib/components/ActionBar/ActionBarOverflowItems.d.ts +55 -16
  211. package/lib/components/ActionBar/ActionBarOverflowItems.js +8 -4
  212. package/lib/components/AddSelect/types/index.d.ts +6 -0
  213. package/lib/components/Card/Card.d.ts +68 -2
  214. package/lib/components/Card/Card.js +28 -35
  215. package/lib/components/Card/CardFooter.d.ts +51 -48
  216. package/lib/components/Card/CardFooter.js +4 -2
  217. package/lib/components/Card/CardHeader.d.ts +67 -49
  218. package/lib/components/Card/CardHeader.js +4 -2
  219. package/lib/components/Coachmark/Coachmark.d.ts +6 -1
  220. package/lib/components/Coachmark/Coachmark.js +46 -10
  221. package/lib/components/Coachmark/CoachmarkOverlay.js +2 -4
  222. package/lib/components/Coachmark/utils/enums.d.ts +6 -0
  223. package/lib/components/CoachmarkBeacon/CoachmarkBeacon.js +1 -7
  224. package/lib/components/CoachmarkFixed/CoachmarkFixed.js +13 -11
  225. package/lib/components/CoachmarkOverlayElements/CoachmarkOverlayElements.js +2 -1
  226. package/lib/components/CoachmarkStack/CoachmarkStack.d.ts +67 -2
  227. package/lib/components/CoachmarkStack/CoachmarkStack.js +22 -11
  228. package/lib/components/CoachmarkStack/CoachmarkStackHome.d.ts +71 -2
  229. package/lib/components/CoachmarkStack/CoachmarkStackHome.js +25 -23
  230. package/lib/components/ConditionBuilder/ConditionBlock/ConditionBlock.js +98 -56
  231. package/lib/components/ConditionBuilder/ConditionBuilder.js +82 -25
  232. package/lib/components/ConditionBuilder/ConditionBuilderActions/ConditionBuilderActions.d.ts +15 -0
  233. package/lib/components/ConditionBuilder/ConditionBuilderActions/ConditionBuilderActions.js +163 -0
  234. package/lib/components/ConditionBuilder/ConditionBuilderAdd/ConditionBuilderAdd.d.ts +3 -1
  235. package/lib/components/ConditionBuilder/ConditionBuilderAdd/ConditionBuilderAdd.js +29 -25
  236. package/lib/components/ConditionBuilder/ConditionBuilderButton/ConditionBuilderButton.d.ts +8 -1
  237. package/lib/components/ConditionBuilder/ConditionBuilderButton/ConditionBuilderButton.js +33 -9
  238. package/lib/components/ConditionBuilder/ConditionBuilderConnector/ConditionConnector.js +16 -8
  239. package/lib/components/ConditionBuilder/ConditionBuilderConnector/GroupConnector.js +18 -10
  240. package/lib/components/ConditionBuilder/ConditionBuilderContent/ConditionBuilderContent.d.ts +9 -13
  241. package/lib/components/ConditionBuilder/ConditionBuilderContent/ConditionBuilderContent.js +81 -62
  242. package/lib/components/ConditionBuilder/ConditionBuilderContext/ConditionBuilderProvider.d.ts +13 -7
  243. package/lib/components/ConditionBuilder/ConditionBuilderContext/ConditionBuilderProvider.js +31 -8
  244. package/lib/components/ConditionBuilder/ConditionBuilderContext/DataConfigs.d.ts +8 -2
  245. package/lib/components/ConditionBuilder/ConditionBuilderContext/DataConfigs.js +34 -24
  246. package/lib/components/ConditionBuilder/ConditionBuilderContext/translationObject.d.ts +43 -36
  247. package/lib/components/ConditionBuilder/ConditionBuilderContext/translationObject.js +43 -36
  248. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItem.d.ts +6 -2
  249. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItem.js +112 -38
  250. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemDate/ConditionBuilderItemDate.d.ts +3 -1
  251. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemDate/ConditionBuilderItemDate.js +24 -9
  252. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemNumber/ConditionBuilderItemNumber.js +28 -10
  253. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/ItemOption.d.ts +13 -0
  254. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/ItemOption.js +122 -0
  255. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/{ConditionBuilderItemOption.d.ts → ItemOptionForValueField.d.ts} +2 -2
  256. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemOption/{ConditionBuilderItemOption.js → ItemOptionForValueField.js} +68 -35
  257. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemText/ConditionBuilderItemText.d.ts +5 -1
  258. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemText/ConditionBuilderItemText.js +21 -8
  259. package/lib/components/ConditionBuilder/ConditionBuilderItem/ConditionBuilderItemTime/ConditionBuilderItemTime.js +1 -1
  260. package/lib/components/ConditionBuilder/ConditionGroupBuilder/ConditionGroupBuilder.d.ts +1 -3
  261. package/lib/components/ConditionBuilder/ConditionGroupBuilder/ConditionGroupBuilder.js +119 -37
  262. package/lib/components/ConditionBuilder/ConditionPreview/ConditionPreview.d.ts +5 -1
  263. package/lib/components/ConditionBuilder/ConditionPreview/ConditionPreview.js +50 -17
  264. package/lib/components/ConditionBuilder/utils/handleKeyboardEvents.d.ts +2 -1
  265. package/lib/components/ConditionBuilder/utils/handleKeyboardEvents.js +152 -41
  266. package/lib/components/ConditionBuilder/utils/useTranslations.d.ts +1 -0
  267. package/lib/components/ConditionBuilder/utils/useTranslations.js +30 -0
  268. package/lib/components/ConditionBuilder/utils/util.d.ts +6 -4
  269. package/lib/components/ConditionBuilder/utils/util.js +44 -16
  270. package/lib/components/CreateFullPage/CreateFullPage.js +2 -2
  271. package/lib/components/DataSpreadsheet/DataSpreadsheet.d.ts +26 -0
  272. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +129 -53
  273. package/lib/components/DataSpreadsheet/DataSpreadsheetBody.d.ts +16 -0
  274. package/lib/components/DataSpreadsheet/DataSpreadsheetBody.js +32 -7
  275. package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.d.ts +8 -0
  276. package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.js +16 -3
  277. package/lib/components/DataSpreadsheet/types/index.d.ts +7 -0
  278. package/lib/components/Datagrid/Datagrid/Datagrid.d.ts +0 -4
  279. package/lib/components/Datagrid/Datagrid/Datagrid.js +4 -9
  280. package/lib/components/Datagrid/Datagrid/DatagridBody.d.ts +6 -0
  281. package/lib/components/Datagrid/Datagrid/DatagridContent.js +4 -3
  282. package/lib/components/Datagrid/Datagrid/DatagridHeaderRow.js +23 -8
  283. package/lib/components/Datagrid/Datagrid/DatagridRefBody.d.ts +6 -0
  284. package/lib/components/Datagrid/Datagrid/DatagridRow.js +21 -8
  285. package/lib/components/Datagrid/Datagrid/DatagridSelectAll.js +6 -6
  286. package/lib/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +3 -2
  287. package/lib/components/Datagrid/Datagrid/DatagridSimpleBody.d.ts +6 -0
  288. package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +3 -1
  289. package/lib/components/Datagrid/Datagrid/DraggableElement.d.ts +6 -0
  290. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +34 -10
  291. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +6 -1
  292. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +6 -1
  293. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.d.ts +6 -3
  294. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +20 -12
  295. package/lib/components/Datagrid/Datagrid/addons/Filtering/handleCheckboxChange.js +7 -0
  296. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.d.ts +1 -1
  297. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +53 -16
  298. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +2 -3
  299. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +74 -11
  300. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +10 -2
  301. package/lib/components/Datagrid/common-column-ids.d.ts +6 -0
  302. package/lib/components/Datagrid/types/index.d.ts +60 -9
  303. package/lib/components/Datagrid/useActionsColumn.d.ts +8 -1
  304. package/lib/components/Datagrid/useActionsColumn.js +7 -6
  305. package/lib/components/Datagrid/useCustomizeColumns.d.ts +8 -1
  306. package/lib/components/Datagrid/useCustomizeColumns.js +4 -3
  307. package/lib/components/Datagrid/useDatagrid.d.ts +6 -0
  308. package/lib/components/Datagrid/useDefaultStringRenderer.js +0 -1
  309. package/lib/components/Datagrid/useDisableSelectRows.d.ts +8 -1
  310. package/lib/components/Datagrid/useDisableSelectRows.js +27 -22
  311. package/lib/components/Datagrid/useInitialColumnSort.js +4 -0
  312. package/lib/components/Datagrid/useInlineEdit.js +12 -2
  313. package/lib/components/Datagrid/useNestedRowExpander.js +1 -3
  314. package/lib/components/Datagrid/useNestedRows.js +5 -4
  315. package/lib/components/Datagrid/useRowExpander.js +1 -3
  316. package/lib/components/Datagrid/useRowIsMouseOver.d.ts +6 -0
  317. package/lib/components/Datagrid/useSelectRows.js +2 -1
  318. package/lib/components/Datagrid/useSortableColumns.d.ts +5 -4
  319. package/lib/components/Datagrid/useSortableColumns.js +18 -13
  320. package/lib/components/Datagrid/useStickyColumn.d.ts +8 -1
  321. package/lib/components/Datagrid/useStickyColumn.js +12 -9
  322. package/lib/components/EditInPlace/EditInPlace.d.ts +4 -0
  323. package/lib/components/EditInPlace/EditInPlace.js +21 -10
  324. package/lib/components/EditTearsheet/EditTearsheet.d.ts +7 -2
  325. package/lib/components/EditTearsheet/EditTearsheet.js +43 -9
  326. package/lib/components/EditTearsheet/EditTearsheetForm.d.ts +45 -2
  327. package/lib/components/EditTearsheet/EditTearsheetForm.js +3 -0
  328. package/lib/components/EmptyStates/EmptyState.d.ts +72 -5
  329. package/lib/components/EmptyStates/EmptyState.js +8 -5
  330. package/lib/components/EmptyStates/EmptyStateV2.d.ts +63 -2
  331. package/lib/components/EmptyStates/EmptyStateV2.js +3 -2
  332. package/lib/components/FullPageError/FullPageError.d.ts +36 -2
  333. package/lib/components/FullPageError/FullPageError.js +0 -3
  334. package/lib/components/GetStartedCard/GetStartedCard.d.ts +60 -2
  335. package/lib/components/GetStartedCard/GetStartedCard.js +10 -9
  336. package/lib/components/HTTPErrors/HTTPError403/HTTPError403.js +6 -0
  337. package/lib/components/HTTPErrors/HTTPError404/HTTPError404.js +6 -0
  338. package/lib/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +6 -0
  339. package/lib/components/HTTPErrors/assets/HTTPErrorSvg403.js +204 -200
  340. package/lib/components/HTTPErrors/assets/HTTPErrorSvg404.js +116 -112
  341. package/lib/components/HTTPErrors/assets/HTTPErrorSvgOther.js +110 -106
  342. package/lib/components/Nav/NavItem.js +10 -1
  343. package/lib/components/OptionsTile/OptionsTile.js +11 -6
  344. package/lib/components/PageHeader/PageHeader.js +1 -0
  345. package/lib/components/PageHeader/PageHeaderUtils.js +1 -1
  346. package/lib/components/RemoveModal/RemoveModal.d.ts +4 -0
  347. package/lib/components/RemoveModal/RemoveModal.js +7 -1
  348. package/lib/components/SearchBar/SearchBar.d.ts +1 -1
  349. package/lib/components/SearchBar/SearchBar.js +2 -2
  350. package/lib/components/SidePanel/SidePanel.js +16 -20
  351. package/lib/components/SidePanel/motion/variants.d.ts +4 -6
  352. package/lib/components/SidePanel/motion/variants.js +10 -11
  353. package/lib/components/StatusIndicator/StatusIndicatorStep.js +94 -0
  354. package/lib/components/StringFormatter/StringFormatter.js +13 -2
  355. package/lib/components/StringFormatter/utils/enums.d.ts +20 -1
  356. package/lib/components/StringFormatter/utils/enums.js +30 -1
  357. package/lib/components/TagOverflow/TagOverflow.d.ts +35 -4
  358. package/lib/components/TagOverflow/TagOverflow.js +46 -63
  359. package/lib/components/TagOverflow/TagOverflowModal.js +4 -6
  360. package/lib/components/TagOverflow/TagOverflowPopover.d.ts +13 -1
  361. package/lib/components/TagOverflow/TagOverflowPopover.js +37 -40
  362. package/lib/components/Tearsheet/Tearsheet.d.ts +8 -1
  363. package/lib/components/Tearsheet/Tearsheet.js +9 -1
  364. package/lib/components/Tearsheet/TearsheetNarrow.d.ts +11 -0
  365. package/lib/components/Tearsheet/TearsheetNarrow.js +12 -0
  366. package/lib/components/Tearsheet/TearsheetShell.d.ts +11 -1
  367. package/lib/components/Tearsheet/TearsheetShell.js +26 -5
  368. package/lib/components/Toolbar/ToolbarButton.js +1 -1
  369. package/lib/components/UserAvatar/UserAvatar.d.ts +59 -1
  370. package/lib/components/UserAvatar/UserAvatar.js +7 -23
  371. package/lib/components/WebTerminal/WebTerminal.js +10 -12
  372. package/lib/components/index.d.ts +1 -1
  373. package/lib/global/js/hooks/useFocus.d.ts +1 -0
  374. package/lib/global/js/hooks/useFocus.js +5 -1
  375. package/lib/global/js/hooks/usePrefersReducedMotion.js +13 -7
  376. package/lib/global/js/package-settings.d.ts +1 -1
  377. package/lib/global/js/package-settings.js +1 -1
  378. package/lib/global/js/utils/scrollableAncestor.js +7 -0
  379. package/lib/global/js/utils/uuidv4.d.ts +6 -0
  380. package/lib/global/js/utils/uuidv4.js +2 -0
  381. package/lib/global/js/utils/wait.d.ts +6 -0
  382. package/lib/global/js/utils/wait.js +2 -0
  383. package/lib/index.js +5 -0
  384. package/lib/node_modules/@carbon/icon-helpers/es/index.js +49 -62
  385. package/lib/node_modules/@carbon/icons-react/es/generated/bucket-2.js +1036 -1074
  386. package/lib/node_modules/@carbon/icons-react/es/generated/bucket-9.js +946 -823
  387. package/lib/settings.d.ts +1 -1
  388. package/package.json +8 -7
  389. package/scss/components/Coachmark/_coachmark-overlay.scss +6 -70
  390. package/scss/components/Coachmark/_coachmark.scss +5 -4
  391. package/scss/components/CoachmarkBeacon/_coachmark-beacon.scss +1 -3
  392. package/scss/components/ConditionBuilder/_condition-builder.scss +8 -1
  393. package/scss/components/ConditionBuilder/styles/_conditionBuilderCondition.scss +30 -5
  394. package/scss/components/ConditionBuilder/styles/_conditionBuilderItem.scss +88 -22
  395. package/scss/components/ConditionBuilder/styles/_index.scss +7 -0
  396. package/scss/components/CreateModal/_create-modal.scss +0 -4
  397. package/scss/components/DataSpreadsheet/_data-spreadsheet.scss +16 -2
  398. package/scss/components/Datagrid/_datagrid.scss +0 -4
  399. package/scss/components/Datagrid/styles/_datagrid.scss +1 -0
  400. package/scss/components/Datagrid/styles/_useActionsColumn.scss +6 -7
  401. package/scss/components/Datagrid/styles/_useColumnRightAlign.scss +6 -7
  402. package/scss/components/Datagrid/styles/_useExpandedRow.scss +6 -7
  403. package/scss/components/Datagrid/styles/_useInlineEdit.scss +19 -7
  404. package/scss/components/Datagrid/styles/_useNestedRows.scss +6 -7
  405. package/scss/components/Datagrid/styles/_useNestedTable.scss +6 -7
  406. package/scss/components/Datagrid/styles/_useStickyColumn.scss +6 -7
  407. package/scss/components/Datagrid/styles/addons/_CustomizeColumnsTearsheet.scss +7 -5
  408. package/scss/components/Datagrid/styles/addons/_FilterFlyout.scss +5 -4
  409. package/scss/components/Datagrid/styles/addons/_RowSizeDropdown.scss +6 -7
  410. package/scss/components/HTTPErrors/_http-errors.scss +77 -0
  411. package/scss/components/OptionsTile/_options-tile.scss +6 -6
  412. package/scss/components/SidePanel/_side-panel.scss +1 -1
  413. package/scss/components/_index-released-only.scss +1 -0
  414. package/scss/config-dev.scss +7 -0
  415. package/scss/config.scss +7 -0
  416. package/telemetry.yml +34 -19
  417. package/es/components/ConditionBuilder/utils/checkForHoldingKey.d.ts +0 -1
  418. package/es/components/ConditionBuilder/utils/checkForHoldingKey.js +0 -16
  419. package/es/global/js/utils/window.d.ts +0 -2
  420. package/es/global/js/utils/window.js +0 -12
  421. package/lib/components/ConditionBuilder/utils/checkForHoldingKey.d.ts +0 -1
  422. package/lib/components/ConditionBuilder/utils/checkForHoldingKey.js +0 -20
  423. package/lib/global/js/utils/window.d.ts +0 -2
  424. package/lib/global/js/utils/window.js +0 -16
@@ -5,7 +5,7 @@
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
7
 
8
- import { slicedToArray as _slicedToArray, extends as _extends, objectSpread2 as _objectSpread2, defineProperty as _defineProperty, toConsumableArray as _toConsumableArray } from '../../../../../../_virtual/_rollupPluginBabelHelpers.js';
8
+ import { slicedToArray as _slicedToArray, toConsumableArray as _toConsumableArray, extends as _extends, objectSpread2 as _objectSpread2, defineProperty as _defineProperty } from '../../../../../../_virtual/_rollupPluginBabelHelpers.js';
9
9
  import { MULTISELECT, DROPDOWN, RADIO, CHECKBOX, NUMBER, DATE, BATCH, SAVED_FILTERS, INSTANT, PANEL } from '../constants.js';
10
10
  import { MultiSelect, Dropdown, FormGroup, RadioButtonGroup, RadioButton, NumberInput, DatePicker, DatePickerInput, Layer, Checkbox } from '@carbon/react';
11
11
  import React__default, { useContext, useState, useRef, useCallback, useEffect } from 'react';
@@ -13,6 +13,7 @@ import OverflowCheckboxes from '../OverflowCheckboxes.js';
13
13
  import { getInitialStateFromFilters } from '../utils.js';
14
14
  import { FilterContext } from '../FilterProvider.js';
15
15
  import { handleCheckboxChange } from '../handleCheckboxChange.js';
16
+ import uuidv4 from '../../../../../../global/js/utils/uuidv4.js';
16
17
  import { usePreviousValue } from '../../../../../../global/js/hooks/usePreviousValue.js';
17
18
 
18
19
  var useFilters = function useFilters(_ref) {
@@ -28,7 +29,8 @@ var useFilters = function useFilters(_ref) {
28
29
  isFetching = _ref.isFetching;
29
30
  var _useContext = useContext(FilterContext),
30
31
  state = _useContext.state,
31
- localDispatch = _useContext.dispatch;
32
+ localDispatch = _useContext.dispatch,
33
+ contextTableId = _useContext.tableId;
32
34
  var savedFilters = state.savedFilters;
33
35
  /** State */
34
36
  var _useState = useState(getInitialStateFromFilters(filters, variation, reactTableFiltersState)),
@@ -46,6 +48,7 @@ var useFilters = function useFilters(_ref) {
46
48
  var previousState = usePreviousValue({
47
49
  panelOpen: panelOpen
48
50
  });
51
+ var filteredItemsRef = useRef();
49
52
 
50
53
  // When using batch actions we have to store the filters to then apply them later
51
54
  var prevFiltersRef = useRef(JSON.stringify(filtersState));
@@ -69,24 +72,28 @@ var useFilters = function useFilters(_ref) {
69
72
  holdingLastAppliedFiltersRef.current = JSON.parse(prevFiltersObjectArrayRef.current);
70
73
  holdingPrevFiltersObjectArrayRef.current = JSON.parse(lastAppliedFilters.current);
71
74
  }, [setAllFilters]);
72
- var reset = useCallback(function () {
73
- // When we reset we want the "initialFilters" to be an empty array
74
- var resetFiltersArray = [];
75
+ var reset = useCallback(function (tableId) {
76
+ // only reset filters if tableid of the datagrid that triggered "clear filters"
77
+ // matches the table id stored in its context instance
78
+ if (tableId === contextTableId) {
79
+ // When we reset we want the "initialFilters" to be an empty array
80
+ var resetFiltersArray = [];
75
81
 
76
- // Get the initial values for the filters
77
- var initialFiltersState = getInitialStateFromFilters(filters, variation, resetFiltersArray);
78
- var initialFiltersObjectArray = [];
82
+ // Get the initial values for the filters
83
+ var initialFiltersState = getInitialStateFromFilters(filters, variation, resetFiltersArray);
84
+ var initialFiltersObjectArray = [];
79
85
 
80
- // Set the state to the initial values
81
- setFiltersState(initialFiltersState);
82
- setFiltersObjectArray(initialFiltersObjectArray);
83
- setAllFilters([]);
86
+ // Set the state to the initial values
87
+ setFiltersState(initialFiltersState);
88
+ setFiltersObjectArray(initialFiltersObjectArray);
89
+ setAllFilters([]);
84
90
 
85
- // Update their respective refs so everything is in sync
86
- prevFiltersRef.current = JSON.stringify(initialFiltersState);
87
- prevFiltersObjectArrayRef.current = JSON.stringify(initialFiltersObjectArray);
88
- lastAppliedFilters.current = JSON.stringify([]);
89
- }, [filters, setAllFilters, variation]);
91
+ // Update their respective refs so everything is in sync
92
+ prevFiltersRef.current = JSON.stringify(initialFiltersState);
93
+ prevFiltersObjectArrayRef.current = JSON.stringify(initialFiltersObjectArray);
94
+ lastAppliedFilters.current = JSON.stringify([]);
95
+ }
96
+ }, [filters, setAllFilters, variation, contextTableId]);
90
97
  var applyFilters = function applyFilters(_ref2) {
91
98
  var column = _ref2.column,
92
99
  value = _ref2.value,
@@ -302,8 +309,18 @@ var useFilters = function useFilters(_ref) {
302
309
  }
303
310
  return null;
304
311
  }).filter(Boolean);
312
+ var isEqual = compareFilterItems(filteredItems);
313
+ if (!isEqual) {
314
+ filteredItemsRef.current = _toConsumableArray(filteredItems);
315
+ }
316
+ var getKey = function getKey() {
317
+ return isEqual ? {
318
+ key: uuidv4()
319
+ } : column;
320
+ };
305
321
  filter = /*#__PURE__*/React__default.createElement(MultiSelect, _extends({}, components.MultiSelect, {
306
322
  selectedItems: filteredItems,
323
+ key: getKey(),
307
324
  onChange: function onChange(_ref9) {
308
325
  var _components$MultiSele, _components$MultiSele2;
309
326
  var selectedItems = _ref9.selectedItems;
@@ -319,6 +336,7 @@ var useFilters = function useFilters(_ref) {
319
336
  }
320
337
  return null;
321
338
  }).filter(Boolean);
339
+ filteredItemsRef.current = _toConsumableArray(foundItems);
322
340
 
323
341
  // Change selected state for those items that have been selected
324
342
  allOptions.map(function (a) {
@@ -361,6 +379,25 @@ var useFilters = function useFilters(_ref) {
361
379
  key: column
362
380
  }, filter);
363
381
  };
382
+ var compareFilterItems = function compareFilterItems(filteredItems) {
383
+ var _filteredItems$map, _filteredItemsRef$cur, _filteredItemsRef$cur2;
384
+ var filteredItemsId = (_filteredItems$map = filteredItems.map(function (item) {
385
+ return item.id;
386
+ })) !== null && _filteredItems$map !== void 0 ? _filteredItems$map : [];
387
+ var previousFilteredItemsId = (_filteredItemsRef$cur = filteredItemsRef === null || filteredItemsRef === void 0 || (_filteredItemsRef$cur2 = filteredItemsRef.current) === null || _filteredItemsRef$cur2 === void 0 ? void 0 : _filteredItemsRef$cur2.map(function (item) {
388
+ return item.id;
389
+ })) !== null && _filteredItemsRef$cur !== void 0 ? _filteredItemsRef$cur : [];
390
+ var set1 = new Set(filteredItemsId);
391
+ var set2 = new Set(previousFilteredItemsId);
392
+ // Check if the sets have the same size (same number of unique elements)
393
+ if (set1.size !== set2.size) {
394
+ return false;
395
+ }
396
+ // Check if all elements in set1 are also present in set2 (using spread syntax)
397
+ return _toConsumableArray(set1).every(function (element) {
398
+ return set2.has(element);
399
+ });
400
+ };
364
401
 
365
402
  /** This useEffect will properly handle the previous filters when the panel closes
366
403
  * 1. If the panel closes we need to call the reset fn but also store the
@@ -27,8 +27,7 @@ var InlineEditButton = function InlineEditButton(_ref) {
27
27
  tabIndex: isActiveCell ? 0 : -1,
28
28
  "data-disabled": disabledCell,
29
29
  "aria-disabled": disabledCell,
30
- role: "button",
31
- title: label
30
+ role: "button"
32
31
  }, LabelIcon && /*#__PURE__*/React__default.createElement("div", {
33
32
  className: "".concat(blockClass, "__label-icon")
34
33
  }, /*#__PURE__*/React__default.createElement(LabelIcon, null)), label !== '' ? /*#__PURE__*/React__default.createElement("span", {
@@ -48,7 +47,7 @@ InlineEditButton.propTypes = {
48
47
  nonEditCell: PropTypes.bool,
49
48
  placeholder: PropTypes.string,
50
49
  renderIcon: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),
51
- type: PropTypes.oneOf(['text', 'number', 'selection', 'date']),
50
+ type: PropTypes.oneOf(['text', 'number', 'selection', 'date', 'checkbox']),
52
51
  value: PropTypes.oneOfType([PropTypes.string, PropTypes.node])
53
52
  };
54
53
 
@@ -8,7 +8,7 @@
8
8
  import { slicedToArray as _slicedToArray, objectSpread2 as _objectSpread2, defineProperty as _defineProperty, extends as _extends, typeof as _typeof } from '../../../../../../_virtual/_rollupPluginBabelHelpers.js';
9
9
  import React__default, { useContext, useState, useRef, useEffect, useCallback } from 'react';
10
10
  import PropTypes from '../../../../../../node_modules/prop-types/index.js';
11
- import { Dropdown, DatePicker, DatePickerInput, NumberInput, TextInput } from '@carbon/react';
11
+ import { Dropdown, DatePicker, DatePickerInput, NumberInput, Checkbox, TextInput } from '@carbon/react';
12
12
  import { Edit, CaretSort, ChevronDown, Calendar } from '@carbon/react/icons';
13
13
  import { pkg } from '../../../../../../settings.js';
14
14
  import cx from 'classnames';
@@ -19,7 +19,7 @@ import { InlineEditButton } from '../InlineEditButton/InlineEditButton.js';
19
19
 
20
20
  var blockClass = "".concat(pkg.prefix, "--datagrid");
21
21
  var InlineEditCell = function InlineEditCell(_ref) {
22
- var _config$validator, _value$text;
22
+ var _config$validator;
23
23
  var cell = _ref.cell,
24
24
  config = _ref.config,
25
25
  _ref$disabledCell = _ref.disabledCell,
@@ -66,6 +66,7 @@ var InlineEditCell = function InlineEditCell(_ref) {
66
66
  var _ref2 = config || {},
67
67
  inputProps = _ref2.inputProps;
68
68
  var textInputRef = useRef();
69
+ var checkboxRef = useRef();
69
70
  var numberInputRef = useRef();
70
71
  var dropdownRef = useRef();
71
72
  var datePickerRef = useRef();
@@ -202,16 +203,42 @@ var InlineEditCell = function InlineEditCell(_ref) {
202
203
  };
203
204
  var getNewCellId = function getNewCellId(key) {
204
205
  var totalRows = instance.rows.length;
205
- var newCellId = key === 'Enter' ? "column-".concat(columnIndex, "-row-").concat(cell.row.index < totalRows - 1 ? cell.row.index + 1 : cell.row.index) : "column-".concat(columnIndex < instance.columns.length - 1 ? columnIndex + 1 : columnIndex, "-row-").concat(cell.row.index);
206
+ var newCellId = key === 'Enter' ? "column-".concat(columnIndex, "-row-").concat(cell.row.index < totalRows - 1 && type === 'checkbox' ? cell.row.index + 1 : cell.row.index) : "column-".concat(columnIndex < instance.columns.length - 1 ? columnIndex + 1 : columnIndex, "-row-").concat(cell.row.index);
206
207
  return newCellId;
207
208
  };
208
209
  var handleKeyDown = function handleKeyDown(event) {
209
210
  var key = event.key;
210
211
  switch (key) {
212
+ case 'ArrowRight':
213
+ case 'ArrowLeft':
214
+ case 'ArrowUp':
215
+ case 'ArrowDown':
216
+ if (inEditMode && event.target.type === 'checkbox') {
217
+ var newCellId = getNewCellId(key);
218
+ saveCellData(cellValue);
219
+ setInitialValue(cellValue);
220
+ dispatch({
221
+ type: 'EXIT_EDIT_MODE',
222
+ payload: newCellId
223
+ });
224
+ setInEditMode(false);
225
+ sendFocusBackToGrid();
226
+ }
227
+ break;
211
228
  // Save cell contents to data
212
229
  case 'Tab':
213
230
  case 'Enter':
214
231
  {
232
+ if (type === 'checkbox') {
233
+ // Since checkbox doesn't need to click into it to enter `inEditMode` we don't need to check for it
234
+ var _newCellId = getNewCellId(key);
235
+ dispatch({
236
+ type: 'EXIT_EDIT_MODE',
237
+ payload: _newCellId
238
+ });
239
+ setInEditMode(false);
240
+ sendFocusBackToGrid();
241
+ }
215
242
  if (inEditMode) {
216
243
  // Dropdown saves are handled in the Dropdown's/DatePicker's onChange prop
217
244
  if (type === 'selection' || type === 'date') {
@@ -225,12 +252,12 @@ var InlineEditCell = function InlineEditCell(_ref) {
225
252
  if (isInvalid) {
226
253
  return;
227
254
  }
228
- var newCellId = getNewCellId(key);
255
+ var _newCellId2 = getNewCellId(key);
229
256
  saveCellData(cellValue);
230
257
  setInitialValue(cellValue);
231
258
  dispatch({
232
259
  type: 'EXIT_EDIT_MODE',
233
- payload: newCellId
260
+ payload: _newCellId2
234
261
  });
235
262
  setInEditMode(false);
236
263
  sendFocusBackToGrid();
@@ -425,9 +452,27 @@ var InlineEditCell = function InlineEditCell(_ref) {
425
452
  ref: numberInputRef
426
453
  }));
427
454
  };
455
+ var renderCheckBoxCell = function renderCheckBoxCell() {
456
+ return /*#__PURE__*/React__default.createElement(Checkbox, _extends({
457
+ labelText: cellLabel || 'Checkbox'
458
+ }, inputProps, {
459
+ className: cx("".concat(blockClass, "__inline-edit--outer-cell-checkbox"), _defineProperty({}, "".concat(blockClass, "__inline-edit--outer-cell-checkbox-focus"), activeCellId === cellId)),
460
+ id: cellId,
461
+ hideLabel: true,
462
+ checked: cellValue,
463
+ onChange: function onChange(event, _ref10) {
464
+ var checked = _ref10.checked;
465
+ setCellValue(checked);
466
+ if (inputProps.onChange) {
467
+ inputProps.onChange(checked);
468
+ }
469
+ },
470
+ ref: checkboxRef
471
+ }));
472
+ };
428
473
  var renderTextInput = function renderTextInput() {
429
- var _ref10 = config || {},
430
- validator = _ref10.validator;
474
+ var _ref11 = config || {},
475
+ validator = _ref11.validator;
431
476
  var isInvalid = validator === null || validator === void 0 ? void 0 : validator(cellValue);
432
477
  return /*#__PURE__*/React__default.createElement(TextInput, _extends({
433
478
  labelText: cellLabel,
@@ -447,6 +492,24 @@ var InlineEditCell = function InlineEditCell(_ref) {
447
492
  ref: textInputRef
448
493
  }));
449
494
  };
495
+ var getLabel = function getLabel() {
496
+ var _value$text, _checkStaticCell;
497
+ var checkStaticCell = function checkStaticCell(val) {
498
+ if (_typeof(val) === 'object' && val !== null && val !== void 0 && val.isStaticCell) {
499
+ return val === null || val === void 0 ? void 0 : val.value;
500
+ }
501
+ };
502
+ switch (type) {
503
+ case 'selection':
504
+ checkStaticCell(value);
505
+ return (_value$text = value === null || value === void 0 ? void 0 : value.text) !== null && _value$text !== void 0 ? _value$text : value;
506
+ case 'date':
507
+ checkStaticCell(value);
508
+ return buildDate(value);
509
+ default:
510
+ return (_checkStaticCell = checkStaticCell(value)) !== null && _checkStaticCell !== void 0 ? _checkStaticCell : value;
511
+ }
512
+ };
450
513
  return (
451
514
  /*#__PURE__*/
452
515
  // eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions
@@ -455,15 +518,15 @@ var InlineEditCell = function InlineEditCell(_ref) {
455
518
  "data-cell-id": cellId,
456
519
  "data-column-index": columnIndex,
457
520
  "data-row-index": cell.row.index,
458
- "data-disabled": disabledCell,
521
+ "data-disabled": disabledCell || nonEditCell,
459
522
  "data-inline-type": type,
460
523
  onClick: !nonEditCell ? handleInlineCellClick : addActiveState,
461
524
  onKeyDown: !nonEditCell ? handleKeyDown : null,
462
525
  className: cx("".concat(blockClass, "__inline-edit--outer-cell-button"), _defineProperty(_defineProperty(_defineProperty(_defineProperty({}, "".concat(blockClass, "__inline-edit--outer-cell-button--").concat(rowSize), rowSize), "".concat(blockClass, "__inline-edit--outer-cell-button--lg"), !rowSize), "".concat(blockClass, "__inline-edit--outer-cell-button--invalid"), inEditMode && (config === null || config === void 0 || (_config$validator = config.validator) === null || _config$validator === void 0 ? void 0 : _config$validator.call(config, cellValue))), "".concat(blockClass, "__static--outer-cell"), !disabledCell))
463
- }, !nonEditCell && !disabledCell && renderRegularCell(), (!inEditMode || disabledCell) && /*#__PURE__*/React__default.createElement(InlineEditButton, {
526
+ }, !nonEditCell && !disabledCell && type !== 'checkbox' && renderRegularCell(), (!inEditMode || disabledCell) && type !== 'checkbox' && /*#__PURE__*/React__default.createElement(InlineEditButton, {
464
527
  isActiveCell: cellId === activeCellId,
465
528
  renderIcon: setRenderIcon(),
466
- label: type === 'selection' ? (_value$text = value === null || value === void 0 ? void 0 : value.text) !== null && _value$text !== void 0 ? _value$text : value : type === 'date' ? buildDate(value) : value,
529
+ label: getLabel(),
467
530
  disabledCell: disabledCell,
468
531
  labelIcon: (value === null || value === void 0 ? void 0 : value.icon) || null,
469
532
  placeholder: placeholder,
@@ -471,7 +534,7 @@ var InlineEditCell = function InlineEditCell(_ref) {
471
534
  nonEditCell: nonEditCell,
472
535
  columnConfig: cell.column,
473
536
  type: type
474
- }), !nonEditCell && inEditMode && cellId === activeCellId && /*#__PURE__*/React__default.createElement(React__default.Fragment, null, type === 'text' && renderTextInput(), type === 'number' && renderNumberInput(), type === 'selection' && renderSelectCell(), type === 'date' && renderDateCell()))
537
+ }), type === 'checkbox' && renderCheckBoxCell(), !nonEditCell && inEditMode && cellId === activeCellId && /*#__PURE__*/React__default.createElement(React__default.Fragment, null, type === 'text' && renderTextInput(), type === 'number' && renderNumberInput(), type === 'selection' && renderSelectCell(), type === 'date' && renderDateCell()))
475
538
  );
476
539
  };
477
540
  InlineEditCell.propTypes = {
@@ -489,7 +552,7 @@ InlineEditCell.propTypes = {
489
552
  nonEditCell: PropTypes.bool,
490
553
  placeholder: PropTypes.string,
491
554
  tabIndex: PropTypes.number,
492
- type: PropTypes.oneOf(['text', 'number', 'selection', 'date']),
555
+ type: PropTypes.oneOf(['text', 'number', 'selection', 'date', 'checkbox']),
493
556
  value: PropTypes.oneOfType([PropTypes.string, PropTypes.node, PropTypes.object])
494
557
  };
495
558
 
@@ -74,7 +74,7 @@ var handleGridKeyPress = function handleGridKeyPress(_ref) {
74
74
  };
75
75
 
76
76
  // Stop grid key listener when in edit mode
77
- var isEditing = document.activeElement.id === activeCellId && document.activeElement.id === editId || dropdownIsActive() || datePickerIsActive();
77
+ var isEditing = focusedCell.getAttribute('data-inline-type') !== 'checkbox' && document.activeElement.id === activeCellId && document.activeElement.id === editId || dropdownIsActive() || datePickerIsActive();
78
78
  if (isEditing || !gridActive) {
79
79
  return;
80
80
  }
@@ -87,6 +87,7 @@ var handleGridKeyPress = function handleGridKeyPress(_ref) {
87
87
  event.preventDefault();
88
88
  }
89
89
  var isDisabledCell = focusedCell.getAttribute('data-disabled') === 'false' ? false : true;
90
+ var isEditableCell = !event.target.classList.contains("".concat(blockClass, "__inline-edit-button--non-edit"));
90
91
  var sharedUpdateParams = {
91
92
  oldId: activeCellId,
92
93
  instance: instance
@@ -194,7 +195,7 @@ var handleGridKeyPress = function handleGridKeyPress(_ref) {
194
195
  case 'Enter':
195
196
  {
196
197
  // Disabled cells are not allowed to go into edit mode
197
- if (isDisabledCell) {
198
+ if (isDisabledCell || !isEditableCell) {
198
199
  return;
199
200
  }
200
201
  // Only go into edit mode if there is no editId, meaning that we're not already in edit mode
@@ -207,6 +208,13 @@ var handleGridKeyPress = function handleGridKeyPress(_ref) {
207
208
  dropdownTrigger === null || dropdownTrigger === void 0 || dropdownTrigger.click();
208
209
  }, 1);
209
210
  }
211
+ if (focusedType === 'checkbox') {
212
+ setTimeout(function () {
213
+ var checkboxTrigger = focusedCell.querySelector('input');
214
+ checkboxTrigger === null || checkboxTrigger === void 0 || checkboxTrigger.click();
215
+ checkboxTrigger === null || checkboxTrigger === void 0 || checkboxTrigger.focus();
216
+ }, 1);
217
+ }
210
218
  if (focusedType === 'date') {
211
219
  setTimeout(function () {
212
220
  var dateInputTrigger = focusedCell.querySelector('input');
@@ -1 +1,7 @@
1
+ /**
2
+ * Copyright IBM Corp. 2024
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
1
7
  export const selectionColumnId: "datagridSelection";
@@ -1,3 +1,9 @@
1
+ /**
2
+ * Copyright IBM Corp. 2024
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
1
7
  /// <reference path="../../../../src/custom-typings/index.d.ts" />
2
8
  import { MultiSelectProps } from '@carbon/react/lib/components/MultiSelect/MultiSelect';
3
9
  import { FormGroupProps } from '@carbon/react/lib/components/FormGroup/FormGroup';
@@ -5,10 +11,10 @@ import { RadioButtonProps } from '@carbon/react/lib/components/RadioButton/Radio
5
11
  import { RadioButtonGroupProps } from '@carbon/react/lib/components/RadioButtonGroup/RadioButtonGroup';
6
12
  import { CheckboxProps } from '@carbon/react/lib/components/Checkbox';
7
13
  import { NumberInputProps } from '@carbon/react/lib/components/NumberInput/NumberInput';
8
- import { CSSProperties, JSXElementConstructor, MutableRefObject, ReactNode, TouchEventHandler } from 'react';
9
- import { Cell, Column, ColumnInstance, FilterValue, Filters, HeaderGroup, Meta, Row, TableCommonProps, TableDispatch, TableInstance, TableToggleAllRowsSelectedProps, UseExpandedRowProps, UseFiltersInstanceProps, UsePaginationInstanceProps, UseResizeColumnsColumnProps, UseResizeColumnsState, UseRowSelectInstanceProps, UseRowSelectRowProps, UseRowSelectState, UseSortByColumnProps, UseSortByOptions, UseTableHooks } from 'react-table';
14
+ import React, { CSSProperties, ComponentType, FunctionComponent, JSXElementConstructor, MutableRefObject, ReactNode, TouchEventHandler } from 'react';
15
+ import { Cell, Column, ColumnInstance, FilterValue, Filters, HeaderGroup, Meta, Row, TableCommonProps, TableDispatch, TableInstance, TableState, TableToggleAllRowsSelectedProps, UseExpandedRowProps, UseFiltersInstanceProps, UsePaginationInstanceProps, UseResizeColumnsColumnProps, UseResizeColumnsOptions, UseResizeColumnsState, UseRowSelectInstanceProps, UseRowSelectRowProps, UseRowSelectState, UseSortByColumnProps, UseSortByOptions, UseTableHooks } from 'react-table';
10
16
  import { CarbonIconType } from '@carbon/react/icons';
11
- import { type ButtonProps } from '@carbon/react';
17
+ import { IconButton, type ButtonProps } from '@carbon/react';
12
18
  import { TableBatchActionsProps } from '@carbon/react/lib/components/DataTable/TableBatchActions';
13
19
  export type Size = 'xs' | 'sm' | 'md' | 'lg';
14
20
  export interface ResizerProps {
@@ -59,6 +65,18 @@ interface Labels {
59
65
  allPageRows?: object;
60
66
  allRows?: object;
61
67
  }
68
+ interface ColumnLabels {
69
+ findColumnPlaceholderLabel?: string;
70
+ resetToDefaultLabel?: string;
71
+ customizeTearsheetHeadingLabel?: string;
72
+ primaryButtonTextLabel?: string;
73
+ secondaryButtonTextLabel?: string;
74
+ instructionsLabel?: string;
75
+ iconTooltipLabel?: string;
76
+ assistiveTextInstructionsLabel?: string;
77
+ assistiveTextDisabledInstructionsLabel?: string;
78
+ selectAllLabel?: string;
79
+ }
62
80
  interface Section {
63
81
  categoryTitle?: string;
64
82
  filters?: DataGridFilter[];
@@ -85,7 +103,7 @@ export interface DataGridToggleAllRowsProps extends TableToggleAllRowsSelectedPr
85
103
  }
86
104
  export interface DatagridTableHooks<T extends object = any> extends UseTableHooks<T> {
87
105
  }
88
- export interface DatagridColumn<T extends object = any> extends ColumnInstance<T>, UseSortByOptions<T> {
106
+ export interface DatagridColumn<T extends object = any> extends ColumnInstance<T>, UseSortByOptions<T>, Partial<UseResizeColumnsColumnProps<T>>, UseResizeColumnsOptions<T> {
89
107
  sticky?: 'left' | 'right';
90
108
  className?: string;
91
109
  rightAlignedColumn?: boolean;
@@ -112,15 +130,31 @@ export interface DataGridHeader<T extends object = any> extends ColumnInstance,
112
130
  }
113
131
  export interface DataGridHeaderGroup<T extends object = any> extends HeaderGroup<T>, UseResizeColumnsColumnProps<T> {
114
132
  }
115
- export interface TableProps {
116
- className?: string;
117
- role?: string;
118
- style?: CSSStyleDeclaration;
133
+ export interface DataGridTableProps extends TableCommonProps {
119
134
  }
120
135
  interface DataGridTableState extends UseResizeColumnsState<any>, UseRowSelectState<any> {
121
136
  filters: Filters<DataGridFilter>;
122
137
  }
123
- export interface DataGridTableInstance<T extends object = any> extends TableInstance<T> {
138
+ export interface DataGridTableInstance<T extends object = any> extends Omit<TableInstance<T>, 'state'>, Partial<UsePaginationInstanceProps<any>> {
139
+ shouldDisableSelectRow?: (...args: any[]) => void | boolean;
140
+ state?: Partial<TableState & UseRowSelectState<any>>;
141
+ disableSelectAll?: boolean;
142
+ disableSelectRowsProps?: {
143
+ labels?: {
144
+ toggleAllRowsLabel?: string;
145
+ };
146
+ };
147
+ withSelectRows?: boolean;
148
+ }
149
+ export interface RowAction {
150
+ id?: string;
151
+ itemText?: string;
152
+ icon?: ComponentType | FunctionComponent;
153
+ align?: React.ComponentProps<typeof IconButton>['align'];
154
+ shouldHideMenuItem?: (...args: any[]) => void;
155
+ shouldDisableMenuItem?: (...args: any[]) => void;
156
+ disabled?: boolean;
157
+ onClick?: (...args: any[]) => void;
124
158
  }
125
159
  export interface DataGridState<T extends object = any> extends TableCommonProps, UsePaginationInstanceProps<T>, Omit<TableInstance<T>, 'state' | 'headers' | 'rows' | 'columns'>, Omit<UseFiltersInstanceProps<T>, 'rows'>, UseRowSelectInstanceProps<T>, Pick<UseRowSelectInstanceProps<T>, 'toggleAllRowsSelected'> {
126
160
  withVirtualScroll?: boolean;
@@ -144,6 +178,7 @@ export interface DataGridState<T extends object = any> extends TableCommonProps,
144
178
  batchActions?: boolean;
145
179
  row: DatagridRow;
146
180
  rows: Array<DatagridRow<any>>;
181
+ rowActions?: RowAction[];
147
182
  columns: Array<DatagridColumn>;
148
183
  key?: any;
149
184
  rowSize?: Size;
@@ -199,11 +234,23 @@ export interface DataGridState<T extends object = any> extends TableCommonProps,
199
234
  expandedRowIds?: object;
200
235
  onRowClick?: (row: any, event: any) => void;
201
236
  onSort?: boolean;
237
+ customizeColumnsProps?: {
238
+ onSaveColumnPrefs?: (args: any) => void;
239
+ labels?: ColumnLabels;
240
+ isTearsheetOpen?: boolean;
241
+ setIsTearsheetOpen?: (args: boolean) => void;
242
+ };
243
+ CustomizeColumnsButton?: (args: any) => ReactNode;
202
244
  column?: DatagridColumn;
203
245
  expandedContentHeight?: number;
204
246
  onRowExpand?: (row: DatagridRow, event: React.MouseEvent<HTMLElement>) => void;
205
247
  ExpandedRowContentComponent?: JSXElementConstructor<any>;
206
248
  }
249
+ export interface DataGridData {
250
+ instance?: DataGridTableInstance;
251
+ column?: DatagridColumn;
252
+ cell?: DataGridCell;
253
+ }
207
254
  export interface ResizeHeaderProps {
208
255
  resizerProps?: ResizerProps;
209
256
  header: DataGridHeader;
@@ -220,4 +267,8 @@ export interface ResizeHeaderProps {
220
267
  }
221
268
  export type VisibleColumns<T extends object = {}> = (allColumns: Array<ColumnInstance<T>>, meta: Meta<T>) => Array<Column<T>>;
222
269
  export type NodeFuncType = (props: any) => ReactNode;
270
+ export interface PropGetterMeta {
271
+ instance?: DataGridTableInstance;
272
+ row?: Partial<Row<any> & DatagridRow<any>>;
273
+ }
223
274
  export {};
@@ -1,2 +1,9 @@
1
+ /**
2
+ * Copyright IBM Corp. 2021, 2023
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import { Hooks } from 'react-table';
8
+ declare const useActionsColumn: (hooks: Hooks) => void;
1
9
  export default useActionsColumn;
2
- declare function useActionsColumn(hooks: any): void;
@@ -17,9 +17,10 @@ var _excluded = ["align", "id", "itemText", "onClick", "icon", "shouldHideMenuIt
17
17
  var blockClass = "".concat(pkg.prefix, "--datagrid");
18
18
  var useActionsColumn = function useActionsColumn(hooks) {
19
19
  var useAttachActionsOnInstance = function useAttachActionsOnInstance(instance) {
20
- var rowActions = instance.rowActions,
21
- isFetching = instance.isFetching,
22
- selectedRowIds = instance.state.selectedRowIds;
20
+ var _ref = instance,
21
+ rowActions = _ref.rowActions,
22
+ isFetching = _ref.isFetching,
23
+ selectedRowIds = _ref.state.selectedRowIds;
23
24
  var getDisabledState = function getDisabledState(rowIndex) {
24
25
  var selectedRowIndexes = Object.keys(selectedRowIds).map(function (n) {
25
26
  return Number(n);
@@ -79,10 +80,10 @@ var useActionsColumn = function useActionsColumn(hooks) {
79
80
  return;
80
81
  }
81
82
  e.stopPropagation();
82
- _onClick(id, row, e);
83
+ _onClick === null || _onClick === void 0 || _onClick(id, row, e);
83
84
  },
84
85
  disabled: isDisabledByRow
85
- }), /*#__PURE__*/React__default.createElement(Icon, null)));
86
+ }), Icon && /*#__PURE__*/React__default.createElement(Icon, null)));
86
87
  })), !isFetching && (rowActions.length > 2 || isColumnSticky) && /*#__PURE__*/React__default.createElement("div", null, /*#__PURE__*/React__default.createElement(OverflowMenu, {
87
88
  align: "left",
88
89
  size: "sm",
@@ -108,7 +109,7 @@ var useActionsColumn = function useActionsColumn(hooks) {
108
109
  disabled: isDisabledByRow,
109
110
  onClick: function onClick(e) {
110
111
  e.stopPropagation();
111
- _onClick2(id, row, e);
112
+ _onClick2 === null || _onClick2 === void 0 || _onClick2(id, row, e);
112
113
  },
113
114
  key: id
114
115
  }));
@@ -1,2 +1,9 @@
1
+ /**
2
+ * Copyright IBM Corp. 2021, 2024
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import { Hooks } from 'react-table';
8
+ declare const useCustomizeColumns: (hooks: Hooks) => void;
1
9
  export default useCustomizeColumns;
2
- declare function useCustomizeColumns(hooks: any): void;
@@ -16,9 +16,10 @@ var useCustomizeColumns = function useCustomizeColumns(hooks) {
16
16
  isTearsheetOpen = _React$useState2[0],
17
17
  setIsTearsheetOpen = _React$useState2[1];
18
18
  hooks.useInstance.push(function (instance) {
19
- var customizeColumnsProps = instance.customizeColumnsProps;
20
- var _ref = customizeColumnsProps || {},
21
- labels = _ref.labels;
19
+ var _ref = instance,
20
+ customizeColumnsProps = _ref.customizeColumnsProps;
21
+ var _ref2 = customizeColumnsProps || {},
22
+ labels = _ref2.labels;
22
23
  Object.assign(instance, {
23
24
  customizeColumnsProps: _objectSpread2(_objectSpread2({}, customizeColumnsProps), {}, {
24
25
  isTearsheetOpen: isTearsheetOpen,
@@ -1,3 +1,9 @@
1
+ /**
2
+ * Copyright IBM Corp. 2024
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
1
7
  import { TableInstance } from 'react-table';
2
8
  declare const useDatagrid: (params: any, ...plugins: any[]) => TableInstance;
3
9
  export default useDatagrid;
@@ -21,7 +21,6 @@ var useDefaultStringRenderer = function useDefaultStringRenderer(hooks) {
21
21
  var HeaderRenderer = function HeaderRenderer(header, slug) {
22
22
  return /*#__PURE__*/React__default.createElement("div", {
23
23
  className: cx("".concat(blockClass, "__defaultStringRenderer"), _defineProperty({}, "".concat(blockClass, "__defaultStringRenderer--slug"), slug && /*#__PURE__*/React__default.isValidElement(slug))),
24
- title: typeof header === 'string' ? header : '',
25
24
  key: typeof header === 'string' ? header : ''
26
25
  }, header);
27
26
  };
@@ -1,2 +1,9 @@
1
+ /**
2
+ * Copyright IBM Corp. 2020, 2024
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import { Hooks } from 'react-table';
8
+ declare const useDisableSelectRows: (hooks: Hooks) => void;
1
9
  export default useDisableSelectRows;
2
- declare function useDisableSelectRows(hooks: any): void;