@atlaskit/avatar 21.3.2 → 21.3.4

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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # @atlaskit/avatar
2
2
 
3
+ ## 21.3.4
4
+
5
+ ### Patch Changes
6
+
7
+ - [`abf69e9a4f6`](https://bitbucket.org/atlassian/atlassian-frontend/commits/abf69e9a4f6) - Removes usage of deprecated theme mixins in favor of static token / color usage.
8
+
9
+ ## 21.3.3
10
+
11
+ ### Patch Changes
12
+
13
+ - [`e2d375fa634`](https://bitbucket.org/atlassian/atlassian-frontend/commits/e2d375fa634) - Refactor how some internal styles are applied; no functional changes.
14
+
3
15
  ## 21.3.2
4
16
 
5
17
  ### Patch Changes
@@ -22,7 +22,7 @@ var _templateObject;
22
22
  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; }
23
23
  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) { (0, _defineProperty2.default)(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; }
24
24
  var packageName = "@atlaskit/avatar";
25
- var packageVersion = "21.3.2";
25
+ var packageVersion = "21.3.4";
26
26
 
27
27
  // eslint-disable-next-line @repo/internal/react/consistent-types-definitions
28
28
 
@@ -5,6 +5,7 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.default = exports.ICON_COLOR = exports.ICON_BACKGROUND = void 0;
8
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
8
9
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
9
10
  var _react = require("react");
10
11
  var _react2 = require("@emotion/react");
@@ -12,10 +13,9 @@ var _person = _interopRequireDefault(require("@atlaskit/icon/glyph/person"));
12
13
  var _ship = _interopRequireDefault(require("@atlaskit/icon/glyph/ship"));
13
14
  var _colors = require("@atlaskit/theme/colors");
14
15
  var _constants = require("./constants");
15
- /** @jsx jsx */
16
- // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
17
-
18
- var ICON_BACKGROUND = "var(--ds-icon-inverse, ".concat((0, _colors.background)(), ")");
16
+ 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; }
17
+ 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) { (0, _defineProperty2.default)(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; } /** @jsx jsx */ // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
18
+ var ICON_BACKGROUND = "var(--ds-icon-inverse, ".concat(_colors.N0, ")");
19
19
  exports.ICON_BACKGROUND = ICON_BACKGROUND;
20
20
  var ICON_COLOR = "var(--ds-icon-subtle, ".concat(_colors.N90, ")");
21
21
  exports.ICON_COLOR = ICON_COLOR;
@@ -25,24 +25,37 @@ var avatarDefaultIconStyles = (0, _react2.css)({
25
25
  height: '100%',
26
26
  backgroundColor: ICON_COLOR
27
27
  });
28
+ var nestedAvatarStyles = Object.entries(_constants.AVATAR_SIZES).reduce(function (styles, _ref) {
29
+ var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
30
+ key = _ref2[0],
31
+ size = _ref2[1];
32
+ return _objectSpread(_objectSpread({}, styles), {}, (0, _defineProperty2.default)({}, key, (0, _react2.css)({
33
+ // eslint-disable-next-line @repo/internal/styles/no-nested-styles
34
+ '& svg': {
35
+ width: "".concat(size, "px"),
36
+ height: "".concat(size, "px")
37
+ }
38
+ })));
39
+ }, {});
28
40
  var avatarImageStyles = (0, _react2.css)({
29
41
  display: 'flex',
30
42
  width: '100%',
31
43
  height: '100%',
32
44
  flex: '1 1 100%'
33
45
  });
46
+
34
47
  /**
35
48
  * __Avatar image__
36
49
  *
37
50
  * An avatar image is an internal component used to control the rendering phases of an image.
38
51
  */
39
- var AvatarImage = function AvatarImage(_ref) {
40
- var _ref$alt = _ref.alt,
41
- alt = _ref$alt === void 0 ? '' : _ref$alt,
42
- src = _ref.src,
43
- appearance = _ref.appearance,
44
- size = _ref.size,
45
- testId = _ref.testId;
52
+ var AvatarImage = function AvatarImage(_ref3) {
53
+ var _ref3$alt = _ref3.alt,
54
+ alt = _ref3$alt === void 0 ? '' : _ref3$alt,
55
+ src = _ref3.src,
56
+ appearance = _ref3.appearance,
57
+ size = _ref3.size,
58
+ testId = _ref3.testId;
46
59
  var _useState = (0, _react.useState)(false),
47
60
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
48
61
  hasImageErrored = _useState2[0],
@@ -55,15 +68,7 @@ var AvatarImage = function AvatarImage(_ref) {
55
68
  }, [src]);
56
69
  if (!src || hasImageErrored) {
57
70
  return (0, _react2.jsx)("span", {
58
- css: [avatarDefaultIconStyles,
59
- // TODO: These dynamic SVG styles can't be set in 'style'. On a refactor, use a css custom property to pass down the size
60
- // eslint-disable-next-line @repo/internal/react/consistent-css-prop-usage
61
- {
62
- '& svg': {
63
- width: "".concat(_constants.AVATAR_SIZES[size], "px"),
64
- height: "".concat(_constants.AVATAR_SIZES[size], "px")
65
- }
66
- }]
71
+ css: [avatarDefaultIconStyles, nestedAvatarStyles[size]]
67
72
  }, appearance === 'circle' ? (0, _react2.jsx)(_person.default, {
68
73
  label: alt,
69
74
  primaryColor: ICON_BACKGROUND,
@@ -32,7 +32,7 @@ var getStyles = function getStyles(css, _ref) {
32
32
  isInteractive = _ref.isInteractive,
33
33
  isDisabled = _ref.isDisabled;
34
34
  return (// eslint-disable-next-line @atlaskit/design-system/ensure-design-token-usage-spacing, @repo/internal/react/no-css-string-literals
35
- css(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n align-items: center;\n background-color: ", ";\n border-radius: ", "px;\n border: ", "px solid transparent;\n box-sizing: border-box;\n color: inherit;\n display: flex;\n font-size: inherit;\n font-style: normal;\n font-weight: normal;\n line-height: 1;\n outline: none;\n margin: ", ";\n padding: ", ";\n text-align: left;\n text-decoration: none;\n width: 100%;\n\n ", "\n\n ", "\n "])), backgroundColor, (0, _constants.borderRadius)(), _constants2.BORDER_WIDTH, "var(--ds-space-0, 0px)", "var(--ds-space-050, 4px)", isInteractive && "\n :hover {\n background-color: ".concat("var(--ds-background-neutral-subtle-hovered, ".concat((0, _colors.backgroundHover)(), ")"), ";\n cursor: pointer;\n text-decoration: none;\n }\n\n :focus {\n outline: none;\n border-color: ", "var(--ds-border-focused, ".concat(_colors.B200, ")"), ";\n }\n\n :active {\n background-color: ", "var(--ds-background-neutral-subtle-pressed, ".concat((0, _colors.backgroundActive)(), ")"), ";\n }\n "), isDisabled && "\n cursor: not-allowed;\n opacity: ".concat("var(--ds-opacity-disabled, 0.5)", ";\n pointer-events: none;\n "))
35
+ css(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n align-items: center;\n background-color: ", ";\n border-radius: ", "px;\n border: ", "px solid transparent;\n box-sizing: border-box;\n color: inherit;\n display: flex;\n font-size: inherit;\n font-style: normal;\n font-weight: normal;\n line-height: 1;\n outline: none;\n margin: ", ";\n padding: ", ";\n text-align: left;\n text-decoration: none;\n width: 100%;\n\n ", "\n\n ", "\n "])), backgroundColor, (0, _constants.borderRadius)(), _constants2.BORDER_WIDTH, "var(--ds-space-0, 0px)", "var(--ds-space-050, 4px)", isInteractive && "\n :hover {\n background-color: ".concat("var(--ds-background-neutral-subtle-hovered, ".concat(_colors.N30, ")"), ";\n cursor: pointer;\n text-decoration: none;\n }\n\n :focus {\n outline: none;\n border-color: ", "var(--ds-border-focused, ".concat(_colors.B200, ")"), ";\n }\n\n :active {\n background-color: ", "var(--ds-background-neutral-subtle-pressed, ".concat(_colors.B50, ")"), ";\n }\n "), isDisabled && "\n cursor: not-allowed;\n opacity: ".concat("var(--ds-opacity-disabled, 0.5)", ";\n pointer-events: none;\n "))
36
36
  );
37
37
  };
38
38
 
@@ -28,7 +28,7 @@ var iconWrapperStyles = (0, _react.css)({
28
28
  */
29
29
  var IconWrapper = function IconWrapper(_ref) {
30
30
  var _ref$bgColor = _ref.bgColor,
31
- bgColor = _ref$bgColor === void 0 ? "var(--ds-surface-overlay, ".concat((0, _colors.background)(), ")") : _ref$bgColor,
31
+ bgColor = _ref$bgColor === void 0 ? "var(--ds-surface-overlay, ".concat(_colors.N0, ")") : _ref$bgColor,
32
32
  children = _ref.children,
33
33
  label = _ref.label;
34
34
  return (0, _react.jsx)("span", {
@@ -22,11 +22,11 @@ var BusyIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragment, n
22
22
  cy: "4",
23
23
  r: "4"
24
24
  }), /*#__PURE__*/_react.default.createElement("path", {
25
- fill: "var(--ds-surface-overlay, ".concat((0, _colors.background)(), ")"),
25
+ fill: "var(--ds-surface-overlay, ".concat(_colors.N0, ")"),
26
26
  d: "M3.3,1.9l2.8,2.8c0.2,0.2,0.2,0.5,0,0.7L5.4,6.1c-0.2,0.2-0.5,0.2-0.7,0L1.9,3.3c-0.2-0.2-0.2-0.5,0-0.7l0.7-0.7C2.8,1.7,3.1,1.7,3.3,1.9z"
27
27
  }));
28
28
  var FocusIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement("path", {
29
- fill: "var(--ds-icon-discovery, ".concat((0, _colors.purple)(), ")"),
29
+ fill: "var(--ds-icon-discovery, ".concat(_colors.P300, ")"),
30
30
  d: "M4,8 C1.790861,8 0,6.209139 0,4 C0,1.790861 1.790861,0 4,0 C6.209139,0 8,1.790861 8,4 C8,6.209139 6.209139,8 4,8 Z M4,6.66666667 C5.47275933,6.66666667 6.66666667,5.47275933 6.66666667,4 C6.66666667,2.52724067 5.47275933,1.33333333 4,1.33333333 C2.52724067,1.33333333 1.33333333,2.52724067 1.33333333,4 C1.33333333,5.47275933 2.52724067,6.66666667 4,6.66666667 Z M4,5.33333333 C3.26362033,5.33333333 2.66666667,4.73637967 2.66666667,4 C2.66666667,3.26362033 3.26362033,2.66666667 4,2.66666667 C4.73637967,2.66666667 5.33333333,3.26362033 5.33333333,4 C5.33333333,4.73637967 4.73637967,5.33333333 4,5.33333333 Z"
31
31
  }));
32
32
  var OfflineIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement("path", {
@@ -1,33 +1,49 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
3
4
  Object.defineProperty(exports, "__esModule", {
4
5
  value: true
5
6
  });
6
7
  exports.default = void 0;
8
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
7
10
  var _react = require("@emotion/react");
8
11
  var _constants = require("./constants");
9
- /** @jsx jsx */
10
- // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
12
+ 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; }
13
+ 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) { (0, _defineProperty2.default)(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; } /** @jsx jsx */ // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
14
+ var skeletonStyles = (0, _react.css)({
15
+ display: 'inline-block',
16
+ backgroundColor: "var(".concat(_constants.CSS_VAR_AVATAR_BGCOLOR, ")"),
17
+ border: "".concat(_constants.BORDER_WIDTH, "px solid transparent")
18
+ });
19
+ var sizeStyles = Object.entries(_constants.AVATAR_SIZES).reduce(function (styles, _ref) {
20
+ var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
21
+ key = _ref2[0],
22
+ size = _ref2[1];
23
+ return _objectSpread(_objectSpread({}, styles), {}, (0, _defineProperty2.default)({}, key, (0, _react.css)({
24
+ width: "".concat(size, "px"),
25
+ height: "".concat(size, "px")
26
+ })));
27
+ }, {});
11
28
 
12
- var getStyles = function getStyles(_ref) {
13
- var _ref$size = _ref.size,
14
- size = _ref$size === void 0 ? 'medium' : _ref$size,
15
- _ref$appearance = _ref.appearance,
16
- appearance = _ref$appearance === void 0 ? 'circle' : _ref$appearance,
17
- _ref$color = _ref.color,
18
- color = _ref$color === void 0 ? 'currentColor' : _ref$color,
19
- _ref$weight = _ref.weight,
20
- weight = _ref$weight === void 0 ? 'normal' : _ref$weight;
21
- return (0, _react.css)({
22
- display: 'inline-block',
23
- width: "".concat(_constants.AVATAR_SIZES[size], "px"),
24
- height: "".concat(_constants.AVATAR_SIZES[size], "px"),
25
- backgroundColor: color,
26
- border: "".concat(_constants.BORDER_WIDTH, "px solid transparent"),
27
- borderRadius: "".concat(appearance === 'square' ? "".concat(_constants.AVATAR_RADIUS[size], "px") : '50%'),
28
- opacity: "".concat(weight === 'strong' ? 0.3 : 0.15)
29
- });
30
- };
29
+ // eslint-disable-next-line @atlaskit/design-system/consistent-css-prop-usage
30
+ var radiusStyles = Object.entries(_constants.AVATAR_RADIUS).reduce(function (styles, _ref3) {
31
+ var _ref4 = (0, _slicedToArray2.default)(_ref3, 2),
32
+ key = _ref4[0],
33
+ size = _ref4[1];
34
+ return _objectSpread(_objectSpread({}, styles), {}, (0, _defineProperty2.default)({}, key, (0, _react.css)({
35
+ borderRadius: "".concat(size, "px")
36
+ })));
37
+ }, {});
38
+ var defaultRadiusStyles = (0, _react.css)({
39
+ borderRadius: '50%'
40
+ });
41
+ var strongOpacityStyles = (0, _react.css)({
42
+ opacity: 0.3
43
+ });
44
+ var defaultOpacityStyles = (0, _react.css)({
45
+ opacity: 0.15
46
+ });
31
47
 
32
48
  /**
33
49
  * __Skeleton__
@@ -37,20 +53,14 @@ var getStyles = function getStyles(_ref) {
37
53
  * - [Examples](https://atlassian.design/components/avatar/avatar-skeleton/examples)
38
54
  * - [Code](https://atlassian.design/components/avatar/avatar-skeleton/code)
39
55
  */
40
- var Skeleton = function Skeleton(_ref2) {
41
- var size = _ref2.size,
42
- appearance = _ref2.appearance,
43
- color = _ref2.color,
44
- weight = _ref2.weight;
56
+ var Skeleton = function Skeleton(_ref5) {
57
+ var size = _ref5.size,
58
+ appearance = _ref5.appearance,
59
+ color = _ref5.color,
60
+ weight = _ref5.weight;
45
61
  return (0, _react.jsx)("div", {
46
- // TODO: Refactor styles to follow css prop rules
47
- // eslint-disable-next-line @repo/internal/react/consistent-css-prop-usage
48
- css: getStyles({
49
- size: size,
50
- appearance: appearance,
51
- color: color,
52
- weight: weight
53
- })
62
+ css: [skeletonStyles, sizeStyles[size !== null && size !== void 0 ? size : 'medium'], appearance === 'square' ? radiusStyles[size !== null && size !== void 0 ? size : 'medium'] : defaultRadiusStyles, weight === 'strong' ? strongOpacityStyles : defaultOpacityStyles],
63
+ style: (0, _defineProperty2.default)({}, _constants.CSS_VAR_AVATAR_BGCOLOR, color !== null && color !== void 0 ? color : 'currentColor')
54
64
  });
55
65
  };
56
66
  var _default = Skeleton;
@@ -22,7 +22,7 @@ var ApprovedIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragmen
22
22
  cy: "4",
23
23
  r: "4"
24
24
  }), /*#__PURE__*/_react.default.createElement("path", {
25
- fill: "var(--ds-surface-overlay, ".concat((0, _colors.background)(), ")"),
25
+ fill: "var(--ds-surface-overlay, ".concat(_colors.N0, ")"),
26
26
  d: "M2.47140452,3.52859548 C2.21105499,3.26824595 1.78894501,3.26824595 1.52859548,3.52859548 C1.26824595,3.78894501 1.26824595,4.21105499 1.52859548,4.47140452 L2.86192881,5.80473785 C3.12227834,6.06508738 3.54438833,6.06508738 3.80473785,5.80473785 L6.47140452,3.13807119 C6.73175405,2.87772166 6.73175405,2.45561167 6.47140452,2.19526215 C6.21105499,1.93491262 5.78894501,1.93491262 5.52859548,2.19526215 L3.33333333,4.39052429 L2.47140452,3.52859548 Z"
27
27
  }));
28
28
  var DeclinedIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement("circle", {
@@ -31,7 +31,7 @@ var DeclinedIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragmen
31
31
  cy: "4",
32
32
  r: "4"
33
33
  }), /*#__PURE__*/_react.default.createElement("path", {
34
- fill: "var(--ds-surface-overlay, ".concat((0, _colors.background)(), ")"),
34
+ fill: "var(--ds-surface-overlay, ".concat(_colors.N0, ")"),
35
35
  d: "M4.890661,4.0088336 L5.81806461,3.07802178 C6.06167933,2.83351177 6.06048933,2.43826992 5.81540668,2.19522442 C5.57032402,1.95217891 5.17415651,1.95336612 4.93054179,2.19787613 L4.00765946,3.12415007 L3.06906871,2.18377143 C2.82523777,1.93947602 2.42906937,1.93863765 2.18420182,2.18189887 C1.93933427,2.42516008 1.93849394,2.82040282 2.18232488,3.06469822 L3.12544091,4.00961077 L2.20275024,4.93569234 C1.95913552,5.18020236 1.96032551,5.5754442 2.20540817,5.81848971 C2.45049083,6.06153521 2.84665833,6.060348 3.09027306,5.81583799 L4.00844245,4.89429431 L4.9092123,5.79678001 C5.15304324,6.04107541 5.54921164,6.04191379 5.79407919,5.79865257 C6.03894674,5.55539135 6.03978708,5.16014862 5.79595614,4.91585321 L4.890661,4.0088336 Z"
36
36
  }));
37
37
  var LockedIndicator = /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement("circle", {
package/dist/cjs/Text.js CHANGED
@@ -1,29 +1,28 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
3
  Object.defineProperty(exports, "__esModule", {
5
4
  value: true
6
5
  });
7
6
  exports.default = void 0;
8
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
9
7
  var _react = require("@emotion/react");
10
8
  var _colors = require("@atlaskit/theme/colors");
11
- 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; }
12
- 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) { (0, _defineProperty2.default)(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; } /** @jsx jsx */ // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
13
- var getStyles = function getStyles(isSecondary, shouldTruncate) {
14
- return (0, _react.css)(_objectSpread(_objectSpread({
15
- display: 'block',
16
- margin: "var(--ds-space-0, 0px)",
17
- color: "var(--ds-text, ".concat(_colors.N900, ")")
18
- }, shouldTruncate && {
19
- overflowX: 'hidden',
20
- textOverflow: 'ellipsis',
21
- whiteSpace: 'nowrap'
22
- }), isSecondary && {
23
- color: "var(--ds-text-subtlest, ".concat(_colors.N200, ")"),
24
- fontSize: '0.85em'
25
- }));
26
- };
9
+ /** @jsx jsx */
10
+ // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
11
+
12
+ var baseStyles = (0, _react.css)({
13
+ display: 'block',
14
+ margin: "var(--ds-space-0, 0px)",
15
+ color: "var(--ds-text, ".concat(_colors.N900, ")")
16
+ });
17
+ var truncateStyles = (0, _react.css)({
18
+ overflowX: 'hidden',
19
+ textOverflow: 'ellipsis',
20
+ whiteSpace: 'nowrap'
21
+ });
22
+ var secondaryStyles = (0, _react.css)({
23
+ color: "var(--ds-text-subtlest, ".concat(_colors.N200, ")"),
24
+ fontSize: '0.85em'
25
+ });
27
26
 
28
27
  /**
29
28
  * __Text__
@@ -34,13 +33,9 @@ var Text = function Text(_ref) {
34
33
  var isSecondary = _ref.isSecondary,
35
34
  children = _ref.children,
36
35
  shouldTruncate = _ref.shouldTruncate;
37
- return (
38
- // TODO: Refactor styles to follow css prop rules
39
- // eslint-disable-next-line @repo/internal/react/consistent-css-prop-usage
40
- (0, _react.jsx)("span", {
41
- css: getStyles(isSecondary, shouldTruncate)
42
- }, children)
43
- );
36
+ return (0, _react.jsx)("span", {
37
+ css: [baseStyles, isSecondary && secondaryStyles, shouldTruncate && truncateStyles]
38
+ }, children);
44
39
  };
45
40
  var _default = Text;
46
41
  exports.default = _default;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.ICON_SIZES = exports.ICON_OFFSET = exports.BORDER_WIDTH = exports.AVATAR_SIZES = exports.AVATAR_RADIUS = exports.ACTIVE_SCALE_FACTOR = void 0;
6
+ exports.ICON_SIZES = exports.ICON_OFFSET = exports.CSS_VAR_AVATAR_BGCOLOR = exports.BORDER_WIDTH = exports.AVATAR_SIZES = exports.AVATAR_RADIUS = exports.ACTIVE_SCALE_FACTOR = void 0;
7
7
  var _constants = require("@atlaskit/theme/constants");
8
8
  // eslint-disable-next-line @repo/internal/fs/filename-pattern-match, @atlaskit/design-system/no-deprecated-imports
9
9
 
@@ -31,6 +31,8 @@ var BORDER_WIDTH = 2;
31
31
  exports.BORDER_WIDTH = BORDER_WIDTH;
32
32
  var ACTIVE_SCALE_FACTOR = 0.9;
33
33
  exports.ACTIVE_SCALE_FACTOR = ACTIVE_SCALE_FACTOR;
34
+ var CSS_VAR_AVATAR_BGCOLOR = '--avatar-background-color';
35
+ exports.CSS_VAR_AVATAR_BGCOLOR = CSS_VAR_AVATAR_BGCOLOR;
34
36
  var ICON_SIZES = {
35
37
  small: 12,
36
38
  medium: 14,
@@ -1,5 +1,5 @@
1
1
  {
2
2
  "name": "@atlaskit/avatar",
3
- "version": "21.3.2",
3
+ "version": "21.3.4",
4
4
  "sideEffects": false
5
5
  }
@@ -10,7 +10,7 @@ import { PresenceWrapper } from './Presence';
10
10
  import { StatusWrapper } from './Status';
11
11
  import { getButtonProps, getCustomElement, getLinkProps } from './utilities';
12
12
  const packageName = "@atlaskit/avatar";
13
- const packageVersion = "21.3.2";
13
+ const packageVersion = "21.3.4";
14
14
 
15
15
  // eslint-disable-next-line @repo/internal/react/consistent-types-definitions
16
16
 
@@ -4,9 +4,9 @@ import { useEffect, useState } from 'react';
4
4
  import { css, jsx } from '@emotion/react';
5
5
  import PersonIcon from '@atlaskit/icon/glyph/person';
6
6
  import ShipIcon from '@atlaskit/icon/glyph/ship';
7
- import { background, N90 } from '@atlaskit/theme/colors';
7
+ import { N0, N90 } from '@atlaskit/theme/colors';
8
8
  import { AVATAR_RADIUS, AVATAR_SIZES } from './constants';
9
- export const ICON_BACKGROUND = `var(--ds-icon-inverse, ${background()})`;
9
+ export const ICON_BACKGROUND = `var(--ds-icon-inverse, ${N0})`;
10
10
  export const ICON_COLOR = `var(--ds-icon-subtle, ${N90})`;
11
11
  const avatarDefaultIconStyles = css({
12
12
  display: 'block',
@@ -14,12 +14,25 @@ const avatarDefaultIconStyles = css({
14
14
  height: '100%',
15
15
  backgroundColor: ICON_COLOR
16
16
  });
17
+ const nestedAvatarStyles = Object.entries(AVATAR_SIZES).reduce((styles, [key, size]) => {
18
+ return {
19
+ ...styles,
20
+ [key]: css({
21
+ // eslint-disable-next-line @repo/internal/styles/no-nested-styles
22
+ '& svg': {
23
+ width: `${size}px`,
24
+ height: `${size}px`
25
+ }
26
+ })
27
+ };
28
+ }, {});
17
29
  const avatarImageStyles = css({
18
30
  display: 'flex',
19
31
  width: '100%',
20
32
  height: '100%',
21
33
  flex: '1 1 100%'
22
34
  });
35
+
23
36
  /**
24
37
  * __Avatar image__
25
38
  *
@@ -41,15 +54,7 @@ const AvatarImage = ({
41
54
  }, [src]);
42
55
  if (!src || hasImageErrored) {
43
56
  return jsx("span", {
44
- css: [avatarDefaultIconStyles,
45
- // TODO: These dynamic SVG styles can't be set in 'style'. On a refactor, use a css custom property to pass down the size
46
- // eslint-disable-next-line @repo/internal/react/consistent-css-prop-usage
47
- {
48
- '& svg': {
49
- width: `${AVATAR_SIZES[size]}px`,
50
- height: `${AVATAR_SIZES[size]}px`
51
- }
52
- }]
57
+ css: [avatarDefaultIconStyles, nestedAvatarStyles[size]]
53
58
  }, appearance === 'circle' ? jsx(PersonIcon, {
54
59
  label: alt,
55
60
  primaryColor: ICON_BACKGROUND,
@@ -2,7 +2,7 @@
2
2
  // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
3
3
  import { createElement, forwardRef, Fragment } from 'react';
4
4
  import { ClassNames, css, jsx } from '@emotion/react';
5
- import { B200, backgroundActive, backgroundHover } from '@atlaskit/theme/colors';
5
+ import { B200, B50, N30 } from '@atlaskit/theme/colors';
6
6
  import { borderRadius } from '@atlaskit/theme/constants';
7
7
  import { BORDER_WIDTH } from './constants';
8
8
  import Text from './Text';
@@ -42,7 +42,7 @@ css`
42
42
 
43
43
  ${isInteractive && `
44
44
  :hover {
45
- background-color: ${`var(--ds-background-neutral-subtle-hovered, ${backgroundHover()})`};
45
+ background-color: ${`var(--ds-background-neutral-subtle-hovered, ${N30})`};
46
46
  cursor: pointer;
47
47
  text-decoration: none;
48
48
  }
@@ -53,7 +53,7 @@ css`
53
53
  }
54
54
 
55
55
  :active {
56
- background-color: ${`var(--ds-background-neutral-subtle-pressed, ${backgroundActive()})`};
56
+ background-color: ${`var(--ds-background-neutral-subtle-pressed, ${B50})`};
57
57
  }
58
58
  `}
59
59
 
@@ -2,7 +2,7 @@
2
2
  // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
3
3
 
4
4
  import { css, jsx } from '@emotion/react';
5
- import { background } from '@atlaskit/theme/colors';
5
+ import { N0 } from '@atlaskit/theme/colors';
6
6
  import { BORDER_WIDTH } from './constants';
7
7
  const iconWrapperStyles = css({
8
8
  display: 'flex',
@@ -21,7 +21,7 @@ const iconWrapperStyles = css({
21
21
  * An icon wrapper is used internally only.
22
22
  */
23
23
  const IconWrapper = ({
24
- bgColor = `var(--ds-surface-overlay, ${background()})`,
24
+ bgColor = `var(--ds-surface-overlay, ${N0})`,
25
25
  children,
26
26
  label
27
27
  }) => jsx("span", {
@@ -1,6 +1,6 @@
1
1
  // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
2
2
  import React, { Fragment } from 'react';
3
- import { background, G300, N200, N40, purple, R300 } from '@atlaskit/theme/colors';
3
+ import { G300, N0, N200, N40, P300, R300 } from '@atlaskit/theme/colors';
4
4
  import { ICON_OFFSET, ICON_SIZES } from './constants';
5
5
  import IconWrapper from './IconWrapper';
6
6
 
@@ -12,11 +12,11 @@ const BusyIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE
12
12
  cy: "4",
13
13
  r: "4"
14
14
  }), /*#__PURE__*/React.createElement("path", {
15
- fill: `var(--ds-surface-overlay, ${background()})`,
15
+ fill: `var(--ds-surface-overlay, ${N0})`,
16
16
  d: "M3.3,1.9l2.8,2.8c0.2,0.2,0.2,0.5,0,0.7L5.4,6.1c-0.2,0.2-0.5,0.2-0.7,0L1.9,3.3c-0.2-0.2-0.2-0.5,0-0.7l0.7-0.7C2.8,1.7,3.1,1.7,3.3,1.9z"
17
17
  }));
18
18
  const FocusIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("path", {
19
- fill: `var(--ds-icon-discovery, ${purple()})`,
19
+ fill: `var(--ds-icon-discovery, ${P300})`,
20
20
  d: "M4,8 C1.790861,8 0,6.209139 0,4 C0,1.790861 1.790861,0 4,0 C6.209139,0 8,1.790861 8,4 C8,6.209139 6.209139,8 4,8 Z M4,6.66666667 C5.47275933,6.66666667 6.66666667,5.47275933 6.66666667,4 C6.66666667,2.52724067 5.47275933,1.33333333 4,1.33333333 C2.52724067,1.33333333 1.33333333,2.52724067 1.33333333,4 C1.33333333,5.47275933 2.52724067,6.66666667 4,6.66666667 Z M4,5.33333333 C3.26362033,5.33333333 2.66666667,4.73637967 2.66666667,4 C2.66666667,3.26362033 3.26362033,2.66666667 4,2.66666667 C4.73637967,2.66666667 5.33333333,3.26362033 5.33333333,4 C5.33333333,4.73637967 4.73637967,5.33333333 4,5.33333333 Z"
21
21
  }));
22
22
  const OfflineIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("path", {
@@ -2,20 +2,39 @@
2
2
  // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
3
3
 
4
4
  import { css, jsx } from '@emotion/react';
5
- import { AVATAR_RADIUS, AVATAR_SIZES, BORDER_WIDTH } from './constants';
6
- const getStyles = ({
7
- size = 'medium',
8
- appearance = 'circle',
9
- color = 'currentColor',
10
- weight = 'normal'
11
- }) => css({
5
+ import { AVATAR_RADIUS, AVATAR_SIZES, BORDER_WIDTH, CSS_VAR_AVATAR_BGCOLOR } from './constants';
6
+ const skeletonStyles = css({
12
7
  display: 'inline-block',
13
- width: `${AVATAR_SIZES[size]}px`,
14
- height: `${AVATAR_SIZES[size]}px`,
15
- backgroundColor: color,
16
- border: `${BORDER_WIDTH}px solid transparent`,
17
- borderRadius: `${appearance === 'square' ? `${AVATAR_RADIUS[size]}px` : '50%'}`,
18
- opacity: `${weight === 'strong' ? 0.3 : 0.15}`
8
+ backgroundColor: `var(${CSS_VAR_AVATAR_BGCOLOR})`,
9
+ border: `${BORDER_WIDTH}px solid transparent`
10
+ });
11
+ const sizeStyles = Object.entries(AVATAR_SIZES).reduce((styles, [key, size]) => {
12
+ return {
13
+ ...styles,
14
+ [key]: css({
15
+ width: `${size}px`,
16
+ height: `${size}px`
17
+ })
18
+ };
19
+ }, {});
20
+
21
+ // eslint-disable-next-line @atlaskit/design-system/consistent-css-prop-usage
22
+ const radiusStyles = Object.entries(AVATAR_RADIUS).reduce((styles, [key, size]) => {
23
+ return {
24
+ ...styles,
25
+ [key]: css({
26
+ borderRadius: `${size}px`
27
+ })
28
+ };
29
+ }, {});
30
+ const defaultRadiusStyles = css({
31
+ borderRadius: '50%'
32
+ });
33
+ const strongOpacityStyles = css({
34
+ opacity: 0.3
35
+ });
36
+ const defaultOpacityStyles = css({
37
+ opacity: 0.15
19
38
  });
20
39
 
21
40
  /**
@@ -32,13 +51,9 @@ const Skeleton = ({
32
51
  color,
33
52
  weight
34
53
  }) => jsx("div", {
35
- // TODO: Refactor styles to follow css prop rules
36
- // eslint-disable-next-line @repo/internal/react/consistent-css-prop-usage
37
- css: getStyles({
38
- size,
39
- appearance,
40
- color,
41
- weight
42
- })
54
+ css: [skeletonStyles, sizeStyles[size !== null && size !== void 0 ? size : 'medium'], appearance === 'square' ? radiusStyles[size !== null && size !== void 0 ? size : 'medium'] : defaultRadiusStyles, weight === 'strong' ? strongOpacityStyles : defaultOpacityStyles],
55
+ style: {
56
+ [CSS_VAR_AVATAR_BGCOLOR]: color !== null && color !== void 0 ? color : 'currentColor'
57
+ }
43
58
  });
44
59
  export default Skeleton;
@@ -1,6 +1,6 @@
1
1
  // eslint-disable-next-line @repo/internal/fs/filename-pattern-match
2
2
  import React, { Fragment } from 'react';
3
- import { background, G400, N40, N500, R400 } from '@atlaskit/theme/colors';
3
+ import { G400, N0, N40, N500, R400 } from '@atlaskit/theme/colors';
4
4
  import { ICON_OFFSET, ICON_SIZES } from './constants';
5
5
  import IconWrapper from './IconWrapper';
6
6
 
@@ -12,7 +12,7 @@ const ApprovedIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__
12
12
  cy: "4",
13
13
  r: "4"
14
14
  }), /*#__PURE__*/React.createElement("path", {
15
- fill: `var(--ds-surface-overlay, ${background()})`,
15
+ fill: `var(--ds-surface-overlay, ${N0})`,
16
16
  d: "M2.47140452,3.52859548 C2.21105499,3.26824595 1.78894501,3.26824595 1.52859548,3.52859548 C1.26824595,3.78894501 1.26824595,4.21105499 1.52859548,4.47140452 L2.86192881,5.80473785 C3.12227834,6.06508738 3.54438833,6.06508738 3.80473785,5.80473785 L6.47140452,3.13807119 C6.73175405,2.87772166 6.73175405,2.45561167 6.47140452,2.19526215 C6.21105499,1.93491262 5.78894501,1.93491262 5.52859548,2.19526215 L3.33333333,4.39052429 L2.47140452,3.52859548 Z"
17
17
  }));
18
18
  const DeclinedIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("circle", {
@@ -21,7 +21,7 @@ const DeclinedIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__
21
21
  cy: "4",
22
22
  r: "4"
23
23
  }), /*#__PURE__*/React.createElement("path", {
24
- fill: `var(--ds-surface-overlay, ${background()})`,
24
+ fill: `var(--ds-surface-overlay, ${N0})`,
25
25
  d: "M4.890661,4.0088336 L5.81806461,3.07802178 C6.06167933,2.83351177 6.06048933,2.43826992 5.81540668,2.19522442 C5.57032402,1.95217891 5.17415651,1.95336612 4.93054179,2.19787613 L4.00765946,3.12415007 L3.06906871,2.18377143 C2.82523777,1.93947602 2.42906937,1.93863765 2.18420182,2.18189887 C1.93933427,2.42516008 1.93849394,2.82040282 2.18232488,3.06469822 L3.12544091,4.00961077 L2.20275024,4.93569234 C1.95913552,5.18020236 1.96032551,5.5754442 2.20540817,5.81848971 C2.45049083,6.06153521 2.84665833,6.060348 3.09027306,5.81583799 L4.00844245,4.89429431 L4.9092123,5.79678001 C5.15304324,6.04107541 5.54921164,6.04191379 5.79407919,5.79865257 C6.03894674,5.55539135 6.03978708,5.16014862 5.79595614,4.91585321 L4.890661,4.0088336 Z"
26
26
  }));
27
27
  const LockedIndicator = /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement("circle", {