carbon-react 116.1.2 → 116.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/esm/__internal__/utils/helpers/events/events.d.ts +1 -1
  2. package/esm/components/date/date.component.js +9 -1
  3. package/esm/components/date/date.style.js +5 -2
  4. package/esm/components/detail/detail.component.d.ts +19 -0
  5. package/esm/components/detail/detail.component.js +176 -42
  6. package/esm/components/detail/detail.style.d.ts +10 -0
  7. package/esm/components/detail/index.d.ts +2 -1
  8. package/esm/components/drawer/drawer.component.d.ts +1 -1
  9. package/esm/components/icon/icon.component.js +1 -1
  10. package/esm/components/menu/index.d.ts +1 -0
  11. package/esm/components/tabs/__internal__/tab-title/index.d.ts +2 -1
  12. package/esm/components/tabs/__internal__/tab-title/index.js +1 -1
  13. package/esm/components/tabs/__internal__/tab-title/tab-title.component.d.ts +37 -3
  14. package/esm/components/tabs/__internal__/tab-title/tab-title.component.js +99 -97
  15. package/esm/components/tabs/__internal__/tab-title/tab-title.style.d.ts +18 -4
  16. package/esm/components/tabs/__internal__/tab-title/tab-title.style.js +14 -50
  17. package/esm/components/tabs/__internal__/tabs-header/index.d.ts +2 -1
  18. package/esm/components/tabs/__internal__/tabs-header/tabs-header.component.d.ts +13 -0
  19. package/esm/components/tabs/__internal__/tabs-header/tabs-header.component.js +8 -8
  20. package/esm/components/tabs/__internal__/tabs-header/tabs-header.style.d.ts +6 -6
  21. package/esm/components/tabs/__internal__/tabs-header/tabs-header.style.js +8 -27
  22. package/esm/components/tabs/index.d.ts +3 -2
  23. package/esm/components/tabs/tab/index.d.ts +2 -2
  24. package/esm/components/tabs/tab/tab.component.d.ts +53 -0
  25. package/esm/components/tabs/tab/tab.component.js +180 -61
  26. package/esm/components/tabs/tab/tab.style.d.ts +8 -1
  27. package/esm/components/tabs/tab/tab.style.js +1 -6
  28. package/esm/components/tabs/tabs.component.d.ts +49 -0
  29. package/esm/components/tabs/tabs.component.js +188 -70
  30. package/esm/components/tabs/tabs.style.d.ts +5 -1
  31. package/esm/components/tabs/tabs.style.js +2 -8
  32. package/esm/components/textbox/textbox.component.d.ts +1 -1
  33. package/lib/__internal__/utils/helpers/events/events.d.ts +1 -1
  34. package/lib/components/date/date.component.js +9 -1
  35. package/lib/components/date/date.style.js +5 -2
  36. package/lib/components/detail/detail.component.d.ts +19 -0
  37. package/lib/components/detail/detail.component.js +178 -47
  38. package/lib/components/detail/detail.style.d.ts +10 -0
  39. package/lib/components/detail/index.d.ts +2 -1
  40. package/lib/components/drawer/drawer.component.d.ts +1 -1
  41. package/lib/components/icon/icon.component.js +1 -1
  42. package/lib/components/menu/index.d.ts +1 -0
  43. package/lib/components/tabs/__internal__/tab-title/index.d.ts +2 -1
  44. package/lib/components/tabs/__internal__/tab-title/index.js +10 -2
  45. package/lib/components/tabs/__internal__/tab-title/tab-title.component.d.ts +37 -3
  46. package/lib/components/tabs/__internal__/tab-title/tab-title.component.js +99 -97
  47. package/lib/components/tabs/__internal__/tab-title/tab-title.style.d.ts +18 -4
  48. package/lib/components/tabs/__internal__/tab-title/tab-title.style.js +17 -53
  49. package/lib/components/tabs/__internal__/tabs-header/index.d.ts +2 -1
  50. package/lib/components/tabs/__internal__/tabs-header/tabs-header.component.d.ts +13 -0
  51. package/lib/components/tabs/__internal__/tabs-header/tabs-header.component.js +8 -8
  52. package/lib/components/tabs/__internal__/tabs-header/tabs-header.style.d.ts +6 -6
  53. package/lib/components/tabs/__internal__/tabs-header/tabs-header.style.js +9 -31
  54. package/lib/components/tabs/index.d.ts +3 -2
  55. package/lib/components/tabs/tab/index.d.ts +2 -2
  56. package/lib/components/tabs/tab/tab.component.d.ts +53 -0
  57. package/lib/components/tabs/tab/tab.component.js +181 -64
  58. package/lib/components/tabs/tab/tab.style.d.ts +8 -1
  59. package/lib/components/tabs/tab/tab.style.js +1 -7
  60. package/lib/components/tabs/tabs.component.d.ts +49 -0
  61. package/lib/components/tabs/tabs.component.js +188 -73
  62. package/lib/components/tabs/tabs.style.d.ts +5 -1
  63. package/lib/components/tabs/tabs.style.js +2 -9
  64. package/lib/components/textbox/textbox.component.d.ts +1 -1
  65. package/package.json +1 -1
  66. package/esm/components/detail/detail.d.ts +0 -16
  67. package/esm/components/tabs/__internal__/tab-title/tab-title.d.ts +0 -47
  68. package/esm/components/tabs/__internal__/tabs-header/tab-header.d.ts +0 -16
  69. package/esm/components/tabs/tab/tab.d.ts +0 -54
  70. package/esm/components/tabs/tabs.d.ts +0 -51
  71. package/lib/components/detail/detail.d.ts +0 -16
  72. package/lib/components/tabs/__internal__/tab-title/tab-title.d.ts +0 -47
  73. package/lib/components/tabs/__internal__/tabs-header/tab-header.d.ts +0 -16
  74. package/lib/components/tabs/tab/tab.d.ts +0 -54
  75. package/lib/components/tabs/tabs.d.ts +0 -51
@@ -7,8 +7,6 @@ exports.default = void 0;
7
7
 
8
8
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
9
9
 
10
- var _propTypes = _interopRequireDefault(require("prop-types"));
11
-
12
10
  var _styledSystem = require("styled-system");
13
11
 
14
12
  var _base = _interopRequireDefault(require("../../../style/themes/base"));
@@ -24,7 +22,7 @@ const StyledTab = _styledComponents.default.div`
24
22
 
25
23
  ${({
26
24
  isTabSelected,
27
- position
25
+ position = "top"
28
26
  }) => isTabSelected && (0, _styledComponents.css)`
29
27
  display: block;
30
28
 
@@ -36,11 +34,7 @@ const StyledTab = _styledComponents.default.div`
36
34
  `}
37
35
  `;
38
36
  StyledTab.defaultProps = {
39
- position: "top",
40
37
  theme: _base.default
41
38
  };
42
- StyledTab.propTypes = {
43
- position: _propTypes.default.oneOf(["top", "left"])
44
- };
45
39
  var _default = StyledTab;
46
40
  exports.default = _default;
@@ -0,0 +1,49 @@
1
+ import React from "react";
2
+ import { MarginProps } from "styled-system";
3
+ import Tab from "./tab";
4
+ export interface TabsProps extends MarginProps {
5
+ /** @ignore @private */
6
+ className?: string;
7
+ /** Prevent rendering of hidden tabs, by default this is set to true and therefore all tabs will be rendered */
8
+ renderHiddenTabs?: boolean;
9
+ /** Allows manual control over the currently selected tab. */
10
+ selectedTabId?: string;
11
+ /** The child elements of Tabs need to be Tab components. */
12
+ children: React.ReactNode;
13
+ /** Sets the alignment of the tab titles. Possible values include. */
14
+ align?: "left" | "right";
15
+ /** A callback for when a tab is changed. You can use this to manually control
16
+ * tab changing or to fire other events when a tab is changed.
17
+ */
18
+ onTabChange?: (tabId: string) => void;
19
+ /** The position of the tab title. */
20
+ position?: "top" | "left";
21
+ /** Sets size of the tab titles. */
22
+ size?: "default" | "large";
23
+ /** Sets the divider of the tab titles header to extend the full width of the parent. */
24
+ extendedLine?: boolean;
25
+ /** Adds a combination of borders to the tab titles. */
26
+ borders?: "off" | "on" | "no left side" | "no right side" | "no sides";
27
+ /** Adds an alternate styling variant to the tab titles. */
28
+ variant?: "default" | "alternate";
29
+ /** sets width to the tab headers. Can be any valid CSS string.
30
+ * The headerWidth prop works only for `position="left"`
31
+ */
32
+ headerWidth?: string;
33
+ /** An object to support overriding validation statuses, when the Tabs have custom targets for example.
34
+ * The `id` property should match the `tabId`s for the rendered Tabs.
35
+ */
36
+ validationStatusOverride?: {
37
+ [id: string]: {
38
+ error?: boolean;
39
+ warning?: boolean;
40
+ info?: boolean;
41
+ };
42
+ };
43
+ /** When this prop is set any string validation failures in the children of each Tab
44
+ * will be summaraised in the Tooltip next to the Tab title
45
+ */
46
+ showValidationsSummary?: boolean;
47
+ }
48
+ declare const Tabs: ({ align, className, children, onTabChange, selectedTabId, renderHiddenTabs, position, extendedLine, size, borders, variant, validationStatusOverride, headerWidth, showValidationsSummary, ...rest }: TabsProps) => JSX.Element;
49
+ export { Tabs, Tab };
@@ -15,8 +15,6 @@ var _react = _interopRequireWildcard(require("react"));
15
15
 
16
16
  var _propTypes = _interopRequireDefault(require("prop-types"));
17
17
 
18
- var _propTypes2 = _interopRequireDefault(require("@styled-system/prop-types"));
19
-
20
18
  var _tab = _interopRequireDefault(require("./tab"));
21
19
 
22
20
  var _events = _interopRequireDefault(require("../../__internal__/utils/helpers/events"));
@@ -31,8 +29,6 @@ var _tabTitle = _interopRequireDefault(require("./__internal__/tab-title"));
31
29
 
32
30
  var _drawer = require("../drawer");
33
31
 
34
- var _utils = require("../../style/utils");
35
-
36
32
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
37
33
 
38
34
  function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
@@ -41,8 +37,6 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
41
37
 
42
38
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
43
39
 
44
- const marginPropTypes = (0, _utils.filterStyledSystemMarginProps)(_propTypes2.default.space);
45
-
46
40
  const Tabs = ({
47
41
  align = "left",
48
42
  className,
@@ -60,7 +54,13 @@ const Tabs = ({
60
54
  showValidationsSummary,
61
55
  ...rest
62
56
  }) => {
57
+ if (position !== "left" && headerWidth !== undefined) {
58
+ // eslint-disable-next-line no-console
59
+ console.error("Invalid usage of prop headerWidth in Tabs. The headerWidth can be used only if position is set to left");
60
+ }
63
61
  /** The children nodes converted into an Array */
62
+
63
+
64
64
  const filteredChildren = (0, _react.useMemo)(() => _react.Children.toArray(children).filter(child => child), [children]);
65
65
  /** Array of the tabIds for the child nodes */
66
66
 
@@ -114,7 +114,12 @@ const Tabs = ({
114
114
  }
115
115
  }, [onTabChange, isTabSelected, hasTabStop]);
116
116
  const blurPreviousSelectedTab = (0, _react.useCallback)(() => {
117
- const previousTabIndex = tabIds.indexOf(previousSelectedTabId.current);
117
+ const {
118
+ current
119
+ } = previousSelectedTabId;
120
+ const previousTabIndex = current ? tabIds.indexOf(current) :
121
+ /* istanbul ignore next */
122
+ -1;
118
123
  /* istanbul ignore else */
119
124
 
120
125
  if (previousTabIndex !== -1) {
@@ -149,7 +154,11 @@ const Tabs = ({
149
154
  /** Focuses the tab for the reference specified */
150
155
 
151
156
 
152
- const focusTab = ref => ref.current.focus();
157
+ const focusTab = ref => {
158
+ var _ref$current;
159
+
160
+ return (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus();
161
+ };
153
162
  /** Will trigger the tab at the given index. */
154
163
 
155
164
 
@@ -245,7 +254,7 @@ const Tabs = ({
245
254
  onClick: handleTabClick,
246
255
  onKeyDown: handleKeyDown(index),
247
256
  ref: tabRefs[index],
248
- tabIndex: isTabSelected(tabId) || hasTabStop(tabId) ? "0" : "-1",
257
+ tabIndex: isTabSelected(tabId) || hasTabStop(tabId) ? 0 : -1,
249
258
  title: title,
250
259
  href: href,
251
260
  isTabSelected: isTabSelected(tabId),
@@ -313,9 +322,7 @@ const Tabs = ({
313
322
 
314
323
  return /*#__PURE__*/_react.default.createElement(_tabs.default, _extends({
315
324
  className: className,
316
- position: isInSidebar ? "left" : position,
317
- updateErrors: updateErrors,
318
- updateWarnings: updateWarnings
325
+ position: isInSidebar ? "left" : position
319
326
  }, (0, _tags.default)("tabs", rest), {
320
327
  isInSidebar: isInSidebar,
321
328
  headerWidth: headerWidth
@@ -323,65 +330,173 @@ const Tabs = ({
323
330
  };
324
331
 
325
332
  exports.Tabs = Tabs;
326
- Tabs.propTypes = { ...marginPropTypes,
327
-
328
- /** @ignore @private */
329
- className: _propTypes.default.string,
330
-
331
- /** Prevent rendering of hidden tabs, by default this is set to true and therefore all tabs will be rendered */
332
- renderHiddenTabs: _propTypes.default.bool,
333
-
334
- /** Allows manual control over the currently selected tab. */
335
- selectedTabId: _propTypes.default.string,
336
-
337
- /** The child elements of Tabs need to be Tab components. */
338
- children: _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.node), _propTypes.default.node]).isRequired,
339
-
340
- /** Sets the alignment of the tab titles. Possible values include. */
341
- align: _propTypes.default.oneOf(["left", "right"]),
342
-
343
- /** A callback for when a tab is changed. You can use this to manually control
344
- * tab changing or to fire other events when a tab is changed. */
345
- onTabChange: _propTypes.default.func,
346
-
347
- /** The position of the tab title. */
348
- position: _propTypes.default.oneOf(["top", "left"]),
349
-
350
- /** Sets size of the tab titles. */
351
- size: _propTypes.default.oneOf(["default", "large"]),
352
-
353
- /** Sets the divider of the tab titles header to extend the full width of the parent. */
354
- extendedLine: _propTypes.default.bool,
355
-
356
- /** Adds a combination of borders to the tab titles. */
357
- borders: _propTypes.default.oneOf(["off", "on", "no left side", "no right side", "no sides"]),
358
-
359
- /** sets width to the tab headers. Can be any valid CSS string.
360
- * The headerWidth prop works only for `position="left"`
361
- */
362
- headerWidth: (props, propName, componentName) => {
363
- if (props.position !== "left" && props[propName] !== undefined) {
364
- return new Error(`Invalid usage of prop ${propName} in ${componentName}. The ${propName} can be used only if position is set to left`);
365
- }
366
-
367
- return null;
368
- },
369
-
370
- /** Adds an alternate styling variant to the tab titles. */
371
- variant: _propTypes.default.oneOf(["default", "alternate"]),
372
-
373
- /** An object to support overriding validation statuses, when the Tabs have custom targets for example.
374
- * The `id` property should match the `tabId`s for the rendered Tabs. */
375
- validationStatusOverride: _propTypes.default.shape({
376
- id: _propTypes.default.shape({
377
- error: _propTypes.default.bool,
378
- warning: _propTypes.default.bool,
379
- info: _propTypes.default.bool
380
- })
381
- }),
382
-
383
- /** When this prop is set any string validation failures in the children of each Tab
384
- * will be summaraised in the Tooltip next to the Tab title
385
- */
386
- showValidationsSummary: _propTypes.default.bool
333
+ Tabs.propTypes = {
334
+ "align": _propTypes.default.oneOf(["left", "right"]),
335
+ "borders": _propTypes.default.oneOf(["no left side", "no right side", "no sides", "off", "on"]),
336
+ "children": _propTypes.default.node,
337
+ "className": _propTypes.default.string,
338
+ "extendedLine": _propTypes.default.bool,
339
+ "headerWidth": _propTypes.default.string,
340
+ "m": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
341
+ "__@toStringTag": _propTypes.default.string.isRequired,
342
+ "description": _propTypes.default.string,
343
+ "toString": _propTypes.default.func.isRequired,
344
+ "valueOf": _propTypes.default.func.isRequired
345
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
346
+ "__@toStringTag": _propTypes.default.string.isRequired,
347
+ "description": _propTypes.default.string,
348
+ "toString": _propTypes.default.func.isRequired,
349
+ "valueOf": _propTypes.default.func.isRequired
350
+ }), _propTypes.default.string]),
351
+ "margin": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
352
+ "__@toStringTag": _propTypes.default.string.isRequired,
353
+ "description": _propTypes.default.string,
354
+ "toString": _propTypes.default.func.isRequired,
355
+ "valueOf": _propTypes.default.func.isRequired
356
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
357
+ "__@toStringTag": _propTypes.default.string.isRequired,
358
+ "description": _propTypes.default.string,
359
+ "toString": _propTypes.default.func.isRequired,
360
+ "valueOf": _propTypes.default.func.isRequired
361
+ }), _propTypes.default.string]),
362
+ "marginBottom": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
363
+ "__@toStringTag": _propTypes.default.string.isRequired,
364
+ "description": _propTypes.default.string,
365
+ "toString": _propTypes.default.func.isRequired,
366
+ "valueOf": _propTypes.default.func.isRequired
367
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
368
+ "__@toStringTag": _propTypes.default.string.isRequired,
369
+ "description": _propTypes.default.string,
370
+ "toString": _propTypes.default.func.isRequired,
371
+ "valueOf": _propTypes.default.func.isRequired
372
+ }), _propTypes.default.string]),
373
+ "marginLeft": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
374
+ "__@toStringTag": _propTypes.default.string.isRequired,
375
+ "description": _propTypes.default.string,
376
+ "toString": _propTypes.default.func.isRequired,
377
+ "valueOf": _propTypes.default.func.isRequired
378
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
379
+ "__@toStringTag": _propTypes.default.string.isRequired,
380
+ "description": _propTypes.default.string,
381
+ "toString": _propTypes.default.func.isRequired,
382
+ "valueOf": _propTypes.default.func.isRequired
383
+ }), _propTypes.default.string]),
384
+ "marginRight": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
385
+ "__@toStringTag": _propTypes.default.string.isRequired,
386
+ "description": _propTypes.default.string,
387
+ "toString": _propTypes.default.func.isRequired,
388
+ "valueOf": _propTypes.default.func.isRequired
389
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
390
+ "__@toStringTag": _propTypes.default.string.isRequired,
391
+ "description": _propTypes.default.string,
392
+ "toString": _propTypes.default.func.isRequired,
393
+ "valueOf": _propTypes.default.func.isRequired
394
+ }), _propTypes.default.string]),
395
+ "marginTop": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
396
+ "__@toStringTag": _propTypes.default.string.isRequired,
397
+ "description": _propTypes.default.string,
398
+ "toString": _propTypes.default.func.isRequired,
399
+ "valueOf": _propTypes.default.func.isRequired
400
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
401
+ "__@toStringTag": _propTypes.default.string.isRequired,
402
+ "description": _propTypes.default.string,
403
+ "toString": _propTypes.default.func.isRequired,
404
+ "valueOf": _propTypes.default.func.isRequired
405
+ }), _propTypes.default.string]),
406
+ "marginX": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
407
+ "__@toStringTag": _propTypes.default.string.isRequired,
408
+ "description": _propTypes.default.string,
409
+ "toString": _propTypes.default.func.isRequired,
410
+ "valueOf": _propTypes.default.func.isRequired
411
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
412
+ "__@toStringTag": _propTypes.default.string.isRequired,
413
+ "description": _propTypes.default.string,
414
+ "toString": _propTypes.default.func.isRequired,
415
+ "valueOf": _propTypes.default.func.isRequired
416
+ }), _propTypes.default.string]),
417
+ "marginY": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
418
+ "__@toStringTag": _propTypes.default.string.isRequired,
419
+ "description": _propTypes.default.string,
420
+ "toString": _propTypes.default.func.isRequired,
421
+ "valueOf": _propTypes.default.func.isRequired
422
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
423
+ "__@toStringTag": _propTypes.default.string.isRequired,
424
+ "description": _propTypes.default.string,
425
+ "toString": _propTypes.default.func.isRequired,
426
+ "valueOf": _propTypes.default.func.isRequired
427
+ }), _propTypes.default.string]),
428
+ "mb": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
429
+ "__@toStringTag": _propTypes.default.string.isRequired,
430
+ "description": _propTypes.default.string,
431
+ "toString": _propTypes.default.func.isRequired,
432
+ "valueOf": _propTypes.default.func.isRequired
433
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
434
+ "__@toStringTag": _propTypes.default.string.isRequired,
435
+ "description": _propTypes.default.string,
436
+ "toString": _propTypes.default.func.isRequired,
437
+ "valueOf": _propTypes.default.func.isRequired
438
+ }), _propTypes.default.string]),
439
+ "ml": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
440
+ "__@toStringTag": _propTypes.default.string.isRequired,
441
+ "description": _propTypes.default.string,
442
+ "toString": _propTypes.default.func.isRequired,
443
+ "valueOf": _propTypes.default.func.isRequired
444
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
445
+ "__@toStringTag": _propTypes.default.string.isRequired,
446
+ "description": _propTypes.default.string,
447
+ "toString": _propTypes.default.func.isRequired,
448
+ "valueOf": _propTypes.default.func.isRequired
449
+ }), _propTypes.default.string]),
450
+ "mr": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
451
+ "__@toStringTag": _propTypes.default.string.isRequired,
452
+ "description": _propTypes.default.string,
453
+ "toString": _propTypes.default.func.isRequired,
454
+ "valueOf": _propTypes.default.func.isRequired
455
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
456
+ "__@toStringTag": _propTypes.default.string.isRequired,
457
+ "description": _propTypes.default.string,
458
+ "toString": _propTypes.default.func.isRequired,
459
+ "valueOf": _propTypes.default.func.isRequired
460
+ }), _propTypes.default.string]),
461
+ "mt": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
462
+ "__@toStringTag": _propTypes.default.string.isRequired,
463
+ "description": _propTypes.default.string,
464
+ "toString": _propTypes.default.func.isRequired,
465
+ "valueOf": _propTypes.default.func.isRequired
466
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
467
+ "__@toStringTag": _propTypes.default.string.isRequired,
468
+ "description": _propTypes.default.string,
469
+ "toString": _propTypes.default.func.isRequired,
470
+ "valueOf": _propTypes.default.func.isRequired
471
+ }), _propTypes.default.string]),
472
+ "mx": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
473
+ "__@toStringTag": _propTypes.default.string.isRequired,
474
+ "description": _propTypes.default.string,
475
+ "toString": _propTypes.default.func.isRequired,
476
+ "valueOf": _propTypes.default.func.isRequired
477
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
478
+ "__@toStringTag": _propTypes.default.string.isRequired,
479
+ "description": _propTypes.default.string,
480
+ "toString": _propTypes.default.func.isRequired,
481
+ "valueOf": _propTypes.default.func.isRequired
482
+ }), _propTypes.default.string]),
483
+ "my": _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.oneOf([null]), _propTypes.default.number, _propTypes.default.shape({
484
+ "__@toStringTag": _propTypes.default.string.isRequired,
485
+ "description": _propTypes.default.string,
486
+ "toString": _propTypes.default.func.isRequired,
487
+ "valueOf": _propTypes.default.func.isRequired
488
+ }), _propTypes.default.string])), _propTypes.default.number, _propTypes.default.object, _propTypes.default.shape({
489
+ "__@toStringTag": _propTypes.default.string.isRequired,
490
+ "description": _propTypes.default.string,
491
+ "toString": _propTypes.default.func.isRequired,
492
+ "valueOf": _propTypes.default.func.isRequired
493
+ }), _propTypes.default.string]),
494
+ "onTabChange": _propTypes.default.func,
495
+ "position": _propTypes.default.oneOf(["left", "top"]),
496
+ "renderHiddenTabs": _propTypes.default.bool,
497
+ "selectedTabId": _propTypes.default.string,
498
+ "showValidationsSummary": _propTypes.default.bool,
499
+ "size": _propTypes.default.oneOf(["default", "large"]),
500
+ "validationStatusOverride": _propTypes.default.object,
501
+ "variant": _propTypes.default.oneOf(["alternate", "default"])
387
502
  };
@@ -1,2 +1,6 @@
1
+ import { TabsProps } from ".";
2
+ export interface StyledTabsProps extends Pick<TabsProps, "headerWidth" | "position"> {
3
+ isInSidebar?: boolean;
4
+ }
5
+ declare const StyledTabs: import("styled-components").StyledComponent<"div", any, StyledTabsProps, never>;
1
6
  export default StyledTabs;
2
- declare const StyledTabs: import("styled-components").StyledComponent<"div", any, {}, never>;
@@ -9,8 +9,6 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
9
9
 
10
10
  var _styledSystem = require("styled-system");
11
11
 
12
- var _propTypes = _interopRequireDefault(require("prop-types"));
13
-
14
12
  var _base = _interopRequireDefault(require("../../style/themes/base"));
15
13
 
16
14
  var _tabsHeader = require("./__internal__/tabs-header/tabs-header.style");
@@ -26,7 +24,7 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
26
24
  const StyledTabs = _styledComponents.default.div`
27
25
  ${({
28
26
  position,
29
- inSidebar,
27
+ isInSidebar,
30
28
  headerWidth
31
29
  }) => (0, _styledComponents.css)`
32
30
  color: var(--colorsActionMinorYin090);
@@ -42,7 +40,7 @@ const StyledTabs = _styledComponents.default.div`
42
40
  }
43
41
  `}
44
42
 
45
- ${!inSidebar && (0, _styledComponents.css)`
43
+ ${!isInSidebar && (0, _styledComponents.css)`
46
44
  display: flex;
47
45
  `}
48
46
 
@@ -53,12 +51,7 @@ const StyledTabs = _styledComponents.default.div`
53
51
  ${_styledSystem.margin}
54
52
  `;
55
53
  StyledTabs.defaultProps = {
56
- position: "top",
57
54
  theme: _base.default
58
55
  };
59
- StyledTabs.propTypes = {
60
- position: _propTypes.default.oneOf(["top", "left"]),
61
- hasCustomTarget: _propTypes.default.bool
62
- };
63
56
  var _default = StyledTabs;
64
57
  exports.default = _default;
@@ -25,7 +25,7 @@ export interface CommonTextboxProps extends ValidationProps, MarginProps, Omit<C
25
25
  formattedValue?: string;
26
26
  /**
27
27
  * Unique identifier for the input.
28
- * Label id will be based on it, using following pattern: <id>-label.
28
+ * Label id will be based on it, using following pattern: [id]-label.
29
29
  * Will use a randomly generated GUID if none is provided.
30
30
  */
31
31
  id?: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "carbon-react",
3
- "version": "116.1.2",
3
+ "version": "116.1.3",
4
4
  "description": "A library of reusable React components for easily building user interfaces.",
5
5
  "files": [
6
6
  "lib",
@@ -1,16 +0,0 @@
1
- import * as React from "react";
2
-
3
- export interface DetailProps {
4
- /** Custom className */
5
- className?: string;
6
- /** The type of icon to use. */
7
- icon?: string;
8
- /** A small detail to display under the main content. */
9
- footnote?: string;
10
- /** The rendered children of the component. */
11
- children?: React.ReactNode;
12
- }
13
-
14
- declare class Detail extends React.Component<DetailProps> {}
15
-
16
- export default Detail;
@@ -1,47 +0,0 @@
1
- import * as React from "react";
2
-
3
- export interface TabTitleContextProps {
4
- isInTab?: boolean;
5
- }
6
-
7
- export interface TabTitleProps {
8
- /** Identifier used for testing purposes */
9
- "data-role"?: string;
10
- title: string;
11
- id?: string;
12
- dataTabId?: string;
13
- className?: string;
14
- children?: React.ReactNode;
15
- isTabSelected?: boolean;
16
- position?: "top" | "left";
17
- errorMessage?: string;
18
- warningMessage?: string;
19
- infoMessage?: string;
20
- errors?: boolean;
21
- warning?: boolean;
22
- info?: boolean;
23
- borders?: boolean;
24
- noLeftBorder?: boolean;
25
- noRightBorder?: boolean;
26
- alternateStyling?: boolean;
27
- isInSidebar?: boolean;
28
- siblings?: React.ReactNode[];
29
- titlePosition?: "before" | "after";
30
- href?: string;
31
- tabIndex?: string;
32
- size?: "default" | "large";
33
- align?: "left" | "right";
34
- customLayout?: React.ReactNode;
35
- onClick?: (
36
- ev: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>
37
- ) => void;
38
- onKeyDown?: (
39
- ev: React.KeyboardEvent<HTMLButtonElement | HTMLAnchorElement>
40
- ) => void;
41
- }
42
-
43
- declare const TabTitleContext: React.Context<TabTitleContextProps>;
44
- declare function TabTitle(props: TabTitleProps): JSX.Element;
45
-
46
- export { TabTitleContext };
47
- export default TabTitle;
@@ -1,16 +0,0 @@
1
- import * as React from "react";
2
-
3
- export interface TabHeaderProps {
4
- role?: string;
5
- position?: "top" | "left";
6
- extendedLine?: boolean;
7
- noRightBorder?: boolean;
8
- alternateStyling?: boolean;
9
- isInSidebar?: boolean;
10
- children: React.ReactNode;
11
- align?: "left" | "right";
12
- }
13
-
14
- declare function TabHeader(props: TabHeaderProps): JSX.Element;
15
-
16
- export default TabHeader;
@@ -1,54 +0,0 @@
1
- import * as React from "react";
2
- import { PaddingProps } from "styled-system";
3
-
4
- export interface TabContextProps {
5
- setError?: (childId: string, error?: boolean | string) => void;
6
- setWarning?: (childId: string, warning?: boolean | string) => void;
7
- setInfo?: (childId: string, info?: boolean | string) => void;
8
- }
9
-
10
- export interface TabProps extends PaddingProps {
11
- title?: string;
12
- /** A unique ID to identify this specific tab. */
13
- tabId: string;
14
- className?: string;
15
- /** The child elements of Tab component. */
16
- children?: React.ReactNode;
17
- /** @ignore @private Boolean indicating selected state of Tab. */
18
- isTabSelected?: boolean;
19
- /** The position of the Tab. */
20
- position?: "top" | "left";
21
- /** Message displayed when Tab has error */
22
- errorMessage?: string;
23
- /** Message displayed when Tab has warning */
24
- warningMessage?: string;
25
- /** Message displayed when Tab has warning */
26
- infoMessage?: string;
27
- /** Additional content to display with title */
28
- siblings?: React.ReactNode[];
29
- /** Position title before or after siblings */
30
- titlePosition?: "before" | "after";
31
- /** Allows Tab to be a link */
32
- href?: string;
33
- /** Overrides default layout with a one defined in this prop */
34
- customLayout?: React.ReactNode;
35
- /** Additional props to be passed to the Tab's corresponding title. */
36
- titleProps?: {
37
- /** Identifier used for testing purposes */
38
- "data-role"?: string;
39
- };
40
- }
41
-
42
- export interface TabAllProps {
43
- role?: string;
44
- ariaLabelledby?: string;
45
- updateErrors?: (id: string, hasError: boolean) => void;
46
- updateWarnings?: (id: string, hasWarning: boolean) => void;
47
- updateInfos?: (id: string, hasInfo: boolean) => void;
48
- }
49
-
50
- declare const TabContext: React.Context<TabContextProps>;
51
- declare function Tab(props: TabProps): JSX.Element;
52
-
53
- export { TabContext };
54
- export default Tab;
@@ -1,51 +0,0 @@
1
- import * as React from "react";
2
- import { MarginProps } from "styled-system";
3
- import Tab from "./tab";
4
-
5
- export interface TabsProps extends MarginProps {
6
- className?: string;
7
- /** Prevent rendering of hidden tabs, by default this is set to true and therefore all tabs will be rendered */
8
- renderHiddenTabs?: boolean;
9
- /** Allows manual control over the currently selected tab. */
10
- selectedTabId?: string;
11
- /** The child elements of Tabs need to be Tab components. */
12
- children: React.ReactNode[] | React.ReactNode;
13
- /** Sets the alignment of the tab titles. Possible values include. */
14
- align?: "left" | "right";
15
- /** A callback for when a tab is changed. You can use this to manually control
16
- * tab changing or to fire other events when a tab is changed.
17
- */
18
- onTabChange?: (tabId: string) => void;
19
- /** The position of the tab title. */
20
- position?: "top" | "left";
21
- /** Sets size of the tab titles. */
22
- size?: "default" | "large";
23
- /** Sets the divider of the tab titles header to extend the full width of the parent. */
24
- extendedLine?: boolean;
25
- /** Adds a combination of borders to the tab titles. */
26
- borders?: "off" | "on" | "no left side" | "no right side" | "no sides";
27
- /** Adds an alternate styling variant to the tab titles. */
28
- variant?: "default" | "alternate";
29
- /** sets width to the tab headers. Can be any valid CSS string.
30
- * The headerWidth prop works only for `position="left"`
31
- */
32
- headerWidth?: string;
33
- /** An object to support overriding validation statuses, when the Tabs have custom targets for example.
34
- * The `id` property should match the `tabId`s for the rendered Tabs.
35
- */
36
- validationStatusOverride?: {
37
- [id: string]: {
38
- error?: boolean;
39
- warning?: boolean;
40
- info?: boolean;
41
- };
42
- };
43
- /** When this prop is set any string validation failures in the children of each Tab
44
- * will be summaraised in the Tooltip next to the Tab title
45
- */
46
- showValidationsSummary?: boolean;
47
- }
48
-
49
- declare function Tabs(props: TabsProps): JSX.Element;
50
-
51
- export { Tabs, Tab };