carbon-react 126.3.1 → 126.4.1

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 (26) hide show
  1. package/esm/components/tile/index.d.ts +2 -0
  2. package/esm/components/tile/index.js +1 -0
  3. package/esm/components/tile/tile-footer/tile-footer.component.d.ts +1 -1
  4. package/esm/components/tile/tile-footer/tile-footer.style.js +6 -1
  5. package/esm/components/tile/tile-header/index.d.ts +2 -0
  6. package/esm/components/tile/tile-header/index.js +1 -0
  7. package/esm/components/tile/tile-header/tile-header.component.d.ts +10 -0
  8. package/esm/components/tile/tile-header/tile-header.component.js +14 -0
  9. package/esm/components/tile/tile-header/tile-header.style.d.ts +5 -0
  10. package/esm/components/tile/tile-header/tile-header.style.js +32 -0
  11. package/esm/components/tile/tile.component.d.ts +4 -4
  12. package/esm/components/tile/tile.style.js +27 -2
  13. package/lib/components/tile/index.d.ts +2 -0
  14. package/lib/components/tile/index.js +7 -0
  15. package/lib/components/tile/tile-footer/tile-footer.component.d.ts +1 -1
  16. package/lib/components/tile/tile-footer/tile-footer.style.js +6 -1
  17. package/lib/components/tile/tile-header/index.d.ts +2 -0
  18. package/lib/components/tile/tile-header/index.js +13 -0
  19. package/lib/components/tile/tile-header/package.json +6 -0
  20. package/lib/components/tile/tile-header/tile-header.component.d.ts +10 -0
  21. package/lib/components/tile/tile-header/tile-header.component.js +22 -0
  22. package/lib/components/tile/tile-header/tile-header.style.d.ts +5 -0
  23. package/lib/components/tile/tile-header/tile-header.style.js +40 -0
  24. package/lib/components/tile/tile.component.d.ts +4 -4
  25. package/lib/components/tile/tile.style.js +27 -2
  26. package/package.json +1 -1
@@ -4,6 +4,8 @@ export { default as TileContent } from "./tile-content";
4
4
  export type { TileContentProps } from "./tile-content";
5
5
  export { default as TileFooter } from "./tile-footer";
6
6
  export type { TileFooterProps } from "./tile-footer";
7
+ export { default as TileHeader } from "./tile-header";
8
+ export type { TileHeaderProps } from "./tile-header";
7
9
  export { default as FlexTileContainer } from "./flex-tile-container";
8
10
  export type { FlexTileContainerProps } from "./flex-tile-container";
9
11
  export { default as FlexTileCell } from "./flex-tile-cell";
@@ -1,6 +1,7 @@
1
1
  export { default as Tile } from "./tile.component";
2
2
  export { default as TileContent } from "./tile-content";
3
3
  export { default as TileFooter } from "./tile-footer";
4
+ export { default as TileHeader } from "./tile-header";
4
5
  export { default as FlexTileContainer } from "./flex-tile-container";
5
6
  export { default as FlexTileCell } from "./flex-tile-cell";
6
7
  export { default as FlexTileDivider } from "./flex-tile-divider";
@@ -4,7 +4,7 @@ import { TagProps } from "../../../__internal__/utils/helpers/tags";
4
4
  export interface TileFooterProps extends PaddingProps, TagProps {
5
5
  children?: React.ReactNode;
6
6
  /** set which background color variant should be used */
7
- variant?: "default" | "black" | "transparent";
7
+ variant?: "default" | "black" | "transparent" | "grey";
8
8
  }
9
9
  export declare const TileFooter: ({ variant, children, ...rest }: TileFooterProps) => React.JSX.Element;
10
10
  export default TileFooter;
@@ -7,18 +7,23 @@ const getBackgroundColor = variant => {
7
7
  return "transparent";
8
8
  case "black":
9
9
  return "var(--colorsUtilityYin100)";
10
+ case "grey":
11
+ return "var(--colorsUtilityMajor025)";
10
12
  default:
11
13
  return "var(--colorsUtilityMajor100)";
12
14
  }
13
15
  };
14
16
  const StyledTileFooter = styled.div`
15
17
  ${padding}
18
+ border-bottom-left-radius: calc(var(--tileBorderRadius) - 1px);
19
+ border-bottom-right-radius: calc(var(--tileBorderRadius) - 1px);
16
20
 
17
21
  ${({
18
22
  variant
19
23
  }) => css`
20
24
  background: ${getBackgroundColor(variant)};
21
- border-top: 1px solid var(--colorsUtilityMajor100);
25
+ border-top: 1px solid
26
+ ${variant === "grey" ? "var(--colorsUtilityMajor200)" : "var(--colorsUtilityMajor100)"};
22
27
  `}
23
28
  `;
24
29
  StyledTileFooter.defaultProps = {
@@ -0,0 +1,2 @@
1
+ export { default } from "./tile-header.component";
2
+ export type { TileHeaderProps } from "./tile-header.component";
@@ -0,0 +1 @@
1
+ export { default } from "./tile-header.component";
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { PaddingProps } from "styled-system";
3
+ import { TagProps } from "../../../__internal__/utils/helpers/tags";
4
+ export interface TileHeaderProps extends PaddingProps, TagProps {
5
+ children?: React.ReactNode;
6
+ /** set which background color variant should be used */
7
+ variant?: "default" | "black" | "transparent" | "grey";
8
+ }
9
+ export declare const TileHeader: ({ variant, children, ...rest }: TileHeaderProps) => React.JSX.Element;
10
+ export default TileHeader;
@@ -0,0 +1,14 @@
1
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : 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); }
2
+ import React from "react";
3
+ import PropTypes from "prop-types";
4
+ import StyledTileHeader from "./tile-header.style";
5
+ import tagComponent from "../../../__internal__/utils/helpers/tags";
6
+ import filterStyledSystemPaddingProps from "../../../style/utils/filter-styled-system-padding-props";
7
+ export const TileHeader = ({
8
+ variant,
9
+ children,
10
+ ...rest
11
+ }) => /*#__PURE__*/React.createElement(StyledTileHeader, _extends({
12
+ variant: variant
13
+ }, filterStyledSystemPaddingProps(rest), tagComponent("tile-header", rest)), children);
14
+ export default TileHeader;
@@ -0,0 +1,5 @@
1
+ import { TileHeaderProps } from "./tile-header.component";
2
+ declare const StyledTileHeader: import("styled-components").StyledComponent<"div", any, {
3
+ variant: TileHeaderProps["variant"];
4
+ }, never>;
5
+ export default StyledTileHeader;
@@ -0,0 +1,32 @@
1
+ import styled, { css } from "styled-components";
2
+ import { padding } from "styled-system";
3
+ import { baseTheme } from "../../../style/themes";
4
+ const getBackgroundColor = variant => {
5
+ switch (variant) {
6
+ case "transparent":
7
+ return "transparent";
8
+ case "black":
9
+ return "var(--colorsUtilityYin100)";
10
+ case "grey":
11
+ return "var(--colorsUtilityMajor025)";
12
+ default:
13
+ return "var(--colorsUtilityMajor100)";
14
+ }
15
+ };
16
+ const StyledTileHeader = styled.div`
17
+ ${padding}
18
+ border-top-left-radius: calc(var(--tileBorderRadius) - 1px);
19
+ border-top-right-radius: calc(var(--tileBorderRadius) - 1px);
20
+
21
+ ${({
22
+ variant
23
+ }) => css`
24
+ background: ${getBackgroundColor(variant)};
25
+ border-bottom: 1px solid
26
+ ${variant === "grey" ? "var(--colorsUtilityMajor200)" : "var(--colorsUtilityMajor100)"};
27
+ `}
28
+ `;
29
+ StyledTileHeader.defaultProps = {
30
+ theme: baseTheme
31
+ };
32
+ export default StyledTileHeader;
@@ -4,8 +4,8 @@ import { SpaceProps, WidthProps } from "styled-system";
4
4
  import { TagProps } from "../../__internal__/utils/helpers/tags";
5
5
  declare type DesignTokensType = keyof typeof DesignTokens;
6
6
  export interface TileProps extends SpaceProps, WidthProps, TagProps {
7
- /** Sets the theme of the tile - either 'tile', 'transparent' or 'active' */
8
- variant?: "tile" | "transparent" | "active";
7
+ /** Sets the theme of the tile */
8
+ variant?: "tile" | "transparent" | "active" | "grey";
9
9
  /**
10
10
  * The content to render within the tile. Each child will be wrapped with
11
11
  * a TileContent wrapper, which allows any individual child component to take a
@@ -25,8 +25,8 @@ export interface TileProps extends SpaceProps, WidthProps, TagProps {
25
25
  borderWidth?: Extract<DesignTokensType, `borderWidth${string}`>;
26
26
  /** Sets the border variant that should be used */
27
27
  borderVariant?: "default" | "selected" | "positive" | "negative" | "caution" | "info";
28
- /** Sets the level of roundness of the corners, "default" is 8px and "large" is 16px */
29
- roundness?: "default" | "large";
28
+ /** Sets the level of roundness of the corners, "default" is 8px, "large" is 16px and "small" is 4px */
29
+ roundness?: "default" | "large" | "small";
30
30
  /**
31
31
  * Set a percentage-based height for the whole Tile component, relative to its parent.
32
32
  */
@@ -18,6 +18,16 @@ const getBorderColor = borderVariant => {
18
18
  return "var(--colorsUtilityMajor100)";
19
19
  }
20
20
  };
21
+ const getBorderRadius = roundness => {
22
+ switch (roundness) {
23
+ case "large":
24
+ return "var(--borderRadius200)";
25
+ case "small":
26
+ return "var(--borderRadius050)";
27
+ default:
28
+ return "var(--borderRadius100)";
29
+ }
30
+ };
21
31
  const StyledTile = styled.div`
22
32
  ${({
23
33
  borderVariant,
@@ -32,8 +42,18 @@ const StyledTile = styled.div`
32
42
 
33
43
  box-sizing: border-box;
34
44
  border: var(--${borderWidth}) solid ${getBorderColor(borderVariant)};
35
- border-radius: ${roundness === "default" ? "var(--borderRadius100)" : "var(--borderRadius200)"};
36
- overflow: hidden;
45
+ border-radius: ${getBorderRadius(roundness)};
46
+ --tileBorderRadius: ${getBorderRadius(roundness)};
47
+
48
+ > *:first-child {
49
+ border-top-left-radius: calc(${getBorderRadius(roundness)} - 1px);
50
+ border-top-right-radius: calc(${getBorderRadius(roundness)} - 1px);
51
+ }
52
+
53
+ > *:last-child {
54
+ border-bottom-left-radius: calc(${getBorderRadius(roundness)} - 1px);
55
+ border-bottom-right-radius: calc(${getBorderRadius(roundness)} - 1px);
56
+ }
37
57
 
38
58
  ${variant === "tile" && css`
39
59
  background-color: var(--colorsUtilityYang100);
@@ -48,6 +68,11 @@ const StyledTile = styled.div`
48
68
  border-color: var(--colorsActionMajor500);
49
69
  `}
50
70
 
71
+ ${variant === "grey" && css`
72
+ background-color: var(--colorsUtilityMajor025);
73
+ border-color: var(--colorsUtilityMajor200);
74
+ `}
75
+
51
76
  display: flex;
52
77
  flex-direction: ${isHorizontal ? "row" : "column"};
53
78
  position: relative;
@@ -4,6 +4,8 @@ export { default as TileContent } from "./tile-content";
4
4
  export type { TileContentProps } from "./tile-content";
5
5
  export { default as TileFooter } from "./tile-footer";
6
6
  export type { TileFooterProps } from "./tile-footer";
7
+ export { default as TileHeader } from "./tile-header";
8
+ export type { TileHeaderProps } from "./tile-header";
7
9
  export { default as FlexTileContainer } from "./flex-tile-container";
8
10
  export type { FlexTileContainerProps } from "./flex-tile-container";
9
11
  export { default as FlexTileCell } from "./flex-tile-cell";
@@ -39,9 +39,16 @@ Object.defineProperty(exports, "TileFooter", {
39
39
  return _tileFooter.default;
40
40
  }
41
41
  });
42
+ Object.defineProperty(exports, "TileHeader", {
43
+ enumerable: true,
44
+ get: function () {
45
+ return _tileHeader.default;
46
+ }
47
+ });
42
48
  var _tile = _interopRequireDefault(require("./tile.component"));
43
49
  var _tileContent = _interopRequireDefault(require("./tile-content"));
44
50
  var _tileFooter = _interopRequireDefault(require("./tile-footer"));
51
+ var _tileHeader = _interopRequireDefault(require("./tile-header"));
45
52
  var _flexTileContainer = _interopRequireDefault(require("./flex-tile-container"));
46
53
  var _flexTileCell = _interopRequireDefault(require("./flex-tile-cell"));
47
54
  var _flexTileDivider = _interopRequireDefault(require("./flex-tile-divider"));
@@ -4,7 +4,7 @@ import { TagProps } from "../../../__internal__/utils/helpers/tags";
4
4
  export interface TileFooterProps extends PaddingProps, TagProps {
5
5
  children?: React.ReactNode;
6
6
  /** set which background color variant should be used */
7
- variant?: "default" | "black" | "transparent";
7
+ variant?: "default" | "black" | "transparent" | "grey";
8
8
  }
9
9
  export declare const TileFooter: ({ variant, children, ...rest }: TileFooterProps) => React.JSX.Element;
10
10
  export default TileFooter;
@@ -15,18 +15,23 @@ const getBackgroundColor = variant => {
15
15
  return "transparent";
16
16
  case "black":
17
17
  return "var(--colorsUtilityYin100)";
18
+ case "grey":
19
+ return "var(--colorsUtilityMajor025)";
18
20
  default:
19
21
  return "var(--colorsUtilityMajor100)";
20
22
  }
21
23
  };
22
24
  const StyledTileFooter = _styledComponents.default.div`
23
25
  ${_styledSystem.padding}
26
+ border-bottom-left-radius: calc(var(--tileBorderRadius) - 1px);
27
+ border-bottom-right-radius: calc(var(--tileBorderRadius) - 1px);
24
28
 
25
29
  ${({
26
30
  variant
27
31
  }) => (0, _styledComponents.css)`
28
32
  background: ${getBackgroundColor(variant)};
29
- border-top: 1px solid var(--colorsUtilityMajor100);
33
+ border-top: 1px solid
34
+ ${variant === "grey" ? "var(--colorsUtilityMajor200)" : "var(--colorsUtilityMajor100)"};
30
35
  `}
31
36
  `;
32
37
  StyledTileFooter.defaultProps = {
@@ -0,0 +1,2 @@
1
+ export { default } from "./tile-header.component";
2
+ export type { TileHeaderProps } from "./tile-header.component";
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "default", {
7
+ enumerable: true,
8
+ get: function () {
9
+ return _tileHeader.default;
10
+ }
11
+ });
12
+ var _tileHeader = _interopRequireDefault(require("./tile-header.component"));
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@@ -0,0 +1,6 @@
1
+ {
2
+ "sideEffects": false,
3
+ "module": "../../../../esm/components/tile/tile-header/index.js",
4
+ "main": "./index.js",
5
+ "types": "./index.d.ts"
6
+ }
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { PaddingProps } from "styled-system";
3
+ import { TagProps } from "../../../__internal__/utils/helpers/tags";
4
+ export interface TileHeaderProps extends PaddingProps, TagProps {
5
+ children?: React.ReactNode;
6
+ /** set which background color variant should be used */
7
+ variant?: "default" | "black" | "transparent" | "grey";
8
+ }
9
+ export declare const TileHeader: ({ variant, children, ...rest }: TileHeaderProps) => React.JSX.Element;
10
+ export default TileHeader;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.TileHeader = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _propTypes = _interopRequireDefault(require("prop-types"));
9
+ var _tileHeader = _interopRequireDefault(require("./tile-header.style"));
10
+ var _tags = _interopRequireDefault(require("../../../__internal__/utils/helpers/tags"));
11
+ var _filterStyledSystemPaddingProps = _interopRequireDefault(require("../../../style/utils/filter-styled-system-padding-props"));
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : 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); }
14
+ const TileHeader = ({
15
+ variant,
16
+ children,
17
+ ...rest
18
+ }) => /*#__PURE__*/_react.default.createElement(_tileHeader.default, _extends({
19
+ variant: variant
20
+ }, (0, _filterStyledSystemPaddingProps.default)(rest), (0, _tags.default)("tile-header", rest)), children);
21
+ exports.TileHeader = TileHeader;
22
+ var _default = exports.default = TileHeader;
@@ -0,0 +1,5 @@
1
+ import { TileHeaderProps } from "./tile-header.component";
2
+ declare const StyledTileHeader: import("styled-components").StyledComponent<"div", any, {
3
+ variant: TileHeaderProps["variant"];
4
+ }, never>;
5
+ export default StyledTileHeader;
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
8
+ var _styledSystem = require("styled-system");
9
+ var _themes = require("../../../style/themes");
10
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
11
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
12
+ const getBackgroundColor = variant => {
13
+ switch (variant) {
14
+ case "transparent":
15
+ return "transparent";
16
+ case "black":
17
+ return "var(--colorsUtilityYin100)";
18
+ case "grey":
19
+ return "var(--colorsUtilityMajor025)";
20
+ default:
21
+ return "var(--colorsUtilityMajor100)";
22
+ }
23
+ };
24
+ const StyledTileHeader = _styledComponents.default.div`
25
+ ${_styledSystem.padding}
26
+ border-top-left-radius: calc(var(--tileBorderRadius) - 1px);
27
+ border-top-right-radius: calc(var(--tileBorderRadius) - 1px);
28
+
29
+ ${({
30
+ variant
31
+ }) => (0, _styledComponents.css)`
32
+ background: ${getBackgroundColor(variant)};
33
+ border-bottom: 1px solid
34
+ ${variant === "grey" ? "var(--colorsUtilityMajor200)" : "var(--colorsUtilityMajor100)"};
35
+ `}
36
+ `;
37
+ StyledTileHeader.defaultProps = {
38
+ theme: _themes.baseTheme
39
+ };
40
+ var _default = exports.default = StyledTileHeader;
@@ -4,8 +4,8 @@ import { SpaceProps, WidthProps } from "styled-system";
4
4
  import { TagProps } from "../../__internal__/utils/helpers/tags";
5
5
  declare type DesignTokensType = keyof typeof DesignTokens;
6
6
  export interface TileProps extends SpaceProps, WidthProps, TagProps {
7
- /** Sets the theme of the tile - either 'tile', 'transparent' or 'active' */
8
- variant?: "tile" | "transparent" | "active";
7
+ /** Sets the theme of the tile */
8
+ variant?: "tile" | "transparent" | "active" | "grey";
9
9
  /**
10
10
  * The content to render within the tile. Each child will be wrapped with
11
11
  * a TileContent wrapper, which allows any individual child component to take a
@@ -25,8 +25,8 @@ export interface TileProps extends SpaceProps, WidthProps, TagProps {
25
25
  borderWidth?: Extract<DesignTokensType, `borderWidth${string}`>;
26
26
  /** Sets the border variant that should be used */
27
27
  borderVariant?: "default" | "selected" | "positive" | "negative" | "caution" | "info";
28
- /** Sets the level of roundness of the corners, "default" is 8px and "large" is 16px */
29
- roundness?: "default" | "large";
28
+ /** Sets the level of roundness of the corners, "default" is 8px, "large" is 16px and "small" is 4px */
29
+ roundness?: "default" | "large" | "small";
30
30
  /**
31
31
  * Set a percentage-based height for the whole Tile component, relative to its parent.
32
32
  */
@@ -27,6 +27,16 @@ const getBorderColor = borderVariant => {
27
27
  return "var(--colorsUtilityMajor100)";
28
28
  }
29
29
  };
30
+ const getBorderRadius = roundness => {
31
+ switch (roundness) {
32
+ case "large":
33
+ return "var(--borderRadius200)";
34
+ case "small":
35
+ return "var(--borderRadius050)";
36
+ default:
37
+ return "var(--borderRadius100)";
38
+ }
39
+ };
30
40
  const StyledTile = _styledComponents.default.div`
31
41
  ${({
32
42
  borderVariant,
@@ -41,8 +51,18 @@ const StyledTile = _styledComponents.default.div`
41
51
 
42
52
  box-sizing: border-box;
43
53
  border: var(--${borderWidth}) solid ${getBorderColor(borderVariant)};
44
- border-radius: ${roundness === "default" ? "var(--borderRadius100)" : "var(--borderRadius200)"};
45
- overflow: hidden;
54
+ border-radius: ${getBorderRadius(roundness)};
55
+ --tileBorderRadius: ${getBorderRadius(roundness)};
56
+
57
+ > *:first-child {
58
+ border-top-left-radius: calc(${getBorderRadius(roundness)} - 1px);
59
+ border-top-right-radius: calc(${getBorderRadius(roundness)} - 1px);
60
+ }
61
+
62
+ > *:last-child {
63
+ border-bottom-left-radius: calc(${getBorderRadius(roundness)} - 1px);
64
+ border-bottom-right-radius: calc(${getBorderRadius(roundness)} - 1px);
65
+ }
46
66
 
47
67
  ${variant === "tile" && (0, _styledComponents.css)`
48
68
  background-color: var(--colorsUtilityYang100);
@@ -57,6 +77,11 @@ const StyledTile = _styledComponents.default.div`
57
77
  border-color: var(--colorsActionMajor500);
58
78
  `}
59
79
 
80
+ ${variant === "grey" && (0, _styledComponents.css)`
81
+ background-color: var(--colorsUtilityMajor025);
82
+ border-color: var(--colorsUtilityMajor200);
83
+ `}
84
+
60
85
  display: flex;
61
86
  flex-direction: ${isHorizontal ? "row" : "column"};
62
87
  position: relative;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "carbon-react",
3
- "version": "126.3.1",
3
+ "version": "126.4.1",
4
4
  "description": "A library of reusable React components for easily building user interfaces.",
5
5
  "files": [
6
6
  "lib",