@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.
@@ -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,6 @@
1
+ import type { Hint } from './types';
2
+ type FeatureHintProps = {
3
+ hint?: Hint;
4
+ };
5
+ export declare const FeatureHint: ({ hint }: FeatureHintProps) => import("@emotion/react/jsx-runtime").JSX.Element;
6
+ export {};
@@ -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,7 @@
1
+ "use strict";
2
+ const PlansLocales = {
3
+ "plans.features": "Features",
4
+ "plans.outOfStock": "Out of stock",
5
+ "plans.currentPlan": "Current plan"
6
+ };
7
+ module.exports = PlansLocales;
@@ -0,0 +1,6 @@
1
+ declare const _default: {
2
+ 'plans.features': string;
3
+ 'plans.outOfStock': string;
4
+ 'plans.currentPlan': string;
5
+ };
6
+ export default _default;
@@ -0,0 +1,8 @@
1
+ const PlansLocales = {
2
+ "plans.features": "Features",
3
+ "plans.outOfStock": "Out of stock",
4
+ "plans.currentPlan": "Current plan"
5
+ };
6
+ export {
7
+ PlansLocales as default
8
+ };
@@ -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
+ };
@@ -7,3 +7,4 @@ export { Conversation } from './Conversation';
7
7
  export { Navigation, NavigationProvider, useNavigation } from './Navigation';
8
8
  export { FAQ } from './FAQ';
9
9
  export { SteppedListCard } from './SteppedListCard';
10
+ export { Plans } from './Plans';
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.7",
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.7"
58
+ "@ultraviolet/ui": "2.0.0-beta.9"
59
59
  },
60
60
  "devDependencies": {
61
- "@babel/core": "7.27.1",
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.6",
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
- "@ultraviolet/ui": "2.0.0-beta.7",
70
- "@utils/test": "0.0.1"
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/icons": "4.0.0-beta.4",
78
- "@ultraviolet/themes": "2.0.0-beta.2"
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",