@ultraviolet/ui 1.85.1 → 1.85.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Alert/index.cjs +16 -15
- package/dist/components/Alert/index.js +16 -15
- package/dist/components/Avatar/index.cjs +4 -4
- package/dist/components/Avatar/index.js +4 -4
- package/dist/components/AvatarV2/index.cjs +8 -7
- package/dist/components/AvatarV2/index.js +8 -7
- package/dist/components/Button/constants.cjs +24 -0
- package/dist/components/Button/constants.d.ts +18 -0
- package/dist/components/Button/constants.js +24 -0
- package/dist/components/Button/index.cjs +8 -27
- package/dist/components/Button/index.d.ts +25 -6
- package/dist/components/Button/index.js +5 -24
- package/dist/components/DateInput/index.cjs +2 -2
- package/dist/components/DateInput/index.js +2 -2
- package/dist/components/GlobalAlert/index.cjs +3 -2
- package/dist/components/GlobalAlert/index.js +4 -3
- package/dist/components/TextArea/index.cjs +13 -12
- package/dist/components/TextArea/index.js +5 -4
- package/package.json +2 -2
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
2
|
import _styled from "@emotion/styled/base";
|
|
3
3
|
import { css } from "@emotion/react";
|
|
4
|
+
import { UploadIcon } from "@ultraviolet/icons";
|
|
4
5
|
import { Icon } from "@ultraviolet/icons/legacy";
|
|
5
6
|
import { UserProductIcon } from "@ultraviolet/icons/product";
|
|
6
7
|
import { Text } from "../Text/index.js";
|
|
@@ -17,7 +18,7 @@ const UploadContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
|
|
|
17
18
|
}) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
|
|
18
19
|
theme,
|
|
19
20
|
size
|
|
20
|
-
}) => theme.radii[RADIUS_SIZES[size]], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
21
|
+
}) => 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":"AAkB4C","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 { UploadIcon } from '@ultraviolet/icons'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport { UserProductIcon } from '@ultraviolet/icons/product'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  TEXT_VARIANT_BY_SIZE,\n  sizes,\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 ReturnType<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 ReturnType<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    ${({ theme }) =>\n      Object.entries(sizes(theme))\n        .map(\n          ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size};\n            height: ${size};\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 ReturnType<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(theme)[size]\n\n  return css`\n    border-left: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-top: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-right: calc(${finalSize} / 2) solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: calc(${finalSize} / 2) 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 ReturnType<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 ReturnType<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  ${({ theme }) =>\n    Object.entries(sizes(theme))\n      .map(\n        ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size};\n          height: ${size};\n\n          & > svg {\n            width: ${size};\n            height: ${size};\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        <UploadIcon size=\"large\" sentiment=\"neutral\" prominence=\"stronger\" />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <UserProductIcon />\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"]} */"));
|
|
21
22
|
const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
22
23
|
shouldForwardProp: (prop) => !["image", "size"].includes(prop),
|
|
23
24
|
target: "e1tvc0xj3"
|
|
@@ -50,7 +51,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
|
|
|
50
51
|
background-size: cover;
|
|
51
52
|
`, " &:hover{", UploadContainer, "{opacity:1;cursor:pointer;background-color:", ({
|
|
52
53
|
theme
|
|
53
|
-
}) => theme.colors.overlay, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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":"AAyC4D","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 { UploadIcon } from '@ultraviolet/icons'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport { UserProductIcon } from '@ultraviolet/icons/product'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  TEXT_VARIANT_BY_SIZE,\n  sizes,\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 ReturnType<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 ReturnType<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    ${({ theme }) =>\n      Object.entries(sizes(theme))\n        .map(\n          ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size};\n            height: ${size};\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 ReturnType<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(theme)[size]\n\n  return css`\n    border-left: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-top: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-right: calc(${finalSize} / 2) solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: calc(${finalSize} / 2) 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 ReturnType<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 ReturnType<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  ${({ theme }) =>\n    Object.entries(sizes(theme))\n      .map(\n        ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size};\n          height: ${size};\n\n          & > svg {\n            width: ${size};\n            height: ${size};\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        <UploadIcon size=\"large\" sentiment=\"neutral\" prominence=\"stronger\" />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <UserProductIcon />\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"]} */"));
|
|
54
55
|
const ElementContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
55
56
|
target: "e1tvc0xj2"
|
|
56
57
|
} : {
|
|
@@ -60,7 +61,7 @@ const ElementContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
|
|
|
60
61
|
theme
|
|
61
62
|
}) => theme.radii.circle, ";}&[data-shape='square']{border-radius:", ({
|
|
62
63
|
theme
|
|
63
|
-
}) => theme.radii.xlarge, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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":"AAwFmC","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 { UploadIcon } from '@ultraviolet/icons'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport { UserProductIcon } from '@ultraviolet/icons/product'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  TEXT_VARIANT_BY_SIZE,\n  sizes,\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 ReturnType<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 ReturnType<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    ${({ theme }) =>\n      Object.entries(sizes(theme))\n        .map(\n          ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size};\n            height: ${size};\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 ReturnType<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(theme)[size]\n\n  return css`\n    border-left: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-top: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-right: calc(${finalSize} / 2) solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: calc(${finalSize} / 2) 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 ReturnType<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 ReturnType<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  ${({ theme }) =>\n    Object.entries(sizes(theme))\n      .map(\n        ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size};\n          height: ${size};\n\n          & > svg {\n            width: ${size};\n            height: ${size};\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        <UploadIcon size=\"large\" sentiment=\"neutral\" prominence=\"stronger\" />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <UserProductIcon />\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"]} */"));
|
|
64
65
|
const bordersStyles = ({
|
|
65
66
|
size,
|
|
66
67
|
colors,
|
|
@@ -70,7 +71,7 @@ const bordersStyles = ({
|
|
|
70
71
|
const isHalved = colors.length > 1;
|
|
71
72
|
const finalColors = colors?.map((bgColor) => theme.colors[bgColor]?.backgroundStrong ?? bgColor);
|
|
72
73
|
const finalSize = sizes(theme)[size];
|
|
73
|
-
return /* @__PURE__ */ css("border-left:calc(", finalSize, " / 2) solid ", finalColors[0], ";border-top:calc(", finalSize, " / 2) solid ", finalColors[0], ";border-right:calc(", finalSize, " / 2) solid ", isHalved ? finalColors[1] : finalColors[0], ";border-bottom:calc(", finalSize, " / 2) 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,
|
|
74
|
+
return /* @__PURE__ */ css("border-left:calc(", finalSize, " / 2) solid ", finalColors[0], ";border-top:calc(", finalSize, " / 2) solid ", finalColors[0], ";border-right:calc(", finalSize, " / 2) solid ", isHalved ? finalColors[1] : finalColors[0], ";border-bottom:calc(", finalSize, " / 2) 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":"AA2HY","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 { UploadIcon } from '@ultraviolet/icons'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport { UserProductIcon } from '@ultraviolet/icons/product'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  TEXT_VARIANT_BY_SIZE,\n  sizes,\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 ReturnType<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 ReturnType<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    ${({ theme }) =>\n      Object.entries(sizes(theme))\n        .map(\n          ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size};\n            height: ${size};\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 ReturnType<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(theme)[size]\n\n  return css`\n    border-left: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-top: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-right: calc(${finalSize} / 2) solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: calc(${finalSize} / 2) 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 ReturnType<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 ReturnType<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  ${({ theme }) =>\n    Object.entries(sizes(theme))\n      .map(\n        ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size};\n          height: ${size};\n\n          & > svg {\n            width: ${size};\n            height: ${size};\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        <UploadIcon size=\"large\" sentiment=\"neutral\" prominence=\"stronger\" />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <UserProductIcon />\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"]} */");
|
|
74
75
|
};
|
|
75
76
|
const StyledColors = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "production" ? {
|
|
76
77
|
shouldForwardProp: (prop) => !["size", "colors", "shape"].includes(prop),
|
|
@@ -79,7 +80,7 @@ const StyledColors = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "p
|
|
|
79
80
|
shouldForwardProp: (prop) => !["size", "colors", "shape"].includes(prop),
|
|
80
81
|
target: "e1tvc0xj1",
|
|
81
82
|
label: "StyledColors"
|
|
82
|
-
})("align-items:center;display:flex;height:100%;justify-content:center;", bordersStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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":"AAwI0E","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 { UploadIcon } from '@ultraviolet/icons'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport { UserProductIcon } from '@ultraviolet/icons/product'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  TEXT_VARIANT_BY_SIZE,\n  sizes,\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 ReturnType<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 ReturnType<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    ${({ theme }) =>\n      Object.entries(sizes(theme))\n        .map(\n          ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size};\n            height: ${size};\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 ReturnType<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(theme)[size]\n\n  return css`\n    border-left: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-top: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-right: calc(${finalSize} / 2) solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: calc(${finalSize} / 2) 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 ReturnType<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 ReturnType<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  ${({ theme }) =>\n    Object.entries(sizes(theme))\n      .map(\n        ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size};\n          height: ${size};\n\n          & > svg {\n            width: ${size};\n            height: ${size};\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        <UploadIcon size=\"large\" sentiment=\"neutral\" prominence=\"stronger\" />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <UserProductIcon />\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"]} */"));
|
|
83
84
|
const ProductIconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
84
85
|
shouldForwardProp: (prop) => !["size"].includes(prop),
|
|
85
86
|
target: "e1tvc0xj0"
|
|
@@ -104,7 +105,7 @@ const ProductIconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV
|
|
|
104
105
|
height: ${size};
|
|
105
106
|
}
|
|
106
107
|
}
|
|
107
|
-
`).join(""), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
108
|
+
`).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":"AAkJ4C","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 { UploadIcon } from '@ultraviolet/icons'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport { UserProductIcon } from '@ultraviolet/icons/product'\nimport { Text } from '../Text'\nimport {\n  DEFAULT_COLORS,\n  ICON_SIZES,\n  RADIUS_SIZES,\n  SENTIMENTS,\n  TEXT_VARIANT_BY_SIZE,\n  sizes,\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 ReturnType<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 ReturnType<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    ${({ theme }) =>\n      Object.entries(sizes(theme))\n        .map(\n          ([key, size]) => `\n          &[data-size=\"${key}\"] {\n            width: ${size};\n            height: ${size};\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 ReturnType<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(theme)[size]\n\n  return css`\n    border-left: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-top: calc(${finalSize} / 2) solid ${finalColors[0]};\n    border-right: calc(${finalSize} / 2) solid\n      ${isHalved ? finalColors[1] : finalColors[0]};\n    border-bottom: calc(${finalSize} / 2) 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 ReturnType<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 ReturnType<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  ${({ theme }) =>\n    Object.entries(sizes(theme))\n      .map(\n        ([key, size]) => `\n        &[data-size=\"${key}\"] {\n          width: ${size};\n          height: ${size};\n\n          & > svg {\n            width: ${size};\n            height: ${size};\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        <UploadIcon size=\"large\" sentiment=\"neutral\" prominence=\"stronger\" />\n      </UploadContainer>\n    ) : null}\n    {variant === 'user' ? (\n      <ProductIconContainer data-shape={shape} data-size={size} size={size}>\n        <UserProductIcon />\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"]} */"));
|
|
108
109
|
const AvatarV2 = ({
|
|
109
110
|
shape,
|
|
110
111
|
variant,
|
|
@@ -119,7 +120,7 @@ const AvatarV2 = ({
|
|
|
119
120
|
className,
|
|
120
121
|
"data-testid": dataTestId
|
|
121
122
|
}) => /* @__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: [
|
|
122
|
-
upload ? /* @__PURE__ */ jsx(UploadContainer, { "data-shape": shape, size, children: /* @__PURE__ */ jsx(
|
|
123
|
+
upload ? /* @__PURE__ */ jsx(UploadContainer, { "data-shape": shape, size, children: /* @__PURE__ */ jsx(UploadIcon, { size: "large", sentiment: "neutral", prominence: "stronger" }) }) : null,
|
|
123
124
|
variant === "user" ? /* @__PURE__ */ jsx(ProductIconContainer, { "data-shape": shape, "data-size": size, size, children: /* @__PURE__ */ jsx(UserProductIcon, {}) }) : null,
|
|
124
125
|
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,
|
|
125
126
|
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,
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const SIZE_HEIGHT = {
|
|
4
|
+
large: "600",
|
|
5
|
+
// sizing key value from tokens
|
|
6
|
+
medium: "500",
|
|
7
|
+
small: "400",
|
|
8
|
+
xsmall: "300"
|
|
9
|
+
};
|
|
10
|
+
const SIZE_PADDING_KEY = {
|
|
11
|
+
large: 2,
|
|
12
|
+
medium: 1.5,
|
|
13
|
+
small: 1,
|
|
14
|
+
xsmall: 0.5
|
|
15
|
+
};
|
|
16
|
+
const SIZE_GAP_KEY = {
|
|
17
|
+
large: 1,
|
|
18
|
+
medium: 1,
|
|
19
|
+
small: 1,
|
|
20
|
+
xsmall: 0.5
|
|
21
|
+
};
|
|
22
|
+
exports.SIZE_GAP_KEY = SIZE_GAP_KEY;
|
|
23
|
+
exports.SIZE_HEIGHT = SIZE_HEIGHT;
|
|
24
|
+
exports.SIZE_PADDING_KEY = SIZE_PADDING_KEY;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare const SIZE_HEIGHT: {
|
|
2
|
+
readonly large: "600";
|
|
3
|
+
readonly medium: "500";
|
|
4
|
+
readonly small: "400";
|
|
5
|
+
readonly xsmall: "300";
|
|
6
|
+
};
|
|
7
|
+
export declare const SIZE_PADDING_KEY: {
|
|
8
|
+
readonly large: 2;
|
|
9
|
+
readonly medium: 1.5;
|
|
10
|
+
readonly small: 1;
|
|
11
|
+
readonly xsmall: 0.5;
|
|
12
|
+
};
|
|
13
|
+
export declare const SIZE_GAP_KEY: {
|
|
14
|
+
readonly large: 1;
|
|
15
|
+
readonly medium: 1;
|
|
16
|
+
readonly small: 1;
|
|
17
|
+
readonly xsmall: 0.5;
|
|
18
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
const SIZE_HEIGHT = {
|
|
2
|
+
large: "600",
|
|
3
|
+
// sizing key value from tokens
|
|
4
|
+
medium: "500",
|
|
5
|
+
small: "400",
|
|
6
|
+
xsmall: "300"
|
|
7
|
+
};
|
|
8
|
+
const SIZE_PADDING_KEY = {
|
|
9
|
+
large: 2,
|
|
10
|
+
medium: 1.5,
|
|
11
|
+
small: 1,
|
|
12
|
+
xsmall: 0.5
|
|
13
|
+
};
|
|
14
|
+
const SIZE_GAP_KEY = {
|
|
15
|
+
large: 1,
|
|
16
|
+
medium: 1,
|
|
17
|
+
small: 1,
|
|
18
|
+
xsmall: 0.5
|
|
19
|
+
};
|
|
20
|
+
export {
|
|
21
|
+
SIZE_GAP_KEY,
|
|
22
|
+
SIZE_HEIGHT,
|
|
23
|
+
SIZE_PADDING_KEY
|
|
24
|
+
};
|