@salutejs/plasma-new-hope 0.240.1-canary.1705.12790178134.0 → 0.241.0-canary.1696.12814018283.0

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 (129) hide show
  1. package/cjs/components/Avatar/Avatar.js +40 -3
  2. package/cjs/components/Avatar/Avatar.js.map +1 -1
  3. package/cjs/components/Avatar/Avatar.styles.js +32 -1
  4. package/cjs/components/Avatar/Avatar.styles.js.map +1 -1
  5. package/cjs/components/Avatar/Avatar.styles_131qvfx.css +8 -0
  6. package/cjs/components/Avatar/Avatar.tokens.js +41 -2
  7. package/cjs/components/Avatar/Avatar.tokens.js.map +1 -1
  8. package/cjs/components/Avatar/utils/index.js +21 -0
  9. package/cjs/components/Avatar/utils/index.js.map +1 -0
  10. package/cjs/components/Combobox/ComboboxOld/Combobox.css +6 -6
  11. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxDivider/ComboboxDivider.css +6 -6
  12. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxFooter/ComboboxFooter.css +6 -6
  13. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxGroup/ComboboxGroup.css +6 -6
  14. package/cjs/components/Combobox/ComboboxOld/ui/ComboboxHeader/ComboboxHeader.css +6 -6
  15. package/cjs/components/Dropdown/Dropdown.css +6 -6
  16. package/cjs/components/Dropdown/Dropdown.tokens.js +0 -1
  17. package/cjs/components/Dropdown/Dropdown.tokens.js.map +1 -1
  18. package/cjs/components/Dropdown/ui/DropdownInner/DropdownInner.css +6 -6
  19. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.css +6 -6
  20. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js +3 -3
  21. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js.map +1 -1
  22. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.styles_z6xd28.css +7 -0
  23. package/cjs/index.css +14 -11
  24. package/emotion/cjs/components/Avatar/Avatar.js +40 -4
  25. package/emotion/cjs/components/Avatar/Avatar.styles.js +29 -10
  26. package/emotion/cjs/components/Avatar/Avatar.template-doc.mdx +54 -0
  27. package/emotion/cjs/components/Avatar/Avatar.tokens.js +41 -2
  28. package/emotion/cjs/components/Avatar/utils/index.js +15 -1
  29. package/emotion/cjs/components/Dropdown/Dropdown.tokens.js +0 -1
  30. package/emotion/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js +8 -8
  31. package/emotion/cjs/examples/plasma_b2c/components/Avatar/Avatar.config.js +25 -7
  32. package/emotion/cjs/examples/plasma_b2c/components/Avatar/Avatar.stories.tsx +134 -1
  33. package/emotion/cjs/examples/plasma_web/components/Avatar/Avatar.config.js +25 -7
  34. package/emotion/cjs/examples/plasma_web/components/Avatar/Avatar.stories.tsx +134 -1
  35. package/emotion/es/components/Avatar/Avatar.js +42 -6
  36. package/emotion/es/components/Avatar/Avatar.styles.js +29 -10
  37. package/emotion/es/components/Avatar/Avatar.template-doc.mdx +54 -0
  38. package/emotion/es/components/Avatar/Avatar.tokens.js +41 -2
  39. package/emotion/es/components/Avatar/utils/index.js +14 -1
  40. package/emotion/es/components/Dropdown/Dropdown.tokens.js +0 -1
  41. package/emotion/es/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js +8 -8
  42. package/emotion/es/examples/plasma_b2c/components/Avatar/Avatar.config.js +25 -7
  43. package/emotion/es/examples/plasma_b2c/components/Avatar/Avatar.stories.tsx +134 -1
  44. package/emotion/es/examples/plasma_web/components/Avatar/Avatar.config.js +25 -7
  45. package/emotion/es/examples/plasma_web/components/Avatar/Avatar.stories.tsx +134 -1
  46. package/es/components/Avatar/Avatar.js +41 -4
  47. package/es/components/Avatar/Avatar.js.map +1 -1
  48. package/es/components/Avatar/Avatar.styles.js +30 -2
  49. package/es/components/Avatar/Avatar.styles.js.map +1 -1
  50. package/es/components/Avatar/Avatar.styles_131qvfx.css +8 -0
  51. package/es/components/Avatar/Avatar.tokens.js +41 -2
  52. package/es/components/Avatar/Avatar.tokens.js.map +1 -1
  53. package/es/components/Avatar/utils/index.js +17 -0
  54. package/es/components/Avatar/utils/index.js.map +1 -0
  55. package/es/components/Combobox/ComboboxOld/Combobox.css +6 -6
  56. package/es/components/Combobox/ComboboxOld/ui/ComboboxDivider/ComboboxDivider.css +6 -6
  57. package/es/components/Combobox/ComboboxOld/ui/ComboboxFooter/ComboboxFooter.css +6 -6
  58. package/es/components/Combobox/ComboboxOld/ui/ComboboxGroup/ComboboxGroup.css +6 -6
  59. package/es/components/Combobox/ComboboxOld/ui/ComboboxHeader/ComboboxHeader.css +6 -6
  60. package/es/components/Dropdown/Dropdown.css +6 -6
  61. package/es/components/Dropdown/Dropdown.tokens.js +0 -1
  62. package/es/components/Dropdown/Dropdown.tokens.js.map +1 -1
  63. package/es/components/Dropdown/ui/DropdownInner/DropdownInner.css +6 -6
  64. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.css +6 -6
  65. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js +3 -3
  66. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js.map +1 -1
  67. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.styles_z6xd28.css +7 -0
  68. package/es/index.css +14 -11
  69. package/package.json +5 -22
  70. package/styled-components/cjs/components/Avatar/Avatar.js +39 -3
  71. package/styled-components/cjs/components/Avatar/Avatar.styles.js +18 -2
  72. package/styled-components/cjs/components/Avatar/Avatar.template-doc.mdx +54 -0
  73. package/styled-components/cjs/components/Avatar/Avatar.tokens.js +41 -2
  74. package/styled-components/cjs/components/Avatar/utils/index.js +15 -1
  75. package/styled-components/cjs/components/Dropdown/Dropdown.tokens.js +0 -1
  76. package/styled-components/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js +2 -2
  77. package/styled-components/cjs/examples/plasma_b2c/components/Avatar/Avatar.config.js +22 -4
  78. package/styled-components/cjs/examples/plasma_b2c/components/Avatar/Avatar.stories.tsx +134 -1
  79. package/styled-components/cjs/examples/plasma_web/components/Avatar/Avatar.config.js +22 -4
  80. package/styled-components/cjs/examples/plasma_web/components/Avatar/Avatar.stories.tsx +134 -1
  81. package/styled-components/es/components/Avatar/Avatar.js +41 -5
  82. package/styled-components/es/components/Avatar/Avatar.styles.js +18 -2
  83. package/styled-components/es/components/Avatar/Avatar.template-doc.mdx +54 -0
  84. package/styled-components/es/components/Avatar/Avatar.tokens.js +41 -2
  85. package/styled-components/es/components/Avatar/utils/index.js +14 -1
  86. package/styled-components/es/components/Dropdown/Dropdown.tokens.js +0 -1
  87. package/styled-components/es/components/Dropdown/ui/DropdownItem/DropdownItem.styles.js +2 -2
  88. package/styled-components/es/examples/plasma_b2c/components/Avatar/Avatar.config.js +22 -4
  89. package/styled-components/es/examples/plasma_b2c/components/Avatar/Avatar.stories.tsx +134 -1
  90. package/styled-components/es/examples/plasma_web/components/Avatar/Avatar.config.js +22 -4
  91. package/styled-components/es/examples/plasma_web/components/Avatar/Avatar.stories.tsx +134 -1
  92. package/types/components/Avatar/Avatar.d.ts +3 -21
  93. package/types/components/Avatar/Avatar.d.ts.map +1 -1
  94. package/types/components/Avatar/Avatar.styles.d.ts +59 -0
  95. package/types/components/Avatar/Avatar.styles.d.ts.map +1 -1
  96. package/types/components/Avatar/Avatar.tokens.d.ts +37 -0
  97. package/types/components/Avatar/Avatar.tokens.d.ts.map +1 -1
  98. package/types/components/Avatar/Avatar.types.d.ts +47 -2
  99. package/types/components/Avatar/Avatar.types.d.ts.map +1 -1
  100. package/types/components/Avatar/utils/index.d.ts +1 -0
  101. package/types/components/Avatar/utils/index.d.ts.map +1 -1
  102. package/types/components/Badge/Badge.types.d.ts +8 -21
  103. package/types/components/Badge/Badge.types.d.ts.map +1 -1
  104. package/types/components/Counter/Counter.d.ts +2 -12
  105. package/types/components/Counter/Counter.d.ts.map +1 -1
  106. package/types/components/Counter/Counter.types.d.ts +1 -2
  107. package/types/components/Counter/Counter.types.d.ts.map +1 -1
  108. package/types/components/Dropdown/Dropdown.tokens.d.ts +0 -1
  109. package/types/components/Dropdown/Dropdown.tokens.d.ts.map +1 -1
  110. package/types/examples/plasma_b2c/components/Avatar/Avatar.config.d.ts +18 -0
  111. package/types/examples/plasma_b2c/components/Avatar/Avatar.config.d.ts.map +1 -1
  112. package/types/examples/plasma_b2c/components/Avatar/Avatar.d.ts +138 -6
  113. package/types/examples/plasma_b2c/components/Avatar/Avatar.d.ts.map +1 -1
  114. package/types/examples/plasma_b2c/components/Badge/Badge.d.ts +8 -48
  115. package/types/examples/plasma_b2c/components/Badge/Badge.d.ts.map +1 -1
  116. package/types/examples/plasma_b2c/components/Counter/Counter.d.ts +1 -6
  117. package/types/examples/plasma_b2c/components/Counter/Counter.d.ts.map +1 -1
  118. package/types/examples/plasma_web/components/Avatar/Avatar.config.d.ts +18 -0
  119. package/types/examples/plasma_web/components/Avatar/Avatar.config.d.ts.map +1 -1
  120. package/types/examples/plasma_web/components/Avatar/Avatar.d.ts +138 -6
  121. package/types/examples/plasma_web/components/Avatar/Avatar.d.ts.map +1 -1
  122. package/types/examples/plasma_web/components/Badge/Badge.d.ts +8 -48
  123. package/types/examples/plasma_web/components/Badge/Badge.d.ts.map +1 -1
  124. package/types/examples/plasma_web/components/Counter/Counter.d.ts +1 -6
  125. package/types/examples/plasma_web/components/Counter/Counter.d.ts.map +1 -1
  126. package/cjs/components/Avatar/Avatar.styles_1gd252x.css +0 -5
  127. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.styles_vp2tis.css +0 -7
  128. package/es/components/Avatar/Avatar.styles_1gd252x.css +0 -5
  129. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.styles_vp2tis.css +0 -7
@@ -4,13 +4,20 @@ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" ==
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
- exports.base = exports.Wrapper = exports.Text = exports.StatusIcon = exports.Image = void 0;
7
+ exports.base = exports.Wrapper = exports.Text = exports.StatusIcon = exports.Image = exports.ExtraCounter = exports.ExtraContent = exports.ExtraBadge = void 0;
8
8
  var _styledComponents = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("styled-components"));
9
+ var _engines = /*#__PURE__*/require("../../engines");
10
+ var _Badge = /*#__PURE__*/require("../Badge");
11
+ var _Counter = /*#__PURE__*/require("../Counter");
9
12
  var _Avatar = /*#__PURE__*/require("./Avatar.tokens");
10
13
  var _templateObject;
11
14
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
12
15
  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 && {}.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; }
13
16
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
17
+ var mergedBadgeConfig = /*#__PURE__*/(0, _engines.mergeConfig)(_Badge.badgeConfig);
18
+ var Badge = /*#__PURE__*/(0, _engines.component)(mergedBadgeConfig);
19
+ var mergedCounterConfig = /*#__PURE__*/(0, _engines.mergeConfig)(_Counter.counterConfig);
20
+ var Counter = /*#__PURE__*/(0, _engines.component)(mergedCounterConfig);
14
21
  var base = exports.base = /*#__PURE__*/(0, _styledComponents.css)(_templateObject || (_templateObject = /*#__PURE__*/_taggedTemplateLiteral(["\n position: relative;\n"])));
15
22
  var Wrapper = exports.Wrapper = /*#__PURE__*/_styledComponents["default"].div.withConfig({
16
23
  componentId: "plasma-new-hope__sc-t16ccn-0"
@@ -29,4 +36,13 @@ var Image = exports.Image = /*#__PURE__*/_styledComponents["default"].img.withCo
29
36
  })(["width:100%;height:100%;border-radius:50%;"]);
30
37
  var Text = exports.Text = /*#__PURE__*/_styledComponents["default"].span.withConfig({
31
38
  componentId: "plasma-new-hope__sc-t16ccn-3"
32
- })(["font-size:var(", ");font-family:var(", ");font-weight:var(", ");line-height:var(", ");background-image:var(", ");background-color:var(", ");background-size:100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;"], _Avatar.tokens.fontSize, _Avatar.tokens.fontFamily, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.color, _Avatar.tokens.color);
39
+ })(["font-size:var(", ");font-family:var(", ");font-weight:var(", ");line-height:var(", ");background-image:var(", ");background-color:var(", ");background-size:100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;"], _Avatar.tokens.fontSize, _Avatar.tokens.fontFamily, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.color, _Avatar.tokens.color);
40
+ var ExtraContent = exports.ExtraContent = /*#__PURE__*/_styledComponents["default"].div.withConfig({
41
+ componentId: "plasma-new-hope__sc-t16ccn-4"
42
+ })(["max-width:100%;display:flex;position:absolute;z-index:2;&.", "{top:calc(-0.063rem * var(", ",0));left:calc(-0.063rem * var(", ",0));}&.", "{top:calc(-0.063rem * var(", ",0));right:calc(-0.063rem * var(", ",0));}&.", "{bottom:calc(-0.063rem * var(", ",0));right:calc(-0.063rem * var(", ",0));}&.", "{bottom:calc(-0.063rem * var(", ",0));left:calc(-0.063rem * var(", ",0));}"], _Avatar.classes.extraPlacementTopLeft, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.extraPlacementFactor, _Avatar.classes.extraPlacementTopRight, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.extraPlacementFactor, _Avatar.classes.extraPlacementBottomRight, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.extraPlacementFactor, _Avatar.classes.extraPlacementBottomLeft, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.extraPlacementFactor);
43
+ var ExtraBadge = exports.ExtraBadge = /*#__PURE__*/(0, _styledComponents["default"])(Badge).withConfig({
44
+ componentId: "plasma-new-hope__sc-t16ccn-5"
45
+ })(["", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");"], _Badge.badgeTokens.background, _Avatar.tokens.badgeBackground, _Badge.badgeTokens.color, _Avatar.tokens.badgeColor, _Badge.badgeTokens.backgroundTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Badge.badgeTokens.colorTransparent, _Avatar.tokens.badgeColorTransparent, _Badge.badgeTokens.colorClear, _Avatar.tokens.badgeColorClear, _Badge.badgeTokens.backgroundClear, _Avatar.tokens.badgeBackgroundClear, _Badge.badgeTokens.borderRadius, _Avatar.tokens.badgeBorderRadius, _Badge.badgeTokens.pilledBorderRadius, _Avatar.tokens.badgePilledBorderRadius, _Badge.badgeTokens.height, _Avatar.tokens.badgeHeight, _Badge.badgeTokens.padding, _Avatar.tokens.badgePadding, _Badge.badgeTokens.paddingIconOnly, _Avatar.tokens.badgePaddingIconOnly, _Badge.badgeTokens.fontFamily, _Avatar.tokens.badgeFontFamily, _Badge.badgeTokens.fontSize, _Avatar.tokens.badgeFontSize, _Badge.badgeTokens.fontStyle, _Avatar.tokens.badgeFontStyle, _Badge.badgeTokens.fontWeight, _Avatar.tokens.badgeFontWeight, _Badge.badgeTokens.letterSpacing, _Avatar.tokens.badgeLetterSpacing, _Badge.badgeTokens.lineHeight, _Avatar.tokens.badgeLineHeight, _Badge.badgeTokens.leftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginLeft, _Badge.badgeTokens.leftContentMarginRight, _Avatar.tokens.badgeLeftContentMarginRight, _Badge.badgeTokens.rightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginLeft, _Badge.badgeTokens.rightContentMarginRight, _Avatar.tokens.badgeRightContentMarginRight);
46
+ var ExtraCounter = exports.ExtraCounter = /*#__PURE__*/(0, _styledComponents["default"])(Counter).withConfig({
47
+ componentId: "plasma-new-hope__sc-t16ccn-6"
48
+ })(["", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");", ":var(", ");"], _Counter.counterTokens.background, _Avatar.tokens.counterBackground, _Counter.counterTokens.color, _Avatar.tokens.counterColor, _Counter.counterTokens.borderRadius, _Avatar.tokens.counterBorderRadius, _Counter.counterTokens.height, _Avatar.tokens.counterHeight, _Counter.counterTokens.padding, _Avatar.tokens.counterPadding, _Counter.counterTokens.fontFamily, _Avatar.tokens.counterFontFamily, _Counter.counterTokens.fontSize, _Avatar.tokens.counterFontSize, _Counter.counterTokens.fontStyle, _Avatar.tokens.counterFontStyle, _Counter.counterTokens.fontWeight, _Avatar.tokens.counterFontWeight, _Counter.counterTokens.letterSpacing, _Avatar.tokens.counterLetterSpacing, _Counter.counterTokens.lineHeight, _Avatar.tokens.counterLineHeight);
@@ -147,3 +147,57 @@ export function App() {
147
147
  Опциональное свойство для корректной озвучки значений свойства `status`.
148
148
 
149
149
  По-умолчанию стоит значение для русскоговорящих `{ active: 'Активен', inactive: 'Неактивен' }`.
150
+
151
+ #### Avatar и дополнительный контент
152
+
153
+ Чтобы отобразить дополнительный контент нужно передать свойство `hasExtra`.
154
+ Тип дополнительного контента задается с помощью свойства `type`, а его вид с помощью `badgeView` и `counterView` соответственно.
155
+ За положение дополнительного контента отвечает `extraPlacement`:
156
+
157
+ ```tsx live
158
+ import React from 'react';
159
+ import { Avatar } from '@salutejs/{{ package }}';
160
+
161
+ export function App() {
162
+ return (
163
+ <>
164
+ <Avatar
165
+ size="l"
166
+ name="Иван Фадеев"
167
+ extraPlacement="top-left"
168
+ type="counter"
169
+ count={33}
170
+ counterView="positive"
171
+ hasExtra
172
+ />
173
+ <Avatar
174
+ size="l"
175
+ name="Иван Фадеев"
176
+ extraPlacement="top-right"
177
+ type="counter"
178
+ count={33}
179
+ counterView="accent"
180
+ hasExtra
181
+ />
182
+ <Avatar
183
+ size="l"
184
+ name="Иван Фадеев"
185
+ extraPlacement="bottom-right"
186
+ type="badge"
187
+ text="15"
188
+ badgeView="warning"
189
+ hasExtra
190
+ />
191
+ <Avatar
192
+ size="l"
193
+ name="Иван Фадеев"
194
+ extraPlacement="bottom-left"
195
+ type="badge"
196
+ text="15"
197
+ badgeView="negative"
198
+ hasExtra
199
+ />
200
+ </>
201
+ );
202
+ }
203
+ ```
@@ -5,7 +5,11 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.tokens = exports.classes = void 0;
7
7
  var classes = exports.classes = {
8
- avatarItem: 'avatar-item'
8
+ avatarItem: 'avatar-item',
9
+ extraPlacementTopRight: 'avatar-extra-placement-top-right',
10
+ extraPlacementTopLeft: 'avatar-extra-placement-top-left',
11
+ extraPlacementBottomLeft: 'avatar-extra-placement-bottom-left',
12
+ extraPlacementBottomRight: 'avatar-extra-placement-bottom-right'
9
13
  };
10
14
  var tokens = exports.tokens = {
11
15
  avatarSize: '--plasma-avatar-size',
@@ -21,5 +25,40 @@ var tokens = exports.tokens = {
21
25
  outlineColor: '--plasma-avatar-outline-color',
22
26
  outlineSize: '--plasma-avatar-outline-size',
23
27
  outlineOffset: '--plasma-avatar-outline-offset',
24
- scaleHover: '--plasma-avatar-scale-hover'
28
+ scaleHover: '--plasma-avatar-scale-hover',
29
+ extraPlacementFactor: '--plasma-avatar-extra-placement-factor',
30
+ // extra badge tokens
31
+ badgeBackground: '--plasma-avatar-extra-badge-background',
32
+ badgeColor: '--plasma-avatar-extra-badge-color',
33
+ badgeBackgroundTransparent: '--plasma-avatar-extra-badge-background-transparent',
34
+ badgeColorTransparent: '--plasma-avatar-extra-badge-color-transparent',
35
+ badgeColorClear: '--plasma-avatar-extra-badge-color-clear',
36
+ badgeBackgroundClear: '--plasma-avatar-extra-badge-background-clear',
37
+ badgeBorderRadius: '--plasma-avatar-extra-badge-border-radius',
38
+ badgePilledBorderRadius: '--plasma-avatar-extra-badge-pilled-border-radius',
39
+ badgeHeight: '--plasma-avatar-extra-badge-height',
40
+ badgePadding: '--plasma-avatar-extra-badge-padding',
41
+ badgePaddingIconOnly: '--plasma-avatar-extra-badge-padding-icon-only',
42
+ badgeFontFamily: '--plasma-avatar-extra-badge-font-family',
43
+ badgeFontSize: '--plasma-avatar-extra-badge-font-size',
44
+ badgeFontStyle: '--plasma-avatar-extra-badge-font-style',
45
+ badgeFontWeight: '--plasma-avatar-extra-badge-font-weight',
46
+ badgeLetterSpacing: '--plasma-avatar-extra-badge-letter-spacing',
47
+ badgeLineHeight: '--plasma-avatar-extra-badge-lineheight',
48
+ badgeLeftContentMarginLeft: '--plasma-avatar-extra-badge-left-content-margin-left',
49
+ badgeLeftContentMarginRight: '--plasma-avatar-extra-badge-left-content-margin-right',
50
+ badgeRightContentMarginLeft: '--plasma-avatar-extra-badge-right-content-margin-left',
51
+ badgeRightContentMarginRight: '--plasma-avatar-extra-badge-right-content-margin-right',
52
+ // extra counter tokens
53
+ counterBackground: '--plasma-avatar-extra-counter-background',
54
+ counterColor: '--plasma-avatar-extra-counter-color',
55
+ counterBorderRadius: '--plasma-avatar-extra-counter-border-radius',
56
+ counterHeight: '--plasma-avatar-extra-counter-height',
57
+ counterPadding: '--plasma-avatar-extra-counter-padding',
58
+ counterFontFamily: '--plasma-avatar-extra-counter-font-family',
59
+ counterFontSize: '--plasma-avatar-extra-counter-font-size',
60
+ counterFontStyle: '--plasma-avatar-extra-counter-font-style',
61
+ counterFontWeight: '--plasma-avatar-extra-counter-font-weight',
62
+ counterLetterSpacing: '--plasma-avatar-extra-counter-letter-spacing',
63
+ counterLineHeight: '--plasma-avatar-extra-counter-lineheight'
25
64
  };
@@ -3,10 +3,24 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ exports.extraPlacementMap = void 0;
6
7
  Object.defineProperty(exports, "getInitialsForName", {
7
8
  enumerable: true,
8
9
  get: function get() {
9
10
  return _getInitialsForName.getInitialsForName;
10
11
  }
11
12
  });
12
- var _getInitialsForName = /*#__PURE__*/require("./getInitialsForName");
13
+ var _Avatar = /*#__PURE__*/require("../Avatar.tokens");
14
+ var _getInitialsForName = /*#__PURE__*/require("./getInitialsForName");
15
+ var extraPlacementMap = exports.extraPlacementMap = function extraPlacementMap(extraPlacement) {
16
+ switch (extraPlacement) {
17
+ case 'top-left':
18
+ return _Avatar.classes.extraPlacementTopLeft;
19
+ case 'bottom-left':
20
+ return _Avatar.classes.extraPlacementBottomLeft;
21
+ case 'bottom-right':
22
+ return _Avatar.classes.extraPlacementBottomRight;
23
+ default:
24
+ return _Avatar.classes.extraPlacementTopRight;
25
+ }
26
+ };
@@ -82,7 +82,6 @@ var tokens = exports.tokens = {
82
82
  itemFontWeightBold: '--plasma-dropdown-item-letter-spacing',
83
83
  itemFontLetterSpacing: '--plasma-dropdown-item-line-height',
84
84
  itemFontLineHeight: '--plasma-dropdown-item-font-weight',
85
- itemMargin: '--plasma-dropdown-item-margin',
86
85
  itemPadding: '--plasma-dropdown-item-padding',
87
86
  itemPaddingTight: '--plasma-dropdown-item-padding-tight',
88
87
  itemGap: '--plasma-dropdown-item-gap',
@@ -51,10 +51,10 @@ var Divider = exports.Divider = /*#__PURE__*/_styledComponents["default"].div.wi
51
51
  }, _Dropdown.tokens.dividerMarginLeft, _Dropdown.tokens.dividerColor);
52
52
  var Wrapper = exports.Wrapper = /*#__PURE__*/_styledComponents["default"].li.withConfig({
53
53
  componentId: "plasma-new-hope__sc-hs0ek1-5"
54
- })(["display:flex;align-items:center;gap:", ";min-height:var(", ");margin:var(", ",0 calc(0.125rem + var(", ",0rem)));box-sizing:content-box;padding:", ";font-family:var(", ");font-size:var(", ");font-style:var(", ");font-weight:var(", ");letter-spacing:var(", ");line-height:var(", ");background-color:var(", ");border-radius:calc(var(", ") - 0.125rem - var(", ",0rem));user-select:none;background-clip:padding-box;&:hover:not(.", "){cursor:pointer;background-color:var(", ");}&.", "{background-color:var(", ");}&.", "{opacity:", ";cursor:not-allowed;}:focus{outline:none;}", ";"], function (_ref5) {
54
+ })(["display:flex;align-items:center;gap:", ";min-height:var(", ");margin:0 calc(0.125rem + var(", ",0rem));box-sizing:content-box;padding:", ";font-family:var(", ");font-size:var(", ");font-style:var(", ");font-weight:var(", ");letter-spacing:var(", ");line-height:var(", ");background-color:var(", ");border-radius:calc(var(", ") - 0.125rem - var(", ",0rem));user-select:none;background-clip:padding-box;&:hover:not(.", "){cursor:pointer;background-color:var(", ");}&.", "{background-color:var(", ");}&.", "{opacity:", ";cursor:not-allowed;}:focus{outline:none;}", ";"], function (_ref5) {
55
55
  var variant = _ref5.variant;
56
56
  return "var(".concat(variant === 'tight' ? _Dropdown.tokens.itemGapTight : _Dropdown.tokens.itemGap, ")");
57
- }, _Dropdown.tokens.itemHeight, _Dropdown.tokens.itemMargin, _Dropdown.tokens.borderWidth, function (_ref6) {
57
+ }, _Dropdown.tokens.itemHeight, _Dropdown.tokens.borderWidth, function (_ref6) {
58
58
  var variant = _ref6.variant;
59
59
  return "var(".concat(variant === 'tight' ? _Dropdown.tokens.itemPaddingTight : _Dropdown.tokens.itemPadding, ")");
60
60
  }, _Dropdown.tokens.itemFontFamily, _Dropdown.tokens.itemFontSize, _Dropdown.tokens.itemFontStyle, _Dropdown.tokens.itemFontWeightBold, _Dropdown.tokens.itemFontLetterSpacing, _Dropdown.tokens.itemFontLineHeight, _Dropdown.constants.itemBackground, _Dropdown.tokens.borderRadius, _Dropdown.tokens.borderWidth, _Dropdown.classes.dropdownItemIsDisabled, _Dropdown.tokens.itemBackgroundHover, _Dropdown.classes.dropdownItemIsActive, _Dropdown.tokens.itemBackgroundHover, _Dropdown.classes.dropdownItemIsDisabled, _Dropdown.constants.opacity, /*#__PURE__*/(0, _mixins.addFocus)({
@@ -16,14 +16,32 @@ var config = exports.config = {
16
16
  "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--text-accent-gradient);", ":linear-gradient(94deg,rgba(62,121,240,0.2) 6.49%,rgba(39,198,229,0.2) 93.51%);", ":var(--surface-positive);", ":var(--surface-solid-tertiary);", ":1.02;"], _Avatar.tokens.color, _Avatar.tokens.backgroundColor, _Avatar.tokens.statusOnlineColor, _Avatar.tokens.statusOfflineColor, _Avatar.tokens.scaleHover)
17
17
  },
18
18
  size: {
19
- xxl: /*#__PURE__*/(0, _styledComponents.css)(["", ":6.25rem;", ":2rem;", ":600;", ":2rem;", ":0.75rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
20
- l: /*#__PURE__*/(0, _styledComponents.css)(["", ":3rem;", ":1.25rem;", ":600;", ":1.25rem;", ":0.5rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
21
- m: /*#__PURE__*/(0, _styledComponents.css)(["", ":2.25rem;", ":0.875rem;", ":600;", ":0.875rem;", ":0.5rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
22
- s: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.5rem;", ":600;", ":0.5rem;", ":0.375rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
19
+ xxl: /*#__PURE__*/(0, _styledComponents.css)(["", ":6.25rem;", ":2rem;", ":600;", ":2rem;", ":0.75rem;", ":0.5rem;", ":1.75rem;", ":0 0.6875rem;", ":0 0.375rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":-0.0625rem;", ":0.25rem;", ":0.25rem;", ":-0.0625rem;", ":1.25rem;", ":1rem;", ":1.75rem;", ":0 0.625rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.badgeBorderRadius, _Avatar.tokens.badgeHeight, _Avatar.tokens.badgePadding, _Avatar.tokens.badgePaddingIconOnly, _Avatar.tokens.badgeFontFamily, _Avatar.tokens.badgeFontSize, _Avatar.tokens.badgeFontStyle, _Avatar.tokens.badgeFontWeight, _Avatar.tokens.badgeLetterSpacing, _Avatar.tokens.badgeLineHeight, _Avatar.tokens.badgeLeftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginRight, _Avatar.tokens.badgeRightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginRight, _Avatar.tokens.badgePilledBorderRadius, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
20
+ l: /*#__PURE__*/(0, _styledComponents.css)(["", ":3rem;", ":1.25rem;", ":600;", ":1.25rem;", ":0.5rem;", ":2;", ":0.375rem;", ":1.25rem;", ":0 0.4375rem;", ":0 0.25rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);", ":-0.0625rem;", ":0.125rem;", ":0.125rem;", ":-0.0625rem;", ":1.25rem;", ":1rem;", ":1.25rem;", ":0 0.375rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.badgeBorderRadius, _Avatar.tokens.badgeHeight, _Avatar.tokens.badgePadding, _Avatar.tokens.badgePaddingIconOnly, _Avatar.tokens.badgeFontFamily, _Avatar.tokens.badgeFontSize, _Avatar.tokens.badgeFontStyle, _Avatar.tokens.badgeFontWeight, _Avatar.tokens.badgeLetterSpacing, _Avatar.tokens.badgeLineHeight, _Avatar.tokens.badgeLeftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginRight, _Avatar.tokens.badgeRightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginRight, _Avatar.tokens.badgePilledBorderRadius, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
21
+ m: /*#__PURE__*/(0, _styledComponents.css)(["", ":2.25rem;", ":0.875rem;", ":600;", ":0.875rem;", ":0.5rem;", ":2;", ":0.25rem;", ":1rem;", ":0 0.25rem;", ":0 0.188rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);", ":-0.0625rem;", ":0.125rem;", ":0.125rem;", ":-0.0625rem;", ":1.25rem;", ":1rem;", ":1rem;", ":0 0.25rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.badgeBorderRadius, _Avatar.tokens.badgeHeight, _Avatar.tokens.badgePadding, _Avatar.tokens.badgePaddingIconOnly, _Avatar.tokens.badgeFontFamily, _Avatar.tokens.badgeFontSize, _Avatar.tokens.badgeFontStyle, _Avatar.tokens.badgeFontWeight, _Avatar.tokens.badgeLetterSpacing, _Avatar.tokens.badgeLineHeight, _Avatar.tokens.badgeLeftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginRight, _Avatar.tokens.badgeRightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginRight, _Avatar.tokens.badgePilledBorderRadius, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
22
+ s: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.5rem;", ":600;", ":0.5rem;", ":0.375rem;", ":1;", ":1rem;", ":0.75rem;", ":0 0.125rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
23
23
  fit: /*#__PURE__*/(0, _styledComponents.css)(["", ":100%;", ":0;", ":0;", ":0;", ":0;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize)
24
24
  },
25
25
  focused: {
26
26
  "true": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.1rem;", ":-0.2rem;", ":var(--surface-accent);"], _Avatar.tokens.outlineSize, _Avatar.tokens.outlineOffset, _Avatar.tokens.outlineColor)
27
+ },
28
+ badgeView: {
29
+ "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--inverse-text-primary);", ":var(--surface-solid-default);", ":var(--text-primary);", ":var(--surface-transparent-secondary);", ":var(--text-primary);", ":var(--surface-clear);"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
30
+ accent: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-accent);", ":var(--text-accent);", ":var(--surface-transparent-accent);", ":var(--text-accent);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
31
+ positive: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-positive);", ":var(--text-positive);", ":var(--surface-transparent-positive);", ":var(--text-positive);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
32
+ warning: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-warning);", ":var(--text-warning);", ":var(--surface-transparent-warning);", ":var(--text-warning);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
33
+ negative: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-negative);", ":var(--text-negative);", ":var(--surface-transparent-negative);", ":var(--text-negative);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
34
+ dark: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--on-light-surface-solid-default);", ":var(--on-dark-text-primary);", ":var(--on-light-surface-transparent-deep);", ":var(--on-light-text-pri ", ":var(--surface-clear)mary);"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
35
+ light: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-light-text-primary);", ":var(--on-dark-surface-solid-default);", ":var(--on-dark-text-primary);", ":var(--on-dark-surface-transparent-card);", ":var(--on-dark-text-prima ", ":var(--surface-clear)ry);"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear)
36
+ },
37
+ counterView: {
38
+ "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--inverse-text-primary);", ":var(--surface-solid-default);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
39
+ accent: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-accent);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
40
+ positive: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-positive);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
41
+ warning: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-warning);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
42
+ negative: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-negative);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
43
+ dark: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--on-light-surface-solid-default);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
44
+ light: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-light-text-primary);", ":var(--on-dark-surface-solid-default);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground)
27
45
  }
28
46
  }
29
47
  };
@@ -1,3 +1,4 @@
1
+ import React from 'react';
1
2
  import type { ComponentProps } from 'react';
2
3
  import type { StoryObj, Meta } from '@storybook/react';
3
4
  import { disableProps } from '@salutejs/plasma-sb-utils';
@@ -6,6 +7,11 @@ import { argTypesFromConfig, WithTheme } from '../../../_helpers';
6
7
 
7
8
  import { Avatar, mergedConfig } from './Avatar';
8
9
 
10
+ const extraPlacements = ['top-left', 'top-right', 'bottom-left', 'bottom-right'];
11
+ const extraType = ['', 'badge', 'counter'];
12
+ const counterViews = ['default', 'accent', 'positive', 'warning', 'negative', 'dark', 'light'];
13
+ const badgeViews = ['default', 'accent', 'positive', 'warning', 'negative', 'dark', 'light'];
14
+
9
15
  const meta: Meta<typeof Avatar> = {
10
16
  title: 'b2c/Data Display/Avatar',
11
17
  decorators: [WithTheme],
@@ -13,12 +19,69 @@ const meta: Meta<typeof Avatar> = {
13
19
  argTypes: {
14
20
  ...argTypesFromConfig(mergedConfig),
15
21
  status: { control: 'select', options: ['active', 'inactive'] },
22
+ type: {
23
+ control: 'select',
24
+ options: extraType,
25
+ if: { arg: 'hasExtra', truthy: true },
26
+ },
27
+ extraPlacement: {
28
+ control: 'select',
29
+ options: extraPlacements,
30
+ if: { arg: 'hasExtra', truthy: true },
31
+ },
32
+ counterView: {
33
+ control: 'select',
34
+ options: counterViews,
35
+ if: { arg: 'type', eq: 'counter' },
36
+ },
37
+ count: {
38
+ control: 'number',
39
+ if: { arg: 'type', eq: 'counter' },
40
+ },
41
+ maxCount: {
42
+ control: 'number',
43
+ if: { arg: 'type', eq: 'counter' },
44
+ },
45
+ badgeView: {
46
+ control: 'select',
47
+ options: badgeViews,
48
+ if: { arg: 'type', eq: 'badge' },
49
+ },
50
+ text: {
51
+ control: 'text',
52
+ if: { arg: 'type', eq: 'badge' },
53
+ },
54
+ customColor: {
55
+ control: 'color',
56
+ if: { arg: 'type', eq: 'badge' },
57
+ },
58
+ customBackgroundColor: {
59
+ control: 'color',
60
+ if: { arg: 'type', eq: 'badge' },
61
+ },
62
+ pilled: {
63
+ control: 'boolean',
64
+ if: { arg: 'type', eq: 'badge' },
65
+ },
16
66
  },
17
67
  };
18
68
 
19
69
  export default meta;
20
70
 
21
- type Story = StoryObj<ComponentProps<typeof Avatar>>;
71
+ type StoryProps = ComponentProps<typeof Avatar> & {
72
+ enableContentLeft: boolean;
73
+ enableContentRight: boolean;
74
+ };
75
+ type Story = StoryObj<StoryProps>;
76
+
77
+ const BellIcon = (props) => (
78
+ <svg width="100%" viewBox="0 0 24 24" fill="none" {...props}>
79
+ <path
80
+ d="M11.501 21.28c1.088 0 1.978-.889 1.978-1.977H9.524c0 1.088.88 1.978 1.977 1.978zm5.933-5.932v-4.944c0-3.035-1.622-5.576-4.45-6.248v-.673c0-.82-.662-1.483-1.483-1.483-.82 0-1.483.662-1.483 1.483v.672c-2.838.673-4.45 3.204-4.45 6.25v4.943l-1.275 1.276c-.623.623-.188 1.69.692 1.69h13.022c.88 0 1.325-1.067.702-1.69l-1.275-1.276z"
81
+ fill="currentColor"
82
+ />
83
+ </svg>
84
+ );
22
85
 
23
86
  export const Default: Story = {
24
87
  args: {
@@ -27,10 +90,56 @@ export const Default: Story = {
27
90
  name: 'Иван Фадеев',
28
91
  url: 'https://avatars.githubusercontent.com/u/1813468?v=4',
29
92
  isScalable: false,
93
+ hasExtra: false,
94
+ extraPlacement: 'top-right',
95
+ type: undefined,
96
+ counterView: 'accent',
97
+ count: 3,
98
+ maxCount: 10,
99
+ badgeView: 'accent',
100
+ text: '31',
101
+ pilled: true,
102
+ enableContentLeft: false,
103
+ enableContentRight: false,
30
104
  },
31
105
  argTypes: {
106
+ enableContentLeft: {
107
+ control: { type: 'boolean' },
108
+ if: { arg: 'type', eq: 'badge' },
109
+ },
110
+ enableContentRight: {
111
+ control: { type: 'boolean' },
112
+ if: { arg: 'type', eq: 'badge' },
113
+ },
32
114
  ...disableProps(['focused']),
33
115
  },
116
+ render: ({ enableContentLeft, enableContentRight, size, ...rest }: StoryProps) => {
117
+ const iconSize = () => {
118
+ switch (size) {
119
+ case 'xxl':
120
+ return '1rem';
121
+ case 'm':
122
+ return '0.625rem';
123
+ default:
124
+ return '0.75rem';
125
+ }
126
+ };
127
+
128
+ return (
129
+ <>
130
+ <Avatar
131
+ contentLeft={enableContentLeft ? <BellIcon width={iconSize()} height={iconSize()} /> : undefined}
132
+ contentRight={
133
+ !enableContentLeft && enableContentRight ? (
134
+ <BellIcon width={iconSize()} height={iconSize()} />
135
+ ) : undefined
136
+ }
137
+ size={size}
138
+ {...rest}
139
+ />
140
+ </>
141
+ );
142
+ },
34
143
  };
35
144
 
36
145
  export const Accessibility: Story = {
@@ -42,6 +151,14 @@ export const Accessibility: Story = {
42
151
  size: 'xxl',
43
152
  status: 'active',
44
153
  focused: true,
154
+ hasExtra: false,
155
+ extraPlacement: 'top-right',
156
+ type: undefined,
157
+ counterView: 'accent',
158
+ count: 3,
159
+ maxCount: 10,
160
+ badgeView: 'accent',
161
+ text: '31',
45
162
  },
46
163
  };
47
164
 
@@ -55,6 +172,14 @@ export const AccessibilityWithURL: Story = {
55
172
  focused: true,
56
173
  name: 'Микула Селянинович',
57
174
  url: 'https://avatars.githubusercontent.com/u/1813468?v=4',
175
+ hasExtra: false,
176
+ extraPlacement: 'top-right',
177
+ type: undefined,
178
+ counterView: 'accent',
179
+ count: 3,
180
+ maxCount: 10,
181
+ badgeView: 'accent',
182
+ text: '31',
58
183
  },
59
184
  };
60
185
 
@@ -67,5 +192,13 @@ export const AccessibilityWithCustomText: Story = {
67
192
  status: 'inactive',
68
193
  focused: true,
69
194
  customText: 'ФИО',
195
+ hasExtra: false,
196
+ extraPlacement: 'top-right',
197
+ type: undefined,
198
+ counterView: 'accent',
199
+ count: 3,
200
+ maxCount: 10,
201
+ badgeView: 'accent',
202
+ text: '31',
70
203
  },
71
204
  };
@@ -16,14 +16,32 @@ var config = exports.config = {
16
16
  "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--text-accent-gradient);", ":linear-gradient(94deg,rgba(62,121,240,0.2) 6.49%,rgba(39,198,229,0.2) 93.51%);", ":var(--surface-positive);", ":var(--surface-solid-tertiary);", ":1.02;"], _Avatar.tokens.color, _Avatar.tokens.backgroundColor, _Avatar.tokens.statusOnlineColor, _Avatar.tokens.statusOfflineColor, _Avatar.tokens.scaleHover)
17
17
  },
18
18
  size: {
19
- xxl: /*#__PURE__*/(0, _styledComponents.css)(["", ":6.25rem;", ":2rem;", ":600;", ":2rem;", ":0.75rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
20
- l: /*#__PURE__*/(0, _styledComponents.css)(["", ":3rem;", ":1.25rem;", ":600;", ":1.25rem;", ":0.5rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
21
- m: /*#__PURE__*/(0, _styledComponents.css)(["", ":2.25rem;", ":0.875rem;", ":600;", ":0.875rem;", ":0.5rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
22
- s: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.5rem;", ":600;", ":0.5rem;", ":0.375rem;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize),
19
+ xxl: /*#__PURE__*/(0, _styledComponents.css)(["", ":6.25rem;", ":2rem;", ":600;", ":2rem;", ":0.75rem;", ":0.5rem;", ":1.75rem;", ":0 0.6875rem;", ":0 0.375rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":-0.0625rem;", ":0.25rem;", ":0.25rem;", ":-0.0625rem;", ":1.25rem;", ":1rem;", ":1.75rem;", ":0 0.625rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.badgeBorderRadius, _Avatar.tokens.badgeHeight, _Avatar.tokens.badgePadding, _Avatar.tokens.badgePaddingIconOnly, _Avatar.tokens.badgeFontFamily, _Avatar.tokens.badgeFontSize, _Avatar.tokens.badgeFontStyle, _Avatar.tokens.badgeFontWeight, _Avatar.tokens.badgeLetterSpacing, _Avatar.tokens.badgeLineHeight, _Avatar.tokens.badgeLeftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginRight, _Avatar.tokens.badgeRightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginRight, _Avatar.tokens.badgePilledBorderRadius, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
20
+ l: /*#__PURE__*/(0, _styledComponents.css)(["", ":3rem;", ":1.25rem;", ":600;", ":1.25rem;", ":0.5rem;", ":2;", ":0.375rem;", ":1.25rem;", ":0 0.4375rem;", ":0 0.25rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);", ":-0.0625rem;", ":0.125rem;", ":0.125rem;", ":-0.0625rem;", ":1.25rem;", ":1rem;", ":1.25rem;", ":0 0.375rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.badgeBorderRadius, _Avatar.tokens.badgeHeight, _Avatar.tokens.badgePadding, _Avatar.tokens.badgePaddingIconOnly, _Avatar.tokens.badgeFontFamily, _Avatar.tokens.badgeFontSize, _Avatar.tokens.badgeFontStyle, _Avatar.tokens.badgeFontWeight, _Avatar.tokens.badgeLetterSpacing, _Avatar.tokens.badgeLineHeight, _Avatar.tokens.badgeLeftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginRight, _Avatar.tokens.badgeRightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginRight, _Avatar.tokens.badgePilledBorderRadius, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
21
+ m: /*#__PURE__*/(0, _styledComponents.css)(["", ":2.25rem;", ":0.875rem;", ":600;", ":0.875rem;", ":0.5rem;", ":2;", ":0.25rem;", ":1rem;", ":0 0.25rem;", ":0 0.188rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);", ":-0.0625rem;", ":0.125rem;", ":0.125rem;", ":-0.0625rem;", ":1.25rem;", ":1rem;", ":1rem;", ":0 0.25rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.badgeBorderRadius, _Avatar.tokens.badgeHeight, _Avatar.tokens.badgePadding, _Avatar.tokens.badgePaddingIconOnly, _Avatar.tokens.badgeFontFamily, _Avatar.tokens.badgeFontSize, _Avatar.tokens.badgeFontStyle, _Avatar.tokens.badgeFontWeight, _Avatar.tokens.badgeLetterSpacing, _Avatar.tokens.badgeLineHeight, _Avatar.tokens.badgeLeftContentMarginLeft, _Avatar.tokens.badgeLeftContentMarginRight, _Avatar.tokens.badgeRightContentMarginLeft, _Avatar.tokens.badgeRightContentMarginRight, _Avatar.tokens.badgePilledBorderRadius, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
22
+ s: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.5rem;", ":600;", ":0.5rem;", ":0.375rem;", ":1;", ":1rem;", ":0.75rem;", ":0 0.125rem;", ":var(--plasma-typo-body-xxs-font-family);", ":var(--plasma-typo-body-xxs-font-size);", ":var(--plasma-typo-body-xxs-font-style);", ":var(--plasma-typo-body-xxs-font-weight);", ":var(--plasma-typo-body-xxs-letter-spacing);", ":var(--plasma-typo-body-xxs-line-height);"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize, _Avatar.tokens.extraPlacementFactor, _Avatar.tokens.counterBorderRadius, _Avatar.tokens.counterHeight, _Avatar.tokens.counterPadding, _Avatar.tokens.counterFontFamily, _Avatar.tokens.counterFontSize, _Avatar.tokens.counterFontStyle, _Avatar.tokens.counterFontWeight, _Avatar.tokens.counterLetterSpacing, _Avatar.tokens.counterLineHeight),
23
23
  fit: /*#__PURE__*/(0, _styledComponents.css)(["", ":100%;", ":0;", ":0;", ":0;", ":0;"], _Avatar.tokens.avatarSize, _Avatar.tokens.fontSize, _Avatar.tokens.fontWeight, _Avatar.tokens.lineHeight, _Avatar.tokens.statusIconSize)
24
24
  },
25
25
  focused: {
26
26
  "true": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.1rem;", ":-0.2rem;", ":var(--surface-accent);"], _Avatar.tokens.outlineSize, _Avatar.tokens.outlineOffset, _Avatar.tokens.outlineColor)
27
+ },
28
+ badgeView: {
29
+ "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--inverse-text-primary);", ":var(--surface-solid-default);", ":var(--text-primary);", ":var(--surface-transparent-secondary);", ":var(--text-primary);", ":var(--surface-clear);"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
30
+ accent: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-accent);", ":var(--text-accent);", ":var(--surface-transparent-accent);", ":var(--text-accent);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
31
+ positive: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-positive);", ":var(--text-positive);", ":var(--surface-transparent-positive);", ":var(--text-positive);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
32
+ warning: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-warning);", ":var(--text-warning);", ":var(--surface-transparent-warning);", ":var(--text-warning);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
33
+ negative: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-negative);", ":var(--text-negative);", ":var(--surface-transparent-negative);", ":var(--text-negative);", ":var(--surface-clear)"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
34
+ dark: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--on-light-surface-solid-default);", ":var(--on-dark-text-primary);", ":var(--on-light-surface-transparent-deep);", ":var(--on-light-text-pri ", ":var(--surface-clear)mary);"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear),
35
+ light: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-light-text-primary);", ":var(--on-dark-surface-solid-default);", ":var(--on-dark-text-primary);", ":var(--on-dark-surface-transparent-card);", ":var(--on-dark-text-prima ", ":var(--surface-clear)ry);"], _Avatar.tokens.badgeColor, _Avatar.tokens.badgeBackground, _Avatar.tokens.badgeColorTransparent, _Avatar.tokens.badgeBackgroundTransparent, _Avatar.tokens.badgeColorClear, _Avatar.tokens.badgeBackgroundClear)
36
+ },
37
+ counterView: {
38
+ "default": /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--inverse-text-primary);", ":var(--surface-solid-default);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
39
+ accent: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-accent);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
40
+ positive: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-positive);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
41
+ warning: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-warning);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
42
+ negative: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--surface-negative);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
43
+ dark: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-dark-text-primary);", ":var(--on-light-surface-solid-default);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground),
44
+ light: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--on-light-text-primary);", ":var(--on-dark-surface-solid-default);"], _Avatar.tokens.counterColor, _Avatar.tokens.counterBackground)
27
45
  }
28
46
  }
29
47
  };