@ultraviolet/ui 1.78.1 → 1.79.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.
@@ -19,18 +19,18 @@ const styles = ({
19
19
  }) => {
20
20
  if (size === "small") {
21
21
  if (variant === "intro") {
22
- 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":"AA0BgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
22
+ 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":"AA0BgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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
23
  }
24
24
  if (variant === "promotional") {
25
- 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":"AAmCgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
25
+ 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":"AAmCgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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
26
  }
27
27
  }
28
28
  if (size === "medium") {
29
29
  if (variant === "intro") {
30
- 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":"AA8CgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
30
+ 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":"AA8CgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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
31
  }
32
32
  if (variant === "promotional") {
33
- 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":"AAuDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
33
+ 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":"AAuDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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
34
  }
35
35
  }
36
36
  return null;
@@ -59,7 +59,7 @@ const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NO
59
59
  size
60
60
  }), ";>svg:first-child,>img{height:", ({
61
61
  size
62
- }) => 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":"AAqEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */"));
62
+ }) => 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":"AAqEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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
63
  const ImageStack = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
64
64
  shouldForwardProp: (prop) => !["size"].includes(prop),
65
65
  target: "e1kdwp5x0"
@@ -69,7 +69,7 @@ const ImageStack = /* @__PURE__ */ _styled__default.default(index.Stack, process
69
69
  label: "ImageStack"
70
70
  })("width:", ({
71
71
  size
72
- }) => 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":"AA+FkB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */"));
72
+ }) => 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":"AA+FkB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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
73
  const Banner = ({
74
74
  variant = "intro",
75
75
  size = "medium",
@@ -93,7 +93,7 @@ const Banner = ({
93
93
  const [opened, setOpened] = React.useState(true);
94
94
  if (!opened) return null;
95
95
  return /* @__PURE__ */ jsxRuntime.jsxs(Container, { variant, size, className, "data-testid": dataTestId, children: [
96
- /* @__PURE__ */ jsxRuntime.jsx(ImageStack, { size, justifyContent: "center", children: image ?? /* @__PURE__ */ jsxRuntime.jsx("img", { src: defaultImage$1, alt: "" }) }),
96
+ image ? /* @__PURE__ */ jsxRuntime.jsx(ImageStack, { size, justifyContent: "center", children: typeof image === "string" ? /* @__PURE__ */ jsxRuntime.jsx("img", { src: image, alt: "" }) : image }) : /* @__PURE__ */ jsxRuntime.jsx("img", { src: defaultImage$1, alt: "" }),
97
97
  /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { direction, gap: 2, justifyContent: "space-between", alignItems: direction === "column" ? "start" : "center", style: {
98
98
  flex: 1
99
99
  }, children: [
@@ -12,6 +12,10 @@ type BannerProps = {
12
12
  onClickButton?: ComponentProps<typeof Button>['onClick'];
13
13
  linkText?: string;
14
14
  linkHref?: string;
15
+ /**
16
+ * Set the image to be displayed on the left side of the banner. If not provided, a default image will be displayed.
17
+ * You can provide the url of the image it will be displayed as an img tag or a ReactNode to be displayed as is.
18
+ */
15
19
  image?: ReactNode;
16
20
  closable?: boolean;
17
21
  className?: string;
@@ -15,18 +15,18 @@ const styles = ({
15
15
  }) => {
16
16
  if (size === "small") {
17
17
  if (variant === "intro") {
18
- return /* @__PURE__ */ 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":"AA0BgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
18
+ return /* @__PURE__ */ 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":"AA0BgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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"]} */");
19
19
  }
20
20
  if (variant === "promotional") {
21
- return /* @__PURE__ */ 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":"AAmCgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
21
+ return /* @__PURE__ */ 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":"AAmCgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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"]} */");
22
22
  }
23
23
  }
24
24
  if (size === "medium") {
25
25
  if (variant === "intro") {
26
- return /* @__PURE__ */ 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":"AA8CgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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__ */ 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":"AA8CgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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"]} */");
27
27
  }
28
28
  if (variant === "promotional") {
29
- return /* @__PURE__ */ 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":"AAuDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */");
29
+ return /* @__PURE__ */ 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":"AAuDgB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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"]} */");
30
30
  }
31
31
  }
32
32
  return null;
@@ -55,7 +55,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
55
55
  size
56
56
  }), ";>svg:first-child,>img{height:", ({
57
57
  size
58
- }) => 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":"AAqEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */"));
58
+ }) => 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":"AAqEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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"]} */"));
59
59
  const ImageStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
60
60
  shouldForwardProp: (prop) => !["size"].includes(prop),
61
61
  target: "e1kdwp5x0"
@@ -65,7 +65,7 @@ const ImageStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "prod
65
65
  label: "ImageStack"
66
66
  })("width:", ({
67
67
  size
68
- }) => 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":"AA+FkB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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  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      <ImageStack size={size} justifyContent=\"center\">\n        {image ?? <img src={defaultImage} alt=\"\" />}\n      </ImageStack>\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"]} */"));
68
+ }) => 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":"AA+FkB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Banner/index.tsx","sourcesContent":["import 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        <img src={defaultImage} alt=\"\" />\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"]} */"));
69
69
  const Banner = ({
70
70
  variant = "intro",
71
71
  size = "medium",
@@ -89,7 +89,7 @@ const Banner = ({
89
89
  const [opened, setOpened] = useState(true);
90
90
  if (!opened) return null;
91
91
  return /* @__PURE__ */ jsxs(Container, { variant, size, className, "data-testid": dataTestId, children: [
92
- /* @__PURE__ */ jsx(ImageStack, { size, justifyContent: "center", children: image ?? /* @__PURE__ */ jsx("img", { src: defaultImage, alt: "" }) }),
92
+ image ? /* @__PURE__ */ jsx(ImageStack, { size, justifyContent: "center", children: typeof image === "string" ? /* @__PURE__ */ jsx("img", { src: image, alt: "" }) : image }) : /* @__PURE__ */ jsx("img", { src: defaultImage, alt: "" }),
93
93
  /* @__PURE__ */ jsxs(Stack, { direction, gap: 2, justifyContent: "space-between", alignItems: direction === "column" ? "start" : "center", style: {
94
94
  flex: 1
95
95
  }, children: [
@@ -0,0 +1,19 @@
1
+ import type { ComponentProps } from 'react';
2
+ import { Modal, type ModalProps } from '../Modal';
3
+ import './style.css';
4
+ export declare const SIZES: {
5
+ small: number;
6
+ medium: number;
7
+ large: number;
8
+ };
9
+ type DrawerProps = Pick<ComponentProps<typeof Modal>, 'ariaLabel' | 'children' | 'className' | 'data-testid' | 'disclosure' | 'hideOnClickOutside' | 'hideOnEsc' | 'id' | 'onClose' | 'open' | 'isClosable'> & {
10
+ header?: ModalProps['children'];
11
+ size?: keyof typeof SIZES;
12
+ /**
13
+ * Fixed info at the bottom of the
14
+ */
15
+ footer?: ModalProps['children'];
16
+ separator?: boolean;
17
+ };
18
+ export declare const Drawer: ({ size, onClose, open, header, footer, disclosure, children, ariaLabel, className, "data-testid": dataTestId, hideOnClickOutside, hideOnEsc, id, isClosable, separator, }: DrawerProps) => import("@emotion/react/jsx-runtime").JSX.Element;
19
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/ui",
3
- "version": "1.78.1",
3
+ "version": "1.79.0",
4
4
  "description": "Ultraviolet UI",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -63,7 +63,7 @@
63
63
  "@babel/core": "7.26.0",
64
64
  "@emotion/react": "11.13.5",
65
65
  "@emotion/styled": "11.13.5",
66
- "@types/react": "18.3.12",
66
+ "@types/react": "18.3.13",
67
67
  "@types/react-datepicker": "6.2.0",
68
68
  "@types/react-dom": "18.3.1",
69
69
  "react": "18.3.1",
@@ -85,7 +85,7 @@
85
85
  "react-toastify": "10.0.6",
86
86
  "react-use-clipboard": "1.0.9",
87
87
  "reakit": "1.3.11",
88
- "@ultraviolet/icons": "3.5.0",
88
+ "@ultraviolet/icons": "3.6.0",
89
89
  "@ultraviolet/themes": "1.15.0"
90
90
  },
91
91
  "scripts": {