@ultraviolet/ui 1.94.1 → 1.95.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -20,18 +20,18 @@ const styles = ({
20
20
  }) => {
21
21
  if (size === "small") {
22
22
  if (variant === "intro") {
23
- return /* @__PURE__ */ react.css("background:", theme.colors.primary.background, ";background-position:left,right;background-repeat:no-repeat,no-repeat;background-size:contain,contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AA4BgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme !== 'light' || variant === 'promotional'\n                    ? 'white'\n                    : 'primary'\n                }\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
23
+ return /* @__PURE__ */ react.css("background:", theme.colors.primary.background, ";background-position:left,right;background-repeat:no-repeat,no-repeat;background-size:contain,contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AA4BgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useMemo, useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const prominence = useMemo(() => {\n    if (variant === 'promotional' && theme === 'light') {\n      return 'strong'\n    }\n\n    if (theme === 'dark' || theme === 'darker') {\n      return 'stronger'\n    }\n\n    return 'default'\n  }, [variant, theme])\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme === 'light' && variant !== 'promotional'\n                    ? 'primary'\n                    : undefined\n                }\n                prominence={prominence}\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
24
24
  }
25
25
  if (variant === "promotional") {
26
- return /* @__PURE__ */ react.css("background-position:left,right;background-image:", theme.colors.other.gradients.background.linear.aqua, ";background-repeat:no-repeat,no-repeat;background-size:contain,contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AAqCgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme !== 'light' || variant === 'promotional'\n                    ? 'white'\n                    : 'primary'\n                }\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
26
+ return /* @__PURE__ */ react.css("background-position:left,right;background-image:", theme.colors.other.gradients.background.linear.aqua, ";background-repeat:no-repeat,no-repeat;background-size:contain,contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AAqCgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useMemo, useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const prominence = useMemo(() => {\n    if (variant === 'promotional' && theme === 'light') {\n      return 'strong'\n    }\n\n    if (theme === 'dark' || theme === 'darker') {\n      return 'stronger'\n    }\n\n    return 'default'\n  }, [variant, theme])\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme === 'light' && variant !== 'promotional'\n                    ? 'primary'\n                    : undefined\n                }\n                prominence={prominence}\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
27
27
  }
28
28
  }
29
29
  if (size === "medium") {
30
30
  if (variant === "intro") {
31
- return /* @__PURE__ */ react.css("background:", theme.colors.primary.background, ";background-position:right;background-repeat:no-repeat;background-size:contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AAgDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme !== 'light' || variant === 'promotional'\n                    ? 'white'\n                    : 'primary'\n                }\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
31
+ return /* @__PURE__ */ react.css("background:", theme.colors.primary.background, ";background-position:right;background-repeat:no-repeat;background-size:contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AAgDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useMemo, useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const prominence = useMemo(() => {\n    if (variant === 'promotional' && theme === 'light') {\n      return 'strong'\n    }\n\n    if (theme === 'dark' || theme === 'darker') {\n      return 'stronger'\n    }\n\n    return 'default'\n  }, [variant, theme])\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme === 'light' && variant !== 'promotional'\n                    ? 'primary'\n                    : undefined\n                }\n                prominence={prominence}\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
32
32
  }
33
33
  if (variant === "promotional") {
34
- return /* @__PURE__ */ react.css("background-image:", theme.colors.other.gradients.background.linear.aqua, ";background-position:right;background-repeat:no-repeat;background-size:contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AAyDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme !== 'light' || variant === 'promotional'\n                    ? 'white'\n                    : 'primary'\n                }\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
34
+ return /* @__PURE__ */ react.css("background-image:", theme.colors.other.gradients.background.linear.aqua, ";background-position:right;background-repeat:no-repeat;background-size:contain;" + (process.env.NODE_ENV === "production" ? "" : ";label:styles;"), 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/Banner/index.tsx"],"names":[],"mappings":"AAyDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useMemo, useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const prominence = useMemo(() => {\n    if (variant === 'promotional' && theme === 'light') {\n      return 'strong'\n    }\n\n    if (theme === 'dark' || theme === 'darker') {\n      return 'stronger'\n    }\n\n    return 'default'\n  }, [variant, theme])\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme === 'light' && variant !== 'promotional'\n                    ? 'primary'\n                    : undefined\n                }\n                prominence={prominence}\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */");
35
35
  }
36
36
  }
37
37
  return null;
@@ -60,7 +60,7 @@ const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NO
60
60
  size
61
61
  }), ";>svg:first-child,>img{height:", ({
62
62
  size
63
- }) => size === "medium" ? "140px" : "100px", ';align-self:center;}button[name="close"]{background:none;&:hover{background:none;}}' + (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/Banner/index.tsx"],"names":[],"mappings":"AAuEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme !== 'light' || variant === 'promotional'\n                    ? 'white'\n                    : 'primary'\n                }\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */"));
63
+ }) => size === "medium" ? "140px" : "100px", ';align-self:center;}button[name="close"]{background:none;&:hover{background:none;}}' + (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/Banner/index.tsx"],"names":[],"mappings":"AAuEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useMemo, useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const prominence = useMemo(() => {\n    if (variant === 'promotional' && theme === 'light') {\n      return 'strong'\n    }\n\n    if (theme === 'dark' || theme === 'darker') {\n      return 'stronger'\n    }\n\n    return 'default'\n  }, [variant, theme])\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme === 'light' && variant !== 'promotional'\n                    ? 'primary'\n                    : undefined\n                }\n                prominence={prominence}\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */"));
64
64
  const ImageStack = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
65
65
  shouldForwardProp: (prop) => !["size"].includes(prop),
66
66
  target: "e1kdwp5x0"
@@ -70,7 +70,7 @@ const ImageStack = /* @__PURE__ */ _styled__default.default(index.Stack, process
70
70
  label: "ImageStack"
71
71
  })("width:", ({
72
72
  size
73
- }) => size === "medium" ? "140px" : "74px", ";" + (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/Banner/index.tsx"],"names":[],"mappings":"AAiGkB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme !== 'light' || variant === 'promotional'\n                    ? 'white'\n                    : 'primary'\n                }\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */"));
73
+ }) => size === "medium" ? "140px" : "74px", ";" + (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/Banner/index.tsx"],"names":[],"mappings":"AAiGkB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { useMemo, useState } from 'react'\nimport { Button } from '../Button'\nimport { Link } from '../Link'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport defaultIllustrationSmall from './assets/default-image-small.svg'\nimport defaultIllustration from './assets/default-image.svg'\n\ntype Variant = 'intro' | 'promotional'\ntype Size = 'small' | 'medium'\n\nconst styles = ({\n  theme,\n  variant,\n  size,\n}: {\n  theme: Theme\n  variant: Variant\n  size: Size\n}) => {\n  if (size === 'small') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: left, right;\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-position: left, right;\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-repeat: no-repeat, no-repeat;\n        background-size: contain, contain;\n      `\n    }\n  }\n\n  if (size === 'medium') {\n    if (variant === 'intro') {\n      return css`\n        background: ${theme.colors.primary.background};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n\n    if (variant === 'promotional') {\n      return css`\n        background-image: ${theme.colors.other.gradients.background.linear.aqua};\n        background-position: right;\n        background-repeat: no-repeat;\n        background-size: contain;\n      `\n    }\n  }\n\n  return null\n}\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['variant', 'size', 'padding'].includes(prop),\n})<{ variant: Variant; size: Size }>`\n  padding: ${({ theme, size }) => theme.space[size === 'small' ? '2' : '3']};\n  border-radius: ${({ theme }) => theme.radii.large};\n  display: flex;\n  flex-direction: row;\n  justify-content: space-between;\n  gap: ${({ theme }) => theme.space['2']};\n  ${({ theme, variant, size }) => styles({ theme, variant, size })};\n\n  > svg:first-child,\n  > img {\n    height: ${({ size }) => (size === 'medium' ? '140px' : '100px')};\n    align-self: center;\n  }\n\n  button[name=\"close\"] {\n    background: none;\n\n    &:hover {\n      background: none;\n    }\n  }\n`\n\nconst ImageStack = styled(Stack, {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})<{ size: Size }>`\n  width: ${({ size }) => (size === 'medium' ? '140px' : '74px')};\n`\n\ntype BannerProps = {\n  variant?: Variant\n  size?: 'small' | 'medium'\n  title: string\n  children: ReactNode\n  direction?: 'row' | 'column'\n  onClose?: () => void\n  buttonText?: string\n  onClickButton?: ComponentProps<typeof Button>['onClick']\n  linkText?: string\n  linkHref?: string\n  /**\n   * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.\n   * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.\n   */\n  image?: ReactNode\n  closable?: boolean\n  className?: string\n  ['data-testid']?: string\n}\n\n/**\n * Banner component is used to display an informative message to the user with style.\n */\nexport const Banner = ({\n  variant = 'intro',\n  size = 'medium',\n  title,\n  children,\n  direction = 'column',\n  onClose,\n  buttonText,\n  onClickButton,\n  linkText,\n  linkHref,\n  image,\n  className,\n  closable = true,\n  'data-testid': dataTestId,\n}: BannerProps) => {\n  const { theme } = useTheme()\n  const defaultImage =\n    size === 'small' ? defaultIllustrationSmall : defaultIllustration\n\n  const prominence = useMemo(() => {\n    if (variant === 'promotional' && theme === 'light') {\n      return 'strong'\n    }\n\n    if (theme === 'dark' || theme === 'darker') {\n      return 'stronger'\n    }\n\n    return 'default'\n  }, [variant, theme])\n\n  const [opened, setOpened] = useState(true)\n\n  if (!opened) return null\n\n  return (\n    <Container\n      variant={variant}\n      size={size}\n      className={className}\n      data-testid={dataTestId}\n    >\n      {image ? (\n        <ImageStack size={size} justifyContent=\"center\">\n          {typeof image === 'string' ? <img src={image} alt=\"\" /> : image}\n        </ImageStack>\n      ) : (\n        <ImageStack size={size} justifyContent=\"center\">\n          <img src={defaultImage} alt=\"\" />\n        </ImageStack>\n      )}\n      <Stack\n        direction={direction}\n        gap={2}\n        justifyContent=\"space-between\"\n        alignItems={direction === 'column' ? 'start' : 'center'}\n        style={{ flex: 1 }}\n      >\n        <Stack gap={0.5} style={{ flex: 1 }} justifyContent=\"center\">\n          <Text\n            as=\"p\"\n            variant={size === 'medium' ? 'headingSmall' : 'bodyStronger'}\n            sentiment={variant === 'promotional' ? 'white' : 'primary'}\n            prominence={variant === 'intro' ? 'default' : 'strong'}\n          >\n            {title}\n          </Text>\n          <Text\n            as=\"p\"\n            variant=\"body\"\n            sentiment={\n              variant === 'promotional' || theme !== 'light'\n                ? 'white'\n                : 'neutral'\n            }\n          >\n            {children}\n          </Text>\n        </Stack>\n        {buttonText || linkText ? (\n          <Stack direction=\"row\" gap={2} alignItems=\"center\">\n            {buttonText ? (\n              <Button\n                size=\"medium\"\n                sentiment={variant === 'intro' ? 'primary' : 'white'}\n                variant=\"filled\"\n                onClick={onClickButton}\n              >\n                {buttonText}\n              </Button>\n            ) : null}\n            {linkText ? (\n              <Link\n                sentiment={\n                  theme === 'light' && variant !== 'promotional'\n                    ? 'primary'\n                    : undefined\n                }\n                prominence={prominence}\n                size=\"small\"\n                target=\"_blank\"\n                href={linkHref ?? ''}\n              >\n                {linkText}\n              </Link>\n            ) : null}\n          </Stack>\n        ) : null}\n      </Stack>\n      {closable ? (\n        <Button\n          icon=\"close\"\n          size=\"small\"\n          name=\"close\"\n          variant={variant === 'intro' ? 'ghost' : 'filled'}\n          sentiment={\n            variant === 'intro' ||\n            (variant === 'promotional' && theme !== 'light')\n              ? 'neutral'\n              : 'primary'\n          }\n          onClick={() => {\n            setOpened(false)\n            onClose?.()\n          }}\n        />\n      ) : null}\n    </Container>\n  )\n}\n"]} */"));
74
74
  const Banner = ({
75
75
  variant = "intro",
76
76
  size = "medium",
@@ -91,6 +91,15 @@ const Banner = ({
91
91
  theme
92
92
  } = react.useTheme();
93
93
  const defaultImage$1 = size === "small" ? defaultImageSmall : defaultImage;
94
+ const prominence = React.useMemo(() => {
95
+ if (variant === "promotional" && theme === "light") {
96
+ return "strong";
97
+ }
98
+ if (theme === "dark" || theme === "darker") {
99
+ return "stronger";
100
+ }
101
+ return "default";
102
+ }, [variant, theme]);
94
103
  const [opened, setOpened] = React.useState(true);
95
104
  if (!opened) return null;
96
105
  return /* @__PURE__ */ jsxRuntime.jsxs(Container, { variant, size, className, "data-testid": dataTestId, children: [
@@ -106,7 +115,7 @@ const Banner = ({
106
115
  ] }),
107
116
  buttonText || linkText ? /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { direction: "row", gap: 2, alignItems: "center", children: [
108
117
  buttonText ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { size: "medium", sentiment: variant === "intro" ? "primary" : "white", variant: "filled", onClick: onClickButton, children: buttonText }) : null,
109
- linkText ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Link, { sentiment: theme !== "light" || variant === "promotional" ? "white" : "primary", size: "small", target: "_blank", href: linkHref ?? "", children: linkText }) : null
118
+ linkText ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Link, { sentiment: theme === "light" && variant !== "promotional" ? "primary" : void 0, prominence, size: "small", target: "_blank", href: linkHref ?? "", children: linkText }) : null
110
119
  ] }) : null
111
120
  ] }),
112
121
  closable ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { icon: "close", size: "small", name: "close", variant: variant === "intro" ? "ghost" : "filled", sentiment: variant === "intro" || variant === "promotional" && theme !== "light" ? "neutral" : "primary", onClick: () => {