UNPKG

@ultraviolet/plus

Version:
55 lines 91.9 kB
"use client"; import { jsx, jsxs } from "@emotion/react/jsx-runtime"; import _styled from "@emotion/styled/base"; import { css } from "@emotion/react"; import { OpenInNewIcon } from "@ultraviolet/icons"; import { Stack, Text } from "@ultraviolet/ui"; import { forwardRef, useRef, useState, useMemo, useEffect } from "react"; import { Skeleton } from "./Skeleton.js"; function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } const activeStyle = (theme) => /* @__PURE__ */ css("&:hover{border:1px solid ", theme.colors.primary.borderHover, ";box-shadow:", theme.shadows.defaultShadow, ";cursor:pointer;}" + (process.env.NODE_ENV === "production" ? "" : ";label:activeStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AAWyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { OpenInNewIcon } from '@ultraviolet/icons'\nimport { Stack, Text } from '@ultraviolet/ui'\nimport type { MouseEventHandler, ReactNode } from 'react'\nimport { forwardRef, useEffect, useMemo, useRef, useState } from 'react'\nimport { Skeleton } from './Skeleton'\n\nconst activeStyle = (theme: Theme) => css`\n  &:hover {\n    border: 1px solid ${theme.colors.primary.borderHover};\n    box-shadow: ${theme.shadows.defaultShadow};\n    cursor: pointer;\n  }\n`\n\nconst Card = styled.div<{\n  onClick?: ContentCardProps['onClick']\n  href?: ContentCardProps['href']\n  disabled?: ContentCardProps['disabled']\n}>`\n  display: block;\n  text-align: left;\n  padding: 0;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  background: ${({ theme }) => theme.colors.neutral.background};\n  ${({ onClick, href, theme }) => (onClick || href ? activeStyle(theme) : null)};\n  overflow-wrap: break-word;\n\n  &[disabled] {\n    cursor: not-allowed;\n    &:hover {\n      border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      box-shadow: none;\n    }\n  }\n`\n\nconst IconContainer = styled.div`\n  display: flex;\n  width: fit-content;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  padding: ${({ theme }) => theme.space['1']};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledIconStack = styled(Stack, {\n  shouldForwardProp: prop => prop !== 'direction',\n})<{ direction: ContentCardProps['direction'] }>`\n  padding: ${({ theme, direction }) =>\n    direction === 'column'\n      ? `0 ${theme.space['3']} ${theme.space['3']} ${theme.space['3']}`\n      : `${theme.space['3']} ${theme.space['3']} ${theme.space['3']} 0`};\n`\n\nconst SubContainer = styled(Stack, {\n  shouldForwardProp: prop => !['direction', 'href'].includes(prop),\n})<{\n  direction: ContentCardProps['direction']\n  href: ContentCardProps['href']\n}>`\n  padding: ${({ theme, direction }) =>\n    direction === 'column'\n      ? `${theme.space['3']} ${theme.space['3']} 0 ${theme.space['3']}`\n      : `${theme.space['3']} 0 ${theme.space['3']} ${theme.space['3']}`};\n  padding: ${({ theme, href }) => (!href ? `${theme.space['3']}` : null)};\n  height: fit-content;\n`\n\nconst Image = styled('img', {\n  shouldForwardProp: prop =>\n    !['direction', 'subContainerHeight'].includes(prop),\n})<{\n  direction: ContentCardProps['direction']\n  subContainerHeight?: number\n}>`\n  object-fit: cover;\n  border-radius: ${({ theme, direction }) =>\n    `${\n      direction === 'column'\n        ? `${theme.radii.default} ${theme.radii.default} 0 0`\n        : `${theme.radii.default} 0 0 ${theme.radii.default}`\n    }`};\n  ${({ direction, subContainerHeight }) =>\n    direction === 'row' ? `max-height: ${subContainerHeight}px` : null}\n\n  &[data-disabled] {\n    filter: grayscale(1);\n  }\n`\n\nconst FullHeightStack = styled(Stack)`\n  height: 100%;\n`\n\ntype ContentCardProps = {\n  direction?: 'row' | 'column'\n  /**\n   * The image to display at the top of the card (if direction is column) or to the left of the card (if direction is row).\n   * By default, the image will be cropped to fit the card.\n   */\n  image?: string\n  /**\n   * The icon the second element of the card to be displayed after the image. We allow any ReactNode but recommend\n   * using `<ProductIcon>` from `@ultraviolet/icons`.\n   */\n  icon?: ReactNode\n  subtitle?: string\n  title: string\n  /*\n   * Define the HTML Section Heading element level (h1 - h6) to use for the header\n   */\n  headingTag?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6'\n\n  description?: string\n  children?: ReactNode\n  /**\n   * The href to link the card to. If not provided, the card will not be clickable.\n   */\n  href?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  onClick?: MouseEventHandler<HTMLElement>\n  disabled?: boolean\n  loading?: boolean\n  className?: string\n}\n\n/**\n * ContentCard is a component that displays a title, subtitle, description, image and icon in a card.\n * It can take different directions to display the image and the content. You can also add more content\n * by passing children.\n */\nexport const ContentCard = forwardRef<\n  HTMLAnchorElement & HTMLButtonElement & HTMLDivElement,\n  ContentCardProps\n>(\n  (\n    {\n      image,\n      direction = 'column',\n      icon,\n      subtitle,\n      title,\n      headingTag = 'h3',\n      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\n      disabled,\n      loading,\n      className,\n    },\n    ref,\n  ) => {\n    const subContainerRef = useRef<HTMLDivElement>(null)\n    const [subContainerHeight, setSubContainerHeight] = useState(\n      subContainerRef?.current?.offsetHeight,\n    )\n    const Container = useMemo(() => {\n      if (href) {\n        return Card.withComponent('a')\n      }\n\n      if (onClick) {\n        return Card.withComponent('button')\n      }\n\n      return Card\n    }, [href, onClick])\n\n    useEffect(\n      () => setSubContainerHeight(subContainerRef?.current?.offsetHeight),\n      [subContainerRef],\n    )\n\n    return (\n      <Container\n        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"); const Card = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? { target: "e2ipnt5" } : { target: "e2ipnt5", label: "Card" })("display:block;text-align:left;padding:0;color:", ({ theme }) => theme.colors.neutral.text, ";text-decoration:none;border:1px solid ", ({ theme }) => theme.colors.neutral.border, ";border-radius:", ({ theme }) => theme.radii.default, ";background:", ({ theme }) => theme.colors.neutral.background, ";", ({ onClick, href, theme }) => onClick || href ? activeStyle(theme) : null, ";overflow-wrap:break-word;&[disabled]{cursor:not-allowed;&:hover{border:1px solid ", ({ theme }) => theme.colors.neutral.border, ";box-shadow:none;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AAuBE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { OpenInNewIcon } from '@ultraviolet/icons'\nimport { Stack, Text } from '@ultraviolet/ui'\nimport type { MouseEventHandler, ReactNode } from 'react'\nimport { forwardRef, useEffect, useMemo, useRef, useState } from 'react'\nimport { Skeleton } from './Skeleton'\n\nconst activeStyle = (theme: Theme) => css`\n  &:hover {\n    border: 1px solid ${theme.colors.primary.borderHover};\n    box-shadow: ${theme.shadows.defaultShadow};\n    cursor: pointer;\n  }\n`\n\nconst Card = styled.div<{\n  onClick?: ContentCardProps['onClick']\n  href?: ContentCardProps['href']\n  disabled?: ContentCardProps['disabled']\n}>`\n  display: block;\n  text-align: left;\n  padding: 0;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  background: ${({ theme }) => theme.colors.neutral.background};\n  ${({ onClick, href, theme }) => (onClick || href ? activeStyle(theme) : null)};\n  overflow-wrap: break-word;\n\n  &[disabled] {\n    cursor: not-allowed;\n    &:hover {\n      border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      box-shadow: none;\n    }\n  }\n`\n\nconst IconContainer = styled.div`\n  display: flex;\n  width: fit-content;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  padding: ${({ theme }) => theme.space['1']};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledIconStack = styled(Stack, {\n  shouldForwardProp: prop => prop !== 'direction',\n})<{ direction: ContentCardProps['direction'] }>`\n  padding: ${({ theme, direction }) =>\n    direction === 'column'\n      ? `0 ${theme.space['3']} ${theme.space['3']} ${theme.space['3']}`\n      : `${theme.space['3']} ${theme.space['3']} ${theme.space['3']} 0`};\n`\n\nconst SubContainer = styled(Stack, {\n  shouldForwardProp: prop => !['direction', 'href'].includes(prop),\n})<{\n  direction: ContentCardProps['direction']\n  href: ContentCardProps['href']\n}>`\n  padding: ${({ theme, direction }) =>\n    direction === 'column'\n      ? `${theme.space['3']} ${theme.space['3']} 0 ${theme.space['3']}`\n      : `${theme.space['3']} 0 ${theme.space['3']} ${theme.space['3']}`};\n  padding: ${({ theme, href }) => (!href ? `${theme.space['3']}` : null)};\n  height: fit-content;\n`\n\nconst Image = styled('img', {\n  shouldForwardProp: prop =>\n    !['direction', 'subContainerHeight'].includes(prop),\n})<{\n  direction: ContentCardProps['direction']\n  subContainerHeight?: number\n}>`\n  object-fit: cover;\n  border-radius: ${({ theme, direction }) =>\n    `${\n      direction === 'column'\n        ? `${theme.radii.default} ${theme.radii.default} 0 0`\n        : `${theme.radii.default} 0 0 ${theme.radii.default}`\n    }`};\n  ${({ direction, subContainerHeight }) =>\n    direction === 'row' ? `max-height: ${subContainerHeight}px` : null}\n\n  &[data-disabled] {\n    filter: grayscale(1);\n  }\n`\n\nconst FullHeightStack = styled(Stack)`\n  height: 100%;\n`\n\ntype ContentCardProps = {\n  direction?: 'row' | 'column'\n  /**\n   * The image to display at the top of the card (if direction is column) or to the left of the card (if direction is row).\n   * By default, the image will be cropped to fit the card.\n   */\n  image?: string\n  /**\n   * The icon the second element of the card to be displayed after the image. We allow any ReactNode but recommend\n   * using `<ProductIcon>` from `@ultraviolet/icons`.\n   */\n  icon?: ReactNode\n  subtitle?: string\n  title: string\n  /*\n   * Define the HTML Section Heading element level (h1 - h6) to use for the header\n   */\n  headingTag?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6'\n\n  description?: string\n  children?: ReactNode\n  /**\n   * The href to link the card to. If not provided, the card will not be clickable.\n   */\n  href?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  onClick?: MouseEventHandler<HTMLElement>\n  disabled?: boolean\n  loading?: boolean\n  className?: string\n}\n\n/**\n * ContentCard is a component that displays a title, subtitle, description, image and icon in a card.\n * It can take different directions to display the image and the content. You can also add more content\n * by passing children.\n */\nexport const ContentCard = forwardRef<\n  HTMLAnchorElement & HTMLButtonElement & HTMLDivElement,\n  ContentCardProps\n>(\n  (\n    {\n      image,\n      direction = 'column',\n      icon,\n      subtitle,\n      title,\n      headingTag = 'h3',\n      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\n      disabled,\n      loading,\n      className,\n    },\n    ref,\n  ) => {\n    const subContainerRef = useRef<HTMLDivElement>(null)\n    const [subContainerHeight, setSubContainerHeight] = useState(\n      subContainerRef?.current?.offsetHeight,\n    )\n    const Container = useMemo(() => {\n      if (href) {\n        return Card.withComponent('a')\n      }\n\n      if (onClick) {\n        return Card.withComponent('button')\n      }\n\n      return Card\n    }, [href, onClick])\n\n    useEffect(\n      () => setSubContainerHeight(subContainerRef?.current?.offsetHeight),\n      [subContainerRef],\n    )\n\n    return (\n      <Container\n        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */")); const IconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? { target: "e2ipnt4" } : { target: "e2ipnt4", label: "IconContainer" })("display:flex;width:fit-content;background:", ({ theme }) => theme.colors.neutral.backgroundWeak, ";padding:", ({ theme }) => theme.space["1"], ";border-radius:", ({ theme }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AA4CgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { OpenInNewIcon } from '@ultraviolet/icons'\nimport { Stack, Text } from '@ultraviolet/ui'\nimport type { MouseEventHandler, ReactNode } from 'react'\nimport { forwardRef, useEffect, useMemo, useRef, useState } from 'react'\nimport { Skeleton } from './Skeleton'\n\nconst activeStyle = (theme: Theme) => css`\n  &:hover {\n    border: 1px solid ${theme.colors.primary.borderHover};\n    box-shadow: ${theme.shadows.defaultShadow};\n    cursor: pointer;\n  }\n`\n\nconst Card = styled.div<{\n  onClick?: ContentCardProps['onClick']\n  href?: ContentCardProps['href']\n  disabled?: ContentCardProps['disabled']\n}>`\n  display: block;\n  text-align: left;\n  padding: 0;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  background: ${({ theme }) => theme.colors.neutral.background};\n  ${({ onClick, href, theme }) => (onClick || href ? activeStyle(theme) : null)};\n  overflow-wrap: break-word;\n\n  &[disabled] {\n    cursor: not-allowed;\n    &:hover {\n      border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      box-shadow: none;\n    }\n  }\n`\n\nconst IconContainer = styled.div`\n  display: flex;\n  width: fit-content;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  padding: ${({ theme }) => theme.space['1']};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledIconStack = styled(Stack, {\n  shouldForwardProp: prop => prop !== 'direction',\n})<{ direction: ContentCardProps['direction'] }>`\n  padding: ${({ theme, direction }) =>\n    direction === 'column'\n      ? `0 ${theme.space['3']} ${theme.space['3']} ${theme.space['3']}`\n      : `${theme.space['3']} ${theme.space['3']} ${theme.space['3']} 0`};\n`\n\nconst SubContainer = styled(Stack, {\n  shouldForwardProp: prop => !['direction', 'href'].includes(prop),\n})<{\n  direction: ContentCardProps['direction']\n  href: ContentCardProps['href']\n}>`\n  padding: ${({ theme, direction }) =>\n    direction === 'column'\n      ? `${theme.space['3']} ${theme.space['3']} 0 ${theme.space['3']}`\n      : `${theme.space['3']} 0 ${theme.space['3']} ${theme.space['3']}`};\n  padding: ${({ theme, href }) => (!href ? `${theme.space['3']}` : null)};\n  height: fit-content;\n`\n\nconst Image = styled('img', {\n  shouldForwardProp: prop =>\n    !['direction', 'subContainerHeight'].includes(prop),\n})<{\n  direction: ContentCardProps['direction']\n  subContainerHeight?: number\n}>`\n  object-fit: cover;\n  border-radius: ${({ theme, direction }) =>\n    `${\n      direction === 'column'\n        ? `${theme.radii.default} ${theme.radii.default} 0 0`\n        : `${theme.radii.default} 0 0 ${theme.radii.default}`\n    }`};\n  ${({ direction, subContainerHeight }) =>\n    direction === 'row' ? `max-height: ${subContainerHeight}px` : null}\n\n  &[data-disabled] {\n    filter: grayscale(1);\n  }\n`\n\nconst FullHeightStack = styled(Stack)`\n  height: 100%;\n`\n\ntype ContentCardProps = {\n  direction?: 'row' | 'column'\n  /**\n   * The image to display at the top of the card (if direction is column) or to the left of the card (if direction is row).\n   * By default, the image will be cropped to fit the card.\n   */\n  image?: string\n  /**\n   * The icon the second element of the card to be displayed after the image. We allow any ReactNode but recommend\n   * using `<ProductIcon>` from `@ultraviolet/icons`.\n   */\n  icon?: ReactNode\n  subtitle?: string\n  title: string\n  /*\n   * Define the HTML Section Heading element level (h1 - h6) to use for the header\n   */\n  headingTag?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6'\n\n  description?: string\n  children?: ReactNode\n  /**\n   * The href to link the card to. If not provided, the card will not be clickable.\n   */\n  href?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  onClick?: MouseEventHandler<HTMLElement>\n  disabled?: boolean\n  loading?: boolean\n  className?: string\n}\n\n/**\n * ContentCard is a component that displays a title, subtitle, description, image and icon in a card.\n * It can take different directions to display the image and the content. You can also add more content\n * by passing children.\n */\nexport const ContentCard = forwardRef<\n  HTMLAnchorElement & HTMLButtonElement & HTMLDivElement,\n  ContentCardProps\n>(\n  (\n    {\n      image,\n      direction = 'column',\n      icon,\n      subtitle,\n      title,\n      headingTag = 'h3',\n      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\n      disabled,\n      loading,\n      className,\n    },\n    ref,\n  ) => {\n    const subContainerRef = useRef<HTMLDivElement>(null)\n    const [subContainerHeight, setSubContainerHeight] = useState(\n      subContainerRef?.current?.offsetHeight,\n    )\n    const Container = useMemo(() => {\n      if (href) {\n        return Card.withComponent('a')\n      }\n\n      if (onClick) {\n        return Card.withComponent('button')\n      }\n\n      return Card\n    }, [href, onClick])\n\n    useEffect(\n      () => setSubContainerHeight(subContainerRef?.current?.offsetHeight),\n      [subContainerRef],\n    )\n\n    return (\n      <Container\n        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */")); const StyledIconStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? { shouldForwardProp: (prop) => prop !== "direction", target: "e2ipnt3" } : { shouldForwardProp: (prop) => prop !== "direction", target: "e2ipnt3", label: "StyledIconStack" })("padding:", ({ theme, direction }) => direction === "column" ? `0 ${theme.space["3"]} ${theme.space["3"]} ${theme.space["3"]}` : `${theme.space["3"]} ${theme.space["3"]} ${theme.space["3"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNEZ0QiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db250ZW50Q2FyZC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHR5cGUgeyBUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IE9wZW5Jbk5ld0ljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudEhhbmRsZXIsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgdXNlRWZmZWN0LCB1c2VNZW1vLCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4vU2tlbGV0b24nXG5cbmNvbnN0IGFjdGl2ZVN0eWxlID0gKHRoZW1lOiBUaGVtZSkgPT4gY3NzYFxuICAmOmhvdmVyIHtcbiAgICBib3JkZXI6IDFweCBzb2xpZCAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJvcmRlckhvdmVyfTtcbiAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MuZGVmYXVsdFNoYWRvd307XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICB9XG5gXG5cbmNvbnN0IENhcmQgPSBzdHlsZWQuZGl2PHtcbiAgb25DbGljaz86IENvbnRlbnRDYXJkUHJvcHNbJ29uQ2xpY2snXVxuICBocmVmPzogQ29udGVudENhcmRQcm9wc1snaHJlZiddXG4gIGRpc2FibGVkPzogQ29udGVudENhcmRQcm9wc1snZGlzYWJsZWQnXVxufT5gXG4gIGRpc3BsYXk6IGJsb2NrO1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBwYWRkaW5nOiAwO1xuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcn07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gICR7KHsgb25DbGljaywgaHJlZiwgdGhlbWUgfSkgPT4gKG9uQ2xpY2sgfHwgaHJlZiA/IGFjdGl2ZVN0eWxlKHRoZW1lKSA6IG51bGwpfTtcbiAgb3ZlcmZsb3ctd3JhcDogYnJlYWstd29yZDtcblxuICAmW2Rpc2FibGVkXSB7XG4gICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgfVxuICB9XG5gXG5cbmNvbnN0IEljb25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuYFxuXG5jb25zdCBTdHlsZWRJY29uU3RhY2sgPSBzdHlsZWQoU3RhY2ssIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gcHJvcCAhPT0gJ2RpcmVjdGlvbicsXG59KTx7IGRpcmVjdGlvbjogQ29udGVudENhcmRQcm9wc1snZGlyZWN0aW9uJ10gfT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIGRpcmVjdGlvbiB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ2NvbHVtbidcbiAgICAgID8gYDAgJHt0aGVtZS5zcGFjZVsnMyddfSAke3RoZW1lLnNwYWNlWyczJ119ICR7dGhlbWUuc3BhY2VbJzMnXX1gXG4gICAgICA6IGAke3RoZW1lLnNwYWNlWyczJ119ICR7dGhlbWUuc3BhY2VbJzMnXX0gJHt0aGVtZS5zcGFjZVsnMyddfSAwYH07XG5gXG5cbmNvbnN0IFN1YkNvbnRhaW5lciA9IHN0eWxlZChTdGFjaywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydkaXJlY3Rpb24nLCAnaHJlZiddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBkaXJlY3Rpb246IENvbnRlbnRDYXJkUHJvcHNbJ2RpcmVjdGlvbiddXG4gIGhyZWY6IENvbnRlbnRDYXJkUHJvcHNbJ2hyZWYnXVxufT5gXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIGRpcmVjdGlvbiB9KSA9PlxuICAgIGRpcmVjdGlvbiA9PT0gJ2NvbHVtbidcbiAgICAgID8gYCR7dGhlbWUuc3BhY2VbJzMnXX0gJHt0aGVtZS5zcGFjZVsnMyddfSAwICR7dGhlbWUuc3BhY2VbJzMnXX1gXG4gICAgICA6IGAke3RoZW1lLnNwYWNlWyczJ119IDAgJHt0aGVtZS5zcGFjZVsnMyddfSAke3RoZW1lLnNwYWNlWyczJ119YH07XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIGhyZWYgfSkgPT4gKCFocmVmID8gYCR7dGhlbWUuc3BhY2VbJzMnXX1gIDogbnVsbCl9O1xuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuYFxuXG5jb25zdCBJbWFnZSA9IHN0eWxlZCgnaW1nJywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PlxuICAgICFbJ2RpcmVjdGlvbicsICdzdWJDb250YWluZXJIZWlnaHQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgZGlyZWN0aW9uOiBDb250ZW50Q2FyZFByb3BzWydkaXJlY3Rpb24nXVxuICBzdWJDb250YWluZXJIZWlnaHQ/OiBudW1iZXJcbn0+YFxuICBvYmplY3QtZml0OiBjb3ZlcjtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSwgZGlyZWN0aW9uIH0pID0+XG4gICAgYCR7XG4gICAgICBkaXJlY3Rpb24gPT09ICdjb2x1bW4nXG4gICAgICAgID8gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH0gJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAwIDBgXG4gICAgICAgIDogYCR7dGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwICR7dGhlbWUucmFkaWkuZGVmYXVsdH1gXG4gICAgfWB9O1xuICAkeyh7IGRpcmVjdGlvbiwgc3ViQ29udGFpbmVySGVpZ2h0IH0pID0+XG4gICAgZGlyZWN0aW9uID09PSAncm93JyA/IGBtYXgtaGVpZ2h0OiAke3N1YkNvbnRhaW5lckhlaWdodH1weGAgOiBudWxsfVxuXG4gICZbZGF0YS1kaXNhYmxlZF0ge1xuICAgIGZpbHRlcjogZ3JheXNjYWxlKDEpO1xuICB9XG5gXG5cbmNvbnN0IEZ1bGxIZWlnaHRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIGhlaWdodDogMTAwJTtcbmBcblxudHlwZSBDb250ZW50Q2FyZFByb3BzID0ge1xuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIC8qKlxuICAgKiBUaGUgaW1hZ2UgdG8gZGlzcGxheSBhdCB0aGUgdG9wIG9mIHRoZSBjYXJkIChpZiBkaXJlY3Rpb24gaXMgY29sdW1uKSBvciB0byB0aGUgbGVmdCBvZiB0aGUgY2FyZCAoaWYgZGlyZWN0aW9uIGlzIHJvdykuXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBpbWFnZSB3aWxsIGJlIGNyb3BwZWQgdG8gZml0IHRoZSBjYXJkLlxuICAgKi9cbiAgaW1hZ2U/OiBzdHJpbmdcbiAgLyoqXG4gICAqIFRoZSBpY29uIHRoZSBzZWNvbmQgZWxlbWVudCBvZiB0aGUgY2FyZCB0byBiZSBkaXNwbGF5ZWQgYWZ0ZXIgdGhlIGltYWdlLiBXZSBhbGxvdyBhbnkgUmVhY3ROb2RlIGJ1dCByZWNvbW1lbmRcbiAgICogdXNpbmcgYDxQcm9kdWN0SWNvbj5gIGZyb20gYEB1bHRyYXZpb2xldC9pY29uc2AuXG4gICAqL1xuICBpY29uPzogUmVhY3ROb2RlXG4gIHN1YnRpdGxlPzogc3RyaW5nXG4gIHRpdGxlOiBzdHJpbmdcbiAgLypcbiAgICogRGVmaW5lIHRoZSBIVE1MIFNlY3Rpb24gSGVhZGluZyBlbGVtZW50IGxldmVsIChoMSAtIGg2KSB0byB1c2UgZm9yIHRoZSBoZWFkZXJcbiAgICovXG4gIGhlYWRpbmdUYWc/OiAnaDEnIHwgJ2gyJyB8ICdoMycgfCAnaDQnIHwgJ2g1JyB8ICdoNidcblxuICBkZXNjcmlwdGlvbj86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVGhlIGhyZWYgdG8gbGluayB0aGUgY2FyZCB0by4gSWYgbm90IHByb3ZpZGVkLCB0aGUgY2FyZCB3aWxsIG5vdCBiZSBjbGlja2FibGUuXG4gICAqL1xuICBocmVmPzogSFRNTEFuY2hvckVsZW1lbnRbJ2hyZWYnXVxuICB0YXJnZXQ/OiBIVE1MQW5jaG9yRWxlbWVudFsndGFyZ2V0J11cbiAgb25DbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxFbGVtZW50PlxuICBkaXNhYmxlZD86IGJvb2xlYW5cbiAgbG9hZGluZz86IGJvb2xlYW5cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG59XG5cbi8qKlxuICogQ29udGVudENhcmQgaXMgYSBjb21wb25lbnQgdGhhdCBkaXNwbGF5cyBhIHRpdGxlLCBzdWJ0aXRsZSwgZGVzY3JpcHRpb24sIGltYWdlIGFuZCBpY29uIGluIGEgY2FyZC5cbiAqIEl0IGNhbiB0YWtlIGRpZmZlcmVudCBkaXJlY3Rpb25zIHRvIGRpc3BsYXkgdGhlIGltYWdlIGFuZCB0aGUgY29udGVudC4gWW91IGNhbiBhbHNvIGFkZCBtb3JlIGNvbnRlbnRcbiAqIGJ5IHBhc3NpbmcgY2hpbGRyZW4uXG4gKi9cbmV4cG9ydCBjb25zdCBDb250ZW50Q2FyZCA9IGZvcndhcmRSZWY8XG4gIEhUTUxBbmNob3JFbGVtZW50ICYgSFRNTEJ1dHRvbkVsZW1lbnQgJiBIVE1MRGl2RWxlbWVudCxcbiAgQ29udGVudENhcmRQcm9wc1xuPihcbiAgKFxuICAgIHtcbiAgICAgIGltYWdlLFxuICAgICAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gICAgICBpY29uLFxuICAgICAgc3VidGl0bGUsXG4gICAgICB0aXRsZSxcbiAgICAgIGhlYWRpbmdUYWcgPSAnaDMnLFxuICAgICAgZGVzY3JpcHRpb24sXG4gICAgICBjaGlsZHJlbixcbiAgICAgIGhyZWYsXG4gICAgICB0YXJnZXQgPSAnX2JsYW5rJyxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBkaXNhYmxlZCxcbiAgICAgIGxvYWRpbmcsXG4gICAgICBjbGFzc05hbWUsXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIGNvbnN0IHN1YkNvbnRhaW5lclJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcbiAgICBjb25zdCBbc3ViQ29udGFpbmVySGVpZ2h0LCBzZXRTdWJDb250YWluZXJIZWlnaHRdID0gdXNlU3RhdGUoXG4gICAgICBzdWJDb250YWluZXJSZWY/LmN1cnJlbnQ/Lm9mZnNldEhlaWdodCxcbiAgICApXG4gICAgY29uc3QgQ29udGFpbmVyID0gdXNlTWVtbygoKSA9PiB7XG4gICAgICBpZiAoaHJlZikge1xuICAgICAgICByZXR1cm4gQ2FyZC53aXRoQ29tcG9uZW50KCdhJylcbiAgICAgIH1cblxuICAgICAgaWYgKG9uQ2xpY2spIHtcbiAgICAgICAgcmV0dXJuIENhcmQud2l0aENvbXBvbmVudCgnYnV0dG9uJylcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIENhcmRcbiAgICB9LCBbaHJlZiwgb25DbGlja10pXG5cbiAgICB1c2VFZmZlY3QoXG4gICAgICAoKSA9PiBzZXRTdWJDb250YWluZXJIZWlnaHQoc3ViQ29udGFpbmVyUmVmPy5jdXJyZW50Py5vZmZzZXRIZWlnaHQpLFxuICAgICAgW3N1YkNvbnRhaW5lclJlZl0sXG4gICAgKVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxDb250YWluZXJcbiAgICAgICAgdGFyZ2V0PXt0YXJnZXR9XG4gICAgICAgIG9uQ2xpY2s9eyFkaXNhYmxlZCA/IG9uQ2xpY2sgOiB1bmRlZmluZWR9XG4gICAgICAgIGhyZWY9eyFkaXNhYmxlZCA/IGhyZWYgOiB1bmRlZmluZWR9XG4gICAgICAgIHJvbGU9e29uQ2xpY2sgJiYgIWhyZWYgPyAnYnV0dG9uJyA6IHVuZGVmaW5lZH1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICA+XG4gICAgICAgIHtsb2FkaW5nID8gKFxuICAgICAgICAgIDxTa2VsZXRvbiBkaXJlY3Rpb249e2RpcmVjdGlvbn0gLz5cbiAgICAgICAgKSA6IChcbiAgICAgICAgICA8RnVsbEhlaWdodFN0YWNrIGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICAgICAgICAgIHtpbWFnZSA/IChcbiAgICAgICAgICAgICAgPEltYWdlXG4gICAgICAgICAgICAgICAgYWx0PVwiXCJcbiAgICAgICAgICAgICAgICBzcmM9e2ltYWdlfVxuICAgICAgICAgICAgICAgIGhlaWdodD17ZGlyZWN0aW9uID09PSAnY29sdW1uJyA/IDEyMCA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgICAgICB3aWR0aD17ZGlyZWN0aW9uID09PSAncm93JyA/IDIyMCA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgICAgICAgICAgICBzdWJDb250YWluZXJIZWlnaHQ9e3N1YkNvbnRhaW5lckhlaWdodH1cbiAgICAgICAgICAgICAgICBkYXRhLWRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPFN0YWNrIGdhcD17Mn0gZGlyZWN0aW9uPXtkaXJlY3Rpb259IGZsZXg9ezF9PlxuICAgICAgICAgICAgICA8U3ViQ29udGFpbmVyXG4gICAgICAgICAgICAgICAgZ2FwPXsyfVxuICAgICAgICAgICAgICAgIGZsZXg9XCIxIDEgYXV0b1wiXG4gICAgICAgICAgICAgICAgYWxpZ25JdGVtcz17XG4gICAgICAgICAgICAgICAgICAhc3VidGl0bGUgJiYgIWRlc2NyaXB0aW9uICYmICFjaGlsZHJlbiA/ICdjZW50ZXInIDogdW5kZWZpbmVkXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgICAgICAgICAgIGhyZWY9e2hyZWZ9XG4gICAgICAgICAgICAgICAgcmVmPXtzdWJDb250YWluZXJSZWZ9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7aWNvbiA/PyBudWxsfVxuICAgICAgICAgICAgICAgIDxTdGFjayBnYXA9ezJ9IGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiIGZsZXg9XCIxIDEgYXV0b1wiPlxuICAgICAgICAgICAgICAgICAgPFN0YWNrIGdhcD17MC41fT5cbiAgICAgICAgICAgICAgICAgICAgPFN0YWNrPlxuICAgICAgICAgICAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICAgICAgICAgIGFzPVwic21hbGxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAge3N1YnRpdGxlfVxuICAgICAgICAgICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICAgICAgICBhcz17aGVhZGluZ1RhZ31cbiAgICAgICAgICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICAgICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAgICAgICAge2NoaWxkcmV