@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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUNnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOENnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdURnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUVvQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0ZrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUNnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOENnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdURnQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUVvQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0Jhbm5lci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0ZrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9CYW5uZXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzLCB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAnLi4vTGluaydcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBkZWZhdWx0SWxsdXN0cmF0aW9uU21hbGwgZnJvbSAnLi9hc3NldHMvZGVmYXVsdC1pbWFnZS1zbWFsbC5zdmcnXG5pbXBvcnQgZGVmYXVsdElsbHVzdHJhdGlvbiBmcm9tICcuL2Fzc2V0cy9kZWZhdWx0LWltYWdlLnN2ZydcblxudHlwZSBWYXJpYW50ID0gJ2ludHJvJyB8ICdwcm9tb3Rpb25hbCdcbnR5cGUgU2l6ZSA9ICdzbWFsbCcgfCAnbWVkaXVtJ1xuXG5jb25zdCBzdHlsZXMgPSAoe1xuICB0aGVtZSxcbiAgdmFyaWFudCxcbiAgc2l6ZSxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIHZhcmlhbnQ6IFZhcmlhbnRcbiAgc2l6ZTogU2l6ZVxufSkgPT4ge1xuICBpZiAoc2l6ZSA9PT0gJ3NtYWxsJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiBsZWZ0LCByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdCwgbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW4sIGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuXG4gICAgaWYgKHZhcmlhbnQgPT09ICdwcm9tb3Rpb25hbCcpIHtcbiAgICAgIHJldHVybiBjc3NgXG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IGxlZnQsIHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQsIG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluLCBjb250YWluO1xuICAgICAgYFxuICAgIH1cbiAgfVxuXG4gIGlmIChzaXplID09PSAnbWVkaXVtJykge1xuICAgIGlmICh2YXJpYW50ID09PSAnaW50cm8nKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmR9O1xuICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiByaWdodDtcbiAgICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgICAgYmFja2dyb3VuZC1zaXplOiBjb250YWluO1xuICAgICAgYFxuICAgIH1cblxuICAgIGlmICh2YXJpYW50ID09PSAncHJvbW90aW9uYWwnKSB7XG4gICAgICByZXR1cm4gY3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWltYWdlOiAke3RoZW1lLmNvbG9ycy5vdGhlci5ncmFkaWVudHMuYmFja2dyb3VuZC5saW5lYXIuYXF1YX07XG4gICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IHJpZ2h0O1xuICAgICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgICBiYWNrZ3JvdW5kLXNpemU6IGNvbnRhaW47XG4gICAgICBgXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGxcbn1cblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3ZhcmlhbnQnLCAnc2l6ZScsICdwYWRkaW5nJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHZhcmlhbnQ6IFZhcmlhbnQ7IHNpemU6IFNpemUgfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIHNpemUgfSkgPT4gdGhlbWUuc3BhY2Vbc2l6ZSA9PT0gJ3NtYWxsJyA/ICcyJyA6ICczJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmxhcmdlfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICR7KHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSkgPT4gc3R5bGVzKHsgdGhlbWUsIHZhcmlhbnQsIHNpemUgfSl9O1xuXG4gID4gc3ZnOmZpcnN0LWNoaWxkLFxuICA+IGltZyB7XG4gICAgaGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gKHNpemUgPT09ICdtZWRpdW0nID8gJzE0MHB4JyA6ICcxMDBweCcpfTtcbiAgICBhbGlnbi1zZWxmOiBjZW50ZXI7XG4gIH1cblxuICBidXR0b25bbmFtZT1cImNsb3NlXCJdIHtcbiAgICBiYWNrZ3JvdW5kOiBub25lO1xuXG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBJbWFnZVN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NpemUnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2l6ZTogU2l6ZSB9PmBcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA9PT0gJ21lZGl1bScgPyAnMTQwcHgnIDogJzc0cHgnKX07XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIHZhcmlhbnQ/OiBWYXJpYW50XG4gIHNpemU/OiAnc21hbGwnIHwgJ21lZGl1bSdcbiAgdGl0bGU6IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpcmVjdGlvbj86ICdyb3cnIHwgJ2NvbHVtbidcbiAgb25DbG9zZT86ICgpID0+
|
|
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
|
|
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.
|
|
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.
|
|
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.
|
|
88
|
+
"@ultraviolet/icons": "3.6.0",
|
|
89
89
|
"@ultraviolet/themes": "1.15.0"
|
|
90
90
|
},
|
|
91
91
|
"scripts": {
|