@ultraviolet/ui 1.65.0 → 1.65.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.
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const TEXT_VARIANT_BY_SIZE = {
4
+ xsmall: "captionSmall",
5
+ small: "bodySmall",
6
+ medium: "headingSmall",
7
+ large: "headingLarge"
8
+ };
9
+ const SIZES = {
10
+ xsmall: 20,
11
+ small: 32,
12
+ medium: 64,
13
+ large: 112
14
+ };
15
+ const ICON_SIZES = {
16
+ xsmall: "small",
17
+ small: "large",
18
+ medium: "xlarge",
19
+ large: "xxlarge"
20
+ };
21
+ const RADIUS_SIZES = {
22
+ xsmall: "default",
23
+ small: "large",
24
+ medium: "xlarge",
25
+ large: "xxlarge"
26
+ };
27
+ const SENTIMENTS = ["primary", "neutral"];
28
+ const DEFAULT_COLORS = ["primary", "secondary"];
29
+ exports.DEFAULT_COLORS = DEFAULT_COLORS;
30
+ exports.ICON_SIZES = ICON_SIZES;
31
+ exports.RADIUS_SIZES = RADIUS_SIZES;
32
+ exports.SENTIMENTS = SENTIMENTS;
33
+ exports.SIZES = SIZES;
34
+ exports.TEXT_VARIANT_BY_SIZE = TEXT_VARIANT_BY_SIZE;
@@ -0,0 +1,34 @@
1
+ const TEXT_VARIANT_BY_SIZE = {
2
+ xsmall: "captionSmall",
3
+ small: "bodySmall",
4
+ medium: "headingSmall",
5
+ large: "headingLarge"
6
+ };
7
+ const SIZES = {
8
+ xsmall: 20,
9
+ small: 32,
10
+ medium: 64,
11
+ large: 112
12
+ };
13
+ const ICON_SIZES = {
14
+ xsmall: "small",
15
+ small: "large",
16
+ medium: "xlarge",
17
+ large: "xxlarge"
18
+ };
19
+ const RADIUS_SIZES = {
20
+ xsmall: "default",
21
+ small: "large",
22
+ medium: "xlarge",
23
+ large: "xxlarge"
24
+ };
25
+ const SENTIMENTS = ["primary", "neutral"];
26
+ const DEFAULT_COLORS = ["primary", "secondary"];
27
+ export {
28
+ DEFAULT_COLORS,
29
+ ICON_SIZES,
30
+ RADIUS_SIZES,
31
+ SENTIMENTS,
32
+ SIZES,
33
+ TEXT_VARIANT_BY_SIZE
34
+ };
@@ -0,0 +1,130 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const react = require("@emotion/react");
6
+ const icons = require("@ultraviolet/icons");
7
+ const index = require("../Text/index.cjs");
8
+ const constants = require("./constants.cjs");
9
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
+ const UploadContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
12
+ shouldForwardProp: (prop) => !["size"].includes(prop),
13
+ target: "e1tvc0xj4"
14
+ } : {
15
+ shouldForwardProp: (prop) => !["size"].includes(prop),
16
+ target: "e1tvc0xj4",
17
+ label: "UploadContainer"
18
+ })("position:absolute;opacity:0;top:0;left:0;bottom:0;right:0;display:flex;justify-content:center;align-items:center;transition:opacity 180ms ease-in-out,background-color 180ms ease-in-out;&[data-shape='circle']{border-radius:", ({
19
+ theme
20
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
21
+ theme,
22
+ size
23
+ }) => theme.radii[constants.RADIUS_SIZES[size]], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAgBgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
24
+ const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
25
+ shouldForwardProp: (prop) => !["image", "size"].includes(prop),
26
+ target: "e1tvc0xj3"
27
+ } : {
28
+ shouldForwardProp: (prop) => !["image", "size"].includes(prop),
29
+ target: "e1tvc0xj3",
30
+ label: "Container"
31
+ })("position:relative;&[data-shape='circle']{border-radius:", ({
32
+ theme
33
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
34
+ theme,
35
+ size
36
+ }) => theme.radii[constants.RADIUS_SIZES[size]], ";}", Object.entries(constants.SIZES).map(([key, size]) => `
37
+ &[data-size="${key}"] {
38
+ width: ${size}px;
39
+ height: ${size}px;
40
+ }
41
+ `).join(""), " ", ({
42
+ theme
43
+ }) => constants.SENTIMENTS.map((sentiment) => `
44
+ &[data-has-background='true'][data-sentiment="${sentiment}"] {
45
+ background-color: ${theme.colors[sentiment].backgroundStrong};
46
+ }
47
+ `).join(""), " ", ({
48
+ image
49
+ }) => image && `
50
+ background-image: url(${image});
51
+ background-size: cover;
52
+ `, " &:hover{", UploadContainer, "{opacity:1;cursor:pointer;background-color:", ({
53
+ theme
54
+ }) => theme.colors.overlay, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAuCgD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
55
+ const ElementContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
56
+ target: "e1tvc0xj2"
57
+ } : {
58
+ target: "e1tvc0xj2",
59
+ label: "ElementContainer"
60
+ })("display:flex;align-items:center;justify-content:center;width:100%;height:100%;&[data-shape='circle']{border-radius:", ({
61
+ theme
62
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
63
+ theme
64
+ }) => theme.radii.xlarge, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAqFmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
65
+ const bordersStyles = ({
66
+ size,
67
+ colors,
68
+ theme,
69
+ shape
70
+ }) => {
71
+ const isHalved = colors.length > 1;
72
+ const finalColors = colors?.map((bgColor) => theme.colors[bgColor]?.backgroundStrong ?? bgColor);
73
+ const finalSize = constants.SIZES[size];
74
+ return /* @__PURE__ */ react.css("border-left:", finalSize / 2, "px solid ", finalColors[0], ";border-top:", finalSize / 2, "px solid ", finalColors[0], ";border-right:", finalSize / 2, "px solid ", isHalved ? finalColors[1] : finalColors[0], ";border-bottom:", finalSize / 2, "px solid ", isHalved ? finalColors[1] : finalColors[0], ";border-radius:", shape === "circle" ? theme.radii.circle : theme.radii[constants.RADIUS_SIZES[size]], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:bordersStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAwHY","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */");
75
+ };
76
+ const StyledColors = /* @__PURE__ */ _styled__default.default("span", process.env.NODE_ENV === "production" ? {
77
+ shouldForwardProp: (prop) => !["size", "colors", "shape"].includes(prop),
78
+ target: "e1tvc0xj1"
79
+ } : {
80
+ shouldForwardProp: (prop) => !["size", "colors", "shape"].includes(prop),
81
+ target: "e1tvc0xj1",
82
+ label: "StyledColors"
83
+ })("align-items:center;display:flex;height:100%;justify-content:center;", bordersStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAqI8D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
84
+ const ProductIconContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
85
+ shouldForwardProp: (prop) => !["size"].includes(prop),
86
+ target: "e1tvc0xj0"
87
+ } : {
88
+ shouldForwardProp: (prop) => !["size"].includes(prop),
89
+ target: "e1tvc0xj0",
90
+ label: "ProductIconContainer"
91
+ })("display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:hidden;&[data-shape='circle']{border-radius:", ({
92
+ theme
93
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
94
+ theme,
95
+ size
96
+ }) => theme.radii[constants.RADIUS_SIZES[size]], ";}", Object.entries(constants.SIZES).map(([key, size]) => `
97
+ &[data-size="${key}"] {
98
+ width: ${size}px;
99
+ height: ${size}px;
100
+
101
+ & > svg {
102
+ width: ${size}px;
103
+ height: ${size}px;
104
+ }
105
+ }
106
+ `).join(""), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AA+IgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
107
+ const AvatarV2 = ({
108
+ shape,
109
+ variant,
110
+ image,
111
+ icon,
112
+ text,
113
+ size = "medium",
114
+ sentiment = "primary",
115
+ colors = constants.DEFAULT_COLORS,
116
+ upload,
117
+ onClick,
118
+ className,
119
+ "data-testid": dataTestId
120
+ }) => /* @__PURE__ */ jsxRuntime.jsxs(Container, { "data-shape": shape, "data-size": size, "data-sentiment": sentiment, "data-upload": upload, "data-has-background": !["user", "image"].includes(variant), image, onClick, role: onClick ? "button" : void 0, size, className, "data-testid": dataTestId, children: [
121
+ upload ? /* @__PURE__ */ jsxRuntime.jsx(UploadContainer, { "data-shape": shape, size, children: /* @__PURE__ */ jsxRuntime.jsx(icons.Icon, { name: "upload", size: "large", sentiment: "neutral", prominence: "stronger" }) }) : null,
122
+ variant === "user" ? /* @__PURE__ */ jsxRuntime.jsx(ProductIconContainer, { "data-shape": shape, "data-size": size, size, children: /* @__PURE__ */ jsxRuntime.jsx(icons.ProductIcon, { name: "user" }) }) : null,
123
+ variant === "icon" ? /* @__PURE__ */ jsxRuntime.jsx(ElementContainer, { "data-shape": shape, children: /* @__PURE__ */ jsxRuntime.jsx(icons.Icon, { name: icon, sentiment: "neutral", size: constants.ICON_SIZES[size], prominence: sentiment === "primary" ? "stronger" : "strong" }) }) : null,
124
+ variant === "text" ? /* @__PURE__ */ jsxRuntime.jsx(ElementContainer, { "data-shape": shape, children: /* @__PURE__ */ jsxRuntime.jsx(index.Text, { as: "span", variant: constants.TEXT_VARIANT_BY_SIZE[size], sentiment: "neutral", prominence: sentiment === "primary" ? "stronger" : "strong", children: text }) }) : null,
125
+ variant === "colors" ? /* @__PURE__ */ jsxRuntime.jsx(StyledColors, { size, colors, shape, style: {
126
+ height: size,
127
+ width: size
128
+ } }) : null
129
+ ] });
130
+ exports.AvatarV2 = AvatarV2;
@@ -0,0 +1,128 @@
1
+ import { jsxs, jsx } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { css } from "@emotion/react";
4
+ import { Icon, ProductIcon } from "@ultraviolet/icons";
5
+ import { Text } from "../Text/index.js";
6
+ import { RADIUS_SIZES, SIZES, SENTIMENTS, ICON_SIZES, TEXT_VARIANT_BY_SIZE, DEFAULT_COLORS } from "./constants.js";
7
+ const UploadContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
8
+ shouldForwardProp: (prop) => !["size"].includes(prop),
9
+ target: "e1tvc0xj4"
10
+ } : {
11
+ shouldForwardProp: (prop) => !["size"].includes(prop),
12
+ target: "e1tvc0xj4",
13
+ label: "UploadContainer"
14
+ })("position:absolute;opacity:0;top:0;left:0;bottom:0;right:0;display:flex;justify-content:center;align-items:center;transition:opacity 180ms ease-in-out,background-color 180ms ease-in-out;&[data-shape='circle']{border-radius:", ({
15
+ theme
16
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
17
+ theme,
18
+ size
19
+ }) => theme.radii[RADIUS_SIZES[size]], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAgBgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
20
+ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
21
+ shouldForwardProp: (prop) => !["image", "size"].includes(prop),
22
+ target: "e1tvc0xj3"
23
+ } : {
24
+ shouldForwardProp: (prop) => !["image", "size"].includes(prop),
25
+ target: "e1tvc0xj3",
26
+ label: "Container"
27
+ })("position:relative;&[data-shape='circle']{border-radius:", ({
28
+ theme
29
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
30
+ theme,
31
+ size
32
+ }) => theme.radii[RADIUS_SIZES[size]], ";}", Object.entries(SIZES).map(([key, size]) => `
33
+ &[data-size="${key}"] {
34
+ width: ${size}px;
35
+ height: ${size}px;
36
+ }
37
+ `).join(""), " ", ({
38
+ theme
39
+ }) => SENTIMENTS.map((sentiment) => `
40
+ &[data-has-background='true'][data-sentiment="${sentiment}"] {
41
+ background-color: ${theme.colors[sentiment].backgroundStrong};
42
+ }
43
+ `).join(""), " ", ({
44
+ image
45
+ }) => image && `
46
+ background-image: url(${image});
47
+ background-size: cover;
48
+ `, " &:hover{", UploadContainer, "{opacity:1;cursor:pointer;background-color:", ({
49
+ theme
50
+ }) => theme.colors.overlay, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAuCgD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
51
+ const ElementContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
52
+ target: "e1tvc0xj2"
53
+ } : {
54
+ target: "e1tvc0xj2",
55
+ label: "ElementContainer"
56
+ })("display:flex;align-items:center;justify-content:center;width:100%;height:100%;&[data-shape='circle']{border-radius:", ({
57
+ theme
58
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
59
+ theme
60
+ }) => theme.radii.xlarge, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAqFmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
61
+ const bordersStyles = ({
62
+ size,
63
+ colors,
64
+ theme,
65
+ shape
66
+ }) => {
67
+ const isHalved = colors.length > 1;
68
+ const finalColors = colors?.map((bgColor) => theme.colors[bgColor]?.backgroundStrong ?? bgColor);
69
+ const finalSize = SIZES[size];
70
+ return /* @__PURE__ */ css("border-left:", finalSize / 2, "px solid ", finalColors[0], ";border-top:", finalSize / 2, "px solid ", finalColors[0], ";border-right:", finalSize / 2, "px solid ", isHalved ? finalColors[1] : finalColors[0], ";border-bottom:", finalSize / 2, "px solid ", isHalved ? finalColors[1] : finalColors[0], ";border-radius:", shape === "circle" ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:bordersStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAwHY","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */");
71
+ };
72
+ const StyledColors = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "production" ? {
73
+ shouldForwardProp: (prop) => !["size", "colors", "shape"].includes(prop),
74
+ target: "e1tvc0xj1"
75
+ } : {
76
+ shouldForwardProp: (prop) => !["size", "colors", "shape"].includes(prop),
77
+ target: "e1tvc0xj1",
78
+ label: "StyledColors"
79
+ })("align-items:center;display:flex;height:100%;justify-content:center;", bordersStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AAqI8D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
80
+ const ProductIconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
81
+ shouldForwardProp: (prop) => !["size"].includes(prop),
82
+ target: "e1tvc0xj0"
83
+ } : {
84
+ shouldForwardProp: (prop) => !["size"].includes(prop),
85
+ target: "e1tvc0xj0",
86
+ label: "ProductIconContainer"
87
+ })("display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:hidden;&[data-shape='circle']{border-radius:", ({
88
+ theme
89
+ }) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
90
+ theme,
91
+ size
92
+ }) => theme.radii[RADIUS_SIZES[size]], ";}", Object.entries(SIZES).map(([key, size]) => `
93
+ &[data-size="${key}"] {
94
+ width: ${size}px;
95
+ height: ${size}px;
96
+
97
+ & > svg {
98
+ width: ${size}px;
99
+ height: ${size}px;
100
+ }
101
+ }
102
+ `).join(""), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx"],"names":[],"mappings":"AA+IgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/AvatarV2/index.tsx","sourcesContent":["import { type Theme, css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, ProductIcon } from '@ultraviolet/icons'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  SIZES,\n  TEXT_VARIANT_BY_SIZE,\n} from './constants'\nimport type { AvatarV2Props, Colors, SentimentColors, Shape } from './types'\n\nconst UploadContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  transition: opacity 180ms ease-in-out, background-color 180ms ease-in-out;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['image', 'size'].includes(prop),\n})<{ image?: string; size: keyof typeof SIZES }>`\n    position: relative;\n    &[data-shape='circle'] {\n      border-radius: ${({ theme }) => theme.radii.circle}\n    }\n\n    &[data-shape='square'] {\n      border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n    }\n\n    ${Object.entries(SIZES)\n      .map(\n        ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size}px;\n            height: ${size}px;\n          }\n    `,\n      )\n      .join('')}\n\n    ${({ theme }) =>\n      SENTIMENTS.map(\n        sentiment => `\n          &[data-has-background='true'][data-sentiment=\"${sentiment}\"] {\n            background-color: ${theme.colors[sentiment].backgroundStrong};\n          }\n      `,\n      ).join('')}\n\n    ${({ image }) =>\n      image &&\n      `\n        background-image: url(${image});\n        background-size: cover;\n    `}\n\n    &:hover {\n      ${UploadContainer} {\n        opacity: 1;\n        cursor: pointer;\n        background-color: ${({ theme }) => theme.colors.overlay};\n      }\n    }\n  `\n\nconst ElementContainer = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme }) => theme.radii.xlarge}\n  }\n`\n\nconst bordersStyles = ({\n  size,\n  colors,\n  theme,\n  shape,\n}: {\n  size: keyof typeof SIZES\n  colors: Colors\n  theme: Theme\n  shape: Shape\n}) => {\n  const isHalved = colors.length > 1\n  const finalColors = colors?.map(\n    bgColor =>\n      theme.colors[bgColor as SentimentColors]?.backgroundStrong ?? bgColor,\n  )\n\n  const finalSize = SIZES[size]\n\n  return css`\n    border-left: ${finalSize / 2}px solid ${finalColors[0]};\n    border-top: ${finalSize / 2}px solid ${finalColors[0]};\n    border-right: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: ${finalSize / 2}px solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-radius: ${shape === 'circle' ? theme.radii.circle : theme.radii[RADIUS_SIZES[size]]}};\n  `\n}\n\nconst StyledColors = styled('span', {\n  shouldForwardProp: prop => !['size', 'colors', 'shape'].includes(prop),\n})<{ size: keyof typeof SIZES; colors: Colors; shape: Shape }>`\n  align-items: center;\n  display: flex;\n  height: 100%;\n  justify-content: center;\n  ${bordersStyles}\n`\n\nconst ProductIconContainer = styled('div', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: keyof typeof SIZES }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n\n  &[data-shape='circle'] {\n    border-radius: ${({ theme }) => theme.radii.circle}\n  }\n\n  &[data-shape='square'] {\n    border-radius: ${({ theme, size }) => theme.radii[RADIUS_SIZES[size]]}\n  }\n\n  ${Object.entries(SIZES)\n    .map(\n      ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size}px;\n          height: ${size}px;\n\n          & > svg {\n            width: ${size}px;\n            height: ${size}px;\n          }\n        }\n  `,\n    )\n    .join('')}\n`\n\n/**\n * The AvatarV2 component is used to represent a user, product, or entity. It can be used to display an image, an icon, a text or a set of colors.\n */\nexport const AvatarV2 = ({\n  shape,\n  variant,\n  image,\n  icon,\n  text,\n  size = 'medium',\n  sentiment = 'primary',\n  colors = DEFAULT_COLORS,\n  upload,\n  onClick,\n  className,\n  'data-testid': dataTestId,\n}: AvatarV2Props) => (\n  <Container\n    data-shape={shape}\n    data-size={size}\n    data-sentiment={sentiment}\n    data-upload={upload}\n    data-has-background={!['user', 'image'].includes(variant)}\n    image={image}\n    onClick={onClick}\n    role={onClick ? 'button' : undefined}\n    size={size}\n    className={className}\n    data-testid={dataTestId}\n  >\n    {upload ? (\n      <UploadContainer data-shape={shape} size={size}>\n        <Icon\n          name=\"upload\"\n          size=\"large\"\n          sentiment=\"neutral\"\n          prominence=\"stronger\"\n        />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <ProductIcon name=\"user\" />\n      </ProductIconContainer>\n    ) : null}\n    {variant === 'icon' ? (\n      <ElementContainer data-shape={shape}>\n        <Icon\n          name={icon}\n          sentiment=\"neutral\"\n          size={ICON_SIZES[size]}\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        />\n      </ElementContainer>\n    ) : null}\n    {variant === 'text' ? (\n      <ElementContainer data-shape={shape}>\n        <Text\n          as=\"span\"\n          variant={TEXT_VARIANT_BY_SIZE[size]}\n          sentiment=\"neutral\"\n          prominence={sentiment === 'primary' ? 'stronger' : 'strong'}\n        >\n          {text}\n        </Text>\n      </ElementContainer>\n    ) : null}\n    {variant === 'colors' ? (\n      <StyledColors\n        size={size}\n        colors={colors}\n        shape={shape}\n        style={{\n          height: size,\n          width: size,\n        }}\n      />\n    ) : null}\n  </Container>\n)\n"]} */"));
103
+ const AvatarV2 = ({
104
+ shape,
105
+ variant,
106
+ image,
107
+ icon,
108
+ text,
109
+ size = "medium",
110
+ sentiment = "primary",
111
+ colors = DEFAULT_COLORS,
112
+ upload,
113
+ onClick,
114
+ className,
115
+ "data-testid": dataTestId
116
+ }) => /* @__PURE__ */ jsxs(Container, { "data-shape": shape, "data-size": size, "data-sentiment": sentiment, "data-upload": upload, "data-has-background": !["user", "image"].includes(variant), image, onClick, role: onClick ? "button" : void 0, size, className, "data-testid": dataTestId, children: [
117
+ upload ? /* @__PURE__ */ jsx(UploadContainer, { "data-shape": shape, size, children: /* @__PURE__ */ jsx(Icon, { name: "upload", size: "large", sentiment: "neutral", prominence: "stronger" }) }) : null,
118
+ variant === "user" ? /* @__PURE__ */ jsx(ProductIconContainer, { "data-shape": shape, "data-size": size, size, children: /* @__PURE__ */ jsx(ProductIcon, { name: "user" }) }) : null,
119
+ variant === "icon" ? /* @__PURE__ */ jsx(ElementContainer, { "data-shape": shape, children: /* @__PURE__ */ jsx(Icon, { name: icon, sentiment: "neutral", size: ICON_SIZES[size], prominence: sentiment === "primary" ? "stronger" : "strong" }) }) : null,
120
+ variant === "text" ? /* @__PURE__ */ jsx(ElementContainer, { "data-shape": shape, children: /* @__PURE__ */ jsx(Text, { as: "span", variant: TEXT_VARIANT_BY_SIZE[size], sentiment: "neutral", prominence: sentiment === "primary" ? "stronger" : "strong", children: text }) }) : null,
121
+ variant === "colors" ? /* @__PURE__ */ jsx(StyledColors, { size, colors, shape, style: {
122
+ height: size,
123
+ width: size
124
+ } }) : null
125
+ ] });
126
+ export {
127
+ AvatarV2
128
+ };
@@ -1,6 +1,7 @@
1
1
  export { ActionBar } from './ActionBar';
2
2
  export { Alert } from './Alert';
3
3
  export { Avatar } from './Avatar';
4
+ export { AvatarV2 } from './AvatarV2';
4
5
  export { Badge } from './Badge';
5
6
  export { Banner } from './Banner';
6
7
  export { BarChart } from './BarChart';
package/dist/index.cjs CHANGED
@@ -10,76 +10,77 @@ const normalize = require("./utils/normalize.cjs");
10
10
  const index$1 = require("./components/ActionBar/index.cjs");
11
11
  const index$2 = require("./components/Alert/index.cjs");
12
12
  const index$3 = require("./components/Avatar/index.cjs");
13
- const index$4 = require("./components/Badge/index.cjs");
14
- const index$5 = require("./components/Banner/index.cjs");
15
- const index$6 = require("./components/BarChart/index.cjs");
16
- const index$7 = require("./components/BarStack/index.cjs");
17
- const index$8 = require("./components/Breadcrumbs/index.cjs");
18
- const index$9 = require("./components/Bullet/index.cjs");
19
- const index$a = require("./components/Button/index.cjs");
20
- const index$b = require("./components/Card/index.cjs");
21
- const index$c = require("./components/Carousel/index.cjs");
22
- const index$d = require("./components/Checkbox/index.cjs");
23
- const index$e = require("./components/CheckboxGroup/index.cjs");
24
- const index$f = require("./components/CopyButton/index.cjs");
25
- const index$g = require("./components/DateInput/index.cjs");
26
- const index$h = require("./components/Dialog/index.cjs");
27
- const index$i = require("./components/EmptyState/index.cjs");
28
- const index$j = require("./components/Expandable/index.cjs");
29
- const index$k = require("./components/ExpandableCard/index.cjs");
30
- const index$l = require("./components/GlobalAlert/index.cjs");
31
- const index$m = require("./components/LineChart/index.cjs");
32
- const index$n = require("./components/Link/index.cjs");
33
- const index$o = require("./components/List/index.cjs");
34
- const index$p = require("./components/Loader/index.cjs");
35
- const index$q = require("./components/Menu/index.cjs");
36
- const index$r = require("./components/MenuV2/index.cjs");
37
- const index$s = require("./components/Meter/index.cjs");
38
- const index$t = require("./components/Modal/index.cjs");
39
- const index$u = require("./components/Notice/index.cjs");
40
- const index$v = require("./components/Notification/index.cjs");
41
- const index$w = require("./components/NumberInput/index.cjs");
42
- const index$x = require("./components/NumberInputV2/index.cjs");
43
- const index$y = require("./components/Pagination/index.cjs");
44
- const index$z = require("./components/PasswordCheck/index.cjs");
45
- const index$A = require("./components/PasswordStrengthMeter/index.cjs");
46
- const index$B = require("./components/PieChart/index.cjs");
47
- const index$C = require("./components/Popover/index.cjs");
48
- const index$D = require("./components/Popup/index.cjs");
49
- const index$E = require("./components/ProgressBar/index.cjs");
50
- const index$F = require("./components/Radio/index.cjs");
51
- const index$G = require("./components/RadioGroup/index.cjs");
52
- const index$H = require("./components/Row/index.cjs");
53
- const index$I = require("./components/SearchInput/index.cjs");
54
- const index$J = require("./components/SelectableCard/index.cjs");
55
- const index$K = require("./components/SelectableCardGroup/index.cjs");
56
- const index$L = require("./components/SelectInput/index.cjs");
57
- const index$M = require("./components/SelectInputV2/index.cjs");
58
- const index$N = require("./components/Separator/index.cjs");
59
- const index$O = require("./components/Skeleton/index.cjs");
60
- const index$P = require("./components/Slider/index.cjs");
61
- const index$Q = require("./components/Snippet/index.cjs");
62
- const index$R = require("./components/Stack/index.cjs");
63
- const index$S = require("./components/Status/index.cjs");
64
- const index$T = require("./components/StepList/index.cjs");
65
- const index$U = require("./components/Stepper/index.cjs");
66
- const index$V = require("./components/SwitchButton/index.cjs");
67
- const index$W = require("./components/Table/index.cjs");
68
- const index$X = require("./components/Tabs/index.cjs");
69
- const index$Y = require("./components/Tag/index.cjs");
70
- const index$Z = require("./components/TagInput/index.cjs");
71
- const index$_ = require("./components/TagList/index.cjs");
72
- const index$$ = require("./components/Text/index.cjs");
73
- const index$10 = require("./components/TextArea/index.cjs");
74
- const index$11 = require("./components/TextInput/index.cjs");
75
- const index$12 = require("./components/TextInputV2/index.cjs");
76
- const index$13 = require("./components/TimeInput/index.cjs");
77
- const index$14 = require("./components/Toaster/index.cjs");
78
- const index$15 = require("./components/Toggle/index.cjs");
79
- const index$16 = require("./components/ToggleGroup/index.cjs");
80
- const index$17 = require("./components/Tooltip/index.cjs");
81
- const index$18 = require("./components/UnitInput/index.cjs");
82
- const index$19 = require("./components/VerificationCode/index.cjs");
13
+ const index$4 = require("./components/AvatarV2/index.cjs");
14
+ const index$5 = require("./components/Badge/index.cjs");
15
+ const index$6 = require("./components/Banner/index.cjs");
16
+ const index$7 = require("./components/BarChart/index.cjs");
17
+ const index$8 = require("./components/BarStack/index.cjs");
18
+ const index$9 = require("./components/Breadcrumbs/index.cjs");
19
+ const index$a = require("./components/Bullet/index.cjs");
20
+ const index$b = require("./components/Button/index.cjs");
21
+ const index$c = require("./components/Card/index.cjs");
22
+ const index$d = require("./components/Carousel/index.cjs");
23
+ const index$e = require("./components/Checkbox/index.cjs");
24
+ const index$f = require("./components/CheckboxGroup/index.cjs");
25
+ const index$g = require("./components/CopyButton/index.cjs");
26
+ const index$h = require("./components/DateInput/index.cjs");
27
+ const index$i = require("./components/Dialog/index.cjs");
28
+ const index$j = require("./components/EmptyState/index.cjs");
29
+ const index$k = require("./components/Expandable/index.cjs");
30
+ const index$l = require("./components/ExpandableCard/index.cjs");
31
+ const index$m = require("./components/GlobalAlert/index.cjs");
32
+ const index$n = require("./components/LineChart/index.cjs");
33
+ const index$o = require("./components/Link/index.cjs");
34
+ const index$p = require("./components/List/index.cjs");
35
+ const index$q = require("./components/Loader/index.cjs");
36
+ const index$r = require("./components/Menu/index.cjs");
37
+ const index$s = require("./components/MenuV2/index.cjs");
38
+ const index$t = require("./components/Meter/index.cjs");
39
+ const index$u = require("./components/Modal/index.cjs");
40
+ const index$v = require("./components/Notice/index.cjs");
41
+ const index$w = require("./components/Notification/index.cjs");
42
+ const index$x = require("./components/NumberInput/index.cjs");
43
+ const index$y = require("./components/NumberInputV2/index.cjs");
44
+ const index$z = require("./components/Pagination/index.cjs");
45
+ const index$A = require("./components/PasswordCheck/index.cjs");
46
+ const index$B = require("./components/PasswordStrengthMeter/index.cjs");
47
+ const index$C = require("./components/PieChart/index.cjs");
48
+ const index$D = require("./components/Popover/index.cjs");
49
+ const index$E = require("./components/Popup/index.cjs");
50
+ const index$F = require("./components/ProgressBar/index.cjs");
51
+ const index$G = require("./components/Radio/index.cjs");
52
+ const index$H = require("./components/RadioGroup/index.cjs");
53
+ const index$I = require("./components/Row/index.cjs");
54
+ const index$J = require("./components/SearchInput/index.cjs");
55
+ const index$K = require("./components/SelectableCard/index.cjs");
56
+ const index$L = require("./components/SelectableCardGroup/index.cjs");
57
+ const index$M = require("./components/SelectInput/index.cjs");
58
+ const index$N = require("./components/SelectInputV2/index.cjs");
59
+ const index$O = require("./components/Separator/index.cjs");
60
+ const index$P = require("./components/Skeleton/index.cjs");
61
+ const index$Q = require("./components/Slider/index.cjs");
62
+ const index$R = require("./components/Snippet/index.cjs");
63
+ const index$S = require("./components/Stack/index.cjs");
64
+ const index$T = require("./components/Status/index.cjs");
65
+ const index$U = require("./components/StepList/index.cjs");
66
+ const index$V = require("./components/Stepper/index.cjs");
67
+ const index$W = require("./components/SwitchButton/index.cjs");
68
+ const index$X = require("./components/Table/index.cjs");
69
+ const index$Y = require("./components/Tabs/index.cjs");
70
+ const index$Z = require("./components/Tag/index.cjs");
71
+ const index$_ = require("./components/TagInput/index.cjs");
72
+ const index$$ = require("./components/TagList/index.cjs");
73
+ const index$10 = require("./components/Text/index.cjs");
74
+ const index$11 = require("./components/TextArea/index.cjs");
75
+ const index$12 = require("./components/TextInput/index.cjs");
76
+ const index$13 = require("./components/TextInputV2/index.cjs");
77
+ const index$14 = require("./components/TimeInput/index.cjs");
78
+ const index$15 = require("./components/Toaster/index.cjs");
79
+ const index$16 = require("./components/Toggle/index.cjs");
80
+ const index$17 = require("./components/ToggleGroup/index.cjs");
81
+ const index$18 = require("./components/Tooltip/index.cjs");
82
+ const index$19 = require("./components/UnitInput/index.cjs");
83
+ const index$1a = require("./components/VerificationCode/index.cjs");
83
84
  const icons = require("@ultraviolet/icons");
84
85
  exports.extendTheme = index.extendTheme;
85
86
  Object.defineProperty(exports, "darkTheme", {
@@ -125,79 +126,80 @@ exports.normalize = normalize;
125
126
  exports.ActionBar = index$1.ActionBar;
126
127
  exports.Alert = index$2.Alert;
127
128
  exports.Avatar = index$3.Avatar;
128
- exports.Badge = index$4.Badge;
129
- exports.Banner = index$5.Banner;
130
- exports.BarChart = index$6.BarChart;
131
- exports.BarStack = index$7.BarStack;
132
- exports.Breadcrumbs = index$8.Breadcrumbs;
133
- exports.Bullet = index$9.Bullet;
134
- exports.Button = index$a.Button;
135
- exports.Card = index$b.Card;
136
- exports.Carousel = index$c.Carousel;
137
- exports.Checkbox = index$d.Checkbox;
138
- exports.CheckboxGroup = index$e.CheckboxGroup;
139
- exports.CheckboxGroupCheckbox = index$e.CheckboxGroupCheckbox;
140
- exports.CopyButton = index$f.CopyButton;
141
- exports.DateInput = index$g.DateInput;
142
- exports.Dialog = index$h.Dialog;
143
- exports.EmptyState = index$i.EmptyState;
144
- exports.Expandable = index$j.Expandable;
145
- exports.ExpandableCard = index$k.ExpandableCard;
146
- exports.GlobalAlert = index$l.GlobalAlert;
147
- exports.LineChart = index$m.LineChart;
148
- exports.Link = index$n.Link;
149
- exports.List = index$o.List;
150
- exports.Loader = index$p.Loader;
151
- exports.Menu = index$q.Menu;
152
- exports.MenuV2 = index$r.MenuV2;
153
- exports.Meter = index$s.Meter;
154
- exports.Modal = index$t.Modal;
155
- exports.Notice = index$u.Notice;
156
- exports.NotificationContainer = index$v.NotificationContainer;
157
- exports.notification = index$v.notification;
158
- exports.NumberInput = index$w.NumberInput;
159
- exports.NumberInputV2 = index$x.NumberInputV2;
160
- exports.Pagination = index$y.Pagination;
161
- exports.PasswordCheck = index$z.PasswordCheck;
162
- exports.PasswordStrengthMeter = index$A.PasswordStrengthMeter;
163
- exports.PieChart = index$B.PieChart;
164
- exports.Popover = index$C.Popover;
165
- exports.Popup = index$D.Popup;
166
- exports.ProgressBar = index$E.ProgressBar;
167
- exports.Radio = index$F.Radio;
168
- exports.RadioGroup = index$G.RadioGroup;
169
- exports.Row = index$H.Row;
170
- exports.SearchInput = index$I.SearchInput;
171
- exports.SelectableCard = index$J.SelectableCard;
172
- exports.SelectableCardGroup = index$K.SelectableCardGroup;
173
- exports.SelectInput = index$L.SelectInput;
174
- exports.SelectInputV2 = index$M.SelectInputV2;
175
- exports.Separator = index$N.Separator;
176
- exports.Skeleton = index$O.Skeleton;
177
- exports.Slider = index$P.Slider;
178
- exports.Snippet = index$Q.Snippet;
179
- exports.Stack = index$R.Stack;
180
- exports.Status = index$S.Status;
181
- exports.StepList = index$T.StepList;
182
- exports.Stepper = index$U.Stepper;
183
- exports.SwitchButton = index$V.SwitchButton;
184
- exports.Table = index$W.Table;
185
- exports.Tabs = index$X.Tabs;
186
- exports.Tag = index$Y.Tag;
187
- exports.TagInput = index$Z.TagInput;
188
- exports.TagList = index$_.TagList;
189
- exports.Text = index$$.Text;
190
- exports.TextArea = index$10.TextArea;
191
- exports.TextInput = index$11.TextInput;
192
- exports.TextInputV2 = index$12.TextInputV2;
193
- exports.TimeInput = index$13.TimeInput;
194
- exports.ToastContainer = index$14.ToastContainer;
195
- exports.toast = index$14.toast;
196
- exports.Toggle = index$15.Toggle;
197
- exports.ToggleGroup = index$16.ToggleGroup;
198
- exports.Tooltip = index$17.Tooltip;
199
- exports.UnitInput = index$18.UnitInput;
200
- exports.VerificationCode = index$19.VerificationCode;
129
+ exports.AvatarV2 = index$4.AvatarV2;
130
+ exports.Badge = index$5.Badge;
131
+ exports.Banner = index$6.Banner;
132
+ exports.BarChart = index$7.BarChart;
133
+ exports.BarStack = index$8.BarStack;
134
+ exports.Breadcrumbs = index$9.Breadcrumbs;
135
+ exports.Bullet = index$a.Bullet;
136
+ exports.Button = index$b.Button;
137
+ exports.Card = index$c.Card;
138
+ exports.Carousel = index$d.Carousel;
139
+ exports.Checkbox = index$e.Checkbox;
140
+ exports.CheckboxGroup = index$f.CheckboxGroup;
141
+ exports.CheckboxGroupCheckbox = index$f.CheckboxGroupCheckbox;
142
+ exports.CopyButton = index$g.CopyButton;
143
+ exports.DateInput = index$h.DateInput;
144
+ exports.Dialog = index$i.Dialog;
145
+ exports.EmptyState = index$j.EmptyState;
146
+ exports.Expandable = index$k.Expandable;
147
+ exports.ExpandableCard = index$l.ExpandableCard;
148
+ exports.GlobalAlert = index$m.GlobalAlert;
149
+ exports.LineChart = index$n.LineChart;
150
+ exports.Link = index$o.Link;
151
+ exports.List = index$p.List;
152
+ exports.Loader = index$q.Loader;
153
+ exports.Menu = index$r.Menu;
154
+ exports.MenuV2 = index$s.MenuV2;
155
+ exports.Meter = index$t.Meter;
156
+ exports.Modal = index$u.Modal;
157
+ exports.Notice = index$v.Notice;
158
+ exports.NotificationContainer = index$w.NotificationContainer;
159
+ exports.notification = index$w.notification;
160
+ exports.NumberInput = index$x.NumberInput;
161
+ exports.NumberInputV2 = index$y.NumberInputV2;
162
+ exports.Pagination = index$z.Pagination;
163
+ exports.PasswordCheck = index$A.PasswordCheck;
164
+ exports.PasswordStrengthMeter = index$B.PasswordStrengthMeter;
165
+ exports.PieChart = index$C.PieChart;
166
+ exports.Popover = index$D.Popover;
167
+ exports.Popup = index$E.Popup;
168
+ exports.ProgressBar = index$F.ProgressBar;
169
+ exports.Radio = index$G.Radio;
170
+ exports.RadioGroup = index$H.RadioGroup;
171
+ exports.Row = index$I.Row;
172
+ exports.SearchInput = index$J.SearchInput;
173
+ exports.SelectableCard = index$K.SelectableCard;
174
+ exports.SelectableCardGroup = index$L.SelectableCardGroup;
175
+ exports.SelectInput = index$M.SelectInput;
176
+ exports.SelectInputV2 = index$N.SelectInputV2;
177
+ exports.Separator = index$O.Separator;
178
+ exports.Skeleton = index$P.Skeleton;
179
+ exports.Slider = index$Q.Slider;
180
+ exports.Snippet = index$R.Snippet;
181
+ exports.Stack = index$S.Stack;
182
+ exports.Status = index$T.Status;
183
+ exports.StepList = index$U.StepList;
184
+ exports.Stepper = index$V.Stepper;
185
+ exports.SwitchButton = index$W.SwitchButton;
186
+ exports.Table = index$X.Table;
187
+ exports.Tabs = index$Y.Tabs;
188
+ exports.Tag = index$Z.Tag;
189
+ exports.TagInput = index$_.TagInput;
190
+ exports.TagList = index$$.TagList;
191
+ exports.Text = index$10.Text;
192
+ exports.TextArea = index$11.TextArea;
193
+ exports.TextInput = index$12.TextInput;
194
+ exports.TextInputV2 = index$13.TextInputV2;
195
+ exports.TimeInput = index$14.TimeInput;
196
+ exports.ToastContainer = index$15.ToastContainer;
197
+ exports.toast = index$15.toast;
198
+ exports.Toggle = index$16.Toggle;
199
+ exports.ToggleGroup = index$17.ToggleGroup;
200
+ exports.Tooltip = index$18.Tooltip;
201
+ exports.UnitInput = index$19.UnitInput;
202
+ exports.VerificationCode = index$1a.VerificationCode;
201
203
  Object.defineProperty(exports, "Icon", {
202
204
  enumerable: true,
203
205
  get: () => icons.Icon
package/dist/index.js CHANGED
@@ -8,6 +8,7 @@ import { default as default3 } from "./utils/normalize.js";
8
8
  import { ActionBar } from "./components/ActionBar/index.js";
9
9
  import { Alert } from "./components/Alert/index.js";
10
10
  import { Avatar } from "./components/Avatar/index.js";
11
+ import { AvatarV2 } from "./components/AvatarV2/index.js";
11
12
  import { Badge } from "./components/Badge/index.js";
12
13
  import { Banner } from "./components/Banner/index.js";
13
14
  import { BarChart } from "./components/BarChart/index.js";
@@ -83,6 +84,7 @@ export {
83
84
  ActionBar,
84
85
  Alert,
85
86
  Avatar,
87
+ AvatarV2,
86
88
  Badge,
87
89
  Banner,
88
90
  BarChart,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/ui",
3
- "version": "1.65.0",
3
+ "version": "1.65.1",
4
4
  "description": "Ultraviolet UI",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {