@ultraviolet/plus 3.0.0-beta.6 → 3.0.0-beta.7

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.
package/README.md CHANGED
@@ -2,8 +2,6 @@
2
2
 
3
3
  [![npm version](https://badge.fury.io/js/%40ultraviolet%2Fplus.svg)](https://badge.fury.io/js/%40ultraviolet%2Fplus)
4
4
 
5
- ⚠️ THIS LIBRARY IS NOT STABLE ⚠️
6
-
7
5
  We are going to make breaking changes regularly until the first version is released.
8
6
 
9
7
  Ultraviolet Plus is a set of complex components that are built on top of Ultraviolet UI.
@@ -11,7 +9,30 @@ Ultraviolet Plus is a set of complex components that are built on top of Ultravi
11
9
  ## Get Started
12
10
 
13
11
  ```sh
14
- $ pnpm add @ultraviolet/ui @ultraviolet/plus @emotion/react @emotion/styled
12
+ $ pnpm add @ultraviolet/ui @ultraviolet/plus
13
+ ```
14
+
15
+ ### Usage
16
+
17
+ In order for the library to work you will need to import both Ultraviolet UI and Ultraviolet Plus styles in your project.
18
+
19
+ ```tsx
20
+ import { ThemeProvider } from '@ultraviolet/ui'
21
+ import { normalize, theme } from '@ultraviolet/ui'
22
+ import { ContentCard } from '@ultraviolet/plus'
23
+ import '@ultraviolet/ui/styles'
24
+ import '@ultraviolet/plus/styles'
25
+
26
+ const App = () => (
27
+ <ThemeProvider theme={theme}>
28
+ <Global
29
+ styles={css`
30
+ ${normalize()}
31
+ `}
32
+ />
33
+ <ContentCard title="Welcome on Ultraviolet Plus" />
34
+ </ThemeProvider>
35
+ )
15
36
  ```
16
37
 
17
38
  ## Documentation
@@ -2,38 +2,17 @@
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 ui = require("@ultraviolet/ui");
7
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
8
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
9
- const SkeletonImage = /* @__PURE__ */ _styled__default.default(ui.Skeleton, process.env.NODE_ENV === "production" ? {
10
- shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
11
- target: "e1wwr9dc1"
12
- } : {
13
- shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
14
- target: "e1wwr9dc1",
15
- label: "SkeletonImage"
16
- })("border-radius:", ({
17
- theme,
18
- direction
19
- }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";width:", ({
20
- width
21
- }) => width, ";height:", ({
22
- height
23
- }) => height, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdFIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgU3RhY2ssIFNrZWxldG9uIGFzIFVsdHJhdmlvbGV0U2tlbGV0b24gfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5cbmNvbnN0IFNrZWxldG9uSW1hZ2UgPSBzdHlsZWQoVWx0cmF2aW9sZXRTa2VsZXRvbiwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydoZWlnaHQnLCAnd2lkdGgnLCAnZGlyZWN0aW9uJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHdpZHRoPzogc3RyaW5nXG4gIGhlaWdodD86IHN0cmluZ1xuICBkaXJlY3Rpb246ICdyb3cnIHwgJ2NvbHVtbidcbn0+YFxuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lLCBkaXJlY3Rpb24gfSkgPT5cbiAgICBgJHtcbiAgICAgIGRpcmVjdGlvbiA9PT0gJ2NvbHVtbidcbiAgICAgICAgPyBgJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAke3RoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMGBcbiAgICAgICAgOiBgJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAwIDAgJHt0aGVtZS5yYWRpaS5kZWZhdWx0fWBcbiAgICB9YH07XG4gIHdpZHRoOiAkeyh7IHdpZHRoIH0pID0+IHdpZHRofTtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBoZWlnaHR9O1xuYFxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzMnXX07XG5gXG5cbnR5cGUgU2tlbGV0b25Qcm9wcyA9IHtcbiAgZGlyZWN0aW9uOiAncm93JyB8ICdjb2x1bW4nXG59XG5cbmV4cG9ydCBjb25zdCBTa2VsZXRvbiA9ICh7IGRpcmVjdGlvbiB9OiBTa2VsZXRvblByb3BzKSA9PiAoXG4gIDxTdGFjayBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgPFNrZWxldG9uSW1hZ2VcbiAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgaGVpZ2h0PXtkaXJlY3Rpb24gPT09ICdjb2x1bW4nID8gJzEyMHB4JyA6ICd1bnNldCd9XG4gICAgICB2YXJpYW50PVwic3F1YXJlXCJcbiAgICAgIHdpZHRoPXtkaXJlY3Rpb24gPT09ICdyb3cnID8gJzIyMHB4JyA6IHVuZGVmaW5lZH1cbiAgICAvPlxuICAgIDxTdHlsZWRTdGFjayBnYXA9ezJ9PlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgIDwvU3R5bGVkU3RhY2s+XG4gIDwvU3RhY2s+XG4pXG4iXX0= */"));
24
- const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
25
- target: "e1wwr9dc0"
26
- } : {
27
- target: "e1wwr9dc0",
28
- label: "StyledStack"
29
- })("padding:", ({
30
- theme
31
- }) => theme.space["3"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db250ZW50Q2FyZC9Ta2VsZXRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgU2tlbGV0b24gYXMgVWx0cmF2aW9sZXRTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcblxuY29uc3QgU2tlbGV0b25JbWFnZSA9IHN0eWxlZChVbHRyYXZpb2xldFNrZWxldG9uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2hlaWdodCcsICd3aWR0aCcsICdkaXJlY3Rpb24nXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgd2lkdGg/OiBzdHJpbmdcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIGRpcmVjdGlvbjogJ3JvdycgfCAnY29sdW1uJ1xufT5gXG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUsIGRpcmVjdGlvbiB9KSA9PlxuICAgIGAke1xuICAgICAgZGlyZWN0aW9uID09PSAnY29sdW1uJ1xuICAgICAgICA/IGAke3RoZW1lLnJhZGlpLmRlZmF1bHR9ICR7dGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwYFxuICAgICAgICA6IGAke3RoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMCAke3RoZW1lLnJhZGlpLmRlZmF1bHR9YFxuICAgIH1gfTtcbiAgd2lkdGg6ICR7KHsgd2lkdGggfSkgPT4gd2lkdGh9O1xuICBoZWlnaHQ6ICR7KHsgaGVpZ2h0IH0pID0+IGhlaWdodH07XG5gXG5cbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbmBcblxudHlwZSBTa2VsZXRvblByb3BzID0ge1xuICBkaXJlY3Rpb246ICdyb3cnIHwgJ2NvbHVtbidcbn1cblxuZXhwb3J0IGNvbnN0IFNrZWxldG9uID0gKHsgZGlyZWN0aW9uIH06IFNrZWxldG9uUHJvcHMpID0+IChcbiAgPFN0YWNrIGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICA8U2tlbGV0b25JbWFnZVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICBoZWlnaHQ9e2RpcmVjdGlvbiA9PT0gJ2NvbHVtbicgPyAnMTIwcHgnIDogJ3Vuc2V0J31cbiAgICAgIHZhcmlhbnQ9XCJzcXVhcmVcIlxuICAgICAgd2lkdGg9e2RpcmVjdGlvbiA9PT0gJ3JvdycgPyAnMjIwcHgnIDogdW5kZWZpbmVkfVxuICAgIC8+XG4gICAgPFN0eWxlZFN0YWNrIGdhcD17Mn0+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgPC9TdHlsZWRTdGFjaz5cbiAgPC9TdGFjaz5cbilcbiJdfQ== */"));
6
+ const dynamic = require("@vanilla-extract/dynamic");
7
+ const styles_css = require("./styles.css.cjs");
32
8
  const Skeleton = ({
33
9
  direction
34
10
  }) => /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction, children: [
35
- /* @__PURE__ */ jsxRuntime.jsx(SkeletonImage, { direction, height: direction === "column" ? "120px" : "unset", variant: "square", width: direction === "row" ? "220px" : void 0 }),
36
- /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { gap: 2, children: [
11
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { className: styles_css.skeletonImage[direction], style: dynamic.assignInlineVars({
12
+ [styles_css.skeletonHeightVar]: direction === "column" ? "120px" : "unset",
13
+ [styles_css.skeletonWidthVar]: direction === "row" ? "220px" : "100%"
14
+ }), variant: "square" }),
15
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { className: styles_css.paddedStack, gap: 2, children: [
37
16
  /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
38
17
  /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
39
18
  /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
@@ -1,35 +1,16 @@
1
1
  "use client";
2
2
  import { jsxs, jsx } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { Stack, Skeleton as Skeleton$1 } from "@ultraviolet/ui";
5
- const SkeletonImage = /* @__PURE__ */ _styled(Skeleton$1, process.env.NODE_ENV === "production" ? {
6
- shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
7
- target: "e1wwr9dc1"
8
- } : {
9
- shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
10
- target: "e1wwr9dc1",
11
- label: "SkeletonImage"
12
- })("border-radius:", ({
13
- theme,
14
- direction
15
- }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";width:", ({
16
- width
17
- }) => width, ";height:", ({
18
- height
19
- }) => height, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdFIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgU3RhY2ssIFNrZWxldG9uIGFzIFVsdHJhdmlvbGV0U2tlbGV0b24gfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5cbmNvbnN0IFNrZWxldG9uSW1hZ2UgPSBzdHlsZWQoVWx0cmF2aW9sZXRTa2VsZXRvbiwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydoZWlnaHQnLCAnd2lkdGgnLCAnZGlyZWN0aW9uJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHdpZHRoPzogc3RyaW5nXG4gIGhlaWdodD86IHN0cmluZ1xuICBkaXJlY3Rpb246ICdyb3cnIHwgJ2NvbHVtbidcbn0+YFxuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lLCBkaXJlY3Rpb24gfSkgPT5cbiAgICBgJHtcbiAgICAgIGRpcmVjdGlvbiA9PT0gJ2NvbHVtbidcbiAgICAgICAgPyBgJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAke3RoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMGBcbiAgICAgICAgOiBgJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAwIDAgJHt0aGVtZS5yYWRpaS5kZWZhdWx0fWBcbiAgICB9YH07XG4gIHdpZHRoOiAkeyh7IHdpZHRoIH0pID0+IHdpZHRofTtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBoZWlnaHR9O1xuYFxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzMnXX07XG5gXG5cbnR5cGUgU2tlbGV0b25Qcm9wcyA9IHtcbiAgZGlyZWN0aW9uOiAncm93JyB8ICdjb2x1bW4nXG59XG5cbmV4cG9ydCBjb25zdCBTa2VsZXRvbiA9ICh7IGRpcmVjdGlvbiB9OiBTa2VsZXRvblByb3BzKSA9PiAoXG4gIDxTdGFjayBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgPFNrZWxldG9uSW1hZ2VcbiAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgICAgaGVpZ2h0PXtkaXJlY3Rpb24gPT09ICdjb2x1bW4nID8gJzEyMHB4JyA6ICd1bnNldCd9XG4gICAgICB2YXJpYW50PVwic3F1YXJlXCJcbiAgICAgIHdpZHRoPXtkaXJlY3Rpb24gPT09ICdyb3cnID8gJzIyMHB4JyA6IHVuZGVmaW5lZH1cbiAgICAvPlxuICAgIDxTdHlsZWRTdGFjayBnYXA9ezJ9PlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPFVsdHJhdmlvbGV0U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgIDwvU3R5bGVkU3RhY2s+XG4gIDwvU3RhY2s+XG4pXG4iXX0= */"));
20
- const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
21
- target: "e1wwr9dc0"
22
- } : {
23
- target: "e1wwr9dc0",
24
- label: "StyledStack"
25
- })("padding:", ({
26
- theme
27
- }) => theme.space["3"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db250ZW50Q2FyZC9Ta2VsZXRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgU2tlbGV0b24gYXMgVWx0cmF2aW9sZXRTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcblxuY29uc3QgU2tlbGV0b25JbWFnZSA9IHN0eWxlZChVbHRyYXZpb2xldFNrZWxldG9uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2hlaWdodCcsICd3aWR0aCcsICdkaXJlY3Rpb24nXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgd2lkdGg/OiBzdHJpbmdcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIGRpcmVjdGlvbjogJ3JvdycgfCAnY29sdW1uJ1xufT5gXG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUsIGRpcmVjdGlvbiB9KSA9PlxuICAgIGAke1xuICAgICAgZGlyZWN0aW9uID09PSAnY29sdW1uJ1xuICAgICAgICA/IGAke3RoZW1lLnJhZGlpLmRlZmF1bHR9ICR7dGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwYFxuICAgICAgICA6IGAke3RoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMCAke3RoZW1lLnJhZGlpLmRlZmF1bHR9YFxuICAgIH1gfTtcbiAgd2lkdGg6ICR7KHsgd2lkdGggfSkgPT4gd2lkdGh9O1xuICBoZWlnaHQ6ICR7KHsgaGVpZ2h0IH0pID0+IGhlaWdodH07XG5gXG5cbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbmBcblxudHlwZSBTa2VsZXRvblByb3BzID0ge1xuICBkaXJlY3Rpb246ICdyb3cnIHwgJ2NvbHVtbidcbn1cblxuZXhwb3J0IGNvbnN0IFNrZWxldG9uID0gKHsgZGlyZWN0aW9uIH06IFNrZWxldG9uUHJvcHMpID0+IChcbiAgPFN0YWNrIGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICA8U2tlbGV0b25JbWFnZVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgICBoZWlnaHQ9e2RpcmVjdGlvbiA9PT0gJ2NvbHVtbicgPyAnMTIwcHgnIDogJ3Vuc2V0J31cbiAgICAgIHZhcmlhbnQ9XCJzcXVhcmVcIlxuICAgICAgd2lkdGg9e2RpcmVjdGlvbiA9PT0gJ3JvdycgPyAnMjIwcHgnIDogdW5kZWZpbmVkfVxuICAgIC8+XG4gICAgPFN0eWxlZFN0YWNrIGdhcD17Mn0+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgPC9TdHlsZWRTdGFjaz5cbiAgPC9TdGFjaz5cbilcbiJdfQ== */"));
4
+ import { assignInlineVars } from "@vanilla-extract/dynamic";
5
+ import { skeletonImage, skeletonWidthVar, skeletonHeightVar, paddedStack } from "./styles.css.js";
28
6
  const Skeleton = ({
29
7
  direction
30
8
  }) => /* @__PURE__ */ jsxs(Stack, { direction, children: [
31
- /* @__PURE__ */ jsx(SkeletonImage, { direction, height: direction === "column" ? "120px" : "unset", variant: "square", width: direction === "row" ? "220px" : void 0 }),
32
- /* @__PURE__ */ jsxs(StyledStack, { gap: 2, children: [
9
+ /* @__PURE__ */ jsx(Skeleton$1, { className: skeletonImage[direction], style: assignInlineVars({
10
+ [skeletonHeightVar]: direction === "column" ? "120px" : "unset",
11
+ [skeletonWidthVar]: direction === "row" ? "220px" : "100%"
12
+ }), variant: "square" }),
13
+ /* @__PURE__ */ jsxs(Stack, { className: paddedStack, gap: 2, children: [
33
14
  /* @__PURE__ */ jsx(Skeleton$1, { variant: "line" }),
34
15
  /* @__PURE__ */ jsx(Skeleton$1, { variant: "line" }),
35
16
  /* @__PURE__ */ jsx(Skeleton$1, { variant: "line" }),
@@ -2,102 +2,12 @@
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
- const react$1 = require("@emotion/react");
7
5
  const icons = require("@ultraviolet/icons");
8
6
  const ui = require("@ultraviolet/ui");
7
+ const dynamic = require("@vanilla-extract/dynamic");
9
8
  const react = require("react");
10
9
  const Skeleton = require("./Skeleton.cjs");
11
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
12
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
14
- 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).";
15
- }
16
- const activeStyle = (theme) => /* @__PURE__ */ react$1.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"]} */");
17
- const Card = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
18
- target: "e2ipnt5"
19
- } : {
20
- target: "e2ipnt5",
21
- label: "Card"
22
- })("display:block;text-align:left;padding:0;color:", ({
23
- theme
24
- }) => theme.colors.neutral.text, ";text-decoration:none;border:1px solid ", ({
25
- theme
26
- }) => theme.colors.neutral.border, ";border-radius:", ({
27
- theme
28
- }) => theme.radii.default, ";background:", ({
29
- theme
30
- }) => theme.colors.neutral.background, ";", ({
31
- onClick,
32
- href,
33
- theme
34
- }) => onClick || href ? activeStyle(theme) : null, ";overflow-wrap:break-word;&[disabled]{cursor:not-allowed;&:hover{border:1px solid ", ({
35
- theme
36
- }) => 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"]} */"));
37
- const IconContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
38
- target: "e2ipnt4"
39
- } : {
40
- target: "e2ipnt4",
41
- label: "IconContainer"
42
- })("display:flex;width:fit-content;background:", ({
43
- theme
44
- }) => theme.colors.neutral.backgroundWeak, ";padding:", ({
45
- theme
46
- }) => theme.space["1"], ";border-radius:", ({
47
- theme
48
- }) => 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"]} */"));
49
- const StyledIconStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
50
- shouldForwardProp: (prop) => prop !== "direction",
51
- target: "e2ipnt3"
52
- } : {
53
- shouldForwardProp: (prop) => prop !== "direction",
54
- target: "e2ipnt3",
55
- label: "StyledIconStack"
56
- })("padding:", ({
57
- theme,
58
- direction
59
- }) => 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"]} */"));
60
- const SubContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
61
- shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
62
- target: "e2ipnt2"
63
- } : {
64
- shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
65
- target: "e2ipnt2",
66
- label: "SubContainer"
67
- })("padding:", ({
68
- theme,
69
- direction
70
- }) => direction === "column" ? `${theme.space["3"]} ${theme.space["3"]} 0 ${theme.space["3"]}` : `${theme.space["3"]} 0 ${theme.space["3"]} ${theme.space["3"]}`, ";padding:", ({
71
- theme,
72
- href
73
- }) => !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"]} */"));
74
- const Image = /* @__PURE__ */ _styled__default.default("img", process.env.NODE_ENV === "production" ? {
75
- shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
76
- target: "e2ipnt1"
77
- } : {
78
- shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
79
- target: "e2ipnt1",
80
- label: "Image"
81
- })("object-fit:cover;border-radius:", ({
82
- theme,
83
- direction
84
- }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";", ({
85
- direction,
86
- subContainerHeight
87
- }) => 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"]} */"));
88
- const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
89
- target: "e2ipnt0"
90
- } : {
91
- target: "e2ipnt0",
92
- label: "FullHeightStack"
93
- })(process.env.NODE_ENV === "production" ? {
94
- name: "13udsys",
95
- styles: "height:100%"
96
- } : {
97
- name: "13udsys",
98
- 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"]} */",
99
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
100
- });
10
+ const styles_css = require("./styles.css.cjs");
101
11
  const ContentCard = react.forwardRef(({
102
12
  image,
103
13
  direction = "column",
@@ -118,28 +28,20 @@ const ContentCard = react.forwardRef(({
118
28
  const [subContainerHeight, setSubContainerHeight] = react.useState(subContainerRef?.current?.offsetHeight);
119
29
  const Container = react.useMemo(() => {
120
30
  if (href) {
121
- return Card.withComponent("a", process.env.NODE_ENV === "production" ? {
122
- target: "e2ipnt6"
123
- } : {
124
- target: "e2ipnt6",
125
- label: "Container"
126
- });
31
+ return "a";
127
32
  }
128
33
  if (onClick) {
129
- return Card.withComponent("button", process.env.NODE_ENV === "production" ? {
130
- target: "e2ipnt7"
131
- } : {
132
- target: "e2ipnt7",
133
- label: "Container"
134
- });
34
+ return "button";
135
35
  }
136
- return Card;
36
+ return "div";
137
37
  }, [href, onClick]);
138
38
  react.useEffect(() => setSubContainerHeight(subContainerRef?.current?.offsetHeight), [subContainerRef]);
139
- return /* @__PURE__ */ jsxRuntime.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__ */ jsxRuntime.jsx(Skeleton.Skeleton, { direction }) : /* @__PURE__ */ jsxRuntime.jsxs(FullHeightStack, { direction, children: [
140
- image ? /* @__PURE__ */ jsxRuntime.jsx(Image, { alt: "", "data-disabled": disabled, direction, height: direction === "column" ? 120 : void 0, src: image, subContainerHeight, width: direction === "row" ? 220 : void 0 }) : null,
39
+ return /* @__PURE__ */ jsxRuntime.jsx(Container, { className: `${className ? `${className} ` : ""}${styles_css.cardClass}${onClick || href ? ` ${styles_css.activeClass}` : ""}`, disabled, href: !disabled ? href : void 0, onClick: !disabled ? onClick : void 0, ref, role: onClick && !href ? "button" : void 0, target, children: loading ? /* @__PURE__ */ jsxRuntime.jsx(Skeleton.Skeleton, { direction }) : /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { className: styles_css.fullHeight, direction, children: [
40
+ image ? /* @__PURE__ */ jsxRuntime.jsx("img", { alt: "", className: styles_css.imageClass[direction], "data-disabled": disabled, height: direction === "column" ? 120 : void 0, src: image, style: dynamic.assignInlineVars({
41
+ [styles_css.subContainerHeightVar]: subContainerHeight ? `${subContainerHeight.toString()}px` : void 0
42
+ }), width: direction === "row" ? 220 : void 0 }) : null,
141
43
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction, flex: 1, gap: 2, children: [
142
- /* @__PURE__ */ jsxRuntime.jsxs(SubContainer, { alignItems: !subtitle && !description && !children ? "center" : void 0, direction, flex: "1 1 auto", gap: 2, href, ref: subContainerRef, children: [
44
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: !subtitle && !description && !children ? "center" : void 0, className: styles_css.subContainer[!href ? "noHref" : direction], direction, flex: "1 1 auto", gap: 2, ref: subContainerRef, children: [
143
45
  icon ?? null,
144
46
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { flex: "1 1 auto", gap: 2, justifyContent: "space-between", children: [
145
47
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 0.5, children: [
@@ -152,7 +54,7 @@ const ContentCard = react.forwardRef(({
152
54
  children ? /* @__PURE__ */ jsxRuntime.jsx(ui.Stack, { children }) : null
153
55
  ] })
154
56
  ] }),
155
- href ? /* @__PURE__ */ jsxRuntime.jsx(StyledIconStack, { alignItems: direction === "column" ? "flex-end" : "center", direction, flex: 1, justifyContent: direction === "column" ? "center" : "end", children: /* @__PURE__ */ jsxRuntime.jsx(IconContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(icons.OpenInNewIcon, { disabled, sentiment: "neutral" }) }) }) : null
57
+ href ? /* @__PURE__ */ jsxRuntime.jsx(ui.Stack, { alignItems: direction === "column" ? "flex-end" : "center", className: styles_css.iconStack[direction], direction, flex: 1, justifyContent: direction === "column" ? "center" : "end", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.iconContainer, children: /* @__PURE__ */ jsxRuntime.jsx(icons.OpenInNewIcon, { disabled, sentiment: "neutral" }) }) }) : null
156
58
  ] })
157
59
  ] }) });
158
60
  });
@@ -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,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
4
+ ;/* empty css */
5
+ var subContainerHeightVar = "var(--uv_plus_u4r1ts0)";
6
+ var skeletonHeightVar = "var(--uv_plus_u4r1ts1)";
7
+ var skeletonWidthVar = "var(--uv_plus_u4r1ts2)";
8
+ var activeClass = "uv_plus_u4r1ts3";
9
+ var cardClass = "uv_plus_u4r1ts4";
10
+ var iconContainer = "uv_plus_u4r1ts5";
11
+ var iconStack = { column: "uv_plus_u4r1ts6", row: "uv_plus_u4r1ts7" };
12
+ var subContainer = { column: "uv_plus_u4r1ts9 uv_plus_u4r1ts8", row: "uv_plus_u4r1tsa uv_plus_u4r1ts8", noHref: "uv_plus_u4r1tsb uv_plus_u4r1ts8" };
13
+ var imageClass = { column: "uv_plus_u4r1tsd uv_plus_u4r1tsc", row: "uv_plus_u4r1tse uv_plus_u4r1tsc" };
14
+ var fullHeight = "uv_plus_u4r1tsf";
15
+ var skeletonImage = { column: "uv_plus_u4r1tsh uv_plus_u4r1tsg", row: "uv_plus_u4r1tsi uv_plus_u4r1tsg" };
16
+ var paddedStack = "uv_plus_u4r1tsj";
17
+ exports.activeClass = activeClass;
18
+ exports.cardClass = cardClass;
19
+ exports.fullHeight = fullHeight;
20
+ exports.iconContainer = iconContainer;
21
+ exports.iconStack = iconStack;
22
+ exports.imageClass = imageClass;
23
+ exports.paddedStack = paddedStack;
24
+ exports.skeletonHeightVar = skeletonHeightVar;
25
+ exports.skeletonImage = skeletonImage;
26
+ exports.skeletonWidthVar = skeletonWidthVar;
27
+ exports.subContainer = subContainer;
28
+ 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<"row" | "column", string>;
8
+ export declare const subContainer: Record<"row" | "column" | "noHref", string>;
9
+ export declare const imageClass: Record<"row" | "column", string>;
10
+ export declare const fullHeight: string;
11
+ export declare const skeletonImage: Record<"row" | "column", string>;
12
+ export declare const paddedStack: string;
@@ -0,0 +1,28 @@
1
+ /* empty css */
2
+ /* empty css */
3
+ var subContainerHeightVar = "var(--uv_plus_u4r1ts0)";
4
+ var skeletonHeightVar = "var(--uv_plus_u4r1ts1)";
5
+ var skeletonWidthVar = "var(--uv_plus_u4r1ts2)";
6
+ var activeClass = "uv_plus_u4r1ts3";
7
+ var cardClass = "uv_plus_u4r1ts4";
8
+ var iconContainer = "uv_plus_u4r1ts5";
9
+ var iconStack = { column: "uv_plus_u4r1ts6", row: "uv_plus_u4r1ts7" };
10
+ var subContainer = { column: "uv_plus_u4r1ts9 uv_plus_u4r1ts8", row: "uv_plus_u4r1tsa uv_plus_u4r1ts8", noHref: "uv_plus_u4r1tsb uv_plus_u4r1ts8" };
11
+ var imageClass = { column: "uv_plus_u4r1tsd uv_plus_u4r1tsc", row: "uv_plus_u4r1tse uv_plus_u4r1tsc" };
12
+ var fullHeight = "uv_plus_u4r1tsf";
13
+ var skeletonImage = { column: "uv_plus_u4r1tsh uv_plus_u4r1tsg", row: "uv_plus_u4r1tsi uv_plus_u4r1tsg" };
14
+ var paddedStack = "uv_plus_u4r1tsj";
15
+ export {
16
+ activeClass,
17
+ cardClass,
18
+ fullHeight,
19
+ iconContainer,
20
+ iconStack,
21
+ imageClass,
22
+ paddedStack,
23
+ skeletonHeightVar,
24
+ skeletonImage,
25
+ skeletonWidthVar,
26
+ subContainer,
27
+ subContainerHeightVar
28
+ };
package/dist/plus.css ADDED
@@ -0,0 +1 @@
1
+ @property --uv_plus_u4r1ts1{syntax: "*"; inherits: false; initial-value: auto;}@property --uv_plus_u4r1ts2{syntax: "*"; inherits: false; initial-value: auto;}.uv_plus_u4r1ts3:hover{border:1px solid var(--rwwhsl5o);box-shadow:var(--rwwhsl8c);cursor:pointer}.uv_plus_u4r1ts4{display:block;text-align:left;padding:0;color:var(--rwwhsl2j);text-decoration:none;border:1px solid var(--rwwhsl1v);border-radius:var(--rwwhsl85);background:var(--rwwhsl1i);overflow-wrap:break-word}.uv_plus_u4r1ts4[disabled]{cursor:not-allowed}.uv_plus_u4r1ts4[disabled]:hover{border:1px solid var(--rwwhsl1v);box-shadow:none}.uv_plus_u4r1ts5{display:flex;width:fit-content;background:var(--rwwhsl1r);padding:var(--rwwhsl9u);border-radius:var(--rwwhsl85)}.uv_plus_u4r1ts6{padding:0 var(--rwwhsl9w) var(--rwwhsl9w) var(--rwwhsl9w)}.uv_plus_u4r1ts7{padding:var(--rwwhsl9w) var(--rwwhsl9w) var(--rwwhsl9w) 0}.uv_plus_u4r1ts8{height:fit-content}.uv_plus_u4r1ts9{padding:var(--rwwhsl9w) var(--rwwhsl9w) 0 var(--rwwhsl9w)}.uv_plus_u4r1tsa{padding:var(--rwwhsl9w) 0 var(--rwwhsl9w) var(--rwwhsl9w)}.uv_plus_u4r1tsb{padding:var(--rwwhsl9w)}.uv_plus_u4r1tsc{object-fit:cover}.uv_plus_u4r1tsc[data-disabled]{filter:grayscale(1)}.uv_plus_u4r1tsd{border-radius:var(--rwwhsl85) var(--rwwhsl85) 0 0}.uv_plus_u4r1tse{border-radius:var(--rwwhsl85) 0 0 var(--rwwhsl85);max-height:var(--uv_plus_u4r1ts0)}.uv_plus_u4r1tsf{height:100%}.uv_plus_u4r1tsg{height:var(--uv_plus_u4r1ts1);width:var(--uv_plus_u4r1ts2)}.uv_plus_u4r1tsh{border-radius:var(--rwwhsl85) var(--rwwhsl85) 0 0}.uv_plus_u4r1tsi{border-radius:var(--rwwhsl85) 0 0 var(--rwwhsl85)}.uv_plus_u4r1tsj{padding:var(--rwwhsl9w)}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/plus",
3
- "version": "3.0.0-beta.6",
3
+ "version": "3.0.0-beta.7",
4
4
  "description": "Ultraviolet Plus",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -35,7 +35,8 @@
35
35
  "types": "./dist/index.d.ts",
36
36
  "require": "./dist/index.cjs",
37
37
  "default": "./dist/index.js"
38
- }
38
+ },
39
+ "./styles": "./dist/plus.css"
39
40
  },
40
41
  "size-limit": [
41
42
  {
@@ -55,7 +56,7 @@
55
56
  "@emotion/styled": "11.14.1",
56
57
  "react": "18.x || 19.x",
57
58
  "react-dom": "18.x || 19.x",
58
- "@ultraviolet/ui": "3.0.0-beta.17"
59
+ "@ultraviolet/ui": "3.0.0-beta.18"
59
60
  },
60
61
  "devDependencies": {
61
62
  "@babel/core": "7.28.4",
@@ -66,13 +67,15 @@
66
67
  "react": "19.1.1",
67
68
  "react-dom": "19.1.1",
68
69
  "@ultraviolet/illustrations": "6.0.0-beta.1",
69
- "@ultraviolet/ui": "3.0.0-beta.17",
70
+ "@ultraviolet/ui": "3.0.0-beta.18",
70
71
  "@utils/test": "0.0.1"
71
72
  },
72
73
  "dependencies": {
73
74
  "@uiw/codemirror-extensions-langs": "4.25.1",
74
75
  "@uiw/codemirror-theme-material": "4.25.1",
75
76
  "@uiw/react-codemirror": "4.25.1",
77
+ "@vanilla-extract/css": "1.17.4",
78
+ "@vanilla-extract/dynamic": "2.1.5",
76
79
  "csstype": "3.1.3",
77
80
  "react-intersection-observer": "9.16.0",
78
81
  "@ultraviolet/icons": "5.0.0-beta.4",
@@ -86,7 +89,7 @@
86
89
  "build:profile": "npx vite-bundle-visualizer -c vite.config.ts",
87
90
  "typecheck": "tsc --noEmit",
88
91
  "size": "size-limit",
89
- "test:unit": "LC_ALL=en_US.UTF-8 pnpm vitest --run --config vite.config.ts",
92
+ "test:unit": "LC_ALL=en_US.UTF-8 pnpm vitest --run --config vitest.config.ts",
90
93
  "test:unit:coverage": "pnpm test:unit --coverage",
91
94
  "lintpublish": "publint"
92
95
  }