@carbon/ibm-products 2.11.3 → 2.12.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (108) hide show
  1. package/css/index-full-carbon.css +43 -12
  2. package/css/index-full-carbon.css.map +1 -1
  3. package/css/index-full-carbon.min.css +3 -3
  4. package/css/index-full-carbon.min.css.map +1 -1
  5. package/css/index-without-carbon-released-only.css +36 -7
  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 +43 -12
  10. package/css/index-without-carbon.css.map +1 -1
  11. package/css/index-without-carbon.min.css +3 -3
  12. package/css/index-without-carbon.min.css.map +1 -1
  13. package/css/index.css +43 -12
  14. package/css/index.css.map +1 -1
  15. package/css/index.min.css +3 -3
  16. package/css/index.min.css.map +1 -1
  17. package/es/components/Card/Card.js +9 -1
  18. package/es/components/Card/CardFooter.js +8 -2
  19. package/es/components/Card/CardHeader.js +8 -2
  20. package/es/components/CreateFullPage/CreateFullPage.docs-page.js +6 -0
  21. package/es/components/CreateFullPage/CreateFullPage.js +66 -8
  22. package/es/components/Datagrid/Datagrid/Datagrid.js +2 -1
  23. package/es/components/Datagrid/Datagrid/DatagridContent.js +7 -1
  24. package/es/components/Datagrid/Datagrid/DatagridEmptyBody.js +1 -3
  25. package/es/components/Datagrid/Datagrid/DatagridHeaderRow.js +3 -5
  26. package/es/components/Datagrid/Datagrid/DatagridRefBody.js +1 -3
  27. package/es/components/Datagrid/Datagrid/DatagridRow.js +2 -6
  28. package/es/components/Datagrid/Datagrid/DatagridSelectAll.js +13 -1
  29. package/es/components/Datagrid/Datagrid/DatagridSimpleBody.js +1 -3
  30. package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +1 -3
  31. package/es/components/Datagrid/Datagrid/DraggableElement.js +1 -0
  32. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +37 -15
  33. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +18 -17
  34. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +104 -18
  35. package/es/components/Datagrid/Datagrid/addons/Filtering/OverflowCheckboxes.js +68 -0
  36. package/es/components/Datagrid/Datagrid/addons/Filtering/constants.js +1 -0
  37. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +120 -54
  38. package/es/components/Datagrid/Datagrid/addons/Filtering/utils.js +9 -3
  39. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +6 -12
  40. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +0 -5
  41. package/es/components/Datagrid/Datagrid.docs-page.js +1 -1
  42. package/es/components/Datagrid/useActionsColumn.js +0 -2
  43. package/es/components/Datagrid/useDisableSelectRows.js +1 -1
  44. package/es/components/Datagrid/useFiltering.js +4 -1
  45. package/es/components/Datagrid/useInlineEdit.js +1 -6
  46. package/es/components/Datagrid/useSelectRows.js +1 -1
  47. package/es/components/Datagrid/useSortableColumns.js +14 -25
  48. package/es/components/Datagrid/utils/DatagridActions.js +2 -3
  49. package/es/components/SimpleHeader/SimpleHeader.docs-page.js +17 -0
  50. package/es/components/SimpleHeader/SimpleHeader.js +92 -0
  51. package/es/components/SimpleHeader/index.js +8 -0
  52. package/es/components/StatusIcon/StatusIcon.js +13 -13
  53. package/es/global/js/hooks/useCreateComponentStepChange.js +14 -20
  54. package/es/global/js/utils/StoryDocsPage.js +3 -3
  55. package/es/global/js/utils/getNodeTextContent.js +4 -0
  56. package/lib/components/Card/Card.js +9 -1
  57. package/lib/components/Card/CardFooter.js +8 -2
  58. package/lib/components/Card/CardHeader.js +8 -2
  59. package/lib/components/CreateFullPage/CreateFullPage.docs-page.js +6 -0
  60. package/lib/components/CreateFullPage/CreateFullPage.js +65 -7
  61. package/lib/components/Datagrid/Datagrid/Datagrid.js +2 -1
  62. package/lib/components/Datagrid/Datagrid/DatagridContent.js +6 -0
  63. package/lib/components/Datagrid/Datagrid/DatagridEmptyBody.js +1 -3
  64. package/lib/components/Datagrid/Datagrid/DatagridHeaderRow.js +3 -5
  65. package/lib/components/Datagrid/Datagrid/DatagridRefBody.js +1 -3
  66. package/lib/components/Datagrid/Datagrid/DatagridRow.js +2 -6
  67. package/lib/components/Datagrid/Datagrid/DatagridSelectAll.js +13 -1
  68. package/lib/components/Datagrid/Datagrid/DatagridSimpleBody.js +1 -3
  69. package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +1 -3
  70. package/lib/components/Datagrid/Datagrid/DraggableElement.js +1 -0
  71. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +37 -15
  72. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +40 -38
  73. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +109 -24
  74. package/lib/components/Datagrid/Datagrid/addons/Filtering/OverflowCheckboxes.js +79 -0
  75. package/lib/components/Datagrid/Datagrid/addons/Filtering/constants.js +4 -2
  76. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +136 -70
  77. package/lib/components/Datagrid/Datagrid/addons/Filtering/utils.js +10 -4
  78. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +6 -12
  79. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +0 -5
  80. package/lib/components/Datagrid/Datagrid.docs-page.js +1 -1
  81. package/lib/components/Datagrid/useActionsColumn.js +0 -2
  82. package/lib/components/Datagrid/useDisableSelectRows.js +1 -1
  83. package/lib/components/Datagrid/useFiltering.js +4 -1
  84. package/lib/components/Datagrid/useInlineEdit.js +1 -6
  85. package/lib/components/Datagrid/useSelectRows.js +1 -1
  86. package/lib/components/Datagrid/useSortableColumns.js +14 -25
  87. package/lib/components/Datagrid/utils/DatagridActions.js +2 -3
  88. package/lib/components/SimpleHeader/SimpleHeader.docs-page.js +28 -0
  89. package/lib/components/SimpleHeader/SimpleHeader.js +102 -0
  90. package/lib/components/SimpleHeader/index.js +12 -0
  91. package/lib/components/StatusIcon/StatusIcon.js +12 -12
  92. package/lib/global/js/hooks/useCreateComponentStepChange.js +14 -20
  93. package/lib/global/js/utils/StoryDocsPage.js +3 -3
  94. package/lib/global/js/utils/getNodeTextContent.js +4 -0
  95. package/package.json +2 -2
  96. package/scss/components/Card/_card.scss +1 -1
  97. package/scss/components/CreateFullPage/_create-full-page.scss +11 -2
  98. package/scss/components/Datagrid/styles/_useInlineEdit.scss +8 -11
  99. package/scss/components/Datagrid/styles/addons/_FilterPanel.scss +4 -0
  100. package/scss/components/ProductiveCard/_productive-card.scss +0 -1
  101. package/scss/components/SimpleHeader/_carbon-imports.scss +11 -0
  102. package/scss/components/SimpleHeader/_index-with-carbon.scss +9 -0
  103. package/scss/components/SimpleHeader/_index.scss +10 -0
  104. package/scss/components/SimpleHeader/_simple-header.scss +37 -0
  105. package/scss/components/StatusIcon/_status-icon.scss +0 -1
  106. package/scss/components/_index-with-carbon.scss +1 -0
  107. package/es/components/Datagrid/utils/getColTitle.js +0 -25
  108. package/lib/components/Datagrid/utils/getColTitle.js +0 -32
@@ -21,14 +21,11 @@ var useInlineEdit = function useInlineEdit(hooks, usingEditableCell) {
21
21
  }
22
22
  }, [usingEditableCell]);
23
23
  var addInlineEdit = function addInlineEdit(props, _ref) {
24
- var _cell$column, _instance$columns$fil;
24
+ var _cell$column;
25
25
  var cell = _ref.cell,
26
26
  instance = _ref.instance;
27
27
  var columnInlineEditConfig = cell.column.inlineEdit;
28
28
  var inlineEditType = (_cell$column = cell.column) === null || _cell$column === void 0 || (_cell$column = _cell$column.inlineEdit) === null || _cell$column === void 0 ? void 0 : _cell$column.type;
29
- var totalInlineEditColumns = (_instance$columns$fil = instance.columns.filter(function (item) {
30
- return item.inlineEdit;
31
- })) === null || _instance$columns$fil === void 0 ? void 0 : _instance$columns$fil.length;
32
29
  var renderInlineEditComponent = function renderInlineEditComponent(type) {
33
30
  return /*#__PURE__*/React.createElement(InlineEditCell, {
34
31
  config: columnInlineEditConfig,
@@ -36,7 +33,6 @@ var useInlineEdit = function useInlineEdit(hooks, usingEditableCell) {
36
33
  value: cell.value,
37
34
  cell: cell,
38
35
  instance: instance,
39
- totalInlineEditColumns: totalInlineEditColumns,
40
36
  type: type
41
37
  });
42
38
  };
@@ -56,7 +52,6 @@ var useInlineEdit = function useInlineEdit(hooks, usingEditableCell) {
56
52
  instance: instance,
57
53
  disabled: true,
58
54
  nonEditCell: true,
59
- totalInlineEditColumns: totalInlineEditColumns,
60
55
  type: "text"
61
56
  }))
62
57
  }];
@@ -87,7 +87,7 @@ var SelectRow = function SelectRow(datagridState) {
87
87
  return window.removeEventListener('resize', updateSize);
88
88
  };
89
89
  }, []);
90
- var selectDisabled = isFetching || row.getRowProps().selectDisabled;
90
+ var selectDisabled = isFetching || row.getRowProps().disabled;
91
91
  var _row$getToggleRowSele = row.getToggleRowSelectedProps(),
92
92
  onChange = _row$getToggleRowSele.onChange,
93
93
  selectProps = _objectWithoutProperties(_row$getToggleRowSele, _excluded);
@@ -1,6 +1,5 @@
1
1
  import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
2
2
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
- import _extends from "@babel/runtime/helpers/extends";
4
3
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
5
4
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
6
5
  /**
@@ -15,6 +14,7 @@ import cx from 'classnames';
15
14
  import { pkg, carbon } from '../../settings';
16
15
  import { Button } from '@carbon/react';
17
16
  import { ArrowUp, ArrowDown, ArrowsVertical } from '@carbon/react/icons';
17
+ import { SelectAll } from './Datagrid/DatagridSelectAll';
18
18
  var blockClass = "".concat(pkg.prefix, "--datagrid");
19
19
  var ordering = {
20
20
  ASC: 'ASC',
@@ -32,13 +32,13 @@ var getAriaSortValue = function getAriaSortValue(col, _ref) {
32
32
  isSorted = _ref2.isSorted,
33
33
  isSortedDesc = _ref2.isSortedDesc;
34
34
  if (!isSorted) {
35
- return defaultSortableLabelText || 'none';
35
+ return defaultSortableLabelText;
36
36
  }
37
37
  if (isSorted && !isSortedDesc) {
38
- return ascendingSortableLabelText || 'ascending';
38
+ return ascendingSortableLabelText;
39
39
  }
40
40
  if (isSorted && isSortedDesc) {
41
- return descendingSortableLabelText || 'descending';
41
+ return descendingSortableLabelText;
42
42
  }
43
43
  };
44
44
  var getAriaPressedValue = function getAriaPressedValue(col) {
@@ -73,37 +73,26 @@ var useSortableColumns = function useSortableColumns(hooks) {
73
73
  };
74
74
  var sortableColumns = visibleColumns.map(function (column) {
75
75
  var icon = function icon(col, props) {
76
+ var iconProps = _objectSpread(_objectSpread({
77
+ size: 16
78
+ }, props), {}, {
79
+ className: "".concat(blockClass, "__sortable-icon ").concat(carbon.prefix, "--btn__icon")
80
+ });
76
81
  if (col !== null && col !== void 0 && col.isSorted) {
77
82
  switch (col.isSortedDesc) {
78
83
  case false:
79
- return /*#__PURE__*/React.createElement(ArrowUp, _extends({
80
- size: 16
81
- }, props, {
82
- className: "".concat(blockClass, "__sortable-icon ").concat(carbon.prefix, "--btn__icon")
83
- }));
84
+ return /*#__PURE__*/React.createElement(ArrowUp, iconProps);
84
85
  case true:
85
- return /*#__PURE__*/React.createElement(ArrowDown, _extends({
86
- size: 16
87
- }, props, {
88
- className: "".concat(blockClass, "__sortable-icon ").concat(carbon.prefix, "--btn__icon")
89
- }));
86
+ return /*#__PURE__*/React.createElement(ArrowDown, iconProps);
90
87
  default:
91
- return /*#__PURE__*/React.createElement(ArrowsVertical, _extends({
92
- size: 16
93
- }, props, {
94
- className: "".concat(blockClass, "__sortable-icon ").concat(carbon.prefix, "--btn__icon")
95
- }));
88
+ return /*#__PURE__*/React.createElement(ArrowsVertical, iconProps);
96
89
  }
97
90
  }
98
- return /*#__PURE__*/React.createElement(ArrowsVertical, _extends({
99
- size: 16
100
- }, props, {
101
- className: "".concat(blockClass, "__sortable-icon ").concat(carbon.prefix, "--btn__icon")
102
- }));
91
+ return /*#__PURE__*/React.createElement(ArrowsVertical, iconProps);
103
92
  };
104
93
  var Header = function Header(headerProp) {
105
94
  var _cx;
106
- return column.disableSortBy === true ? column.Header : /*#__PURE__*/React.createElement(Button, {
95
+ return column.disableSortBy === true || column.id === 'datagridSelection' ? column.disableSortBy ? column.Header : /*#__PURE__*/React.createElement(SelectAll, instance) : /*#__PURE__*/React.createElement(Button, {
107
96
  "aria-sort": getAriaSortValue(headerProp === null || headerProp === void 0 ? void 0 : headerProp.column, {
108
97
  ascendingSortableLabelText: ascendingSortableLabelText,
109
98
  descendingSortableLabelText: descendingSortableLabelText,
@@ -126,7 +126,7 @@ export var DatagridActions = function DatagridActions(datagridState) {
126
126
  size: "lg",
127
127
  id: "columnSearch",
128
128
  persistent: true,
129
- placeHolderText: searchForAColumn,
129
+ placeholder: searchForAColumn,
130
130
  onChange: function onChange(e) {
131
131
  return setGlobalFilter(e.target.value);
132
132
  }
@@ -152,7 +152,6 @@ export var DatagridActions = function DatagridActions(datagridState) {
152
152
  style: style
153
153
  }, /*#__PURE__*/React.createElement(CustomizeColumnsButton, null)), /*#__PURE__*/React.createElement(RowSizeDropdown, rowSizeDropdownProps), /*#__PURE__*/React.createElement(MenuButton, {
154
154
  label: "Primary button",
155
- renderIcon: ChevronDown,
156
155
  className: "".concat(blockClass, "__toolbar-options")
157
156
  }, /*#__PURE__*/React.createElement(MenuItem, {
158
157
  label: "Option 1",
@@ -167,7 +166,7 @@ export var DatagridActions = function DatagridActions(datagridState) {
167
166
  size: "xl",
168
167
  id: "columnSearch",
169
168
  persistent: true,
170
- placeHolderText: searchForAColumn,
169
+ placeholder: searchForAColumn,
171
170
  onChange: function onChange(e) {
172
171
  return setGlobalFilter(e.target.value);
173
172
  }
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { StoryDocsPage } from '../../global/js/utils/StoryDocsPage';
3
+ import * as stories from './SimpleHeader.stories';
4
+ var DocsPage = function DocsPage() {
5
+ return /*#__PURE__*/React.createElement(StoryDocsPage, {
6
+ blocks: [{
7
+ story: stories.simpleHeader
8
+ }, {
9
+ story: stories.simpleHeaderWithBreadcrumbsOnly
10
+ }, {
11
+ story: stories.simpleHeaderWithTitleOnly
12
+ }, {
13
+ story: stories.simpleHeaderWithOverflowBreadcrumbs
14
+ }]
15
+ });
16
+ };
17
+ export default DocsPage;
@@ -0,0 +1,92 @@
1
+ import _extends from "@babel/runtime/helpers/extends";
2
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
3
+ var _excluded = ["breadcrumbs", "className", "title", "noTrailingSlash", "maxVisible", "overflowAriaLabel"];
4
+ /**
5
+ * Copyright IBM Corp. 2023, 2023
6
+ *
7
+ * This source code is licensed under the Apache-2.0 license found in the
8
+ * LICENSE file in the root directory of this source tree.
9
+ */
10
+
11
+ import PropTypes from 'prop-types';
12
+ import React, { useCallback, useEffect } from 'react';
13
+ import cx from 'classnames';
14
+ import { pkg } from '../../settings';
15
+ import pconsole from '../../global/js/utils/pconsole';
16
+ import { BreadcrumbWithOverflow } from '../BreadcrumbWithOverflow';
17
+ import { isRequiredIf } from '../../global/js/utils/props-helper';
18
+ var blockClass = "".concat(pkg.prefix, "--simple-header");
19
+ var componentName = 'SimpleHeader';
20
+ /**
21
+ * The SimpleHeader is not public and only used internally by CreateFullPage.
22
+ *
23
+ * Component varieties:
24
+ * - Header with Breadcrumbs
25
+ * - Header with Title
26
+ * - Header with Breadcrumbs and Title
27
+ *
28
+ *
29
+ * The component will throw a warning message if neither a title or breadcrumbs are provided
30
+ * since it requires at least one of them.
31
+ * */
32
+ var SimpleHeader = function SimpleHeader(_ref) {
33
+ var breadcrumbs = _ref.breadcrumbs,
34
+ className = _ref.className,
35
+ title = _ref.title,
36
+ noTrailingSlash = _ref.noTrailingSlash,
37
+ maxVisible = _ref.maxVisible,
38
+ overflowAriaLabel = _ref.overflowAriaLabel,
39
+ rest = _objectWithoutProperties(_ref, _excluded);
40
+ var warnIfNoTitleOrBreadcrumbs = useCallback(function () {
41
+ if (!title && !(breadcrumbs !== null && breadcrumbs !== void 0 && breadcrumbs.length)) {
42
+ pconsole.error("Warning: You have tried using a ".concat(componentName, " component without specifying a title or breadcrumbs props"));
43
+ }
44
+ }, [breadcrumbs, title]);
45
+ useEffect(function () {
46
+ warnIfNoTitleOrBreadcrumbs();
47
+ }, [title, breadcrumbs, warnIfNoTitleOrBreadcrumbs]);
48
+ return /*#__PURE__*/React.createElement("header", _extends({
49
+ className: cx(blockClass, className)
50
+ }, rest), (breadcrumbs === null || breadcrumbs === void 0 ? void 0 : breadcrumbs.length) > 0 && /*#__PURE__*/React.createElement(BreadcrumbWithOverflow, {
51
+ noTrailingSlash: noTrailingSlash,
52
+ className: cx("".concat(blockClass, "__breadcrumbs")),
53
+ breadcrumbs: breadcrumbs,
54
+ maxVisible: maxVisible,
55
+ overflowAriaLabel: overflowAriaLabel
56
+ }), title && /*#__PURE__*/React.createElement("h1", {
57
+ className: cx("".concat(blockClass, "__title"))
58
+ }, title));
59
+ };
60
+ export var overflowAriaLabel_required_if_breadcrumbs_exist = isRequiredIf(PropTypes.string, function (props) {
61
+ var _props$breadcrumbs;
62
+ return ((_props$breadcrumbs = props.breadcrumbs) === null || _props$breadcrumbs === void 0 ? void 0 : _props$breadcrumbs.length) > 0;
63
+ });
64
+ SimpleHeader.propTypes = {
65
+ /** Header breadcrumbs */
66
+ breadcrumbs: PropTypes.arrayOf(PropTypes.shape({
67
+ /** breadcrumb item key */
68
+ key: PropTypes.string.isRequired,
69
+ /** breadcrumb item label */
70
+ label: PropTypes.string.isRequired,
71
+ /** breadcrumb item link */
72
+ href: PropTypes.string,
73
+ /** breadcrumb item title tooltip */
74
+ title: PropTypes.string,
75
+ /** Provide if this breadcrumb item represents the current page */
76
+ isCurrentPage: PropTypes.bool
77
+ })),
78
+ /** Header classname */
79
+ className: PropTypes.string,
80
+ /** Maximum visible breadcrumb-items before overflow is used (values less than 1 are treated as 1) */
81
+ maxVisible: PropTypes.number,
82
+ /** A prop to omit the trailing slash for the breadcrumbs */
83
+ noTrailingSlash: PropTypes.bool,
84
+ /** Label for open/close overflow button used for breadcrumb items that do not fit */
85
+ overflowAriaLabel: overflowAriaLabel_required_if_breadcrumbs_exist,
86
+ /** Header title */
87
+ title: PropTypes.string
88
+ };
89
+ SimpleHeader.defaultProps = {
90
+ noTrailingSlash: true
91
+ };
92
+ export { SimpleHeader };
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Copyright IBM Corp. 2023, 2023
3
+ *
4
+ * This source code is licensed under the Apache-2.0 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+
8
+ export { CreateFullPageHeader } from './SimpleHeader';
@@ -11,7 +11,7 @@ var _excluded = ["kind", "theme", "size", "className", "iconDescription"];
11
11
  import React, { forwardRef } from 'react';
12
12
  import PropTypes from 'prop-types';
13
13
  import cx from 'classnames';
14
- import { Misuse, ErrorFilled, WarningAltInvertedFilled, WarningAltFilled, UndefinedFilled, UnknownFilled, CheckmarkFilled, InformationSquareFilled, Renew, Time } from '@carbon/react/icons';
14
+ import { Misuse, ErrorFilled, WarningAltInvertedFilled, WarningAltFilled, UndefinedFilled, UnknownFilled, CheckmarkFilled, InformationSquareFilled, InProgress, CheckmarkOutline, Pending } from '@carbon/react/icons';
15
15
  import { getDevtoolsProps } from '../../global/js/utils/devtools';
16
16
  import { pkg } from '../../settings';
17
17
  var blockClass = "".concat(pkg.prefix, "--status-icon");
@@ -245,25 +245,25 @@ export var StatusIcon = /*#__PURE__*/forwardRef(function (_ref, ref) {
245
245
  },
246
246
  'in-progress': {
247
247
  sm: /*#__PURE__*/forwardRef(function (props, ref) {
248
- return /*#__PURE__*/React.createElement(Renew, _extends({
248
+ return /*#__PURE__*/React.createElement(InProgress, _extends({
249
249
  size: 16,
250
250
  ref: ref
251
251
  }, props));
252
252
  }),
253
253
  md: /*#__PURE__*/forwardRef(function (props, ref) {
254
- return /*#__PURE__*/React.createElement(Renew, _extends({
254
+ return /*#__PURE__*/React.createElement(InProgress, _extends({
255
255
  size: 20,
256
256
  ref: ref
257
257
  }, props));
258
258
  }),
259
259
  lg: /*#__PURE__*/forwardRef(function (props, ref) {
260
- return /*#__PURE__*/React.createElement(Renew, _extends({
260
+ return /*#__PURE__*/React.createElement(InProgress, _extends({
261
261
  size: 24,
262
262
  ref: ref
263
263
  }, props));
264
264
  }),
265
265
  xl: /*#__PURE__*/forwardRef(function (props, ref) {
266
- return /*#__PURE__*/React.createElement(Renew, _extends({
266
+ return /*#__PURE__*/React.createElement(InProgress, _extends({
267
267
  size: 32,
268
268
  ref: ref
269
269
  }, props));
@@ -271,25 +271,25 @@ export var StatusIcon = /*#__PURE__*/forwardRef(function (_ref, ref) {
271
271
  },
272
272
  running: {
273
273
  sm: /*#__PURE__*/forwardRef(function (props, ref) {
274
- return /*#__PURE__*/React.createElement(Renew, _extends({
274
+ return /*#__PURE__*/React.createElement(CheckmarkOutline, _extends({
275
275
  size: 16,
276
276
  ref: ref
277
277
  }, props));
278
278
  }),
279
279
  md: /*#__PURE__*/forwardRef(function (props, ref) {
280
- return /*#__PURE__*/React.createElement(Renew, _extends({
280
+ return /*#__PURE__*/React.createElement(CheckmarkOutline, _extends({
281
281
  size: 20,
282
282
  ref: ref
283
283
  }, props));
284
284
  }),
285
285
  lg: /*#__PURE__*/forwardRef(function (props, ref) {
286
- return /*#__PURE__*/React.createElement(Renew, _extends({
286
+ return /*#__PURE__*/React.createElement(CheckmarkOutline, _extends({
287
287
  size: 24,
288
288
  ref: ref
289
289
  }, props));
290
290
  }),
291
291
  xl: /*#__PURE__*/forwardRef(function (props, ref) {
292
- return /*#__PURE__*/React.createElement(Renew, _extends({
292
+ return /*#__PURE__*/React.createElement(CheckmarkOutline, _extends({
293
293
  size: 32,
294
294
  ref: ref
295
295
  }, props));
@@ -297,25 +297,25 @@ export var StatusIcon = /*#__PURE__*/forwardRef(function (_ref, ref) {
297
297
  },
298
298
  pending: {
299
299
  sm: /*#__PURE__*/forwardRef(function (props, ref) {
300
- return /*#__PURE__*/React.createElement(Time, _extends({
300
+ return /*#__PURE__*/React.createElement(Pending, _extends({
301
301
  size: 16,
302
302
  ref: ref
303
303
  }, props));
304
304
  }),
305
305
  md: /*#__PURE__*/forwardRef(function (props, ref) {
306
- return /*#__PURE__*/React.createElement(Time, _extends({
306
+ return /*#__PURE__*/React.createElement(Pending, _extends({
307
307
  size: 20,
308
308
  ref: ref
309
309
  }, props));
310
310
  }),
311
311
  lg: /*#__PURE__*/forwardRef(function (props, ref) {
312
- return /*#__PURE__*/React.createElement(Time, _extends({
312
+ return /*#__PURE__*/React.createElement(Pending, _extends({
313
313
  size: 24,
314
314
  ref: ref
315
315
  }, props));
316
316
  }),
317
317
  xl: /*#__PURE__*/forwardRef(function (props, ref) {
318
- return /*#__PURE__*/React.createElement(Time, _extends({
318
+ return /*#__PURE__*/React.createElement(Pending, _extends({
319
319
  size: 32,
320
320
  ref: ref
321
321
  }, props));
@@ -101,38 +101,32 @@ export var useCreateComponentStepChange = function useCreateComponentStepChange(
101
101
  return _regeneratorRuntime.wrap(function _callee2$(_context2) {
102
102
  while (1) switch (_context2.prev = _context2.next) {
103
103
  case 0:
104
- if (!(componentName === 'CreateFullPage')) {
105
- _context2.next = 2;
106
- break;
107
- }
108
- return _context2.abrupt("return");
109
- case 2:
110
- setLoadingPrevious(true);
104
+ setLoadingPrevious === null || setLoadingPrevious === void 0 || setLoadingPrevious(true);
111
105
  if (!(typeof onPrevious === 'function')) {
112
- _context2.next = 15;
106
+ _context2.next = 13;
113
107
  break;
114
108
  }
115
- _context2.prev = 4;
116
- _context2.next = 7;
109
+ _context2.prev = 2;
110
+ _context2.next = 5;
117
111
  return onPrevious();
118
- case 7:
112
+ case 5:
119
113
  moveToPreviousStep();
120
- _context2.next = 13;
114
+ _context2.next = 11;
121
115
  break;
122
- case 10:
123
- _context2.prev = 10;
124
- _context2.t0 = _context2["catch"](4);
116
+ case 8:
117
+ _context2.prev = 8;
118
+ _context2.t0 = _context2["catch"](2);
125
119
  console.warn("".concat(componentName, " onBack error: ").concat(_context2.t0));
126
- case 13:
127
- _context2.next = 16;
120
+ case 11:
121
+ _context2.next = 14;
128
122
  break;
129
- case 15:
123
+ case 13:
130
124
  moveToPreviousStep();
131
- case 16:
125
+ case 14:
132
126
  case "end":
133
127
  return _context2.stop();
134
128
  }
135
- }, _callee2, null, [[4, 10]]);
129
+ }, _callee2, null, [[2, 8]]);
136
130
  }))).apply(this, arguments);
137
131
  };
138
132
  var handleNext = function handleNext() {
@@ -172,10 +172,10 @@ StoryDocsPage.propTypes = {
172
172
  /**
173
173
  * location if any of guidelines on the PAL site, constructed by default
174
174
  */
175
- altGuidelinesHref: PropTypes.oneOfType(PropTypes.string, PropTypes.arrayOf(PropTypes.shape({
175
+ altGuidelinesHref: PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.shape({
176
176
  href: PropTypes.string,
177
177
  label: PropTypes.string
178
- }))),
178
+ }))]),
179
179
  /**
180
180
  * Uses component name by default
181
181
  */
@@ -209,7 +209,7 @@ StoryDocsPage.propTypes = {
209
209
  * default language `jsx`
210
210
  */
211
211
  source: PropTypes.shape({
212
- language: PropTypes.oneOf('javascript', 'css', 'jsx', 'json'),
212
+ language: PropTypes.oneOf(['javascript', 'css', 'jsx', 'json']),
213
213
  code: PropTypes.string
214
214
  })
215
215
  })),
@@ -40,6 +40,10 @@ export var getNodeTextContent = function getNodeTextContent(node) {
40
40
  // Ignore any other JavaScript 'object' types.
41
41
  return '';
42
42
  }
43
+ case 'function':
44
+ {
45
+ return getNodeTextContent(node());
46
+ }
43
47
  default:
44
48
  // Ignore all other JavaScript types.
45
49
  return '';
@@ -16,7 +16,7 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
16
16
  var _CardHeader = require("./CardHeader");
17
17
  var _CardFooter = require("./CardFooter");
18
18
  var _settings = require("../../settings");
19
- var _excluded = ["actionIcons", "actionsPlacement", "children", "className", "clickZone", "description", "label", "media", "mediaPosition", "onClick", "onKeyDown", "onPrimaryButtonClick", "overflowActions", "overflowAriaLabel", "onSecondaryButtonClick", "pictogram", "primaryButtonHref", "primaryButtonIcon", "primaryButtonKind", "primaryButtonPlacement", "primaryButtonText", "productive", "secondaryButtonHref", "secondaryButtonIcon", "secondaryButtonKind", "secondaryButtonPlacement", "secondaryButtonText", "title", "titleSize"],
19
+ var _excluded = ["actionIcons", "actionsPlacement", "children", "className", "clickZone", "description", "label", "media", "mediaPosition", "onClick", "onKeyDown", "onPrimaryButtonClick", "overflowActions", "overflowAriaLabel", "onSecondaryButtonClick", "pictogram", "primaryButtonDisabled", "primaryButtonHref", "primaryButtonIcon", "primaryButtonKind", "primaryButtonPlacement", "primaryButtonText", "productive", "secondaryButtonDisabled", "secondaryButtonHref", "secondaryButtonIcon", "secondaryButtonKind", "secondaryButtonPlacement", "secondaryButtonText", "title", "titleSize"],
20
20
  _excluded2 = ["id"],
21
21
  _excluded3 = ["id", "icon", "onClick", "iconDescription", "href"]; //
22
22
  // Copyright IBM Corp. 2020, 2023
@@ -66,6 +66,7 @@ var Card = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
66
66
  overflowAriaLabel = _ref.overflowAriaLabel,
67
67
  onSecondaryButtonClick = _ref.onSecondaryButtonClick,
68
68
  Pictogram = _ref.pictogram,
69
+ primaryButtonDisabled = _ref.primaryButtonDisabled,
69
70
  primaryButtonHref = _ref.primaryButtonHref,
70
71
  primaryButtonIcon = _ref.primaryButtonIcon,
71
72
  _ref$primaryButtonKin = _ref.primaryButtonKind,
@@ -75,6 +76,7 @@ var Card = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
75
76
  primaryButtonText = _ref.primaryButtonText,
76
77
  _ref$productive = _ref.productive,
77
78
  productive = _ref$productive === void 0 ? defaults.productive : _ref$productive,
79
+ secondaryButtonDisabled = _ref.secondaryButtonDisabled,
78
80
  secondaryButtonHref = _ref.secondaryButtonHref,
79
81
  secondaryButtonIcon = _ref.secondaryButtonIcon,
80
82
  _ref$secondaryButtonK = _ref.secondaryButtonKind,
@@ -189,9 +191,11 @@ var Card = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
189
191
  primaryButtonIcon: primaryButtonIcon,
190
192
  primaryButtonPlacement: primaryButtonPlacement,
191
193
  primaryButtonText: primaryButtonText,
194
+ primaryButtonDisabled: primaryButtonDisabled,
192
195
  description: description,
193
196
  hasActions: hasActions,
194
197
  label: label,
198
+ secondaryButtonDisabled: secondaryButtonDisabled,
195
199
  secondaryButtonHref: secondaryButtonHref,
196
200
  secondaryButtonIcon: secondaryButtonIcon,
197
201
  secondaryButtonPlacement: secondaryButtonPlacement,
@@ -215,12 +219,14 @@ var Card = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
215
219
  hasButton: hasFooterButton,
216
220
  onPrimaryButtonClick: onPrimaryButtonClick,
217
221
  onSecondaryButtonClick: onSecondaryButtonClick,
222
+ primaryButtonDisabled: primaryButtonDisabled,
218
223
  primaryButtonHref: primaryButtonHref,
219
224
  primaryButtonIcon: primaryButtonIcon,
220
225
  primaryButtonKind: primaryButtonKind,
221
226
  primaryButtonPlacement: primaryButtonPlacement,
222
227
  primaryButtonText: primaryButtonText,
223
228
  productive: productive,
229
+ secondaryButtonDisabled: secondaryButtonDisabled,
224
230
  secondaryButtonHref: secondaryButtonHref,
225
231
  secondaryButtonIcon: secondaryButtonIcon,
226
232
  secondaryButtonKind: secondaryButtonKind,
@@ -266,12 +272,14 @@ Card.propTypes = {
266
272
  })),
267
273
  overflowAriaLabel: _propTypes.default.string,
268
274
  pictogram: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
275
+ primaryButtonDisabled: _propTypes.default.bool,
269
276
  primaryButtonHref: _propTypes.default.string,
270
277
  primaryButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
271
278
  primaryButtonKind: _propTypes.default.oneOf(['primary', 'ghost']),
272
279
  primaryButtonPlacement: _propTypes.default.oneOf(['top', 'bottom']),
273
280
  primaryButtonText: _propTypes.default.node,
274
281
  productive: _propTypes.default.bool,
282
+ secondaryButtonDisabled: _propTypes.default.bool,
275
283
  secondaryButtonHref: _propTypes.default.string,
276
284
  secondaryButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
277
285
  secondaryButtonKind: _propTypes.default.oneOf(['secondary', 'ghost']),
@@ -32,6 +32,7 @@ var CardFooter = function CardFooter(_ref) {
32
32
  hasButton = _ref.hasButton,
33
33
  onPrimaryButtonClick = _ref.onPrimaryButtonClick,
34
34
  onSecondaryButtonClick = _ref.onSecondaryButtonClick,
35
+ primaryButtonDisabled = _ref.primaryButtonDisabled,
35
36
  primaryButtonHref = _ref.primaryButtonHref,
36
37
  primaryButtonIcon = _ref.primaryButtonIcon,
37
38
  _ref$primaryButtonKin = _ref.primaryButtonKind,
@@ -40,6 +41,7 @@ var CardFooter = function CardFooter(_ref) {
40
41
  primaryButtonText = _ref.primaryButtonText,
41
42
  _ref$productive = _ref.productive,
42
43
  productive = _ref$productive === void 0 ? defaults.productive : _ref$productive,
44
+ secondaryButtonDisabled = _ref.secondaryButtonDisabled,
43
45
  secondaryButtonHref = _ref.secondaryButtonHref,
44
46
  secondaryButtonIcon = _ref.secondaryButtonIcon,
45
47
  _ref$secondaryButtonK = _ref.secondaryButtonKind,
@@ -56,13 +58,15 @@ var CardFooter = function CardFooter(_ref) {
56
58
  onClick: onSecondaryButtonClick,
57
59
  size: "md",
58
60
  renderIcon: secondaryButtonIcon,
59
- href: secondaryButtonHref
61
+ href: secondaryButtonHref,
62
+ disabled: secondaryButtonDisabled
60
63
  }, secondaryButtonText), primaryButtonText && primaryButtonPlacement === 'bottom' && /*#__PURE__*/_react.default.createElement(_react2.Button, {
61
64
  kind: productive ? 'ghost' : primaryButtonKind,
62
65
  onClick: onPrimaryButtonClick,
63
66
  size: "md",
64
67
  renderIcon: primaryButtonIcon,
65
- href: primaryButtonHref
68
+ href: primaryButtonHref,
69
+ disabled: primaryButtonDisabled
66
70
  }, primaryButtonText), hasActions && /*#__PURE__*/_react.default.createElement("div", {
67
71
  className: "".concat(blockClass, "__actions")
68
72
  }, actions));
@@ -74,12 +78,14 @@ CardFooter.propTypes = {
74
78
  hasButton: _propTypes.default.bool,
75
79
  onPrimaryButtonClick: _propTypes.default.func,
76
80
  onSecondaryButtonClick: _propTypes.default.func,
81
+ primaryButtonDisabled: _propTypes.default.bool,
77
82
  primaryButtonHref: _propTypes.default.string,
78
83
  primaryButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
79
84
  primaryButtonKind: _propTypes.default.oneOf(['primary', 'ghost']),
80
85
  primaryButtonPlacement: _propTypes.default.oneOf(['top', 'bottom']),
81
86
  primaryButtonText: _propTypes.default.string,
82
87
  productive: _propTypes.default.bool,
88
+ secondaryButtonDisabled: _propTypes.default.bool,
83
89
  secondaryButtonHref: _propTypes.default.string,
84
90
  secondaryButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
85
91
  secondaryButtonKind: _propTypes.default.oneOf(['secondary', 'ghost']),
@@ -32,10 +32,12 @@ var CardHeader = function CardHeader(_ref) {
32
32
  primaryButtonIcon = _ref.primaryButtonIcon,
33
33
  primaryButtonPlacement = _ref.primaryButtonPlacement,
34
34
  primaryButtonText = _ref.primaryButtonText,
35
+ primaryButtonDisabled = _ref.primaryButtonDisabled,
35
36
  description = _ref.description,
36
37
  _ref$hasActions = _ref.hasActions,
37
38
  hasActions = _ref$hasActions === void 0 ? defaults.hasActions : _ref$hasActions,
38
39
  label = _ref.label,
40
+ secondaryButtonDisabled = _ref.secondaryButtonDisabled,
39
41
  secondaryButtonHref = _ref.secondaryButtonHref,
40
42
  secondaryButtonIcon = _ref.secondaryButtonIcon,
41
43
  secondaryButtonPlacement = _ref.secondaryButtonPlacement,
@@ -68,13 +70,15 @@ var CardHeader = function CardHeader(_ref) {
68
70
  size: "sm",
69
71
  renderIcon: secondaryButtonIcon,
70
72
  href: secondaryButtonHref,
71
- className: actionGhostButtonClass
73
+ className: actionGhostButtonClass,
74
+ disabled: secondaryButtonDisabled
72
75
  }, secondaryButtonText), primaryButtonText && primaryButtonPlacement === 'top' && /*#__PURE__*/_react.default.createElement(_react2.Button, {
73
76
  kind: "ghost",
74
77
  size: "sm",
75
78
  renderIcon: primaryButtonIcon,
76
79
  onClick: onPrimaryButtonClick,
77
- className: actionGhostButtonClass
80
+ className: actionGhostButtonClass,
81
+ disabled: primaryButtonDisabled
78
82
  }, primaryButtonText))));
79
83
  };
80
84
  exports.CardHeader = CardHeader;
@@ -86,9 +90,11 @@ CardHeader.propTypes = {
86
90
  noActionIcons: _propTypes.default.bool,
87
91
  onPrimaryButtonClick: _propTypes.default.func,
88
92
  onSecondaryButtonClick: _propTypes.default.func,
93
+ primaryButtonDisabled: _propTypes.default.bool,
89
94
  primaryButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
90
95
  primaryButtonPlacement: _propTypes.default.oneOf(['top', 'bottom']),
91
96
  primaryButtonText: _propTypes.default.string,
97
+ secondaryButtonDisabled: _propTypes.default.bool,
92
98
  secondaryButtonHref: _propTypes.default.string,
93
99
  secondaryButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
94
100
  secondaryButtonKind: _propTypes.default.oneOf(['secondary', 'ghost']),
@@ -28,6 +28,12 @@ var DocsPage = function DocsPage() {
28
28
  source: {
29
29
  code: "<CreateFullPageStep\n title=\"Required title\"\n subtitle=\"Optional subtitle\"\n description=\"Optional description\"\n onNext={() => {'Optional function'}}\n >\n <Row>\n <Column xlg={5} lg={5} md={4} sm={4}>\n <fieldset className={`#{$pkg-prefix}--create-full-page__step-fieldset`}>\n <TextInput\n id=\"test-1\"\n invalidText=\"A valid value is required\"\n labelText=\"Topic name\"\n placeholder=\"Enter topic name\"\n />\n </fieldset>\n </Column>\n </Row>\n <span className={`#{$pkg-prefix}--create-full-page__section-divider`} />\n <h5 className={`#{$pkg-prefix}--create-full-page__step-title`}>Required title</h5>\n <h6 className={`#{$pkg-prefix}--create-full-page__step-subtitle`}>\n Optional subtitle\n </h6>\n <p className={`#{$pkg-prefix}--create-full-page__step-description`}>\n Optional description\n </p>\n <Row>\n <Column xlg={5} lg={5} md={4} sm={4}>\n <fieldset className={`#{$pkg-prefix}--create-full-page__step-fieldset`}>\n <TextInput\n id=\"test-2\"\n invalidText=\"A valid value is required\"\n labelText=\"Topic name\"\n placeholder=\"Enter topic name\"\n />\n </fieldset>\n </Column>\n </Row>\n</CreateFullPageStep>"
30
30
  }
31
+ }, {
32
+ story: stories.createFullPageWithHeader,
33
+ description: "This is used when you want to show a header title and breadcrumbs. This can be created by\npassing in a title or breadcrumbs to the `<CreateFullPage />` component as shown below:",
34
+ source: {
35
+ code: "<CreateFullPage\n title='Page title'\n breadcrumbsOverflowAriaLabel='Open and close additional breadcrumb item list.'\n breadcrumbs={[\n { key: '0', label: 'Breadcrumb 1', href: '/', title: 'home page' },\n { key: '1', label: 'Breadcrumb 2', href: '/', },\n { key: '2', label: 'Breadcrumb 3', href:'/' },\n { key: '3', label: 'Breadcrumb 4', isCurrentPage: true }\n ]}\n maxVisibleBreadcrumbs={3}\n {...props}\n>\n <CreateFullPageStep {...createFullPageStepProps}>...</CreateFullPageStep>\n</CreateFullPage>"
36
+ }
31
37
  }, {
32
38
  title: 'Using custom components',
33
39
  description: "It is possible to use custom components that return `CreateFullPageStep`s in\norder to help reduce the amount of logic in the component that contains the main\n`CreateFullPage`. _It is required that each child of the `CreateFullPage` either\nbe a custom step or a `CreateFullPageStep`_. An example of this could look like\nthe following:",