@ultraviolet/plus 0.15.1 → 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.
- package/dist/components/CodeEditor/CodeEditor.cjs +39 -0
- package/dist/components/CodeEditor/CodeEditor.js +17 -24
- package/dist/components/ContentCard/Skeleton.cjs +43 -0
- package/dist/components/ContentCard/Skeleton.js +28 -21
- package/dist/components/ContentCard/index.cjs +154 -0
- package/dist/components/ContentCard/index.js +143 -149
- package/dist/components/ContentCardGroup/Card.cjs +93 -0
- package/dist/components/ContentCardGroup/Card.js +84 -76
- package/dist/components/ContentCardGroup/SkeletonCard.cjs +34 -0
- package/dist/components/ContentCardGroup/SkeletonCard.js +19 -13
- package/dist/components/ContentCardGroup/index.cjs +33 -0
- package/dist/components/ContentCardGroup/index.js +17 -8
- package/dist/components/Conversation/index.cjs +128 -0
- package/dist/components/Conversation/index.js +100 -42
- package/dist/components/CustomerSatisfaction/assets/1-5.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/1-5NB.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/2-5.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/2-5NB.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/3-5.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/3-5NB.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/4-5.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/4-5NB.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/5-5.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/assets/5-5NB.svg.cjs +3 -0
- package/dist/components/CustomerSatisfaction/index.cjs +123 -0
- package/dist/components/CustomerSatisfaction/index.js +58 -81
- package/dist/components/EstimateCost/Components/CustomUnitInput.cjs +33 -0
- package/dist/components/EstimateCost/Components/CustomUnitInput.js +19 -34
- package/dist/components/EstimateCost/Components/Item.cjs +303 -0
- package/dist/components/EstimateCost/Components/Item.js +182 -199
- package/dist/components/EstimateCost/Components/LineThrough.cjs +18 -0
- package/dist/components/EstimateCost/Components/LineThrough.js +12 -9
- package/dist/components/EstimateCost/Components/NumberInput.cjs +29 -0
- package/dist/components/EstimateCost/Components/NumberInput.js +8 -15
- package/dist/components/EstimateCost/Components/Region.cjs +41 -0
- package/dist/components/EstimateCost/Components/Region.js +16 -27
- package/dist/components/EstimateCost/Components/Regular.cjs +35 -0
- package/dist/components/EstimateCost/Components/Regular.js +20 -28
- package/dist/components/EstimateCost/Components/Strong.cjs +28 -0
- package/dist/components/EstimateCost/Components/Strong.js +15 -12
- package/dist/components/EstimateCost/Components/Unit.cjs +50 -0
- package/dist/components/EstimateCost/Components/Unit.js +27 -33
- package/dist/components/EstimateCost/Components/UnitInput.cjs +90 -0
- package/dist/components/EstimateCost/Components/UnitInput.js +39 -87
- package/dist/components/EstimateCost/Components/Zone.cjs +40 -0
- package/dist/components/EstimateCost/Components/Zone.js +16 -26
- package/dist/components/EstimateCost/EstimateCost.cjs +88 -0
- package/dist/components/EstimateCost/EstimateCost.js +24 -63
- package/dist/components/EstimateCost/EstimateCostContent.cjs +245 -0
- package/dist/components/EstimateCost/EstimateCostContent.js +148 -208
- package/dist/components/EstimateCost/EstimateCostProvider.cjs +36 -0
- package/dist/components/EstimateCost/EstimateCostProvider.js +20 -23
- package/dist/components/EstimateCost/OverlayComponent.cjs +122 -0
- package/dist/components/EstimateCost/OverlayComponent.js +79 -73
- package/dist/components/EstimateCost/OverlayContext.cjs +14 -0
- package/dist/components/EstimateCost/OverlayContext.js +3 -1
- package/dist/components/EstimateCost/componentStyle.cjs +230 -0
- package/dist/components/EstimateCost/componentStyle.js +206 -148
- package/dist/components/EstimateCost/constants.cjs +30 -0
- package/dist/components/EstimateCost/helper.cjs +19 -0
- package/dist/components/EstimateCost/locales/en.cjs +23 -0
- package/dist/components/FAQ/index.cjs +36 -0
- package/dist/components/FAQ/index.js +9 -5
- package/dist/components/Navigation/Navigation.cjs +20 -0
- package/dist/components/Navigation/Navigation.d.ts +4 -3
- package/dist/components/Navigation/Navigation.js +1 -10
- package/dist/components/Navigation/NavigationContent.cjs +216 -0
- package/dist/components/Navigation/NavigationContent.js +96 -146
- package/dist/components/Navigation/NavigationProvider.cjs +111 -0
- package/dist/components/Navigation/NavigationProvider.d.ts +7 -18
- package/dist/components/Navigation/NavigationProvider.js +67 -98
- package/dist/components/Navigation/components/Group.cjs +57 -0
- package/dist/components/Navigation/components/Group.js +37 -41
- package/dist/components/Navigation/components/Item.cjs +438 -0
- package/dist/components/Navigation/components/Item.d.ts +4 -3
- package/dist/components/Navigation/components/Item.js +296 -555
- package/dist/components/Navigation/components/PinnedItems.cjs +108 -0
- package/dist/components/Navigation/components/PinnedItems.d.ts +5 -1
- package/dist/components/Navigation/components/PinnedItems.js +81 -119
- package/dist/components/Navigation/components/Separator.cjs +17 -0
- package/dist/components/Navigation/components/Separator.js +9 -4
- package/dist/components/Navigation/constants.cjs +37 -0
- package/dist/components/Navigation/constants.d.ts +14 -0
- package/dist/components/Navigation/index.d.ts +1 -0
- package/dist/components/Navigation/locales/en.cjs +11 -0
- package/dist/components/SteppedListCard/Step.cjs +37 -0
- package/dist/components/SteppedListCard/Step.js +19 -38
- package/dist/components/SteppedListCard/SteppedListContainer.cjs +80 -0
- package/dist/components/SteppedListCard/SteppedListContainer.js +39 -48
- package/dist/components/SteppedListCard/SteppedListContent.cjs +67 -0
- package/dist/components/SteppedListCard/SteppedListContent.js +46 -24
- package/dist/components/SteppedListCard/helper.cjs +37 -0
- package/dist/components/SteppedListCard/helper.js +1 -3
- package/dist/components/index.d.ts +1 -0
- package/dist/index.cjs +25 -0
- package/package.json +24 -9
|
@@ -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;
|
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
3
|
import { langs } from "@uiw/codemirror-extensions-langs";
|
|
4
4
|
import { material } from "@uiw/codemirror-theme-material";
|
|
5
5
|
import CodeMirror from "@uiw/react-codemirror";
|
|
6
6
|
import { Text } from "@ultraviolet/ui";
|
|
7
|
-
const StyledText =
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
7
|
+
const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
8
|
+
target: "e13pskxy0"
|
|
9
|
+
} : {
|
|
10
|
+
target: "e13pskxy0",
|
|
11
|
+
label: "StyledText"
|
|
12
|
+
})("background-color:", ({
|
|
13
|
+
theme
|
|
14
|
+
}) => theme.colors.neutral.backgroundStrong, ";padding:", ({
|
|
15
|
+
theme
|
|
16
|
+
}) => `${theme.space["1"]} ${theme.space["2"]}`, ";border-radius:", ({
|
|
17
|
+
theme
|
|
18
|
+
}) => 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= */"));
|
|
13
19
|
const CodeEditor = ({
|
|
14
20
|
title,
|
|
15
21
|
value,
|
|
@@ -20,23 +26,10 @@ const CodeEditor = ({
|
|
|
20
26
|
readOnly
|
|
21
27
|
}) => /* @__PURE__ */ jsxs("div", { children: [
|
|
22
28
|
title ? /* @__PURE__ */ jsx(StyledText, { as: "h3", variant: "headingSmall", children: title }) : null,
|
|
23
|
-
/* @__PURE__ */ jsx(
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
width: "100%",
|
|
28
|
-
height,
|
|
29
|
-
theme: material,
|
|
30
|
-
onChange,
|
|
31
|
-
value,
|
|
32
|
-
extensions: [langs[extensions]()],
|
|
33
|
-
onBlur,
|
|
34
|
-
basicSetup: {
|
|
35
|
-
highlightActiveLine: false,
|
|
36
|
-
highlightActiveLineGutter: false
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
)
|
|
29
|
+
/* @__PURE__ */ jsx(CodeMirror, { readOnly, width: "100%", height, theme: material, onChange, value, extensions: [langs[extensions]()], onBlur, basicSetup: {
|
|
30
|
+
highlightActiveLine: false,
|
|
31
|
+
highlightActiveLineGutter: false
|
|
32
|
+
} })
|
|
40
33
|
] });
|
|
41
34
|
export {
|
|
42
35
|
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;
|
|
@@ -1,26 +1,33 @@
|
|
|
1
1
|
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
-
import
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
3
|
import { Skeleton as Skeleton$1, Stack } from "@ultraviolet/ui";
|
|
4
|
-
const SkeletonImage =
|
|
5
|
-
shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop)
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
4
|
+
const SkeletonImage = /* @__PURE__ */ _styled(Skeleton$1, process.env.NODE_ENV === "production" ? {
|
|
5
|
+
shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
|
|
6
|
+
target: "e1wwr9dc1"
|
|
7
|
+
} : {
|
|
8
|
+
shouldForwardProp: (prop) => !["height", "width", "direction"].includes(prop),
|
|
9
|
+
target: "e1wwr9dc1",
|
|
10
|
+
label: "SkeletonImage"
|
|
11
|
+
})("border-radius:", ({
|
|
12
|
+
theme,
|
|
13
|
+
direction
|
|
14
|
+
}) => `${direction === "column" ? `${theme.radii.default} ${theme.radii.default} 0 0` : `${theme.radii.default} 0 0 ${theme.radii.default}`}`, ";width:", ({
|
|
15
|
+
width
|
|
16
|
+
}) => width, ";height:", ({
|
|
17
|
+
height
|
|
18
|
+
}) => 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== */"));
|
|
19
|
+
const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
20
|
+
target: "e1wwr9dc0"
|
|
21
|
+
} : {
|
|
22
|
+
target: "e1wwr9dc0",
|
|
23
|
+
label: "StyledStack"
|
|
24
|
+
})("padding:", ({
|
|
25
|
+
theme
|
|
26
|
+
}) => theme.space["3"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvQ29udGVudENhcmQvU2tlbGV0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9CaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9Db250ZW50Q2FyZC9Ta2VsZXRvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IFN0YWNrLCBTa2VsZXRvbiBhcyBVbHRyYXZpb2xldFNrZWxldG9uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuXG5jb25zdCBTa2VsZXRvbkltYWdlID0gc3R5bGVkKFVsdHJhdmlvbGV0U2tlbGV0b24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnaGVpZ2h0JywgJ3dpZHRoJywgJ2RpcmVjdGlvbiddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICB3aWR0aD86IHN0cmluZ1xuICBoZWlnaHQ/OiBzdHJpbmdcbiAgZGlyZWN0aW9uOiAncm93JyB8ICdjb2x1bW4nXG59PmBcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSwgZGlyZWN0aW9uIH0pID0+XG4gICAgYCR7XG4gICAgICBkaXJlY3Rpb24gPT09ICdjb2x1bW4nXG4gICAgICAgID8gYCR7dGhlbWUucmFkaWkuZGVmYXVsdH0gJHt0aGVtZS5yYWRpaS5kZWZhdWx0fSAwIDBgXG4gICAgICAgIDogYCR7dGhlbWUucmFkaWkuZGVmYXVsdH0gMCAwICR7dGhlbWUucmFkaWkuZGVmYXVsdH1gXG4gICAgfWB9O1xuICB3aWR0aDogJHsoeyB3aWR0aCB9KSA9PiB3aWR0aH07XG4gIGhlaWdodDogJHsoeyBoZWlnaHQgfSkgPT4gaGVpZ2h0fTtcbmBcblxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyczJ119O1xuYFxuXG50eXBlIFNrZWxldG9uUHJvcHMgPSB7XG4gIGRpcmVjdGlvbjogJ3JvdycgfCAnY29sdW1uJ1xufVxuXG5leHBvcnQgY29uc3QgU2tlbGV0b24gPSAoeyBkaXJlY3Rpb24gfTogU2tlbGV0b25Qcm9wcykgPT4gKFxuICA8U3RhY2sgZGlyZWN0aW9uPXtkaXJlY3Rpb259PlxuICAgIDxTa2VsZXRvbkltYWdlXG4gICAgICB2YXJpYW50PVwic3F1YXJlXCJcbiAgICAgIGhlaWdodD17ZGlyZWN0aW9uID09PSAnY29sdW1uJyA/ICcxMjBweCcgOiAndW5zZXQnfVxuICAgICAgd2lkdGg9e2RpcmVjdGlvbiA9PT0gJ3JvdycgPyAnMjIwcHgnIDogdW5kZWZpbmVkfVxuICAgICAgZGlyZWN0aW9uPXtkaXJlY3Rpb259XG4gICAgLz5cbiAgICA8U3R5bGVkU3RhY2sgZ2FwPXsyfT5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICAgIDxVbHRyYXZpb2xldFNrZWxldG9uIHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICA8L1N0eWxlZFN0YWNrPlxuICA8L1N0YWNrPlxuKVxuIl19 */"));
|
|
27
|
+
const Skeleton = ({
|
|
28
|
+
direction
|
|
29
|
+
}) => /* @__PURE__ */ jsxs(Stack, { direction, children: [
|
|
30
|
+
/* @__PURE__ */ jsx(SkeletonImage, { variant: "square", height: direction === "column" ? "120px" : "unset", width: direction === "row" ? "220px" : void 0, direction }),
|
|
24
31
|
/* @__PURE__ */ jsxs(StyledStack, { gap: 2, children: [
|
|
25
32
|
/* @__PURE__ */ jsx(Skeleton$1, { variant: "line" }),
|
|
26
33
|
/* @__PURE__ */ jsx(Skeleton$1, { variant: "line" }),
|
|
@@ -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;
|