@ultraviolet/plus 0.15.2 → 0.15.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/dist/components/CodeEditor/CodeEditor.cjs +39 -0
  2. package/dist/components/ContentCard/Skeleton.cjs +43 -0
  3. package/dist/components/ContentCard/index.cjs +154 -0
  4. package/dist/components/ContentCardGroup/Card.cjs +93 -0
  5. package/dist/components/ContentCardGroup/SkeletonCard.cjs +34 -0
  6. package/dist/components/ContentCardGroup/index.cjs +33 -0
  7. package/dist/components/Conversation/index.cjs +128 -0
  8. package/dist/components/CustomerSatisfaction/assets/1-5.svg.cjs +3 -0
  9. package/dist/components/CustomerSatisfaction/assets/1-5NB.svg.cjs +3 -0
  10. package/dist/components/CustomerSatisfaction/assets/2-5.svg.cjs +3 -0
  11. package/dist/components/CustomerSatisfaction/assets/2-5NB.svg.cjs +3 -0
  12. package/dist/components/CustomerSatisfaction/assets/3-5.svg.cjs +3 -0
  13. package/dist/components/CustomerSatisfaction/assets/3-5NB.svg.cjs +3 -0
  14. package/dist/components/CustomerSatisfaction/assets/4-5.svg.cjs +3 -0
  15. package/dist/components/CustomerSatisfaction/assets/4-5NB.svg.cjs +3 -0
  16. package/dist/components/CustomerSatisfaction/assets/5-5.svg.cjs +3 -0
  17. package/dist/components/CustomerSatisfaction/assets/5-5NB.svg.cjs +3 -0
  18. package/dist/components/CustomerSatisfaction/index.cjs +123 -0
  19. package/dist/components/EstimateCost/Components/CustomUnitInput.cjs +33 -0
  20. package/dist/components/EstimateCost/Components/Item.cjs +303 -0
  21. package/dist/components/EstimateCost/Components/LineThrough.cjs +18 -0
  22. package/dist/components/EstimateCost/Components/NumberInput.cjs +29 -0
  23. package/dist/components/EstimateCost/Components/Region.cjs +41 -0
  24. package/dist/components/EstimateCost/Components/Regular.cjs +35 -0
  25. package/dist/components/EstimateCost/Components/Strong.cjs +28 -0
  26. package/dist/components/EstimateCost/Components/Unit.cjs +50 -0
  27. package/dist/components/EstimateCost/Components/UnitInput.cjs +90 -0
  28. package/dist/components/EstimateCost/Components/Zone.cjs +40 -0
  29. package/dist/components/EstimateCost/EstimateCost.cjs +88 -0
  30. package/dist/components/EstimateCost/EstimateCostContent.cjs +245 -0
  31. package/dist/components/EstimateCost/EstimateCostProvider.cjs +36 -0
  32. package/dist/components/EstimateCost/OverlayComponent.cjs +122 -0
  33. package/dist/components/EstimateCost/OverlayContext.cjs +14 -0
  34. package/dist/components/EstimateCost/componentStyle.cjs +230 -0
  35. package/dist/components/EstimateCost/constants.cjs +30 -0
  36. package/dist/components/EstimateCost/helper.cjs +19 -0
  37. package/dist/components/EstimateCost/locales/en.cjs +23 -0
  38. package/dist/components/FAQ/index.cjs +36 -0
  39. package/dist/components/Navigation/Navigation.cjs +20 -0
  40. package/dist/components/Navigation/Navigation.d.ts +4 -3
  41. package/dist/components/Navigation/NavigationContent.cjs +216 -0
  42. package/dist/components/Navigation/NavigationProvider.cjs +111 -0
  43. package/dist/components/Navigation/NavigationProvider.d.ts +7 -18
  44. package/dist/components/Navigation/NavigationProvider.js +18 -16
  45. package/dist/components/Navigation/components/Group.cjs +57 -0
  46. package/dist/components/Navigation/components/Item.cjs +438 -0
  47. package/dist/components/Navigation/components/Item.d.ts +4 -3
  48. package/dist/components/Navigation/components/Item.js +34 -23
  49. package/dist/components/Navigation/components/PinnedItems.cjs +108 -0
  50. package/dist/components/Navigation/components/PinnedItems.d.ts +5 -1
  51. package/dist/components/Navigation/components/PinnedItems.js +11 -8
  52. package/dist/components/Navigation/components/Separator.cjs +17 -0
  53. package/dist/components/Navigation/constants.cjs +37 -0
  54. package/dist/components/Navigation/constants.d.ts +14 -0
  55. package/dist/components/Navigation/index.d.ts +1 -0
  56. package/dist/components/Navigation/locales/en.cjs +11 -0
  57. package/dist/components/SteppedListCard/Step.cjs +37 -0
  58. package/dist/components/SteppedListCard/SteppedListContainer.cjs +80 -0
  59. package/dist/components/SteppedListCard/SteppedListContent.cjs +67 -0
  60. package/dist/components/SteppedListCard/helper.cjs +37 -0
  61. package/dist/components/index.d.ts +1 -0
  62. package/dist/index.cjs +25 -0
  63. package/package.json +23 -7
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const codemirrorExtensionsLangs = require("@uiw/codemirror-extensions-langs");
6
+ const codemirrorThemeMaterial = require("@uiw/codemirror-theme-material");
7
+ const CodeMirror = require("@uiw/react-codemirror");
8
+ const ui = require("@ultraviolet/ui");
9
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
+ const CodeMirror__default = /* @__PURE__ */ _interopDefaultCompat(CodeMirror);
12
+ const StyledText = /* @__PURE__ */ _styled__default.default(ui.Text, process.env.NODE_ENV === "production" ? {
13
+ target: "e13pskxy0"
14
+ } : {
15
+ target: "e13pskxy0",
16
+ label: "StyledText"
17
+ })("background-color:", ({
18
+ theme
19
+ }) => theme.colors.neutral.backgroundStrong, ";padding:", ({
20
+ theme
21
+ }) => `${theme.space["1"]} ${theme.space["2"]}`, ";border-radius:", ({
22
+ theme
23
+ }) => theme.radii.default, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29kZUVkaXRvci9Db2RlRWRpdG9yLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db2RlRWRpdG9yL0NvZGVFZGl0b3IudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBsYW5ncyB9IGZyb20gJ0B1aXcvY29kZW1pcnJvci1leHRlbnNpb25zLWxhbmdzJ1xuaW1wb3J0IHsgbWF0ZXJpYWwgfSBmcm9tICdAdWl3L2NvZGVtaXJyb3ItdGhlbWUtbWF0ZXJpYWwnXG5pbXBvcnQgQ29kZU1pcnJvciBmcm9tICdAdWl3L3JlYWN0LWNvZGVtaXJyb3InXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRTdHJvbmd9O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IGAke3RoZW1lLnNwYWNlWycxJ119ICR7dGhlbWUuc3BhY2VbJzInXX1gfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbnR5cGUgQ29kZUVkaXRvclByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nXG4gIG9uQ2hhbmdlOiBDb21wb25lbnRQcm9wczx0eXBlb2YgQ29kZU1pcnJvcj5bJ29uQ2hhbmdlJ11cbiAgZXh0ZW5zaW9uczoga2V5b2YgdHlwZW9mIGxhbmdzXG4gIG9uQmx1cj86ICgpID0+IHZvaWRcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIHJlYWRPbmx5PzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgQ29kZUVkaXRvciA9ICh7XG4gIHRpdGxlLFxuICB2YWx1ZSxcbiAgb25DaGFuZ2UsXG4gIGV4dGVuc2lvbnMgPSAnamF2YXNjcmlwdCcsXG4gIG9uQmx1cixcbiAgaGVpZ2h0LFxuICByZWFkT25seSxcbn06IENvZGVFZGl0b3JQcm9wcykgPT4gKFxuICA8ZGl2PlxuICAgIHt0aXRsZSA/IChcbiAgICAgIDxTdHlsZWRUZXh0IGFzPVwiaDNcIiB2YXJpYW50PVwiaGVhZGluZ1NtYWxsXCI+XG4gICAgICAgIHt0aXRsZX1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICApIDogbnVsbH1cbiAgICA8Q29kZU1pcnJvclxuICAgICAgcmVhZE9ubHk9e3JlYWRPbmx5fVxuICAgICAgd2lkdGg9XCIxMDAlXCJcbiAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgdGhlbWU9e21hdGVyaWFsfVxuICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgZXh0ZW5zaW9ucz17W2xhbmdzW2V4dGVuc2lvbnNdKCldfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBiYXNpY1NldHVwPXt7XG4gICAgICAgIGhpZ2hsaWdodEFjdGl2ZUxpbmU6IGZhbHNlLFxuICAgICAgICBoaWdobGlnaHRBY3RpdmVMaW5lR3V0dGVyOiBmYWxzZSxcbiAgICAgIH19XG4gICAgLz5cbiAgPC9kaXY+XG4pXG4iXX0= */"));
24
+ const CodeEditor = ({
25
+ title,
26
+ value,
27
+ onChange,
28
+ extensions = "javascript",
29
+ onBlur,
30
+ height,
31
+ readOnly
32
+ }) => /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
33
+ title ? /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "h3", variant: "headingSmall", children: title }) : null,
34
+ /* @__PURE__ */ jsxRuntime.jsx(CodeMirror__default.default, { readOnly, width: "100%", height, theme: codemirrorThemeMaterial.material, onChange, value, extensions: [codemirrorExtensionsLangs.langs[extensions]()], onBlur, basicSetup: {
35
+ highlightActiveLine: false,
36
+ highlightActiveLineGutter: false
37
+ } })
38
+ ] });
39
+ exports.CodeEditor = CodeEditor;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const ui = require("@ultraviolet/ui");
6
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
7
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
8
+ const SkeletonImage = /* @__PURE__ */ _styled__default.default(ui.Skeleton, process.env.NODE_ENV === "production" ? {
9
+ shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
10
+ target: "e1wwr9dc1"
11
+ } : {
12
+ shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
13
+ target: "e1wwr9dc1",
14
+ label: "SkeletonImage"
15
+ })("border-radius:", ({
16
+ theme,
17
+ direction
18
+ }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";width:", ({
19
+ width
20
+ }) => width, ";height:", ({
21
+ height
22
+ }) => height, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVNFIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgU2tlbGV0b24gYXMgVWx0cmF2aW9sZXRTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcblxuY29uc3QgU2tlbGV0b25JbWFnZSA9IHN0eWxlZChVbHRyYXZpb2xldFNrZWxldG9uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2hlaWdodCcsICd3aWR0aCcsICdkaXJlY3Rpb24nXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgd2lkdGg/OiBzdHJpbmdcbiAgaGVpZ2h0Pzogc3RyaW5nXG4gIGRpcmVjdGlvbjogJ3JvdycgfCAnY29sdW1uJ1xufT5gXG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUsIGRpcmVjdGlvbiB9KSA9PlxuICAgIGAke1xuICAgICAgZGlyZWN0aW9uID09PSAnY29sdW1uJ1xuICAgICAgICA/IGAke3RoZW1lLnJhZGlpLmRlZmF1bHR9ICR7dGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwYFxuICAgICAgICA6IGAke3RoZW1lLnJhZGlpLmRlZmF1bHR9IDAgMCAke3RoZW1lLnJhZGlpLmRlZmF1bHR9YFxuICAgIH1gfTtcbiAgd2lkdGg6ICR7KHsgd2lkdGggfSkgPT4gd2lkdGh9O1xuICBoZWlnaHQ6ICR7KHsgaGVpZ2h0IH0pID0+IGhlaWdodH07XG5gXG5cbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbmBcblxudHlwZSBTa2VsZXRvblByb3BzID0ge1xuICBkaXJlY3Rpb246ICdyb3cnIHwgJ2NvbHVtbidcbn1cblxuZXhwb3J0IGNvbnN0IFNrZWxldG9uID0gKHsgZGlyZWN0aW9uIH06IFNrZWxldG9uUHJvcHMpID0+IChcbiAgPFN0YWNrIGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICA8U2tlbGV0b25JbWFnZVxuICAgICAgdmFyaWFudD1cInNxdWFyZVwiXG4gICAgICBoZWlnaHQ9e2RpcmVjdGlvbiA9PT0gJ2NvbHVtbicgPyAnMTIwcHgnIDogJ3Vuc2V0J31cbiAgICAgIHdpZHRoPXtkaXJlY3Rpb24gPT09ICdyb3cnID8gJzIyMHB4JyA6IHVuZGVmaW5lZH1cbiAgICAgIGRpcmVjdGlvbj17ZGlyZWN0aW9ufVxuICAgIC8+XG4gICAgPFN0eWxlZFN0YWNrIGdhcD17Mn0+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgICA8VWx0cmF2aW9sZXRTa2VsZXRvbiB2YXJpYW50PVwibGluZVwiIC8+XG4gICAgPC9TdHlsZWRTdGFjaz5cbiAgPC9TdGFjaz5cbilcbiJdfQ== */"));
23
+ const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
24
+ target: "e1wwr9dc0"
25
+ } : {
26
+ target: "e1wwr9dc0",
27
+ label: "StyledStack"
28
+ })("padding:", ({
29
+ theme
30
+ }) => theme.space["3"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9CaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db250ZW50Q2FyZC9Ta2VsZXRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFN0YWNrLCBTa2VsZXRvbiBhcyBVbHRyYXZpb2xldFNrZWxldG9uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuXG5jb25zdCBTa2VsZXRvbkltYWdlID0gc3R5bGVkKFVsdHJhdmlvbGV0U2tlbGV0b24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnaGVpZ2h0JywgJ3dpZHRoJywgJ2RpcmVjdGlvbiddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICB3aWR0aD86IHN0cmluZ1xuICBoZWlnaHQ/OiBzdHJpbmdcbiAgZGlyZWN0aW9uOiAncm93JyB8ICdjb2x1bW4nXG59PmBcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSwgZGlyZWN0aW9uIH0pID0+XG4gICAgYCR7XG4gICAgICBkaXJlY3Rpb24gPT09ICdjb2x1bW4nXG4gICAgICAgID8gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH0gJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAwIDBgXG4gICAgICAgIDogYCR7dGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwICR7dGhlbWUucmFkaWkuZGVmYXVsdH1gXG4gICAgfWB9O1xuICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aH07XG4gIGhlaWdodDogJHsoeyBoZWlnaHQgfSkgPT4gaGVpZ2h0fTtcbmBcblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyczJ119O1xuYFxuXG50eXBlIFNrZWxldG9uUHJvcHMgPSB7XG4gIGRpcmVjdGlvbjogJ3JvdycgfCAnY29sdW1uJ1xufVxuXG5leHBvcnQgY29uc3QgU2tlbGV0b24gPSAoeyBkaXJlY3Rpb24gfTogU2tlbGV0b25Qcm9wcykgPT4gKFxuICA8U3RhY2sgZGlyZWN0aW9uPXtkaXJlY3Rpb259PlxuICAgIDxTa2VsZXRvbkltYWdlXG4gICAgICB2YXJpYW50PVwic3F1YXJlXCJcbiAgICAgIGhlaWdodD17ZGlyZWN0aW9uID09PSAnY29sdW1uJyA/ICcxMjBweCcgOiAndW5zZXQnfVxuICAgICAgd2lkdGg9e2RpcmVjdGlvbiA9PT0gJ3JvdycgPyAnMjIwcHgnIDogdW5kZWZpbmVkfVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgLz5cbiAgICA8U3R5bGVkU3RhY2sgZ2FwPXsyfT5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICA8L1N0eWxlZFN0YWNrPlxuICA8L1N0YWNrPlxuKVxuIl19 */"));
31
+ const Skeleton = ({
32
+ direction
33
+ }) => /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction, children: [
34
+ /* @__PURE__ */ jsxRuntime.jsx(SkeletonImage, { variant: "square", height: direction === "column" ? "120px" : "unset", width: direction === "row" ? "220px" : void 0, direction }),
35
+ /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { gap: 2, children: [
36
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
37
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
38
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
39
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
40
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" })
41
+ ] })
42
+ ] });
43
+ exports.Skeleton = Skeleton;
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const react$1 = require("@emotion/react");
6
+ const ui = require("@ultraviolet/ui");
7
+ const react = require("react");
8
+ const Skeleton = require("./Skeleton.cjs");
9
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
13
+ }
14
+ const 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":"AAQyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */");
15
+ const Card = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
16
+ target: "e2ipnt5"
17
+ } : {
18
+ target: "e2ipnt5",
19
+ label: "Card"
20
+ })("display:block;text-align:left;padding:0;color:", ({
21
+ theme
22
+ }) => theme.colors.neutral.text, ";text-decoration:none;border:1px solid ", ({
23
+ theme
24
+ }) => theme.colors.neutral.border, ";border-radius:", ({
25
+ theme
26
+ }) => theme.radii.default, ";background:", ({
27
+ theme
28
+ }) => theme.colors.neutral.background, ";", ({
29
+ onClick,
30
+ href,
31
+ theme
32
+ }) => onClick || href ? activeStyle(theme) : null, ";overflow-wrap:break-word;" + (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":"AAmBE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
33
+ const IconContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
34
+ target: "e2ipnt4"
35
+ } : {
36
+ target: "e2ipnt4",
37
+ label: "IconContainer"
38
+ })("display:flex;width:fit-content;background:", ({
39
+ theme
40
+ }) => theme.colors.neutral.backgroundWeak, ";padding:", ({
41
+ theme
42
+ }) => theme.space["1"], ";border-radius:", ({
43
+ theme
44
+ }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AAiCgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
45
+ const StyledIconStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
46
+ shouldForwardProp: (prop) => prop !== "direction",
47
+ target: "e2ipnt3"
48
+ } : {
49
+ shouldForwardProp: (prop) => prop !== "direction",
50
+ target: "e2ipnt3",
51
+ label: "StyledIconStack"
52
+ })("padding:", ({
53
+ theme,
54
+ direction
55
+ }) => direction === "column" ? `0 ${theme.space["3"]} ${theme.space["3"]} ${theme.space["3"]}` : `${theme.space["3"]} ${theme.space["3"]} ${theme.space["3"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AA2CgD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
56
+ const SubContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
57
+ shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
58
+ target: "e2ipnt2"
59
+ } : {
60
+ shouldForwardProp: (prop) => !["direction", "href"].includes(prop),
61
+ target: "e2ipnt2",
62
+ label: "SubContainer"
63
+ })("padding:", ({
64
+ theme,
65
+ direction
66
+ }) => direction === "column" ? `${theme.space["3"]} ${theme.space["3"]} 0 ${theme.space["3"]}` : `${theme.space["3"]} 0 ${theme.space["3"]} ${theme.space["3"]}`, ";padding:", ({
67
+ theme,
68
+ href
69
+ }) => !href ? `${theme.space["3"]}` : null, ";height:fit-content;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx"],"names":[],"mappings":"AAuDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
70
+ const Image = /* @__PURE__ */ _styled__default.default("img", process.env.NODE_ENV === "production" ? {
71
+ shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
72
+ target: "e2ipnt1"
73
+ } : {
74
+ shouldForwardProp: (prop) => !["direction", "subContainerHeight"].includes(prop),
75
+ target: "e2ipnt1",
76
+ label: "Image"
77
+ })("object-fit:cover;border-radius:", ({
78
+ theme,
79
+ direction
80
+ }) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";", ({
81
+ direction,
82
+ subContainerHeight
83
+ }) => direction === "row" ? `max-height: ${subContainerHeight}px` : null, ";" + (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":"AAsEE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */"));
84
+ const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
85
+ target: "e2ipnt0"
86
+ } : {
87
+ target: "e2ipnt0",
88
+ label: "FullHeightStack"
89
+ })(process.env.NODE_ENV === "production" ? {
90
+ name: "13udsys",
91
+ styles: "height:100%"
92
+ } : {
93
+ name: "13udsys",
94
+ styles: "height:100%",
95
+ map: "/*# 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":"AAkFqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/ContentCard/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon, 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}>`\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 }) =>\n    onClick || href ? activeStyle(theme) : null};\n  overflow-wrap: break-word;\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\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  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  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      description,\n      children,\n      href,\n      target = '_blank',\n      onClick,\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={onClick}\n        href={href}\n        role={onClick && !href ? 'button' : undefined}\n        ref={ref}\n        className={className}\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              />\n            ) : null}\n            <Stack gap={2} direction={direction} flex={1}>\n              <SubContainer\n                gap={2}\n                direction={direction}\n                href={href}\n                ref={subContainerRef}\n              >\n                {icon ?? null}\n                <Stack gap={2} justifyContent=\"center\">\n                  <Stack gap={0.5}>\n                    <Stack>\n                      {subtitle ? (\n                        <Text\n                          as=\"small\"\n                          variant=\"caption\"\n                          prominence=\"weak\"\n                          sentiment=\"neutral\"\n                        >\n                          {subtitle}\n                        </Text>\n                      ) : null}\n                      <Text as=\"h3\" variant=\"bodyStrong\" sentiment=\"neutral\">\n                        {title}\n                      </Text>\n                    </Stack>\n                    {description ? (\n                      <Text as=\"p\" variant=\"bodySmall\" sentiment=\"neutral\">\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                    <Icon name=\"open-in-new\" color=\"neutral\" />\n                  </IconContainer>\n                </StyledIconStack>\n              ) : null}\n            </Stack>\n          </FullHeightStack>\n        )}\n      </Container>\n    )\n  },\n)\n"]} */",
96
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
97
+ });
98
+ const ContentCard = react.forwardRef(({
99
+ image,
100
+ direction = "column",
101
+ icon,
102
+ subtitle,
103
+ title,
104
+ description,
105
+ children,
106
+ href,
107
+ target = "_blank",
108
+ onClick,
109
+ loading,
110
+ className
111
+ }, ref) => {
112
+ const subContainerRef = react.useRef(null);
113
+ const [subContainerHeight, setSubContainerHeight] = react.useState(subContainerRef?.current?.offsetHeight);
114
+ const Container = react.useMemo(() => {
115
+ if (href) {
116
+ return Card.withComponent("a", process.env.NODE_ENV === "production" ? {
117
+ target: "e2ipnt6"
118
+ } : {
119
+ target: "e2ipnt6",
120
+ label: "Container"
121
+ });
122
+ }
123
+ if (onClick) {
124
+ return Card.withComponent("button", process.env.NODE_ENV === "production" ? {
125
+ target: "e2ipnt7"
126
+ } : {
127
+ target: "e2ipnt7",
128
+ label: "Container"
129
+ });
130
+ }
131
+ return Card;
132
+ }, [href, onClick]);
133
+ react.useEffect(() => setSubContainerHeight(subContainerRef?.current?.offsetHeight), [subContainerRef]);
134
+ return /* @__PURE__ */ jsxRuntime.jsx(Container, { target, onClick, href, role: onClick && !href ? "button" : void 0, ref, className, children: loading ? /* @__PURE__ */ jsxRuntime.jsx(Skeleton.Skeleton, { direction }) : /* @__PURE__ */ jsxRuntime.jsxs(FullHeightStack, { direction, children: [
135
+ image ? /* @__PURE__ */ jsxRuntime.jsx(Image, { alt: "", src: image, height: direction === "column" ? 120 : void 0, width: direction === "row" ? 220 : void 0, direction, subContainerHeight }) : null,
136
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 2, direction, flex: 1, children: [
137
+ /* @__PURE__ */ jsxRuntime.jsxs(SubContainer, { gap: 2, direction, href, ref: subContainerRef, children: [
138
+ icon ?? null,
139
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 2, justifyContent: "center", children: [
140
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 0.5, children: [
141
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { children: [
142
+ subtitle ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "small", variant: "caption", prominence: "weak", sentiment: "neutral", children: subtitle }) : null,
143
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "h3", variant: "bodyStrong", sentiment: "neutral", children: title })
144
+ ] }),
145
+ description ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", variant: "bodySmall", sentiment: "neutral", children: description }) : null
146
+ ] }),
147
+ children ? /* @__PURE__ */ jsxRuntime.jsx(ui.Stack, { children }) : null
148
+ ] })
149
+ ] }),
150
+ href ? /* @__PURE__ */ jsxRuntime.jsx(StyledIconStack, { flex: 1, alignItems: direction === "column" ? "flex-end" : "center", justifyContent: direction === "column" ? "center" : "end", direction, children: /* @__PURE__ */ jsxRuntime.jsx(IconContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Icon, { name: "open-in-new", color: "neutral" }) }) }) : null
151
+ ] })
152
+ ] }) });
153
+ });
154
+ exports.ContentCard = ContentCard;
@@ -0,0 +1,93 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const icons = require("@ultraviolet/icons");
6
+ const ui = require("@ultraviolet/ui");
7
+ const react = require("react");
8
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
9
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
10
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
11
+ 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).";
12
+ }
13
+ const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
14
+ target: "eqcw8nr3"
15
+ } : {
16
+ target: "eqcw8nr3",
17
+ label: "StyledStack"
18
+ })(process.env.NODE_ENV === "production" ? {
19
+ name: "ovk77c",
20
+ styles: "min-width:0"
21
+ } : {
22
+ name: "ovk77c",
23
+ styles: "min-width:0",
24
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db250ZW50Q2FyZEdyb3VwL0NhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHsgU3RhY2ssIFRleHQgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgdHlwZSB7IEFuY2hvckhUTUxBdHRyaWJ1dGVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcblxudHlwZSBDYXJkUHJvcHMgPSB7XG4gIHRpdGxlPzogc3RyaW5nXG4gIHN1YnRpdGxlPzogc3RyaW5nXG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nXG4gIGNoaWxkcmVuPzogUmVhY3ROb2RlXG4gIGhyZWY6IHN0cmluZ1xuICB0YXJnZXQ/OiBBbmNob3JIVE1MQXR0cmlidXRlczxIVE1MQW5jaG9yRWxlbWVudD5bJ3RhcmdldCddXG59XG5cbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgbWluLXdpZHRoOiAwO1xuYFxuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbmBcblxuY29uc3QgU3R5bGVkV3JhcHBlciA9IHN0eWxlZC5hYFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyczJ119O1xuICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gIGhlaWdodDogMTAwJTtcblxuICAmOm5vdCg6Zmlyc3QtY2hpbGQpIHtcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICB9XG5cbiAgJjpmaXJzdC1jaGlsZCB7XG4gICAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fVxuICAgICAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fSAwIDA7XG4gIH1cblxuICAmOmxhc3QtY2hpbGQge1xuICAgIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9XG4gICAgICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB9XG5cbiAgJiAke0ljb25XcmFwcGVyfSB7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha307XG4gIH1cblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRIb3Zlcn07XG5cbiAgICAmICR7SWNvbldyYXBwZXJ9IHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gXG5cbmNvbnN0IEZ1bGxIZWlnaHRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIGhlaWdodDogMTAwJTtcbmBcblxuZXhwb3J0IGNvbnN0IENhcmQgPSBmb3J3YXJkUmVmPEhUTUxBbmNob3JFbGVtZW50LCBDYXJkUHJvcHM+KFxuICAoXG4gICAgeyB0aXRsZSwgc3VidGl0bGUsIGRlc2NyaXB0aW9uLCBjaGlsZHJlbiwgaHJlZiwgdGFyZ2V0ID0gJ19ibGFuaycgfSxcbiAgICByZWYsXG4gICkgPT4gKFxuICAgIDxTdHlsZWRXcmFwcGVyIGhyZWY9e2hyZWZ9IHRhcmdldD17dGFyZ2V0fSByZWY9e3JlZn0+XG4gICAgICA8RnVsbEhlaWdodFN0YWNrXG4gICAgICAgIGRpcmVjdGlvbj1cInJvd1wiXG4gICAgICAgIGdhcD17Mn1cbiAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiXG4gICAgICA+XG4gICAgICAgIDxTdHlsZWRTdGFjayBnYXA9XCIwLjVcIj5cbiAgICAgICAgICA8ZGl2PlxuICAgICAgICAgICAge3N1YnRpdGxlID8gKFxuICAgICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICAgIGFzPVwiaDVcIlxuICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgb25lTGluZVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3N1YnRpdGxlfVxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxUZXh0IGFzPVwiaDNcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiIHNlbnRpbWVudD1cIm5ldXRyYWxcIiBvbmVMaW5lPlxuICAgICAgICAgICAgICB7dGl0bGV9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAge2Rlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHNlbnRpbWVudD1cIm5ldXRyYWxcIiBvbmVMaW5lPlxuICAgICAgICAgICAgICB7ZGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZFN0YWNrPlxuICAgICAgICA8SWNvbldyYXBwZXI+XG4gICAgICAgICAgPEljb24gbmFtZT1cIm9wZW4taW4tbmV3XCIgY29sb3I9XCJuZXV0cmFsXCIgLz5cbiAgICAgICAgPC9JY29uV3JhcHBlcj5cbiAgICAgIDwvRnVsbEhlaWdodFN0YWNrPlxuICAgIDwvU3R5bGVkV3JhcHBlcj5cbiAgKSxcbilcbiJdfQ== */",
25
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
26
+ });
27
+ const IconWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
28
+ target: "eqcw8nr2"
29
+ } : {
30
+ target: "eqcw8nr2",
31
+ label: "IconWrapper"
32
+ })("display:inline-flex;background:", ({
33
+ theme
34
+ }) => theme.colors.neutral.backgroundWeak, ";padding:", ({
35
+ theme
36
+ }) => theme.space["1"], ";border-radius:", ({
37
+ theme
38
+ }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBBbmNob3JIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnXG5cbnR5cGUgQ2FyZFByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBkZXNjcmlwdGlvbj86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZVxuICBocmVmOiBzdHJpbmdcbiAgdGFyZ2V0PzogQW5jaG9ySFRNTEF0dHJpYnV0ZXM8SFRNTEFuY2hvckVsZW1lbnQ+Wyd0YXJnZXQnXVxufVxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIG1pbi13aWR0aDogMDtcbmBcblxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha307XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG5gXG5cbmNvbnN0IFN0eWxlZFdyYXBwZXIgPSBzdHlsZWQuYWBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBoZWlnaHQ6IDEwMCU7XG5cbiAgJjpub3QoOmZpcnN0LWNoaWxkKSB7XG4gICAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgfVxuXG4gICY6Zmlyc3QtY2hpbGQge1xuICAgIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwO1xuICB9XG5cbiAgJjpsYXN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAwIDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fVxuICAgICAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgfVxuXG4gICYgJHtJY29uV3JhcHBlcn0ge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICB9XG5cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kSG92ZXJ9O1xuXG4gICAgJiAke0ljb25XcmFwcGVyfSB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmV4cG9ydCBjb25zdCBDYXJkID0gZm9yd2FyZFJlZjxIVE1MQW5jaG9yRWxlbWVudCwgQ2FyZFByb3BzPihcbiAgKFxuICAgIHsgdGl0bGUsIHN1YnRpdGxlLCBkZXNjcmlwdGlvbiwgY2hpbGRyZW4sIGhyZWYsIHRhcmdldCA9ICdfYmxhbmsnIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSB0YXJnZXQ9e3RhcmdldH0gcmVmPXtyZWZ9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBkaXJlY3Rpb249XCJyb3dcIlxuICAgICAgICBnYXA9ezJ9XG4gICAgICAgIGFsaWduSXRlbXM9XCJjZW50ZXJcIlxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz1cImg1XCJcbiAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtzdWJ0aXRsZX1cbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICA8VGV4dCBhcz1cImgzXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgb25lTGluZT5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgb25lTGluZT5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxJY29uIG5hbWU9XCJvcGVuLWluLW5ld1wiIGNvbG9yPVwibmV1dHJhbFwiIC8+XG4gICAgICAgIDwvSWNvbldyYXBwZXI+XG4gICAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICksXG4pXG4iXX0= */"));
39
+ const StyledWrapper = /* @__PURE__ */ _styled__default.default("a", process.env.NODE_ENV === "production" ? {
40
+ target: "eqcw8nr1"
41
+ } : {
42
+ target: "eqcw8nr1",
43
+ label: "StyledWrapper"
44
+ })("padding:", ({
45
+ theme
46
+ }) => theme.space["3"], ";text-decoration:none;height:100%;&:not(:first-child){border-top:1px solid ", ({
47
+ theme
48
+ }) => theme.colors.neutral.border, ";}&:first-child{border-radius:", ({
49
+ theme
50
+ }) => theme.radii.default, " ", ({
51
+ theme
52
+ }) => theme.radii.default, " 0 0;}&:last-child{border-radius:0 0 ", ({
53
+ theme
54
+ }) => theme.radii.default, " ", ({
55
+ theme
56
+ }) => theme.radii.default, ";}& ", IconWrapper, "{background:", ({
57
+ theme
58
+ }) => theme.colors.neutral.backgroundWeak, ";}&:hover{background:", ({
59
+ theme
60
+ }) => theme.colors.neutral.backgroundHover, ";& ", IconWrapper, "{background:none;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBBbmNob3JIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnXG5cbnR5cGUgQ2FyZFByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBkZXNjcmlwdGlvbj86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZVxuICBocmVmOiBzdHJpbmdcbiAgdGFyZ2V0PzogQW5jaG9ySFRNTEF0dHJpYnV0ZXM8SFRNTEFuY2hvckVsZW1lbnQ+Wyd0YXJnZXQnXVxufVxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIG1pbi13aWR0aDogMDtcbmBcblxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha307XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG5gXG5cbmNvbnN0IFN0eWxlZFdyYXBwZXIgPSBzdHlsZWQuYWBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBoZWlnaHQ6IDEwMCU7XG5cbiAgJjpub3QoOmZpcnN0LWNoaWxkKSB7XG4gICAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgfVxuXG4gICY6Zmlyc3QtY2hpbGQge1xuICAgIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwO1xuICB9XG5cbiAgJjpsYXN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAwIDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fVxuICAgICAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgfVxuXG4gICYgJHtJY29uV3JhcHBlcn0ge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICB9XG5cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kSG92ZXJ9O1xuXG4gICAgJiAke0ljb25XcmFwcGVyfSB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmV4cG9ydCBjb25zdCBDYXJkID0gZm9yd2FyZFJlZjxIVE1MQW5jaG9yRWxlbWVudCwgQ2FyZFByb3BzPihcbiAgKFxuICAgIHsgdGl0bGUsIHN1YnRpdGxlLCBkZXNjcmlwdGlvbiwgY2hpbGRyZW4sIGhyZWYsIHRhcmdldCA9ICdfYmxhbmsnIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSB0YXJnZXQ9e3RhcmdldH0gcmVmPXtyZWZ9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBkaXJlY3Rpb249XCJyb3dcIlxuICAgICAgICBnYXA9ezJ9XG4gICAgICAgIGFsaWduSXRlbXM9XCJjZW50ZXJcIlxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz1cImg1XCJcbiAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtzdWJ0aXRsZX1cbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICA8VGV4dCBhcz1cImgzXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgb25lTGluZT5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgb25lTGluZT5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxJY29uIG5hbWU9XCJvcGVuLWluLW5ld1wiIGNvbG9yPVwibmV1dHJhbFwiIC8+XG4gICAgICAgIDwvSWNvbldyYXBwZXI+XG4gICAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICksXG4pXG4iXX0= */"));
61
+ const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
62
+ target: "eqcw8nr0"
63
+ } : {
64
+ target: "eqcw8nr0",
65
+ label: "FullHeightStack"
66
+ })(process.env.NODE_ENV === "production" ? {
67
+ name: "13udsys",
68
+ styles: "height:100%"
69
+ } : {
70
+ name: "13udsys",
71
+ styles: "height:100%",
72
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRHFDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7IFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBBbmNob3JIVE1MQXR0cmlidXRlcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnXG5cbnR5cGUgQ2FyZFByb3BzID0ge1xuICB0aXRsZT86IHN0cmluZ1xuICBzdWJ0aXRsZT86IHN0cmluZ1xuICBkZXNjcmlwdGlvbj86IHN0cmluZ1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZVxuICBocmVmOiBzdHJpbmdcbiAgdGFyZ2V0PzogQW5jaG9ySFRNTEF0dHJpYnV0ZXM8SFRNTEFuY2hvckVsZW1lbnQ+Wyd0YXJnZXQnXVxufVxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIG1pbi13aWR0aDogMDtcbmBcblxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha307XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG5gXG5cbmNvbnN0IFN0eWxlZFdyYXBwZXIgPSBzdHlsZWQuYWBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICBoZWlnaHQ6IDEwMCU7XG5cbiAgJjpub3QoOmZpcnN0LWNoaWxkKSB7XG4gICAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcbiAgfVxuXG4gICY6Zmlyc3QtY2hpbGQge1xuICAgIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH1cbiAgICAgICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwO1xuICB9XG5cbiAgJjpsYXN0LWNoaWxkIHtcbiAgICBib3JkZXItcmFkaXVzOiAwIDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fVxuICAgICAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgfVxuXG4gICYgJHtJY29uV3JhcHBlcn0ge1xuICAgIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWt9O1xuICB9XG5cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kSG92ZXJ9O1xuXG4gICAgJiAke0ljb25XcmFwcGVyfSB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmV4cG9ydCBjb25zdCBDYXJkID0gZm9yd2FyZFJlZjxIVE1MQW5jaG9yRWxlbWVudCwgQ2FyZFByb3BzPihcbiAgKFxuICAgIHsgdGl0bGUsIHN1YnRpdGxlLCBkZXNjcmlwdGlvbiwgY2hpbGRyZW4sIGhyZWYsIHRhcmdldCA9ICdfYmxhbmsnIH0sXG4gICAgcmVmLFxuICApID0+IChcbiAgICA8U3R5bGVkV3JhcHBlciBocmVmPXtocmVmfSB0YXJnZXQ9e3RhcmdldH0gcmVmPXtyZWZ9PlxuICAgICAgPEZ1bGxIZWlnaHRTdGFja1xuICAgICAgICBkaXJlY3Rpb249XCJyb3dcIlxuICAgICAgICBnYXA9ezJ9XG4gICAgICAgIGFsaWduSXRlbXM9XCJjZW50ZXJcIlxuICAgICAgICBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkU3RhY2sgZ2FwPVwiMC41XCI+XG4gICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIHtzdWJ0aXRsZSA/IChcbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz1cImg1XCJcbiAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgIG9uZUxpbmVcbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtzdWJ0aXRsZX1cbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICA8VGV4dCBhcz1cImgzXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgb25lTGluZT5cbiAgICAgICAgICAgICAge3RpdGxlfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgb25lTGluZT5cbiAgICAgICAgICAgICAge2Rlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRTdGFjaz5cbiAgICAgICAgPEljb25XcmFwcGVyPlxuICAgICAgICAgIDxJY29uIG5hbWU9XCJvcGVuLWluLW5ld1wiIGNvbG9yPVwibmV1dHJhbFwiIC8+XG4gICAgICAgIDwvSWNvbldyYXBwZXI+XG4gICAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgICA8L1N0eWxlZFdyYXBwZXI+XG4gICksXG4pXG4iXX0= */",
73
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
74
+ });
75
+ const Card = react.forwardRef(({
76
+ title,
77
+ subtitle,
78
+ description,
79
+ children,
80
+ href,
81
+ target = "_blank"
82
+ }, ref) => /* @__PURE__ */ jsxRuntime.jsx(StyledWrapper, { href, target, ref, children: /* @__PURE__ */ jsxRuntime.jsxs(FullHeightStack, { direction: "row", gap: 2, alignItems: "center", justifyContent: "space-between", children: [
83
+ /* @__PURE__ */ jsxRuntime.jsxs(StyledStack, { gap: "0.5", children: [
84
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
85
+ subtitle ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "h5", variant: "caption", prominence: "weak", sentiment: "neutral", oneLine: true, children: subtitle }) : null,
86
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "h3", variant: "bodyStrong", sentiment: "neutral", oneLine: true, children: title })
87
+ ] }),
88
+ description ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", variant: "bodySmall", sentiment: "neutral", oneLine: true, children: description }) : null,
89
+ children
90
+ ] }),
91
+ /* @__PURE__ */ jsxRuntime.jsx(IconWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(icons.Icon, { name: "open-in-new", color: "neutral" }) })
92
+ ] }) }));
93
+ exports.Card = Card;
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const ui = require("@ultraviolet/ui");
6
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
7
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
8
+ const StyledWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
9
+ target: "e1xovou51"
10
+ } : {
11
+ target: "e1xovou51",
12
+ label: "StyledWrapper"
13
+ })("padding:", ({
14
+ theme
15
+ }) => theme.space["3"], ";&:not(:first-child){border-top:1px solid ", ({
16
+ theme
17
+ }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9Ta2VsZXRvbkNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdnQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL0NvbnRlbnRDYXJkR3JvdXAvU2tlbGV0b25DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgU2tlbGV0b24sIFN0YWNrIH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcblxuICAmOm5vdCg6Zmlyc3QtY2hpbGQpIHtcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFNxdWFyZVNrZWxldG9uID0gc3R5bGVkKFNrZWxldG9uKWBcbiAgaGVpZ2h0OiAzMnB4O1xuICB3aWR0aDogMzJweDtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbmBcblxuZXhwb3J0IGNvbnN0IFNrZWxldG9uQ2FyZCA9ICgpID0+IChcbiAgPFN0eWxlZFdyYXBwZXI+XG4gICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgIDxTdGFjayBnYXA9ezJ9PlxuICAgICAgICA8U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICA8U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICA8U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPC9TdGFjaz5cbiAgICAgIDxTdHlsZWRTcXVhcmVTa2VsZXRvbiB2YXJpYW50PVwic3F1YXJlXCIgLz5cbiAgICA8L1N0YWNrPlxuICA8L1N0eWxlZFdyYXBwZXI+XG4pXG4iXX0= */"));
18
+ const StyledSquareSkeleton = /* @__PURE__ */ _styled__default.default(ui.Skeleton, process.env.NODE_ENV === "production" ? {
19
+ target: "e1xovou50"
20
+ } : {
21
+ target: "e1xovou50",
22
+ label: "StyledSquareSkeleton"
23
+ })("height:32px;width:32px;border-radius:", ({
24
+ theme
25
+ }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmRHcm91cC9Ta2VsZXRvbkNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVc2QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL0NvbnRlbnRDYXJkR3JvdXAvU2tlbGV0b25DYXJkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgU2tlbGV0b24sIFN0YWNrIH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuXG5jb25zdCBTdHlsZWRXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMyddfTtcblxuICAmOm5vdCg6Zmlyc3QtY2hpbGQpIHtcbiAgICBib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFNxdWFyZVNrZWxldG9uID0gc3R5bGVkKFNrZWxldG9uKWBcbiAgaGVpZ2h0OiAzMnB4O1xuICB3aWR0aDogMzJweDtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbmBcblxuZXhwb3J0IGNvbnN0IFNrZWxldG9uQ2FyZCA9ICgpID0+IChcbiAgPFN0eWxlZFdyYXBwZXI+XG4gICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgIDxTdGFjayBnYXA9ezJ9PlxuICAgICAgICA8U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICA8U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgICA8U2tlbGV0b24gdmFyaWFudD1cImxpbmVcIiAvPlxuICAgICAgPC9TdGFjaz5cbiAgICAgIDxTdHlsZWRTcXVhcmVTa2VsZXRvbiB2YXJpYW50PVwic3F1YXJlXCIgLz5cbiAgICA8L1N0YWNrPlxuICA8L1N0eWxlZFdyYXBwZXI+XG4pXG4iXX0= */"));
26
+ const SkeletonCard = () => /* @__PURE__ */ jsxRuntime.jsx(StyledWrapper, { children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction: "row", alignItems: "center", justifyContent: "space-between", children: [
27
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 2, children: [
28
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
29
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" }),
30
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { variant: "line" })
31
+ ] }),
32
+ /* @__PURE__ */ jsxRuntime.jsx(StyledSquareSkeleton, { variant: "square" })
33
+ ] }) });
34
+ exports.SkeletonCard = SkeletonCard;