@ultraviolet/plus 0.15.1 → 0.15.2

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 (37) hide show
  1. package/dist/components/CodeEditor/CodeEditor.js +17 -24
  2. package/dist/components/ContentCard/Skeleton.js +28 -21
  3. package/dist/components/ContentCard/index.js +143 -149
  4. package/dist/components/ContentCardGroup/Card.js +84 -76
  5. package/dist/components/ContentCardGroup/SkeletonCard.js +19 -13
  6. package/dist/components/ContentCardGroup/index.js +17 -8
  7. package/dist/components/Conversation/index.js +100 -42
  8. package/dist/components/CustomerSatisfaction/index.js +58 -81
  9. package/dist/components/EstimateCost/Components/CustomUnitInput.js +19 -34
  10. package/dist/components/EstimateCost/Components/Item.js +182 -199
  11. package/dist/components/EstimateCost/Components/LineThrough.js +12 -9
  12. package/dist/components/EstimateCost/Components/NumberInput.js +8 -15
  13. package/dist/components/EstimateCost/Components/Region.js +16 -27
  14. package/dist/components/EstimateCost/Components/Regular.js +20 -28
  15. package/dist/components/EstimateCost/Components/Strong.js +15 -12
  16. package/dist/components/EstimateCost/Components/Unit.js +27 -33
  17. package/dist/components/EstimateCost/Components/UnitInput.js +39 -87
  18. package/dist/components/EstimateCost/Components/Zone.js +16 -26
  19. package/dist/components/EstimateCost/EstimateCost.js +24 -63
  20. package/dist/components/EstimateCost/EstimateCostContent.js +148 -208
  21. package/dist/components/EstimateCost/EstimateCostProvider.js +20 -23
  22. package/dist/components/EstimateCost/OverlayComponent.js +79 -73
  23. package/dist/components/EstimateCost/OverlayContext.js +3 -1
  24. package/dist/components/EstimateCost/componentStyle.js +206 -148
  25. package/dist/components/FAQ/index.js +9 -5
  26. package/dist/components/Navigation/Navigation.js +1 -10
  27. package/dist/components/Navigation/NavigationContent.js +96 -146
  28. package/dist/components/Navigation/NavigationProvider.js +57 -90
  29. package/dist/components/Navigation/components/Group.js +37 -41
  30. package/dist/components/Navigation/components/Item.js +284 -554
  31. package/dist/components/Navigation/components/PinnedItems.js +78 -119
  32. package/dist/components/Navigation/components/Separator.js +9 -4
  33. package/dist/components/SteppedListCard/Step.js +19 -38
  34. package/dist/components/SteppedListCard/SteppedListContainer.js +39 -48
  35. package/dist/components/SteppedListCard/SteppedListContent.js +46 -24
  36. package/dist/components/SteppedListCard/helper.js +1 -3
  37. package/package.json +5 -6
@@ -1,6 +1,6 @@
1
1
  import { jsxs, jsx, Fragment } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
2
3
  import { css } from "@emotion/react";
3
- import styled from "@emotion/styled";
4
4
  import { zoomIn, Badge, Text, Tooltip, Stack, Icon } from "@ultraviolet/ui";
5
5
  import { useMemo, useState, useEffect, useCallback, useId, Children, isValidElement, cloneElement } from "react";
6
6
  import { useEstimateCost } from "../EstimateCostProvider.js";
@@ -8,49 +8,103 @@ import { useOverlay } from "../OverlayContext.js";
8
8
  import { Cell, PriceCell, StyledDiv, OverlayRow, StyledTr, StyledLeftSide } from "../componentStyle.js";
9
9
  import { multiplier, maximumFractionDigitsLong, maximumFractionDigits, MAX_CELL_WIDTH } from "../constants.js";
10
10
  import { calculatePrice } from "../helper.js";
11
- const TIME_RELATED_UNIT = [
12
- "seconds",
13
- "minutes",
14
- "hours",
15
- "days",
16
- "months"
17
- ];
18
- const StyledResourceName = styled("div", {
19
- shouldForwardProp: (prop) => !["isOverlay", "animated"].includes(prop)
20
- })`
21
- text-align: ${({ isOverlay }) => isOverlay ? "initial" : "right"};
22
-
23
- ${({ isOverlay, animated }) => isOverlay ? css`
24
- height: 48px;
25
- display: flex;
26
- flex-direction: column;
27
- -webkit-box-pack: center;
28
- justify-content: center;
29
- animation: ${animated ? css`800ms ${zoomIn}` : ""};
30
- ` : null}
31
- `;
32
- const StyledBadge = styled(Badge)`
33
- margin-left: ${({ theme }) => theme.space["1"]};
34
- align-self: center;
35
- `;
36
- const StyledText = styled(Text)`
37
- margin-left: ${({ theme }) => theme.space["1"]};
38
- `;
39
- const MaxWidthText = styled(Text)`
40
- max-width: 75%;
41
- `;
42
- const TextAlignRight = styled(Text)`
43
- text-align: right;
44
- `;
45
- const StyledTooltip = styled(Tooltip)`
46
- vertical-align: text-top;
47
- `;
48
- const StyledPriceCell = styled(Cell)`
49
- ${({ theme }) => PriceCell(theme)}
50
- `;
51
- const StyleNoPriceItem = styled(Text)`
52
- text-align: right;
53
- `;
11
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
13
+ }
14
+ const TIME_RELATED_UNIT = ["seconds", "minutes", "hours", "days", "months"];
15
+ const StyledResourceName = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
16
+ shouldForwardProp: (prop) => !["isOverlay", "animated"].includes(prop),
17
+ target: "e1kzy2rr7"
18
+ } : {
19
+ shouldForwardProp: (prop) => !["isOverlay", "animated"].includes(prop),
20
+ target: "e1kzy2rr7",
21
+ label: "StyledResourceName"
22
+ })("text-align:", ({
23
+ isOverlay
24
+ }) => isOverlay ? "initial" : "right", ";", ({
25
+ isOverlay,
26
+ animated
27
+ }) => isOverlay ? /* @__PURE__ */ css("height:48px;display:flex;flex-direction:column;-webkit-box-pack:center;justify-content:center;animation:", animated ? /* @__PURE__ */ css("800ms ", zoomIn, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledResourceName;"), 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/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AA8DqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */") : "", ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledResourceName;"), 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/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAwDW","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */") : null, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAmDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */"));
28
+ const StyledBadge = /* @__PURE__ */ _styled(Badge, process.env.NODE_ENV === "production" ? {
29
+ target: "e1kzy2rr6"
30
+ } : {
31
+ target: "e1kzy2rr6",
32
+ label: "StyledBadge"
33
+ })("margin-left:", ({
34
+ theme
35
+ }) => theme.space["1"], ";align-self:center;" + (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/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAmEiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */"));
36
+ const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
37
+ target: "e1kzy2rr5"
38
+ } : {
39
+ target: "e1kzy2rr5",
40
+ label: "StyledText"
41
+ })("margin-left:", ({
42
+ theme
43
+ }) => theme.space["1"], ";" + (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/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAwE+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */"));
44
+ const MaxWidthText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
45
+ target: "e1kzy2rr4"
46
+ } : {
47
+ target: "e1kzy2rr4",
48
+ label: "MaxWidthText"
49
+ })(process.env.NODE_ENV === "production" ? {
50
+ name: "88bww",
51
+ styles: "max-width:75%"
52
+ } : {
53
+ name: "88bww",
54
+ styles: "max-width:75%",
55
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AA4EiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */",
56
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
57
+ });
58
+ const TextAlignRight = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
59
+ target: "e1kzy2rr3"
60
+ } : {
61
+ target: "e1kzy2rr3",
62
+ label: "TextAlignRight"
63
+ })(process.env.NODE_ENV === "production" ? {
64
+ name: "2qga7i",
65
+ styles: "text-align:right"
66
+ } : {
67
+ name: "2qga7i",
68
+ styles: "text-align:right",
69
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAgFmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */",
70
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
+ });
72
+ const StyledTooltip = /* @__PURE__ */ _styled(Tooltip, process.env.NODE_ENV === "production" ? {
73
+ target: "e1kzy2rr2"
74
+ } : {
75
+ target: "e1kzy2rr2",
76
+ label: "StyledTooltip"
77
+ })(process.env.NODE_ENV === "production" ? {
78
+ name: "uaxjgr",
79
+ styles: "vertical-align:text-top"
80
+ } : {
81
+ name: "uaxjgr",
82
+ styles: "vertical-align:text-top",
83
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAoFqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */",
84
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
+ });
86
+ const StyledPriceCell = /* @__PURE__ */ _styled(Cell, process.env.NODE_ENV === "production" ? {
87
+ target: "e1kzy2rr1"
88
+ } : {
89
+ target: "e1kzy2rr1",
90
+ label: "StyledPriceCell"
91
+ })(({
92
+ theme
93
+ }) => PriceCell(theme), ";" + (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/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AAwF0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */"));
94
+ const StyleNoPriceItem = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
95
+ target: "e1kzy2rr0"
96
+ } : {
97
+ target: "e1kzy2rr0",
98
+ label: "StyleNoPriceItem"
99
+ })(process.env.NODE_ENV === "production" ? {
100
+ name: "2qga7i",
101
+ styles: "text-align:right"
102
+ } : {
103
+ name: "2qga7i",
104
+ styles: "text-align:right",
105
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx"],"names":[],"mappings":"AA8NqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/EstimateCost/Components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Badge, Icon, Stack, Text, Tooltip, zoomIn } from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useMemo,\n  useState,\n} from 'react'\nimport { useEstimateCost } from '../EstimateCostProvider'\nimport { useOverlay } from '../OverlayContext'\nimport {\n  OverlayRow,\n  PriceCell,\n  Cell as StyledCell,\n  StyledDiv,\n  StyledLeftSide,\n  StyledTr,\n} from '../componentStyle'\nimport {\n  MAX_CELL_WIDTH,\n  maximumFractionDigits,\n  maximumFractionDigitsLong,\n  multiplier,\n} from '../constants'\nimport { calculatePrice } from '../helper'\nimport type {\n  BareEstimateProduct,\n  EstimateProduct,\n  Iteration,\n  Units,\n} from '../types'\n\nconst TIME_RELATED_UNIT: Units[] = [\n  'seconds',\n  'minutes',\n  'hours',\n  'days',\n  'months',\n]\n\nconst StyledResourceName = styled('div', {\n  shouldForwardProp: prop => !['isOverlay', 'animated'].includes(prop),\n})<{\n  isOverlay: boolean\n  animated: boolean\n}>`\n  text-align: ${({ isOverlay }) => (isOverlay ? 'initial' : 'right')};\n\n  ${({ isOverlay, animated }) =>\n    isOverlay\n      ? css`\n          height: 48px;\n          display: flex;\n          flex-direction: column;\n          -webkit-box-pack: center;\n          justify-content: center;\n          animation: ${animated ? css`800ms ${zoomIn}` : ''};\n        `\n      : null}\n`\n\nconst StyledBadge = styled(Badge)`\n  margin-left: ${({ theme }) => theme.space['1']};\n  align-self: center;\n`\n\nconst StyledText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst MaxWidthText = styled(Text)`\n  max-width: 75%;\n`\n\nconst TextAlignRight = styled(Text)`\n  text-align: right;\n`\n\nconst StyledTooltip = styled(Tooltip)`\n  vertical-align: text-top;\n`\n\nconst StyledPriceCell = styled(StyledCell)`\n  ${({ theme }) => PriceCell(theme)}\n`\n\ntype ExtraProps = {\n  itemCallback: (amount: number, isVariant: boolean) => void\n  amount: number\n  maxAmount: number\n  unit: string\n}\n\ntype ItemProps = {\n  amount?: number\n  /**\n   * Number of items that are free. It will be deducted to price of the item.\n   */\n  amountFree?: number\n  /**\n   * if true, zoomIn animation is triggered\n   */\n  animated?: boolean\n  children?: ReactNode\n  discount?: number\n  discountText?: string\n  /**\n   * Hide element from overlay\n   */\n  hideFromOverlay?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isDefined?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isFirstElement?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  isLastElement?: boolean\n  isPrimaryBackground?: boolean\n  /**\n   * Do not set this prop, it is transferred from parent\n   */\n  iteration?: Iteration\n  /**\n   * String that is displayed on left part of the item, it defines the item\n   */\n  label?: ReactNode\n  /**\n   * Changes label typography variant\n   */\n  labelTextVariant?: ComponentProps<typeof Text>['variant']\n  /**\n   * Changes label typography prominence\n   */\n  labelTextProminence?: ComponentProps<typeof Text>['prominence']\n  /**\n   * If your price has a lot of number after decimal point (ex: 0.0000076) - up 8 fraction digits\n   */\n  longFractionDigits?: boolean\n  /**\n   * Create a range price with [amount - maxAmount] values and prices\n   */\n  maxAmount?: number\n  /**\n   * Price per month\n   */\n  monthlyPrice?: number\n  /**\n   * Remove border bottom of the item\n   */\n  noBorder?: boolean\n  /**\n   * If the price of the item is not based on time enable this prop. ex: 5kg of chocolate is same price over 1 month or 1 hour.\n   */\n  noIteration?: boolean\n  noIterationText?: string\n  /**\n   * Remove the price on the right section of the table\n   */\n  noPrice?: boolean\n  /**\n   * Notice to display below the label\n   */\n  notice?: string\n  onAmountChange?: (amount: number) => void\n  /**\n   * Hourly price for one unit\n   */\n  price?: number\n  priceText?: ReactNode\n  productsCallback?: {\n    add: (product: EstimateProduct) => void\n    remove: (product: BareEstimateProduct) => void\n  }\n  /**\n   * Hide item from overlay if screen width is small\n   */\n  shouldBeHidden?: boolean\n  /**\n   * Display a complementary text on the right of the label\n   */\n  subLabel?: string\n  /**\n   * Increase left padding of the item like\n   */\n  tabulation?: number\n  /**\n   * Text to display in case of not defined value\n   */\n  textNotDefined?: string\n  /**\n   * Display near label, an icon with a tooltip that contains your text\n   */\n  tooltipInfo?: string\n  /**\n   * Unit of your item, examples: GB, MB, Node, Queries, etc.\n   */\n  unit?:\n    | 'mb'\n    | 'gb'\n    | 'tb'\n    | 'seconds'\n    | 'minutes'\n    | 'hours'\n    | 'days'\n    | 'months'\n    | 'years'\n    // Allow a string for unit but keep autocomplete for the above values\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    | (string & {})\n}\n\nconst StyleNoPriceItem = styled(Text)`\n  text-align: right;\n`\n\nexport const Item = ({\n  discount = 0,\n  priceText,\n  discountText,\n  label,\n  tooltipInfo, // Shows an icon with tooltip that contains this text\n  subLabel = '', // Usually used for showing amount that is free\n  price: basePrice = 0, // Hourly price for one unit\n  monthlyPrice = 0, // Price per month\n  unit: baseUnit, // Can be GB, MB, Node, Queries, etc.\n  amount: currentAmount = 1, // Current number of items\n  onAmountChange,\n  amountFree = 0, // Amount that is free - offered by company\n  maxAmount = 0, // Max amount - used for kubernetes for example\n  longFractionDigits = false, // In case price is really long 0.0000076 - up 7 fraction digits\n  noIteration = false, // if item is not based on time (ex: download, upload, transfer)\n  noIterationText,\n  noBorder, // remove the border bottom of the item\n  noPrice, // remove the price on right side of the table\n  isDefined = true,\n  children = null,\n  isFirstElement = false,\n  isLastElement = false,\n  isPrimaryBackground = false,\n  productsCallback,\n  iteration: receivedIteration, // Object from parent that contains time period (hours, days, months)\n  shouldBeHidden = false, // Hide element from overlay if screen width is small\n  hideFromOverlay = false, // Hide element from overlay in any case\n  textNotDefined, // Text to display in case of not defined value\n  animated = false, // if true, zoomIn animation is triggered\n  tabulation, // Increase left padding of the item\n  labelTextVariant, // To change left cell typography variant\n  labelTextProminence, // To change left cell typography prominence\n  notice, // To display a gray text below the label\n}: ItemProps) => {\n  const { locales, formatNumber } = useEstimateCost()\n\n  let iteration: Iteration | undefined\n\n  if (noIteration) {\n    iteration = {\n      ...(receivedIteration ?? { value: 0 }),\n      unit: 'hours',\n    }\n  } else {\n    iteration = receivedIteration\n  }\n\n  const price = useMemo(() => {\n    if (monthlyPrice > 0 && basePrice === 0) {\n      return monthlyPrice / multiplier.months\n    }\n\n    return basePrice\n  }, [basePrice, monthlyPrice])\n\n  const unit = useMemo(() => {\n    if (!baseUnit) {\n      return locales['estimate.cost.units.gb.label']\n    }\n\n    return baseUnit\n  }, [baseUnit, locales])\n\n  const { isOverlay } = useOverlay()\n  const Row = isOverlay ? OverlayRow : StyledTr\n  const Cell = isOverlay ? StyledCell.withComponent('div') : StyledCell\n  const LeftSide = isOverlay ? 'div' : StyledLeftSide\n\n  const [amount, setAmount] = useState(currentAmount)\n  const [isVariant, setIsVariant] = useState(false)\n\n  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount])\n  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount])\n\n  const itemCallback = useCallback(\n    (localAmount: number, localIsVariant: boolean) => {\n      setAmount(localAmount)\n      setIsVariant(localIsVariant)\n    },\n    [setAmount, setIsVariant],\n  )\n\n  const id = useId()\n\n  // We remove Item from object list when Iem component unmount to avoid duplicates\n  useEffect(\n    () => () => productsCallback?.remove({ id }),\n    [id, productsCallback],\n  )\n\n  useEffect(() => {\n    if (!isOverlay) {\n      productsCallback?.add({\n        id,\n        amount,\n        price,\n        amountFree,\n        isVariant,\n        maxAmount,\n        noIteration,\n        longFractionDigits,\n        discount,\n      })\n    }\n  }, [\n    price,\n    discount,\n    amount,\n    id,\n    productsCallback,\n    maxAmount,\n    noIteration,\n    isVariant,\n    amountFree,\n    isOverlay,\n    longFractionDigits,\n  ])\n\n  const computedItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, amount, amountFree, iteration, noIteration, discount],\n  )\n\n  const computedMaxItemPrice = useMemo(\n    () =>\n      calculatePrice({\n        price,\n        amount: maxAmount,\n        amountFree,\n        timeUnit: noIteration ? 'hours' : iteration?.unit ?? 'hours',\n        timeAmount: noIteration ? 1 : iteration?.value ?? 1,\n        discount,\n      }),\n    [price, maxAmount, amountFree, iteration, noIteration, discount],\n  )\n\n  const formatMaximumFractionDigits = useMemo(() => {\n    if (!iteration?.unit) {\n      return undefined\n    }\n\n    return longFractionDigits\n      ? maximumFractionDigitsLong[iteration?.unit]\n      : maximumFractionDigits[iteration?.unit]\n  }, [iteration?.unit, longFractionDigits])\n\n  return (\n    <Row\n      isFirstElement={isFirstElement}\n      shouldBeHidden={shouldBeHidden}\n      hideFromOverlay={hideFromOverlay}\n    >\n      <Cell\n        width={!isOverlay ? MAX_CELL_WIDTH : 'inherit'}\n        hasBorder={!isLastElement && !noBorder && !isOverlay}\n        tabulation={tabulation}\n      >\n        <LeftSide>\n          <Stack>\n            <Stack direction=\"row\">\n              <Text\n                as=\"p\"\n                variant={labelTextVariant ?? 'body'}\n                prominence={labelTextProminence ?? 'default'}\n              >\n                {label}\n              </Text>\n              {tooltipInfo ? (\n                <StyledDiv>\n                  <StyledTooltip text={tooltipInfo}>\n                    <Icon\n                      name=\"help-circle-outline\"\n                      size={20}\n                      variant=\"outlined\"\n                    />\n                  </StyledTooltip>\n                </StyledDiv>\n              ) : null}\n              {subLabel && !isOverlay ? (\n                <StyledText as=\"p\" variant=\"body\" color=\"primary\" italic>\n                  {subLabel}\n                </StyledText>\n              ) : null}\n              {discount > 0 && discountText ? (\n                <StyledBadge\n                  prominence=\"strong\"\n                  size=\"small\"\n                  sentiment=\"warning\"\n                >\n                  {discountText}\n                </StyledBadge>\n              ) : null}\n            </Stack>\n            {notice ? (\n              <MaxWidthText as=\"p\" variant=\"caption\" prominence=\"weak\">\n                {notice}\n              </MaxWidthText>\n            ) : null}\n          </Stack>\n          <StyledResourceName isOverlay={isOverlay} animated={animated}>\n            {isDefined\n              ? Children.map(children, child =>\n                  isValidElement<ExtraProps>(child)\n                    ? cloneElement(child, {\n                        itemCallback,\n                        amount,\n                        maxAmount,\n                        unit,\n                      })\n                    : null,\n                )\n              : textNotDefined || locales['estimate.cost.notDefined']}\n          </StyledResourceName>\n        </LeftSide>\n      </Cell>\n      {!isOverlay ? (\n        <StyledPriceCell\n          hasBorder={!isLastElement && !noBorder}\n          primary={isPrimaryBackground}\n        >\n          {!noPrice ? (\n            <>\n              <StyleNoPriceItem\n                as=\"p\"\n                variant={noIterationText ? 'headingSmall' : 'bodyStrong'}\n                prominence={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'weak'\n                    : 'default'\n                }\n                color={\n                  computedItemPrice === 0 && computedMaxItemPrice === 0\n                    ? 'neutral'\n                    : 'primary'\n                }\n              >\n                {priceText}\n                {!priceText\n                  ? formatNumber(computedItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })\n                  : null}\n                {noIterationText ? (\n                  <Text sentiment=\"primary\" as=\"span\" variant=\"bodySmall\">\n                    /{noIterationText}\n                  </Text>\n                ) : null}\n                {!priceText && computedMaxItemPrice > 0\n                  ? ` - ${formatNumber(computedMaxItemPrice, {\n                      maximumFractionDigits: formatMaximumFractionDigits,\n                    })}`\n                  : null}\n              </StyleNoPriceItem>\n              {(amount - amountFree !== 1 && computedItemPrice > 0) ||\n              (maxAmount > 0 && computedMaxItemPrice > 0) ? (\n                <TextAlignRight as=\"p\" variant=\"body\">\n                  {formatNumber(\n                    calculatePrice({\n                      price,\n                      amount: 1,\n                      timeUnit: 'hours',\n                      timeAmount: 1,\n                      discount,\n                    }),\n                    {\n                      maximumFractionDigits: longFractionDigits\n                        ? maximumFractionDigitsLong.hours\n                        : maximumFractionDigits.hours,\n                    },\n                  )}\n                  {TIME_RELATED_UNIT.includes(unit as Units)\n                    ? locales[\n                        `estimate.cost.units.${unit as Units}.label`\n                      ].toLowerCase()\n                    : `/${unit}`}\n                  {!noIteration\n                    ? `/${locales[\n                        'estimate.cost.units.hours.label'\n                      ].toLowerCase()}`\n                    : null}\n                </TextAlignRight>\n              ) : null}\n            </>\n          ) : null}\n        </StyledPriceCell>\n      ) : null}\n    </Row>\n  )\n}\n"]} */",
106
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
107
+ });
54
108
  const Item = ({
55
109
  discount = 0,
56
110
  priceText,
@@ -107,11 +161,16 @@ const Item = ({
107
161
  notice
108
162
  // To display a gray text below the label
109
163
  }) => {
110
- const { locales, formatNumber } = useEstimateCost();
164
+ const {
165
+ locales,
166
+ formatNumber
167
+ } = useEstimateCost();
111
168
  let iteration;
112
169
  if (noIteration) {
113
170
  iteration = {
114
- ...receivedIteration ?? { value: 0 },
171
+ ...receivedIteration ?? {
172
+ value: 0
173
+ },
115
174
  unit: "hours"
116
175
  };
117
176
  } else {
@@ -129,26 +188,29 @@ const Item = ({
129
188
  }
130
189
  return baseUnit;
131
190
  }, [baseUnit, locales]);
132
- const { isOverlay } = useOverlay();
191
+ const {
192
+ isOverlay
193
+ } = useOverlay();
133
194
  const Row = isOverlay ? OverlayRow : StyledTr;
134
- const Cell$1 = isOverlay ? Cell.withComponent("div") : Cell;
195
+ const Cell$1 = isOverlay ? Cell.withComponent("div", process.env.NODE_ENV === "production" ? {
196
+ target: "e1kzy2rr8"
197
+ } : {
198
+ target: "e1kzy2rr8",
199
+ label: "Cell"
200
+ }) : Cell;
135
201
  const LeftSide = isOverlay ? "div" : StyledLeftSide;
136
202
  const [amount, setAmount] = useState(currentAmount);
137
203
  const [isVariant, setIsVariant] = useState(false);
138
204
  useEffect(() => setAmount(currentAmount), [setAmount, currentAmount]);
139
205
  useEffect(() => onAmountChange?.(amount), [onAmountChange, amount]);
140
- const itemCallback = useCallback(
141
- (localAmount, localIsVariant) => {
142
- setAmount(localAmount);
143
- setIsVariant(localIsVariant);
144
- },
145
- [setAmount, setIsVariant]
146
- );
206
+ const itemCallback = useCallback((localAmount, localIsVariant) => {
207
+ setAmount(localAmount);
208
+ setIsVariant(localIsVariant);
209
+ }, [setAmount, setIsVariant]);
147
210
  const id = useId();
148
- useEffect(
149
- () => () => productsCallback?.remove({ id }),
150
- [id, productsCallback]
151
- );
211
+ useEffect(() => () => productsCallback?.remove({
212
+ id
213
+ }), [id, productsCallback]);
152
214
  useEffect(() => {
153
215
  if (!isOverlay) {
154
216
  productsCallback?.add({
@@ -163,155 +225,76 @@ const Item = ({
163
225
  discount
164
226
  });
165
227
  }
166
- }, [
228
+ }, [price, discount, amount, id, productsCallback, maxAmount, noIteration, isVariant, amountFree, isOverlay, longFractionDigits]);
229
+ const computedItemPrice = useMemo(() => calculatePrice({
167
230
  price,
168
- discount,
169
231
  amount,
170
- id,
171
- productsCallback,
172
- maxAmount,
173
- noIteration,
174
- isVariant,
175
232
  amountFree,
176
- isOverlay,
177
- longFractionDigits
178
- ]);
179
- const computedItemPrice = useMemo(
180
- () => calculatePrice({
181
- price,
182
- amount,
183
- amountFree,
184
- timeUnit: noIteration ? "hours" : iteration?.unit ?? "hours",
185
- timeAmount: noIteration ? 1 : iteration?.value ?? 1,
186
- discount
187
- }),
188
- [price, amount, amountFree, iteration, noIteration, discount]
189
- );
190
- const computedMaxItemPrice = useMemo(
191
- () => calculatePrice({
192
- price,
193
- amount: maxAmount,
194
- amountFree,
195
- timeUnit: noIteration ? "hours" : iteration?.unit ?? "hours",
196
- timeAmount: noIteration ? 1 : iteration?.value ?? 1,
197
- discount
198
- }),
199
- [price, maxAmount, amountFree, iteration, noIteration, discount]
200
- );
233
+ timeUnit: noIteration ? "hours" : iteration?.unit ?? "hours",
234
+ timeAmount: noIteration ? 1 : iteration?.value ?? 1,
235
+ discount
236
+ }), [price, amount, amountFree, iteration, noIteration, discount]);
237
+ const computedMaxItemPrice = useMemo(() => calculatePrice({
238
+ price,
239
+ amount: maxAmount,
240
+ amountFree,
241
+ timeUnit: noIteration ? "hours" : iteration?.unit ?? "hours",
242
+ timeAmount: noIteration ? 1 : iteration?.value ?? 1,
243
+ discount
244
+ }), [price, maxAmount, amountFree, iteration, noIteration, discount]);
201
245
  const formatMaximumFractionDigits = useMemo(() => {
202
246
  if (!iteration?.unit) {
203
247
  return void 0;
204
248
  }
205
249
  return longFractionDigits ? maximumFractionDigitsLong[iteration?.unit] : maximumFractionDigits[iteration?.unit];
206
250
  }, [iteration?.unit, longFractionDigits]);
207
- return /* @__PURE__ */ jsxs(
208
- Row,
209
- {
210
- isFirstElement,
211
- shouldBeHidden,
212
- hideFromOverlay,
213
- children: [
214
- /* @__PURE__ */ jsx(
215
- Cell$1,
216
- {
217
- width: !isOverlay ? MAX_CELL_WIDTH : "inherit",
218
- hasBorder: !isLastElement && !noBorder && !isOverlay,
219
- tabulation,
220
- children: /* @__PURE__ */ jsxs(LeftSide, { children: [
221
- /* @__PURE__ */ jsxs(Stack, { children: [
222
- /* @__PURE__ */ jsxs(Stack, { direction: "row", children: [
223
- /* @__PURE__ */ jsx(
224
- Text,
225
- {
226
- as: "p",
227
- variant: labelTextVariant ?? "body",
228
- prominence: labelTextProminence ?? "default",
229
- children: label
230
- }
231
- ),
232
- tooltipInfo ? /* @__PURE__ */ jsx(StyledDiv, { children: /* @__PURE__ */ jsx(StyledTooltip, { text: tooltipInfo, children: /* @__PURE__ */ jsx(
233
- Icon,
234
- {
235
- name: "help-circle-outline",
236
- size: 20,
237
- variant: "outlined"
238
- }
239
- ) }) }) : null,
240
- subLabel && !isOverlay ? /* @__PURE__ */ jsx(StyledText, { as: "p", variant: "body", color: "primary", italic: true, children: subLabel }) : null,
241
- discount > 0 && discountText ? /* @__PURE__ */ jsx(
242
- StyledBadge,
243
- {
244
- prominence: "strong",
245
- size: "small",
246
- sentiment: "warning",
247
- children: discountText
248
- }
249
- ) : null
250
- ] }),
251
- notice ? /* @__PURE__ */ jsx(MaxWidthText, { as: "p", variant: "caption", prominence: "weak", children: notice }) : null
252
- ] }),
253
- /* @__PURE__ */ jsx(StyledResourceName, { isOverlay, animated, children: isDefined ? Children.map(
254
- children,
255
- (child) => isValidElement(child) ? cloneElement(child, {
256
- itemCallback,
257
- amount,
258
- maxAmount,
259
- unit
260
- }) : null
261
- ) : textNotDefined || locales["estimate.cost.notDefined"] })
262
- ] })
263
- }
264
- ),
265
- !isOverlay ? /* @__PURE__ */ jsx(
266
- StyledPriceCell,
267
- {
268
- hasBorder: !isLastElement && !noBorder,
269
- primary: isPrimaryBackground,
270
- children: !noPrice ? /* @__PURE__ */ jsxs(Fragment, { children: [
271
- /* @__PURE__ */ jsxs(
272
- StyleNoPriceItem,
273
- {
274
- as: "p",
275
- variant: noIterationText ? "headingSmall" : "bodyStrong",
276
- prominence: computedItemPrice === 0 && computedMaxItemPrice === 0 ? "weak" : "default",
277
- color: computedItemPrice === 0 && computedMaxItemPrice === 0 ? "neutral" : "primary",
278
- children: [
279
- priceText,
280
- !priceText ? formatNumber(computedItemPrice, {
281
- maximumFractionDigits: formatMaximumFractionDigits
282
- }) : null,
283
- noIterationText ? /* @__PURE__ */ jsxs(Text, { sentiment: "primary", as: "span", variant: "bodySmall", children: [
284
- "/",
285
- noIterationText
286
- ] }) : null,
287
- !priceText && computedMaxItemPrice > 0 ? ` - ${formatNumber(computedMaxItemPrice, {
288
- maximumFractionDigits: formatMaximumFractionDigits
289
- })}` : null
290
- ]
291
- }
292
- ),
293
- amount - amountFree !== 1 && computedItemPrice > 0 || maxAmount > 0 && computedMaxItemPrice > 0 ? /* @__PURE__ */ jsxs(TextAlignRight, { as: "p", variant: "body", children: [
294
- formatNumber(
295
- calculatePrice({
296
- price,
297
- amount: 1,
298
- timeUnit: "hours",
299
- timeAmount: 1,
300
- discount
301
- }),
302
- {
303
- maximumFractionDigits: longFractionDigits ? maximumFractionDigitsLong.hours : maximumFractionDigits.hours
304
- }
305
- ),
306
- TIME_RELATED_UNIT.includes(unit) ? locales[`estimate.cost.units.${unit}.label`].toLowerCase() : `/${unit}`,
307
- !noIteration ? `/${locales["estimate.cost.units.hours.label"].toLowerCase()}` : null
308
- ] }) : null
309
- ] }) : null
310
- }
311
- ) : null
312
- ]
313
- }
314
- );
251
+ return /* @__PURE__ */ jsxs(Row, { isFirstElement, shouldBeHidden, hideFromOverlay, children: [
252
+ /* @__PURE__ */ jsx(Cell$1, { width: !isOverlay ? MAX_CELL_WIDTH : "inherit", hasBorder: !isLastElement && !noBorder && !isOverlay, tabulation, children: /* @__PURE__ */ jsxs(LeftSide, { children: [
253
+ /* @__PURE__ */ jsxs(Stack, { children: [
254
+ /* @__PURE__ */ jsxs(Stack, { direction: "row", children: [
255
+ /* @__PURE__ */ jsx(Text, { as: "p", variant: labelTextVariant ?? "body", prominence: labelTextProminence ?? "default", children: label }),
256
+ tooltipInfo ? /* @__PURE__ */ jsx(StyledDiv, { children: /* @__PURE__ */ jsx(StyledTooltip, { text: tooltipInfo, children: /* @__PURE__ */ jsx(Icon, { name: "help-circle-outline", size: 20, variant: "outlined" }) }) }) : null,
257
+ subLabel && !isOverlay ? /* @__PURE__ */ jsx(StyledText, { as: "p", variant: "body", color: "primary", italic: true, children: subLabel }) : null,
258
+ discount > 0 && discountText ? /* @__PURE__ */ jsx(StyledBadge, { prominence: "strong", size: "small", sentiment: "warning", children: discountText }) : null
259
+ ] }),
260
+ notice ? /* @__PURE__ */ jsx(MaxWidthText, { as: "p", variant: "caption", prominence: "weak", children: notice }) : null
261
+ ] }),
262
+ /* @__PURE__ */ jsx(StyledResourceName, { isOverlay, animated, children: isDefined ? Children.map(children, (child) => isValidElement(child) ? cloneElement(child, {
263
+ itemCallback,
264
+ amount,
265
+ maxAmount,
266
+ unit
267
+ }) : null) : textNotDefined || locales["estimate.cost.notDefined"] })
268
+ ] }) }),
269
+ !isOverlay ? /* @__PURE__ */ jsx(StyledPriceCell, { hasBorder: !isLastElement && !noBorder, primary: isPrimaryBackground, children: !noPrice ? /* @__PURE__ */ jsxs(Fragment, { children: [
270
+ /* @__PURE__ */ jsxs(StyleNoPriceItem, { as: "p", variant: noIterationText ? "headingSmall" : "bodyStrong", prominence: computedItemPrice === 0 && computedMaxItemPrice === 0 ? "weak" : "default", color: computedItemPrice === 0 && computedMaxItemPrice === 0 ? "neutral" : "primary", children: [
271
+ priceText,
272
+ !priceText ? formatNumber(computedItemPrice, {
273
+ maximumFractionDigits: formatMaximumFractionDigits
274
+ }) : null,
275
+ noIterationText ? /* @__PURE__ */ jsxs(Text, { sentiment: "primary", as: "span", variant: "bodySmall", children: [
276
+ "/",
277
+ noIterationText
278
+ ] }) : null,
279
+ !priceText && computedMaxItemPrice > 0 ? ` - ${formatNumber(computedMaxItemPrice, {
280
+ maximumFractionDigits: formatMaximumFractionDigits
281
+ })}` : null
282
+ ] }),
283
+ amount - amountFree !== 1 && computedItemPrice > 0 || maxAmount > 0 && computedMaxItemPrice > 0 ? /* @__PURE__ */ jsxs(TextAlignRight, { as: "p", variant: "body", children: [
284
+ formatNumber(calculatePrice({
285
+ price,
286
+ amount: 1,
287
+ timeUnit: "hours",
288
+ timeAmount: 1,
289
+ discount
290
+ }), {
291
+ maximumFractionDigits: longFractionDigits ? maximumFractionDigitsLong.hours : maximumFractionDigits.hours
292
+ }),
293
+ TIME_RELATED_UNIT.includes(unit) ? locales[`estimate.cost.units.${unit}.label`].toLowerCase() : `/${unit}`,
294
+ !noIteration ? `/${locales["estimate.cost.units.hours.label"].toLowerCase()}` : null
295
+ ] }) : null
296
+ ] }) : null }) : null
297
+ ] });
315
298
  };
316
299
  export {
317
300
  Item