@ultraviolet/plus 1.0.0-beta.7 → 1.0.0-beta.9
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/Plans/FeatureHint.cjs +42 -0
- package/dist/components/Plans/FeatureHint.d.ts +6 -0
- package/dist/components/Plans/FeatureHint.js +40 -0
- package/dist/components/Plans/PlanHeader.cjs +102 -0
- package/dist/components/Plans/PlanHeader.d.ts +13 -0
- package/dist/components/Plans/PlanHeader.js +100 -0
- package/dist/components/Plans/index.cjs +152 -0
- package/dist/components/Plans/index.d.ts +14 -0
- package/dist/components/Plans/index.js +150 -0
- package/dist/components/Plans/locales/en.cjs +7 -0
- package/dist/components/Plans/locales/en.d.ts +6 -0
- package/dist/components/Plans/locales/en.js +8 -0
- package/dist/components/Plans/types.d.ts +37 -0
- package/dist/components/index.d.ts +1 -0
- package/dist/index.cjs +2 -0
- package/dist/index.js +2 -0
- package/package.json +8 -8
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
4
|
+
const _styled = require("@emotion/styled/base");
|
|
5
|
+
const icons = require("@ultraviolet/icons");
|
|
6
|
+
const ui = require("@ultraviolet/ui");
|
|
7
|
+
const react = require("react");
|
|
8
|
+
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
9
|
+
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
10
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
11
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
12
|
+
}
|
|
13
|
+
const IconWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
14
|
+
target: "edqjxph0"
|
|
15
|
+
} : {
|
|
16
|
+
target: "edqjxph0",
|
|
17
|
+
label: "IconWrapper"
|
|
18
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
19
|
+
name: "e0dnmk",
|
|
20
|
+
styles: "cursor:pointer"
|
|
21
|
+
} : {
|
|
22
|
+
name: "e0dnmk",
|
|
23
|
+
styles: "cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvRmVhdHVyZUhpbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU4QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL0ZlYXR1cmVIaW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSW5mb3JtYXRpb25PdXRsaW5lSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7IFBvcG92ZXIsIFRvb2x0aXAgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBIaW50IH0gZnJvbSAnLi90eXBlcydcblxudHlwZSBGZWF0dXJlSGludFByb3BzID0ge1xuICBoaW50PzogSGludFxufVxuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGN1cnNvcjogcG9pbnRlcjtcbmBcblxuZXhwb3J0IGNvbnN0IEZlYXR1cmVIaW50ID0gKHsgaGludCB9OiBGZWF0dXJlSGludFByb3BzKSA9PiB7XG4gIGNvbnN0IFt2aXNpYmxlLCBzZXRWaXNpYmxlXSA9IHVzZVN0YXRlKGZhbHNlKVxuXG4gIGlmICghaGludCkge1xuICAgIHJldHVybiA8ZGl2IC8+XG4gIH1cblxuICBpZiAoaGludC50eXBlID09PSAndG9vbHRpcCcpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFRvb2x0aXAgdGV4dD17aGludC50ZXh0fT5cbiAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZUljb24gc2VudGltZW50PVwibmV1dHJhbFwiIHByb21pbmVuY2U9XCJ3ZWFrXCIgLz5cbiAgICAgIDwvVG9vbHRpcD5cbiAgICApXG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyXG4gICAgICB0aXRsZT17aGludC50aXRsZX1cbiAgICAgIGNvbnRlbnQ9e2hpbnQuY29udGVudH1cbiAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICBvbkNsb3NlPXsoKSA9PiBzZXRWaXNpYmxlKGZhbHNlKX1cbiAgICA+XG4gICAgICA8SWNvbldyYXBwZXJcbiAgICAgICAgcm9sZT1cImJ1dHRvblwiXG4gICAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4ge1xuICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICdTcGFjZScgfHwgZXZlbnQua2V5ID09PSAnRW50ZXInKSB7XG4gICAgICAgICAgICBzZXRWaXNpYmxlKHRydWUpXG4gICAgICAgICAgfVxuICAgICAgICB9fVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRWaXNpYmxlKHRydWUpfVxuICAgICAgICB0YWJJbmRleD17MH1cbiAgICAgICAgZGF0YS10ZXN0aWQ9XCJoaW50LXBvcG92ZXJcIlxuICAgICAgPlxuICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvbiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgcHJvbWluZW5jZT1cIndlYWtcIiAvPlxuICAgICAgPC9JY29uV3JhcHBlcj5cbiAgICA8L1BvcG92ZXI+XG4gIClcbn1cbiJdfQ== */",
|
|
24
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
25
|
+
});
|
|
26
|
+
const FeatureHint = ({
|
|
27
|
+
hint
|
|
28
|
+
}) => {
|
|
29
|
+
const [visible, setVisible] = react.useState(false);
|
|
30
|
+
if (!hint) {
|
|
31
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", {});
|
|
32
|
+
}
|
|
33
|
+
if (hint.type === "tooltip") {
|
|
34
|
+
return /* @__PURE__ */ jsxRuntime.jsx(ui.Tooltip, { text: hint.text, children: /* @__PURE__ */ jsxRuntime.jsx(icons.InformationOutlineIcon, { sentiment: "neutral", prominence: "weak" }) });
|
|
35
|
+
}
|
|
36
|
+
return /* @__PURE__ */ jsxRuntime.jsx(ui.Popover, { title: hint.title, content: hint.content, visible, onClose: () => setVisible(false), children: /* @__PURE__ */ jsxRuntime.jsx(IconWrapper, { role: "button", onKeyDown: (event) => {
|
|
37
|
+
if (event.key === "Space" || event.key === "Enter") {
|
|
38
|
+
setVisible(true);
|
|
39
|
+
}
|
|
40
|
+
}, onClick: () => setVisible(true), tabIndex: 0, "data-testid": "hint-popover", children: /* @__PURE__ */ jsxRuntime.jsx(icons.InformationOutlineIcon, { sentiment: "neutral", prominence: "weak" }) }) });
|
|
41
|
+
};
|
|
42
|
+
exports.FeatureHint = FeatureHint;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
|
+
import { InformationOutlineIcon } from "@ultraviolet/icons";
|
|
4
|
+
import { Tooltip, Popover } from "@ultraviolet/ui";
|
|
5
|
+
import { useState } from "react";
|
|
6
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
7
|
+
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).";
|
|
8
|
+
}
|
|
9
|
+
const IconWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
10
|
+
target: "edqjxph0"
|
|
11
|
+
} : {
|
|
12
|
+
target: "edqjxph0",
|
|
13
|
+
label: "IconWrapper"
|
|
14
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
15
|
+
name: "e0dnmk",
|
|
16
|
+
styles: "cursor:pointer"
|
|
17
|
+
} : {
|
|
18
|
+
name: "e0dnmk",
|
|
19
|
+
styles: "cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvRmVhdHVyZUhpbnQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU4QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL0ZlYXR1cmVIaW50LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSW5mb3JtYXRpb25PdXRsaW5lSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucydcbmltcG9ydCB7IFBvcG92ZXIsIFRvb2x0aXAgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBIaW50IH0gZnJvbSAnLi90eXBlcydcblxudHlwZSBGZWF0dXJlSGludFByb3BzID0ge1xuICBoaW50PzogSGludFxufVxuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGN1cnNvcjogcG9pbnRlcjtcbmBcblxuZXhwb3J0IGNvbnN0IEZlYXR1cmVIaW50ID0gKHsgaGludCB9OiBGZWF0dXJlSGludFByb3BzKSA9PiB7XG4gIGNvbnN0IFt2aXNpYmxlLCBzZXRWaXNpYmxlXSA9IHVzZVN0YXRlKGZhbHNlKVxuXG4gIGlmICghaGludCkge1xuICAgIHJldHVybiA8ZGl2IC8+XG4gIH1cblxuICBpZiAoaGludC50eXBlID09PSAndG9vbHRpcCcpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFRvb2x0aXAgdGV4dD17aGludC50ZXh0fT5cbiAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZUljb24gc2VudGltZW50PVwibmV1dHJhbFwiIHByb21pbmVuY2U9XCJ3ZWFrXCIgLz5cbiAgICAgIDwvVG9vbHRpcD5cbiAgICApXG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyXG4gICAgICB0aXRsZT17aGludC50aXRsZX1cbiAgICAgIGNvbnRlbnQ9e2hpbnQuY29udGVudH1cbiAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICBvbkNsb3NlPXsoKSA9PiBzZXRWaXNpYmxlKGZhbHNlKX1cbiAgICA+XG4gICAgICA8SWNvbldyYXBwZXJcbiAgICAgICAgcm9sZT1cImJ1dHRvblwiXG4gICAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4ge1xuICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICdTcGFjZScgfHwgZXZlbnQua2V5ID09PSAnRW50ZXInKSB7XG4gICAgICAgICAgICBzZXRWaXNpYmxlKHRydWUpXG4gICAgICAgICAgfVxuICAgICAgICB9fVxuICAgICAgICBvbkNsaWNrPXsoKSA9PiBzZXRWaXNpYmxlKHRydWUpfVxuICAgICAgICB0YWJJbmRleD17MH1cbiAgICAgICAgZGF0YS10ZXN0aWQ9XCJoaW50LXBvcG92ZXJcIlxuICAgICAgPlxuICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvbiBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgcHJvbWluZW5jZT1cIndlYWtcIiAvPlxuICAgICAgPC9JY29uV3JhcHBlcj5cbiAgICA8L1BvcG92ZXI+XG4gIClcbn1cbiJdfQ== */",
|
|
20
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
21
|
+
});
|
|
22
|
+
const FeatureHint = ({
|
|
23
|
+
hint
|
|
24
|
+
}) => {
|
|
25
|
+
const [visible, setVisible] = useState(false);
|
|
26
|
+
if (!hint) {
|
|
27
|
+
return /* @__PURE__ */ jsx("div", {});
|
|
28
|
+
}
|
|
29
|
+
if (hint.type === "tooltip") {
|
|
30
|
+
return /* @__PURE__ */ jsx(Tooltip, { text: hint.text, children: /* @__PURE__ */ jsx(InformationOutlineIcon, { sentiment: "neutral", prominence: "weak" }) });
|
|
31
|
+
}
|
|
32
|
+
return /* @__PURE__ */ jsx(Popover, { title: hint.title, content: hint.content, visible, onClose: () => setVisible(false), children: /* @__PURE__ */ jsx(IconWrapper, { role: "button", onKeyDown: (event) => {
|
|
33
|
+
if (event.key === "Space" || event.key === "Enter") {
|
|
34
|
+
setVisible(true);
|
|
35
|
+
}
|
|
36
|
+
}, onClick: () => setVisible(true), tabIndex: 0, "data-testid": "hint-popover", children: /* @__PURE__ */ jsx(InformationOutlineIcon, { sentiment: "neutral", prominence: "weak" }) }) });
|
|
37
|
+
};
|
|
38
|
+
export {
|
|
39
|
+
FeatureHint
|
|
40
|
+
};
|
|
@@ -0,0 +1,102 @@
|
|
|
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 en = require("./locales/en.cjs");
|
|
7
|
+
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
8
|
+
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
9
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
10
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
11
|
+
}
|
|
12
|
+
const StyledInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
|
|
13
|
+
target: "e1szn1u74"
|
|
14
|
+
} : {
|
|
15
|
+
target: "e1szn1u74",
|
|
16
|
+
label: "StyledInput"
|
|
17
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
18
|
+
name: "90z8hu",
|
|
19
|
+
styles: "position:absolute;opacity:0;top:0;left:0"
|
|
20
|
+
} : {
|
|
21
|
+
name: "90z8hu",
|
|
22
|
+
styles: "position:absolute;opacity:0;top:0;left:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS2dDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEJhZGdlLCBTZXBhcmF0b3IsIFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IFBsYW5zTG9jYWxlcyBmcm9tICcuL2xvY2FsZXMvZW4nXG5pbXBvcnQgdHlwZSB7IFBsYW5UeXBlIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgU3R5bGVkSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgb3BhY2l0eTogMDtcbiAgdG9wOiAwO1xuICBsZWZ0OiAwO1xuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmNvbnN0IFBsYW5EZXNjcmlwdGlvbiA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHdpZHRoOiAxMDAlO1xuYFxuXG5jb25zdCBGdWxsU2l6ZVNlcGFyYXRvciA9IHN0eWxlZChTZXBhcmF0b3IpYFxuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgQ3VycmVudFBsYW5XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLyogU2FtZSBhcyBidXR0b24gKi9cbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1snNjAwJ119O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYFxuXG50eXBlIFBsYW5IZWFkZXJQcm9wcyA9IHtcbiAgZmllbGROYW1lPzogc3RyaW5nXG4gIHNldEZvY3VzZWRQbGFuOiAocGxhblZhbHVlPzogc3RyaW5nKSA9PiB2b2lkXG4gIG9uQ2hhbmdlPzogKG5ld1BsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBjdXJyZW50UGxhblZhbHVlPzogc3RyaW5nXG4gIHBsYW46IFBsYW5UeXBlPHN0cmluZz5cbiAgZGlzYWJsZWQ6IGJvb2xlYW5cbiAgbG9jYWxlcz86IFJlY29yZDxrZXlvZiB0eXBlb2YgUGxhbnNMb2NhbGVzLCBzdHJpbmc+XG59XG5cbmV4cG9ydCBjb25zdCBQbGFuSGVhZGVyID0gKHtcbiAgZmllbGROYW1lLFxuICBzZXRGb2N1c2VkUGxhbixcbiAgb25DaGFuZ2UsXG4gIGN1cnJlbnRQbGFuVmFsdWUsXG4gIHBsYW4sXG4gIGRpc2FibGVkLFxuICBsb2NhbGVzID0gUGxhbnNMb2NhbGVzLFxufTogUGxhbkhlYWRlclByb3BzKSA9PiAoXG4gIDw+XG4gICAge2ZpZWxkTmFtZSAmJiBvbkNoYW5nZSAmJiAhZGlzYWJsZWQgPyAoXG4gICAgICA8U3R5bGVkSW5wdXRcbiAgICAgICAgaWQ9e3BsYW4udmFsdWV9XG4gICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgIG5hbWU9e2ZpZWxkTmFtZX1cbiAgICAgICAgdmFsdWU9e3BsYW4udmFsdWV9XG4gICAgICAgIG9uQ2hhbmdlPXsoKSA9PiBvbkNoYW5nZShwbGFuLnZhbHVlKX1cbiAgICAgICAgb25Gb2N1cz17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHBsYW4udmFsdWUpXG4gICAgICAgIH19XG4gICAgICAgIG9uQmx1cj17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHVuZGVmaW5lZClcbiAgICAgICAgfX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e3BsYW4udmFsdWV9XG4gICAgICAvPlxuICAgICkgOiBudWxsfVxuICAgIDxGdWxsSGVpZ2h0U3RhY2sgZ2FwPXsyfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICA8U3RhY2sgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgd2lkdGg9XCIxMDAlXCI+XG4gICAgICAgIDxTdGFjayBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8QmFkZ2VcbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIHNlbnRpbWVudD17XG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnYmxhY2snICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnd2hpdGUnXG4gICAgICAgICAgICAgICAgPyBwbGFuLnNlbnRpbWVudFxuICAgICAgICAgICAgICAgIDogJ3ByaW1hcnknXG4gICAgICAgICAgICB9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPGxhYmVsIGh0bWxGb3I9e3BsYW4udmFsdWV9PntwbGFuLnRpdGxlfTwvbGFiZWw+XG4gICAgICAgICAgPC9CYWRnZT5cbiAgICAgICAgICB7cGxhbi50aXRsZUhlYWRlcn1cbiAgICAgICAgICA8U3RhY2sgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImhlYWRpbmdTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBzdHlsZT17eyBtaW5IZWlnaHQ6ICcxNnB4JyB9fT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2VEZXNjcmlwdGlvbn1cbiAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L1N0YWNrPlxuICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgPFBsYW5EZXNjcmlwdGlvbj5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwiZGl2XCIgdmFyaWFudD1cImNhcHRpb25cIiBkaXNhYmxlZD17ZGlzYWJsZWR9PlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9QbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICAgIDxTdGFjayB3aWR0aD1cIjEwMCVcIiBnYXA9ezN9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge3BsYW4uaGVhZGVyLmN0YSAmJiBjdXJyZW50UGxhblZhbHVlICE9PSBwbGFuLnZhbHVlXG4gICAgICAgICAgPyBwbGFuLmhlYWRlci5jdGFcbiAgICAgICAgICA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSA9PT0gcGxhbi52YWx1ZSA/IChcbiAgICAgICAgICA8Q3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsb2NhbGVzWydwbGFucy5jdXJyZW50UGxhbiddfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvQ3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge3BsYW4uaGVhZGVyLnNlcGFyYXRvciA/IDxGdWxsU2l6ZVNlcGFyYXRvciAvPiA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvRnVsbEhlaWdodFN0YWNrPlxuICA8Lz5cbilcbiJdfQ== */",
|
|
23
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
24
|
+
});
|
|
25
|
+
const FullHeightStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
|
|
26
|
+
target: "e1szn1u73"
|
|
27
|
+
} : {
|
|
28
|
+
target: "e1szn1u73",
|
|
29
|
+
label: "FullHeightStack"
|
|
30
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
31
|
+
name: "13udsys",
|
|
32
|
+
styles: "height:100%"
|
|
33
|
+
} : {
|
|
34
|
+
name: "13udsys",
|
|
35
|
+
styles: "height:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWXFDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEJhZGdlLCBTZXBhcmF0b3IsIFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IFBsYW5zTG9jYWxlcyBmcm9tICcuL2xvY2FsZXMvZW4nXG5pbXBvcnQgdHlwZSB7IFBsYW5UeXBlIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgU3R5bGVkSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgb3BhY2l0eTogMDtcbiAgdG9wOiAwO1xuICBsZWZ0OiAwO1xuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmNvbnN0IFBsYW5EZXNjcmlwdGlvbiA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHdpZHRoOiAxMDAlO1xuYFxuXG5jb25zdCBGdWxsU2l6ZVNlcGFyYXRvciA9IHN0eWxlZChTZXBhcmF0b3IpYFxuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgQ3VycmVudFBsYW5XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLyogU2FtZSBhcyBidXR0b24gKi9cbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1snNjAwJ119O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYFxuXG50eXBlIFBsYW5IZWFkZXJQcm9wcyA9IHtcbiAgZmllbGROYW1lPzogc3RyaW5nXG4gIHNldEZvY3VzZWRQbGFuOiAocGxhblZhbHVlPzogc3RyaW5nKSA9PiB2b2lkXG4gIG9uQ2hhbmdlPzogKG5ld1BsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBjdXJyZW50UGxhblZhbHVlPzogc3RyaW5nXG4gIHBsYW46IFBsYW5UeXBlPHN0cmluZz5cbiAgZGlzYWJsZWQ6IGJvb2xlYW5cbiAgbG9jYWxlcz86IFJlY29yZDxrZXlvZiB0eXBlb2YgUGxhbnNMb2NhbGVzLCBzdHJpbmc+XG59XG5cbmV4cG9ydCBjb25zdCBQbGFuSGVhZGVyID0gKHtcbiAgZmllbGROYW1lLFxuICBzZXRGb2N1c2VkUGxhbixcbiAgb25DaGFuZ2UsXG4gIGN1cnJlbnRQbGFuVmFsdWUsXG4gIHBsYW4sXG4gIGRpc2FibGVkLFxuICBsb2NhbGVzID0gUGxhbnNMb2NhbGVzLFxufTogUGxhbkhlYWRlclByb3BzKSA9PiAoXG4gIDw+XG4gICAge2ZpZWxkTmFtZSAmJiBvbkNoYW5nZSAmJiAhZGlzYWJsZWQgPyAoXG4gICAgICA8U3R5bGVkSW5wdXRcbiAgICAgICAgaWQ9e3BsYW4udmFsdWV9XG4gICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgIG5hbWU9e2ZpZWxkTmFtZX1cbiAgICAgICAgdmFsdWU9e3BsYW4udmFsdWV9XG4gICAgICAgIG9uQ2hhbmdlPXsoKSA9PiBvbkNoYW5nZShwbGFuLnZhbHVlKX1cbiAgICAgICAgb25Gb2N1cz17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHBsYW4udmFsdWUpXG4gICAgICAgIH19XG4gICAgICAgIG9uQmx1cj17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHVuZGVmaW5lZClcbiAgICAgICAgfX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e3BsYW4udmFsdWV9XG4gICAgICAvPlxuICAgICkgOiBudWxsfVxuICAgIDxGdWxsSGVpZ2h0U3RhY2sgZ2FwPXsyfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICA8U3RhY2sgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgd2lkdGg9XCIxMDAlXCI+XG4gICAgICAgIDxTdGFjayBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8QmFkZ2VcbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIHNlbnRpbWVudD17XG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnYmxhY2snICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnd2hpdGUnXG4gICAgICAgICAgICAgICAgPyBwbGFuLnNlbnRpbWVudFxuICAgICAgICAgICAgICAgIDogJ3ByaW1hcnknXG4gICAgICAgICAgICB9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPGxhYmVsIGh0bWxGb3I9e3BsYW4udmFsdWV9PntwbGFuLnRpdGxlfTwvbGFiZWw+XG4gICAgICAgICAgPC9CYWRnZT5cbiAgICAgICAgICB7cGxhbi50aXRsZUhlYWRlcn1cbiAgICAgICAgICA8U3RhY2sgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImhlYWRpbmdTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBzdHlsZT17eyBtaW5IZWlnaHQ6ICcxNnB4JyB9fT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2VEZXNjcmlwdGlvbn1cbiAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L1N0YWNrPlxuICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgPFBsYW5EZXNjcmlwdGlvbj5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwiZGl2XCIgdmFyaWFudD1cImNhcHRpb25cIiBkaXNhYmxlZD17ZGlzYWJsZWR9PlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9QbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICAgIDxTdGFjayB3aWR0aD1cIjEwMCVcIiBnYXA9ezN9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge3BsYW4uaGVhZGVyLmN0YSAmJiBjdXJyZW50UGxhblZhbHVlICE9PSBwbGFuLnZhbHVlXG4gICAgICAgICAgPyBwbGFuLmhlYWRlci5jdGFcbiAgICAgICAgICA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSA9PT0gcGxhbi52YWx1ZSA/IChcbiAgICAgICAgICA8Q3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsb2NhbGVzWydwbGFucy5jdXJyZW50UGxhbiddfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvQ3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge3BsYW4uaGVhZGVyLnNlcGFyYXRvciA/IDxGdWxsU2l6ZVNlcGFyYXRvciAvPiA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvRnVsbEhlaWdodFN0YWNrPlxuICA8Lz5cbilcbiJdfQ== */",
|
|
36
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
37
|
+
});
|
|
38
|
+
const PlanDescription = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
39
|
+
target: "e1szn1u72"
|
|
40
|
+
} : {
|
|
41
|
+
target: "e1szn1u72",
|
|
42
|
+
label: "PlanDescription"
|
|
43
|
+
})("padding:", ({
|
|
44
|
+
theme
|
|
45
|
+
}) => theme.space["1"], ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JrQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL1BsYW5IZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBCYWRnZSwgU2VwYXJhdG9yLCBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCBQbGFuc0xvY2FsZXMgZnJvbSAnLi9sb2NhbGVzL2VuJ1xuaW1wb3J0IHR5cGUgeyBQbGFuVHlwZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkLmlucHV0YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG9wYWNpdHk6IDA7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5jb25zdCBQbGFuRGVzY3JpcHRpb24gPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgRnVsbFNpemVTZXBhcmF0b3IgPSBzdHlsZWQoU2VwYXJhdG9yKWBcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbmNvbnN0IEN1cnJlbnRQbGFuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC8qIFNhbWUgYXMgYnV0dG9uICovXG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzYwMCddfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxudHlwZSBQbGFuSGVhZGVyUHJvcHMgPSB7XG4gIGZpZWxkTmFtZT86IHN0cmluZ1xuICBzZXRGb2N1c2VkUGxhbjogKHBsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBvbkNoYW5nZT86IChuZXdQbGFuVmFsdWU/OiBzdHJpbmcpID0+IHZvaWRcbiAgY3VycmVudFBsYW5WYWx1ZT86IHN0cmluZ1xuICBwbGFuOiBQbGFuVHlwZTxzdHJpbmc+XG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGxvY2FsZXM/OiBSZWNvcmQ8a2V5b2YgdHlwZW9mIFBsYW5zTG9jYWxlcywgc3RyaW5nPlxufVxuXG5leHBvcnQgY29uc3QgUGxhbkhlYWRlciA9ICh7XG4gIGZpZWxkTmFtZSxcbiAgc2V0Rm9jdXNlZFBsYW4sXG4gIG9uQ2hhbmdlLFxuICBjdXJyZW50UGxhblZhbHVlLFxuICBwbGFuLFxuICBkaXNhYmxlZCxcbiAgbG9jYWxlcyA9IFBsYW5zTG9jYWxlcyxcbn06IFBsYW5IZWFkZXJQcm9wcykgPT4gKFxuICA8PlxuICAgIHtmaWVsZE5hbWUgJiYgb25DaGFuZ2UgJiYgIWRpc2FibGVkID8gKFxuICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgIGlkPXtwbGFuLnZhbHVlfVxuICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICBuYW1lPXtmaWVsZE5hbWV9XG4gICAgICAgIHZhbHVlPXtwbGFuLnZhbHVlfVxuICAgICAgICBvbkNoYW5nZT17KCkgPT4gb25DaGFuZ2UocGxhbi52YWx1ZSl9XG4gICAgICAgIG9uRm9jdXM9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbihwbGFuLnZhbHVlKVxuICAgICAgICB9fVxuICAgICAgICBvbkJsdXI9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbih1bmRlZmluZWQpXG4gICAgICAgIH19XG4gICAgICAgIGRhdGEtdGVzdGlkPXtwbGFuLnZhbHVlfVxuICAgICAgLz5cbiAgICApIDogbnVsbH1cbiAgICA8RnVsbEhlaWdodFN0YWNrIGdhcD17Mn0gYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFN0YWNrIGdhcD17M30gYWxpZ25JdGVtcz1cImNlbnRlclwiIHdpZHRoPVwiMTAwJVwiPlxuICAgICAgICA8U3RhY2sgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e1xuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ2JsYWNrJyAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ3doaXRlJ1xuICAgICAgICAgICAgICAgID8gcGxhbi5zZW50aW1lbnRcbiAgICAgICAgICAgICAgICA6ICdwcmltYXJ5J1xuICAgICAgICAgICAgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxsYWJlbCBodG1sRm9yPXtwbGFuLnZhbHVlfT57cGxhbi50aXRsZX08L2xhYmVsPlxuICAgICAgICAgIDwvQmFkZ2U+XG4gICAgICAgICAge3BsYW4udGl0bGVIZWFkZXJ9XG4gICAgICAgICAgPFN0YWNrIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2V9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgc3R5bGU9e3sgbWluSGVpZ2h0OiAnMTZweCcgfX0+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZURlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICAgICAgc2VudGltZW50PXtwbGFuLnNlbnRpbWVudCA/PyAncHJpbWFyeSd9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9uID8gKFxuICAgICAgICAgIDxQbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImRpdlwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvUGxhbkRlc2NyaXB0aW9uPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgICA8U3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSAhPT0gcGxhbi52YWx1ZVxuICAgICAgICAgID8gcGxhbi5oZWFkZXIuY3RhXG4gICAgICAgICAgOiBudWxsfVxuICAgICAgICB7cGxhbi5oZWFkZXIuY3RhICYmIGN1cnJlbnRQbGFuVmFsdWUgPT09IHBsYW4udmFsdWUgPyAoXG4gICAgICAgICAgPEN1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bG9jYWxlc1sncGxhbnMuY3VycmVudFBsYW4nXX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0N1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5zZXBhcmF0b3IgPyA8RnVsbFNpemVTZXBhcmF0b3IgLz4gOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgPC8+XG4pXG4iXX0= */"));
|
|
46
|
+
const FullSizeSeparator = /* @__PURE__ */ _styled__default.default(ui.Separator, process.env.NODE_ENV === "production" ? {
|
|
47
|
+
target: "e1szn1u71"
|
|
48
|
+
} : {
|
|
49
|
+
target: "e1szn1u71",
|
|
50
|
+
label: "FullSizeSeparator"
|
|
51
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
52
|
+
name: "1d3w5wq",
|
|
53
|
+
styles: "width:100%"
|
|
54
|
+
} : {
|
|
55
|
+
name: "1d3w5wq",
|
|
56
|
+
styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUIyQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL1BsYW5IZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBCYWRnZSwgU2VwYXJhdG9yLCBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCBQbGFuc0xvY2FsZXMgZnJvbSAnLi9sb2NhbGVzL2VuJ1xuaW1wb3J0IHR5cGUgeyBQbGFuVHlwZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkLmlucHV0YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG9wYWNpdHk6IDA7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5jb25zdCBQbGFuRGVzY3JpcHRpb24gPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgRnVsbFNpemVTZXBhcmF0b3IgPSBzdHlsZWQoU2VwYXJhdG9yKWBcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbmNvbnN0IEN1cnJlbnRQbGFuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC8qIFNhbWUgYXMgYnV0dG9uICovXG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzYwMCddfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxudHlwZSBQbGFuSGVhZGVyUHJvcHMgPSB7XG4gIGZpZWxkTmFtZT86IHN0cmluZ1xuICBzZXRGb2N1c2VkUGxhbjogKHBsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBvbkNoYW5nZT86IChuZXdQbGFuVmFsdWU/OiBzdHJpbmcpID0+IHZvaWRcbiAgY3VycmVudFBsYW5WYWx1ZT86IHN0cmluZ1xuICBwbGFuOiBQbGFuVHlwZTxzdHJpbmc+XG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGxvY2FsZXM/OiBSZWNvcmQ8a2V5b2YgdHlwZW9mIFBsYW5zTG9jYWxlcywgc3RyaW5nPlxufVxuXG5leHBvcnQgY29uc3QgUGxhbkhlYWRlciA9ICh7XG4gIGZpZWxkTmFtZSxcbiAgc2V0Rm9jdXNlZFBsYW4sXG4gIG9uQ2hhbmdlLFxuICBjdXJyZW50UGxhblZhbHVlLFxuICBwbGFuLFxuICBkaXNhYmxlZCxcbiAgbG9jYWxlcyA9IFBsYW5zTG9jYWxlcyxcbn06IFBsYW5IZWFkZXJQcm9wcykgPT4gKFxuICA8PlxuICAgIHtmaWVsZE5hbWUgJiYgb25DaGFuZ2UgJiYgIWRpc2FibGVkID8gKFxuICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgIGlkPXtwbGFuLnZhbHVlfVxuICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICBuYW1lPXtmaWVsZE5hbWV9XG4gICAgICAgIHZhbHVlPXtwbGFuLnZhbHVlfVxuICAgICAgICBvbkNoYW5nZT17KCkgPT4gb25DaGFuZ2UocGxhbi52YWx1ZSl9XG4gICAgICAgIG9uRm9jdXM9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbihwbGFuLnZhbHVlKVxuICAgICAgICB9fVxuICAgICAgICBvbkJsdXI9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbih1bmRlZmluZWQpXG4gICAgICAgIH19XG4gICAgICAgIGRhdGEtdGVzdGlkPXtwbGFuLnZhbHVlfVxuICAgICAgLz5cbiAgICApIDogbnVsbH1cbiAgICA8RnVsbEhlaWdodFN0YWNrIGdhcD17Mn0gYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFN0YWNrIGdhcD17M30gYWxpZ25JdGVtcz1cImNlbnRlclwiIHdpZHRoPVwiMTAwJVwiPlxuICAgICAgICA8U3RhY2sgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e1xuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ2JsYWNrJyAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ3doaXRlJ1xuICAgICAgICAgICAgICAgID8gcGxhbi5zZW50aW1lbnRcbiAgICAgICAgICAgICAgICA6ICdwcmltYXJ5J1xuICAgICAgICAgICAgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxsYWJlbCBodG1sRm9yPXtwbGFuLnZhbHVlfT57cGxhbi50aXRsZX08L2xhYmVsPlxuICAgICAgICAgIDwvQmFkZ2U+XG4gICAgICAgICAge3BsYW4udGl0bGVIZWFkZXJ9XG4gICAgICAgICAgPFN0YWNrIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2V9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgc3R5bGU9e3sgbWluSGVpZ2h0OiAnMTZweCcgfX0+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZURlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICAgICAgc2VudGltZW50PXtwbGFuLnNlbnRpbWVudCA/PyAncHJpbWFyeSd9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9uID8gKFxuICAgICAgICAgIDxQbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImRpdlwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvUGxhbkRlc2NyaXB0aW9uPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgICA8U3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSAhPT0gcGxhbi52YWx1ZVxuICAgICAgICAgID8gcGxhbi5oZWFkZXIuY3RhXG4gICAgICAgICAgOiBudWxsfVxuICAgICAgICB7cGxhbi5oZWFkZXIuY3RhICYmIGN1cnJlbnRQbGFuVmFsdWUgPT09IHBsYW4udmFsdWUgPyAoXG4gICAgICAgICAgPEN1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bG9jYWxlc1sncGxhbnMuY3VycmVudFBsYW4nXX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0N1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5zZXBhcmF0b3IgPyA8RnVsbFNpemVTZXBhcmF0b3IgLz4gOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgPC8+XG4pXG4iXX0= */",
|
|
57
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
58
|
+
});
|
|
59
|
+
const CurrentPlanWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
60
|
+
target: "e1szn1u70"
|
|
61
|
+
} : {
|
|
62
|
+
target: "e1szn1u70",
|
|
63
|
+
label: "CurrentPlanWrapper"
|
|
64
|
+
})("height:", ({
|
|
65
|
+
theme
|
|
66
|
+
}) => theme.sizing["600"], ";display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJxQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL1BsYW5IZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBCYWRnZSwgU2VwYXJhdG9yLCBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCBQbGFuc0xvY2FsZXMgZnJvbSAnLi9sb2NhbGVzL2VuJ1xuaW1wb3J0IHR5cGUgeyBQbGFuVHlwZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkLmlucHV0YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG9wYWNpdHk6IDA7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5jb25zdCBQbGFuRGVzY3JpcHRpb24gPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgRnVsbFNpemVTZXBhcmF0b3IgPSBzdHlsZWQoU2VwYXJhdG9yKWBcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbmNvbnN0IEN1cnJlbnRQbGFuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC8qIFNhbWUgYXMgYnV0dG9uICovXG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzYwMCddfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxudHlwZSBQbGFuSGVhZGVyUHJvcHMgPSB7XG4gIGZpZWxkTmFtZT86IHN0cmluZ1xuICBzZXRGb2N1c2VkUGxhbjogKHBsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBvbkNoYW5nZT86IChuZXdQbGFuVmFsdWU/OiBzdHJpbmcpID0+IHZvaWRcbiAgY3VycmVudFBsYW5WYWx1ZT86IHN0cmluZ1xuICBwbGFuOiBQbGFuVHlwZTxzdHJpbmc+XG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGxvY2FsZXM/OiBSZWNvcmQ8a2V5b2YgdHlwZW9mIFBsYW5zTG9jYWxlcywgc3RyaW5nPlxufVxuXG5leHBvcnQgY29uc3QgUGxhbkhlYWRlciA9ICh7XG4gIGZpZWxkTmFtZSxcbiAgc2V0Rm9jdXNlZFBsYW4sXG4gIG9uQ2hhbmdlLFxuICBjdXJyZW50UGxhblZhbHVlLFxuICBwbGFuLFxuICBkaXNhYmxlZCxcbiAgbG9jYWxlcyA9IFBsYW5zTG9jYWxlcyxcbn06IFBsYW5IZWFkZXJQcm9wcykgPT4gKFxuICA8PlxuICAgIHtmaWVsZE5hbWUgJiYgb25DaGFuZ2UgJiYgIWRpc2FibGVkID8gKFxuICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgIGlkPXtwbGFuLnZhbHVlfVxuICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICBuYW1lPXtmaWVsZE5hbWV9XG4gICAgICAgIHZhbHVlPXtwbGFuLnZhbHVlfVxuICAgICAgICBvbkNoYW5nZT17KCkgPT4gb25DaGFuZ2UocGxhbi52YWx1ZSl9XG4gICAgICAgIG9uRm9jdXM9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbihwbGFuLnZhbHVlKVxuICAgICAgICB9fVxuICAgICAgICBvbkJsdXI9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbih1bmRlZmluZWQpXG4gICAgICAgIH19XG4gICAgICAgIGRhdGEtdGVzdGlkPXtwbGFuLnZhbHVlfVxuICAgICAgLz5cbiAgICApIDogbnVsbH1cbiAgICA8RnVsbEhlaWdodFN0YWNrIGdhcD17Mn0gYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFN0YWNrIGdhcD17M30gYWxpZ25JdGVtcz1cImNlbnRlclwiIHdpZHRoPVwiMTAwJVwiPlxuICAgICAgICA8U3RhY2sgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e1xuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ2JsYWNrJyAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ3doaXRlJ1xuICAgICAgICAgICAgICAgID8gcGxhbi5zZW50aW1lbnRcbiAgICAgICAgICAgICAgICA6ICdwcmltYXJ5J1xuICAgICAgICAgICAgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxsYWJlbCBodG1sRm9yPXtwbGFuLnZhbHVlfT57cGxhbi50aXRsZX08L2xhYmVsPlxuICAgICAgICAgIDwvQmFkZ2U+XG4gICAgICAgICAge3BsYW4udGl0bGVIZWFkZXJ9XG4gICAgICAgICAgPFN0YWNrIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2V9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgc3R5bGU9e3sgbWluSGVpZ2h0OiAnMTZweCcgfX0+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZURlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICAgICAgc2VudGltZW50PXtwbGFuLnNlbnRpbWVudCA/PyAncHJpbWFyeSd9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9uID8gKFxuICAgICAgICAgIDxQbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImRpdlwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvUGxhbkRlc2NyaXB0aW9uPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgICA8U3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSAhPT0gcGxhbi52YWx1ZVxuICAgICAgICAgID8gcGxhbi5oZWFkZXIuY3RhXG4gICAgICAgICAgOiBudWxsfVxuICAgICAgICB7cGxhbi5oZWFkZXIuY3RhICYmIGN1cnJlbnRQbGFuVmFsdWUgPT09IHBsYW4udmFsdWUgPyAoXG4gICAgICAgICAgPEN1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bG9jYWxlc1sncGxhbnMuY3VycmVudFBsYW4nXX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0N1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5zZXBhcmF0b3IgPyA8RnVsbFNpemVTZXBhcmF0b3IgLz4gOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgPC8+XG4pXG4iXX0= */"));
|
|
67
|
+
const PlanHeader = ({
|
|
68
|
+
fieldName,
|
|
69
|
+
setFocusedPlan,
|
|
70
|
+
onChange,
|
|
71
|
+
currentPlanValue,
|
|
72
|
+
plan,
|
|
73
|
+
disabled,
|
|
74
|
+
locales = en
|
|
75
|
+
}) => /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
76
|
+
fieldName && onChange && !disabled ? /* @__PURE__ */ jsxRuntime.jsx(StyledInput, { id: plan.value, type: "radio", name: fieldName, value: plan.value, onChange: () => onChange(plan.value), onFocus: () => {
|
|
77
|
+
setFocusedPlan(plan.value);
|
|
78
|
+
}, onBlur: () => {
|
|
79
|
+
setFocusedPlan(void 0);
|
|
80
|
+
}, "data-testid": plan.value }) : null,
|
|
81
|
+
/* @__PURE__ */ jsxRuntime.jsxs(FullHeightStack, { gap: 2, alignItems: "center", justifyContent: "space-between", children: [
|
|
82
|
+
/* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 3, alignItems: "center", width: "100%", children: [
|
|
83
|
+
/* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { gap: 1, alignItems: "center", children: [
|
|
84
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Badge, { disabled, sentiment: plan.sentiment && plan.sentiment !== "black" && plan.sentiment !== "white" ? plan.sentiment : "primary", children: /* @__PURE__ */ jsxRuntime.jsx("label", { htmlFor: plan.value, children: plan.title }) }),
|
|
85
|
+
plan.titleHeader,
|
|
86
|
+
/* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", children: [
|
|
87
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", variant: "headingSmallStrong", sentiment: plan.sentiment ?? "primary", disabled, children: plan.header.price }),
|
|
88
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Stack, { style: {
|
|
89
|
+
minHeight: "16px"
|
|
90
|
+
}, children: plan.header.priceDescription ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { disabled, as: "span", variant: "caption", sentiment: plan.sentiment ?? "primary", children: plan.header.priceDescription }) : null })
|
|
91
|
+
] })
|
|
92
|
+
] }),
|
|
93
|
+
plan.header.description ? /* @__PURE__ */ jsxRuntime.jsx(PlanDescription, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "div", variant: "caption", disabled, children: plan.header.description }) }) : null
|
|
94
|
+
] }),
|
|
95
|
+
/* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { width: "100%", gap: 3, alignItems: "center", children: [
|
|
96
|
+
plan.header.cta && currentPlanValue !== plan.value ? plan.header.cta : null,
|
|
97
|
+
plan.header.cta && currentPlanValue === plan.value ? /* @__PURE__ */ jsxRuntime.jsx(CurrentPlanWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", variant: "bodySmallStrong", sentiment: plan.sentiment ?? "primary", disabled, children: locales["plans.currentPlan"] }) }) : null,
|
|
98
|
+
plan.header.separator ? /* @__PURE__ */ jsxRuntime.jsx(FullSizeSeparator, {}) : null
|
|
99
|
+
] })
|
|
100
|
+
] })
|
|
101
|
+
] });
|
|
102
|
+
exports.PlanHeader = PlanHeader;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import PlansLocales from './locales/en';
|
|
2
|
+
import type { PlanType } from './types';
|
|
3
|
+
type PlanHeaderProps = {
|
|
4
|
+
fieldName?: string;
|
|
5
|
+
setFocusedPlan: (planValue?: string) => void;
|
|
6
|
+
onChange?: (newPlanValue?: string) => void;
|
|
7
|
+
currentPlanValue?: string;
|
|
8
|
+
plan: PlanType<string>;
|
|
9
|
+
disabled: boolean;
|
|
10
|
+
locales?: Record<keyof typeof PlansLocales, string>;
|
|
11
|
+
};
|
|
12
|
+
export declare const PlanHeader: ({ fieldName, setFocusedPlan, onChange, currentPlanValue, plan, disabled, locales, }: PlanHeaderProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { jsxs, Fragment, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
|
+
import { Stack, Badge, Text, Separator } from "@ultraviolet/ui";
|
|
4
|
+
import PlansLocales from "./locales/en.js";
|
|
5
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
6
|
+
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).";
|
|
7
|
+
}
|
|
8
|
+
const StyledInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
|
|
9
|
+
target: "e1szn1u74"
|
|
10
|
+
} : {
|
|
11
|
+
target: "e1szn1u74",
|
|
12
|
+
label: "StyledInput"
|
|
13
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
14
|
+
name: "90z8hu",
|
|
15
|
+
styles: "position:absolute;opacity:0;top:0;left:0"
|
|
16
|
+
} : {
|
|
17
|
+
name: "90z8hu",
|
|
18
|
+
styles: "position:absolute;opacity:0;top:0;left:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS2dDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEJhZGdlLCBTZXBhcmF0b3IsIFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IFBsYW5zTG9jYWxlcyBmcm9tICcuL2xvY2FsZXMvZW4nXG5pbXBvcnQgdHlwZSB7IFBsYW5UeXBlIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgU3R5bGVkSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgb3BhY2l0eTogMDtcbiAgdG9wOiAwO1xuICBsZWZ0OiAwO1xuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmNvbnN0IFBsYW5EZXNjcmlwdGlvbiA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHdpZHRoOiAxMDAlO1xuYFxuXG5jb25zdCBGdWxsU2l6ZVNlcGFyYXRvciA9IHN0eWxlZChTZXBhcmF0b3IpYFxuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgQ3VycmVudFBsYW5XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLyogU2FtZSBhcyBidXR0b24gKi9cbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1snNjAwJ119O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYFxuXG50eXBlIFBsYW5IZWFkZXJQcm9wcyA9IHtcbiAgZmllbGROYW1lPzogc3RyaW5nXG4gIHNldEZvY3VzZWRQbGFuOiAocGxhblZhbHVlPzogc3RyaW5nKSA9PiB2b2lkXG4gIG9uQ2hhbmdlPzogKG5ld1BsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBjdXJyZW50UGxhblZhbHVlPzogc3RyaW5nXG4gIHBsYW46IFBsYW5UeXBlPHN0cmluZz5cbiAgZGlzYWJsZWQ6IGJvb2xlYW5cbiAgbG9jYWxlcz86IFJlY29yZDxrZXlvZiB0eXBlb2YgUGxhbnNMb2NhbGVzLCBzdHJpbmc+XG59XG5cbmV4cG9ydCBjb25zdCBQbGFuSGVhZGVyID0gKHtcbiAgZmllbGROYW1lLFxuICBzZXRGb2N1c2VkUGxhbixcbiAgb25DaGFuZ2UsXG4gIGN1cnJlbnRQbGFuVmFsdWUsXG4gIHBsYW4sXG4gIGRpc2FibGVkLFxuICBsb2NhbGVzID0gUGxhbnNMb2NhbGVzLFxufTogUGxhbkhlYWRlclByb3BzKSA9PiAoXG4gIDw+XG4gICAge2ZpZWxkTmFtZSAmJiBvbkNoYW5nZSAmJiAhZGlzYWJsZWQgPyAoXG4gICAgICA8U3R5bGVkSW5wdXRcbiAgICAgICAgaWQ9e3BsYW4udmFsdWV9XG4gICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgIG5hbWU9e2ZpZWxkTmFtZX1cbiAgICAgICAgdmFsdWU9e3BsYW4udmFsdWV9XG4gICAgICAgIG9uQ2hhbmdlPXsoKSA9PiBvbkNoYW5nZShwbGFuLnZhbHVlKX1cbiAgICAgICAgb25Gb2N1cz17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHBsYW4udmFsdWUpXG4gICAgICAgIH19XG4gICAgICAgIG9uQmx1cj17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHVuZGVmaW5lZClcbiAgICAgICAgfX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e3BsYW4udmFsdWV9XG4gICAgICAvPlxuICAgICkgOiBudWxsfVxuICAgIDxGdWxsSGVpZ2h0U3RhY2sgZ2FwPXsyfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICA8U3RhY2sgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgd2lkdGg9XCIxMDAlXCI+XG4gICAgICAgIDxTdGFjayBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8QmFkZ2VcbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIHNlbnRpbWVudD17XG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnYmxhY2snICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnd2hpdGUnXG4gICAgICAgICAgICAgICAgPyBwbGFuLnNlbnRpbWVudFxuICAgICAgICAgICAgICAgIDogJ3ByaW1hcnknXG4gICAgICAgICAgICB9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPGxhYmVsIGh0bWxGb3I9e3BsYW4udmFsdWV9PntwbGFuLnRpdGxlfTwvbGFiZWw+XG4gICAgICAgICAgPC9CYWRnZT5cbiAgICAgICAgICB7cGxhbi50aXRsZUhlYWRlcn1cbiAgICAgICAgICA8U3RhY2sgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImhlYWRpbmdTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBzdHlsZT17eyBtaW5IZWlnaHQ6ICcxNnB4JyB9fT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2VEZXNjcmlwdGlvbn1cbiAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L1N0YWNrPlxuICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgPFBsYW5EZXNjcmlwdGlvbj5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwiZGl2XCIgdmFyaWFudD1cImNhcHRpb25cIiBkaXNhYmxlZD17ZGlzYWJsZWR9PlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9QbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICAgIDxTdGFjayB3aWR0aD1cIjEwMCVcIiBnYXA9ezN9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge3BsYW4uaGVhZGVyLmN0YSAmJiBjdXJyZW50UGxhblZhbHVlICE9PSBwbGFuLnZhbHVlXG4gICAgICAgICAgPyBwbGFuLmhlYWRlci5jdGFcbiAgICAgICAgICA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSA9PT0gcGxhbi52YWx1ZSA/IChcbiAgICAgICAgICA8Q3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsb2NhbGVzWydwbGFucy5jdXJyZW50UGxhbiddfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvQ3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge3BsYW4uaGVhZGVyLnNlcGFyYXRvciA/IDxGdWxsU2l6ZVNlcGFyYXRvciAvPiA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvRnVsbEhlaWdodFN0YWNrPlxuICA8Lz5cbilcbiJdfQ== */",
|
|
19
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
20
|
+
});
|
|
21
|
+
const FullHeightStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
22
|
+
target: "e1szn1u73"
|
|
23
|
+
} : {
|
|
24
|
+
target: "e1szn1u73",
|
|
25
|
+
label: "FullHeightStack"
|
|
26
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
27
|
+
name: "13udsys",
|
|
28
|
+
styles: "height:100%"
|
|
29
|
+
} : {
|
|
30
|
+
name: "13udsys",
|
|
31
|
+
styles: "height:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWXFDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEJhZGdlLCBTZXBhcmF0b3IsIFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IFBsYW5zTG9jYWxlcyBmcm9tICcuL2xvY2FsZXMvZW4nXG5pbXBvcnQgdHlwZSB7IFBsYW5UeXBlIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgU3R5bGVkSW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgb3BhY2l0eTogMDtcbiAgdG9wOiAwO1xuICBsZWZ0OiAwO1xuYFxuXG5jb25zdCBGdWxsSGVpZ2h0U3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG5gXG5cbmNvbnN0IFBsYW5EZXNjcmlwdGlvbiA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gIHdpZHRoOiAxMDAlO1xuYFxuXG5jb25zdCBGdWxsU2l6ZVNlcGFyYXRvciA9IHN0eWxlZChTZXBhcmF0b3IpYFxuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgQ3VycmVudFBsYW5XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLyogU2FtZSBhcyBidXR0b24gKi9cbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1snNjAwJ119O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYFxuXG50eXBlIFBsYW5IZWFkZXJQcm9wcyA9IHtcbiAgZmllbGROYW1lPzogc3RyaW5nXG4gIHNldEZvY3VzZWRQbGFuOiAocGxhblZhbHVlPzogc3RyaW5nKSA9PiB2b2lkXG4gIG9uQ2hhbmdlPzogKG5ld1BsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBjdXJyZW50UGxhblZhbHVlPzogc3RyaW5nXG4gIHBsYW46IFBsYW5UeXBlPHN0cmluZz5cbiAgZGlzYWJsZWQ6IGJvb2xlYW5cbiAgbG9jYWxlcz86IFJlY29yZDxrZXlvZiB0eXBlb2YgUGxhbnNMb2NhbGVzLCBzdHJpbmc+XG59XG5cbmV4cG9ydCBjb25zdCBQbGFuSGVhZGVyID0gKHtcbiAgZmllbGROYW1lLFxuICBzZXRGb2N1c2VkUGxhbixcbiAgb25DaGFuZ2UsXG4gIGN1cnJlbnRQbGFuVmFsdWUsXG4gIHBsYW4sXG4gIGRpc2FibGVkLFxuICBsb2NhbGVzID0gUGxhbnNMb2NhbGVzLFxufTogUGxhbkhlYWRlclByb3BzKSA9PiAoXG4gIDw+XG4gICAge2ZpZWxkTmFtZSAmJiBvbkNoYW5nZSAmJiAhZGlzYWJsZWQgPyAoXG4gICAgICA8U3R5bGVkSW5wdXRcbiAgICAgICAgaWQ9e3BsYW4udmFsdWV9XG4gICAgICAgIHR5cGU9XCJyYWRpb1wiXG4gICAgICAgIG5hbWU9e2ZpZWxkTmFtZX1cbiAgICAgICAgdmFsdWU9e3BsYW4udmFsdWV9XG4gICAgICAgIG9uQ2hhbmdlPXsoKSA9PiBvbkNoYW5nZShwbGFuLnZhbHVlKX1cbiAgICAgICAgb25Gb2N1cz17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHBsYW4udmFsdWUpXG4gICAgICAgIH19XG4gICAgICAgIG9uQmx1cj17KCkgPT4ge1xuICAgICAgICAgIHNldEZvY3VzZWRQbGFuKHVuZGVmaW5lZClcbiAgICAgICAgfX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e3BsYW4udmFsdWV9XG4gICAgICAvPlxuICAgICkgOiBudWxsfVxuICAgIDxGdWxsSGVpZ2h0U3RhY2sgZ2FwPXsyfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICA8U3RhY2sgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgd2lkdGg9XCIxMDAlXCI+XG4gICAgICAgIDxTdGFjayBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8QmFkZ2VcbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIHNlbnRpbWVudD17XG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnYmxhY2snICYmXG4gICAgICAgICAgICAgIHBsYW4uc2VudGltZW50ICE9PSAnd2hpdGUnXG4gICAgICAgICAgICAgICAgPyBwbGFuLnNlbnRpbWVudFxuICAgICAgICAgICAgICAgIDogJ3ByaW1hcnknXG4gICAgICAgICAgICB9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPGxhYmVsIGh0bWxGb3I9e3BsYW4udmFsdWV9PntwbGFuLnRpdGxlfTwvbGFiZWw+XG4gICAgICAgICAgPC9CYWRnZT5cbiAgICAgICAgICB7cGxhbi50aXRsZUhlYWRlcn1cbiAgICAgICAgICA8U3RhY2sgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImhlYWRpbmdTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBzdHlsZT17eyBtaW5IZWlnaHQ6ICcxNnB4JyB9fT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgICB2YXJpYW50PVwiY2FwdGlvblwiXG4gICAgICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2VEZXNjcmlwdGlvbn1cbiAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L1N0YWNrPlxuICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgPFBsYW5EZXNjcmlwdGlvbj5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwiZGl2XCIgdmFyaWFudD1cImNhcHRpb25cIiBkaXNhYmxlZD17ZGlzYWJsZWR9PlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIuZGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9QbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICAgIDxTdGFjayB3aWR0aD1cIjEwMCVcIiBnYXA9ezN9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge3BsYW4uaGVhZGVyLmN0YSAmJiBjdXJyZW50UGxhblZhbHVlICE9PSBwbGFuLnZhbHVlXG4gICAgICAgICAgPyBwbGFuLmhlYWRlci5jdGFcbiAgICAgICAgICA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSA9PT0gcGxhbi52YWx1ZSA/IChcbiAgICAgICAgICA8Q3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD17cGxhbi5zZW50aW1lbnQgPz8gJ3ByaW1hcnknfVxuICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsb2NhbGVzWydwbGFucy5jdXJyZW50UGxhbiddfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvQ3VycmVudFBsYW5XcmFwcGVyPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge3BsYW4uaGVhZGVyLnNlcGFyYXRvciA/IDxGdWxsU2l6ZVNlcGFyYXRvciAvPiA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvRnVsbEhlaWdodFN0YWNrPlxuICA8Lz5cbilcbiJdfQ== */",
|
|
32
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
33
|
+
});
|
|
34
|
+
const PlanDescription = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
35
|
+
target: "e1szn1u72"
|
|
36
|
+
} : {
|
|
37
|
+
target: "e1szn1u72",
|
|
38
|
+
label: "PlanDescription"
|
|
39
|
+
})("padding:", ({
|
|
40
|
+
theme
|
|
41
|
+
}) => theme.space["1"], ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JrQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL1BsYW5IZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBCYWRnZSwgU2VwYXJhdG9yLCBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCBQbGFuc0xvY2FsZXMgZnJvbSAnLi9sb2NhbGVzL2VuJ1xuaW1wb3J0IHR5cGUgeyBQbGFuVHlwZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkLmlucHV0YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG9wYWNpdHk6IDA7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5jb25zdCBQbGFuRGVzY3JpcHRpb24gPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgRnVsbFNpemVTZXBhcmF0b3IgPSBzdHlsZWQoU2VwYXJhdG9yKWBcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbmNvbnN0IEN1cnJlbnRQbGFuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC8qIFNhbWUgYXMgYnV0dG9uICovXG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzYwMCddfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxudHlwZSBQbGFuSGVhZGVyUHJvcHMgPSB7XG4gIGZpZWxkTmFtZT86IHN0cmluZ1xuICBzZXRGb2N1c2VkUGxhbjogKHBsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBvbkNoYW5nZT86IChuZXdQbGFuVmFsdWU/OiBzdHJpbmcpID0+IHZvaWRcbiAgY3VycmVudFBsYW5WYWx1ZT86IHN0cmluZ1xuICBwbGFuOiBQbGFuVHlwZTxzdHJpbmc+XG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGxvY2FsZXM/OiBSZWNvcmQ8a2V5b2YgdHlwZW9mIFBsYW5zTG9jYWxlcywgc3RyaW5nPlxufVxuXG5leHBvcnQgY29uc3QgUGxhbkhlYWRlciA9ICh7XG4gIGZpZWxkTmFtZSxcbiAgc2V0Rm9jdXNlZFBsYW4sXG4gIG9uQ2hhbmdlLFxuICBjdXJyZW50UGxhblZhbHVlLFxuICBwbGFuLFxuICBkaXNhYmxlZCxcbiAgbG9jYWxlcyA9IFBsYW5zTG9jYWxlcyxcbn06IFBsYW5IZWFkZXJQcm9wcykgPT4gKFxuICA8PlxuICAgIHtmaWVsZE5hbWUgJiYgb25DaGFuZ2UgJiYgIWRpc2FibGVkID8gKFxuICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgIGlkPXtwbGFuLnZhbHVlfVxuICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICBuYW1lPXtmaWVsZE5hbWV9XG4gICAgICAgIHZhbHVlPXtwbGFuLnZhbHVlfVxuICAgICAgICBvbkNoYW5nZT17KCkgPT4gb25DaGFuZ2UocGxhbi52YWx1ZSl9XG4gICAgICAgIG9uRm9jdXM9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbihwbGFuLnZhbHVlKVxuICAgICAgICB9fVxuICAgICAgICBvbkJsdXI9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbih1bmRlZmluZWQpXG4gICAgICAgIH19XG4gICAgICAgIGRhdGEtdGVzdGlkPXtwbGFuLnZhbHVlfVxuICAgICAgLz5cbiAgICApIDogbnVsbH1cbiAgICA8RnVsbEhlaWdodFN0YWNrIGdhcD17Mn0gYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFN0YWNrIGdhcD17M30gYWxpZ25JdGVtcz1cImNlbnRlclwiIHdpZHRoPVwiMTAwJVwiPlxuICAgICAgICA8U3RhY2sgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e1xuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ2JsYWNrJyAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ3doaXRlJ1xuICAgICAgICAgICAgICAgID8gcGxhbi5zZW50aW1lbnRcbiAgICAgICAgICAgICAgICA6ICdwcmltYXJ5J1xuICAgICAgICAgICAgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxsYWJlbCBodG1sRm9yPXtwbGFuLnZhbHVlfT57cGxhbi50aXRsZX08L2xhYmVsPlxuICAgICAgICAgIDwvQmFkZ2U+XG4gICAgICAgICAge3BsYW4udGl0bGVIZWFkZXJ9XG4gICAgICAgICAgPFN0YWNrIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2V9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgc3R5bGU9e3sgbWluSGVpZ2h0OiAnMTZweCcgfX0+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZURlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICAgICAgc2VudGltZW50PXtwbGFuLnNlbnRpbWVudCA/PyAncHJpbWFyeSd9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9uID8gKFxuICAgICAgICAgIDxQbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImRpdlwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvUGxhbkRlc2NyaXB0aW9uPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgICA8U3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSAhPT0gcGxhbi52YWx1ZVxuICAgICAgICAgID8gcGxhbi5oZWFkZXIuY3RhXG4gICAgICAgICAgOiBudWxsfVxuICAgICAgICB7cGxhbi5oZWFkZXIuY3RhICYmIGN1cnJlbnRQbGFuVmFsdWUgPT09IHBsYW4udmFsdWUgPyAoXG4gICAgICAgICAgPEN1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bG9jYWxlc1sncGxhbnMuY3VycmVudFBsYW4nXX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0N1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5zZXBhcmF0b3IgPyA8RnVsbFNpemVTZXBhcmF0b3IgLz4gOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgPC8+XG4pXG4iXX0= */"));
|
|
42
|
+
const FullSizeSeparator = /* @__PURE__ */ _styled(Separator, process.env.NODE_ENV === "production" ? {
|
|
43
|
+
target: "e1szn1u71"
|
|
44
|
+
} : {
|
|
45
|
+
target: "e1szn1u71",
|
|
46
|
+
label: "FullSizeSeparator"
|
|
47
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
48
|
+
name: "1d3w5wq",
|
|
49
|
+
styles: "width:100%"
|
|
50
|
+
} : {
|
|
51
|
+
name: "1d3w5wq",
|
|
52
|
+
styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUIyQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL1BsYW5IZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBCYWRnZSwgU2VwYXJhdG9yLCBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCBQbGFuc0xvY2FsZXMgZnJvbSAnLi9sb2NhbGVzL2VuJ1xuaW1wb3J0IHR5cGUgeyBQbGFuVHlwZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkLmlucHV0YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG9wYWNpdHk6IDA7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5jb25zdCBQbGFuRGVzY3JpcHRpb24gPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgRnVsbFNpemVTZXBhcmF0b3IgPSBzdHlsZWQoU2VwYXJhdG9yKWBcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbmNvbnN0IEN1cnJlbnRQbGFuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC8qIFNhbWUgYXMgYnV0dG9uICovXG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzYwMCddfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxudHlwZSBQbGFuSGVhZGVyUHJvcHMgPSB7XG4gIGZpZWxkTmFtZT86IHN0cmluZ1xuICBzZXRGb2N1c2VkUGxhbjogKHBsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBvbkNoYW5nZT86IChuZXdQbGFuVmFsdWU/OiBzdHJpbmcpID0+IHZvaWRcbiAgY3VycmVudFBsYW5WYWx1ZT86IHN0cmluZ1xuICBwbGFuOiBQbGFuVHlwZTxzdHJpbmc+XG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGxvY2FsZXM/OiBSZWNvcmQ8a2V5b2YgdHlwZW9mIFBsYW5zTG9jYWxlcywgc3RyaW5nPlxufVxuXG5leHBvcnQgY29uc3QgUGxhbkhlYWRlciA9ICh7XG4gIGZpZWxkTmFtZSxcbiAgc2V0Rm9jdXNlZFBsYW4sXG4gIG9uQ2hhbmdlLFxuICBjdXJyZW50UGxhblZhbHVlLFxuICBwbGFuLFxuICBkaXNhYmxlZCxcbiAgbG9jYWxlcyA9IFBsYW5zTG9jYWxlcyxcbn06IFBsYW5IZWFkZXJQcm9wcykgPT4gKFxuICA8PlxuICAgIHtmaWVsZE5hbWUgJiYgb25DaGFuZ2UgJiYgIWRpc2FibGVkID8gKFxuICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgIGlkPXtwbGFuLnZhbHVlfVxuICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICBuYW1lPXtmaWVsZE5hbWV9XG4gICAgICAgIHZhbHVlPXtwbGFuLnZhbHVlfVxuICAgICAgICBvbkNoYW5nZT17KCkgPT4gb25DaGFuZ2UocGxhbi52YWx1ZSl9XG4gICAgICAgIG9uRm9jdXM9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbihwbGFuLnZhbHVlKVxuICAgICAgICB9fVxuICAgICAgICBvbkJsdXI9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbih1bmRlZmluZWQpXG4gICAgICAgIH19XG4gICAgICAgIGRhdGEtdGVzdGlkPXtwbGFuLnZhbHVlfVxuICAgICAgLz5cbiAgICApIDogbnVsbH1cbiAgICA8RnVsbEhlaWdodFN0YWNrIGdhcD17Mn0gYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFN0YWNrIGdhcD17M30gYWxpZ25JdGVtcz1cImNlbnRlclwiIHdpZHRoPVwiMTAwJVwiPlxuICAgICAgICA8U3RhY2sgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e1xuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ2JsYWNrJyAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ3doaXRlJ1xuICAgICAgICAgICAgICAgID8gcGxhbi5zZW50aW1lbnRcbiAgICAgICAgICAgICAgICA6ICdwcmltYXJ5J1xuICAgICAgICAgICAgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxsYWJlbCBodG1sRm9yPXtwbGFuLnZhbHVlfT57cGxhbi50aXRsZX08L2xhYmVsPlxuICAgICAgICAgIDwvQmFkZ2U+XG4gICAgICAgICAge3BsYW4udGl0bGVIZWFkZXJ9XG4gICAgICAgICAgPFN0YWNrIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2V9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgc3R5bGU9e3sgbWluSGVpZ2h0OiAnMTZweCcgfX0+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZURlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICAgICAgc2VudGltZW50PXtwbGFuLnNlbnRpbWVudCA/PyAncHJpbWFyeSd9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9uID8gKFxuICAgICAgICAgIDxQbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImRpdlwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvUGxhbkRlc2NyaXB0aW9uPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgICA8U3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSAhPT0gcGxhbi52YWx1ZVxuICAgICAgICAgID8gcGxhbi5oZWFkZXIuY3RhXG4gICAgICAgICAgOiBudWxsfVxuICAgICAgICB7cGxhbi5oZWFkZXIuY3RhICYmIGN1cnJlbnRQbGFuVmFsdWUgPT09IHBsYW4udmFsdWUgPyAoXG4gICAgICAgICAgPEN1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bG9jYWxlc1sncGxhbnMuY3VycmVudFBsYW4nXX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0N1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5zZXBhcmF0b3IgPyA8RnVsbFNpemVTZXBhcmF0b3IgLz4gOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgPC8+XG4pXG4iXX0= */",
|
|
53
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
54
|
+
});
|
|
55
|
+
const CurrentPlanWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
56
|
+
target: "e1szn1u70"
|
|
57
|
+
} : {
|
|
58
|
+
target: "e1szn1u70",
|
|
59
|
+
label: "CurrentPlanWrapper"
|
|
60
|
+
})("height:", ({
|
|
61
|
+
theme
|
|
62
|
+
}) => theme.sizing["600"], ";display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvUGxhbnMvUGxhbkhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJxQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy9wbHVzL3NyYy9jb21wb25lbnRzL1BsYW5zL1BsYW5IZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBCYWRnZSwgU2VwYXJhdG9yLCBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCBQbGFuc0xvY2FsZXMgZnJvbSAnLi9sb2NhbGVzL2VuJ1xuaW1wb3J0IHR5cGUgeyBQbGFuVHlwZSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IFN0eWxlZElucHV0ID0gc3R5bGVkLmlucHV0YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG9wYWNpdHk6IDA7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbmBcblxuY29uc3QgRnVsbEhlaWdodFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuYFxuXG5jb25zdCBQbGFuRGVzY3JpcHRpb24gPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICB3aWR0aDogMTAwJTtcbmBcblxuY29uc3QgRnVsbFNpemVTZXBhcmF0b3IgPSBzdHlsZWQoU2VwYXJhdG9yKWBcbiAgd2lkdGg6IDEwMCU7XG5gXG5cbmNvbnN0IEN1cnJlbnRQbGFuV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC8qIFNhbWUgYXMgYnV0dG9uICovXG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzYwMCddfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxudHlwZSBQbGFuSGVhZGVyUHJvcHMgPSB7XG4gIGZpZWxkTmFtZT86IHN0cmluZ1xuICBzZXRGb2N1c2VkUGxhbjogKHBsYW5WYWx1ZT86IHN0cmluZykgPT4gdm9pZFxuICBvbkNoYW5nZT86IChuZXdQbGFuVmFsdWU/OiBzdHJpbmcpID0+IHZvaWRcbiAgY3VycmVudFBsYW5WYWx1ZT86IHN0cmluZ1xuICBwbGFuOiBQbGFuVHlwZTxzdHJpbmc+XG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGxvY2FsZXM/OiBSZWNvcmQ8a2V5b2YgdHlwZW9mIFBsYW5zTG9jYWxlcywgc3RyaW5nPlxufVxuXG5leHBvcnQgY29uc3QgUGxhbkhlYWRlciA9ICh7XG4gIGZpZWxkTmFtZSxcbiAgc2V0Rm9jdXNlZFBsYW4sXG4gIG9uQ2hhbmdlLFxuICBjdXJyZW50UGxhblZhbHVlLFxuICBwbGFuLFxuICBkaXNhYmxlZCxcbiAgbG9jYWxlcyA9IFBsYW5zTG9jYWxlcyxcbn06IFBsYW5IZWFkZXJQcm9wcykgPT4gKFxuICA8PlxuICAgIHtmaWVsZE5hbWUgJiYgb25DaGFuZ2UgJiYgIWRpc2FibGVkID8gKFxuICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgIGlkPXtwbGFuLnZhbHVlfVxuICAgICAgICB0eXBlPVwicmFkaW9cIlxuICAgICAgICBuYW1lPXtmaWVsZE5hbWV9XG4gICAgICAgIHZhbHVlPXtwbGFuLnZhbHVlfVxuICAgICAgICBvbkNoYW5nZT17KCkgPT4gb25DaGFuZ2UocGxhbi52YWx1ZSl9XG4gICAgICAgIG9uRm9jdXM9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbihwbGFuLnZhbHVlKVxuICAgICAgICB9fVxuICAgICAgICBvbkJsdXI9eygpID0+IHtcbiAgICAgICAgICBzZXRGb2N1c2VkUGxhbih1bmRlZmluZWQpXG4gICAgICAgIH19XG4gICAgICAgIGRhdGEtdGVzdGlkPXtwbGFuLnZhbHVlfVxuICAgICAgLz5cbiAgICApIDogbnVsbH1cbiAgICA8RnVsbEhlaWdodFN0YWNrIGdhcD17Mn0gYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFN0YWNrIGdhcD17M30gYWxpZ25JdGVtcz1cImNlbnRlclwiIHdpZHRoPVwiMTAwJVwiPlxuICAgICAgICA8U3RhY2sgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e1xuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ2JsYWNrJyAmJlxuICAgICAgICAgICAgICBwbGFuLnNlbnRpbWVudCAhPT0gJ3doaXRlJ1xuICAgICAgICAgICAgICAgID8gcGxhbi5zZW50aW1lbnRcbiAgICAgICAgICAgICAgICA6ICdwcmltYXJ5J1xuICAgICAgICAgICAgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxsYWJlbCBodG1sRm9yPXtwbGFuLnZhbHVlfT57cGxhbi50aXRsZX08L2xhYmVsPlxuICAgICAgICAgIDwvQmFkZ2U+XG4gICAgICAgICAge3BsYW4udGl0bGVIZWFkZXJ9XG4gICAgICAgICAgPFN0YWNrIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7cGxhbi5oZWFkZXIucHJpY2V9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgc3R5bGU9e3sgbWluSGVpZ2h0OiAnMTZweCcgfX0+XG4gICAgICAgICAgICAgIHtwbGFuLmhlYWRlci5wcmljZURlc2NyaXB0aW9uID8gKFxuICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgICAgICAgICAgc2VudGltZW50PXtwbGFuLnNlbnRpbWVudCA/PyAncHJpbWFyeSd9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLnByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9TdGFjaz5cbiAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9uID8gKFxuICAgICAgICAgIDxQbGFuRGVzY3JpcHRpb24+XG4gICAgICAgICAgICA8VGV4dCBhcz1cImRpdlwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgICAgICAgICAge3BsYW4uaGVhZGVyLmRlc2NyaXB0aW9ufVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgIDwvUGxhbkRlc2NyaXB0aW9uPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgICA8U3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXszfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIHtwbGFuLmhlYWRlci5jdGEgJiYgY3VycmVudFBsYW5WYWx1ZSAhPT0gcGxhbi52YWx1ZVxuICAgICAgICAgID8gcGxhbi5oZWFkZXIuY3RhXG4gICAgICAgICAgOiBudWxsfVxuICAgICAgICB7cGxhbi5oZWFkZXIuY3RhICYmIGN1cnJlbnRQbGFuVmFsdWUgPT09IHBsYW4udmFsdWUgPyAoXG4gICAgICAgICAgPEN1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3BsYW4uc2VudGltZW50ID8/ICdwcmltYXJ5J31cbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7bG9jYWxlc1sncGxhbnMuY3VycmVudFBsYW4nXX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0N1cnJlbnRQbGFuV3JhcHBlcj5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtwbGFuLmhlYWRlci5zZXBhcmF0b3IgPyA8RnVsbFNpemVTZXBhcmF0b3IgLz4gOiBudWxsfVxuICAgICAgPC9TdGFjaz5cbiAgICA8L0Z1bGxIZWlnaHRTdGFjaz5cbiAgPC8+XG4pXG4iXX0= */"));
|
|
63
|
+
const PlanHeader = ({
|
|
64
|
+
fieldName,
|
|
65
|
+
setFocusedPlan,
|
|
66
|
+
onChange,
|
|
67
|
+
currentPlanValue,
|
|
68
|
+
plan,
|
|
69
|
+
disabled,
|
|
70
|
+
locales = PlansLocales
|
|
71
|
+
}) => /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
72
|
+
fieldName && onChange && !disabled ? /* @__PURE__ */ jsx(StyledInput, { id: plan.value, type: "radio", name: fieldName, value: plan.value, onChange: () => onChange(plan.value), onFocus: () => {
|
|
73
|
+
setFocusedPlan(plan.value);
|
|
74
|
+
}, onBlur: () => {
|
|
75
|
+
setFocusedPlan(void 0);
|
|
76
|
+
}, "data-testid": plan.value }) : null,
|
|
77
|
+
/* @__PURE__ */ jsxs(FullHeightStack, { gap: 2, alignItems: "center", justifyContent: "space-between", children: [
|
|
78
|
+
/* @__PURE__ */ jsxs(Stack, { gap: 3, alignItems: "center", width: "100%", children: [
|
|
79
|
+
/* @__PURE__ */ jsxs(Stack, { gap: 1, alignItems: "center", children: [
|
|
80
|
+
/* @__PURE__ */ jsx(Badge, { disabled, sentiment: plan.sentiment && plan.sentiment !== "black" && plan.sentiment !== "white" ? plan.sentiment : "primary", children: /* @__PURE__ */ jsx("label", { htmlFor: plan.value, children: plan.title }) }),
|
|
81
|
+
plan.titleHeader,
|
|
82
|
+
/* @__PURE__ */ jsxs(Stack, { alignItems: "center", children: [
|
|
83
|
+
/* @__PURE__ */ jsx(Text, { as: "span", variant: "headingSmallStrong", sentiment: plan.sentiment ?? "primary", disabled, children: plan.header.price }),
|
|
84
|
+
/* @__PURE__ */ jsx(Stack, { style: {
|
|
85
|
+
minHeight: "16px"
|
|
86
|
+
}, children: plan.header.priceDescription ? /* @__PURE__ */ jsx(Text, { disabled, as: "span", variant: "caption", sentiment: plan.sentiment ?? "primary", children: plan.header.priceDescription }) : null })
|
|
87
|
+
] })
|
|
88
|
+
] }),
|
|
89
|
+
plan.header.description ? /* @__PURE__ */ jsx(PlanDescription, { children: /* @__PURE__ */ jsx(Text, { as: "div", variant: "caption", disabled, children: plan.header.description }) }) : null
|
|
90
|
+
] }),
|
|
91
|
+
/* @__PURE__ */ jsxs(Stack, { width: "100%", gap: 3, alignItems: "center", children: [
|
|
92
|
+
plan.header.cta && currentPlanValue !== plan.value ? plan.header.cta : null,
|
|
93
|
+
plan.header.cta && currentPlanValue === plan.value ? /* @__PURE__ */ jsx(CurrentPlanWrapper, { children: /* @__PURE__ */ jsx(Text, { as: "span", variant: "bodySmallStrong", sentiment: plan.sentiment ?? "primary", disabled, children: locales["plans.currentPlan"] }) }) : null,
|
|
94
|
+
plan.header.separator ? /* @__PURE__ */ jsx(FullSizeSeparator, {}) : null
|
|
95
|
+
] })
|
|
96
|
+
] })
|
|
97
|
+
] });
|
|
98
|
+
export {
|
|
99
|
+
PlanHeader
|
|
100
|
+
};
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
4
|
+
const _styled = require("@emotion/styled/base");
|
|
5
|
+
const icons = require("@ultraviolet/icons");
|
|
6
|
+
const ui = require("@ultraviolet/ui");
|
|
7
|
+
const react = require("react");
|
|
8
|
+
const FeatureHint = require("./FeatureHint.cjs");
|
|
9
|
+
const PlanHeader = require("./PlanHeader.cjs");
|
|
10
|
+
const en = require("./locales/en.cjs");
|
|
11
|
+
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
12
|
+
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
13
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
14
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
15
|
+
}
|
|
16
|
+
const PlanTable = /* @__PURE__ */ _styled__default.default("table", process.env.NODE_ENV === "production" ? {
|
|
17
|
+
target: "e1q2r1pt3"
|
|
18
|
+
} : {
|
|
19
|
+
target: "e1q2r1pt3",
|
|
20
|
+
label: "PlanTable"
|
|
21
|
+
})("table-layout:fixed;border-collapse:separate;border-spacing:", ({
|
|
22
|
+
theme
|
|
23
|
+
}) => theme.space[2], " 0;margin:0 -", ({
|
|
24
|
+
theme
|
|
25
|
+
}) => theme.space[2], ";width:calc(100% + ", ({
|
|
26
|
+
theme
|
|
27
|
+
}) => theme.space[4], ");height:1px;thead tr{height:100%;}td{outline:none;padding:", ({
|
|
28
|
+
theme
|
|
29
|
+
}) => theme.space["1"], `;text-align:center;&[data-selectable='true']{cursor:pointer;}}&[data-hide-labels="true"]{td{text-align:start;padding-left:`, ({
|
|
30
|
+
theme
|
|
31
|
+
}) => theme.space["3"], ";}}td:first-child{text-align:left;}thead td{height:100%;vertical-align:top;position:relative;padding-top:", ({
|
|
32
|
+
theme
|
|
33
|
+
}) => theme.space["4"], ";padding-bottom:", ({
|
|
34
|
+
theme
|
|
35
|
+
}) => theme.space["3"], ";}thead td:first-child{vertical-align:bottom;}thead td:not(:first-child){border:1px solid ", ({
|
|
36
|
+
theme
|
|
37
|
+
}) => theme.colors.neutral.border, ";border-radius:", ({
|
|
38
|
+
theme
|
|
39
|
+
}) => `${theme.radii.large} ${theme.radii.large} 0 0`, ";border-width:1px 1px 0 1px;&[data-hover='true'],&[data-active='true']{border-color:", ({
|
|
40
|
+
theme
|
|
41
|
+
}) => theme.colors.primary.border, ";}&[data-focus='true']{border-color:blue;border-width:2px 2px 0 2px;}}tbody td{&[data-space-after='true']{padding-bottom:", ({
|
|
42
|
+
theme
|
|
43
|
+
}) => theme.space["6"], ";}}tbody td:not(:first-child){border:1px solid ", ({
|
|
44
|
+
theme
|
|
45
|
+
}) => theme.colors.neutral.border, ";border-width:0px 1px;&[data-hover='true'],&[data-active='true']{border-color:", ({
|
|
46
|
+
theme
|
|
47
|
+
}) => theme.colors.primary.border, ";}&[data-focus='true']{border-color:blue;border-width:0px 2px;}}tbody tr:last-child td{padding-bottom:", ({
|
|
48
|
+
theme
|
|
49
|
+
}) => theme.space["4"], ";}tbody tr:last-child td:not(:first-child){border:1px solid ", ({
|
|
50
|
+
theme
|
|
51
|
+
}) => theme.colors.neutral.border, ";border-radius:", ({
|
|
52
|
+
theme
|
|
53
|
+
}) => `0 0 ${theme.radii.large} ${theme.radii.large}`, ";border-width:0 1px 1px 1px;&[data-hover='true'],&[data-active='true']{border-color:", ({
|
|
54
|
+
theme
|
|
55
|
+
}) => theme.colors.primary.border, `;}&[data-focus='true']{border-color:blue;border-width:0px 2px 2px 2px;}}tr{&[data-hide="true"]{display:none;}}` + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AAS8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */"));
|
|
56
|
+
const OutOfStockBadge = /* @__PURE__ */ _styled__default.default(ui.Badge, process.env.NODE_ENV === "production" ? {
|
|
57
|
+
target: "e1q2r1pt2"
|
|
58
|
+
} : {
|
|
59
|
+
target: "e1q2r1pt2",
|
|
60
|
+
label: "OutOfStockBadge"
|
|
61
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
62
|
+
name: "f96qbz",
|
|
63
|
+
styles: "position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(50%)"
|
|
64
|
+
} : {
|
|
65
|
+
name: "f96qbz",
|
|
66
|
+
styles: "position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(50%)/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AAqIqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */",
|
|
67
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
68
|
+
});
|
|
69
|
+
const PlanCell = /* @__PURE__ */ _styled__default.default("td", process.env.NODE_ENV === "production" ? {
|
|
70
|
+
target: "e1q2r1pt1"
|
|
71
|
+
} : {
|
|
72
|
+
target: "e1q2r1pt1",
|
|
73
|
+
label: "PlanCell"
|
|
74
|
+
})('background-color:transparent;&[data-disabled="true"]{background-color:', ({
|
|
75
|
+
theme
|
|
76
|
+
}) => theme.colors.neutral.backgroundDisabled, ';}&[data-hide="true"]{display:none;}' + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AA4I0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */"));
|
|
77
|
+
const UppercaseText = /* @__PURE__ */ _styled__default.default(ui.Text, process.env.NODE_ENV === "production" ? {
|
|
78
|
+
target: "e1q2r1pt0"
|
|
79
|
+
} : {
|
|
80
|
+
target: "e1q2r1pt0",
|
|
81
|
+
label: "UppercaseText"
|
|
82
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
83
|
+
name: "50zrmy",
|
|
84
|
+
styles: "text-transform:uppercase"
|
|
85
|
+
} : {
|
|
86
|
+
name: "50zrmy",
|
|
87
|
+
styles: "text-transform:uppercase/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AAyJkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */",
|
|
88
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
89
|
+
});
|
|
90
|
+
const Plans = ({
|
|
91
|
+
fieldName,
|
|
92
|
+
onChange,
|
|
93
|
+
value,
|
|
94
|
+
features,
|
|
95
|
+
plans,
|
|
96
|
+
hideFeatureText = false,
|
|
97
|
+
hideLabels = false,
|
|
98
|
+
locales = en
|
|
99
|
+
}) => {
|
|
100
|
+
const hasCardBehavior = !!(fieldName && onChange);
|
|
101
|
+
const [focusedPlan, setFocusedPlan] = react.useState();
|
|
102
|
+
const [hoveredPlan, setHoveredPlan] = react.useState();
|
|
103
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(PlanTable, { "data-hide-labels": hideLabels, children: [
|
|
104
|
+
/* @__PURE__ */ jsxRuntime.jsx("thead", { children: /* @__PURE__ */ jsxRuntime.jsxs("tr", { children: [
|
|
105
|
+
/* @__PURE__ */ jsxRuntime.jsx(PlanCell, { "data-hide": hideLabels, children: !hideFeatureText ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", variant: "headingSmallStrong", children: locales["plans.features"] }) : null }),
|
|
106
|
+
plans.map((plan) => {
|
|
107
|
+
const computedDisabled = !!(plan.outOfStock || plan.disabled);
|
|
108
|
+
const selectable = hasCardBehavior && !computedDisabled;
|
|
109
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(PlanCell, { "data-disabled": computedDisabled, "data-active": value === plan.value, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value, "data-selectable": selectable, onClick: selectable ? () => onChange(plan.value) : void 0, onMouseOver: selectable ? () => setHoveredPlan(plan.value) : void 0, onMouseOut: selectable ? () => setHoveredPlan(void 0) : void 0, children: [
|
|
110
|
+
plan.outOfStock ? /* @__PURE__ */ jsxRuntime.jsx(OutOfStockBadge, { size: "small", children: locales["plans.outOfStock"] }) : null,
|
|
111
|
+
plan.header.quotas ? /* @__PURE__ */ jsxRuntime.jsx(OutOfStockBadge, { size: "small", children: plan.header.quotas }) : null,
|
|
112
|
+
/* @__PURE__ */ jsxRuntime.jsx(PlanHeader.PlanHeader, { fieldName, setFocusedPlan, onChange, currentPlanValue: value, plan, disabled: computedDisabled })
|
|
113
|
+
] }, plan.value);
|
|
114
|
+
})
|
|
115
|
+
] }) }),
|
|
116
|
+
/* @__PURE__ */ jsxRuntime.jsx("tbody", { children: features.map((feature) => {
|
|
117
|
+
if ("group" in feature) {
|
|
118
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("tr", { "data-hide": hideLabels, children: [
|
|
119
|
+
/* @__PURE__ */ jsxRuntime.jsx(PlanCell, { children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction: "row", alignItems: "center", gap: 1, children: [
|
|
120
|
+
/* @__PURE__ */ jsxRuntime.jsx(UppercaseText, { as: "p", variant: "bodySmallStronger", sentiment: "neutral", children: feature.group }),
|
|
121
|
+
feature.hint ? /* @__PURE__ */ jsxRuntime.jsx(FeatureHint.FeatureHint, { hint: feature.hint }) : null
|
|
122
|
+
] }) }),
|
|
123
|
+
plans.map((plan) => /* @__PURE__ */ jsxRuntime.jsx(PlanCell, { "data-disabled": plan.outOfStock || plan.disabled, "data-active": value === plan.value, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value }, plan.value))
|
|
124
|
+
] }, feature.group);
|
|
125
|
+
}
|
|
126
|
+
const featureKey = feature.key ?? "";
|
|
127
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("tr", { children: [
|
|
128
|
+
/* @__PURE__ */ jsxRuntime.jsx(PlanCell, { "data-hide": hideLabels, children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { children: [
|
|
129
|
+
/* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", direction: "row", gap: 1, children: [
|
|
130
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", variant: "bodyStrong", children: feature.text }),
|
|
131
|
+
/* @__PURE__ */ jsxRuntime.jsx(FeatureHint.FeatureHint, { hint: feature.hint })
|
|
132
|
+
] }),
|
|
133
|
+
feature.description ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "div", variant: "caption", prominence: "weak", sentiment: "neutral", placement: "start", children: feature.description }) : null
|
|
134
|
+
] }) }),
|
|
135
|
+
plans.map((plan) => {
|
|
136
|
+
const computedDisabled = plan.outOfStock || plan.disabled;
|
|
137
|
+
const selectable = hasCardBehavior && !computedDisabled;
|
|
138
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(PlanCell, { "data-disabled": computedDisabled, "data-selectable": selectable, onClick: selectable ? () => onChange(plan.value) : void 0, "data-active": value === plan.value, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value, onMouseOver: selectable ? () => {
|
|
139
|
+
setHoveredPlan(plan.value);
|
|
140
|
+
} : void 0, onMouseOut: selectable ? () => {
|
|
141
|
+
setHoveredPlan(void 0);
|
|
142
|
+
} : void 0, "data-testid": `${plan.value}-${feature.key}`, children: [
|
|
143
|
+
plan.data[featureKey] === false ? /* @__PURE__ */ jsxRuntime.jsx(icons.CloseIcon, { disabled: computedDisabled, size: "large", sentiment: "neutral", prominence: "weak" }) : null,
|
|
144
|
+
plan.data[featureKey] === true ? /* @__PURE__ */ jsxRuntime.jsx(icons.CheckCircleIcon, { disabled: computedDisabled, size: "medium", sentiment: "success" }) : null,
|
|
145
|
+
typeof plan.data[featureKey] !== "boolean" ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { disabled: computedDisabled, as: "span", variant: "body", sentiment: "neutral", children: plan.data[featureKey] }) : null
|
|
146
|
+
] }, plan.value);
|
|
147
|
+
})
|
|
148
|
+
] }, feature.key);
|
|
149
|
+
}) })
|
|
150
|
+
] });
|
|
151
|
+
};
|
|
152
|
+
exports.Plans = Plans;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import PlansLocales from './locales/en';
|
|
2
|
+
import type { Feature, PlanType } from './types';
|
|
3
|
+
type PlansProps<T extends string> = {
|
|
4
|
+
fieldName?: string;
|
|
5
|
+
onChange?: (newPlanValue: string | undefined) => void;
|
|
6
|
+
value?: string;
|
|
7
|
+
features: Feature<T>[];
|
|
8
|
+
plans: PlanType<T>[];
|
|
9
|
+
hideFeatureText?: boolean;
|
|
10
|
+
hideLabels?: boolean;
|
|
11
|
+
locales?: Record<keyof typeof PlansLocales, string>;
|
|
12
|
+
};
|
|
13
|
+
export declare const Plans: <T extends string>({ fieldName, onChange, value, features, plans, hideFeatureText, hideLabels, locales, }: PlansProps<T>) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
|
+
import { CloseIcon, CheckCircleIcon } from "@ultraviolet/icons";
|
|
4
|
+
import { Text, Stack, Badge } from "@ultraviolet/ui";
|
|
5
|
+
import { useState } from "react";
|
|
6
|
+
import { FeatureHint } from "./FeatureHint.js";
|
|
7
|
+
import { PlanHeader } from "./PlanHeader.js";
|
|
8
|
+
import PlansLocales from "./locales/en.js";
|
|
9
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
10
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
11
|
+
}
|
|
12
|
+
const PlanTable = /* @__PURE__ */ _styled("table", process.env.NODE_ENV === "production" ? {
|
|
13
|
+
target: "e1q2r1pt3"
|
|
14
|
+
} : {
|
|
15
|
+
target: "e1q2r1pt3",
|
|
16
|
+
label: "PlanTable"
|
|
17
|
+
})("table-layout:fixed;border-collapse:separate;border-spacing:", ({
|
|
18
|
+
theme
|
|
19
|
+
}) => theme.space[2], " 0;margin:0 -", ({
|
|
20
|
+
theme
|
|
21
|
+
}) => theme.space[2], ";width:calc(100% + ", ({
|
|
22
|
+
theme
|
|
23
|
+
}) => theme.space[4], ");height:1px;thead tr{height:100%;}td{outline:none;padding:", ({
|
|
24
|
+
theme
|
|
25
|
+
}) => theme.space["1"], `;text-align:center;&[data-selectable='true']{cursor:pointer;}}&[data-hide-labels="true"]{td{text-align:start;padding-left:`, ({
|
|
26
|
+
theme
|
|
27
|
+
}) => theme.space["3"], ";}}td:first-child{text-align:left;}thead td{height:100%;vertical-align:top;position:relative;padding-top:", ({
|
|
28
|
+
theme
|
|
29
|
+
}) => theme.space["4"], ";padding-bottom:", ({
|
|
30
|
+
theme
|
|
31
|
+
}) => theme.space["3"], ";}thead td:first-child{vertical-align:bottom;}thead td:not(:first-child){border:1px solid ", ({
|
|
32
|
+
theme
|
|
33
|
+
}) => theme.colors.neutral.border, ";border-radius:", ({
|
|
34
|
+
theme
|
|
35
|
+
}) => `${theme.radii.large} ${theme.radii.large} 0 0`, ";border-width:1px 1px 0 1px;&[data-hover='true'],&[data-active='true']{border-color:", ({
|
|
36
|
+
theme
|
|
37
|
+
}) => theme.colors.primary.border, ";}&[data-focus='true']{border-color:blue;border-width:2px 2px 0 2px;}}tbody td{&[data-space-after='true']{padding-bottom:", ({
|
|
38
|
+
theme
|
|
39
|
+
}) => theme.space["6"], ";}}tbody td:not(:first-child){border:1px solid ", ({
|
|
40
|
+
theme
|
|
41
|
+
}) => theme.colors.neutral.border, ";border-width:0px 1px;&[data-hover='true'],&[data-active='true']{border-color:", ({
|
|
42
|
+
theme
|
|
43
|
+
}) => theme.colors.primary.border, ";}&[data-focus='true']{border-color:blue;border-width:0px 2px;}}tbody tr:last-child td{padding-bottom:", ({
|
|
44
|
+
theme
|
|
45
|
+
}) => theme.space["4"], ";}tbody tr:last-child td:not(:first-child){border:1px solid ", ({
|
|
46
|
+
theme
|
|
47
|
+
}) => theme.colors.neutral.border, ";border-radius:", ({
|
|
48
|
+
theme
|
|
49
|
+
}) => `0 0 ${theme.radii.large} ${theme.radii.large}`, ";border-width:0 1px 1px 1px;&[data-hover='true'],&[data-active='true']{border-color:", ({
|
|
50
|
+
theme
|
|
51
|
+
}) => theme.colors.primary.border, `;}&[data-focus='true']{border-color:blue;border-width:0px 2px 2px 2px;}}tr{&[data-hide="true"]{display:none;}}` + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AAS8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */"));
|
|
52
|
+
const OutOfStockBadge = /* @__PURE__ */ _styled(Badge, process.env.NODE_ENV === "production" ? {
|
|
53
|
+
target: "e1q2r1pt2"
|
|
54
|
+
} : {
|
|
55
|
+
target: "e1q2r1pt2",
|
|
56
|
+
label: "OutOfStockBadge"
|
|
57
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
58
|
+
name: "f96qbz",
|
|
59
|
+
styles: "position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(50%)"
|
|
60
|
+
} : {
|
|
61
|
+
name: "f96qbz",
|
|
62
|
+
styles: "position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(50%)/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AAqIqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */",
|
|
63
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
64
|
+
});
|
|
65
|
+
const PlanCell = /* @__PURE__ */ _styled("td", process.env.NODE_ENV === "production" ? {
|
|
66
|
+
target: "e1q2r1pt1"
|
|
67
|
+
} : {
|
|
68
|
+
target: "e1q2r1pt1",
|
|
69
|
+
label: "PlanCell"
|
|
70
|
+
})('background-color:transparent;&[data-disabled="true"]{background-color:', ({
|
|
71
|
+
theme
|
|
72
|
+
}) => theme.colors.neutral.backgroundDisabled, ';}&[data-hide="true"]{display:none;}' + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AA4I0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */"));
|
|
73
|
+
const UppercaseText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
74
|
+
target: "e1q2r1pt0"
|
|
75
|
+
} : {
|
|
76
|
+
target: "e1q2r1pt0",
|
|
77
|
+
label: "UppercaseText"
|
|
78
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
79
|
+
name: "50zrmy",
|
|
80
|
+
styles: "text-transform:uppercase"
|
|
81
|
+
} : {
|
|
82
|
+
name: "50zrmy",
|
|
83
|
+
styles: "text-transform:uppercase/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx"],"names":[],"mappings":"AAyJkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Plans/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport { Badge, Stack, Text } from '@ultraviolet/ui'\nimport { useState } from 'react'\nimport { FeatureHint } from './FeatureHint'\nimport { PlanHeader } from './PlanHeader'\nimport PlansLocales from './locales/en'\nimport type { Feature, PlanType } from './types'\n\nconst PlanTable = styled.table`\n  table-layout: fixed;\n  border-collapse: separate;\n  border-spacing: ${({ theme }) => theme.space[2]} 0;\n\n  /* Needed to compensate border-spacing behavior */\n  margin: 0 -${({ theme }) => theme.space[2]};\n  width: calc(100% + ${({ theme }) => theme.space[4]});\n\n  /* Needed to have full height div in header cell */\n  height: 1px;\n\n  thead tr {\n    height: 100%;\n  }\n\n  /* All cells */\n  td {\n    outline: none;\n    padding: ${({ theme }) => theme.space['1']};\n    text-align: center;\n\n    &[data-selectable='true'] {\n      cursor: pointer;\n    }\n  }\n\n  &[data-hide-labels=\"true\"] {\n    td {\n      text-align: start;\n      padding-left:  ${({ theme }) => theme.space['3']};\n    }\n  }\n\n  /* First column */\n  td:first-child {\n    text-align: left;\n  }\n\n  /* Header Cell */\n  thead td {\n    height: 100%;\n    vertical-align: top;\n    position: relative;\n    padding-top: ${({ theme }) => theme.space['4']};\n    padding-bottom: ${({ theme }) => theme.space['3']};\n  }\n\n  /* First Header Cell */\n  thead td:first-child {\n    vertical-align: bottom;\n  }\n\n  /* Not First Header Cell */\n  thead td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `${theme.radii.large} ${theme.radii.large} 0 0`};\n    border-width: 1px 1px 0 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 2px 2px 0 2px;\n    }\n  }\n\n  tbody td {\n    &[data-space-after='true'] {\n      padding-bottom: ${({ theme }) => theme.space['6']};\n    }\n  }\n\n  tbody td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-width: 0px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px;\n    }\n  }\n\n  /* Last row cells */\n  tbody tr:last-child td {\n    padding-bottom: ${({ theme }) => theme.space['4']};\n  }\n\n  tbody tr:last-child td:not(:first-child) {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) =>\n      `0 0 ${theme.radii.large} ${theme.radii.large}`};\n    border-width: 0 1px 1px 1px;\n\n    &[data-hover='true'],\n    &[data-active='true'] {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &[data-focus='true'] {\n      /* using native color to reproduce focus color */\n      border-color: blue;\n      border-width: 0px 2px 2px 2px;\n    }\n  }\n\n  tr {\n    &[data-hide=\"true\"] {\n    display: none;\n  }\n  }\n`\n\nconst OutOfStockBadge = styled(Badge)`\n  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%) translateY(50%);\n`\n\nconst PlanCell = styled.td`\n    background-color: transparent;\n\n  &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n    }\n\n  &[data-hide=\"true\"] {\n    display: none;\n  }\n`\n\nconst UppercaseText = styled(Text)`\n  text-transform: uppercase;\n`\ntype PlansProps<T extends string> = {\n  fieldName?: string\n  onChange?: (newPlanValue: string | undefined) => void\n  value?: string\n  features: Feature<T>[]\n  plans: PlanType<T>[]\n  hideFeatureText?: boolean\n  hideLabels?: boolean\n  locales?: Record<keyof typeof PlansLocales, string>\n}\n\nexport const Plans = <T extends string>({\n  fieldName,\n  onChange,\n  value,\n  features,\n  plans,\n  hideFeatureText = false,\n  hideLabels = false,\n  locales = PlansLocales,\n}: PlansProps<T>) => {\n  const hasCardBehavior = !!(fieldName && onChange)\n  const [focusedPlan, setFocusedPlan] = useState<string>()\n  const [hoveredPlan, setHoveredPlan] = useState<string>()\n\n  return (\n    <PlanTable data-hide-labels={hideLabels}>\n      <thead>\n        <tr>\n          <PlanCell data-hide={hideLabels}>\n            {!hideFeatureText ? (\n              <Text as=\"span\" variant=\"headingSmallStrong\">\n                {locales['plans.features']}\n              </Text>\n            ) : null}\n          </PlanCell>\n          {plans.map(plan => {\n            const computedDisabled = !!(plan.outOfStock || plan.disabled)\n            const selectable = hasCardBehavior && !computedDisabled\n\n            return (\n              <PlanCell\n                key={plan.value}\n                data-disabled={computedDisabled}\n                data-active={value === plan.value}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : undefined\n                }\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n              >\n                {plan.outOfStock ? (\n                  <OutOfStockBadge size=\"small\">\n                    {locales['plans.outOfStock']}\n                  </OutOfStockBadge>\n                ) : null}\n                {plan.header.quotas ? (\n                  <OutOfStockBadge size=\"small\">\n                    {plan.header.quotas}\n                  </OutOfStockBadge>\n                ) : null}\n                <PlanHeader\n                  fieldName={fieldName}\n                  setFocusedPlan={setFocusedPlan}\n                  onChange={onChange}\n                  currentPlanValue={value}\n                  plan={plan}\n                  disabled={computedDisabled}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr key={feature.group} data-hide={hideLabels}>\n                <PlanCell>\n                  <Stack direction=\"row\" alignItems=\"center\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      variant=\"bodySmallStronger\"\n                      sentiment=\"neutral\"\n                    >\n                      {feature.group}\n                    </UppercaseText>\n                    {feature.hint ? <FeatureHint hint={feature.hint} /> : null}\n                  </Stack>\n                </PlanCell>\n                {plans.map(plan => (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                  />\n                ))}\n              </tr>\n            )\n          }\n\n          const featureKey = feature.key ?? ''\n\n          return (\n            <tr key={feature.key}>\n              <PlanCell data-hide={hideLabels}>\n                <Stack>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <Text as=\"p\" variant=\"bodyStrong\">\n                      {feature.text}\n                    </Text>\n                    <FeatureHint hint={feature.hint} />\n                  </Stack>\n                  {feature.description ? (\n                    <Text\n                      as=\"div\"\n                      variant=\"caption\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      placement=\"start\"\n                    >\n                      {feature.description}\n                    </Text>\n                  ) : null}\n                </Stack>\n              </PlanCell>\n              {plans.map(plan => {\n                const computedDisabled = plan.outOfStock || plan.disabled\n                const selectable = hasCardBehavior && !computedDisabled\n\n                return (\n                  <PlanCell\n                    key={plan.value}\n                    data-disabled={computedDisabled}\n                    data-selectable={selectable}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    data-active={value === plan.value}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    data-testid={`${plan.value}-${feature.key}`}\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        size=\"large\"\n                        sentiment=\"neutral\"\n                        prominence=\"weak\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        size=\"medium\"\n                        sentiment=\"success\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        disabled={computedDisabled}\n                        as=\"span\"\n                        variant=\"body\"\n                        sentiment=\"neutral\"\n                      >\n                        {plan.data[featureKey]}\n                      </Text>\n                    ) : null}\n                  </PlanCell>\n                )\n              })}\n            </tr>\n          )\n        })}\n      </tbody>\n    </PlanTable>\n  )\n}\n"]} */",
|
|
84
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
85
|
+
});
|
|
86
|
+
const Plans = ({
|
|
87
|
+
fieldName,
|
|
88
|
+
onChange,
|
|
89
|
+
value,
|
|
90
|
+
features,
|
|
91
|
+
plans,
|
|
92
|
+
hideFeatureText = false,
|
|
93
|
+
hideLabels = false,
|
|
94
|
+
locales = PlansLocales
|
|
95
|
+
}) => {
|
|
96
|
+
const hasCardBehavior = !!(fieldName && onChange);
|
|
97
|
+
const [focusedPlan, setFocusedPlan] = useState();
|
|
98
|
+
const [hoveredPlan, setHoveredPlan] = useState();
|
|
99
|
+
return /* @__PURE__ */ jsxs(PlanTable, { "data-hide-labels": hideLabels, children: [
|
|
100
|
+
/* @__PURE__ */ jsx("thead", { children: /* @__PURE__ */ jsxs("tr", { children: [
|
|
101
|
+
/* @__PURE__ */ jsx(PlanCell, { "data-hide": hideLabels, children: !hideFeatureText ? /* @__PURE__ */ jsx(Text, { as: "span", variant: "headingSmallStrong", children: locales["plans.features"] }) : null }),
|
|
102
|
+
plans.map((plan) => {
|
|
103
|
+
const computedDisabled = !!(plan.outOfStock || plan.disabled);
|
|
104
|
+
const selectable = hasCardBehavior && !computedDisabled;
|
|
105
|
+
return /* @__PURE__ */ jsxs(PlanCell, { "data-disabled": computedDisabled, "data-active": value === plan.value, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value, "data-selectable": selectable, onClick: selectable ? () => onChange(plan.value) : void 0, onMouseOver: selectable ? () => setHoveredPlan(plan.value) : void 0, onMouseOut: selectable ? () => setHoveredPlan(void 0) : void 0, children: [
|
|
106
|
+
plan.outOfStock ? /* @__PURE__ */ jsx(OutOfStockBadge, { size: "small", children: locales["plans.outOfStock"] }) : null,
|
|
107
|
+
plan.header.quotas ? /* @__PURE__ */ jsx(OutOfStockBadge, { size: "small", children: plan.header.quotas }) : null,
|
|
108
|
+
/* @__PURE__ */ jsx(PlanHeader, { fieldName, setFocusedPlan, onChange, currentPlanValue: value, plan, disabled: computedDisabled })
|
|
109
|
+
] }, plan.value);
|
|
110
|
+
})
|
|
111
|
+
] }) }),
|
|
112
|
+
/* @__PURE__ */ jsx("tbody", { children: features.map((feature) => {
|
|
113
|
+
if ("group" in feature) {
|
|
114
|
+
return /* @__PURE__ */ jsxs("tr", { "data-hide": hideLabels, children: [
|
|
115
|
+
/* @__PURE__ */ jsx(PlanCell, { children: /* @__PURE__ */ jsxs(Stack, { direction: "row", alignItems: "center", gap: 1, children: [
|
|
116
|
+
/* @__PURE__ */ jsx(UppercaseText, { as: "p", variant: "bodySmallStronger", sentiment: "neutral", children: feature.group }),
|
|
117
|
+
feature.hint ? /* @__PURE__ */ jsx(FeatureHint, { hint: feature.hint }) : null
|
|
118
|
+
] }) }),
|
|
119
|
+
plans.map((plan) => /* @__PURE__ */ jsx(PlanCell, { "data-disabled": plan.outOfStock || plan.disabled, "data-active": value === plan.value, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value }, plan.value))
|
|
120
|
+
] }, feature.group);
|
|
121
|
+
}
|
|
122
|
+
const featureKey = feature.key ?? "";
|
|
123
|
+
return /* @__PURE__ */ jsxs("tr", { children: [
|
|
124
|
+
/* @__PURE__ */ jsx(PlanCell, { "data-hide": hideLabels, children: /* @__PURE__ */ jsxs(Stack, { children: [
|
|
125
|
+
/* @__PURE__ */ jsxs(Stack, { alignItems: "center", direction: "row", gap: 1, children: [
|
|
126
|
+
/* @__PURE__ */ jsx(Text, { as: "p", variant: "bodyStrong", children: feature.text }),
|
|
127
|
+
/* @__PURE__ */ jsx(FeatureHint, { hint: feature.hint })
|
|
128
|
+
] }),
|
|
129
|
+
feature.description ? /* @__PURE__ */ jsx(Text, { as: "div", variant: "caption", prominence: "weak", sentiment: "neutral", placement: "start", children: feature.description }) : null
|
|
130
|
+
] }) }),
|
|
131
|
+
plans.map((plan) => {
|
|
132
|
+
const computedDisabled = plan.outOfStock || plan.disabled;
|
|
133
|
+
const selectable = hasCardBehavior && !computedDisabled;
|
|
134
|
+
return /* @__PURE__ */ jsxs(PlanCell, { "data-disabled": computedDisabled, "data-selectable": selectable, onClick: selectable ? () => onChange(plan.value) : void 0, "data-active": value === plan.value, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value, onMouseOver: selectable ? () => {
|
|
135
|
+
setHoveredPlan(plan.value);
|
|
136
|
+
} : void 0, onMouseOut: selectable ? () => {
|
|
137
|
+
setHoveredPlan(void 0);
|
|
138
|
+
} : void 0, "data-testid": `${plan.value}-${feature.key}`, children: [
|
|
139
|
+
plan.data[featureKey] === false ? /* @__PURE__ */ jsx(CloseIcon, { disabled: computedDisabled, size: "large", sentiment: "neutral", prominence: "weak" }) : null,
|
|
140
|
+
plan.data[featureKey] === true ? /* @__PURE__ */ jsx(CheckCircleIcon, { disabled: computedDisabled, size: "medium", sentiment: "success" }) : null,
|
|
141
|
+
typeof plan.data[featureKey] !== "boolean" ? /* @__PURE__ */ jsx(Text, { disabled: computedDisabled, as: "span", variant: "body", sentiment: "neutral", children: plan.data[featureKey] }) : null
|
|
142
|
+
] }, plan.value);
|
|
143
|
+
})
|
|
144
|
+
] }, feature.key);
|
|
145
|
+
}) })
|
|
146
|
+
] });
|
|
147
|
+
};
|
|
148
|
+
export {
|
|
149
|
+
Plans
|
|
150
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { Text } from '@ultraviolet/ui';
|
|
2
|
+
import type { ComponentProps, ReactNode } from 'react';
|
|
3
|
+
export type Hint = {
|
|
4
|
+
type: 'tooltip';
|
|
5
|
+
text: string;
|
|
6
|
+
} | {
|
|
7
|
+
type: 'popover';
|
|
8
|
+
title: string;
|
|
9
|
+
content: ReactNode;
|
|
10
|
+
};
|
|
11
|
+
export type PlanType<T extends string> = {
|
|
12
|
+
value: string;
|
|
13
|
+
title: string;
|
|
14
|
+
titleHeader?: ReactNode;
|
|
15
|
+
sentiment?: ComponentProps<typeof Text>['sentiment'];
|
|
16
|
+
header: {
|
|
17
|
+
description?: ReactNode;
|
|
18
|
+
price: string;
|
|
19
|
+
quotas?: string;
|
|
20
|
+
priceDescription?: string;
|
|
21
|
+
cta?: ReactNode;
|
|
22
|
+
separator?: ReactNode;
|
|
23
|
+
};
|
|
24
|
+
outOfStock?: boolean;
|
|
25
|
+
disabled?: boolean;
|
|
26
|
+
data: Record<T, string | number | undefined | ReactNode>;
|
|
27
|
+
};
|
|
28
|
+
export type Feature<T extends string> = {
|
|
29
|
+
key: T;
|
|
30
|
+
text: string;
|
|
31
|
+
description?: string;
|
|
32
|
+
spaceAfter?: boolean;
|
|
33
|
+
hint?: Hint;
|
|
34
|
+
} | {
|
|
35
|
+
group: string;
|
|
36
|
+
hint?: Hint;
|
|
37
|
+
};
|
package/dist/index.cjs
CHANGED
|
@@ -11,6 +11,7 @@ const Navigation = require("./components/Navigation/Navigation.cjs");
|
|
|
11
11
|
const NavigationProvider = require("./components/Navigation/NavigationProvider.cjs");
|
|
12
12
|
const index$4 = require("./components/FAQ/index.cjs");
|
|
13
13
|
const SteppedListCard = require("./components/SteppedListCard/SteppedListCard.cjs");
|
|
14
|
+
const index$5 = require("./components/Plans/index.cjs");
|
|
14
15
|
exports.ContentCard = index.ContentCard;
|
|
15
16
|
exports.ContentCardGroup = index$1.ContentCardGroup;
|
|
16
17
|
exports.CodeEditor = CodeEditor.CodeEditor;
|
|
@@ -23,3 +24,4 @@ exports.NavigationProvider = NavigationProvider.NavigationProvider;
|
|
|
23
24
|
exports.useNavigation = NavigationProvider.useNavigation;
|
|
24
25
|
exports.FAQ = index$4.FAQ;
|
|
25
26
|
exports.SteppedListCard = SteppedListCard.SteppedListCard;
|
|
27
|
+
exports.Plans = index$5.Plans;
|
package/dist/index.js
CHANGED
|
@@ -9,6 +9,7 @@ import { Navigation } from "./components/Navigation/Navigation.js";
|
|
|
9
9
|
import { NavigationProvider, useNavigation } from "./components/Navigation/NavigationProvider.js";
|
|
10
10
|
import { FAQ } from "./components/FAQ/index.js";
|
|
11
11
|
import { SteppedListCard } from "./components/SteppedListCard/SteppedListCard.js";
|
|
12
|
+
import { Plans } from "./components/Plans/index.js";
|
|
12
13
|
export {
|
|
13
14
|
CodeEditor,
|
|
14
15
|
ContentCard,
|
|
@@ -19,6 +20,7 @@ export {
|
|
|
19
20
|
FAQ,
|
|
20
21
|
Navigation,
|
|
21
22
|
NavigationProvider,
|
|
23
|
+
Plans,
|
|
22
24
|
SteppedListCard,
|
|
23
25
|
default2 as estimateCostDefaultLocales,
|
|
24
26
|
useNavigation
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ultraviolet/plus",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.9",
|
|
4
4
|
"description": "Ultraviolet Plus",
|
|
5
5
|
"homepage": "https://github.com/scaleway/ultraviolet#readme",
|
|
6
6
|
"repository": {
|
|
@@ -55,27 +55,27 @@
|
|
|
55
55
|
"@emotion/styled": "11.14.0",
|
|
56
56
|
"react": "18.x || 19.x",
|
|
57
57
|
"react-dom": "18.x || 19.x",
|
|
58
|
-
"@ultraviolet/ui": "2.0.0-beta.
|
|
58
|
+
"@ultraviolet/ui": "2.0.0-beta.9"
|
|
59
59
|
},
|
|
60
60
|
"devDependencies": {
|
|
61
|
-
"@babel/core": "7.27.
|
|
61
|
+
"@babel/core": "7.27.4",
|
|
62
62
|
"@emotion/react": "11.14.0",
|
|
63
63
|
"@emotion/styled": "11.14.0",
|
|
64
|
-
"@types/react": "19.1.
|
|
64
|
+
"@types/react": "19.1.8",
|
|
65
65
|
"@types/react-dom": "19.1.6",
|
|
66
66
|
"react": "19.1.0",
|
|
67
67
|
"react-dom": "19.1.0",
|
|
68
68
|
"@ultraviolet/illustrations": "5.0.0-beta.2",
|
|
69
|
-
"@
|
|
70
|
-
"@
|
|
69
|
+
"@utils/test": "0.0.1",
|
|
70
|
+
"@ultraviolet/ui": "2.0.0-beta.9"
|
|
71
71
|
},
|
|
72
72
|
"dependencies": {
|
|
73
73
|
"@uiw/codemirror-extensions-langs": "4.23.12",
|
|
74
74
|
"@uiw/codemirror-theme-material": "4.23.12",
|
|
75
75
|
"@uiw/react-codemirror": "4.23.12",
|
|
76
76
|
"react-intersection-observer": "9.16.0",
|
|
77
|
-
"@ultraviolet/
|
|
78
|
-
"@ultraviolet/
|
|
77
|
+
"@ultraviolet/themes": "2.0.0-beta.2",
|
|
78
|
+
"@ultraviolet/icons": "4.0.0-beta.5"
|
|
79
79
|
},
|
|
80
80
|
"scripts": {
|
|
81
81
|
"type:generate": "tsc --declaration -p tsconfig.build.json",
|