@carbon/ibm-products 1.7.0 → 1.10.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (179) hide show
  1. package/css/index-full-carbon.css +227 -5762
  2. package/css/index-full-carbon.css.map +1 -1
  3. package/css/index-full-carbon.min.css +5 -5
  4. package/css/index-full-carbon.min.css.map +1 -1
  5. package/css/index-without-carbon-released-only.css +46 -3426
  6. package/css/index-without-carbon-released-only.css.map +1 -1
  7. package/css/index-without-carbon-released-only.min.css +3 -3
  8. package/css/index-without-carbon-released-only.min.css.map +1 -1
  9. package/css/index-without-carbon.css +195 -4028
  10. package/css/index-without-carbon.css.map +1 -1
  11. package/css/index-without-carbon.min.css +5 -5
  12. package/css/index-without-carbon.min.css.map +1 -1
  13. package/css/index.css +195 -4029
  14. package/css/index.css.map +1 -1
  15. package/css/index.min.css +5 -5
  16. package/css/index.min.css.map +1 -1
  17. package/es/components/APIKeyModal/APIKeyModal.js +10 -13
  18. package/es/components/ActionBar/ActionBar.js +0 -3
  19. package/es/components/ActionBar/ActionBarItem.js +2 -6
  20. package/es/components/ActionSet/ActionSet.js +10 -12
  21. package/es/components/AddSelect/AddSelect.js +120 -25
  22. package/es/components/AddSelect/AddSelectBreadcrumbs.js +4 -4
  23. package/es/components/AddSelect/AddSelectColumn.js +58 -0
  24. package/es/components/AddSelect/AddSelectList.js +67 -8
  25. package/es/components/AddSelect/AddSelectSidebar.js +7 -1
  26. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +0 -3
  27. package/es/components/ButtonMenu/ButtonMenu.js +7 -5
  28. package/es/components/ButtonMenu/ButtonMenuItem.js +1 -2
  29. package/es/components/Card/Card.js +31 -21
  30. package/es/components/Card/CardFooter.js +14 -10
  31. package/es/components/Card/CardHeader.js +8 -6
  32. package/es/components/Cascade/Cascade.js +5 -4
  33. package/es/components/ComboButton/ComboButton.js +0 -4
  34. package/es/components/ComboButton/ComboButtonItem/index.js +0 -5
  35. package/es/components/CreateFullPage/CreateFullPageStep.js +15 -8
  36. package/es/components/CreateModal/CreateModal.js +1 -4
  37. package/es/components/CreateTearsheet/CreateTearsheet.js +10 -11
  38. package/es/components/CreateTearsheet/CreateTearsheetStep.js +18 -14
  39. package/es/components/DataSpreadsheet/DataSpreadsheet.js +563 -80
  40. package/es/components/DataSpreadsheet/DataSpreadsheetBody.js +366 -0
  41. package/es/components/DataSpreadsheet/DataSpreadsheetHeader.js +81 -0
  42. package/es/components/DataSpreadsheet/checkActiveHeaderCell.js +34 -0
  43. package/es/components/DataSpreadsheet/createActiveCellFn.js +47 -0
  44. package/es/components/DataSpreadsheet/createCellSelectionArea.js +45 -0
  45. package/es/components/DataSpreadsheet/getCellSize.js +30 -0
  46. package/es/components/EditSidePanel/EditSidePanel.js +9 -10
  47. package/es/components/EmptyStates/EmptyState.js +7 -6
  48. package/es/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +4 -8
  49. package/es/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +4 -8
  50. package/es/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +4 -8
  51. package/es/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +4 -8
  52. package/es/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +4 -8
  53. package/es/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +4 -8
  54. package/es/components/ExampleComponent/ExampleComponent.js +12 -13
  55. package/es/components/ExportModal/ExportModal.js +13 -9
  56. package/es/components/ExpressiveCard/ExpressiveCard.js +0 -8
  57. package/es/components/ImportModal/ImportModal.js +7 -5
  58. package/es/components/InlineEdit/InlineEdit.js +44 -46
  59. package/es/components/LoadingBar/LoadingBar.js +13 -17
  60. package/es/components/ModifiedTabs/ModifiedTabLabelNew.js +0 -4
  61. package/es/components/ModifiedTabs/ModifiedTabLabelWithClose.js +0 -5
  62. package/es/components/ModifiedTabs/ModifiedTabs.js +24 -18
  63. package/es/components/NotificationsPanel/NotificationsPanel.js +109 -86
  64. package/es/components/OptionsTile/OptionsTile.js +17 -10
  65. package/es/components/PageHeader/PageHeader.js +58 -47
  66. package/es/components/PageHeader/PageHeaderUtils.js +3 -7
  67. package/es/components/ProductiveCard/ProductiveCard.js +23 -12
  68. package/es/components/RemoveModal/RemoveModal.js +0 -3
  69. package/es/components/SidePanel/SidePanel.js +22 -17
  70. package/es/components/TagSet/TagSet.js +25 -12
  71. package/es/components/TagSet/TagSetModal.js +16 -12
  72. package/es/components/TagSet/TagSetOverflow.js +21 -13
  73. package/es/components/Tearsheet/Tearsheet.js +27 -18
  74. package/es/components/Tearsheet/TearsheetNarrow.js +18 -15
  75. package/es/components/Toolbar/ToolbarButton.js +0 -3
  76. package/es/components/UserProfileImage/UserProfileImage.js +2 -1
  77. package/es/components/WebTerminal/WebTerminal.js +17 -18
  78. package/es/components/index.js +0 -1
  79. package/es/global/js/hooks/index.js +1 -0
  80. package/es/global/js/hooks/useActiveElement.js +27 -0
  81. package/es/global/js/utils/DisplayBox.js +31 -0
  82. package/es/global/js/utils/Wrap.js +7 -5
  83. package/es/global/js/utils/deepCloneObject.js +26 -0
  84. package/lib/components/APIKeyModal/APIKeyModal.js +10 -13
  85. package/lib/components/ActionBar/ActionBar.js +0 -3
  86. package/lib/components/ActionBar/ActionBarItem.js +2 -6
  87. package/lib/components/ActionSet/ActionSet.js +10 -12
  88. package/lib/components/AddSelect/AddSelect.js +118 -24
  89. package/lib/components/AddSelect/AddSelectBreadcrumbs.js +2 -3
  90. package/lib/components/AddSelect/AddSelectColumn.js +79 -0
  91. package/lib/components/AddSelect/AddSelectList.js +65 -8
  92. package/lib/components/AddSelect/AddSelectSidebar.js +7 -1
  93. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +0 -3
  94. package/lib/components/ButtonMenu/ButtonMenu.js +7 -5
  95. package/lib/components/ButtonMenu/ButtonMenuItem.js +1 -2
  96. package/lib/components/Card/Card.js +31 -21
  97. package/lib/components/Card/CardFooter.js +14 -10
  98. package/lib/components/Card/CardHeader.js +8 -6
  99. package/lib/components/Cascade/Cascade.js +5 -4
  100. package/lib/components/ComboButton/ComboButton.js +0 -4
  101. package/lib/components/ComboButton/ComboButtonItem/index.js +0 -5
  102. package/lib/components/CreateFullPage/CreateFullPageStep.js +17 -14
  103. package/lib/components/CreateModal/CreateModal.js +1 -4
  104. package/lib/components/CreateTearsheet/CreateTearsheet.js +10 -11
  105. package/lib/components/CreateTearsheet/CreateTearsheetStep.js +20 -20
  106. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +567 -77
  107. package/lib/components/DataSpreadsheet/DataSpreadsheetBody.js +391 -0
  108. package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.js +99 -0
  109. package/lib/components/DataSpreadsheet/checkActiveHeaderCell.js +45 -0
  110. package/lib/components/DataSpreadsheet/createActiveCellFn.js +58 -0
  111. package/lib/components/DataSpreadsheet/createCellSelectionArea.js +56 -0
  112. package/lib/components/DataSpreadsheet/getCellSize.js +39 -0
  113. package/lib/components/EditSidePanel/EditSidePanel.js +9 -10
  114. package/lib/components/EmptyStates/EmptyState.js +9 -8
  115. package/lib/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +3 -7
  116. package/lib/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +3 -7
  117. package/lib/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +3 -7
  118. package/lib/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +3 -7
  119. package/lib/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +3 -7
  120. package/lib/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +3 -7
  121. package/lib/components/ExampleComponent/ExampleComponent.js +12 -13
  122. package/lib/components/ExportModal/ExportModal.js +13 -9
  123. package/lib/components/ExpressiveCard/ExpressiveCard.js +0 -8
  124. package/lib/components/ImportModal/ImportModal.js +7 -5
  125. package/lib/components/InlineEdit/InlineEdit.js +43 -45
  126. package/lib/components/LoadingBar/LoadingBar.js +13 -17
  127. package/lib/components/ModifiedTabs/ModifiedTabLabelNew.js +0 -4
  128. package/lib/components/ModifiedTabs/ModifiedTabLabelWithClose.js +0 -5
  129. package/lib/components/ModifiedTabs/ModifiedTabs.js +24 -18
  130. package/lib/components/NotificationsPanel/NotificationsPanel.js +109 -86
  131. package/lib/components/OptionsTile/OptionsTile.js +17 -10
  132. package/lib/components/PageHeader/PageHeader.js +56 -46
  133. package/lib/components/PageHeader/PageHeaderUtils.js +3 -7
  134. package/lib/components/ProductiveCard/ProductiveCard.js +24 -18
  135. package/lib/components/RemoveModal/RemoveModal.js +0 -3
  136. package/lib/components/SidePanel/SidePanel.js +22 -17
  137. package/lib/components/TagSet/TagSet.js +26 -12
  138. package/lib/components/TagSet/TagSetModal.js +17 -13
  139. package/lib/components/TagSet/TagSetOverflow.js +24 -19
  140. package/lib/components/Tearsheet/Tearsheet.js +26 -17
  141. package/lib/components/Tearsheet/TearsheetNarrow.js +18 -15
  142. package/lib/components/Toolbar/ToolbarButton.js +0 -3
  143. package/lib/components/UserProfileImage/UserProfileImage.js +2 -1
  144. package/lib/components/WebTerminal/WebTerminal.js +17 -18
  145. package/lib/components/index.js +0 -8
  146. package/lib/global/js/hooks/index.js +8 -0
  147. package/lib/global/js/hooks/useActiveElement.js +39 -0
  148. package/lib/global/js/utils/DisplayBox.js +46 -0
  149. package/lib/global/js/utils/Wrap.js +7 -5
  150. package/lib/global/js/utils/deepCloneObject.js +37 -0
  151. package/package.json +18 -18
  152. package/scss/components/{CancelableTextEdit/_index.scss → ActionBar/_storybook-styles.scss} +2 -2
  153. package/scss/components/ActionSet/_storybook-styles.scss +1 -3
  154. package/scss/components/AddSelect/_add-select.scss +83 -14
  155. package/scss/components/{CancelableTextEdit → BreadcrumbWithOverflow}/_storybook-styles.scss +2 -2
  156. package/scss/components/ButtonSetWithOverflow/_storybook-styles.scss +8 -0
  157. package/scss/components/CreateInfluencer/_create-influencer.scss +2 -0
  158. package/scss/components/CreateModal/_create-modal.scss +1 -0
  159. package/scss/components/CreateTearsheet/_create-tearsheet.scss +1 -0
  160. package/scss/components/CreateTearsheetNarrow/_create-tearsheet-narrow.scss +1 -0
  161. package/scss/components/DataSpreadsheet/_data-spreadsheet.scss +53 -7
  162. package/scss/components/InlineEdit/_inline-edit.scss +36 -15
  163. package/scss/components/InlineEdit/_storybook-styles.scss +2 -0
  164. package/scss/components/LoadingBar/_loading-bar.scss +13 -0
  165. package/scss/components/NotificationsPanel/_notifications-panel.scss +3 -0
  166. package/scss/components/PageHeader/_page-header.scss +2 -0
  167. package/scss/components/SidePanel/_side-panel.scss +11 -4
  168. package/scss/components/StatusIcon/_status-icon.scss +1 -0
  169. package/scss/components/TagSet/_storybook-styles.scss +8 -0
  170. package/scss/components/Tearsheet/_tearsheet.scss +1 -2
  171. package/scss/components/UserProfileImage/_user-profile-image.scss +9 -0
  172. package/scss/components/WebTerminal/_web-terminal.scss +2 -0
  173. package/scss/components/_index.scss +0 -1
  174. package/scss/global/styles/_display-box.scss +62 -0
  175. package/es/components/CancelableTextEdit/CancelableTextEdit.js +0 -245
  176. package/es/components/CancelableTextEdit/index.js +0 -7
  177. package/lib/components/CancelableTextEdit/CancelableTextEdit.js +0 -265
  178. package/lib/components/CancelableTextEdit/index.js +0 -13
  179. package/scss/components/CancelableTextEdit/_cancelable-text-edit.scss +0 -212
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Copyright IBM Corp. 2022, 2022
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 PropTypes from 'prop-types';
8
+ import React from 'react';
9
+ import cx from 'classnames';
10
+ var blockClass = 'ccs-sb--display-box';
11
+ export var DisplayBox = function DisplayBox(_ref) {
12
+ var children = _ref.children,
13
+ className = _ref.className,
14
+ msg = _ref.msg;
15
+ return /*#__PURE__*/React.createElement("div", {
16
+ className: cx(blockClass, className)
17
+ }, /*#__PURE__*/React.createElement("div", {
18
+ className: "".concat(blockClass, "__indicator")
19
+ }, /*#__PURE__*/React.createElement("div", {
20
+ className: "".concat(blockClass, "__message")
21
+ }, msg || /*#__PURE__*/React.createElement(React.Fragment, null, "width available to component", /*#__PURE__*/React.createElement("br", null), "(use containerWidth control to adjust)")), /*#__PURE__*/React.createElement("div", {
22
+ className: "".concat(blockClass, "__indicator--left")
23
+ }), /*#__PURE__*/React.createElement("div", {
24
+ className: "".concat(blockClass, "__indicator--right")
25
+ })), children);
26
+ };
27
+ DisplayBox.propTypes = {
28
+ children: PropTypes.node,
29
+ className: PropTypes.string,
30
+ msg: PropTypes.node
31
+ };
@@ -25,6 +25,11 @@ var isEmpty = function isEmpty(children) {
25
25
  }
26
26
  });
27
27
  return result;
28
+ }; // Default values for props
29
+
30
+
31
+ var defaults = {
32
+ element: 'div'
28
33
  };
29
34
  /**
30
35
  * A simple conditional wrapper that encloses its children in a <div> (or other
@@ -37,11 +42,11 @@ var isEmpty = function isEmpty(children) {
37
42
  * remain undefined if it does not render.
38
43
  */
39
44
 
40
-
41
45
  export var Wrap = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
42
46
  var alwaysRender = _ref.alwaysRender,
43
47
  children = _ref.children,
44
- Wrapper = _ref.element,
48
+ _ref$element = _ref.element,
49
+ Wrapper = _ref$element === void 0 ? defaults.element : _ref$element,
45
50
  neverRender = _ref.neverRender,
46
51
  rest = _objectWithoutProperties(_ref, _excluded);
47
52
 
@@ -79,7 +84,4 @@ Wrap.propTypes = {
79
84
  * content will be rendered.
80
85
  */
81
86
  neverRender: PropTypes.bool
82
- };
83
- Wrap.defaultProps = {
84
- element: 'div'
85
87
  };
@@ -0,0 +1,26 @@
1
+ import _typeof from "@babel/runtime/helpers/typeof";
2
+
3
+ /**
4
+ * Copyright IBM Corp. 2022, 2022
5
+ *
6
+ * This source code is licensed under the Apache-2.0 license found in the
7
+ * LICENSE file in the root directory of this source tree.
8
+ */
9
+ // Utility to return a deep clone of a nested object or array.
10
+ export var deepCloneObject = function deepCloneObject(objectToClone) {
11
+ // Return the value if objectToClone is not an object
12
+ if (_typeof(objectToClone) !== 'object' || objectToClone === null) {
13
+ return objectToClone;
14
+ } // Create a new array/object to hold the values
15
+
16
+
17
+ var clonedObject = Array.isArray(objectToClone) ? [] : {};
18
+
19
+ for (var key in objectToClone) {
20
+ var value = objectToClone[key]; // Recursively check for nested objects/arrays
21
+
22
+ clonedObject[key] = deepCloneObject(value);
23
+ }
24
+
25
+ return clonedObject;
26
+ };
@@ -51,18 +51,25 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
51
51
 
52
52
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
53
53
 
54
- var componentName = 'APIKeyModal';
54
+ var componentName = 'APIKeyModal'; // Default values for props
55
+
56
+ var defaults = {
57
+ apiKeyName: '',
58
+ customSteps: Object.freeze([])
59
+ };
55
60
  var APIKeyModal = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
56
61
  var apiKey = _ref.apiKey,
57
62
  apiKeyLabel = _ref.apiKeyLabel,
58
- apiKeyName = _ref.apiKeyName,
63
+ _ref$apiKeyName = _ref.apiKeyName,
64
+ apiKeyName = _ref$apiKeyName === void 0 ? defaults.apiKeyName : _ref$apiKeyName,
59
65
  body = _ref.body,
60
66
  className = _ref.className,
61
67
  closeButtonText = _ref.closeButtonText,
62
68
  copyButtonText = _ref.copyButtonText,
63
69
  copyErrorText = _ref.copyErrorText,
64
70
  copyIconDescription = _ref.copyIconDescription,
65
- customSteps = _ref.customSteps,
71
+ _ref$customSteps = _ref.customSteps,
72
+ customSteps = _ref$customSteps === void 0 ? defaults.customSteps : _ref$customSteps,
66
73
  downloadBodyText = _ref.downloadBodyText,
67
74
  downloadFileName = _ref.downloadFileName,
68
75
  downloadFileType = _ref.downloadFileType,
@@ -602,14 +609,4 @@ APIKeyModal.propTypes = {
602
609
  */
603
610
  showAPIKeyLabel: _propTypes.default.string
604
611
  };
605
- APIKeyModal.defaultProps = {
606
- apiKeyName: '',
607
- customSteps: [],
608
- error: false,
609
- hasAPIKeyVisibilityToggle: false,
610
- hasDownloadLink: false,
611
- loading: false,
612
- nameRequired: false,
613
- open: false
614
- };
615
612
  APIKeyModal.displayName = componentName;
@@ -291,7 +291,4 @@ ActionBar.propTypes = {
291
291
  * align tags to right of available space
292
292
  */
293
293
  rightAlign: _propTypes.default.bool
294
- };
295
- ActionBar.defaultProps = {
296
- rightAlign: false
297
294
  };
@@ -56,14 +56,11 @@ exports.ActionBarItem = ActionBarItem = _settings.pkg.checkComponentEnabled(Acti
56
56
 
57
57
  var reservedProps = ['hasIconOnly', 'kind', 'size', 'tooltipPosition', 'tooltipAlignment', 'type']; // Base props on Carbon Button
58
58
 
59
- var propTypes = _objectSpread({}, _carbonComponentsReact.Button.propTypes);
60
-
61
- var defaultProps = _objectSpread({}, _carbonComponentsReact.Button.defaultProps); // Remove reserved props
59
+ var propTypes = _objectSpread({}, _carbonComponentsReact.Button.propTypes); // Remove reserved props
62
60
 
63
61
 
64
62
  reservedProps.forEach(function (prop) {
65
63
  delete propTypes[prop];
66
- delete defaultProps[prop];
67
64
  });
68
65
  ActionBarItem.displayName = componentName;
69
66
  ActionBarItem.propTypes = _objectSpread(_objectSpread({}, propTypes), {}, {
@@ -103,5 +100,4 @@ ActionBarItem.propTypes = _objectSpread(_objectSpread({}, propTypes), {}, {
103
100
  * (inherited from Carbon Button)
104
101
  */
105
102
  renderIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object])
106
- });
107
- ActionBarItem.defaultProps = _objectSpread({}, defaultProps);
103
+ });
@@ -25,7 +25,7 @@ var _propsHelper = require("../../global/js/utils/props-helper");
25
25
 
26
26
  var _carbonComponentsReact = require("carbon-components-react");
27
27
 
28
- var _excluded = ["className", "disabled", "kind", "label", "loading", "onClick", "size"],
28
+ var _excluded = ["className", "disabled", "kind", "label", "loading"],
29
29
  _excluded2 = ["actions", "buttonSize", "className", "size"];
30
30
 
31
31
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
@@ -41,17 +41,13 @@ var ActionSetButton = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref
41
41
  kind = _ref.kind,
42
42
  label = _ref.label,
43
43
  loading = _ref.loading,
44
- onClick = _ref.onClick,
45
- size = _ref.size,
46
44
  rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
47
45
  return /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Button, (0, _extends2.default)({}, rest, {
48
46
  isExpressive: true,
49
47
  className: (0, _classnames.default)(className, ["".concat(blockClass, "__action-button"), (0, _defineProperty2.default)({}, "".concat(blockClass, "__action-button--ghost"), kind === 'ghost' || kind === 'danger--ghost')]),
50
48
  disabled: disabled || loading || false,
51
49
  kind: kind,
52
- onClick: onClick,
53
- ref: ref,
54
- size: size
50
+ ref: ref
55
51
  }), label, loading && /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.InlineLoading, null));
56
52
  });
57
53
 
@@ -65,6 +61,11 @@ var defaultKind = 'primary';
65
61
 
66
62
  var willStack = function willStack(size, numberOfActions) {
67
63
  return size === 'xs' || size === 'sm' || size === 'md' && numberOfActions > 2;
64
+ }; // Default values for props
65
+
66
+
67
+ var defaults = {
68
+ size: 'md'
68
69
  };
69
70
  /**
70
71
  * An ActionSet presents a set of action buttons, constructed from bundles
@@ -79,14 +80,14 @@ var willStack = function willStack(size, numberOfActions) {
79
80
  * right.
80
81
  */
81
82
 
82
-
83
83
  var ActionSet = /*#__PURE__*/_react.default.forwardRef(function (_ref3, ref) {
84
84
  var _actions$slice, _cx;
85
85
 
86
86
  var actions = _ref3.actions,
87
87
  buttonSize = _ref3.buttonSize,
88
88
  className = _ref3.className,
89
- size = _ref3.size,
89
+ _ref3$size = _ref3.size,
90
+ size = _ref3$size === void 0 ? defaults.size : _ref3$size,
90
91
  rest = (0, _objectWithoutProperties2.default)(_ref3, _excluded2);
91
92
  var buttons = actions && ((_actions$slice = actions.slice) === null || _actions$slice === void 0 ? void 0 : _actions$slice.call(actions, 0)) || []; // We stack the buttons in a xs/sm set, or if there are three or more in a md set.
92
93
 
@@ -147,7 +148,7 @@ ActionSet.validateActions = function (sizeFn) {
147
148
  var problems = [];
148
149
 
149
150
  if (actions > 0) {
150
- var size = sizeFn ? sizeFn(props) : props.size;
151
+ var size = sizeFn ? sizeFn(props) : props.size || defaults.size;
151
152
  var stacking = willStack(size, actions);
152
153
 
153
154
  var countActions = function countActions(kind) {
@@ -211,7 +212,4 @@ ActionSet.propTypes = {
211
212
  * different sizes, to make best use of the available space.
212
213
  */
213
214
  size: _propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xlg', 'max'])
214
- };
215
- ActionSet.defaultProps = {
216
- size: 'md'
217
215
  };
@@ -37,21 +37,34 @@ var _AddSelectBreadcrumbs = require("./AddSelectBreadcrumbs");
37
37
 
38
38
  var _AddSelectList = require("./AddSelectList");
39
39
 
40
- var _excluded = ["className", "description", "influencerTitle", "inputPlaceholder", "items", "itemsLabel", "multi", "noResultsDescription", "noResultsTitle", "noSelectionDescription", "noSelectionTitle", "onClose", "onCloseButtonText", "onSearchFilter", "onSubmit", "onSubmitButtonText", "open", "removeIconDescription", "textInputLabel", "title"];
40
+ var _AddSelectColumn = require("./AddSelectColumn");
41
+
42
+ var _excluded = ["className", "columnInputPlaceholder", "description", "influencerTitle", "inputPlaceholder", "items", "itemsLabel", "multi", "noResultsDescription", "noResultsTitle", "noSelectionDescription", "noSelectionTitle", "onClose", "onCloseButtonText", "onSearchFilter", "onSubmit", "onSubmitButtonText", "open", "removeIconDescription", "textInputLabel", "title"],
43
+ _excluded2 = ["children"];
41
44
 
42
45
  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); }
43
46
 
44
47
  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; }
45
48
 
46
- var componentName = 'AddSelect';
49
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
50
+
51
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
52
+
53
+ var componentName = 'AddSelect'; // Default values for props
54
+
55
+ var defaults = {
56
+ items: Object.freeze([])
57
+ };
47
58
  var AddSelect = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
48
59
  var _cx;
49
60
 
50
61
  var className = _ref.className,
62
+ columnInputPlaceholder = _ref.columnInputPlaceholder,
51
63
  description = _ref.description,
52
64
  influencerTitle = _ref.influencerTitle,
53
65
  inputPlaceholder = _ref.inputPlaceholder,
54
- items = _ref.items,
66
+ _ref$items = _ref.items,
67
+ items = _ref$items === void 0 ? defaults.items : _ref$items,
55
68
  itemsLabel = _ref.itemsLabel,
56
69
  multi = _ref.multi,
57
70
  noResultsDescription = _ref.noResultsDescription,
@@ -88,7 +101,78 @@ var AddSelect = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
88
101
  var _useState7 = (0, _react.useState)(''),
89
102
  _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
90
103
  searchTerm = _useState8[0],
91
- setSearchTerm = _useState8[1]; // handlers
104
+ setSearchTerm = _useState8[1];
105
+
106
+ var _useState9 = (0, _react.useState)({}),
107
+ _useState10 = (0, _slicedToArray2.default)(_useState9, 2),
108
+ normalizedItems = _useState10[0],
109
+ setNormalizedItems = _useState10[1];
110
+
111
+ var _useState11 = (0, _react.useState)(false),
112
+ _useState12 = (0, _slicedToArray2.default)(_useState11, 2),
113
+ useNormalizedItems = _useState12[0],
114
+ setUsedNormalizedItems = _useState12[1];
115
+
116
+ (0, _react.useEffect)(function () {
117
+ var normalize = function normalize(arr, parentId) {
118
+ return arr.reduce(function (acc, cur) {
119
+ var children = cur.children,
120
+ item = (0, _objectWithoutProperties2.default)(cur, _excluded2);
121
+ acc[cur.id] = _objectSpread({}, item);
122
+
123
+ if (parentId) {
124
+ acc[cur.id].parent = parentId;
125
+ }
126
+
127
+ if (children) {
128
+ acc[cur.id].children = children.map(function (child) {
129
+ return child.id;
130
+ });
131
+ var child = normalize(children, cur.id);
132
+ return _objectSpread(_objectSpread({}, acc), child);
133
+ }
134
+
135
+ return acc;
136
+ }, {});
137
+ };
138
+
139
+ if (multi && items.find(function (item) {
140
+ return item.children;
141
+ })) {
142
+ var newItems = normalize(items);
143
+ setNormalizedItems(newItems);
144
+ setUsedNormalizedItems(true);
145
+ }
146
+ }, [items, multi]);
147
+
148
+ var getPages = function getPages() {
149
+ var results = [];
150
+ var itemIds = Object.keys(normalizedItems);
151
+ var topLevelItems = [];
152
+ itemIds.forEach(function (itemId) {
153
+ if (!normalizedItems[itemId].parent) {
154
+ topLevelItems.push(normalizedItems[itemId]);
155
+ }
156
+ });
157
+ results.push(topLevelItems);
158
+
159
+ if (path.length) {
160
+ var pathIds = path.map(function (p) {
161
+ return p.id;
162
+ });
163
+ pathIds.forEach(function (pathId) {
164
+ var childItems = [];
165
+ itemIds.forEach(function (itemId) {
166
+ if (normalizedItems[itemId].parent === pathId) {
167
+ childItems.push(normalizedItems[itemId]);
168
+ }
169
+ });
170
+ results.push(childItems);
171
+ });
172
+ }
173
+
174
+ return results;
175
+ }; // handlers
92
176
 
93
177
 
94
178
  var handleSearch = function handleSearch(e) {
@@ -125,7 +209,16 @@ var AddSelect = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
125
209
  return results;
126
210
  };
127
211
 
128
- var filteredItems = getFilteredItems(); // main content
212
+ var itemsToDisplay = useNormalizedItems ? getPages() : getFilteredItems();
213
+ var commonListProps = {
214
+ multi: multi,
215
+ multiSelection: multiSelection,
216
+ path: path,
217
+ setMultiSelection: setMultiSelection,
218
+ setPath: setPath,
219
+ setSingleSelection: setSingleSelection,
220
+ singleSelection: singleSelection
221
+ }; // main content
129
222
 
130
223
  var body = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
131
224
  className: "".concat(blockClass, "__header")
@@ -136,32 +229,35 @@ var AddSelect = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
136
229
  value: searchTerm,
137
230
  onChange: handleSearch
138
231
  }), /*#__PURE__*/_react.default.createElement("div", {
139
- className: "".concat(blockClass, "__items-label-container")
232
+ className: "".concat(blockClass, "__tag-container")
140
233
  }, path.length ? /*#__PURE__*/_react.default.createElement(_AddSelectBreadcrumbs.AddSelectBreadcrumbs, {
141
234
  itemsLabel: itemsLabel,
142
235
  path: path,
143
236
  setPath: setPath
144
237
  }) : /*#__PURE__*/_react.default.createElement("p", {
145
- className: "".concat(blockClass, "__items-label")
146
- }, itemsLabel), /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Tag, {
238
+ className: "".concat(blockClass, "__tag-container-label")
239
+ }, itemsLabel), !useNormalizedItems && /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Tag, {
147
240
  type: "gray",
148
- size: "sm",
149
- className: "".concat(blockClass, "__items-label-tag")
150
- }, filteredItems.length))), filteredItems.length > 0 ? /*#__PURE__*/_react.default.createElement(_AddSelectList.AddSelectList, {
151
- filteredItems: filteredItems,
152
- multi: multi,
153
- multiSelection: multiSelection,
154
- path: path,
155
- setMultiSelection: setMultiSelection,
156
- setPath: setPath,
157
- setSingleSelection: setSingleSelection,
158
- singleSelection: singleSelection
159
- }) : /*#__PURE__*/_react.default.createElement("div", {
241
+ size: "sm"
242
+ }, itemsToDisplay.length))), useNormalizedItems ? /*#__PURE__*/_react.default.createElement("div", {
243
+ className: "".concat(blockClass, "__columns")
244
+ }, itemsToDisplay.map(function (page, idx) {
245
+ var _path;
246
+
247
+ return /*#__PURE__*/_react.default.createElement(_AddSelectColumn.AddSelectColumn, (0, _extends2.default)({}, commonListProps, {
248
+ key: idx,
249
+ filteredItems: page,
250
+ header: idx === 0 ? itemsLabel : (_path = path[idx - 1]) === null || _path === void 0 ? void 0 : _path.title,
251
+ columnInputPlaceholder: columnInputPlaceholder
252
+ }));
253
+ })) : /*#__PURE__*/_react.default.createElement("div", null, itemsToDisplay.length > 0 ? /*#__PURE__*/_react.default.createElement(_AddSelectList.AddSelectList, (0, _extends2.default)({}, commonListProps, {
254
+ filteredItems: itemsToDisplay
255
+ })) : /*#__PURE__*/_react.default.createElement("div", {
160
256
  className: "".concat(blockClass, "__body")
161
257
  }, /*#__PURE__*/_react.default.createElement(_NoDataEmptyState.NoDataEmptyState, {
162
258
  subtitle: noResultsDescription,
163
259
  title: noResultsTitle
164
- })));
260
+ }))));
165
261
 
166
262
  var commonTearsheetProps = {
167
263
  open: open,
@@ -200,6 +296,7 @@ var AddSelect = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
200
296
  exports.AddSelect = AddSelect;
201
297
  AddSelect.propTypes = {
202
298
  className: _propTypes.default.string,
299
+ columnInputPlaceholder: _propTypes.default.string,
203
300
  description: _propTypes.default.string,
204
301
  influencerTitle: _propTypes.default.string,
205
302
  inputPlaceholder: _propTypes.default.string,
@@ -224,7 +321,4 @@ AddSelect.propTypes = {
224
321
  textInputLabel: _propTypes.default.string,
225
322
  title: _propTypes.default.string
226
323
  };
227
- AddSelect.defaultProps = {
228
- items: []
229
- };
230
324
  AddSelect.displayName = componentName;
@@ -29,11 +29,10 @@ var AddSelectBreadcrumbs = function AddSelectBreadcrumbs(_ref) {
29
29
  setPath = _ref.setPath;
30
30
 
31
31
  var clickHandler = function clickHandler(id) {
32
- var newPath = (0, _toConsumableArray2.default)(path);
33
- var pathIdx = newPath.findIndex(function (entry) {
32
+ var pathIdx = path.findIndex(function (entry) {
34
33
  return entry.id === id;
35
34
  });
36
- var finalPath = newPath.splice(0, pathIdx + 1);
35
+ var finalPath = (0, _toConsumableArray2.default)(path).splice(0, pathIdx + 1);
37
36
  setPath(finalPath);
38
37
  };
39
38
 
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.AddSelectColumn = void 0;
11
+
12
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _propTypes = _interopRequireDefault(require("prop-types"));
21
+
22
+ var _carbonComponentsReact = require("carbon-components-react");
23
+
24
+ var _settings = require("../../settings");
25
+
26
+ var _AddSelectList = require("./AddSelectList");
27
+
28
+ var _excluded = ["columnInputPlaceholder", "filteredItems", "header"];
29
+
30
+ 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); }
31
+
32
+ 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; }
33
+
34
+ var componentName = 'AddSelect';
35
+
36
+ var AddSelectColumn = function AddSelectColumn(_ref) {
37
+ var columnInputPlaceholder = _ref.columnInputPlaceholder,
38
+ filteredItems = _ref.filteredItems,
39
+ header = _ref.header,
40
+ props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
41
+
42
+ var _useState = (0, _react.useState)(''),
43
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
44
+ searchTerm = _useState2[0],
45
+ setSearchTerm = _useState2[1];
46
+
47
+ var blockClass = "".concat(_settings.pkg.prefix, "--add-select");
48
+ var colItems = filteredItems.filter(function (item) {
49
+ return item.title.toLowerCase().includes(searchTerm);
50
+ });
51
+ return /*#__PURE__*/_react.default.createElement("div", {
52
+ className: "".concat(blockClass, "__column")
53
+ }, /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.TextInput, {
54
+ value: searchTerm,
55
+ onChange: function onChange(e) {
56
+ return setSearchTerm(e.target.value);
57
+ },
58
+ light: true,
59
+ placeholder: columnInputPlaceholder
60
+ }), /*#__PURE__*/_react.default.createElement("div", {
61
+ className: "".concat(blockClass, "__tag-container")
62
+ }, /*#__PURE__*/_react.default.createElement("p", {
63
+ className: "".concat(blockClass, "__tag-container-label")
64
+ }, header), /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Tag, {
65
+ type: "gray",
66
+ size: "sm"
67
+ }, colItems.length)), /*#__PURE__*/_react.default.createElement(_AddSelectList.AddSelectList, (0, _extends2.default)({}, props, {
68
+ inColumn: true,
69
+ filteredItems: colItems
70
+ })));
71
+ };
72
+
73
+ exports.AddSelectColumn = AddSelectColumn;
74
+ AddSelectColumn.propTypes = {
75
+ columnInputPlaceholder: _propTypes.default.string,
76
+ filteredItems: _propTypes.default.array,
77
+ header: _propTypes.default.string
78
+ };
79
+ AddSelectColumn.displayName = componentName;
@@ -29,6 +29,7 @@ var componentName = 'AddSelectList';
29
29
 
30
30
  var AddSelectList = function AddSelectList(_ref) {
31
31
  var filteredItems = _ref.filteredItems,
32
+ inColumn = _ref.inColumn,
32
33
  multi = _ref.multi,
33
34
  multiSelection = _ref.multiSelection,
34
35
  path = _ref.path,
@@ -57,11 +58,59 @@ var AddSelectList = function AddSelectList(_ref) {
57
58
 
58
59
  var onNavigateItem = function onNavigateItem(_ref2) {
59
60
  var id = _ref2.id,
60
- title = _ref2.title;
61
- setPath([].concat((0, _toConsumableArray2.default)(path), [{
62
- id: id,
63
- title: title
64
- }]));
61
+ title = _ref2.title,
62
+ parent = _ref2.parent;
63
+
64
+ // if multi select
65
+ if (multi) {
66
+ // if top level reset the path
67
+ if (!parent) {
68
+ setPath([{
69
+ id: id,
70
+ title: title
71
+ }]);
72
+ } else {
73
+ var pathIds = path.map(function (p) {
74
+ return p.id;
75
+ }); // if item is already selected somewhere go back to that item
76
+
77
+ if (pathIds.includes(id)) {
78
+ var pathIdx = pathIds.findIndex(function (pathId) {
79
+ return pathId === id;
80
+ });
81
+ var newPath = (0, _toConsumableArray2.default)(path).splice(0, pathIdx + 1);
82
+ setPath((0, _toConsumableArray2.default)(newPath));
83
+ } else {
84
+ // if the item is on the same level as another selected item start from the parent level
85
+ if (path.find(function (p) {
86
+ return p.parent === parent;
87
+ })) {
88
+ var parentIdx = path.findIndex(function (p) {
89
+ return p.id === parent;
90
+ });
91
+
92
+ var _newPath = (0, _toConsumableArray2.default)(path).splice(0, parentIdx + 1);
93
+
94
+ setPath([].concat((0, _toConsumableArray2.default)(_newPath), [{
95
+ id: id,
96
+ title: title,
97
+ parent: parent
98
+ }]));
99
+ } else {
100
+ setPath([].concat((0, _toConsumableArray2.default)(path), [{
101
+ id: id,
102
+ title: title,
103
+ parent: parent
104
+ }]));
105
+ }
106
+ }
107
+ }
108
+ } else {
109
+ setPath([].concat((0, _toConsumableArray2.default)(path), [{
110
+ id: id,
111
+ title: title
112
+ }]));
113
+ }
65
114
  };
66
115
 
67
116
  return /*#__PURE__*/_react.default.createElement("div", {
@@ -71,15 +120,22 @@ var AddSelectList = function AddSelectList(_ref) {
71
120
  className: "".concat(blockClass)
72
121
  }, /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.StructuredListBody, null, filteredItems.map(function (item) {
73
122
  return /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.StructuredListRow, {
74
- key: item.id
75
- }, /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.StructuredListCell, null, /*#__PURE__*/_react.default.createElement("div", {
123
+ key: item.id,
124
+ className: "".concat(blockClass, "-row")
125
+ }, /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.StructuredListCell, {
126
+ className: "".concat(blockClass, "-cell")
127
+ }, /*#__PURE__*/_react.default.createElement("div", {
76
128
  className: "".concat(blockClass, "-cell-wrapper")
77
129
  }, multi ? /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Checkbox, {
78
130
  className: "".concat(blockClass, "-checkbox"),
79
131
  onChange: function onChange(value) {
80
132
  return handleMultiSelection(item.id, value);
81
133
  },
82
- labelText: item.title,
134
+ labelText: !inColumn ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
135
+ className: "".concat(blockClass, "-cell-title")
136
+ }, item.title), /*#__PURE__*/_react.default.createElement("span", {
137
+ className: "".concat(blockClass, "-cell-subtitle")
138
+ }, item.subtitle)) : item.title,
83
139
  id: item.id,
84
140
  checked: multiSelection.includes(item.id)
85
141
  }) : /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.RadioButton, {
@@ -101,6 +157,7 @@ var AddSelectList = function AddSelectList(_ref) {
101
157
  exports.AddSelectList = AddSelectList;
102
158
  AddSelectList.propTypes = {
103
159
  filteredItems: _propTypes.default.array,
160
+ inColumn: _propTypes.default.bool,
104
161
  multi: _propTypes.default.bool,
105
162
  multiSelection: _propTypes.default.array,
106
163
  path: _propTypes.default.array,
@@ -63,7 +63,13 @@ var AddSelectSidebar = function AddSelectSidebar(_ref) {
63
63
  id = _ref2.id;
64
64
  return /*#__PURE__*/_react.default.createElement("div", {
65
65
  className: "".concat(blockClass, "-accordion-title")
66
- }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("p", null, title), /*#__PURE__*/_react.default.createElement("p", null, subtitle)), /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Button, {
66
+ }, /*#__PURE__*/_react.default.createElement("div", {
67
+ className: "".concat(blockClass, "-selected-item")
68
+ }, /*#__PURE__*/_react.default.createElement("p", {
69
+ className: "".concat(blockClass, "-selected-item-title")
70
+ }, title), /*#__PURE__*/_react.default.createElement("p", {
71
+ className: "".concat(blockClass, "-selected-item-subtitle")
72
+ }, subtitle)), /*#__PURE__*/_react.default.createElement(_carbonComponentsReact.Button, {
67
73
  renderIcon: _iconsReact.SubtractAlt32,
68
74
  iconDescription: removeIconDescription,
69
75
  hasIconOnly: true,