@ultraviolet/plus 3.0.0-beta.12 → 3.0.0-beta.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/dist/components/ContentCardGroup/styles.css.cjs +1 -0
  2. package/dist/components/ContentCardGroup/styles.css.js +1 -0
  3. package/dist/components/Conversation/styles.css.cjs +0 -1
  4. package/dist/components/Conversation/styles.css.js +0 -1
  5. package/dist/components/EstimateCost/Components/Item.cjs +32 -115
  6. package/dist/components/EstimateCost/Components/Item.js +34 -115
  7. package/dist/components/EstimateCost/Components/LineThrough.cjs +6 -14
  8. package/dist/components/EstimateCost/Components/LineThrough.d.ts +3 -5
  9. package/dist/components/EstimateCost/Components/LineThrough.js +6 -12
  10. package/dist/components/EstimateCost/Components/NumberInput.cjs +2 -2
  11. package/dist/components/EstimateCost/Components/NumberInput.js +2 -2
  12. package/dist/components/EstimateCost/Components/Region.cjs +2 -12
  13. package/dist/components/EstimateCost/Components/Region.js +2 -10
  14. package/dist/components/EstimateCost/Components/Regular.cjs +5 -20
  15. package/dist/components/EstimateCost/Components/Regular.js +5 -18
  16. package/dist/components/EstimateCost/Components/Strong.cjs +7 -22
  17. package/dist/components/EstimateCost/Components/Strong.d.ts +1 -9
  18. package/dist/components/EstimateCost/Components/Strong.js +8 -21
  19. package/dist/components/EstimateCost/Components/Unit.cjs +3 -22
  20. package/dist/components/EstimateCost/Components/Unit.js +3 -20
  21. package/dist/components/EstimateCost/Components/Zone.cjs +2 -12
  22. package/dist/components/EstimateCost/Components/Zone.js +2 -10
  23. package/dist/components/EstimateCost/Components/components.css.cjs +123 -0
  24. package/dist/components/EstimateCost/Components/components.css.d.ts +77 -0
  25. package/dist/components/EstimateCost/Components/components.css.js +123 -0
  26. package/dist/components/EstimateCost/EstimateCost.cjs +15 -20
  27. package/dist/components/EstimateCost/EstimateCost.d.ts +9 -15
  28. package/dist/components/EstimateCost/EstimateCost.js +15 -18
  29. package/dist/components/EstimateCost/EstimateCostContent.cjs +21 -72
  30. package/dist/components/EstimateCost/EstimateCostContent.js +22 -71
  31. package/dist/components/EstimateCost/OverlayComponent.cjs +13 -51
  32. package/dist/components/EstimateCost/OverlayComponent.js +14 -50
  33. package/dist/components/EstimateCost/constants.cjs +0 -4
  34. package/dist/components/EstimateCost/constants.js +0 -4
  35. package/dist/components/EstimateCost/styles.css.cjs +50 -0
  36. package/dist/components/EstimateCost/styles.css.d.ts +76 -0
  37. package/dist/components/EstimateCost/styles.css.js +50 -0
  38. package/dist/components/Navigation/Footer.cjs +4 -19
  39. package/dist/components/Navigation/Footer.js +4 -17
  40. package/dist/components/Navigation/Header.cjs +2 -20
  41. package/dist/components/Navigation/Header.js +2 -18
  42. package/dist/components/Navigation/NavigationContent.cjs +13 -64
  43. package/dist/components/Navigation/NavigationContent.js +14 -63
  44. package/dist/components/Navigation/animations.css.d.ts +6 -0
  45. package/dist/components/Navigation/components/Group.cjs +6 -33
  46. package/dist/components/Navigation/components/Group.js +6 -31
  47. package/dist/components/Navigation/components/Item.cjs +83 -237
  48. package/dist/components/Navigation/components/Item.js +84 -236
  49. package/dist/components/Navigation/components/PinnedItems.cjs +7 -45
  50. package/dist/components/Navigation/components/PinnedItems.js +7 -43
  51. package/dist/components/Navigation/components/Separator.cjs +2 -12
  52. package/dist/components/Navigation/components/Separator.js +2 -10
  53. package/dist/components/Navigation/components/items.css.cjs +47 -0
  54. package/dist/components/Navigation/components/items.css.d.ts +70 -0
  55. package/dist/components/Navigation/components/items.css.js +47 -0
  56. package/dist/components/Navigation/components/styles.css.cjs +17 -0
  57. package/dist/components/Navigation/components/styles.css.d.ts +23 -0
  58. package/dist/components/Navigation/components/styles.css.js +17 -0
  59. package/dist/components/Navigation/constants.cjs +0 -27
  60. package/dist/components/Navigation/constants.d.ts +0 -12
  61. package/dist/components/Navigation/constants.js +1 -28
  62. package/dist/components/Navigation/styles.css.cjs +23 -0
  63. package/dist/components/Navigation/styles.css.d.ts +33 -0
  64. package/dist/components/Navigation/styles.css.js +23 -0
  65. package/dist/components/Navigation/variables.css.cjs +4 -0
  66. package/dist/components/Navigation/variables.css.d.ts +1 -0
  67. package/dist/components/Navigation/variables.css.js +4 -0
  68. package/dist/components/OrderSummary/NonScrollableContent.cjs +2 -14
  69. package/dist/components/OrderSummary/NonScrollableContent.js +2 -12
  70. package/dist/components/OrderSummary/ScrollableContent.cjs +5 -41
  71. package/dist/components/OrderSummary/ScrollableContent.js +5 -39
  72. package/dist/components/OrderSummary/index.cjs +4 -38
  73. package/dist/components/OrderSummary/index.js +5 -37
  74. package/dist/components/OrderSummary/styles.css.cjs +19 -0
  75. package/dist/components/OrderSummary/styles.css.d.ts +8 -0
  76. package/dist/components/OrderSummary/styles.css.js +19 -0
  77. package/dist/components/Plans/FeatureHint.cjs +2 -20
  78. package/dist/components/Plans/FeatureHint.js +2 -18
  79. package/dist/components/Plans/index.cjs +40 -91
  80. package/dist/components/Plans/index.js +44 -93
  81. package/dist/components/Plans/styles.css.cjs +16 -0
  82. package/dist/components/Plans/styles.css.d.ts +56 -0
  83. package/dist/components/Plans/styles.css.js +16 -0
  84. package/dist/components/SteppedListCard/Step.cjs +2 -33
  85. package/dist/components/SteppedListCard/Step.js +2 -31
  86. package/dist/components/SteppedListCard/SteppedListCard.cjs +3 -31
  87. package/dist/components/SteppedListCard/SteppedListCard.js +4 -30
  88. package/dist/components/SteppedListCard/SteppedListContent.cjs +4 -40
  89. package/dist/components/SteppedListCard/SteppedListContent.js +5 -39
  90. package/dist/components/SteppedListCard/styles.css.cjs +17 -0
  91. package/dist/components/SteppedListCard/styles.css.d.ts +7 -0
  92. package/dist/components/SteppedListCard/styles.css.js +17 -0
  93. package/dist/plus.css +1 -1
  94. package/package.json +6 -6
  95. package/dist/components/EstimateCost/componentStyle.cjs +0 -221
  96. package/dist/components/EstimateCost/componentStyle.d.ts +0 -106
  97. package/dist/components/EstimateCost/componentStyle.js +0 -219
@@ -1,92 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
- const _styled = require("@emotion/styled/base");
5
4
  const icons = require("@ultraviolet/icons");
6
5
  const ui = require("@ultraviolet/ui");
7
6
  const react = require("react");
8
7
  const FeatureHint = require("./FeatureHint.cjs");
9
8
  const en = require("./locales/en.cjs");
10
9
  const PlanHeader = require("./PlanHeader.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 PlansLocales from './locales/en'\nimport { PlanHeader } from './PlanHeader'\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                data-active={value === plan.value}\n                data-disabled={computedDisabled}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                key={plan.value}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : 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                  currentPlanValue={value}\n                  disabled={computedDisabled}\n                  fieldName={fieldName}\n                  onChange={onChange}\n                  plan={plan}\n                  setFocusedPlan={setFocusedPlan}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr data-hide={hideLabels} key={feature.group}>\n                <PlanCell>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      sentiment=\"neutral\"\n                      variant=\"bodySmallStronger\"\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                    data-active={value === plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    key={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                      placement=\"start\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      variant=\"caption\"\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                    data-active={value === plan.value}\n                    data-disabled={computedDisabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    data-selectable={selectable}\n                    data-testid={`${plan.value}-${feature.key}`}\n                    key={plan.value}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        prominence=\"weak\"\n                        sentiment=\"neutral\"\n                        size=\"large\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        sentiment=\"success\"\n                        size=\"medium\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        as=\"span\"\n                        disabled={computedDisabled}\n                        sentiment=\"neutral\"\n                        variant=\"body\"\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 PlansLocales from './locales/en'\nimport { PlanHeader } from './PlanHeader'\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                data-active={value === plan.value}\n                data-disabled={computedDisabled}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                key={plan.value}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : 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                  currentPlanValue={value}\n                  disabled={computedDisabled}\n                  fieldName={fieldName}\n                  onChange={onChange}\n                  plan={plan}\n                  setFocusedPlan={setFocusedPlan}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr data-hide={hideLabels} key={feature.group}>\n                <PlanCell>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      sentiment=\"neutral\"\n                      variant=\"bodySmallStronger\"\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                    data-active={value === plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    key={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                      placement=\"start\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      variant=\"caption\"\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                    data-active={value === plan.value}\n                    data-disabled={computedDisabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    data-selectable={selectable}\n                    data-testid={`${plan.value}-${feature.key}`}\n                    key={plan.value}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        prominence=\"weak\"\n                        sentiment=\"neutral\"\n                        size=\"large\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        sentiment=\"success\"\n                        size=\"medium\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        as=\"span\"\n                        disabled={computedDisabled}\n                        sentiment=\"neutral\"\n                        variant=\"body\"\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 PlansLocales from './locales/en'\nimport { PlanHeader } from './PlanHeader'\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                data-active={value === plan.value}\n                data-disabled={computedDisabled}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                key={plan.value}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : 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                  currentPlanValue={value}\n                  disabled={computedDisabled}\n                  fieldName={fieldName}\n                  onChange={onChange}\n                  plan={plan}\n                  setFocusedPlan={setFocusedPlan}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr data-hide={hideLabels} key={feature.group}>\n                <PlanCell>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      sentiment=\"neutral\"\n                      variant=\"bodySmallStronger\"\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                    data-active={value === plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    key={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                      placement=\"start\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      variant=\"caption\"\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                    data-active={value === plan.value}\n                    data-disabled={computedDisabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    data-selectable={selectable}\n                    data-testid={`${plan.value}-${feature.key}`}\n                    key={plan.value}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        prominence=\"weak\"\n                        sentiment=\"neutral\"\n                        size=\"large\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        sentiment=\"success\"\n                        size=\"medium\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        as=\"span\"\n                        disabled={computedDisabled}\n                        sentiment=\"neutral\"\n                        variant=\"body\"\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 PlansLocales from './locales/en'\nimport { PlanHeader } from './PlanHeader'\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                data-active={value === plan.value}\n                data-disabled={computedDisabled}\n                data-focus={focusedPlan === plan.value}\n                data-hover={hoveredPlan === plan.value}\n                data-selectable={selectable}\n                key={plan.value}\n                onClick={selectable ? () => onChange(plan.value) : undefined}\n                onMouseOut={\n                  selectable ? () => setHoveredPlan(undefined) : undefined\n                }\n                onMouseOver={\n                  selectable ? () => setHoveredPlan(plan.value) : 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                  currentPlanValue={value}\n                  disabled={computedDisabled}\n                  fieldName={fieldName}\n                  onChange={onChange}\n                  plan={plan}\n                  setFocusedPlan={setFocusedPlan}\n                />\n              </PlanCell>\n            )\n          })}\n        </tr>\n      </thead>\n      <tbody>\n        {features.map(feature => {\n          if ('group' in feature) {\n            return (\n              <tr data-hide={hideLabels} key={feature.group}>\n                <PlanCell>\n                  <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n                    <UppercaseText\n                      as=\"p\"\n                      sentiment=\"neutral\"\n                      variant=\"bodySmallStronger\"\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                    data-active={value === plan.value}\n                    data-disabled={plan.outOfStock || plan.disabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    key={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                      placement=\"start\"\n                      prominence=\"weak\"\n                      sentiment=\"neutral\"\n                      variant=\"caption\"\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                    data-active={value === plan.value}\n                    data-disabled={computedDisabled}\n                    data-focus={focusedPlan === plan.value}\n                    data-hover={hoveredPlan === plan.value}\n                    data-selectable={selectable}\n                    data-testid={`${plan.value}-${feature.key}`}\n                    key={plan.value}\n                    onClick={\n                      selectable ? () => onChange(plan.value) : undefined\n                    }\n                    onMouseOut={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(undefined)\n                          }\n                        : undefined\n                    }\n                    onMouseOver={\n                      selectable\n                        ? () => {\n                            setHoveredPlan(plan.value)\n                          }\n                        : undefined\n                    }\n                  >\n                    {plan.data[featureKey] === false ? (\n                      <CloseIcon\n                        disabled={computedDisabled}\n                        prominence=\"weak\"\n                        sentiment=\"neutral\"\n                        size=\"large\"\n                      />\n                    ) : null}\n                    {plan.data[featureKey] === true ? (\n                      <CheckCircleIcon\n                        disabled={computedDisabled}\n                        sentiment=\"success\"\n                        size=\"medium\"\n                      />\n                    ) : null}\n                    {typeof plan.data[featureKey] !== 'boolean' ? (\n                      <Text\n                        as=\"span\"\n                        disabled={computedDisabled}\n                        sentiment=\"neutral\"\n                        variant=\"body\"\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
- });
10
+ const styles_css = require("./styles.css.cjs");
90
11
  const Plans = ({
91
12
  fieldName,
92
13
  onChange,
@@ -100,32 +21,51 @@ const Plans = ({
100
21
  const hasCardBehavior = !!(fieldName && onChange);
101
22
  const [focusedPlan, setFocusedPlan] = react.useState();
102
23
  const [hoveredPlan, setHoveredPlan] = react.useState();
103
- return /* @__PURE__ */ jsxRuntime.jsxs(PlanTable, { "data-hide-labels": hideLabels, children: [
24
+ return /* @__PURE__ */ jsxRuntime.jsxs("table", { className: styles_css.plans, children: [
104
25
  /* @__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 }),
26
+ /* @__PURE__ */ jsxRuntime.jsx("td", { className: styles_css.plansCell({
27
+ hide: hideLabels
28
+ }), children: !hideFeatureText ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", variant: "headingSmallStrong", children: locales["plans.features"] }) : null }),
106
29
  plans.map((plan) => {
107
30
  const computedDisabled = !!(plan.outOfStock || plan.disabled);
108
31
  const selectable = hasCardBehavior && !computedDisabled;
109
- return /* @__PURE__ */ jsxRuntime.jsxs(PlanCell, { "data-active": value === plan.value, "data-disabled": computedDisabled, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value, "data-selectable": selectable, onClick: selectable ? () => onChange(plan.value) : void 0, onMouseOut: selectable ? () => setHoveredPlan(void 0) : void 0, onMouseOver: selectable ? () => setHoveredPlan(plan.value) : 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,
32
+ return /* @__PURE__ */ jsxRuntime.jsxs("td", { className: styles_css.plansCell({
33
+ activeColor: value === plan.value || hoveredPlan === plan.value,
34
+ disabled: computedDisabled,
35
+ focus: focusedPlan === plan.value,
36
+ hideLabels,
37
+ selectable
38
+ }), onBlur: selectable ? () => setHoveredPlan(void 0) : void 0, onClick: selectable ? () => onChange(plan.value) : void 0, onFocus: selectable ? () => setHoveredPlan(plan.value) : void 0, onKeyDown: (event) => {
39
+ if ([" ", "Enter"].includes(event.key) && selectable) {
40
+ onChange(plan.value);
41
+ }
42
+ }, onMouseOut: selectable ? () => setHoveredPlan(void 0) : void 0, onMouseOver: selectable ? () => setHoveredPlan(plan.value) : void 0, children: [
43
+ plan.outOfStock ? /* @__PURE__ */ jsxRuntime.jsx(ui.Badge, { className: styles_css.plansOutOfStockBadge, size: "small", children: locales["plans.outOfStock"] }) : null,
44
+ plan.header.quotas ? /* @__PURE__ */ jsxRuntime.jsx(ui.Badge, { className: styles_css.plansOutOfStockBadge, size: "small", children: plan.header.quotas }) : null,
112
45
  /* @__PURE__ */ jsxRuntime.jsx(PlanHeader.PlanHeader, { currentPlanValue: value, disabled: computedDisabled, fieldName, onChange, plan, setFocusedPlan })
113
46
  ] }, plan.value);
114
47
  })
115
48
  ] }) }),
116
49
  /* @__PURE__ */ jsxRuntime.jsx("tbody", { children: features.map((feature) => {
117
50
  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, { alignItems: "center", direction: "row", gap: 1, children: [
120
- /* @__PURE__ */ jsxRuntime.jsx(UppercaseText, { as: "p", sentiment: "neutral", variant: "bodySmallStronger", children: feature.group }),
51
+ return /* @__PURE__ */ jsxRuntime.jsxs("tr", { className: hideLabels ? styles_css.plansRowHidden : "", children: [
52
+ /* @__PURE__ */ jsxRuntime.jsx("td", { className: styles_css.plansCell({}), children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", direction: "row", gap: 1, children: [
53
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", className: styles_css.plansUppercaseText, sentiment: "neutral", variant: "bodySmallStronger", children: feature.group }),
121
54
  feature.hint ? /* @__PURE__ */ jsxRuntime.jsx(FeatureHint.FeatureHint, { hint: feature.hint }) : null
122
55
  ] }) }),
123
- plans.map((plan) => /* @__PURE__ */ jsxRuntime.jsx(PlanCell, { "data-active": value === plan.value, "data-disabled": plan.outOfStock || plan.disabled, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value }, plan.value))
56
+ plans.map((plan) => /* @__PURE__ */ jsxRuntime.jsx("td", { className: styles_css.plansCell({
57
+ activeColor: value === plan.value || hoveredPlan === plan.value,
58
+ disabled: plan.outOfStock || plan.disabled,
59
+ focus: focusedPlan === plan.value,
60
+ hide: hideLabels
61
+ }) }, plan.value))
124
62
  ] }, feature.group);
125
63
  }
126
64
  const featureKey = feature.key ?? "";
127
65
  return /* @__PURE__ */ jsxRuntime.jsxs("tr", { children: [
128
- /* @__PURE__ */ jsxRuntime.jsx(PlanCell, { "data-hide": hideLabels, children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { children: [
66
+ /* @__PURE__ */ jsxRuntime.jsx("td", { className: styles_css.plansCell({
67
+ hide: hideLabels
68
+ }), children: /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { children: [
129
69
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", direction: "row", gap: 1, children: [
130
70
  /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", variant: "bodyStrong", children: feature.text }),
131
71
  /* @__PURE__ */ jsxRuntime.jsx(FeatureHint.FeatureHint, { hint: feature.hint })
@@ -135,7 +75,16 @@ const Plans = ({
135
75
  plans.map((plan) => {
136
76
  const computedDisabled = plan.outOfStock || plan.disabled;
137
77
  const selectable = hasCardBehavior && !computedDisabled;
138
- return /* @__PURE__ */ jsxRuntime.jsxs(PlanCell, { "data-active": value === plan.value, "data-disabled": computedDisabled, "data-focus": focusedPlan === plan.value, "data-hover": hoveredPlan === plan.value, "data-selectable": selectable, "data-testid": `${plan.value}-${feature.key}`, onClick: selectable ? () => onChange(plan.value) : void 0, onMouseOut: selectable ? () => {
78
+ return /* @__PURE__ */ jsxRuntime.jsxs("td", { className: styles_css.plansCell({
79
+ activeColor: value === plan.value || hoveredPlan === plan.value,
80
+ disabled: computedDisabled,
81
+ focus: focusedPlan === plan.value,
82
+ hideLabels,
83
+ selectable
84
+ }), "data-testid": `${plan.value}-${feature.key}`, onBlur: () => {
85
+ }, onClick: selectable ? () => onChange(plan.value) : void 0, onFocus: () => {
86
+ }, onKeyDown: () => {
87
+ }, onMouseOut: selectable ? () => {
139
88
  setHoveredPlan(void 0);
140
89
  } : void 0, onMouseOver: selectable ? () => {
141
90
  setHoveredPlan(plan.value);