@ultraviolet/plus 0.26.1 → 0.27.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -21,7 +21,7 @@ const StyledText = /* @__PURE__ */ _styled__default.default(ui.Text, process.env
21
21
  theme
22
22
  }) => `${theme.space["1"]} ${theme.space["2"]}`, ";border-radius:", ({
23
23
  theme
24
- }) => `${theme.radii.default}`, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29kZUVkaXRvci9Db2RlRWRpdG9yLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db2RlRWRpdG9yL0NvZGVFZGl0b3IudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgbGFuZ3MgfSBmcm9tICdAdWl3L2NvZGVtaXJyb3ItZXh0ZW5zaW9ucy1sYW5ncydcbmltcG9ydCB7IG1hdGVyaWFsIH0gZnJvbSAnQHVpdy9jb2RlbWlycm9yLXRoZW1lLW1hdGVyaWFsJ1xuaW1wb3J0IENvZGVNaXJyb3IgZnJvbSAnQHVpdy9yZWFjdC1jb2RlbWlycm9yJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH1gfTtcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbnR5cGUgQ29kZUVkaXRvclByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nXG4gIG9uQ2hhbmdlOiBDb21wb25lbnRQcm9wczx0eXBlb2YgQ29kZU1pcnJvcj5bJ29uQ2hhbmdlJ11cbiAgZXh0ZW5zaW9uczoga2V5b2YgdHlwZW9mIGxhbmdzXG4gIG9uQmx1cj86ICgpID0+IHZvaWRcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIHJlYWRPbmx5PzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgQ29kZUVkaXRvciA9ICh7XG4gIHRpdGxlLFxuICB2YWx1ZSxcbiAgb25DaGFuZ2UsXG4gIGV4dGVuc2lvbnMgPSAnamF2YXNjcmlwdCcsXG4gIG9uQmx1cixcbiAgaGVpZ2h0LFxuICByZWFkT25seSxcbn06IENvZGVFZGl0b3JQcm9wcykgPT4gKFxuICA8ZGl2PlxuICAgIHt0aXRsZSA/IChcbiAgICAgIDxTdHlsZWRUZXh0IGFzPVwiaDNcIiB2YXJpYW50PVwiaGVhZGluZ1NtYWxsXCI+XG4gICAgICAgIHt0aXRsZX1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICApIDogbnVsbH1cbiAgICA8Q29kZU1pcnJvclxuICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgd2lkdGg9XCIxMDAlXCJcbiAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgdGhlbWU9e21hdGVyaWFsfVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgZXh0ZW5zaW9ucz17W2xhbmdzW2V4dGVuc2lvbnNdKCldfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBiYXNpY1NldHVwPXt7XG4gICAgICAgIGhpZ2hsaWdodEFjdGl2ZUxpbmU6IGZhbHNlLFxuICAgICAgICBoaWdobGlnaHRBY3RpdmVMaW5lR3V0dGVyOiBmYWxzZSxcbiAgICAgIH19XG4gICAgLz5cbiAgPC9kaXY+XG4pXG4iXX0= */"));
24
+ }) => `${theme.radii.default}`, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29kZUVkaXRvci9Db2RlRWRpdG9yLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db2RlRWRpdG9yL0NvZGVFZGl0b3IudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgbGFuZ3MgfSBmcm9tICdAdWl3L2NvZGVtaXJyb3ItZXh0ZW5zaW9ucy1sYW5ncydcbmltcG9ydCB7IG1hdGVyaWFsIH0gZnJvbSAnQHVpdy9jb2RlbWlycm9yLXRoZW1lLW1hdGVyaWFsJ1xuaW1wb3J0IENvZGVNaXJyb3IgZnJvbSAnQHVpdy9yZWFjdC1jb2RlbWlycm9yJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH1gfTtcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbnR5cGUgQ29kZUVkaXRvclByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nXG4gIG9uQ2hhbmdlOiBDb21wb25lbnRQcm9wczx0eXBlb2YgQ29kZU1pcnJvcj5bJ29uQ2hhbmdlJ11cbiAgZXh0ZW5zaW9uczoga2V5b2YgdHlwZW9mIGxhbmdzXG4gIG9uQmx1cj86ICgpID0+IHZvaWRcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIHJlYWRPbmx5PzogYm9vbGVhblxuICBhdXRvQ29tcGxldGlvbj86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IENvZGVFZGl0b3IgPSAoe1xuICB0aXRsZSxcbiAgdmFsdWUsXG4gIG9uQ2hhbmdlLFxuICBleHRlbnNpb25zID0gJ2phdmFzY3JpcHQnLFxuICBvbkJsdXIsXG4gIGhlaWdodCxcbiAgcmVhZE9ubHksXG4gIGF1dG9Db21wbGV0aW9uLFxufTogQ29kZUVkaXRvclByb3BzKSA9PiAoXG4gIDxkaXY+XG4gICAge3RpdGxlID8gKFxuICAgICAgPFN0eWxlZFRleHQgYXM9XCJoM1wiIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxcIj5cbiAgICAgICAge3RpdGxlfVxuICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICkgOiBudWxsfVxuICAgIDxDb2RlTWlycm9yXG4gICAgICByZWFkT25seT17cmVhZE9ubHl9XG4gICAgICB3aWR0aD1cIjEwMCVcIlxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICB0aGVtZT17bWF0ZXJpYWx9XG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICBleHRlbnNpb25zPXtbbGFuZ3NbZXh0ZW5zaW9uc10oKV19XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgIGJhc2ljU2V0dXA9e3tcbiAgICAgICAgaGlnaGxpZ2h0QWN0aXZlTGluZTogZmFsc2UsXG4gICAgICAgIGhpZ2hsaWdodEFjdGl2ZUxpbmVHdXR0ZXI6IGZhbHNlLFxuICAgICAgICBhdXRvY29tcGxldGlvbjogYXV0b0NvbXBsZXRpb24sXG4gICAgICB9fVxuICAgIC8+XG4gIDwvZGl2PlxuKVxuIl19 */"));
25
25
  const CodeEditor = ({
26
26
  title,
27
27
  value,
@@ -29,12 +29,14 @@ const CodeEditor = ({
29
29
  extensions = "javascript",
30
30
  onBlur,
31
31
  height,
32
- readOnly
32
+ readOnly,
33
+ autoCompletion
33
34
  }) => /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
34
35
  title ? /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "h3", variant: "headingSmall", children: title }) : null,
35
36
  /* @__PURE__ */ jsxRuntime.jsx(CodeMirror__default.default, { readOnly, width: "100%", height, theme: codemirrorThemeMaterial.material, onChange, value, extensions: [codemirrorExtensionsLangs.langs[extensions]()], onBlur, basicSetup: {
36
37
  highlightActiveLine: false,
37
- highlightActiveLineGutter: false
38
+ highlightActiveLineGutter: false,
39
+ autocompletion: autoCompletion
38
40
  } })
39
41
  ] });
40
42
  exports.CodeEditor = CodeEditor;
@@ -9,6 +9,7 @@ type CodeEditorProps = {
9
9
  onBlur?: () => void;
10
10
  height?: string;
11
11
  readOnly?: boolean;
12
+ autoCompletion?: boolean;
12
13
  };
13
- export declare const CodeEditor: ({ title, value, onChange, extensions, onBlur, height, readOnly, }: CodeEditorProps) => import("@emotion/react/jsx-runtime").JSX.Element;
14
+ export declare const CodeEditor: ({ title, value, onChange, extensions, onBlur, height, readOnly, autoCompletion, }: CodeEditorProps) => import("@emotion/react/jsx-runtime").JSX.Element;
14
15
  export {};
@@ -16,7 +16,7 @@ const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
16
16
  theme
17
17
  }) => `${theme.space["1"]} ${theme.space["2"]}`, ";border-radius:", ({
18
18
  theme
19
- }) => `${theme.radii.default}`, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29kZUVkaXRvci9Db2RlRWRpdG9yLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db2RlRWRpdG9yL0NvZGVFZGl0b3IudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgbGFuZ3MgfSBmcm9tICdAdWl3L2NvZGVtaXJyb3ItZXh0ZW5zaW9ucy1sYW5ncydcbmltcG9ydCB7IG1hdGVyaWFsIH0gZnJvbSAnQHVpdy9jb2RlbWlycm9yLXRoZW1lLW1hdGVyaWFsJ1xuaW1wb3J0IENvZGVNaXJyb3IgZnJvbSAnQHVpdy9yZWFjdC1jb2RlbWlycm9yJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH1gfTtcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbnR5cGUgQ29kZUVkaXRvclByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nXG4gIG9uQ2hhbmdlOiBDb21wb25lbnRQcm9wczx0eXBlb2YgQ29kZU1pcnJvcj5bJ29uQ2hhbmdlJ11cbiAgZXh0ZW5zaW9uczoga2V5b2YgdHlwZW9mIGxhbmdzXG4gIG9uQmx1cj86ICgpID0+IHZvaWRcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIHJlYWRPbmx5PzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgQ29kZUVkaXRvciA9ICh7XG4gIHRpdGxlLFxuICB2YWx1ZSxcbiAgb25DaGFuZ2UsXG4gIGV4dGVuc2lvbnMgPSAnamF2YXNjcmlwdCcsXG4gIG9uQmx1cixcbiAgaGVpZ2h0LFxuICByZWFkT25seSxcbn06IENvZGVFZGl0b3JQcm9wcykgPT4gKFxuICA8ZGl2PlxuICAgIHt0aXRsZSA/IChcbiAgICAgIDxTdHlsZWRUZXh0IGFzPVwiaDNcIiB2YXJpYW50PVwiaGVhZGluZ1NtYWxsXCI+XG4gICAgICAgIHt0aXRsZX1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICApIDogbnVsbH1cbiAgICA8Q29kZU1pcnJvclxuICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgd2lkdGg9XCIxMDAlXCJcbiAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgdGhlbWU9e21hdGVyaWFsfVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgZXh0ZW5zaW9ucz17W2xhbmdzW2V4dGVuc2lvbnNdKCldfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBiYXNpY1NldHVwPXt7XG4gICAgICAgIGhpZ2hsaWdodEFjdGl2ZUxpbmU6IGZhbHNlLFxuICAgICAgICBoaWdobGlnaHRBY3RpdmVMaW5lR3V0dGVyOiBmYWxzZSxcbiAgICAgIH19XG4gICAgLz5cbiAgPC9kaXY+XG4pXG4iXX0= */"));
19
+ }) => `${theme.radii.default}`, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29kZUVkaXRvci9Db2RlRWRpdG9yLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db2RlRWRpdG9yL0NvZGVFZGl0b3IudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgbGFuZ3MgfSBmcm9tICdAdWl3L2NvZGVtaXJyb3ItZXh0ZW5zaW9ucy1sYW5ncydcbmltcG9ydCB7IG1hdGVyaWFsIH0gZnJvbSAnQHVpdy9jb2RlbWlycm9yLXRoZW1lLW1hdGVyaWFsJ1xuaW1wb3J0IENvZGVNaXJyb3IgZnJvbSAnQHVpdy9yZWFjdC1jb2RlbWlycm9yJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH1gfTtcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbnR5cGUgQ29kZUVkaXRvclByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nXG4gIG9uQ2hhbmdlOiBDb21wb25lbnRQcm9wczx0eXBlb2YgQ29kZU1pcnJvcj5bJ29uQ2hhbmdlJ11cbiAgZXh0ZW5zaW9uczoga2V5b2YgdHlwZW9mIGxhbmdzXG4gIG9uQmx1cj86ICgpID0+IHZvaWRcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIHJlYWRPbmx5PzogYm9vbGVhblxuICBhdXRvQ29tcGxldGlvbj86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IENvZGVFZGl0b3IgPSAoe1xuICB0aXRsZSxcbiAgdmFsdWUsXG4gIG9uQ2hhbmdlLFxuICBleHRlbnNpb25zID0gJ2phdmFzY3JpcHQnLFxuICBvbkJsdXIsXG4gIGhlaWdodCxcbiAgcmVhZE9ubHksXG4gIGF1dG9Db21wbGV0aW9uLFxufTogQ29kZUVkaXRvclByb3BzKSA9PiAoXG4gIDxkaXY+XG4gICAge3RpdGxlID8gKFxuICAgICAgPFN0eWxlZFRleHQgYXM9XCJoM1wiIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxcIj5cbiAgICAgICAge3RpdGxlfVxuICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICkgOiBudWxsfVxuICAgIDxDb2RlTWlycm9yXG4gICAgICByZWFkT25seT17cmVhZE9ubHl9XG4gICAgICB3aWR0aD1cIjEwMCVcIlxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICB0aGVtZT17bWF0ZXJpYWx9XG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICBleHRlbnNpb25zPXtbbGFuZ3NbZXh0ZW5zaW9uc10oKV19XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgIGJhc2ljU2V0dXA9e3tcbiAgICAgICAgaGlnaGxpZ2h0QWN0aXZlTGluZTogZmFsc2UsXG4gICAgICAgIGhpZ2hsaWdodEFjdGl2ZUxpbmVHdXR0ZXI6IGZhbHNlLFxuICAgICAgICBhdXRvY29tcGxldGlvbjogYXV0b0NvbXBsZXRpb24sXG4gICAgICB9fVxuICAgIC8+XG4gIDwvZGl2PlxuKVxuIl19 */"));
20
20
  const CodeEditor = ({
21
21
  title,
22
22
  value,
@@ -24,12 +24,14 @@ const CodeEditor = ({
24
24
  extensions = "javascript",
25
25
  onBlur,
26
26
  height,
27
- readOnly
27
+ readOnly,
28
+ autoCompletion
28
29
  }) => /* @__PURE__ */ jsxs("div", { children: [
29
30
  title ? /* @__PURE__ */ jsx(StyledText, { as: "h3", variant: "headingSmall", children: title }) : null,
30
31
  /* @__PURE__ */ jsx(CodeMirror, { readOnly, width: "100%", height, theme: material, onChange, value, extensions: [langs[extensions]()], onBlur, basicSetup: {
31
32
  highlightActiveLine: false,
32
- highlightActiveLineGutter: false
33
+ highlightActiveLineGutter: false,
34
+ autocompletion: autoCompletion
33
35
  } })
34
36
  ] });
35
37
  export {
@@ -13,7 +13,7 @@ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
13
  function _EMOTION_STRINGIFIED_CSS_ERROR__() {
14
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
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */");
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */");
17
17
  const Card = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
18
18
  target: "e2ipnt5"
19
19
  } : {
@@ -33,7 +33,7 @@ const Card = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_EN
33
33
  theme
34
34
  }) => onClick || href ? activeStyle(theme) : null, ";overflow-wrap:break-word;&[disabled]{cursor:not-allowed;&:hover{border:1px solid ", ({
35
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
37
37
  const IconContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
38
38
  target: "e2ipnt4"
39
39
  } : {
@@ -45,7 +45,7 @@ const IconContainer = /* @__PURE__ */ _styled__default.default("div", process.en
45
45
  theme
46
46
  }) => theme.space["1"], ";border-radius:", ({
47
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
49
49
  const StyledIconStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
50
50
  shouldForwardProp: (prop) => prop !== "direction",
51
51
  target: "e2ipnt3"
@@ -56,7 +56,7 @@ const StyledIconStack = /* @__PURE__ */ _styled__default.default(ui.Stack, proce
56
56
  })("padding:", ({
57
57
  theme,
58
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
60
60
  const SubContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
61
61
  shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
62
62
  target: "e2ipnt2"
@@ -70,7 +70,7 @@ const SubContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.
70
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
71
  theme,
72
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
74
74
  const Image = /* @__PURE__ */ _styled__default.default("img", process.env.NODE_ENV === "production" ? {
75
75
  shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
76
76
  target: "e2ipnt1"
@@ -84,7 +84,7 @@ const Image = /* @__PURE__ */ _styled__default.default("img", process.env.NODE_E
84
84
  }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";", ({
85
85
  direction,
86
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
88
88
  const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
89
89
  target: "e2ipnt0"
90
90
  } : {
@@ -95,7 +95,7 @@ const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, proce
95
95
  styles: "height:100%"
96
96
  } : {
97
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */",
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */",
99
99
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
100
100
  });
101
101
  const ContentCard = react.forwardRef(({
@@ -139,7 +139,7 @@ const ContentCard = react.forwardRef(({
139
139
  return /* @__PURE__ */ jsxRuntime.jsx(Container, { target, onClick: !disabled ? onClick : void 0, href: !disabled ? href : void 0, role: onClick && !href ? "button" : void 0, ref, className, disabled, children: loading ? /* @__PURE__ */ jsxRuntime.jsx(Skeleton.Skeleton, { direction }) : /* @__PURE__ */ jsxRuntime.jsxs(FullHeightStack, { direction, children: [
140
140
  image ? /* @__PURE__ */ jsxRuntime.jsx(Image, { alt: "", src: image, height: direction === "column" ? 120 : void 0, width: direction === "row" ? 220 : void 0, direction, subContainerHeight, "data-disabled": disabled }) : null,
141
141
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 2, direction, flex: 1, children: [
142
- /* @__PURE__ */ jsxRuntime.jsxs(SubContainer, { gap: 2, flex: "1 1 auto", direction, href, ref: subContainerRef, children: [
142
+ /* @__PURE__ */ jsxRuntime.jsxs(SubContainer, { gap: 2, flex: "1 1 auto", alignItems: !subtitle && !description && !children ? "center" : void 0, direction, href, ref: subContainerRef, children: [
143
143
  icon ?? null,
144
144
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 2, justifyContent: "space-between", flex: "1 1 auto", children: [
145
145
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 0.5, children: [
@@ -9,7 +9,7 @@ import { Skeleton } from "./Skeleton.js";
9
9
  function _EMOTION_STRINGIFIED_CSS_ERROR__() {
10
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
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */");
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */");
13
13
  const Card = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
14
14
  target: "e2ipnt5"
15
15
  } : {
@@ -29,7 +29,7 @@ const Card = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production
29
29
  theme
30
30
  }) => onClick || href ? activeStyle(theme) : null, ";overflow-wrap:break-word;&[disabled]{cursor:not-allowed;&:hover{border:1px solid ", ({
31
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
33
33
  const IconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
34
34
  target: "e2ipnt4"
35
35
  } : {
@@ -41,7 +41,7 @@ const IconContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "p
41
41
  theme
42
42
  }) => theme.space["1"], ";border-radius:", ({
43
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
45
45
  const StyledIconStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
46
46
  shouldForwardProp: (prop) => prop !== "direction",
47
47
  target: "e2ipnt3"
@@ -52,7 +52,7 @@ const StyledIconStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV ===
52
52
  })("padding:", ({
53
53
  theme,
54
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
56
56
  const SubContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
57
57
  shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
58
58
  target: "e2ipnt2"
@@ -66,7 +66,7 @@ const SubContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pr
66
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
67
  theme,
68
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
70
70
  const Image = /* @__PURE__ */ _styled("img", process.env.NODE_ENV === "production" ? {
71
71
  shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
72
72
  target: "e2ipnt1"
@@ -80,7 +80,7 @@ const Image = /* @__PURE__ */ _styled("img", process.env.NODE_ENV === "productio
80
80
  }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";", ({
81
81
  direction,
82
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
84
84
  const FullHeightStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
85
85
  target: "e2ipnt0"
86
86
  } : {
@@ -91,7 +91,7 @@ const FullHeightStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV ===
91
91
  styles: "height:100%"
92
92
  } : {
93
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */",
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        target={target}\n        onClick={!disabled ? onClick : undefined}\n        href={!disabled ? href : undefined}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\n        disabled={disabled}\n      >\n        {loading ? (\n          <Skeleton direction={direction} />\n        ) : (\n          <FullHeightStack direction={direction}>\n            {image ? (\n              <Image\n                alt=\"\"\n                src={image}\n                height={direction === 'column' ? 120 : undefined}\n                width={direction === 'row' ? 220 : undefined}\n                direction={direction}\n                subContainerHeight={subContainerHeight}\n                data-disabled={disabled}\n              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                flex=\"1 1 auto\"\n                alignItems={\n                  !subtitle && !description && !children ? 'center' : undefined\n                }\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"space-between\" flex=\"1 1 auto\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                          disabled={disabled}\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text\n                        as={headingTag}\n                        variant=\"bodyStrong\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text\n                        as=\"p\"\n                        variant=\"bodySmall\"\n                        sentiment=\"neutral\"\n                        disabled={disabled}\n                      >\n                        {description}\n                      </Text>\n                    ) : null}\n                  </Stack>\n                  {children ? <Stack>{children}</Stack> : null}\n                </Stack>\n              </SubContainer>\n              {href ? (\n                <StyledIconStack\n                  flex={1}\n                  alignItems={direction === 'column' ? 'flex-end' : 'center'}\n                  justifyContent={direction === 'column' ? 'center' : 'end'}\n                  direction={direction}\n                >\n                  <IconContainer>\n                    <OpenInNewIcon sentiment=\"neutral\" disabled={disabled} />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */",
95
95
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
96
96
  });
97
97
  const ContentCard = forwardRef(({
@@ -135,7 +135,7 @@ const ContentCard = forwardRef(({
135
135
  return /* @__PURE__ */ jsx(Container, { target, onClick: !disabled ? onClick : void 0, href: !disabled ? href : void 0, role: onClick && !href ? "button" : void 0, ref, className, disabled, children: loading ? /* @__PURE__ */ jsx(Skeleton, { direction }) : /* @__PURE__ */ jsxs(FullHeightStack, { direction, children: [
136
136
  image ? /* @__PURE__ */ jsx(Image, { alt: "", src: image, height: direction === "column" ? 120 : void 0, width: direction === "row" ? 220 : void 0, direction, subContainerHeight, "data-disabled": disabled }) : null,
137
137
  /* @__PURE__ */ jsxs(Stack, { gap: 2, direction, flex: 1, children: [
138
- /* @__PURE__ */ jsxs(SubContainer, { gap: 2, flex: "1 1 auto", direction, href, ref: subContainerRef, children: [
138
+ /* @__PURE__ */ jsxs(SubContainer, { gap: 2, flex: "1 1 auto", alignItems: !subtitle && !description && !children ? "center" : void 0, direction, href, ref: subContainerRef, children: [
139
139
  icon ?? null,
140
140
  /* @__PURE__ */ jsxs(Stack, { gap: 2, justifyContent: "space-between", flex: "1 1 auto", children: [
141
141
  /* @__PURE__ */ jsxs(Stack, { gap: 0.5, children: [
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/plus",
3
- "version": "0.26.1",
3
+ "version": "0.27.0",
4
4
  "description": "Ultraviolet Plus",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -72,9 +72,9 @@
72
72
  "@uiw/codemirror-theme-material": "4.23.10",
73
73
  "@uiw/react-codemirror": "4.23.10",
74
74
  "react-intersection-observer": "9.16.0",
75
- "@ultraviolet/icons": "3.14.0",
75
+ "@ultraviolet/icons": "3.15.0",
76
76
  "@ultraviolet/themes": "1.17.0",
77
- "@ultraviolet/ui": "1.94.0"
77
+ "@ultraviolet/ui": "1.94.1"
78
78
  },
79
79
  "scripts": {
80
80
  "type:generate": "tsc --declaration -p tsconfig.build.json",