@carbon/ibm-products 1.3.0 → 1.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (107) hide show
  1. package/css/index-full-carbon.css +1766 -1701
  2. package/css/index-full-carbon.css.map +1 -1
  3. package/css/index-full-carbon.min.css +2 -2
  4. package/css/index-without-carbon-released-only.css +32 -41
  5. package/css/index-without-carbon-released-only.css.map +1 -1
  6. package/css/index-without-carbon-released-only.min.css +2 -2
  7. package/css/index-without-carbon.css +228 -163
  8. package/css/index-without-carbon.css.map +1 -1
  9. package/css/index-without-carbon.min.css +2 -2
  10. package/css/index.css +1767 -1702
  11. package/css/index.css.map +1 -1
  12. package/css/index.min.css +2 -2
  13. package/es/components/APIKeyModal/APIKeyModal.js +25 -29
  14. package/es/components/ActionBar/ActionBar.js +4 -1
  15. package/es/components/AddSelect/AddSelect.js +65 -19
  16. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +19 -15
  17. package/es/components/CancelableTextEdit/CancelableTextEdit.js +60 -22
  18. package/es/components/CreateFullPage/CreateFullPage.js +78 -259
  19. package/es/components/CreateFullPage/CreateFullPageStep.js +58 -14
  20. package/es/components/CreateFullPage/index.js +1 -2
  21. package/es/components/CreateInfluencer/CreateInfluencer.js +23 -225
  22. package/es/components/CreateTearsheet/CreateTearsheet.js +69 -146
  23. package/es/components/CreateTearsheet/CreateTearsheetStep.js +59 -16
  24. package/es/components/CreateTearsheet/index.js +0 -1
  25. package/es/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +66 -27
  26. package/es/components/ExportModal/ExportModal.js +4 -2
  27. package/es/components/ImportModal/ImportModal.js +2 -1
  28. package/es/components/InlineEdit/InlineEdit.js +224 -0
  29. package/es/components/InlineEdit/index.js +7 -0
  30. package/es/components/MultiAddSelect/MultiAddSelect.js +16 -0
  31. package/es/components/MultiAddSelect/index.js +1 -0
  32. package/es/components/OptionsTile/OptionsTile.js +36 -15
  33. package/es/components/PageHeader/PageHeader.js +54 -33
  34. package/es/components/PageHeader/PageHeaderTitle.js +78 -7
  35. package/es/components/PageHeader/PageHeaderUtils.js +21 -2
  36. package/es/components/RemoveModal/RemoveModal.js +4 -2
  37. package/es/components/SingleAddSelect/SingleAddSelect.js +15 -0
  38. package/es/components/SingleAddSelect/index.js +1 -0
  39. package/es/components/TagSet/TagSet.js +4 -1
  40. package/es/components/Toolbar/Toolbar.js +69 -8
  41. package/es/components/index.js +4 -2
  42. package/es/global/js/hooks/useCreateComponentFocus.js +15 -19
  43. package/es/global/js/hooks/useCreateComponentStepChange.js +44 -74
  44. package/es/global/js/hooks/useValidCreateStepCount.js +4 -7
  45. package/es/global/js/package-settings.js +4 -2
  46. package/lib/components/APIKeyModal/APIKeyModal.js +25 -29
  47. package/lib/components/ActionBar/ActionBar.js +4 -1
  48. package/lib/components/AddSelect/AddSelect.js +64 -19
  49. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +18 -14
  50. package/lib/components/CancelableTextEdit/CancelableTextEdit.js +61 -22
  51. package/lib/components/CreateFullPage/CreateFullPage.js +78 -259
  52. package/lib/components/CreateFullPage/CreateFullPageStep.js +61 -14
  53. package/lib/components/CreateFullPage/index.js +1 -9
  54. package/lib/components/CreateInfluencer/CreateInfluencer.js +21 -236
  55. package/lib/components/CreateTearsheet/CreateTearsheet.js +71 -148
  56. package/lib/components/CreateTearsheet/CreateTearsheetStep.js +61 -15
  57. package/lib/components/CreateTearsheet/index.js +0 -8
  58. package/lib/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +67 -35
  59. package/lib/components/ExportModal/ExportModal.js +4 -2
  60. package/lib/components/ImportModal/ImportModal.js +2 -1
  61. package/lib/components/InlineEdit/InlineEdit.js +242 -0
  62. package/lib/components/InlineEdit/index.js +13 -0
  63. package/lib/components/MultiAddSelect/MultiAddSelect.js +37 -0
  64. package/lib/components/MultiAddSelect/index.js +13 -0
  65. package/lib/components/OptionsTile/OptionsTile.js +36 -15
  66. package/lib/components/PageHeader/PageHeader.js +54 -33
  67. package/lib/components/PageHeader/PageHeaderTitle.js +87 -9
  68. package/lib/components/PageHeader/PageHeaderUtils.js +21 -2
  69. package/lib/components/RemoveModal/RemoveModal.js +4 -2
  70. package/lib/components/SingleAddSelect/SingleAddSelect.js +36 -0
  71. package/lib/components/SingleAddSelect/index.js +13 -0
  72. package/lib/components/TagSet/TagSet.js +4 -1
  73. package/lib/components/Toolbar/Toolbar.js +69 -6
  74. package/lib/components/index.js +25 -9
  75. package/lib/global/js/hooks/useCreateComponentFocus.js +15 -19
  76. package/lib/global/js/hooks/useCreateComponentStepChange.js +44 -74
  77. package/lib/global/js/hooks/useValidCreateStepCount.js +4 -7
  78. package/lib/global/js/package-settings.js +4 -2
  79. package/package.json +8 -8
  80. package/scss/components/AddSelect/_add-select.scss +14 -3
  81. package/scss/components/BreadcrumbWithOverflow/_breadcrumb-with-overflow.scss +19 -15
  82. package/scss/components/CancelableTextEdit/_cancelable-text-edit.scss +141 -70
  83. package/scss/components/CreateFullPage/_create-full-page.scss +4 -11
  84. package/scss/components/CreateTearsheet/_create-tearsheet.scss +4 -8
  85. package/scss/components/InlineEdit/_index.scss +8 -0
  86. package/scss/components/InlineEdit/_inline-edit.scss +44 -0
  87. package/scss/components/InlineEdit/_storybook-styles.scss +15 -0
  88. package/scss/components/MultiAddSelect/_index.scss +1 -0
  89. package/scss/components/MultiAddSelect/_multi-add-select.scss +1 -0
  90. package/scss/components/MultiAddSelect/_storybook-styles.scss +6 -0
  91. package/scss/components/PageHeader/_page-header.scss +14 -4
  92. package/scss/components/SingleAddSelect/_index.scss +1 -0
  93. package/scss/components/SingleAddSelect/_single-add-select.scss +1 -0
  94. package/scss/components/SingleAddSelect/_storybook-styles.scss +6 -0
  95. package/scss/components/_index.scss +3 -1
  96. package/es/components/CreateFullPage/CreateFullPageSection.js +0 -53
  97. package/es/components/CreateFullPage/constants.js +0 -8
  98. package/es/components/CreateTearsheet/CreateTearsheetSection.js +0 -83
  99. package/es/components/CreateTearsheet/constants.js +0 -8
  100. package/es/components/CreateTearsheet/preview-components/MultiStepWithSectionsTearsheet.js +0 -327
  101. package/es/global/js/utils/hasValidType.js +0 -94
  102. package/lib/components/CreateFullPage/CreateFullPageSection.js +0 -74
  103. package/lib/components/CreateFullPage/constants.js +0 -16
  104. package/lib/components/CreateTearsheet/CreateTearsheetSection.js +0 -105
  105. package/lib/components/CreateTearsheet/constants.js +0 -17
  106. package/lib/components/CreateTearsheet/preview-components/MultiStepWithSectionsTearsheet.js +0 -354
  107. package/lib/global/js/utils/hasValidType.js +0 -110
@@ -87,7 +87,6 @@ export var APIKeyModal = /*#__PURE__*/forwardRef(function (_ref, ref) {
87
87
  currentStep = _useState6[0],
88
88
  setCurrentStep = _useState6[1];
89
89
 
90
- var inputRef = useRef();
91
90
  var copyRef = useRef();
92
91
  var apiKeyInputId = useRef(uuidv4());
93
92
  var nameInputId = useRef(uuidv4());
@@ -101,11 +100,6 @@ export var APIKeyModal = /*#__PURE__*/forwardRef(function (_ref, ref) {
101
100
  ref: copyRef
102
101
  };
103
102
  var blockClass = "".concat(pkg.prefix, "--apikey-modal");
104
- useEffect(function () {
105
- if (inputRef.current && open) {
106
- inputRef.current.focus();
107
- }
108
- }, [open]);
109
103
  useEffect(function () {
110
104
  if (copyRef.current && open && apiKeyLoaded) {
111
105
  copyRef.current.focus();
@@ -179,70 +173,72 @@ export var APIKeyModal = /*#__PURE__*/forwardRef(function (_ref, ref) {
179
173
  };
180
174
 
181
175
  var submitHandler = /*#__PURE__*/function () {
182
- var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
176
+ var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(e) {
183
177
  return _regeneratorRuntime.wrap(function _callee$(_context) {
184
178
  while (1) {
185
179
  switch (_context.prev = _context.next) {
186
180
  case 0:
181
+ e.preventDefault();
182
+
187
183
  if (!hasNextStep) {
188
- _context.next = 4;
184
+ _context.next = 5;
189
185
  break;
190
186
  }
191
187
 
192
188
  setCurrentStep(currentStep + 1);
193
- _context.next = 21;
189
+ _context.next = 22;
194
190
  break;
195
191
 
196
- case 4:
192
+ case 5:
197
193
  if (!apiKeyLoaded) {
198
- _context.next = 20;
194
+ _context.next = 21;
199
195
  break;
200
196
  }
201
197
 
202
198
  if (!onCopy) {
203
- _context.next = 9;
199
+ _context.next = 10;
204
200
  break;
205
201
  }
206
202
 
207
203
  onCopy(apiKey);
208
- _context.next = 18;
204
+ _context.next = 19;
209
205
  break;
210
206
 
211
- case 9:
212
- _context.prev = 9;
213
- _context.next = 12;
207
+ case 10:
208
+ _context.prev = 10;
209
+ _context.next = 13;
214
210
  return navigator.clipboard.writeText(apiKey);
215
211
 
216
- case 12:
217
- _context.next = 18;
212
+ case 13:
213
+ _context.next = 19;
218
214
  break;
219
215
 
220
- case 14:
221
- _context.prev = 14;
222
- _context.t0 = _context["catch"](9);
216
+ case 15:
217
+ _context.prev = 15;
218
+ _context.t0 = _context["catch"](10);
223
219
  console.error(_context.t0);
224
220
  setCopyError(true);
225
221
 
226
- case 18:
227
- _context.next = 21;
222
+ case 19:
223
+ _context.next = 22;
228
224
  break;
229
225
 
230
- case 20:
226
+ case 21:
231
227
  if (editing) {
232
228
  onRequestEdit(name);
233
229
  } else {
234
230
  onRequestGenerate(name);
235
231
  }
236
232
 
237
- case 21:
233
+ case 22:
238
234
  case "end":
239
235
  return _context.stop();
240
236
  }
241
237
  }
242
- }, _callee, null, [[9, 14]]);
238
+ }, _callee, null, [[10, 15]]);
243
239
  }));
244
240
 
245
- return function submitHandler() {
241
+ return function submitHandler(_x) {
246
242
  return _ref2.apply(this, arguments);
247
243
  };
248
244
  }();
@@ -293,8 +289,8 @@ export var APIKeyModal = /*#__PURE__*/forwardRef(function (_ref, ref) {
293
289
  value: name,
294
290
  id: nameInputId.current,
295
291
  disabled: loading,
296
- ref: inputRef,
297
- required: nameRequired
292
+ required: nameRequired,
293
+ "data-modal-primary-focus": true
298
294
  })), loading && /*#__PURE__*/React.createElement(InlineLoading, {
299
295
  description: loadingText,
300
296
  className: "".concat(blockClass, "__loader")
@@ -3,7 +3,7 @@ import _extends from "@babel/runtime/helpers/extends";
3
3
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
5
5
  var _excluded = ["actions", "className", "maxVisible", "menuOptionsClass", "onWidthChange", "overflowAriaLabel", "rightAlign"],
6
- _excluded2 = ["key"],
6
+ _excluded2 = ["key", "id"],
7
7
  _excluded3 = ["key"];
8
8
 
9
9
  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; }
@@ -80,9 +80,12 @@ export var ActionBar = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
80
80
  key: "hidden-overflow-menu"
81
81
  }), actions.map(function (_ref2) {
82
82
  var key = _ref2.key,
83
+ id = _ref2.id,
83
84
  rest = _objectWithoutProperties(_ref2, _excluded2);
84
85
 
85
86
  return /*#__PURE__*/React.createElement(ActionBarItem, _extends({}, rest, {
87
+ // ensure id is not duplicated
88
+ "data-original-id": id,
86
89
  key: "hidden-item-".concat(key),
87
90
  className: "".concat(blockClass, "__hidden-sizing-item")
88
91
  }));
@@ -1,7 +1,7 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
2
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
3
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
- var _excluded = ["actions", "className", "description", "influencerTitle", "inputPlaceholder", "items", "itemsLabel", "multiSelect", "noSelectionDescription", "noSelectionTitle", "open", "title"];
4
+ var _excluded = ["actions", "className", "description", "influencerTitle", "inputPlaceholder", "items", "itemsLabel", "multi", "noResultsDescription", "noResultsTitle", "noSelectionDescription", "noSelectionTitle", "onSearchFilter", "open", "title"];
5
5
  //
6
6
  // Copyright IBM Corp. 2021
7
7
  //
@@ -25,26 +25,59 @@ export var AddSelect = /*#__PURE__*/forwardRef(function (_ref, ref) {
25
25
  inputPlaceholder = _ref.inputPlaceholder,
26
26
  items = _ref.items,
27
27
  itemsLabel = _ref.itemsLabel,
28
- multiSelect = _ref.multiSelect,
28
+ multi = _ref.multi,
29
+ noResultsDescription = _ref.noResultsDescription,
30
+ noResultsTitle = _ref.noResultsTitle,
29
31
  noSelectionDescription = _ref.noSelectionDescription,
30
32
  noSelectionTitle = _ref.noSelectionTitle,
33
+ onSearchFilter = _ref.onSearchFilter,
31
34
  open = _ref.open,
32
35
  title = _ref.title,
33
36
  rest = _objectWithoutProperties(_ref, _excluded);
34
37
 
35
38
  var blockClass = "".concat(pkg.prefix, "--add-select");
36
-
37
- var _useState = useState(0),
38
- _useState2 = _slicedToArray(_useState, 1),
39
- selected = _useState2[0];
40
-
41
39
  var commonTearsheetProps = {
42
40
  open: open,
43
41
  title: title,
44
42
  actions: actions,
45
43
  description: description,
46
44
  closeIconDescription: 'temp description'
45
+ }; // hooks
46
+
47
+ var _useState = useState(0),
48
+ _useState2 = _slicedToArray(_useState, 1),
49
+ selected = _useState2[0];
50
+
51
+ var _useState3 = useState(''),
52
+ _useState4 = _slicedToArray(_useState3, 2),
53
+ searchTerm = _useState4[0],
54
+ setSearchTerm = _useState4[1]; // handlers
55
+
56
+
57
+ var onSearchHandler = function onSearchHandler(e) {
58
+ var value = e.target.value;
59
+ setSearchTerm(value);
60
+
61
+ if (onSearchFilter) {
62
+ onSearchFilter(value);
63
+ }
64
+ }; // data manipulation
65
+
66
+
67
+ var getFilteredItems = function getFilteredItems() {
68
+ // if the user uses their own filter then they provide the filtered items
69
+ if (onSearchFilter) {
70
+ return items;
71
+ } // by default, just filter results by their label from a single search term
72
+
73
+
74
+ return items.filter(function (i) {
75
+ return i.label.includes(searchTerm);
76
+ });
47
77
  };
78
+
79
+ var filteredResults = getFilteredItems(); // sidebar
80
+
48
81
  var influencer = /*#__PURE__*/React.createElement("div", {
49
82
  className: "".concat(blockClass, "__influencer")
50
83
  }, /*#__PURE__*/React.createElement("div", {
@@ -60,13 +93,16 @@ export var AddSelect = /*#__PURE__*/forwardRef(function (_ref, ref) {
60
93
  subtitle: noSelectionDescription,
61
94
  title: noSelectionTitle,
62
95
  size: "sm"
63
- })));
96
+ }))); // main content
97
+
64
98
  var body = /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
65
99
  className: "".concat(blockClass, "__header")
66
100
  }, /*#__PURE__*/React.createElement(TextInput, {
67
101
  id: "temp-id",
68
102
  labelText: "temp label",
69
- placeholder: inputPlaceholder
103
+ placeholder: inputPlaceholder,
104
+ value: searchTerm,
105
+ onChange: onSearchHandler
70
106
  }), /*#__PURE__*/React.createElement("div", {
71
107
  className: "".concat(blockClass, "__items-label-container")
72
108
  }, /*#__PURE__*/React.createElement("p", {
@@ -74,38 +110,48 @@ export var AddSelect = /*#__PURE__*/forwardRef(function (_ref, ref) {
74
110
  }, itemsLabel), /*#__PURE__*/React.createElement(Tag, {
75
111
  type: "gray",
76
112
  size: "sm"
77
- }, items.length))), /*#__PURE__*/React.createElement(StructuredListWrapper, {
113
+ }, filteredResults.length))), filteredResults.length > 0 ? /*#__PURE__*/React.createElement(StructuredListWrapper, {
78
114
  selection: true,
79
115
  className: "".concat(blockClass, "__selections")
80
- }, /*#__PURE__*/React.createElement(StructuredListBody, null, items.map(function (item) {
116
+ }, /*#__PURE__*/React.createElement(StructuredListBody, null, filteredResults.map(function (item) {
81
117
  return /*#__PURE__*/React.createElement(StructuredListRow, {
82
118
  key: item.id
83
119
  }, /*#__PURE__*/React.createElement(StructuredListCell, null, /*#__PURE__*/React.createElement("p", null, item.label)));
84
- }))));
120
+ }))) : /*#__PURE__*/React.createElement("div", {
121
+ className: "".concat(blockClass, "__body")
122
+ }, /*#__PURE__*/React.createElement(NoDataEmptyState, {
123
+ subtitle: noResultsDescription,
124
+ title: noResultsTitle
125
+ })));
85
126
  return /*#__PURE__*/React.createElement("div", _extends({
86
127
  ref: ref,
87
128
  className: cx(className, blockClass)
88
- }, rest), multiSelect ? /*#__PURE__*/React.createElement(Tearsheet, _extends({}, commonTearsheetProps, {
89
- influencer: multiSelect && influencer,
129
+ }, rest), multi ? /*#__PURE__*/React.createElement(Tearsheet, _extends({}, commonTearsheetProps, {
130
+ influencer: multi && influencer,
90
131
  influencerPosition: "right"
91
132
  }), body) : /*#__PURE__*/React.createElement(TearsheetNarrow, commonTearsheetProps, body));
92
133
  });
93
- AddSelect = pkg.checkComponentEnabled(AddSelect, componentName);
94
- AddSelect.displayName = componentName;
95
134
  AddSelect.propTypes = {
96
135
  actions: PropTypes.array,
97
136
  className: PropTypes.string,
98
137
  description: PropTypes.string,
99
138
  influencerTitle: PropTypes.string,
100
139
  inputPlaceholder: PropTypes.string,
101
- items: PropTypes.array,
140
+ items: PropTypes.arrayOf(PropTypes.shape({
141
+ label: PropTypes.string,
142
+ id: PropTypes.oneOfType([PropTypes.string, PropTypes.number])
143
+ })),
102
144
  itemsLabel: PropTypes.string,
103
- multiSelect: PropTypes.bool,
145
+ multi: PropTypes.bool,
146
+ noResultsDescription: PropTypes.string,
147
+ noResultsTitle: PropTypes.string,
104
148
  noSelectionDescription: PropTypes.string,
105
149
  noSelectionTitle: PropTypes.string,
150
+ onSearchFilter: PropTypes.func,
106
151
  open: PropTypes.bool,
107
152
  title: PropTypes.string
108
153
  };
109
154
  AddSelect.defaultProps = {
110
155
  items: []
111
- };
156
+ };
157
+ AddSelect.displayName = componentName;
@@ -3,7 +3,7 @@ import _extends from "@babel/runtime/helpers/extends";
3
3
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
5
5
  var _excluded = ["breadcrumbs", "className", "maxVisible", "noTrailingSlash", "overflowAriaLabel"],
6
- _excluded2 = ["label", "key", "title"],
6
+ _excluded2 = ["label", "key", "title", "id"],
7
7
  _excluded3 = ["className", "key", "label", "title"];
8
8
 
9
9
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
@@ -23,7 +23,7 @@ import React, { useState, useEffect, useRef } from 'react'; // Other standard im
23
23
 
24
24
  import PropTypes from 'prop-types';
25
25
  import cx from 'classnames';
26
- import { Button } from 'carbon-components-react';
26
+ import { Link, TooltipIcon } from 'carbon-components-react';
27
27
  import { pkg, carbon } from '../../settings';
28
28
  import { useResizeDetector } from 'react-resize-detector';
29
29
  import { ArrowLeft16 } from '@carbon/icons-react'; // Carbon and package components we use.
@@ -105,11 +105,14 @@ export var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
105
105
  var label = _ref3.label,
106
106
  key = _ref3.key,
107
107
  title = _ref3.title,
108
+ id = _ref3.id,
108
109
  rest = _objectWithoutProperties(_ref3, _excluded2);
109
110
 
110
111
  return /*#__PURE__*/React.createElement(BreadcrumbItem, _extends({
111
112
  key: key
112
113
  }, rest, {
114
+ // ensure id is not duplicated
115
+ "data-original-id": id,
113
116
  title: title !== null && title !== void 0 ? title : label
114
117
  }), label);
115
118
  }))));
@@ -258,7 +261,7 @@ export var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
258
261
  /* istanbul ignore if */
259
262
  // not sure how to test media queries
260
263
 
261
- if ((_backItem = backItem) !== null && _backItem !== void 0 && _backItem.isCurrentPage) {
264
+ if (backItem.isCurrentPage) {
262
265
  backItem = breadcrumbs[breadcrumbs.length - 2];
263
266
  }
264
267
 
@@ -275,20 +278,21 @@ export var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
275
278
  ref: breadcrumbItemWithOverflow
276
279
  }, /*#__PURE__*/React.createElement("div", {
277
280
  className: cx(["".concat(blockClass, "__space")])
278
- }, hiddenSizingItems, ((_backItem2 = backItem) === null || _backItem2 === void 0 ? void 0 : _backItem2.href) && ((_backItem3 = backItem) === null || _backItem3 === void 0 ? void 0 : _backItem3.title) && /*#__PURE__*/React.createElement(Button, {
279
- className: "".concat(blockClass, "__breadcrumb-back-button"),
280
- hasIconOnly: true,
281
- iconDescription: backItem.title,
282
- kind: "ghost",
283
- href: backItem.href,
284
- renderIcon: ArrowLeft16,
285
- size: "field",
286
- tooltipPosition: "right",
287
- type: "button"
288
- }), /*#__PURE__*/React.createElement(Breadcrumb, _extends({
281
+ }, hiddenSizingItems, /*#__PURE__*/React.createElement(Breadcrumb, _extends({
289
282
  className: cx("".concat(blockClass, "__breadcrumb-container"), _defineProperty({}, "".concat(blockClass, "__breadcrumb-container-with-items"), displayedBreadcrumbItems.length > 1)),
290
283
  noTrailingSlash: noTrailingSlash
291
- }, other), displayedBreadcrumbItems)));
284
+ }, other), ((_backItem = backItem) === null || _backItem === void 0 ? void 0 : _backItem.href) && (((_backItem2 = backItem) === null || _backItem2 === void 0 ? void 0 : _backItem2.label) || ((_backItem3 = backItem) === null || _backItem3 === void 0 ? void 0 : _backItem3.title)) && /*#__PURE__*/React.createElement(BreadcrumbItem, {
285
+ className: cx("".concat(blockClass, "__breadcrumb-back"))
286
+ }, /*#__PURE__*/React.createElement(Link, {
287
+ href: backItem.href,
288
+ renderIcon: function renderIcon() {
289
+ return /*#__PURE__*/React.createElement(TooltipIcon, {
290
+ tooltipText: backItem.title || backItem.label,
291
+ direction: "right",
292
+ renderIcon: ArrowLeft16
293
+ });
294
+ }
295
+ })), displayedBreadcrumbItems)));
292
296
  }; // Return a placeholder if not released and not enabled by feature flag
293
297
 
294
298
  BreadcrumbWithOverflow = pkg.checkComponentEnabled(BreadcrumbWithOverflow, componentName);
@@ -2,7 +2,7 @@ import _extends from "@babel/runtime/helpers/extends";
2
2
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
3
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
5
- var _excluded = ["className", "inline", "invalid", "invalidText", "labelText", "onChange", "onInput", "revertLabel", "saveLabel", "value", "warn", "warnText"];
5
+ var _excluded = ["className", "hideLabel", "inline", "invalid", "invalidText", "labelText", "onChange", "onInput", "onRevert", "revertDescription", "saveDescription", "saveDisabled", "size", "value", "warn", "warnText"];
6
6
 
7
7
  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; }
8
8
 
@@ -22,6 +22,7 @@ import cx from 'classnames';
22
22
  import { Button, TextInput } from 'carbon-components-react';
23
23
  import { prepareProps } from '../../global/js/utils/props-helper';
24
24
  import { pkg, carbon } from '../../settings';
25
+ import { getDevtoolsProps } from '../../global/js/utils/devtools';
25
26
  import { Checkmark16, Reset16 } from '@carbon/icons-react'; // Carbon and package components we use.
26
27
 
27
28
  /* TODO: @import(s) of carbon components and other package components. */
@@ -38,14 +39,18 @@ export var CancelableTextEdit = /*#__PURE__*/React.forwardRef(function (_ref, re
38
39
  var _cx;
39
40
 
40
41
  var className = _ref.className,
42
+ hideLabel = _ref.hideLabel,
41
43
  inline = _ref.inline,
42
44
  invalid = _ref.invalid,
43
45
  invalidText = _ref.invalidText,
44
46
  labelText = _ref.labelText,
45
47
  onChange = _ref.onChange,
46
48
  onInput = _ref.onInput,
47
- revertLabel = _ref.revertLabel,
48
- saveLabel = _ref.saveLabel,
49
+ onRevert = _ref.onRevert,
50
+ revertDescription = _ref.revertDescription,
51
+ saveDescription = _ref.saveDescription,
52
+ saveDisabled = _ref.saveDisabled,
53
+ size = _ref.size,
49
54
  value = _ref.value,
50
55
  warn = _ref.warn,
51
56
  warnText = _ref.warnText,
@@ -83,6 +88,10 @@ export var CancelableTextEdit = /*#__PURE__*/React.forwardRef(function (_ref, re
83
88
 
84
89
  var handleRevert = function handleRevert() {
85
90
  doInput(value);
91
+
92
+ if (onRevert) {
93
+ onRevert(value);
94
+ }
86
95
  };
87
96
 
88
97
  var handleSave = function handleSave() {
@@ -91,15 +100,19 @@ export var CancelableTextEdit = /*#__PURE__*/React.forwardRef(function (_ref, re
91
100
  }
92
101
  };
93
102
 
94
- return /*#__PURE__*/React.createElement("div", {
95
- className: cx(className, "".concat(blockClass), (_cx = {}, _defineProperty(_cx, "".concat(blockClass, "--invalid"), invalid), _defineProperty(_cx, "".concat(blockClass, "--warn"), warn), _cx))
103
+ return /*#__PURE__*/React.createElement("div", _extends({
104
+ className: cx(className, "".concat(blockClass), "".concat(blockClass, "--").concat(size), (_cx = {}, _defineProperty(_cx, "".concat(blockClass, "--invalid"), invalid), _defineProperty(_cx, "".concat(blockClass, "--warn"), warn), _defineProperty(_cx, "".concat(blockClass, "--inline"), inline), _cx))
105
+ }, getDevtoolsProps(componentName)), /*#__PURE__*/React.createElement("div", {
106
+ className: "".concat(blockClass, "__main")
96
107
  }, /*#__PURE__*/React.createElement(TextInput, _extends({}, prepareProps(rest, removeProps), {
97
108
  // it is not permitted to pass children down to TextInput guard against this
98
109
  className: "".concat(blockClass, "__input"),
99
110
  ref: ref,
100
111
  onInput: handleInput,
112
+ size: size,
101
113
  value: liveValue !== null && liveValue !== void 0 ? liveValue : '' // ?? '' prevents controlled components test failure https://reactjs.org/docs/forms.html#controlled-components
102
114
  ,
115
+ hideLabel: hideLabel,
103
116
  inline: inline,
104
117
  invalid: invalid,
105
118
  invalidText: invalidText,
@@ -108,25 +121,29 @@ export var CancelableTextEdit = /*#__PURE__*/React.forwardRef(function (_ref, re
108
121
  warnText: warnText
109
122
  })), /*#__PURE__*/React.createElement("div", {
110
123
  className: "".concat(blockClass, "__buttons")
111
- }, !inline && labelText && /*#__PURE__*/React.createElement("div", {
124
+ }, !inline && !hideLabel && labelText && /*#__PURE__*/React.createElement("div", {
112
125
  className: "".concat(blockClass, "__label-spacer ").concat(carbon.prefix, "--label")
113
- }, "\xA0"), /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Button, {
114
- className: "".concat(blockClass, "__revert ").concat(carbon.prefix, "--search-close"),
126
+ }, "\xA0"), /*#__PURE__*/React.createElement("div", {
127
+ className: "".concat(blockClass, "__buttons-inner")
128
+ }, /*#__PURE__*/React.createElement(Button, {
129
+ className: "".concat(blockClass, "__revert"),
115
130
  kind: "ghost",
116
131
  hasIconOnly: true,
117
- iconDescription: revertLabel,
132
+ iconDescription: revertDescription,
118
133
  onClick: handleRevert,
119
134
  renderIcon: Reset16
120
135
  }), /*#__PURE__*/React.createElement(Button, {
121
- className: "".concat(blockClass, "__save ").concat(carbon.prefix, "--search-close"),
136
+ className: "".concat(blockClass, "__save"),
122
137
  kind: "ghost",
123
138
  hasIconOnly: true,
124
- iconDescription: saveLabel,
139
+ iconDescription: saveDescription,
125
140
  onClick: handleSave,
126
141
  renderIcon: Checkmark16,
127
- disabled: invalid
128
- }))), inline && (showInvalid || showWarn) && /*#__PURE__*/React.createElement("div", {
129
- className: "".concat(carbon.prefix, "--form-requirement")
142
+ disabled: invalid || saveDisabled || value === liveValue,
143
+ "data-v": value,
144
+ "data-lv": liveValue
145
+ })))), inline && (showInvalid || showWarn) && /*#__PURE__*/React.createElement("div", {
146
+ className: "".concat(blockClass, "__problem ").concat(carbon.prefix, "--form-requirement")
130
147
  }, showInvalid ? invalidText : warnText));
131
148
  }); // Return a placeholder if not released and not enabled by feature flag
132
149
 
@@ -143,23 +160,28 @@ CancelableTextEdit.propTypes = _objectSpread(_objectSpread({}, prepareProps(Text
143
160
  */
144
161
  className: PropTypes.string,
145
162
 
163
+ /**
164
+ * hide the label
165
+ */
166
+ hideLabel: PropTypes.bool,
167
+
146
168
  /**
147
169
  * inline variant
148
170
  */
149
171
  inline: PropTypes.bool,
150
172
 
151
173
  /**
152
- * show invalid for current value
174
+ * set invalid state for input
153
175
  */
154
176
  invalid: PropTypes.bool,
155
177
 
156
178
  /**
157
- * invalid text
179
+ * text shown when invalid is true
158
180
  */
159
181
  invalidText: PropTypes.string,
160
182
 
161
183
  /**
162
- * labelText for text input
184
+ * label for text input
163
185
  */
164
186
  labelText: PropTypes.string,
165
187
 
@@ -173,28 +195,43 @@ CancelableTextEdit.propTypes = _objectSpread(_objectSpread({}, prepareProps(Text
173
195
  */
174
196
  onInput: PropTypes.func,
175
197
 
198
+ /**
199
+ * method called on revert event
200
+ */
201
+ onRevert: PropTypes.func,
202
+
176
203
  /**
177
204
  * label for revert button
178
205
  */
179
- revertLabel: PropTypes.string.isRequired,
206
+ revertDescription: PropTypes.string.isRequired,
180
207
 
181
208
  /**
182
209
  * label for save button
183
210
  */
184
- saveLabel: PropTypes.string.isRequired,
211
+ saveDescription: PropTypes.string.isRequired,
212
+
213
+ /**
214
+ * disabled state of the save button
215
+ */
216
+ saveDisabled: PropTypes.bool,
217
+
218
+ /**
219
+ * vertical size of control
220
+ */
221
+ size: PropTypes.oneOf(['sm', 'md', 'lg']),
185
222
 
186
223
  /**
187
- * unedited value
224
+ * initial/unedited value
188
225
  */
189
226
  value: PropTypes.string,
190
227
 
191
228
  /**
192
- * show warning for current value
229
+ * set warn state for input
193
230
  */
194
231
  warn: PropTypes.bool,
195
232
 
196
233
  /**
197
- * warn text
234
+ * text shown when warn true
198
235
  */
199
236
  warnText: PropTypes.string
200
237
  }); // Default values for component props. Default values are not required for
@@ -204,4 +241,5 @@ CancelableTextEdit.propTypes = _objectSpread(_objectSpread({}, prepareProps(Text
204
241
 
205
242
  CancelableTextEdit.defaultProps = {
206
243
  /* TODO: add defaults for relevant props. */
244
+ size: 'md'
207
245
  };