@carbon/ibm-products 1.2.5 → 1.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (164) hide show
  1. package/css/index-full-carbon.css +1028 -517
  2. package/css/index-full-carbon.css.map +1 -1
  3. package/css/index-full-carbon.min.css +3 -3
  4. package/css/index-without-carbon-released-only.css +187 -108
  5. package/css/index-without-carbon-released-only.css.map +1 -1
  6. package/css/index-without-carbon-released-only.min.css +3 -3
  7. package/css/index-without-carbon.css +580 -114
  8. package/css/index-without-carbon.css.map +1 -1
  9. package/css/index-without-carbon.min.css +3 -3
  10. package/css/index.css +804 -116
  11. package/css/index.css.map +1 -1
  12. package/css/index.min.css +3 -3
  13. package/es/components/APIKeyModal/APIKeyModal.js +25 -29
  14. package/es/components/ActionBar/ActionBar.js +4 -1
  15. package/es/components/ActionSet/ActionSet.js +22 -10
  16. package/es/components/ActionSet/actions.js +25 -17
  17. package/es/components/AddSelect/AddSelect.js +198 -0
  18. package/es/components/AddSelect/AddSelectBreadcrumbs.js +56 -0
  19. package/es/components/AddSelect/AddSelectList.js +94 -0
  20. package/es/components/AddSelect/AddSelectSidebar.js +46 -0
  21. package/es/components/AddSelect/index.js +7 -0
  22. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +24 -17
  23. package/es/components/CancelableTextEdit/CancelableTextEdit.js +245 -0
  24. package/es/components/{CreateTearsheet/constants.js → CancelableTextEdit/index.js} +1 -2
  25. package/es/components/Card/Card.js +6 -4
  26. package/es/components/CreateFullPage/CreateFullPage.js +102 -258
  27. package/es/components/CreateFullPage/CreateFullPageStep.js +65 -13
  28. package/es/components/CreateFullPage/index.js +1 -2
  29. package/es/components/CreateInfluencer/CreateInfluencer.js +40 -220
  30. package/es/components/CreateTearsheet/CreateTearsheet.js +95 -146
  31. package/es/components/CreateTearsheet/CreateTearsheetStep.js +70 -20
  32. package/es/components/CreateTearsheet/index.js +0 -1
  33. package/es/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +87 -28
  34. package/es/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +8 -6
  35. package/es/components/ExportModal/ExportModal.js +41 -12
  36. package/es/components/ImportModal/ImportModal.js +2 -1
  37. package/es/components/InlineEdit/InlineEdit.js +373 -0
  38. package/es/components/InlineEdit/index.js +7 -0
  39. package/es/components/MultiAddSelect/MultiAddSelect.js +16 -0
  40. package/es/components/MultiAddSelect/index.js +1 -0
  41. package/es/components/NotificationsPanel/NotificationsPanel.js +16 -3
  42. package/es/components/OptionsTile/OptionsTile.js +36 -15
  43. package/es/components/PageHeader/PageHeader.js +59 -35
  44. package/es/components/PageHeader/PageHeaderTitle.js +82 -7
  45. package/es/components/PageHeader/PageHeaderUtils.js +21 -2
  46. package/es/components/RemoveModal/RemoveModal.js +4 -2
  47. package/es/components/SidePanel/SidePanel.js +33 -16
  48. package/es/components/SingleAddSelect/SingleAddSelect.js +15 -0
  49. package/es/components/SingleAddSelect/index.js +1 -0
  50. package/es/components/TagSet/TagSet.js +4 -1
  51. package/es/components/Tearsheet/Tearsheet.js +1 -1
  52. package/es/components/Tearsheet/TearsheetNarrow.js +1 -1
  53. package/es/components/Tearsheet/TearsheetShell.js +1 -1
  54. package/es/components/Toolbar/Toolbar.js +69 -8
  55. package/es/components/WebTerminal/WebTerminal.js +1 -1
  56. package/es/components/index.js +5 -1
  57. package/es/global/js/hooks/index.js +1 -0
  58. package/es/global/js/hooks/useCreateComponentFocus.js +15 -19
  59. package/es/global/js/hooks/useCreateComponentStepChange.js +69 -79
  60. package/es/global/js/hooks/useResetCreateComponent.js +7 -4
  61. package/es/global/js/hooks/useRetrieveStepData.js +51 -0
  62. package/es/global/js/hooks/useValidCreateStepCount.js +4 -7
  63. package/es/global/js/package-settings.js +5 -1
  64. package/es/global/js/utils/lastIndexInArray.js +26 -0
  65. package/es/settings.js +0 -5
  66. package/lib/components/APIKeyModal/APIKeyModal.js +25 -29
  67. package/lib/components/ActionBar/ActionBar.js +4 -1
  68. package/lib/components/ActionSet/ActionSet.js +22 -10
  69. package/lib/components/ActionSet/actions.js +25 -17
  70. package/lib/components/AddSelect/AddSelect.js +223 -0
  71. package/lib/components/AddSelect/AddSelectBreadcrumbs.js +71 -0
  72. package/lib/components/AddSelect/AddSelectList.js +112 -0
  73. package/lib/components/AddSelect/AddSelectSidebar.js +63 -0
  74. package/lib/components/AddSelect/index.js +13 -0
  75. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +23 -16
  76. package/lib/components/CancelableTextEdit/CancelableTextEdit.js +265 -0
  77. package/lib/components/CancelableTextEdit/index.js +13 -0
  78. package/lib/components/Card/Card.js +6 -4
  79. package/lib/components/CreateFullPage/CreateFullPage.js +102 -258
  80. package/lib/components/CreateFullPage/CreateFullPageStep.js +68 -13
  81. package/lib/components/CreateFullPage/index.js +1 -9
  82. package/lib/components/CreateInfluencer/CreateInfluencer.js +38 -231
  83. package/lib/components/CreateTearsheet/CreateTearsheet.js +97 -148
  84. package/lib/components/CreateTearsheet/CreateTearsheetStep.js +72 -19
  85. package/lib/components/CreateTearsheet/index.js +0 -8
  86. package/lib/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +86 -34
  87. package/lib/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +8 -6
  88. package/lib/components/ExportModal/ExportModal.js +38 -11
  89. package/lib/components/ImportModal/ImportModal.js +2 -1
  90. package/lib/components/InlineEdit/InlineEdit.js +389 -0
  91. package/lib/components/InlineEdit/index.js +13 -0
  92. package/lib/components/MultiAddSelect/MultiAddSelect.js +37 -0
  93. package/lib/components/MultiAddSelect/index.js +13 -0
  94. package/lib/components/NotificationsPanel/NotificationsPanel.js +13 -1
  95. package/lib/components/OptionsTile/OptionsTile.js +36 -15
  96. package/lib/components/PageHeader/PageHeader.js +59 -35
  97. package/lib/components/PageHeader/PageHeaderTitle.js +91 -9
  98. package/lib/components/PageHeader/PageHeaderUtils.js +21 -2
  99. package/lib/components/RemoveModal/RemoveModal.js +4 -2
  100. package/lib/components/SidePanel/SidePanel.js +33 -16
  101. package/lib/components/SingleAddSelect/SingleAddSelect.js +36 -0
  102. package/lib/components/SingleAddSelect/index.js +13 -0
  103. package/lib/components/TagSet/TagSet.js +4 -1
  104. package/lib/components/Tearsheet/Tearsheet.js +1 -1
  105. package/lib/components/Tearsheet/TearsheetNarrow.js +1 -1
  106. package/lib/components/Tearsheet/TearsheetShell.js +1 -1
  107. package/lib/components/Toolbar/Toolbar.js +69 -6
  108. package/lib/components/WebTerminal/WebTerminal.js +1 -1
  109. package/lib/components/index.js +33 -1
  110. package/lib/global/js/hooks/index.js +8 -0
  111. package/lib/global/js/hooks/useCreateComponentFocus.js +15 -19
  112. package/lib/global/js/hooks/useCreateComponentStepChange.js +69 -79
  113. package/lib/global/js/hooks/useResetCreateComponent.js +7 -4
  114. package/lib/global/js/hooks/useRetrieveStepData.js +62 -0
  115. package/lib/global/js/hooks/useValidCreateStepCount.js +4 -7
  116. package/lib/global/js/package-settings.js +5 -1
  117. package/lib/global/js/utils/lastIndexInArray.js +35 -0
  118. package/lib/settings.js +0 -6
  119. package/package.json +19 -19
  120. package/scss/components/AddSelect/_add-select.scss +108 -0
  121. package/scss/components/AddSelect/_index.scss +10 -0
  122. package/scss/components/AddSelect/_storybook-styles.scss +6 -0
  123. package/scss/components/BreadcrumbWithOverflow/_breadcrumb-with-overflow.scss +19 -15
  124. package/scss/components/BreadcrumbWithOverflow/_index.scss +1 -1
  125. package/scss/components/CancelableTextEdit/_cancelable-text-edit.scss +212 -0
  126. package/{es/components/CreateFullPage/constants.js → scss/components/CancelableTextEdit/_index.scss} +2 -2
  127. package/scss/components/CancelableTextEdit/_storybook-styles.scss +15 -0
  128. package/scss/components/CreateFullPage/_create-full-page.scss +4 -11
  129. package/scss/components/CreateInfluencer/_create-influencer.scss +4 -4
  130. package/scss/components/CreateTearsheet/_create-tearsheet.scss +6 -10
  131. package/scss/components/InlineEdit/_index.scss +8 -0
  132. package/scss/components/InlineEdit/_inline-edit.scss +245 -0
  133. package/scss/components/InlineEdit/_storybook-styles.scss +28 -0
  134. package/scss/components/MultiAddSelect/_index.scss +1 -0
  135. package/scss/components/MultiAddSelect/_multi-add-select.scss +1 -0
  136. package/scss/components/MultiAddSelect/_storybook-styles.scss +6 -0
  137. package/scss/components/NotificationsPanel/_notifications-panel.scss +2 -2
  138. package/scss/components/PageHeader/_index.scss +1 -1
  139. package/scss/components/PageHeader/_page-header.scss +15 -5
  140. package/scss/components/ProductiveCard/_productive-card.scss +0 -4
  141. package/scss/components/SidePanel/_side-panel.scss +15 -6
  142. package/scss/components/SingleAddSelect/_index.scss +1 -0
  143. package/scss/components/SingleAddSelect/_single-add-select.scss +1 -0
  144. package/scss/components/SingleAddSelect/_storybook-styles.scss +6 -0
  145. package/scss/components/StatusIcon/_index.scss +1 -1
  146. package/scss/components/StatusIcon/_status-icon.scss +2 -0
  147. package/scss/components/TagSet/_index.scss +1 -1
  148. package/scss/components/UserProfileImage/_index.scss +1 -1
  149. package/scss/components/WebTerminal/_web-terminal.scss +2 -2
  150. package/scss/components/_index.scss +4 -0
  151. package/scss/global/styles/_project-settings.scss +5 -1
  152. package/es/components/CreateFullPage/CreateFullPageSection.js +0 -53
  153. package/es/components/CreateTearsheet/CreateTearsheetSection.js +0 -83
  154. package/es/components/CreateTearsheet/preview-components/MultiStepWithSectionsTearsheet.js +0 -327
  155. package/es/generated/feature-flags/feature-flags.js +0 -15
  156. package/es/global/js/utils/hasValidType.js +0 -94
  157. package/lib/components/CreateFullPage/CreateFullPageSection.js +0 -74
  158. package/lib/components/CreateFullPage/constants.js +0 -16
  159. package/lib/components/CreateTearsheet/CreateTearsheetSection.js +0 -105
  160. package/lib/components/CreateTearsheet/constants.js +0 -17
  161. package/lib/components/CreateTearsheet/preview-components/MultiStepWithSectionsTearsheet.js +0 -354
  162. package/lib/generated/feature-flags/feature-flags.js +0 -22
  163. package/lib/global/js/utils/hasValidType.js +0 -110
  164. package/scss/generated/feature-flags/_feature-flags.scss +0 -19
@@ -0,0 +1,46 @@
1
+ //
2
+ // Copyright IBM Corp. 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 React from 'react';
8
+ import { Tag } from 'carbon-components-react';
9
+ import PropTypes from 'prop-types';
10
+ import { NoDataEmptyState } from '../../components/EmptyStates/NoDataEmptyState';
11
+ import { pkg } from '../../settings';
12
+ var componentName = 'AddSelectSidebar';
13
+ export var AddSelectSidebar = function AddSelectSidebar(_ref) {
14
+ var influencerTitle = _ref.influencerTitle,
15
+ multiSelection = _ref.multiSelection,
16
+ noSelectionDescription = _ref.noSelectionDescription,
17
+ noSelectionTitle = _ref.noSelectionTitle;
18
+ var blockClass = "".concat(pkg.prefix, "--add-select__influencer");
19
+ return /*#__PURE__*/React.createElement("div", {
20
+ className: "".concat(blockClass)
21
+ }, /*#__PURE__*/React.createElement("div", {
22
+ className: "".concat(blockClass, "-header")
23
+ }, /*#__PURE__*/React.createElement("p", {
24
+ className: "".concat(blockClass, "-title")
25
+ }, influencerTitle), /*#__PURE__*/React.createElement(Tag, {
26
+ type: "gray",
27
+ size: "sm"
28
+ }, multiSelection.length)), /*#__PURE__*/React.createElement("div", {
29
+ className: "".concat(blockClass, "-body")
30
+ }, multiSelection.length > 0 ? multiSelection.map(function (item) {
31
+ return /*#__PURE__*/React.createElement("p", {
32
+ key: item
33
+ }, item);
34
+ }) : /*#__PURE__*/React.createElement(NoDataEmptyState, {
35
+ subtitle: noSelectionDescription,
36
+ title: noSelectionTitle,
37
+ size: "sm"
38
+ })));
39
+ };
40
+ AddSelectSidebar.propTypes = {
41
+ influencerTitle: PropTypes.string,
42
+ multiSelection: PropTypes.array,
43
+ noSelectionDescription: PropTypes.string,
44
+ noSelectionTitle: PropTypes.string
45
+ };
46
+ AddSelectSidebar.displayName = componentName;
@@ -0,0 +1,7 @@
1
+ //
2
+ // Copyright IBM Corp. 2021
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
+ export { AddSelect } from './AddSelect';
@@ -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);
@@ -339,9 +343,12 @@ BreadcrumbWithOverflow.propTypes = {
339
343
  noTrailingSlash: PropTypes.bool,
340
344
 
341
345
  /**
342
- * overflowAriaLabel label for open close button overflow used for action bar items that do nto fit.
346
+ * overflowAriaLabel label for open close button overflow used for breadcrumb items that do not fit.
343
347
  */
344
- overflowAriaLabel: PropTypes.string.isRequired
348
+ overflowAriaLabel: PropTypes.string.isRequired.if(function (_ref6) {
349
+ var breadcrumbs = _ref6.breadcrumbs;
350
+ return breadcrumbs.length > 1;
351
+ })
345
352
  };
346
353
  BreadcrumbWithOverflow.defaultProps = {
347
354
  noTrailingSlash: false
@@ -0,0 +1,245 @@
1
+ import _extends from "@babel/runtime/helpers/extends";
2
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
5
+ var _excluded = ["className", "hideLabel", "inline", "invalid", "invalidText", "labelText", "onChange", "onInput", "onRevert", "revertDescription", "saveDescription", "saveDisabled", "size", "value", "warn", "warnText"];
6
+
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
+
9
+ 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) { _defineProperty(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; }
10
+
11
+ /**
12
+ * Copyright IBM Corp. 2021, 2021
13
+ *
14
+ * This source code is licensed under the Apache-2.0 license found in the
15
+ * LICENSE file in the root directory of this source tree.
16
+ */
17
+ // Import portions of React that are needed.
18
+ import React, { useEffect, useState } from 'react'; // Other standard imports.
19
+
20
+ import PropTypes from 'prop-types';
21
+ import cx from 'classnames';
22
+ import { Button, TextInput } from 'carbon-components-react';
23
+ import { prepareProps } from '../../global/js/utils/props-helper';
24
+ import { pkg, carbon } from '../../settings';
25
+ import { getDevtoolsProps } from '../../global/js/utils/devtools';
26
+ import { Checkmark16, Close16 } from '@carbon/icons-react'; // Carbon and package components we use.
27
+
28
+ /* TODO: @import(s) of carbon components and other package components. */
29
+ // The block part of our conventional BEM class names (blockClass__E--M).
30
+
31
+ var blockClass = "".concat(pkg.prefix, "--cancelable-text-edit");
32
+ var componentName = 'CancelableTextEdit'; // NOTE: the component SCSS is not imported here: it is rolled up separately.
33
+
34
+ /**
35
+ * TODO: A description of the component.
36
+ */
37
+
38
+ export var CancelableTextEdit = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
39
+ var _cx;
40
+
41
+ var className = _ref.className,
42
+ hideLabel = _ref.hideLabel,
43
+ inline = _ref.inline,
44
+ invalid = _ref.invalid,
45
+ invalidText = _ref.invalidText,
46
+ labelText = _ref.labelText,
47
+ onChange = _ref.onChange,
48
+ onInput = _ref.onInput,
49
+ onRevert = _ref.onRevert,
50
+ revertDescription = _ref.revertDescription,
51
+ saveDescription = _ref.saveDescription,
52
+ saveDisabled = _ref.saveDisabled,
53
+ size = _ref.size,
54
+ value = _ref.value,
55
+ warn = _ref.warn,
56
+ warnText = _ref.warnText,
57
+ rest = _objectWithoutProperties(_ref, _excluded);
58
+
59
+ // remove these props later
60
+ var removeProps = ['children', 'onInput', 'onChange', 'value'];
61
+ var showWarn = inline && warn && !invalid;
62
+ var showInvalid = inline && invalid;
63
+
64
+ var _useState = useState(value !== null && value !== void 0 ? value : ''),
65
+ _useState2 = _slicedToArray(_useState, 2),
66
+ liveValue = _useState2[0],
67
+ setLiveValue = _useState2[1];
68
+
69
+ useEffect(function () {
70
+ if (value !== liveValue) {
71
+ setLiveValue(value);
72
+ } // Do not care if liveValue changes here
73
+ // eslint-disable-next-line react-hooks/exhaustive-deps
74
+
75
+ }, [value]);
76
+
77
+ var doInput = function doInput(newValue) {
78
+ setLiveValue(newValue);
79
+
80
+ if (onInput) {
81
+ onInput(newValue);
82
+ }
83
+ };
84
+
85
+ var handleInput = function handleInput(ev) {
86
+ doInput(ev.target.value);
87
+ };
88
+
89
+ var handleRevert = function handleRevert() {
90
+ doInput(value);
91
+
92
+ if (onRevert) {
93
+ onRevert(value);
94
+ }
95
+ };
96
+
97
+ var handleSave = function handleSave() {
98
+ if (onChange && !invalid) {
99
+ onChange(liveValue);
100
+ }
101
+ };
102
+
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")
107
+ }, /*#__PURE__*/React.createElement(TextInput, _extends({}, prepareProps(rest, removeProps), {
108
+ // it is not permitted to pass children down to TextInput guard against this
109
+ className: "".concat(blockClass, "__input"),
110
+ ref: ref,
111
+ onInput: handleInput,
112
+ size: size,
113
+ value: liveValue !== null && liveValue !== void 0 ? liveValue : '' // ?? '' prevents controlled components test failure https://reactjs.org/docs/forms.html#controlled-components
114
+ ,
115
+ hideLabel: hideLabel,
116
+ inline: inline,
117
+ invalid: invalid,
118
+ invalidText: invalidText,
119
+ labelText: labelText,
120
+ warn: warn,
121
+ warnText: warnText
122
+ })), /*#__PURE__*/React.createElement("div", {
123
+ className: "".concat(blockClass, "__buttons")
124
+ }, !inline && !hideLabel && labelText && /*#__PURE__*/React.createElement("div", {
125
+ className: "".concat(blockClass, "__label-spacer ").concat(carbon.prefix, "--label")
126
+ }, "\xA0"), /*#__PURE__*/React.createElement("div", {
127
+ className: "".concat(blockClass, "__buttons-inner")
128
+ }, /*#__PURE__*/React.createElement(Button, {
129
+ className: "".concat(blockClass, "__revert"),
130
+ kind: "ghost",
131
+ hasIconOnly: true,
132
+ iconDescription: revertDescription,
133
+ onClick: handleRevert,
134
+ renderIcon: Close16
135
+ }), /*#__PURE__*/React.createElement(Button, {
136
+ className: "".concat(blockClass, "__save"),
137
+ kind: "ghost",
138
+ hasIconOnly: true,
139
+ iconDescription: saveDescription,
140
+ onClick: handleSave,
141
+ renderIcon: Checkmark16,
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")
147
+ }, showInvalid ? invalidText : warnText));
148
+ }); // Return a placeholder if not released and not enabled by feature flag
149
+
150
+ CancelableTextEdit = pkg.checkComponentEnabled(CancelableTextEdit, componentName); // The display name of the component, used by React. Note that displayName
151
+ // is used in preference to relying on function.name.
152
+
153
+ CancelableTextEdit.displayName = componentName; // The types and DocGen commentary for the component props,
154
+ // in alphabetical order (for consistency).
155
+ // See https://www.npmjs.com/package/prop-types#usage.
156
+
157
+ CancelableTextEdit.propTypes = _objectSpread(_objectSpread({}, prepareProps(TextInput.propTypes, ['inline', 'invalid', 'invalidText', 'labelText', 'onChange', 'onInput', 'value', 'warn', 'warnText'])), {}, {
158
+ /**
159
+ * Provide an optional class to be applied to the containing node.
160
+ */
161
+ className: PropTypes.string,
162
+
163
+ /**
164
+ * hide the label
165
+ */
166
+ hideLabel: PropTypes.bool,
167
+
168
+ /**
169
+ * inline variant
170
+ */
171
+ inline: PropTypes.bool,
172
+
173
+ /**
174
+ * set invalid state for input
175
+ */
176
+ invalid: PropTypes.bool,
177
+
178
+ /**
179
+ * text shown when invalid is true
180
+ */
181
+ invalidText: PropTypes.string,
182
+
183
+ /**
184
+ * label for text input
185
+ */
186
+ labelText: PropTypes.string,
187
+
188
+ /**
189
+ * method called on change event
190
+ */
191
+ onChange: PropTypes.func,
192
+
193
+ /**
194
+ * method called on input event
195
+ */
196
+ onInput: PropTypes.func,
197
+
198
+ /**
199
+ * method called on revert event
200
+ */
201
+ onRevert: PropTypes.func,
202
+
203
+ /**
204
+ * label for revert button
205
+ */
206
+ revertDescription: PropTypes.string.isRequired,
207
+
208
+ /**
209
+ * label for save button
210
+ */
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']),
222
+
223
+ /**
224
+ * initial/unedited value
225
+ */
226
+ value: PropTypes.string,
227
+
228
+ /**
229
+ * set warn state for input
230
+ */
231
+ warn: PropTypes.bool,
232
+
233
+ /**
234
+ * text shown when warn true
235
+ */
236
+ warnText: PropTypes.string
237
+ }); // Default values for component props. Default values are not required for
238
+ // props that are required, nor for props where the component can apply
239
+ // 'undefined' values reasonably. Default values should be provided when the
240
+ // component needs to make a choice or assumption when a prop is not supplied.
241
+
242
+ CancelableTextEdit.defaultProps = {
243
+ /* TODO: add defaults for relevant props. */
244
+ size: 'md'
245
+ };
@@ -4,5 +4,4 @@
4
4
  * This source code is licensed under the Apache-2.0 license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
- export var CREATE_TEARSHEET_STEP = 'CreateTearsheetStep';
8
- export var CREATE_TEARSHEET_SECTION = 'CreateTearsheetSection';
7
+ export { CancelableTextEdit } from './CancelableTextEdit';
@@ -2,7 +2,8 @@ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
2
  import _extends from "@babel/runtime/helpers/extends";
3
3
  import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
4
  var _excluded = ["actionIcons", "actionsPlacement", "children", "className", "clickZone", "description", "label", "media", "mediaPosition", "onClick", "onKeyDown", "onPrimaryButtonClick", "overflowActions", "onSecondaryButtonClick", "pictogram", "primaryButtonHref", "primaryButtonIcon", "primaryButtonKind", "primaryButtonText", "productive", "secondaryButtonHref", "secondaryButtonIcon", "secondaryButtonKind", "secondaryButtonText", "title", "titleSize"],
5
- _excluded2 = ["id"];
5
+ _excluded2 = ["id"],
6
+ _excluded3 = ["id", "icon", "onClick", "iconDescription", "onKeyDown", "href"];
6
7
 
7
8
  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
9
 
@@ -88,10 +89,11 @@ export var Card = /*#__PURE__*/forwardRef(function (_ref, ref) {
88
89
  onClick = _ref3.onClick,
89
90
  iconDescription = _ref3.iconDescription,
90
91
  onKeyDown = _ref3.onKeyDown,
91
- href = _ref3.href;
92
+ href = _ref3.href,
93
+ rest = _objectWithoutProperties(_ref3, _excluded3);
92
94
 
93
95
  if (productive) {
94
- return /*#__PURE__*/React.createElement(Button, {
96
+ return /*#__PURE__*/React.createElement(Button, _extends({}, rest, {
95
97
  key: id,
96
98
  renderIcon: Icon,
97
99
  hasIconOnly: true,
@@ -100,7 +102,7 @@ export var Card = /*#__PURE__*/forwardRef(function (_ref, ref) {
100
102
  iconDescription: iconDescription,
101
103
  kind: "ghost",
102
104
  href: href
103
- });
105
+ }));
104
106
  }
105
107
 
106
108
  if (href) {