@carbon/ibm-products 2.2.0 → 2.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (225) hide show
  1. package/css/index-full-carbon.css +965 -434
  2. package/css/index-full-carbon.css.map +1 -1
  3. package/css/index-full-carbon.min.css +4 -4
  4. package/css/index-full-carbon.min.css.map +1 -1
  5. package/css/index-without-carbon-released-only.css +354 -155
  6. package/css/index-without-carbon-released-only.css.map +1 -1
  7. package/css/index-without-carbon-released-only.min.css +2 -2
  8. package/css/index-without-carbon-released-only.min.css.map +1 -1
  9. package/css/index-without-carbon.css +600 -236
  10. package/css/index-without-carbon.css.map +1 -1
  11. package/css/index-without-carbon.min.css +4 -4
  12. package/css/index-without-carbon.min.css.map +1 -1
  13. package/css/index.css +516 -293
  14. package/css/index.css.map +1 -1
  15. package/css/index.min.css +4 -4
  16. package/css/index.min.css.map +1 -1
  17. package/es/components/APIKeyModal/APIKeyModal.docs-page.js +26 -0
  18. package/es/components/AboutModal/AboutModal.docs-page.js +21 -0
  19. package/es/components/AboutModal/AboutModal.js +2 -4
  20. package/es/components/ActionBar/ActionBar.js +2 -6
  21. package/es/components/AddSelect/AddSelectFormControl.js +6 -6
  22. package/es/components/AddSelect/AddSelectRow.js +15 -5
  23. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +5 -6
  24. package/es/components/ButtonMenu/ButtonMenu.js +4 -4
  25. package/es/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +3 -9
  26. package/es/components/Cascade/Cascade.docs-page.js +22 -0
  27. package/es/components/Cascade/Cascade.js +11 -1
  28. package/es/components/CreateFullPage/CreateFullPage.docs-page.js +39 -0
  29. package/es/components/CreateFullPage/CreateFullPage.js +13 -0
  30. package/es/components/CreateModal/CreateModal.docs-page.js +24 -0
  31. package/es/components/CreateModal/CreateModal.js +7 -0
  32. package/es/components/CreateSidePanel/CreateSidePanel.docs-page.js +18 -0
  33. package/es/components/CreateSidePanel/CreateSidePanel.js +1 -1
  34. package/es/components/CreateTearsheet/CreateTearsheet.docs-page.js +29 -0
  35. package/es/components/DataSpreadsheet/DataSpreadsheet.js +3 -3
  36. package/es/components/Datagrid/Datagrid/DatagridContent.js +1 -1
  37. package/es/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +3 -3
  38. package/es/components/Datagrid/Datagrid/DatagridToolbar.js +25 -10
  39. package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +1 -3
  40. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +1 -1
  41. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +39 -47
  42. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +20 -24
  43. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +2 -2
  44. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilterContext.js +13 -0
  45. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +44 -15
  46. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +16 -30
  47. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +2 -2
  48. package/es/components/Datagrid/index.js +2 -1
  49. package/es/components/Datagrid/useActionsColumn.js +10 -7
  50. package/es/components/Datagrid/useCustomizeColumns.js +9 -7
  51. package/es/components/Datagrid/useExpandedRow.js +11 -7
  52. package/es/components/Datagrid/useFiltering.js +12 -8
  53. package/es/components/Datagrid/useInlineEdit.js +3 -0
  54. package/es/components/Datagrid/useNestedRows.js +10 -6
  55. package/es/components/Datagrid/useStickyColumn.js +10 -3
  56. package/es/components/Datagrid/utils/DatagridActions.js +12 -20
  57. package/es/components/EditFullPage/EditFullPage.docs-page.js +39 -0
  58. package/es/components/EditFullPage/EditFullPage.js +2 -1
  59. package/es/components/EditSidePanel/EditSidePanel.js +1 -1
  60. package/es/components/EditTearsheet/EditTearsheet.docs-page.js +25 -0
  61. package/es/components/EditTearsheet/EditTearsheet.js +4 -0
  62. package/es/components/EditTearsheetNarrow/EditTearsheetNarrow.js +1 -1
  63. package/es/components/EditUpdateCards/EditUpdateCards.js +3 -2
  64. package/es/components/EmptyStates/EmptyState.js +4 -0
  65. package/es/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +4 -0
  66. package/es/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +4 -0
  67. package/es/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +4 -0
  68. package/es/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +4 -0
  69. package/es/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +4 -0
  70. package/es/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +4 -0
  71. package/es/components/ExampleComponent/ExampleComponent.docs-page.js +22 -0
  72. package/es/components/ExportModal/ExportModal.js +4 -0
  73. package/es/components/HTTPErrors/HTTPError403/HTTPError403.js +6 -0
  74. package/es/components/HTTPErrors/HTTPError404/HTTPError404.js +6 -0
  75. package/es/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +6 -0
  76. package/es/components/ImportModal/ImportModal.docs-page.js +18 -0
  77. package/es/components/ImportModal/ImportModal.js +13 -6
  78. package/es/components/MultiAddSelect/MultiAddSelect.docs-page.js +17 -0
  79. package/es/components/MultiAddSelect/MultiAddSelect.js +4 -0
  80. package/es/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +2 -17
  81. package/es/components/PageHeader/PageHeader.js +2 -6
  82. package/es/components/PageHeader/PageHeaderUtils.js +2 -2
  83. package/es/components/RemoveModal/RemoveModal.docs-page.js +18 -0
  84. package/es/components/RemoveModal/RemoveModal.js +6 -0
  85. package/es/components/SidePanel/SidePanel.js +1 -3
  86. package/es/components/SingleAddSelect/SingleAddSelect.docs-page.js +15 -0
  87. package/es/components/SingleAddSelect/SingleAddSelect.js +4 -0
  88. package/es/components/StatusIcon/StatusIcon.docs-page.js +17 -0
  89. package/es/components/StatusIcon/StatusIcon.js +10 -0
  90. package/es/components/TagSet/TagSet.js +4 -7
  91. package/es/components/Tearsheet/TearsheetShell.js +11 -6
  92. package/es/components/Toolbar/Toolbar.docs-page.js +14 -0
  93. package/es/components/UserProfileImage/UserProfileImage.docs-page.js +17 -0
  94. package/es/components/UserProfileImage/UserProfileImage.js +14 -3
  95. package/es/components/WebTerminal/WebTerminal.docs-page.js +52 -0
  96. package/es/components/WebTerminal/WebTerminal.js +4 -0
  97. package/es/components/index.js +1 -1
  98. package/es/global/js/hooks/useCreateComponentStepChange.js +16 -15
  99. package/es/global/js/hooks/useResizeObserver.js +14 -28
  100. package/es/global/js/package-settings.js +14 -1
  101. package/es/global/js/utils/StoryDocsPage.js +218 -0
  102. package/es/global/js/utils/story-helper.js +108 -6
  103. package/lib/components/APIKeyModal/APIKeyModal.docs-page.js +37 -0
  104. package/lib/components/AboutModal/AboutModal.docs-page.js +32 -0
  105. package/lib/components/AboutModal/AboutModal.js +2 -4
  106. package/lib/components/ActionBar/ActionBar.js +2 -6
  107. package/lib/components/AddSelect/AddSelectFormControl.js +6 -6
  108. package/lib/components/AddSelect/AddSelectRow.js +15 -5
  109. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +5 -6
  110. package/lib/components/ButtonMenu/ButtonMenu.js +4 -4
  111. package/lib/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +3 -9
  112. package/lib/components/Cascade/Cascade.docs-page.js +33 -0
  113. package/lib/components/Cascade/Cascade.js +11 -1
  114. package/lib/components/CreateFullPage/CreateFullPage.docs-page.js +50 -0
  115. package/lib/components/CreateFullPage/CreateFullPage.js +13 -0
  116. package/lib/components/CreateModal/CreateModal.docs-page.js +35 -0
  117. package/lib/components/CreateModal/CreateModal.js +7 -0
  118. package/lib/components/CreateSidePanel/CreateSidePanel.docs-page.js +29 -0
  119. package/lib/components/CreateSidePanel/CreateSidePanel.js +1 -1
  120. package/lib/components/CreateTearsheet/CreateTearsheet.docs-page.js +40 -0
  121. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +3 -3
  122. package/lib/components/Datagrid/Datagrid/DatagridContent.js +1 -1
  123. package/lib/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +3 -3
  124. package/lib/components/Datagrid/Datagrid/DatagridToolbar.js +25 -10
  125. package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +1 -3
  126. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +1 -1
  127. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +37 -45
  128. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +20 -24
  129. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +6 -6
  130. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilterContext.js +20 -0
  131. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +42 -13
  132. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +16 -30
  133. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +2 -2
  134. package/lib/components/Datagrid/index.js +8 -1
  135. package/lib/components/Datagrid/useActionsColumn.js +12 -7
  136. package/lib/components/Datagrid/useCustomizeColumns.js +10 -8
  137. package/lib/components/Datagrid/useExpandedRow.js +9 -6
  138. package/lib/components/Datagrid/useFiltering.js +10 -7
  139. package/lib/components/Datagrid/useInlineEdit.js +3 -0
  140. package/lib/components/Datagrid/useNestedRows.js +9 -6
  141. package/lib/components/Datagrid/useStickyColumn.js +10 -3
  142. package/lib/components/Datagrid/utils/DatagridActions.js +49 -57
  143. package/lib/components/EditFullPage/EditFullPage.docs-page.js +50 -0
  144. package/lib/components/EditFullPage/EditFullPage.js +2 -1
  145. package/lib/components/EditSidePanel/EditSidePanel.js +1 -1
  146. package/lib/components/EditTearsheet/EditTearsheet.docs-page.js +36 -0
  147. package/lib/components/EditTearsheet/EditTearsheet.js +4 -0
  148. package/lib/components/EditTearsheetNarrow/EditTearsheetNarrow.js +1 -1
  149. package/lib/components/EditUpdateCards/EditUpdateCards.js +3 -2
  150. package/lib/components/EmptyStates/EmptyState.js +4 -0
  151. package/lib/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +4 -0
  152. package/lib/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +4 -0
  153. package/lib/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +4 -0
  154. package/lib/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +4 -0
  155. package/lib/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +4 -0
  156. package/lib/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +4 -0
  157. package/lib/components/ExampleComponent/ExampleComponent.docs-page.js +33 -0
  158. package/lib/components/ExportModal/ExportModal.js +4 -0
  159. package/lib/components/HTTPErrors/HTTPError403/HTTPError403.js +6 -0
  160. package/lib/components/HTTPErrors/HTTPError404/HTTPError404.js +6 -0
  161. package/lib/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +6 -0
  162. package/lib/components/ImportModal/ImportModal.docs-page.js +26 -0
  163. package/lib/components/ImportModal/ImportModal.js +13 -6
  164. package/lib/components/MultiAddSelect/MultiAddSelect.docs-page.js +25 -0
  165. package/lib/components/MultiAddSelect/MultiAddSelect.js +4 -0
  166. package/lib/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +2 -17
  167. package/lib/components/PageHeader/PageHeader.js +2 -6
  168. package/lib/components/PageHeader/PageHeaderUtils.js +2 -2
  169. package/lib/components/RemoveModal/RemoveModal.docs-page.js +26 -0
  170. package/lib/components/RemoveModal/RemoveModal.js +6 -0
  171. package/lib/components/SidePanel/SidePanel.js +1 -3
  172. package/lib/components/SingleAddSelect/SingleAddSelect.docs-page.js +23 -0
  173. package/lib/components/SingleAddSelect/SingleAddSelect.js +4 -0
  174. package/lib/components/StatusIcon/StatusIcon.docs-page.js +28 -0
  175. package/lib/components/StatusIcon/StatusIcon.js +10 -0
  176. package/lib/components/TagSet/TagSet.js +4 -7
  177. package/lib/components/Tearsheet/TearsheetShell.js +11 -6
  178. package/lib/components/Toolbar/Toolbar.docs-page.js +25 -0
  179. package/lib/components/UserProfileImage/UserProfileImage.docs-page.js +28 -0
  180. package/lib/components/UserProfileImage/UserProfileImage.js +14 -3
  181. package/lib/components/WebTerminal/WebTerminal.docs-page.js +63 -0
  182. package/lib/components/WebTerminal/WebTerminal.js +4 -0
  183. package/lib/components/index.js +6 -0
  184. package/lib/global/js/hooks/useCreateComponentStepChange.js +16 -15
  185. package/lib/global/js/hooks/useResizeObserver.js +13 -27
  186. package/lib/global/js/package-settings.js +14 -1
  187. package/lib/global/js/utils/StoryDocsPage.js +225 -0
  188. package/lib/global/js/utils/story-helper.js +115 -7
  189. package/package.json +4 -4
  190. package/scss/components/AddSelect/_add-select.scss +10 -6
  191. package/scss/components/BreadcrumbWithOverflow/_breadcrumb-with-overflow.scss +0 -1
  192. package/scss/components/ButtonMenu/_button-menu.scss +32 -1
  193. package/scss/components/Cascade/_storybook-styles.scss +3 -2
  194. package/scss/components/CreateFullPage/_create-full-page.scss +3 -3
  195. package/scss/components/CreateModal/_create-modal.scss +3 -3
  196. package/scss/components/CreateSidePanel/_create-side-panel.scss +4 -4
  197. package/scss/components/CreateTearsheet/_create-tearsheet.scss +2 -2
  198. package/scss/components/CreateTearsheet/_storybook-styles.scss +1 -1
  199. package/scss/components/CreateTearsheetNarrow/_create-tearsheet-narrow.scss +2 -2
  200. package/scss/components/DataSpreadsheet/_data-spreadsheet.scss +5 -5
  201. package/scss/components/DataSpreadsheet/_storybook-styles.scss +6 -0
  202. package/scss/components/Datagrid/_datagrid.scss +4 -2
  203. package/scss/components/Datagrid/_storybook-styles.scss +18 -4
  204. package/scss/components/Datagrid/styles/_datagrid.scss +26 -13
  205. package/scss/components/Datagrid/styles/addons/_FilterFlyout.scss +7 -0
  206. package/scss/components/Datagrid/styles/addons/_FilterPanel.scss +4 -0
  207. package/scss/components/EditSidePanel/_edit-side-panel.scss +2 -2
  208. package/scss/components/EditTearsheet/_edit-tearsheet.scss +2 -2
  209. package/scss/components/EditTearsheet/_storybook-styles.scss +1 -1
  210. package/scss/components/ImportModal/_import-modal.scss +1 -1
  211. package/scss/components/NotificationsPanel/_notifications-panel.scss +3 -3
  212. package/scss/components/NotificationsPanel/_storybook-styles.scss +10 -2
  213. package/scss/components/OptionsTile/_storybook-styles.scss +1 -1
  214. package/scss/components/PageHeader/_page-header.scss +4 -5
  215. package/scss/components/PageHeader/_storybook-styles.scss +24 -14
  216. package/scss/components/Saving/_saving.scss +1 -1
  217. package/scss/components/SidePanel/_side-panel.scss +3 -5
  218. package/scss/components/TagSet/_tag-set.scss +1 -1
  219. package/scss/components/Tearsheet/_tearsheet.scss +9 -8
  220. package/scss/components/UserProfileImage/_user-profile-image.scss +2 -2
  221. package/scss/components/WebTerminal/_storybook-styles.scss +11 -1
  222. package/scss/global/styles/_display-box.scss +1 -0
  223. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useInitialStateFromFilters.js +0 -21
  224. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useInitialStateFromFilters.js +0 -30
  225. package/scss/components/HTTPErrors/_storybook-styles.scss +0 -6
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _StoryDocsPage = require("../../global/js/utils/StoryDocsPage");
11
+ var stories = _interopRequireWildcard(require("./CreateSidePanel.stories"));
12
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
13
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
14
+ var DocsPage = function DocsPage() {
15
+ return /*#__PURE__*/_react.default.createElement(_StoryDocsPage.StoryDocsPage, {
16
+ altGuidelinesHref: [{
17
+ href: 'https://pages.github.ibm.com/cdai-design/pal/patterns/creation-flows/usage#side-panel',
18
+ label: 'Carbon create flows side panel usage guidelines'
19
+ }],
20
+ blocks: [{
21
+ story: stories.Default
22
+ }, {
23
+ title: 'Form validation',
24
+ description: "All forms, including that within the `CreateSidePanel` should follow C&CS\nguidelines for form validation.\n\nThis includes the following:\n\n- The `Submit` button in the side panel should be disabled, until all required\n inputs are filled in and valid\n- All required inputs should _only_ throw an invalid error _after_ the element\n loses focus\n- All optional form fields should have an `(optional)` text at the end of the\n input `labelText`. Optional should always be in parentheses\n\nYou can find more information on how to validate your form fields in\n[Carbon's Form usage page](https://www.carbondesignsystem.com/components/form/usage)."
25
+ }]
26
+ });
27
+ };
28
+ var _default = DocsPage;
29
+ exports.default = _default;
@@ -34,7 +34,7 @@ var componentName = 'CreateSidePanel';
34
34
  // NOTE: the component SCSS is not imported here: it is rolled up separately.
35
35
 
36
36
  /**
37
- * This is an example component to show relevant conventions and usage.
37
+ * Use with medium complexity creations if the user needs page context. On-page content can be seen and interacted with.
38
38
  */
39
39
  var CreateSidePanel = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref) {
40
40
  var className = _ref.className,
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _StoryDocsPage = require("../../global/js/utils/StoryDocsPage");
11
+ var stories = _interopRequireWildcard(require("./CreateTearsheet.stories"));
12
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
13
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
14
+ var DocsPage = function DocsPage() {
15
+ return /*#__PURE__*/_react.default.createElement(_StoryDocsPage.StoryDocsPage, {
16
+ altGuidelinesHref: "https://pages.github.ibm.com/cdai-design/pal/patterns/creation-flows/usage#wide-tearsheet",
17
+ blocks: [{
18
+ story: stories.multiStepTearsheet,
19
+ description: "This is used when you have one section per step. This can be created by passing\nin the overall `<CreateTearsheet />` component and the `<CreateTearsheetStep />`\ncomponent with form items as children:",
20
+ source: {
21
+ code: " <CreateTearsheet {...props}>\n <CreateTearsheetStep\n title=\"Required title\"\n subtitle=\"Optional subtitle\"\n description=\"Optional description\"\n onNext={() => {'Optional function'}}\n disableSubmit={}\n >\n <TextInput\n id=\"test-1\"\n invalidText=\"A valid value is required\"\n labelText=\"Topic name\"\n placeholder=\"Enter topic name\"\n />\n </CreateTearsheetStep>\n </CreateTearsheet>"
22
+ }
23
+ }, {
24
+ title: 'Using custom components',
25
+ description: "It is possible to use custom components that return `CreateTearsheetStep`s in\norder to help reduce the amount of logic in the component that contains the main\n`CreateTearsheet`. _It is required that each child of the `CreateTearsheet`\neither be a custom step or a `CreateTearsheetStep`_. An example of this could\nlook like the following:",
26
+ source: {
27
+ code: "const CreateStepCustom = ({ subtitle, ...rest }) => {\n return (\n <CreateTearsheetStep\n {...rest}\n subtitle={subtitle}\n title=\"Step 1\"\n onNext={() => console.log('optional validation check')}\n onMount={() => console.log('optional onMount fn')}\n disableSubmit={false}\n >\n step content here\n </CreateTearsheetStep>\n );\n};\n\nconst CreateComponent = () => {\n return (\n <CreateTearsheet {...createTearsheetProps}>\n <CreateStepCustom subtitle=\"Custom step subtitle\" />\n <CreateTearsheetStep\n title=\"Topic name\"\n fieldsetLegendText=\"Topic information\"\n disableSubmit={!value}\n subtitle=\"This is the unique name used to recognize your topic\"\n description=\"It will also be used by your producers and consumers as part of the\n connection information, so make it something easy to recognize.\"\n >\n Content for second step\n </CreateTearsheetStep>\n </CreateTearsheet>\n );\n};"
28
+ }
29
+ }, {
30
+ title: 'Using dynamic steps',
31
+ description: "The use of dynamic steps can be utilized in a scenario when the user makes a\ncertain selection on one step that effects which steps will follow it, this is\ncontrolled via the `includeStep` prop. See abbreviated example below:",
32
+ code: "import { useState } from 'react';\n\nconst CreateFlow = () => {\n const [shouldIncludeAdditionalStep, setShouldIncludeAdditionalStep] =\n useState(false);\n return (\n <CreateTearsheet {...createTearsheetProps}>\n <CreateTearsheetStep {...step1Props}>\n Step 1 content\n <Checkbox\n labelText={`Include additional step`}\n id=\"include-additional-step-checkbox\"\n onChange={(value) => setShouldIncludeAdditionalStep(value)}\n checked={shouldIncludeAdditionalStep}\n />\n </CreateTearsheetStep>\n <CreateTearsheetStep\n {...step2Props}\n includeStep={shouldIncludeAdditionalStep}\n >\n Dynamic step content\n </CreateTearsheetStep>\n <CreateTearsheetStep {...step3Props}>\n Final step content\n </CreateTearsheetStep>\n </CreateTearsheet>\n );\n};"
33
+ }, {
34
+ title: 'Class names',
35
+ description: "Additionally, to get the preferred styling when including your own children as\nsections, you can utilize the below included class names.\n\n| Class name | Element | Features |\n| ----------------------------------------------------- | ----------- | ---------------------------------------------------------- |\n| `#{$pkg-prefix}--create-tearsheet__step--title` | title | `productive-heading-04` & `margin-bottom` of `$spacing-05` |\n| `#{$pkg-prefix}--create-tearsheet__step--subtitle` | subtitle | `productive-heading-01` & `margin-bottom` of `$spacing-03` |\n| `#{$pkg-prefix}--create-tearsheet__step--description` | description | `body-long-01` & `margin-bottom` of `$spacing-06` |\n| `#{$pkg-prefix}--create-tearsheet__step--fieldset` | fieldset | `margin-bottom` of `$spacing-05` to all children elements |\n| `#{$pkg-prefix}--create-tearsheet__section--divider` | divider | Includes a `1px` divider line inside the `main` content |\n"
36
+ }]
37
+ });
38
+ };
39
+ var _default = DocsPage;
40
+ exports.default = _default;
@@ -674,9 +674,6 @@ var DataSpreadsheet = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref
674
674
  defaultColumn: defaultColumn,
675
675
  cellEditorValue: cellEditorValue
676
676
  });
677
- var handleActiveCellMouseEnter = (0, _react.useCallback)(function () {
678
- handleActiveCellMouseEnterCallback(selectionAreas, clickAndHoldActive);
679
- }, [clickAndHoldActive, selectionAreas, handleActiveCellMouseEnterCallback]);
680
677
 
681
678
  // Only update if there are cell selection areas
682
679
  // Find point object that matches currentMatcher and remove the second point
@@ -709,6 +706,9 @@ var DataSpreadsheet = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref
709
706
  });
710
707
  }
711
708
  }, [spreadsheetRef, currentMatcher]);
709
+ var handleActiveCellMouseEnter = (0, _react.useCallback)(function () {
710
+ handleActiveCellMouseEnterCallback(selectionAreas, clickAndHoldActive);
711
+ }, [clickAndHoldActive, selectionAreas, handleActiveCellMouseEnterCallback]);
712
712
  return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, rest, getTableProps(), (0, _devtools.getDevtoolsProps)(componentName), {
713
713
  className: (0, _classnames.default)(blockClass, className, "".concat(blockClass, "--interactive-cell-element"), (_cx = {}, (0, _defineProperty2.default)(_cx, "".concat(blockClass, "__container-has-focus"), containerHasFocus), (0, _defineProperty2.default)(_cx, "".concat(blockClass, "__").concat(theme), theme === 'dark'), _cx)),
714
714
  ref: spreadsheetRef,
@@ -92,7 +92,7 @@ var DatagridContent = function DatagridContent(_ref) {
92
92
  return /*#__PURE__*/_react.default.createElement(_react2.Table, (0, _extends2.default)({}, getTableProps(), {
93
93
  className: (0, _classnames.default)(withVirtualScroll ? '' : "".concat(blockClass, "__table-simple"), "".concat(blockClass, "__vertical-align-").concat(verticalAlign), (0, _defineProperty2.default)({}, "".concat(blockClass, "__variable-row-height"), variableRowHeight), (0, _defineProperty2.default)({}, "".concat(blockClass, "__table-with-inline-edit"), withInlineEdit), (0, _defineProperty2.default)({}, "".concat(blockClass, "__table-grid-active"), gridActive), (_getTableProps = getTableProps()) === null || _getTableProps === void 0 ? void 0 : _getTableProps.className),
94
94
  role: withInlineEdit && 'grid',
95
- tabIndex: withInlineEdit && 0,
95
+ tabIndex: withInlineEdit ? 0 : -1,
96
96
  onKeyDown: withInlineEdit ? function (event) {
97
97
  return (0, _handleGridKeyPress.handleGridKeyPress)({
98
98
  event: event,
@@ -44,6 +44,9 @@ var SelectAllWithToggle = function SelectAllWithToggle(_ref) {
44
44
  allRowsLabel = _ref$allRowsLabel === void 0 ? 'Select all' : _ref$allRowsLabel,
45
45
  columns = _ref.columns,
46
46
  withStickyColumn = _ref.withStickyColumn;
47
+ var _ref2 = selectAllToggle || {},
48
+ onSelectAllRows = _ref2.onSelectAllRows,
49
+ labels = _ref2.labels;
47
50
  var _useState = (0, _react.useState)(SELECT_ALL_PAGE_ROWS),
48
51
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
49
52
  selectAllMode = _useState2[0],
@@ -66,9 +69,6 @@ var SelectAllWithToggle = function SelectAllWithToggle(_ref) {
66
69
  return window.removeEventListener('resize', updateSize);
67
70
  };
68
71
  }, []);
69
- var _ref2 = selectAllToggle || {},
70
- onSelectAllRows = _ref2.onSelectAllRows,
71
- labels = _ref2.labels;
72
72
  if (labels) {
73
73
  allPageRowsLabel = labels.allPageRows || allPageRowsLabel;
74
74
  allRowsLabel = labels.allRows || allRowsLabel;
@@ -18,7 +18,7 @@ var _classnames = _interopRequireDefault(require("classnames"));
18
18
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
19
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
20
20
  /**
21
- * Copyright IBM Corp. 2022, 2022
21
+ * Copyright IBM Corp. 2022, 2023
22
22
  *
23
23
  * This source code is licensed under the Apache-2.0 license found in the
24
24
  * LICENSE file in the root directory of this source tree.
@@ -26,6 +26,7 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
26
26
 
27
27
  var blockClass = "".concat(_settings.pkg.prefix, "--datagrid");
28
28
  var DatagridBatchActionsToolbar = function DatagridBatchActionsToolbar(datagridState, width, ref) {
29
+ var _Object$keys;
29
30
  var _useState = (0, _react.useState)(false),
30
31
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
31
32
  displayAllInMenu = _useState2[0],
@@ -38,11 +39,12 @@ var DatagridBatchActionsToolbar = function DatagridBatchActionsToolbar(datagridS
38
39
  _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
39
40
  receivedInitialWidth = _useState6[0],
40
41
  setReceivedInitialWidth = _useState6[1];
41
- var selectedFlatRows = datagridState.selectedFlatRows,
42
+ var selectedRowIds = datagridState.state.selectedRowIds,
42
43
  toggleAllRowsSelected = datagridState.toggleAllRowsSelected,
43
44
  toolbarBatchActions = datagridState.toolbarBatchActions,
44
- setGlobalFilter = datagridState.setGlobalFilter;
45
- var totalSelected = selectedFlatRows && selectedFlatRows.length;
45
+ setGlobalFilter = datagridState.setGlobalFilter,
46
+ rows = datagridState.rows;
47
+ var totalSelected = (_Object$keys = Object.keys(selectedRowIds || {})) === null || _Object$keys === void 0 ? void 0 : _Object$keys.length;
46
48
 
47
49
  // Get initial width of batch actions container,
48
50
  // used to measure when all items are put inside
@@ -62,6 +64,19 @@ var DatagridBatchActionsToolbar = function DatagridBatchActionsToolbar(datagridS
62
64
  setDisplayAllInMenu(false);
63
65
  }
64
66
  }, [width, ref, initialListWidth]);
67
+ var getSelectedRowData = function getSelectedRowData() {
68
+ var selectedRowIndexes = Object.keys(selectedRowIds);
69
+ var selectedRowData = selectedRowIndexes && selectedRowIndexes.length ? selectedRowIndexes.map(function (rowIndex) {
70
+ var filteredRow = rows.filter(function (row) {
71
+ return row.index === parseInt(rowIndex);
72
+ });
73
+ if (filteredRow.length) {
74
+ return filteredRow[0];
75
+ }
76
+ return [];
77
+ }) : [];
78
+ return selectedRowData;
79
+ };
65
80
 
66
81
  // Render batch actions in ButtonMenu
67
82
  var renderBatchActionOverflow = function renderBatchActionOverflow() {
@@ -84,8 +99,8 @@ var DatagridBatchActionsToolbar = function DatagridBatchActionsToolbar(datagridS
84
99
  return /*#__PURE__*/_react.default.createElement(_ButtonMenu.ButtonMenuItem, {
85
100
  key: "".concat(batchAction.label, "-").concat(index),
86
101
  itemText: batchAction.label,
87
- onClick: function onClick() {
88
- batchAction.onClick();
102
+ onClick: function onClick(event) {
103
+ batchAction.onClick(getSelectedRowData(), event);
89
104
  if (batchAction.type === 'select_all') {
90
105
  toggleAllRowsSelected(true);
91
106
  }
@@ -97,8 +112,8 @@ var DatagridBatchActionsToolbar = function DatagridBatchActionsToolbar(datagridS
97
112
  return /*#__PURE__*/_react.default.createElement(_ButtonMenu.ButtonMenuItem, {
98
113
  key: "".concat(batchAction.label, "-").concat(index),
99
114
  itemText: batchAction.label,
100
- onClick: function onClick() {
101
- batchAction.onClick();
115
+ onClick: function onClick(event) {
116
+ batchAction.onClick(getSelectedRowData(), event);
102
117
  if (batchAction.type === 'select_all') {
103
118
  toggleAllRowsSelected(true);
104
119
  }
@@ -122,8 +137,8 @@ var DatagridBatchActionsToolbar = function DatagridBatchActionsToolbar(datagridS
122
137
  return /*#__PURE__*/_react.default.createElement(_react2.TableBatchAction, {
123
138
  key: "".concat(batchAction.label, "-").concat(index),
124
139
  renderIcon: batchAction.renderIcon,
125
- onClick: function onClick() {
126
- batchAction.onClick();
140
+ onClick: function onClick(event) {
141
+ batchAction.onClick(getSelectedRowData(), event);
127
142
  if (batchAction.type === 'select_all') {
128
143
  toggleAllRowsSelected(true);
129
144
  }
@@ -59,9 +59,7 @@ var DatagridVirtualBody = function DatagridVirtualBody(datagridState) {
59
59
  var gridRefElement = gridRef === null || gridRef === void 0 ? void 0 : gridRef.current;
60
60
  gridRefElement.style.width = gridRefElement === null || gridRefElement === void 0 ? void 0 : gridRefElement.clientWidth;
61
61
  };
62
- (0, _useResizeObserver.useResizeObserver)(gridRef, {
63
- callback: handleVirtualGridResize
64
- });
62
+ (0, _useResizeObserver.useResizeObserver)(gridRef, handleVirtualGridResize);
65
63
  var syncScroll = function syncScroll(e) {
66
64
  var virtualBody = e.target;
67
65
  document.querySelector(".".concat(blockClass, "__head-wrap")).scrollLeft = virtualBody.scrollLeft;
@@ -29,7 +29,7 @@ var TearsheetWrapper = function TearsheetWrapper(_ref) {
29
29
  rest = (0, _objectWithoutProperties2.default)(_instance$customizeCo, _excluded);
30
30
  return /*#__PURE__*/React.createElement(_CustomizeColumnsTearsheet.default, (0, _extends2.default)({}, rest, labels, {
31
31
  isOpen: isTearsheetOpen,
32
- isTableSortable: instance === null || instance === void 0 ? void 0 : instance.isTableSortable,
32
+ isTableSortable: (instance === null || instance === void 0 ? void 0 : instance.isTableSortable) || false,
33
33
  setIsTearsheetOpen: setIsTearsheetOpen,
34
34
  columnDefinitions: instance.allColumns,
35
35
  originalColumnDefinitions: instance.columns,
@@ -55,11 +55,8 @@ var FilterFlyout = function FilterFlyout(_ref) {
55
55
  setAllFilters = _ref.setAllFilters,
56
56
  _ref$data = _ref.data,
57
57
  data = _ref$data === void 0 ? [] : _ref$data,
58
- _ref$initialFilters = _ref.initialFilters,
59
- initialFilters = _ref$initialFilters === void 0 ? [] : _ref$initialFilters;
60
- // Save the initial filters we only need the filters once when it loads
61
- var initialFiltersRef = (0, _react2.useRef)(initialFilters);
62
-
58
+ _ref$reactTableFilter = _ref.reactTableFiltersState,
59
+ reactTableFiltersState = _ref$reactTableFilter === void 0 ? [] : _ref$reactTableFilter;
63
60
  /** State */
64
61
  var _useState = (0, _react2.useState)(false),
65
62
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
@@ -70,15 +67,17 @@ var FilterFlyout = function FilterFlyout(_ref) {
70
67
  filters: filters,
71
68
  setAllFilters: setAllFilters,
72
69
  variation: _constants.FLYOUT,
73
- initialFilters: initialFiltersRef.current
70
+ reactTableFiltersState: reactTableFiltersState,
71
+ onCancel: onCancel
74
72
  }),
75
73
  filtersState = _useFilters.filtersState,
76
74
  prevFiltersObjectArrayRef = _useFilters.prevFiltersObjectArrayRef,
77
75
  prevFiltersRef = _useFilters.prevFiltersRef,
78
- revertToPreviousFilters = _useFilters.revertToPreviousFilters,
76
+ cancel = _useFilters.cancel,
79
77
  reset = _useFilters.reset,
80
78
  renderFilter = _useFilters.renderFilter,
81
- filtersObjectArray = _useFilters.filtersObjectArray;
79
+ filtersObjectArray = _useFilters.filtersObjectArray,
80
+ lastAppliedFilters = _useFilters.lastAppliedFilters;
82
81
 
83
82
  /** Refs */
84
83
  var filterFlyoutRef = (0, _react2.useRef)(null);
@@ -117,26 +116,10 @@ var FilterFlyout = function FilterFlyout(_ref) {
117
116
  // updates the ref so next time the flyout opens we have records of the previous filters
118
117
  prevFiltersRef.current = JSON.stringify(filtersState);
119
118
  prevFiltersObjectArrayRef.current = JSON.stringify(filtersObjectArray);
120
- };
121
- var cancel = function cancel() {
122
- // Reverting to previous filters only applies when using batch actions
123
- if (updateMethod === _constants.BATCH) {
124
- revertToPreviousFilters();
125
- onCancel();
126
- }
127
- closeFlyout();
128
- };
129
119
 
130
- /** Effects */
131
- (0, _hooks.useClickOutside)(filterFlyoutRef, function (target) {
132
- var hasClickedOnDatePicker = target.closest('.flatpickr-calendar');
133
- var hasClickedOnDropdown = target.className === "".concat(carbonPrefix, "--list-box__menu-item__option");
134
- if (!open || hasClickedOnDatePicker || hasClickedOnDropdown) {
135
- return;
136
- }
137
- cancel();
138
- });
139
- (0, _hooks2.useSubscribeToEventEmitter)(_constants.CLEAR_FILTERS, reset);
120
+ // Update the last applied filters
121
+ lastAppliedFilters.current = JSON.stringify(filtersObjectArray);
122
+ };
140
123
 
141
124
  /** Renders all filters */
142
125
  var renderFilters = function renderFilters() {
@@ -163,22 +146,31 @@ var FilterFlyout = function FilterFlyout(_ref) {
163
146
  buttonSize: "md"
164
147
  });
165
148
  };
149
+
150
+ /** Effects */
151
+ (0, _hooks.useClickOutside)(filterFlyoutRef, function (target) {
152
+ var hasClickedOnDatePicker = target.closest('.flatpickr-calendar');
153
+ var hasClickedOnDropdown = target.className === "".concat(carbonPrefix, "--list-box__menu-item__option");
154
+ if (!open || hasClickedOnDatePicker || hasClickedOnDropdown) {
155
+ return;
156
+ }
157
+ closeFlyout();
158
+ cancel();
159
+ });
160
+ (0, _hooks2.useSubscribeToEventEmitter)(_constants.CLEAR_FILTERS, reset);
161
+ (0, _react2.useEffect)(function reflectLastAppliedFiltersWhenReactTableUpdates() {
162
+ lastAppliedFilters.current = JSON.stringify(reactTableFiltersState);
163
+ }, [reactTableFiltersState, lastAppliedFilters]);
166
164
  return /*#__PURE__*/_react2.default.createElement("div", {
167
165
  className: "".concat(componentClass, "__container")
168
- }, /*#__PURE__*/_react2.default.createElement(_react.Button, {
166
+ }, /*#__PURE__*/_react2.default.createElement(_react.IconButton, {
167
+ label: flyoutIconDescription,
169
168
  kind: "ghost",
170
- hasIconOnly: true,
171
- tooltipPosition: "bottom",
172
- renderIcon: function renderIcon() {
173
- return /*#__PURE__*/_react2.default.createElement(_icons.Filter, {
174
- size: 16
175
- });
176
- },
177
- iconDescription: flyoutIconDescription,
169
+ align: "bottom",
178
170
  onClick: open ? closeFlyout : openFlyout,
179
171
  className: (0, _classnames.default)("".concat(componentClass, "__trigger"), (0, _defineProperty2.default)({}, "".concat(componentClass, "__trigger--open"), open)),
180
172
  disabled: data.length === 0
181
- }), /*#__PURE__*/_react2.default.createElement("div", {
173
+ }, /*#__PURE__*/_react2.default.createElement(_icons.Filter, null)), /*#__PURE__*/_react2.default.createElement("div", {
182
174
  ref: filterFlyoutRef,
183
175
  className: (0, _classnames.default)(componentClass, (_cx2 = {}, (0, _defineProperty2.default)(_cx2, "".concat(componentClass, "--open"), open), (0, _defineProperty2.default)(_cx2, "".concat(componentClass, "--batch"), showActionSet), (0, _defineProperty2.default)(_cx2, "".concat(componentClass, "--instant"), !showActionSet), _cx2))
184
176
  }, /*#__PURE__*/_react2.default.createElement("div", {
@@ -206,14 +198,6 @@ FilterFlyout.propTypes = {
206
198
  * Icon description for the filter flyout button
207
199
  */
208
200
  flyoutIconDescription: _propTypes.default.string,
209
- /**
210
- * Filters that should be applied on load
211
- */
212
- initialFilters: _propTypes.default.arrayOf(_propTypes.default.shape({
213
- id: _propTypes.default.string.isRequired,
214
- type: _propTypes.default.string.isRequired,
215
- value: _propTypes.default.any.isRequired
216
- })),
217
201
  /**
218
202
  * Callback when the apply button is clicked
219
203
  */
@@ -234,6 +218,14 @@ FilterFlyout.propTypes = {
234
218
  * Label text of the primary action in the flyout
235
219
  */
236
220
  primaryActionLabel: _propTypes.default.string,
221
+ /**
222
+ * Filters from react table's state
223
+ */
224
+ reactTableFiltersState: _propTypes.default.arrayOf(_propTypes.default.shape({
225
+ id: _propTypes.default.string.isRequired,
226
+ type: _propTypes.default.string.isRequired,
227
+ value: _propTypes.default.any.isRequired
228
+ })),
237
229
  /**
238
230
  * Label text of the secondary action in the flyout
239
231
  */
@@ -66,11 +66,8 @@ var FilterPanel = function FilterPanel(_ref) {
66
66
  searchLabelText = _ref$searchLabelText === void 0 ? 'Filter search' : _ref$searchLabelText,
67
67
  _ref$searchPlaceholde = _ref.searchPlaceholder,
68
68
  searchPlaceholder = _ref$searchPlaceholde === void 0 ? 'Find filters' : _ref$searchPlaceholde,
69
- _ref$initialFilters = _ref.initialFilters,
70
- initialFilters = _ref$initialFilters === void 0 ? [] : _ref$initialFilters;
71
- // Save the initial filters we only need the filters once
72
- var initialFiltersRef = (0, _react.useRef)(initialFilters);
73
-
69
+ _ref$reactTableFilter = _ref.reactTableFiltersState,
70
+ reactTableFiltersState = _ref$reactTableFilter === void 0 ? [] : _ref$reactTableFilter;
74
71
  /** State */
75
72
  var _useState = (0, _react.useState)(false),
76
73
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
@@ -81,15 +78,17 @@ var FilterPanel = function FilterPanel(_ref) {
81
78
  filters: filterSections,
82
79
  setAllFilters: setAllFilters,
83
80
  variation: _constants.PANEL,
84
- initialFilters: initialFiltersRef.current
81
+ reactTableFiltersState: reactTableFiltersState,
82
+ onCancel: onCancel
85
83
  }),
86
84
  filtersState = _useFilters.filtersState,
87
85
  prevFiltersObjectArrayRef = _useFilters.prevFiltersObjectArrayRef,
88
86
  prevFiltersRef = _useFilters.prevFiltersRef,
89
- revertToPreviousFilters = _useFilters.revertToPreviousFilters,
87
+ cancel = _useFilters.cancel,
90
88
  reset = _useFilters.reset,
91
89
  renderFilter = _useFilters.renderFilter,
92
- filtersObjectArray = _useFilters.filtersObjectArray;
90
+ filtersObjectArray = _useFilters.filtersObjectArray,
91
+ lastAppliedFilters = _useFilters.lastAppliedFilters;
93
92
 
94
93
  /** Refs */
95
94
  var filterPanelRef = (0, _react.useRef)();
@@ -119,14 +118,8 @@ var FilterPanel = function FilterPanel(_ref) {
119
118
 
120
119
  /** Methods */
121
120
  var closePanel = function closePanel() {
122
- return setPanelOpen(false);
123
- };
124
- var cancel = function cancel() {
125
- // Reverting to previous filters only applies when using batch actions
126
- if (updateMethod === _constants.BATCH) {
127
- revertToPreviousFilters();
128
- onCancel();
129
- }
121
+ cancel();
122
+ setPanelOpen(false);
130
123
  };
131
124
  var apply = function apply() {
132
125
  setAllFilters(filtersObjectArray);
@@ -138,6 +131,9 @@ var FilterPanel = function FilterPanel(_ref) {
138
131
  // updates the ref so next time the flyout opens we have records of the previous filters
139
132
  prevFiltersRef.current = JSON.stringify(filtersState);
140
133
  prevFiltersObjectArrayRef.current = JSON.stringify(filtersObjectArray);
134
+
135
+ // Update the last applied filters
136
+ lastAppliedFilters.current = JSON.stringify(filtersObjectArray);
141
137
  };
142
138
  var renderActionSet = function renderActionSet() {
143
139
  return showActionSet && /*#__PURE__*/_react.default.createElement(MotionActionSet, {
@@ -254,20 +250,20 @@ FilterPanel.propTypes = {
254
250
  closeIconDescription: _propTypes.default.string,
255
251
  filterPanelMinHeight: _propTypes.default.number,
256
252
  filterSections: _propTypes.default.array,
257
- /**
258
- * Filters that should be applied on load
259
- */
260
- initialFilters: _propTypes.default.arrayOf(_propTypes.default.shape({
261
- id: _propTypes.default.string.isRequired,
262
- type: _propTypes.default.string.isRequired,
263
- value: _propTypes.default.any.isRequired
264
- })),
265
253
  onApply: _propTypes.default.func,
266
254
  onCancel: _propTypes.default.func,
267
255
  onPanelClose: _propTypes.default.func,
268
256
  onPanelOpen: _propTypes.default.func,
269
257
  open: _propTypes.default.bool,
270
258
  primaryActionLabel: _propTypes.default.string,
259
+ /**
260
+ * Filters from react table's state
261
+ */
262
+ reactTableFiltersState: _propTypes.default.arrayOf(_propTypes.default.shape({
263
+ id: _propTypes.default.string.isRequired,
264
+ type: _propTypes.default.string.isRequired,
265
+ value: _propTypes.default.any.isRequired
266
+ })),
271
267
  searchLabelText: _propTypes.default.string,
272
268
  searchPlaceholder: _propTypes.default.string,
273
269
  secondaryActionLabel: _propTypes.default.string,
@@ -4,16 +4,16 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- Object.defineProperty(exports, "useFilters", {
7
+ Object.defineProperty(exports, "useFilterContext", {
8
8
  enumerable: true,
9
9
  get: function get() {
10
- return _useFilters.default;
10
+ return _useFilterContext.default;
11
11
  }
12
12
  });
13
- Object.defineProperty(exports, "useInitialStateFromFilters", {
13
+ Object.defineProperty(exports, "useFilters", {
14
14
  enumerable: true,
15
15
  get: function get() {
16
- return _useInitialStateFromFilters.default;
16
+ return _useFilters.default;
17
17
  }
18
18
  });
19
19
  Object.defineProperty(exports, "useShouldDisableButtons", {
@@ -28,7 +28,7 @@ Object.defineProperty(exports, "useSubscribeToEventEmitter", {
28
28
  return _useSubscribeToEventEmitter.default;
29
29
  }
30
30
  });
31
- var _useInitialStateFromFilters = _interopRequireDefault(require("./useInitialStateFromFilters"));
32
31
  var _useSubscribeToEventEmitter = _interopRequireDefault(require("./useSubscribeToEventEmitter"));
33
32
  var _useFilters = _interopRequireDefault(require("./useFilters"));
34
- var _useShouldDisableButtons = _interopRequireDefault(require("./useShouldDisableButtons"));
33
+ var _useShouldDisableButtons = _interopRequireDefault(require("./useShouldDisableButtons"));
34
+ var _useFilterContext = _interopRequireDefault(require("./useFilterContext"));
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _FilterProvider = require("../FilterProvider");
8
+ var _react = require("react");
9
+ var useFilterContext = function useFilterContext() {
10
+ // get the context
11
+ var context = (0, _react.useContext)(_FilterProvider.FilterContext);
12
+
13
+ // if `undefined`, throw an error
14
+ if (context === undefined) {
15
+ throw new Error('useFilterContext was used outside of its Provider');
16
+ }
17
+ return context;
18
+ };
19
+ var _default = useFilterContext;
20
+ exports.default = _default;
@@ -13,7 +13,6 @@ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/sli
13
13
  var _react = _interopRequireWildcard(require("react"));
14
14
  var _react2 = require("@carbon/react");
15
15
  var _constants = require("../constants");
16
- var _useInitialStateFromFilters = _interopRequireDefault(require("./useInitialStateFromFilters"));
17
16
  var _utils = require("../utils");
18
17
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
18
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -31,19 +30,22 @@ var useFilters = function useFilters(_ref) {
31
30
  filters = _ref$filters === void 0 ? [] : _ref$filters,
32
31
  setAllFilters = _ref.setAllFilters,
33
32
  variation = _ref.variation,
34
- initialFilters = _ref.initialFilters;
33
+ reactTableFiltersState = _ref.reactTableFiltersState,
34
+ _ref$onCancel = _ref.onCancel,
35
+ onCancel = _ref$onCancel === void 0 ? function () {} : _ref$onCancel;
35
36
  /** State */
36
- var _useInitialStateFromF = (0, _useInitialStateFromFilters.default)(filters, variation, initialFilters),
37
- _useInitialStateFromF2 = (0, _slicedToArray2.default)(_useInitialStateFromF, 2),
38
- filtersState = _useInitialStateFromF2[0],
39
- setFiltersState = _useInitialStateFromF2[1];
40
- var _useState = (0, _react.useState)(initialFilters),
37
+ var _useState = (0, _react.useState)((0, _utils.getInitialStateFromFilters)(filters, variation, reactTableFiltersState)),
41
38
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
42
- filtersObjectArray = _useState2[0],
43
- setFiltersObjectArray = _useState2[1];
39
+ filtersState = _useState2[0],
40
+ setFiltersState = _useState2[1];
41
+ var _useState3 = (0, _react.useState)(reactTableFiltersState),
42
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
43
+ filtersObjectArray = _useState4[0],
44
+ setFiltersObjectArray = _useState4[1];
44
45
 
45
46
  // When using batch actions we have to store the filters to then apply them later
46
47
  var prevFiltersRef = (0, _react.useRef)(JSON.stringify(filtersState));
48
+ var lastAppliedFilters = (0, _react.useRef)(JSON.stringify(reactTableFiltersState));
47
49
  var prevFiltersObjectArrayRef = (0, _react.useRef)(JSON.stringify(filtersObjectArray));
48
50
 
49
51
  /** Methods */
@@ -52,6 +54,7 @@ var useFilters = function useFilters(_ref) {
52
54
  var revertToPreviousFilters = function revertToPreviousFilters() {
53
55
  setFiltersState(JSON.parse(prevFiltersRef.current));
54
56
  setFiltersObjectArray(JSON.parse(prevFiltersObjectArrayRef.current));
57
+ setAllFilters(JSON.parse(lastAppliedFilters.current));
55
58
  };
56
59
  var reset = function reset() {
57
60
  // When we reset we want the "initialFilters" to be an empty array
@@ -163,8 +166,11 @@ var useFilters = function useFilters(_ref) {
163
166
  var type = _ref3.type,
164
167
  column = _ref3.column,
165
168
  components = _ref3.props;
166
- var isPanel = variation === _constants.PANEL;
167
169
  var filter;
170
+ var isPanel = variation === _constants.PANEL;
171
+ if (!type) {
172
+ return console.error("type: ".concat(type, "; does not exist as a type of filter."));
173
+ }
168
174
  switch (type) {
169
175
  case _constants.DATE:
170
176
  filter = /*#__PURE__*/_react.default.createElement(_react2.DatePicker, (0, _extends2.default)({}, components.DatePicker, {
@@ -290,10 +296,31 @@ var useFilters = function useFilters(_ref) {
290
296
  break;
291
297
  }
292
298
  if (isPanel) {
293
- return /*#__PURE__*/_react.default.createElement(_react2.Layer, null, filter);
299
+ return /*#__PURE__*/_react.default.createElement(_react2.Layer, {
300
+ key: column
301
+ }, filter);
294
302
  }
295
- return filter;
303
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, {
304
+ key: column
305
+ }, filter);
296
306
  };
307
+ var cancel = function cancel() {
308
+ // Reverting to previous filters only applies when using batch actions
309
+ if (updateMethod === _constants.BATCH) {
310
+ revertToPreviousFilters();
311
+ onCancel();
312
+ }
313
+ };
314
+
315
+ /** The purpose of this function is to sync any changes in react-tables state.filters array and reflect
316
+ those new filter changes in the panel/flyout state. The external change is triggered if setAllFilters is called outside of the Datagrid */
317
+ (0, _react.useEffect)(function updateStateAndFiltersToReflectExternalFilterChanges() {
318
+ var newFiltersState = (0, _utils.getInitialStateFromFilters)(filters, variation, reactTableFiltersState);
319
+ setFiltersState(newFiltersState);
320
+ prevFiltersRef.current = JSON.stringify(newFiltersState);
321
+ prevFiltersObjectArrayRef.current = JSON.stringify(reactTableFiltersState);
322
+ setFiltersObjectArray(reactTableFiltersState);
323
+ }, [filters, reactTableFiltersState, variation]);
297
324
  return {
298
325
  filtersState: filtersState,
299
326
  setFiltersState: setFiltersState,
@@ -302,7 +329,9 @@ var useFilters = function useFilters(_ref) {
302
329
  revertToPreviousFilters: revertToPreviousFilters,
303
330
  reset: reset,
304
331
  renderFilter: renderFilter,
305
- filtersObjectArray: filtersObjectArray
332
+ filtersObjectArray: filtersObjectArray,
333
+ lastAppliedFilters: lastAppliedFilters,
334
+ cancel: cancel
306
335
  };
307
336
  };
308
337
  var _default = useFilters;