@ultraviolet/plus 3.0.0-beta.1 → 3.0.0-beta.10

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.
Files changed (49) hide show
  1. package/README.md +24 -3
  2. package/dist/components/CodeEditor/CodeEditor.cjs +4 -54
  3. package/dist/components/CodeEditor/CodeEditor.js +6 -55
  4. package/dist/components/CodeEditor/styles.css.cjs +9 -0
  5. package/dist/components/CodeEditor/styles.css.d.ts +3 -0
  6. package/dist/components/CodeEditor/styles.css.js +9 -0
  7. package/dist/components/ContentCard/Skeleton.cjs +7 -28
  8. package/dist/components/ContentCard/Skeleton.js +7 -26
  9. package/dist/components/ContentCard/index.cjs +11 -109
  10. package/dist/components/ContentCard/index.js +11 -107
  11. package/dist/components/ContentCard/styles.css.cjs +27 -0
  12. package/dist/components/ContentCard/styles.css.d.ts +12 -0
  13. package/dist/components/ContentCard/styles.css.js +27 -0
  14. package/dist/components/ContentCardGroup/Card.cjs +4 -69
  15. package/dist/components/ContentCardGroup/Card.js +5 -68
  16. package/dist/components/ContentCardGroup/SkeletonCard.cjs +3 -23
  17. package/dist/components/ContentCardGroup/SkeletonCard.js +3 -21
  18. package/dist/components/ContentCardGroup/index.cjs +2 -16
  19. package/dist/components/ContentCardGroup/index.js +2 -14
  20. package/dist/components/ContentCardGroup/styles.css.cjs +18 -0
  21. package/dist/components/ContentCardGroup/styles.css.d.ts +7 -0
  22. package/dist/components/ContentCardGroup/styles.css.js +18 -0
  23. package/dist/components/EstimateCost/componentStyle.d.ts +6 -6
  24. package/dist/components/FAQ/index.cjs +2 -12
  25. package/dist/components/FAQ/index.js +3 -11
  26. package/dist/components/FAQ/styles.css.cjs +5 -0
  27. package/dist/components/FAQ/styles.css.d.ts +1 -0
  28. package/dist/components/FAQ/styles.css.js +5 -0
  29. package/dist/components/InfoTable/InfoTable.cjs +5 -3
  30. package/dist/components/InfoTable/InfoTable.d.ts +3 -1
  31. package/dist/components/InfoTable/InfoTable.js +5 -3
  32. package/dist/components/InfoTable/components/Row.d.ts +5 -5
  33. package/dist/components/Navigation/NavigationContent.cjs +7 -6
  34. package/dist/components/Navigation/NavigationContent.d.ts +1 -1
  35. package/dist/components/Navigation/NavigationContent.js +7 -6
  36. package/dist/components/Navigation/components/PinnedItems.cjs +9 -9
  37. package/dist/components/Navigation/components/PinnedItems.js +4 -4
  38. package/dist/components/Navigation/types.d.ts +1 -0
  39. package/dist/components/OfferList/OfferList.cjs +5 -3
  40. package/dist/components/OfferList/OfferList.d.ts +4 -2
  41. package/dist/components/OfferList/OfferList.js +5 -3
  42. package/dist/components/OrderSummary/ScrollableContent.cjs +8 -5
  43. package/dist/components/OrderSummary/ScrollableContent.js +8 -5
  44. package/dist/components/OrderSummary/index.cjs +10 -8
  45. package/dist/components/OrderSummary/index.d.ts +1 -1
  46. package/dist/components/OrderSummary/index.js +10 -8
  47. package/dist/components/OrderSummary/types.d.ts +3 -0
  48. package/dist/plus.css +1 -0
  49. package/package.json +14 -11
@@ -1,99 +1,11 @@
1
1
  "use client";
2
2
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
- import { css } from "@emotion/react";
5
3
  import { OpenInNewIcon } from "@ultraviolet/icons";
6
4
  import { Stack, Text } from "@ultraviolet/ui";
5
+ import { assignInlineVars } from "@vanilla-extract/dynamic";
7
6
  import { forwardRef, useRef, useState, useMemo, useEffect } from "react";
8
7
  import { Skeleton } from "./Skeleton.js";
9
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
10
- 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).";
11
- }
12
- 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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */");
13
- const Card = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
14
- target: "e2ipnt5"
15
- } : {
16
- target: "e2ipnt5",
17
- label: "Card"
18
- })("display:block;text-align:left;padding:0;color:", ({
19
- theme
20
- }) => theme.colors.neutral.text, ";text-decoration:none;border:1px solid ", ({
21
- theme
22
- }) => theme.colors.neutral.border, ";border-radius:", ({
23
- theme
24
- }) => theme.radii.default, ";background:", ({
25
- theme
26
- }) => theme.colors.neutral.background, ";", ({
27
- onClick,
28
- href,
29
- theme
30
- }) => onClick || href ? activeStyle(theme) : null, ";overflow-wrap:break-word;&[disabled]{cursor:not-allowed;&:hover{border:1px solid ", ({
31
- theme
32
- }) => 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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
33
- const IconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
34
- target: "e2ipnt4"
35
- } : {
36
- target: "e2ipnt4",
37
- label: "IconContainer"
38
- })("display:flex;width:fit-content;background:", ({
39
- theme
40
- }) => theme.colors.neutral.backgroundWeak, ";padding:", ({
41
- theme
42
- }) => theme.space["1"], ";border-radius:", ({
43
- theme
44
- }) => 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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
45
- const StyledIconStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
46
- shouldForwardProp: (prop) => prop !== "direction",
47
- target: "e2ipnt3"
48
- } : {
49
- shouldForwardProp: (prop) => prop !== "direction",
50
- target: "e2ipnt3",
51
- label: "StyledIconStack"
52
- })("padding:", ({
53
- theme,
54
- direction
55
- }) => 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,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AAsDgD","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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
56
- const SubContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
57
- shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
58
- target: "e2ipnt2"
59
- } : {
60
- shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
61
- target: "e2ipnt2",
62
- label: "SubContainer"
63
- })("padding:", ({
64
- theme,
65
- direction
66
- }) => direction === "column" ? `${theme.space["3"]} ${theme.space["3"]} 0 ${theme.space["3"]}` : `${theme.space["3"]} 0 ${theme.space["3"]} ${theme.space["3"]}`, ";padding:", ({
67
- theme,
68
- href
69
- }) => !href ? `${theme.space["3"]}` : null, ";height:fit-content;" + (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":"AAkEE","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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
70
- const Image = /* @__PURE__ */ _styled("img", process.env.NODE_ENV === "production" ? {
71
- shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
72
- target: "e2ipnt1"
73
- } : {
74
- shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
75
- target: "e2ipnt1",
76
- label: "Image"
77
- })("object-fit:cover;border-radius:", ({
78
- theme,
79
- direction
80
- }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";", ({
81
- direction,
82
- subContainerHeight
83
- }) => direction === "row" ? `max-height: ${subContainerHeight}px` : null, " &[data-disabled]{filter:grayscale(1);}" + (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":"AAiFE","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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
84
- const FullHeightStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
85
- target: "e2ipnt0"
86
- } : {
87
- target: "e2ipnt0",
88
- label: "FullHeightStack"
89
- })(process.env.NODE_ENV === "production" ? {
90
- name: "13udsys",
91
- styles: "height:100%"
92
- } : {
93
- name: "13udsys",
94
- styles: "height:100%/*# 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":"AAiGqC","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        className={className}\n        disabled={disabled}\n        href={!disabled ? href : undefined}\n        onClick={!disabled ? onClick : undefined}\n        ref={ref}\n        role={onClick && !href ? 'button' : undefined}\n        target={target}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                data-disabled={disabled}\n                direction={direction}\n                height={direction === 'column' ? 120 : undefined}\n                src={image}\n                subContainerHeight={subContainerHeight}\n                width={direction === 'row' ? 220 : undefined}\n              />\n            ) : null}\n            <Stack direction={direction} flex={1} gap={2}>\n              <SubContainer\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                flex=\"1 1 auto\"\n                gap={2}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack flex=\"1 1 auto\" gap={2} justifyContent=\"space-between\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          disabled={disabled}\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          variant=\"caption\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodyStrong\"\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        disabled={disabled}\n                        sentiment=\"neutral\"\n                        variant=\"bodySmall\"\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  direction={direction}\n                  flex={1}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon disabled={disabled} sentiment=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */",
95
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
96
- });
8
+ import { cardClass, activeClass, fullHeight, imageClass, subContainerHeightVar, subContainer, iconStack, iconContainer } from "./styles.css.js";
97
9
  const ContentCard = forwardRef(({
98
10
  image,
99
11
  direction = "column",
@@ -114,28 +26,20 @@ const ContentCard = forwardRef(({
114
26
  const [subContainerHeight, setSubContainerHeight] = useState(subContainerRef?.current?.offsetHeight);
115
27
  const Container = useMemo(() => {
116
28
  if (href) {
117
- return Card.withComponent("a", process.env.NODE_ENV === "production" ? {
118
- target: "e2ipnt6"
119
- } : {
120
- target: "e2ipnt6",
121
- label: "Container"
122
- });
29
+ return "a";
123
30
  }
124
31
  if (onClick) {
125
- return Card.withComponent("button", process.env.NODE_ENV === "production" ? {
126
- target: "e2ipnt7"
127
- } : {
128
- target: "e2ipnt7",
129
- label: "Container"
130
- });
32
+ return "button";
131
33
  }
132
- return Card;
34
+ return "div";
133
35
  }, [href, onClick]);
134
36
  useEffect(() => setSubContainerHeight(subContainerRef?.current?.offsetHeight), [subContainerRef]);
135
- return /* @__PURE__ */ jsx(Container, { className, disabled, href: !disabled ? href : void 0, onClick: !disabled ? onClick : void 0, ref, role: onClick && !href ? "button" : void 0, target, children: loading ? /* @__PURE__ */ jsx(Skeleton, { direction }) : /* @__PURE__ */ jsxs(FullHeightStack, { direction, children: [
136
- image ? /* @__PURE__ */ jsx(Image, { alt: "", "data-disabled": disabled, direction, height: direction === "column" ? 120 : void 0, src: image, subContainerHeight, width: direction === "row" ? 220 : void 0 }) : null,
37
+ return /* @__PURE__ */ jsx(Container, { className: `${className ? `${className} ` : ""}${cardClass}${onClick || href ? ` ${activeClass}` : ""}`, disabled, href: !disabled ? href : void 0, onClick: !disabled ? onClick : void 0, ref, role: onClick && !href ? "button" : void 0, target, children: loading ? /* @__PURE__ */ jsx(Skeleton, { direction }) : /* @__PURE__ */ jsxs(Stack, { className: fullHeight, direction, children: [
38
+ image ? /* @__PURE__ */ jsx("img", { alt: "", className: imageClass[direction], "data-disabled": disabled, height: direction === "column" ? 120 : void 0, src: image, style: assignInlineVars({
39
+ [subContainerHeightVar]: subContainerHeight ? `${subContainerHeight.toString()}px` : void 0
40
+ }), width: direction === "row" ? 220 : void 0 }) : null,
137
41
  /* @__PURE__ */ jsxs(Stack, { direction, flex: 1, gap: 2, children: [
138
- /* @__PURE__ */ jsxs(SubContainer, { alignItems: !subtitle && !description && !children ? "center" : void 0, direction, flex: "1 1 auto", gap: 2, href, ref: subContainerRef, children: [
42
+ /* @__PURE__ */ jsxs(Stack, { alignItems: !subtitle && !description && !children ? "center" : void 0, className: subContainer[!href ? "noHref" : direction], direction, flex: "1 1 auto", gap: 2, ref: subContainerRef, children: [
139
43
  icon ?? null,
140
44
  /* @__PURE__ */ jsxs(Stack, { flex: "1 1 auto", gap: 2, justifyContent: "space-between", children: [
141
45
  /* @__PURE__ */ jsxs(Stack, { gap: 0.5, children: [
@@ -148,7 +52,7 @@ const ContentCard = forwardRef(({
148
52
  children ? /* @__PURE__ */ jsx(Stack, { children }) : null
149
53
  ] })
150
54
  ] }),
151
- href ? /* @__PURE__ */ jsx(StyledIconStack, { alignItems: direction === "column" ? "flex-end" : "center", direction, flex: 1, justifyContent: direction === "column" ? "center" : "end", children: /* @__PURE__ */ jsx(IconContainer, { children: /* @__PURE__ */ jsx(OpenInNewIcon, { disabled, sentiment: "neutral" }) }) }) : null
55
+ href ? /* @__PURE__ */ jsx(Stack, { alignItems: direction === "column" ? "flex-end" : "center", className: iconStack[direction], direction, flex: 1, justifyContent: direction === "column" ? "center" : "end", children: /* @__PURE__ */ jsx("div", { className: iconContainer, children: /* @__PURE__ */ jsx(OpenInNewIcon, { disabled, sentiment: "neutral" }) }) }) : null
152
56
  ] })
153
57
  ] }) });
154
58
  });
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
4
+ var subContainerHeightVar = "var(--uv_plus_u4r1ts0)";
5
+ var skeletonHeightVar = "var(--uv_plus_u4r1ts1)";
6
+ var skeletonWidthVar = "var(--uv_plus_u4r1ts2)";
7
+ var activeClass = "uv_plus_u4r1ts3";
8
+ var cardClass = "uv_plus_u4r1ts4";
9
+ var iconContainer = "uv_plus_u4r1ts5";
10
+ var iconStack = { column: "uv_plus_u4r1ts6", row: "uv_plus_u4r1ts7" };
11
+ var subContainer = { column: "uv_plus_u4r1ts9 uv_plus_u4r1ts8", row: "uv_plus_u4r1tsa uv_plus_u4r1ts8", noHref: "uv_plus_u4r1tsb uv_plus_u4r1ts8" };
12
+ var imageClass = { column: "uv_plus_u4r1tsd uv_plus_u4r1tsc", row: "uv_plus_u4r1tse uv_plus_u4r1tsc" };
13
+ var fullHeight = "uv_plus_u4r1tsf";
14
+ var skeletonImage = { column: "uv_plus_u4r1tsh uv_plus_u4r1tsg", row: "uv_plus_u4r1tsi uv_plus_u4r1tsg" };
15
+ var paddedStack = "uv_plus_u4r1tsj";
16
+ exports.activeClass = activeClass;
17
+ exports.cardClass = cardClass;
18
+ exports.fullHeight = fullHeight;
19
+ exports.iconContainer = iconContainer;
20
+ exports.iconStack = iconStack;
21
+ exports.imageClass = imageClass;
22
+ exports.paddedStack = paddedStack;
23
+ exports.skeletonHeightVar = skeletonHeightVar;
24
+ exports.skeletonImage = skeletonImage;
25
+ exports.skeletonWidthVar = skeletonWidthVar;
26
+ exports.subContainer = subContainer;
27
+ exports.subContainerHeightVar = subContainerHeightVar;
@@ -0,0 +1,12 @@
1
+ export declare const subContainerHeightVar: `var(--${string})`;
2
+ export declare const skeletonHeightVar: `var(--${string})`;
3
+ export declare const skeletonWidthVar: `var(--${string})`;
4
+ export declare const activeClass: string;
5
+ export declare const cardClass: string;
6
+ export declare const iconContainer: string;
7
+ export declare const iconStack: Record<"column" | "row", string>;
8
+ export declare const subContainer: Record<"column" | "row" | "noHref", string>;
9
+ export declare const imageClass: Record<"column" | "row", string>;
10
+ export declare const fullHeight: string;
11
+ export declare const skeletonImage: Record<"column" | "row", string>;
12
+ export declare const paddedStack: string;
@@ -0,0 +1,27 @@
1
+ /* empty css */
2
+ var subContainerHeightVar = "var(--uv_plus_u4r1ts0)";
3
+ var skeletonHeightVar = "var(--uv_plus_u4r1ts1)";
4
+ var skeletonWidthVar = "var(--uv_plus_u4r1ts2)";
5
+ var activeClass = "uv_plus_u4r1ts3";
6
+ var cardClass = "uv_plus_u4r1ts4";
7
+ var iconContainer = "uv_plus_u4r1ts5";
8
+ var iconStack = { column: "uv_plus_u4r1ts6", row: "uv_plus_u4r1ts7" };
9
+ var subContainer = { column: "uv_plus_u4r1ts9 uv_plus_u4r1ts8", row: "uv_plus_u4r1tsa uv_plus_u4r1ts8", noHref: "uv_plus_u4r1tsb uv_plus_u4r1ts8" };
10
+ var imageClass = { column: "uv_plus_u4r1tsd uv_plus_u4r1tsc", row: "uv_plus_u4r1tse uv_plus_u4r1tsc" };
11
+ var fullHeight = "uv_plus_u4r1tsf";
12
+ var skeletonImage = { column: "uv_plus_u4r1tsh uv_plus_u4r1tsg", row: "uv_plus_u4r1tsi uv_plus_u4r1tsg" };
13
+ var paddedStack = "uv_plus_u4r1tsj";
14
+ export {
15
+ activeClass,
16
+ cardClass,
17
+ fullHeight,
18
+ iconContainer,
19
+ iconStack,
20
+ imageClass,
21
+ paddedStack,
22
+ skeletonHeightVar,
23
+ skeletonImage,
24
+ skeletonWidthVar,
25
+ subContainer,
26
+ subContainerHeightVar
27
+ };
@@ -2,75 +2,10 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const icons = require("@ultraviolet/icons");
7
6
  const ui = require("@ultraviolet/ui");
8
7
  const react = require("react");
9
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
- 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).";
13
- }
14
- const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
15
- target: "eqcw8nr3"
16
- } : {
17
- target: "eqcw8nr3",
18
- label: "StyledStack"
19
- })(process.env.NODE_ENV === "production" ? {
20
- name: "ovk77c",
21
- styles: "min-width:0"
22
- } : {
23
- name: "ovk77c",
24
- styles: "min-width:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQmlDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IE9wZW5Jbk5ld0ljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQW5jaG9ySFRNTEF0dHJpYnV0ZXMsIEVsZW1lbnRUeXBlLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcblxudHlwZSBDYXJkUHJvcHMgPSB7XG4gIHRpdGxlPzogc3RyaW5nXG4gIHRpdGxlQXM/OiBFbGVtZW50VHlwZVxuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZUFzPzogRWxlbWVudFR5cGVcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbiAgaHJlZjogc3RyaW5nXG4gIHRhcmdldD86IEFuY2hvckhUTUxBdHRyaWJ1dGVzPEhUTUxBbmNob3JFbGVtZW50PlsndGFyZ2V0J11cbn1cblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBtaW4td2lkdGg6IDA7XG5gXG5cbmNvbnN0IEljb25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuYFxuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmFgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzMnXX07XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgaGVpZ2h0OiAxMDAlO1xuXG4gICY6bm90KDpmaXJzdC1jaGlsZCkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcn07XG4gIH1cblxuICAmOmZpcnN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9XG4gICAgICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMDtcbiAgfVxuXG4gICY6bGFzdC1jaGlsZCB7XG4gICAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIH1cblxuICAmICR7SWNvbldyYXBwZXJ9IHtcbiAgICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZEhvdmVyfTtcblxuICAgICYgJHtJY29uV3JhcHBlcn0ge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGZvcndhcmRSZWY8SFRNTEFuY2hvckVsZW1lbnQsIENhcmRQcm9wcz4oXG4gIChcbiAgICB7XG4gICAgICB0aXRsZSxcbiAgICAgIHRpdGxlQXMsXG4gICAgICBzdWJ0aXRsZSxcbiAgICAgIHN1YnRpdGxlQXMsXG4gICAgICBkZXNjcmlwdGlvbixcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgaHJlZixcbiAgICAgIHRhcmdldCA9ICdfYmxhbmsnLFxuICAgIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSByZWY9e3JlZn0gdGFyZ2V0PXt0YXJnZXR9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBhbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgZGlyZWN0aW9uPVwicm93XCJcbiAgICAgICAgZ2FwPXsyfVxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz17c3VidGl0bGVBcyB8fCAnaDUnfVxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3N1YnRpdGxlfVxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPXt0aXRsZUFzIHx8ICdoMyd9XG4gICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIG9uZUxpbmUgc2VudGltZW50PVwibmV1dHJhbFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIj5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxPcGVuSW5OZXdJY29uIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPlxuICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgPC9GdWxsSGVpZ2h0U3RhY2s+XG4gICAgPC9TdHlsZWRXcmFwcGVyPlxuICApLFxuKVxuIl19 */",
25
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
26
- });
27
- const IconWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
28
- target: "eqcw8nr2"
29
- } : {
30
- target: "eqcw8nr2",
31
- label: "IconWrapper"
32
- })("display:inline-flex;background:", ({
33
- theme
34
- }) => theme.colors.neutral.backgroundWeak, ";padding:", ({
35
- theme
36
- }) => theme.space["1"], ";border-radius:", ({
37
- theme
38
- }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IE9wZW5Jbk5ld0ljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQW5jaG9ySFRNTEF0dHJpYnV0ZXMsIEVsZW1lbnRUeXBlLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcblxudHlwZSBDYXJkUHJvcHMgPSB7XG4gIHRpdGxlPzogc3RyaW5nXG4gIHRpdGxlQXM/OiBFbGVtZW50VHlwZVxuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZUFzPzogRWxlbWVudFR5cGVcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbiAgaHJlZjogc3RyaW5nXG4gIHRhcmdldD86IEFuY2hvckhUTUxBdHRyaWJ1dGVzPEhUTUxBbmNob3JFbGVtZW50PlsndGFyZ2V0J11cbn1cblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBtaW4td2lkdGg6IDA7XG5gXG5cbmNvbnN0IEljb25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuYFxuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmFgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzMnXX07XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgaGVpZ2h0OiAxMDAlO1xuXG4gICY6bm90KDpmaXJzdC1jaGlsZCkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcn07XG4gIH1cblxuICAmOmZpcnN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9XG4gICAgICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMDtcbiAgfVxuXG4gICY6bGFzdC1jaGlsZCB7XG4gICAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIH1cblxuICAmICR7SWNvbldyYXBwZXJ9IHtcbiAgICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZEhvdmVyfTtcblxuICAgICYgJHtJY29uV3JhcHBlcn0ge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGZvcndhcmRSZWY8SFRNTEFuY2hvckVsZW1lbnQsIENhcmRQcm9wcz4oXG4gIChcbiAgICB7XG4gICAgICB0aXRsZSxcbiAgICAgIHRpdGxlQXMsXG4gICAgICBzdWJ0aXRsZSxcbiAgICAgIHN1YnRpdGxlQXMsXG4gICAgICBkZXNjcmlwdGlvbixcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgaHJlZixcbiAgICAgIHRhcmdldCA9ICdfYmxhbmsnLFxuICAgIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSByZWY9e3JlZn0gdGFyZ2V0PXt0YXJnZXR9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBhbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgZGlyZWN0aW9uPVwicm93XCJcbiAgICAgICAgZ2FwPXsyfVxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz17c3VidGl0bGVBcyB8fCAnaDUnfVxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3N1YnRpdGxlfVxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPXt0aXRsZUFzIHx8ICdoMyd9XG4gICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIG9uZUxpbmUgc2VudGltZW50PVwibmV1dHJhbFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIj5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxPcGVuSW5OZXdJY29uIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPlxuICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgPC9GdWxsSGVpZ2h0U3RhY2s+XG4gICAgPC9TdHlsZWRXcmFwcGVyPlxuICApLFxuKVxuIl19 */"));
39
- const StyledWrapper = /* @__PURE__ */ _styled__default.default("a", process.env.NODE_ENV === "production" ? {
40
- target: "eqcw8nr1"
41
- } : {
42
- target: "eqcw8nr1",
43
- label: "StyledWrapper"
44
- })("padding:", ({
45
- theme
46
- }) => theme.space["3"], ";text-decoration:none;height:100%;&:not(:first-child){border-top:1px solid ", ({
47
- theme
48
- }) => theme.colors.neutral.border, ";}&:first-child{border-radius:", ({
49
- theme
50
- }) => theme.radii.default, " ", ({
51
- theme
52
- }) => theme.radii.default, " 0 0;}&:last-child{border-radius:0 0 ", ({
53
- theme
54
- }) => theme.radii.default, " ", ({
55
- theme
56
- }) => theme.radii.default, ";}& ", IconWrapper, "{background:", ({
57
- theme
58
- }) => theme.colors.neutral.backgroundWeak, ";}&:hover{background:", ({
59
- theme
60
- }) => theme.colors.neutral.backgroundHover, ";& ", IconWrapper, "{background:none;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4QjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IE9wZW5Jbk5ld0ljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQW5jaG9ySFRNTEF0dHJpYnV0ZXMsIEVsZW1lbnRUeXBlLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcblxudHlwZSBDYXJkUHJvcHMgPSB7XG4gIHRpdGxlPzogc3RyaW5nXG4gIHRpdGxlQXM/OiBFbGVtZW50VHlwZVxuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZUFzPzogRWxlbWVudFR5cGVcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbiAgaHJlZjogc3RyaW5nXG4gIHRhcmdldD86IEFuY2hvckhUTUxBdHRyaWJ1dGVzPEhUTUxBbmNob3JFbGVtZW50PlsndGFyZ2V0J11cbn1cblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBtaW4td2lkdGg6IDA7XG5gXG5cbmNvbnN0IEljb25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuYFxuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmFgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzMnXX07XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgaGVpZ2h0OiAxMDAlO1xuXG4gICY6bm90KDpmaXJzdC1jaGlsZCkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcn07XG4gIH1cblxuICAmOmZpcnN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9XG4gICAgICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMDtcbiAgfVxuXG4gICY6bGFzdC1jaGlsZCB7XG4gICAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIH1cblxuICAmICR7SWNvbldyYXBwZXJ9IHtcbiAgICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZEhvdmVyfTtcblxuICAgICYgJHtJY29uV3JhcHBlcn0ge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGZvcndhcmRSZWY8SFRNTEFuY2hvckVsZW1lbnQsIENhcmRQcm9wcz4oXG4gIChcbiAgICB7XG4gICAgICB0aXRsZSxcbiAgICAgIHRpdGxlQXMsXG4gICAgICBzdWJ0aXRsZSxcbiAgICAgIHN1YnRpdGxlQXMsXG4gICAgICBkZXNjcmlwdGlvbixcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgaHJlZixcbiAgICAgIHRhcmdldCA9ICdfYmxhbmsnLFxuICAgIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSByZWY9e3JlZn0gdGFyZ2V0PXt0YXJnZXR9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBhbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgZGlyZWN0aW9uPVwicm93XCJcbiAgICAgICAgZ2FwPXsyfVxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz17c3VidGl0bGVBcyB8fCAnaDUnfVxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3N1YnRpdGxlfVxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPXt0aXRsZUFzIHx8ICdoMyd9XG4gICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIG9uZUxpbmUgc2VudGltZW50PVwibmV1dHJhbFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIj5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxPcGVuSW5OZXdJY29uIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPlxuICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgPC9GdWxsSGVpZ2h0U3RhY2s+XG4gICAgPC9TdHlsZWRXcmFwcGVyPlxuICApLFxuKVxuIl19 */"));
61
- const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
62
- target: "eqcw8nr0"
63
- } : {
64
- target: "eqcw8nr0",
65
- label: "FullHeightStack"
66
- })(process.env.NODE_ENV === "production" ? {
67
- name: "13udsys",
68
- styles: "height:100%"
69
- } : {
70
- name: "13udsys",
71
- styles: "height:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RHFDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IE9wZW5Jbk5ld0ljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQW5jaG9ySFRNTEF0dHJpYnV0ZXMsIEVsZW1lbnRUeXBlLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcblxudHlwZSBDYXJkUHJvcHMgPSB7XG4gIHRpdGxlPzogc3RyaW5nXG4gIHRpdGxlQXM/OiBFbGVtZW50VHlwZVxuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZUFzPzogRWxlbWVudFR5cGVcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmdcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGVcbiAgaHJlZjogc3RyaW5nXG4gIHRhcmdldD86IEFuY2hvckhUTUxBdHRyaWJ1dGVzPEhUTUxBbmNob3JFbGVtZW50PlsndGFyZ2V0J11cbn1cblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBtaW4td2lkdGg6IDA7XG5gXG5cbmNvbnN0IEljb25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuYFxuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmFgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzMnXX07XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgaGVpZ2h0OiAxMDAlO1xuXG4gICY6bm90KDpmaXJzdC1jaGlsZCkge1xuICAgIGJvcmRlci10b3A6IDFweCBzb2xpZCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJvcmRlcn07XG4gIH1cblxuICAmOmZpcnN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9XG4gICAgICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMDtcbiAgfVxuXG4gICY6bGFzdC1jaGlsZCB7XG4gICAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIH1cblxuICAmICR7SWNvbldyYXBwZXJ9IHtcbiAgICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZEhvdmVyfTtcblxuICAgICYgJHtJY29uV3JhcHBlcn0ge1xuICAgICAgYmFja2dyb3VuZDogbm9uZTtcbiAgICB9XG4gIH1cbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGZvcndhcmRSZWY8SFRNTEFuY2hvckVsZW1lbnQsIENhcmRQcm9wcz4oXG4gIChcbiAgICB7XG4gICAgICB0aXRsZSxcbiAgICAgIHRpdGxlQXMsXG4gICAgICBzdWJ0aXRsZSxcbiAgICAgIHN1YnRpdGxlQXMsXG4gICAgICBkZXNjcmlwdGlvbixcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgaHJlZixcbiAgICAgIHRhcmdldCA9ICdfYmxhbmsnLFxuICAgIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSByZWY9e3JlZn0gdGFyZ2V0PXt0YXJnZXR9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBhbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgZGlyZWN0aW9uPVwicm93XCJcbiAgICAgICAgZ2FwPXsyfVxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz17c3VidGl0bGVBcyB8fCAnaDUnfVxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3N1YnRpdGxlfVxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPXt0aXRsZUFzIHx8ICdoMyd9XG4gICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIG9uZUxpbmUgc2VudGltZW50PVwibmV1dHJhbFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIj5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxPcGVuSW5OZXdJY29uIHNlbnRpbWVudD1cIm5ldXRyYWxcIiAvPlxuICAgICAgICA8L0ljb25XcmFwcGVyPlxuICAgICAgPC9GdWxsSGVpZ2h0U3RhY2s+XG4gICAgPC9TdHlsZWRXcmFwcGVyPlxuICApLFxuKVxuIl19 */",
72
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
73
- });
8
+ const styles_css = require("./styles.css.cjs");
74
9
  const Card = react.forwardRef(({
75
10
  title,
76
11
  titleAs,
@@ -80,8 +15,8 @@ const Card = react.forwardRef(({
80
15
  children,
81
16
  href,
82
17
  target = "_blank"
83
- }, ref) => /* @__PURE__ */ jsxRuntime.jsx(StyledWrapper, { href, ref, target, children: /* @__PURE__ */ jsxRuntime.jsxs(FullHeightStack, { alignItems: "center", direction: "row", gap: 2, justifyContent: "space-between", children: [
84
- /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { gap: "0.5", children: [
18
+ }, ref) => /* @__PURE__ */ jsxRuntime.jsx("a", { className: styles_css.styledWrapper, href, ref, target, children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", className: styles_css.fullHeightStack, direction: "row", gap: 2, justifyContent: "space-between", children: [
19
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { className: styles_css.customStack, gap: "0.5", children: [
85
20
  /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
86
21
  subtitle ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: subtitleAs || "h5", oneLine: true, prominence: "weak", sentiment: "neutral", variant: "caption", children: subtitle }) : null,
87
22
  /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: titleAs || "h3", oneLine: true, sentiment: "neutral", variant: "bodyStrong", children: title })
@@ -89,6 +24,6 @@ const Card = react.forwardRef(({
89
24
  description ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", oneLine: true, sentiment: "neutral", variant: "bodySmall", children: description }) : null,
90
25
  children
91
26
  ] }),
92
- /* @__PURE__ */ jsxRuntime.jsx(IconWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(icons.OpenInNewIcon, { sentiment: "neutral" }) })
27
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.iconWrapper, children: /* @__PURE__ */ jsxRuntime.jsx(icons.OpenInNewIcon, { sentiment: "neutral" }) })
93
28
  ] }) }));
94
29
  exports.Card = Card;