@amboss/design-system 3.34.2 → 3.35.0

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 (45) hide show
  1. package/build/cjs/components/Content/ContentBox/ContentBox.d.ts +11 -0
  2. package/build/cjs/components/Content/ContentBox/ContentBox.js +1 -0
  3. package/build/cjs/components/Content/ContentBox/constants.d.ts +6 -0
  4. package/build/cjs/components/Content/ContentBox/constants.js +1 -0
  5. package/build/cjs/components/Content/ContentBox/types.d.ts +2 -0
  6. package/build/cjs/components/Content/ContentBox/types.js +1 -0
  7. package/build/cjs/components/Form/Combobox/-types.d.ts +5 -0
  8. package/build/cjs/components/Form/Combobox/-types.js +1 -0
  9. package/build/cjs/components/Form/Combobox/Combobox.d.ts +16 -2
  10. package/build/cjs/components/Form/Combobox/Combobox.js +1 -1
  11. package/build/cjs/components/Form/Combobox/MultiSelect.d.ts +7 -2
  12. package/build/cjs/components/Form/Combobox/MultiSelect.js +1 -1
  13. package/build/cjs/components/MediaItem/MediaItem.js +1 -1
  14. package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +1 -1
  15. package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
  16. package/build/cjs/components/Toggletip/BasePopover.js +1 -1
  17. package/build/cjs/components/Tooltip/TooltipContent.d.ts +1 -1
  18. package/build/cjs/components/Tooltip/TooltipContent.js +1 -1
  19. package/build/cjs/components/Typography/TextClamped/TextClamped.js +1 -1
  20. package/build/cjs/index.d.ts +1 -0
  21. package/build/cjs/index.js +1 -1
  22. package/build/cjs/web-tokens/assets/icons16.json +2 -2
  23. package/build/esm/components/Content/ContentBox/ContentBox.d.ts +11 -0
  24. package/build/esm/components/Content/ContentBox/ContentBox.js +1 -0
  25. package/build/esm/components/Content/ContentBox/constants.d.ts +6 -0
  26. package/build/esm/components/Content/ContentBox/constants.js +1 -0
  27. package/build/esm/components/Content/ContentBox/types.d.ts +2 -0
  28. package/build/esm/components/Content/ContentBox/types.js +1 -0
  29. package/build/esm/components/Form/Combobox/-types.d.ts +5 -0
  30. package/build/esm/components/Form/Combobox/-types.js +1 -0
  31. package/build/esm/components/Form/Combobox/Combobox.d.ts +16 -2
  32. package/build/esm/components/Form/Combobox/Combobox.js +1 -1
  33. package/build/esm/components/Form/Combobox/MultiSelect.d.ts +7 -2
  34. package/build/esm/components/Form/Combobox/MultiSelect.js +1 -1
  35. package/build/esm/components/MediaItem/MediaItem.js +1 -1
  36. package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +1 -1
  37. package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
  38. package/build/esm/components/Toggletip/BasePopover.js +1 -1
  39. package/build/esm/components/Tooltip/TooltipContent.d.ts +1 -1
  40. package/build/esm/components/Tooltip/TooltipContent.js +1 -1
  41. package/build/esm/components/Typography/TextClamped/TextClamped.js +1 -1
  42. package/build/esm/index.d.ts +1 -0
  43. package/build/esm/index.js +1 -1
  44. package/build/esm/web-tokens/assets/icons16.json +2 -2
  45. package/package.json +1 -1
@@ -1 +1 @@
1
- import React from"react";import styled from"@emotion/styled";import{getBackgroundColor}from"./-utils/getBackgroundColor";import{sanitizeInputValues}from"./-utils/sanitizeInputValues";import{getPercentagesForVariants}from"./-utils/getPercentagesForVariants";import{getTotalFilledValue}from"./-utils/getTotalFilledValue";import{LegendPopover}from"./LegendPopover";let StyledProgressBarContainer=styled("div",{target:"e1hklaqt0",label:"StyledProgressBarContainer"})(({theme,squareCorners,weight})=>({width:"100%",lineHeight:0,backgroundColor:theme.values.color.background.placeholder.default,...!squareCorners&&{borderRadius:theme.variables.size.borderRadius.xs},height:"thin"===weight?theme.variables.size.spacing.xxs:theme.variables.size.spacing.xs,position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgLz5cbiAgICAgICAge3NlZ21lbnRzfVxuICAgICAgPC9TdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lcj5cbiAgICAgIHtoYXNUb29sdGlwICYmIChcbiAgICAgICAgPExlZ2VuZFBvcG92ZXJcbiAgICAgICAgICBwZXJjZW50YWdlcz17cGVyY2VudGFnZXN9XG4gICAgICAgICAgZ2V0VG9vbHRpcFRleHQ9e2dldFRvb2x0aXBUZXh0fVxuICAgICAgICAgIHRvb2x0aXBQcm9wcz17dG9vbHRpcFByb3BzfVxuICAgICAgICAgIG1vbm9jaHJvbWU9e21vbm9jaHJvbWV9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCbUMifQ== */"),StyledSegment=styled("div",{target:"e1hklaqt1",label:"StyledSegment"})(({theme,styleVariant,percentage,monochrome,filledPercentage})=>({height:"100%",backgroundColor:getBackgroundColor(theme,styleVariant,monochrome),width:`${percentage/filledPercentage*100}%`,minWidth:4,"&:first-of-type":{borderTopLeftRadius:"inherit",borderBottomLeftRadius:"inherit"},"&:last-of-type":{borderTopRightRadius:"inherit",borderBottomRightRadius:"inherit"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgLz5cbiAgICAgICAge3NlZ21lbnRzfVxuICAgICAgPC9TdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lcj5cbiAgICAgIHtoYXNUb29sdGlwICYmIChcbiAgICAgICAgPExlZ2VuZFBvcG92ZXJcbiAgICAgICAgICBwZXJjZW50YWdlcz17cGVyY2VudGFnZXN9XG4gICAgICAgICAgZ2V0VG9vbHRpcFRleHQ9e2dldFRvb2x0aXBUZXh0fVxuICAgICAgICAgIHRvb2x0aXBQcm9wcz17dG9vbHRpcFByb3BzfVxuICAgICAgICAgIG1vbm9jaHJvbWU9e21vbm9jaHJvbWV9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdDc0IifQ== */"),StyledSegmentContainer=styled("div",{target:"e1hklaqt2",label:"StyledSegmentContainer"})(({theme,filledPercentage})=>({width:`${filledPercentage}%`,minWidth:"fit-content",display:"flex",flexDirection:"row",gap:theme.variables.size.spacing.xxxs,backgroundColor:theme.values.color.background.primary.default,borderRadius:"inherit",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgLz5cbiAgICAgICAge3NlZ21lbnRzfVxuICAgICAgPC9TdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lcj5cbiAgICAgIHtoYXNUb29sdGlwICYmIChcbiAgICAgICAgPExlZ2VuZFBvcG92ZXJcbiAgICAgICAgICBwZXJjZW50YWdlcz17cGVyY2VudGFnZXN9XG4gICAgICAgICAgZ2V0VG9vbHRpcFRleHQ9e2dldFRvb2x0aXBUZXh0fVxuICAgICAgICAgIHRvb2x0aXBQcm9wcz17dG9vbHRpcFByb3BzfVxuICAgICAgICAgIG1vbm9jaHJvbWU9e21vbm9jaHJvbWV9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNEK0IifQ== */"),StyledProgressElement=styled("progress",{target:"e1hklaqt3",label:"StyledProgressElement"})(({theme})=>({appearance:"none",height:1,width:1,margin:-1,overflow:"hidden",padding:0,opacity:theme.variables.opacity.hidden,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgLz5cbiAgICAgICAge3NlZ21lbnRzfVxuICAgICAgPC9TdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lcj5cbiAgICAgIHtoYXNUb29sdGlwICYmIChcbiAgICAgICAgPExlZ2VuZFBvcG92ZXJcbiAgICAgICAgICBwZXJjZW50YWdlcz17cGVyY2VudGFnZXN9XG4gICAgICAgICAgZ2V0VG9vbHRpcFRleHQ9e2dldFRvb2x0aXBUZXh0fVxuICAgICAgICAgIHRvb2x0aXBQcm9wcz17dG9vbHRpcFByb3BzfVxuICAgICAgICAgIG1vbm9jaHJvbWU9e21vbm9jaHJvbWV9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1FOEIifQ== */"),StyledContainer=styled("div",{target:"e1hklaqt4",label:"StyledContainer"})(({theme})=>({width:"100%",display:"flex",gap:theme.variables.size.spacing.xs,alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgLz5cbiAgICAgICAge3NlZ21lbnRzfVxuICAgICAgPC9TdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lcj5cbiAgICAgIHtoYXNUb29sdGlwICYmIChcbiAgICAgICAgPExlZ2VuZFBvcG92ZXJcbiAgICAgICAgICBwZXJjZW50YWdlcz17cGVyY2VudGFnZXN9XG4gICAgICAgICAgZ2V0VG9vbHRpcFRleHQ9e2dldFRvb2x0aXBUZXh0fVxuICAgICAgICAgIHRvb2x0aXBQcm9wcz17dG9vbHRpcFByb3BzfVxuICAgICAgICAgIG1vbm9jaHJvbWU9e21vbm9jaHJvbWV9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThFd0IifQ== */");export function SegmentedProgressBar({maxValue,values,weight="fat",squareCorners=!1,getTooltipText,tooltipProps={triggerAriaLabel:"More information"},privateProps:{monochrome}={monochrome:!1},"data-e2e-test-id":dataE2eTestId}){let{sanitizedMaxValue,sanitizedValues}=sanitizeInputValues(maxValue,values),percentages=getPercentagesForVariants(sanitizedMaxValue,sanitizedValues),totalFilledValue=getTotalFilledValue(sanitizedValues),filledSegmentPercentages=percentages.filter(({variant})=>"empty"!==variant),filledPercentage=filledSegmentPercentages.reduce((currentValue,item)=>currentValue+item.percentage,0),segments=filledPercentage?React.createElement(StyledSegmentContainer,{filledPercentage:filledPercentage,"data-e2e-test-id":"segmentContainer"},filledSegmentPercentages.map(({percentage,variant})=>React.createElement(StyledSegment,{key:variant,"data-e2e-test-id":variant,styleVariant:variant,monochrome:monochrome,percentage:percentage,filledPercentage:filledPercentage}))):null;return React.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"SegmentedProgressBar"},React.createElement(StyledProgressBarContainer,{squareCorners:squareCorners,weight:weight,"data-e2e-test-id":"progressBarContainer"},React.createElement(StyledProgressElement,{max:sanitizedMaxValue,value:totalFilledValue}),segments),!!getTooltipText&&React.createElement(LegendPopover,{percentages:percentages,getTooltipText:getTooltipText,tooltipProps:tooltipProps,monochrome:monochrome}))}
1
+ import React from"react";import styled from"@emotion/styled";import{getBackgroundColor}from"./-utils/getBackgroundColor";import{sanitizeInputValues}from"./-utils/sanitizeInputValues";import{getPercentagesForVariants}from"./-utils/getPercentagesForVariants";import{getTotalFilledValue}from"./-utils/getTotalFilledValue";import{LegendPopover}from"./LegendPopover";let StyledProgressBarContainer=styled("div",{target:"eicbbq50",label:"StyledProgressBarContainer"})(({theme,squareCorners,weight})=>({width:"100%",lineHeight:0,backgroundColor:theme.values.color.background.placeholder.default,...!squareCorners&&{borderRadius:theme.variables.size.borderRadius.xs},height:"thin"===weight?theme.variables.size.spacing.xxs:theme.variables.size.spacing.xs,position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIC8+XG4gICAgICAgIHtzZWdtZW50c31cbiAgICAgIDwvU3R5bGVkUHJvZ3Jlc3NCYXJDb250YWluZXI+XG4gICAgICB7aGFzVG9vbHRpcCAmJiAoXG4gICAgICAgIDxMZWdlbmRQb3BvdmVyXG4gICAgICAgICAgcGVyY2VudGFnZXM9e3BlcmNlbnRhZ2VzfVxuICAgICAgICAgIGdldFRvb2x0aXBUZXh0PXtnZXRUb29sdGlwVGV4dH1cbiAgICAgICAgICB0b29sdGlwUHJvcHM9e3Rvb2x0aXBQcm9wc31cbiAgICAgICAgICBtb25vY2hyb21lPXttb25vY2hyb21lfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQm1DIn0= */"),StyledSegment=styled("div",{target:"eicbbq51",label:"StyledSegment"})(({theme,styleVariant,percentage,monochrome,filledPercentage})=>({height:"100%",backgroundColor:getBackgroundColor(theme,styleVariant,monochrome),width:`${percentage/filledPercentage*100}%`,minWidth:4,"&:first-of-type":{borderTopLeftRadius:"inherit",borderBottomLeftRadius:"inherit"},"&:last-of-type":{borderTopRightRadius:"inherit",borderBottomRightRadius:"inherit"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIC8+XG4gICAgICAgIHtzZWdtZW50c31cbiAgICAgIDwvU3R5bGVkUHJvZ3Jlc3NCYXJDb250YWluZXI+XG4gICAgICB7aGFzVG9vbHRpcCAmJiAoXG4gICAgICAgIDxMZWdlbmRQb3BvdmVyXG4gICAgICAgICAgcGVyY2VudGFnZXM9e3BlcmNlbnRhZ2VzfVxuICAgICAgICAgIGdldFRvb2x0aXBUZXh0PXtnZXRUb29sdGlwVGV4dH1cbiAgICAgICAgICB0b29sdGlwUHJvcHM9e3Rvb2x0aXBQcm9wc31cbiAgICAgICAgICBtb25vY2hyb21lPXttb25vY2hyb21lfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ3NCIn0= */"),StyledSegmentContainer=styled("div",{target:"eicbbq52",label:"StyledSegmentContainer"})(({theme,filledPercentage})=>({width:`${filledPercentage}%`,minWidth:"fit-content",display:"flex",flexDirection:"row",gap:theme.variables.size.spacing.xxxs,backgroundColor:theme.values.color.background.primary.default,borderRadius:"inherit",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIC8+XG4gICAgICAgIHtzZWdtZW50c31cbiAgICAgIDwvU3R5bGVkUHJvZ3Jlc3NCYXJDb250YWluZXI+XG4gICAgICB7aGFzVG9vbHRpcCAmJiAoXG4gICAgICAgIDxMZWdlbmRQb3BvdmVyXG4gICAgICAgICAgcGVyY2VudGFnZXM9e3BlcmNlbnRhZ2VzfVxuICAgICAgICAgIGdldFRvb2x0aXBUZXh0PXtnZXRUb29sdGlwVGV4dH1cbiAgICAgICAgICB0b29sdGlwUHJvcHM9e3Rvb2x0aXBQcm9wc31cbiAgICAgICAgICBtb25vY2hyb21lPXttb25vY2hyb21lfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRCtCIn0= */"),StyledProgressElement=styled("progress",{target:"eicbbq53",label:"StyledProgressElement"})(({theme})=>({appearance:"none",height:1,width:1,margin:-1,overflow:"hidden",padding:0,opacity:theme.variables.opacity.hidden,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIC8+XG4gICAgICAgIHtzZWdtZW50c31cbiAgICAgIDwvU3R5bGVkUHJvZ3Jlc3NCYXJDb250YWluZXI+XG4gICAgICB7aGFzVG9vbHRpcCAmJiAoXG4gICAgICAgIDxMZWdlbmRQb3BvdmVyXG4gICAgICAgICAgcGVyY2VudGFnZXM9e3BlcmNlbnRhZ2VzfVxuICAgICAgICAgIGdldFRvb2x0aXBUZXh0PXtnZXRUb29sdGlwVGV4dH1cbiAgICAgICAgICB0b29sdGlwUHJvcHM9e3Rvb2x0aXBQcm9wc31cbiAgICAgICAgICBtb25vY2hyb21lPXttb25vY2hyb21lfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRThCIn0= */"),StyledContainer=styled("div",{target:"eicbbq54",label:"StyledContainer"})(({theme})=>({width:"100%",display:"flex",gap:theme.variables.size.spacing.xs,alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU2VnbWVudGVkUHJvZ3Jlc3NCYXIvU2VnbWVudGVkUHJvZ3Jlc3NCYXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TZWdtZW50ZWRQcm9ncmVzc0Jhci9TZWdtZW50ZWRQcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7XG4gIFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMsXG4gIFNlZ21lbnRQcm9wcyxcbiAgU3R5bGVWYXJpYW50LFxuICBWYWx1ZXNWYXJpYW50LFxufSBmcm9tIFwiLi8tdHlwZXNcIjtcbmltcG9ydCB7IGdldEJhY2tncm91bmRDb2xvciB9IGZyb20gXCIuLy11dGlscy9nZXRCYWNrZ3JvdW5kQ29sb3JcIjtcbmltcG9ydCB7IHNhbml0aXplSW5wdXRWYWx1ZXMgfSBmcm9tIFwiLi8tdXRpbHMvc2FuaXRpemVJbnB1dFZhbHVlc1wiO1xuaW1wb3J0IHsgZ2V0UGVyY2VudGFnZXNGb3JWYXJpYW50cyB9IGZyb20gXCIuLy11dGlscy9nZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzXCI7XG5pbXBvcnQgeyBnZXRUb3RhbEZpbGxlZFZhbHVlIH0gZnJvbSBcIi4vLXV0aWxzL2dldFRvdGFsRmlsbGVkVmFsdWVcIjtcbmltcG9ydCB7IExlZ2VuZFBvcG92ZXIgfSBmcm9tIFwiLi9MZWdlbmRQb3BvdmVyXCI7XG5cbmV4cG9ydCB0eXBlIHsgU2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcyB9O1xuXG5jb25zdCBTdHlsZWRQcm9ncmVzc0JhckNvbnRhaW5lciA9IHN0eWxlZC5kaXY8XG4gIFBhcnRpYWw8U2VnbWVudGVkUHJvZ3Jlc3NCYXJQcm9wcz5cbj4oKHsgdGhlbWUsIHNxdWFyZUNvcm5lcnMsIHdlaWdodCB9KSA9PiAoe1xuICB3aWR0aDogXCIxMDAlXCIsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucGxhY2Vob2xkZXIuZGVmYXVsdCxcbiAgLi4uKCFzcXVhcmVDb3JuZXJzICYmIHtcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgfSksXG4gIGhlaWdodDpcbiAgICB3ZWlnaHQgPT09IFwidGhpblwiXG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZFNlZ21lbnQgPSBzdHlsZWQuZGl2PFBhcnRpYWw8U2VnbWVudFByb3BzPj4oXG4gICh7IHRoZW1lLCBzdHlsZVZhcmlhbnQsIHBlcmNlbnRhZ2UsIG1vbm9jaHJvbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICAgIGJhY2tncm91bmRDb2xvcjogZ2V0QmFja2dyb3VuZENvbG9yKHRoZW1lLCBzdHlsZVZhcmlhbnQsIG1vbm9jaHJvbWUpLFxuICAgIHdpZHRoOiBgJHsocGVyY2VudGFnZSAvIGZpbGxlZFBlcmNlbnRhZ2UpICogMTAwfSVgLFxuICAgIG1pbldpZHRoOiA0LFxuXG4gICAgXCImOmZpcnN0LW9mLXR5cGVcIjoge1xuICAgICAgYm9yZGVyVG9wTGVmdFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiBcImluaGVyaXRcIixcbiAgICB9LFxuXG4gICAgXCImOmxhc3Qtb2YtdHlwZVwiOiB7XG4gICAgICBib3JkZXJUb3BSaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czogXCJpbmhlcml0XCIsXG4gICAgfSxcbiAgfSlcbik7XG5cbnR5cGUgU3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzID0ge1xuICBmaWxsZWRQZXJjZW50YWdlOiBudW1iZXI7XG59O1xuY29uc3QgU3R5bGVkU2VnbWVudENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkU2VnbWVudENvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIGZpbGxlZFBlcmNlbnRhZ2UgfSkgPT4gKHtcbiAgICB3aWR0aDogYCR7ZmlsbGVkUGVyY2VudGFnZX0lYCxcbiAgICBtaW5XaWR0aDogXCJmaXQtY29udGVudFwiLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwicm93XCIsXG4gICAgZ2FwOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBoZWlnaHQ6IFwiMTAwJVwiLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzKCh7IHRoZW1lIH0pID0+ICh7XG4gIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICBoZWlnaHQ6IDEsXG4gIHdpZHRoOiAxLFxuICBtYXJnaW46IC0xLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgcGFkZGluZzogMCxcbiAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuaGlkZGVuLFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZFByb2dyZXNzQmFyKHtcbiAgbWF4VmFsdWUsXG4gIHZhbHVlcyxcbiAgd2VpZ2h0ID0gXCJmYXRcIixcbiAgc3F1YXJlQ29ybmVycyA9IGZhbHNlLFxuICBnZXRUb29sdGlwVGV4dCxcbiAgdG9vbHRpcFByb3BzID0geyB0cmlnZ2VyQXJpYUxhYmVsOiBcIk1vcmUgaW5mb3JtYXRpb25cIiB9LFxuICBwcml2YXRlUHJvcHM6IHsgbW9ub2Nocm9tZSB9ID0geyBtb25vY2hyb21lOiBmYWxzZSB9LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IFNlZ21lbnRlZFByb2dyZXNzQmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCB7IHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMgfSA9IHNhbml0aXplSW5wdXRWYWx1ZXMoXG4gICAgbWF4VmFsdWUsXG4gICAgdmFsdWVzXG4gICk7XG5cbiAgY29uc3QgcGVyY2VudGFnZXM6IHtcbiAgICBwZXJjZW50YWdlOiBudW1iZXI7XG4gICAgdmFyaWFudDogU3R5bGVWYXJpYW50O1xuICB9W10gPSBnZXRQZXJjZW50YWdlc0ZvclZhcmlhbnRzKHNhbml0aXplZE1heFZhbHVlLCBzYW5pdGl6ZWRWYWx1ZXMpO1xuXG4gIGNvbnN0IHRvdGFsRmlsbGVkVmFsdWUgPSBnZXRUb3RhbEZpbGxlZFZhbHVlKHNhbml0aXplZFZhbHVlcyk7XG4gIGNvbnN0IGZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcyA9IHBlcmNlbnRhZ2VzLmZpbHRlcihcbiAgICAoeyB2YXJpYW50IH0pID0+IHZhcmlhbnQgIT09IFwiZW1wdHlcIlxuICApO1xuXG4gIGNvbnN0IGZpbGxlZFBlcmNlbnRhZ2UgPSBmaWxsZWRTZWdtZW50UGVyY2VudGFnZXMucmVkdWNlKFxuICAgIChjdXJyZW50VmFsdWUsIGl0ZW0pID0+IGN1cnJlbnRWYWx1ZSArIGl0ZW0ucGVyY2VudGFnZSxcbiAgICAwXG4gICk7XG4gIGNvbnN0IGhhc1Rvb2x0aXAgPSBCb29sZWFuKGdldFRvb2x0aXBUZXh0KTtcblxuICBjb25zdCBzZWdtZW50cyA9IGZpbGxlZFBlcmNlbnRhZ2UgPyAoXG4gICAgPFN0eWxlZFNlZ21lbnRDb250YWluZXJcbiAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPVwic2VnbWVudENvbnRhaW5lclwiXG4gICAgPlxuICAgICAge2ZpbGxlZFNlZ21lbnRQZXJjZW50YWdlcy5tYXAoKHsgcGVyY2VudGFnZSwgdmFyaWFudCB9KSA9PiAoXG4gICAgICAgIDxTdHlsZWRTZWdtZW50XG4gICAgICAgICAga2V5PXt2YXJpYW50fVxuICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e3ZhcmlhbnR9XG4gICAgICAgICAgc3R5bGVWYXJpYW50PXt2YXJpYW50IGFzIFZhbHVlc1ZhcmlhbnR9XG4gICAgICAgICAgbW9ub2Nocm9tZT17bW9ub2Nocm9tZX1cbiAgICAgICAgICBwZXJjZW50YWdlPXtwZXJjZW50YWdlfVxuICAgICAgICAgIGZpbGxlZFBlcmNlbnRhZ2U9e2ZpbGxlZFBlcmNlbnRhZ2V9XG4gICAgICAgIC8+XG4gICAgICApKX1cbiAgICA8L1N0eWxlZFNlZ21lbnRDb250YWluZXI+XG4gICkgOiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRQcm9ncmVzc0JhclwiXG4gICAgPlxuICAgICAgPFN0eWxlZFByb2dyZXNzQmFyQ29udGFpbmVyXG4gICAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgICAgIHdlaWdodD17d2VpZ2h0fVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwicHJvZ3Jlc3NCYXJDb250YWluZXJcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkUHJvZ3Jlc3NFbGVtZW50XG4gICAgICAgICAgbWF4PXtzYW5pdGl6ZWRNYXhWYWx1ZX1cbiAgICAgICAgICB2YWx1ZT17dG90YWxGaWxsZWRWYWx1ZX1cbiAgICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIC8+XG4gICAgICAgIHtzZWdtZW50c31cbiAgICAgIDwvU3R5bGVkUHJvZ3Jlc3NCYXJDb250YWluZXI+XG4gICAgICB7aGFzVG9vbHRpcCAmJiAoXG4gICAgICAgIDxMZWdlbmRQb3BvdmVyXG4gICAgICAgICAgcGVyY2VudGFnZXM9e3BlcmNlbnRhZ2VzfVxuICAgICAgICAgIGdldFRvb2x0aXBUZXh0PXtnZXRUb29sdGlwVGV4dH1cbiAgICAgICAgICB0b29sdGlwUHJvcHM9e3Rvb2x0aXBQcm9wc31cbiAgICAgICAgICBtb25vY2hyb21lPXttb25vY2hyb21lfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RXdCIn0= */");export function SegmentedProgressBar({maxValue,values,weight="fat",squareCorners=!1,getTooltipText,tooltipProps={triggerAriaLabel:"More information"},privateProps:{monochrome}={monochrome:!1},"data-e2e-test-id":dataE2eTestId,...ariaAttributes}){let{sanitizedMaxValue,sanitizedValues}=sanitizeInputValues(maxValue,values),percentages=getPercentagesForVariants(sanitizedMaxValue,sanitizedValues),totalFilledValue=getTotalFilledValue(sanitizedValues),filledSegmentPercentages=percentages.filter(({variant})=>"empty"!==variant),filledPercentage=filledSegmentPercentages.reduce((currentValue,item)=>currentValue+item.percentage,0),segments=filledPercentage?React.createElement(StyledSegmentContainer,{filledPercentage:filledPercentage,"data-e2e-test-id":"segmentContainer"},filledSegmentPercentages.map(({percentage,variant})=>React.createElement(StyledSegment,{key:variant,"data-e2e-test-id":variant,styleVariant:variant,monochrome:monochrome,percentage:percentage,filledPercentage:filledPercentage}))):null;return React.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"SegmentedProgressBar"},React.createElement(StyledProgressBarContainer,{squareCorners:squareCorners,weight:weight,"data-e2e-test-id":"progressBarContainer"},React.createElement(StyledProgressElement,{max:sanitizedMaxValue,value:totalFilledValue,...ariaAttributes}),segments),!!getTooltipText&&React.createElement(LegendPopover,{percentages:percentages,getTooltipText:getTooltipText,tooltipProps:tooltipProps,monochrome:monochrome}))}
@@ -1 +1 @@
1
- import React,{useState,useRef,useEffect,useCallback,useMemo}from"react";import styled from"@emotion/styled";import{TooltipContent}from"../Tooltip/TooltipContent";import{Sheet}from"../Sheet/Sheet";import{FocusTrapWrapper}from"../../shared/FocusTrapWrapper";import breakpoints from"../../web-tokens/_breakpoints.json";let StyledContainer=styled("div",{target:"e1sgspad0",label:"StyledContainer"})(()=>({borderRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Toggletip/BasePopover.tsx","sources":["src/components/Toggletip/BasePopover.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { ReactElement, PropsWithChildren } from \"react\";\nimport React, {\n  useState,\n  useRef,\n  useEffect,\n  useCallback,\n  useMemo,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TooltipContentProps } from \"../Tooltip/TooltipContent\";\nimport type { TooltipConditionalProps } from \"../Tooltip/types\";\nimport { TooltipContent } from \"../Tooltip/TooltipContent\";\nimport type { PopupRole } from \"../Sheet/Sheet\";\nimport { Sheet } from \"../Sheet/Sheet\";\nimport { FocusTrapWrapper } from \"../../shared/FocusTrapWrapper\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\ntype BaseProps = Pick<\n  TooltipContentProps,\n  | \"placement\"\n  | \"portalContainer\"\n  | \"maxWidth\"\n  | \"contentPadding\"\n  | \"hideArrow\"\n  | \"subTheme\"\n  | \"defaultVerticalPlacement\"\n  | \"onOverflowViewport\"\n> & {\n  name?: string;\n  /**  Popover content */\n  content: ReactElement;\n  \"data-e2e-test-id\"?: string;\n  /**  Programmatically toggle Popover visibility with this prop */\n  isVisible?: boolean;\n  /**  Called when tooltip appears and disappears */\n  onVisibilityChange?: (isVisible: boolean, reason: string) => void;\n  /**  Controls whether BasePopover  closes on outside click */\n  dismissOnOutsideClick?: boolean;\n  /**  Option for focus-trap, controls whether the first focuable item recieves focus */\n  disableInitialFocus?: boolean;\n  /**  Option for focus-trap, controls whether the trigger should receive back the focus on popover close */\n  disableReturnFocusToTrigger?: boolean;\n  /**  Render as sheet on mobile web */\n  renderAsSheetOnMobile?: boolean;\n  /** Role for accessibility */\n  role?: PopupRole;\n  /**  Props for configuring the sheet on mobile web */\n  sheetProps?: {\n    /**  Show the dark scrim backdrop on mobile web when rendering as Sheet */\n    hasBackdrop?: boolean;\n  };\n};\n\nexport type BasePopoverProps = BaseProps & TooltipConditionalProps;\n\nconst StyledContainer = styled.div(() => ({\n  borderRadius: \"inherit\",\n}));\n\nconst FocusTrapContent = React.forwardRef<\n  HTMLDivElement,\n  PropsWithChildren<unknown>\n>(({ children }, ref) => (\n  <StyledContainer ref={ref}>{children}</StyledContainer>\n));\n\nconst VisibilityChangeReason = {\n  triggerClick: \"triggerClick\",\n  outsideClick: \"outsideClick\",\n};\n\nfunction getAriaPopupType(role: PopupRole | undefined): string {\n  let popupType: string = String(role);\n  if (!role) {\n    popupType = \"true\";\n  }\n  if (role === \"alertdialog\") {\n    return \"dialog\";\n  }\n  return popupType;\n}\n\nfunction getMobileBreakpoint(renderAsSheetOnMobile: boolean) {\n  if (!window) {\n    // TODO window should be extracted from hook useWindow\n    return false;\n  }\n\n  const maxMobileHeightInLandscape = 450; // is 430 for iphone pro max, but let's add 20px for next generations\n  const isMobileInPortrait = window.innerWidth <= breakpoints.m.value;\n  const isSmallHeight = window.innerHeight <= maxMobileHeightInLandscape;\n  const isLandscape = window.matchMedia?.(\"(orientation: landscape)\").matches;\n  const isMobileInLandscape = isLandscape && isSmallHeight;\n\n  return renderAsSheetOnMobile && (isMobileInPortrait || isMobileInLandscape);\n}\n\nexport function BasePopover({\n  placement = \"auto\",\n  content,\n  children,\n  contentPadding = \"m\",\n  maxWidth,\n  externalTriggerRef,\n  portalContainer,\n  name = \"Popover\",\n  isVisible: isPopoverVisible,\n  dismissOnOutsideClick = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  subTheme,\n  defaultVerticalPlacement,\n  onVisibilityChange,\n  disableInitialFocus = false,\n  disableReturnFocusToTrigger = false,\n  renderAsSheetOnMobile = false,\n  role,\n  sheetProps,\n  ...restContentProps\n}: BasePopoverProps): React.ReactElement {\n  const tooltipId = useMemo(\n    () => `DS${name}_${Math.floor(Date.now() * Math.random())}`,\n    [name]\n  );\n  const [isVisible, setVisible] = useState(isPopoverVisible);\n  const [isMobileBreakPoint, setIsMobileBreakpoint] = useState(\n    getMobileBreakpoint(renderAsSheetOnMobile)\n  );\n  const internalTriggerRef = useRef<HTMLElement>(null);\n  const triggerRef = externalTriggerRef || internalTriggerRef;\n  const isOutsideClickOnTrigger = useRef(false);\n\n  const toggleVisibility = useCallback(\n    (status: boolean, reason: string) => {\n      setVisible(status);\n\n      if (onVisibilityChange) {\n        onVisibilityChange(status, reason);\n      }\n    },\n    [onVisibilityChange]\n  );\n\n  // Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.\n  const handleTriggerClick = useCallback(() => {\n    if (!isOutsideClickOnTrigger.current) {\n      toggleVisibility(!isVisible, VisibilityChangeReason.triggerClick);\n    } else {\n      // reset this value so that Popover can open in next click\n      isOutsideClickOnTrigger.current = false;\n    }\n  }, [toggleVisibility, isVisible]);\n\n  const handleClickOutsideDeactivates = useCallback(\n    (evt: MouseEvent) => {\n      if (\n        triggerRef.current &&\n        triggerRef.current.contains(evt.target as Node)\n      ) {\n        isOutsideClickOnTrigger.current = true;\n      }\n      return true;\n    },\n    [triggerRef, isOutsideClickOnTrigger]\n  );\n\n  const handlePostDeactivate = useCallback(() => {\n    const reason = isOutsideClickOnTrigger.current\n      ? VisibilityChangeReason.triggerClick\n      : VisibilityChangeReason.outsideClick;\n\n    toggleVisibility(false, reason);\n  }, [toggleVisibility]);\n\n  useEffect(() => {\n    setVisible(isPopoverVisible);\n  }, [isPopoverVisible]);\n\n  useEffect(() => {\n    // Check if this is a mobile breakpoint\n    setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile));\n  }, [isVisible, renderAsSheetOnMobile]);\n\n  useEffect(() => {\n    const trigger = triggerRef.current;\n    if (!trigger) return undefined;\n\n    trigger.addEventListener(\"click\", handleTriggerClick);\n\n    return () => {\n      trigger.removeEventListener(\"click\", handleTriggerClick);\n    };\n  }, [handleTriggerClick, triggerRef]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n      const triggerTabIndex = trigger.getAttribute(\"tabindex\");\n\n      trigger.setAttribute(\"tabindex\", triggerTabIndex ?? \"0\");\n    }\n  }, [externalTriggerRef, children]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n\n      trigger.setAttribute(\"aria-haspopup\", getAriaPopupType(role));\n      if (isVisible) {\n        trigger.setAttribute(\"aria-expanded\", \"true\");\n        trigger.setAttribute(\"aria-controls\", tooltipId);\n      } else {\n        trigger.removeAttribute(\"aria-expanded\");\n        trigger.removeAttribute(\"aria-controls\");\n      }\n    }\n  }, [externalTriggerRef, children, role, tooltipId, isVisible]);\n\n  const triggerElm = children\n    ? React.cloneElement(children, {\n        ref: triggerRef,\n        ...(isVisible && {\n          \"aria-expanded\": true,\n          \"aria-controls\": tooltipId,\n        }),\n        tabIndex: children.props.tabIndex ?? 0,\n        \"aria-haspopup\": getAriaPopupType(role),\n      })\n    : null;\n\n  if (isMobileBreakPoint) {\n    // render as Sheet\n    const sheetElm = (\n      <Sheet\n        id={tooltipId}\n        isVisible={isVisible}\n        portalContainer={portalContainer}\n        dismissOnOutsideClick={dismissOnOutsideClick}\n        disableInitialFocus={disableInitialFocus}\n        disableReturnFocusToTrigger={disableReturnFocusToTrigger}\n        onClose={handlePostDeactivate}\n        onClickOutsideDeactivates={handleClickOutsideDeactivates}\n        role={role}\n        {...(sheetProps ?? {})}\n      >\n        {content}\n      </Sheet>\n    );\n\n    return (\n      <>\n        {triggerElm}\n        {sheetElm}\n      </>\n    );\n  }\n\n  // render as Popover\n  const contentElm = (\n    <FocusTrapWrapper\n      active={isVisible}\n      focusTrapOptions={{\n        clickOutsideDeactivates:\n          dismissOnOutsideClick && handleClickOutsideDeactivates, // de-activate focus trap on outside click\n        allowOutsideClick: true,\n        escapeDeactivates: true,\n        fallbackFocus: `#${tooltipId}`, // set focus to tooltip content container if it has no focusable element\n        onPostDeactivate: handlePostDeactivate,\n        preventScroll: true,\n        initialFocus: () => !disableInitialFocus,\n        returnFocusOnDeactivate: !disableReturnFocusToTrigger,\n      }}\n    >\n      <FocusTrapContent>{content}</FocusTrapContent>\n    </FocusTrapWrapper>\n  );\n\n  const tooltipElm = (\n    <TooltipContent\n      {...restContentProps} // eslint-disable-line react/jsx-props-no-spreading\n      role={role}\n      defaultVerticalPlacement={defaultVerticalPlacement}\n      dataDSId={name}\n      content={contentElm}\n      contentPadding={contentPadding}\n      maxWidth={maxWidth}\n      placement={placement}\n      portalContainer={portalContainer}\n      dataE2eTestId={dataE2eTestId}\n      subTheme={subTheme}\n      isVisible={isVisible}\n      tooltipId={tooltipId}\n      triggerRef={triggerRef}\n      isHiddenOnInvisibleTrigger\n    />\n  );\n\n  return (\n    <>\n      {triggerElm}\n      {tooltipElm}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAwDwB"} */"),FocusTrapContent=React.forwardRef(({children},ref)=>React.createElement(StyledContainer,{ref:ref},children)),VisibilityChangeReason={triggerClick:"triggerClick",outsideClick:"outsideClick"};function getAriaPopupType(role){let popupType=String(role);return(role||(popupType="true"),"alertdialog"===role)?"dialog":popupType}function getMobileBreakpoint(renderAsSheetOnMobile){if(!window)return!1;let isMobileInPortrait=window.innerWidth<=breakpoints.m.value,isSmallHeight=window.innerHeight<=450,isLandscape=window.matchMedia?.("(orientation: landscape)").matches;return renderAsSheetOnMobile&&(isMobileInPortrait||isLandscape&&isSmallHeight)}export function BasePopover({placement="auto",content,children,contentPadding="m",maxWidth,externalTriggerRef,portalContainer,name="Popover",isVisible:isPopoverVisible,dismissOnOutsideClick=!0,"data-e2e-test-id":dataE2eTestId,subTheme,defaultVerticalPlacement,onVisibilityChange,disableInitialFocus=!1,disableReturnFocusToTrigger=!1,renderAsSheetOnMobile=!1,role,sheetProps,...restContentProps}){let tooltipId=useMemo(()=>`DS${name}_${Math.floor(Date.now()*Math.random())}`,[name]),[isVisible,setVisible]=useState(isPopoverVisible),[isMobileBreakPoint,setIsMobileBreakpoint]=useState(getMobileBreakpoint(renderAsSheetOnMobile)),internalTriggerRef=useRef(null),triggerRef=externalTriggerRef||internalTriggerRef,isOutsideClickOnTrigger=useRef(!1),toggleVisibility=useCallback((status,reason)=>{setVisible(status),onVisibilityChange&&onVisibilityChange(status,reason)},[onVisibilityChange]),handleTriggerClick=useCallback(()=>{isOutsideClickOnTrigger.current?isOutsideClickOnTrigger.current=!1:toggleVisibility(!isVisible,VisibilityChangeReason.triggerClick)},[toggleVisibility,isVisible]),handleClickOutsideDeactivates=useCallback(evt=>(triggerRef.current&&triggerRef.current.contains(evt.target)&&(isOutsideClickOnTrigger.current=!0),!0),[triggerRef,isOutsideClickOnTrigger]),handlePostDeactivate=useCallback(()=>{toggleVisibility(!1,isOutsideClickOnTrigger.current?VisibilityChangeReason.triggerClick:VisibilityChangeReason.outsideClick)},[toggleVisibility]);useEffect(()=>{setVisible(isPopoverVisible)},[isPopoverVisible]),useEffect(()=>{setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile))},[isVisible,renderAsSheetOnMobile]),useEffect(()=>{let trigger=triggerRef.current;if(trigger)return trigger.addEventListener("click",handleTriggerClick),()=>{trigger.removeEventListener("click",handleTriggerClick)}},[handleTriggerClick,triggerRef]),useEffect(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current,triggerTabIndex=trigger.getAttribute("tabindex");trigger.setAttribute("tabindex",triggerTabIndex??"0")}},[externalTriggerRef,children]),useEffect(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current;trigger.setAttribute("aria-haspopup",getAriaPopupType(role)),isVisible?(trigger.setAttribute("aria-expanded","true"),trigger.setAttribute("aria-controls",tooltipId)):(trigger.removeAttribute("aria-expanded"),trigger.removeAttribute("aria-controls"))}},[externalTriggerRef,children,role,tooltipId,isVisible]);let triggerElm=children?React.cloneElement(children,{ref:triggerRef,...isVisible&&{"aria-expanded":!0,"aria-controls":tooltipId},tabIndex:children.props.tabIndex??0,"aria-haspopup":getAriaPopupType(role)}):null;if(isMobileBreakPoint){let sheetElm=React.createElement(Sheet,{id:tooltipId,isVisible:isVisible,portalContainer:portalContainer,dismissOnOutsideClick:dismissOnOutsideClick,disableInitialFocus:disableInitialFocus,disableReturnFocusToTrigger:disableReturnFocusToTrigger,onClose:handlePostDeactivate,onClickOutsideDeactivates:handleClickOutsideDeactivates,role:role,...sheetProps??{}},content);return React.createElement(React.Fragment,null,triggerElm,sheetElm)}let contentElm=React.createElement(FocusTrapWrapper,{active:isVisible,focusTrapOptions:{clickOutsideDeactivates:dismissOnOutsideClick&&handleClickOutsideDeactivates,allowOutsideClick:!0,escapeDeactivates:!0,fallbackFocus:`#${tooltipId}`,onPostDeactivate:handlePostDeactivate,preventScroll:!0,initialFocus:()=>!disableInitialFocus,returnFocusOnDeactivate:!disableReturnFocusToTrigger}},React.createElement(FocusTrapContent,null,content)),tooltipElm=React.createElement(TooltipContent,{...restContentProps,role:role,defaultVerticalPlacement:defaultVerticalPlacement,dataDSId:name,content:contentElm,contentPadding:contentPadding,maxWidth:maxWidth,placement:placement,portalContainer:portalContainer,dataE2eTestId:dataE2eTestId,subTheme:subTheme,isVisible:isVisible,tooltipId:tooltipId,triggerRef:triggerRef,isHiddenOnInvisibleTrigger:!0});return React.createElement(React.Fragment,null,triggerElm,tooltipElm)}
1
+ import React,{useState,useRef,useEffect,useCallback,useMemo}from"react";import styled from"@emotion/styled";import{TooltipContent}from"../Tooltip/TooltipContent";import{Sheet}from"../Sheet/Sheet";import{FocusTrapWrapper}from"../../shared/FocusTrapWrapper";import breakpoints from"../../web-tokens/_breakpoints.json";import{getAriaAttributes}from"../../shared/ariaAttributes";let StyledContainer=styled("div",{target:"ewyi9km0",label:"StyledContainer"})(()=>({borderRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Toggletip/BasePopover.tsx","sources":["src/components/Toggletip/BasePopover.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { ReactElement, PropsWithChildren } from \"react\";\nimport React, {\n  useState,\n  useRef,\n  useEffect,\n  useCallback,\n  useMemo,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TooltipContentProps } from \"../Tooltip/TooltipContent\";\nimport type { TooltipConditionalProps } from \"../Tooltip/types\";\nimport { TooltipContent } from \"../Tooltip/TooltipContent\";\nimport type { PopupRole } from \"../Sheet/Sheet\";\nimport { Sheet } from \"../Sheet/Sheet\";\nimport { FocusTrapWrapper } from \"../../shared/FocusTrapWrapper\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { getAriaAttributes } from \"../../shared/ariaAttributes\";\n\ntype BaseProps = Pick<\n  TooltipContentProps,\n  | \"placement\"\n  | \"portalContainer\"\n  | \"maxWidth\"\n  | \"contentPadding\"\n  | \"hideArrow\"\n  | \"subTheme\"\n  | \"defaultVerticalPlacement\"\n  | \"onOverflowViewport\"\n> & {\n  name?: string;\n  /**  Popover content */\n  content: ReactElement;\n  \"data-e2e-test-id\"?: string;\n  /**  Programmatically toggle Popover visibility with this prop */\n  isVisible?: boolean;\n  /**  Called when tooltip appears and disappears */\n  onVisibilityChange?: (isVisible: boolean, reason: string) => void;\n  /**  Controls whether BasePopover  closes on outside click */\n  dismissOnOutsideClick?: boolean;\n  /**  Option for focus-trap, controls whether the first focuable item recieves focus */\n  disableInitialFocus?: boolean;\n  /**  Option for focus-trap, controls whether the trigger should receive back the focus on popover close */\n  disableReturnFocusToTrigger?: boolean;\n  /**  Render as sheet on mobile web */\n  renderAsSheetOnMobile?: boolean;\n  /** Role for accessibility */\n  role?: PopupRole;\n  /**  Props for configuring the sheet on mobile web */\n  sheetProps?: {\n    /**  Show the dark scrim backdrop on mobile web when rendering as Sheet */\n    hasBackdrop?: boolean;\n  };\n};\n\nexport type BasePopoverProps = BaseProps & TooltipConditionalProps;\n\nconst StyledContainer = styled.div(() => ({\n  borderRadius: \"inherit\",\n}));\n\nconst FocusTrapContent = React.forwardRef<\n  HTMLDivElement,\n  PropsWithChildren<unknown>\n>(({ children }, ref) => (\n  <StyledContainer ref={ref}>{children}</StyledContainer>\n));\n\nconst VisibilityChangeReason = {\n  triggerClick: \"triggerClick\",\n  outsideClick: \"outsideClick\",\n};\n\nfunction getAriaPopupType(role: PopupRole | undefined): string {\n  let popupType: string = String(role);\n  if (!role) {\n    popupType = \"true\";\n  }\n  if (role === \"alertdialog\") {\n    return \"dialog\";\n  }\n  return popupType;\n}\n\nfunction getMobileBreakpoint(renderAsSheetOnMobile: boolean) {\n  if (!window) {\n    // TODO window should be extracted from hook useWindow\n    return false;\n  }\n\n  const maxMobileHeightInLandscape = 450; // is 430 for iphone pro max, but let's add 20px for next generations\n  const isMobileInPortrait = window.innerWidth <= breakpoints.m.value;\n  const isSmallHeight = window.innerHeight <= maxMobileHeightInLandscape;\n  const isLandscape = window.matchMedia?.(\"(orientation: landscape)\").matches;\n  const isMobileInLandscape = isLandscape && isSmallHeight;\n\n  return renderAsSheetOnMobile && (isMobileInPortrait || isMobileInLandscape);\n}\n\nexport function BasePopover({\n  placement = \"auto\",\n  content,\n  children,\n  contentPadding = \"m\",\n  maxWidth,\n  externalTriggerRef,\n  portalContainer,\n  name = \"Popover\",\n  isVisible: isPopoverVisible,\n  dismissOnOutsideClick = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  subTheme,\n  defaultVerticalPlacement,\n  onVisibilityChange,\n  disableInitialFocus = false,\n  disableReturnFocusToTrigger = false,\n  renderAsSheetOnMobile = false,\n  role,\n  sheetProps,\n  ...restContentProps\n}: BasePopoverProps): React.ReactElement {\n  const tooltipId = useMemo(\n    () => `DS${name}_${Math.floor(Date.now() * Math.random())}`,\n    [name]\n  );\n  const [isVisible, setVisible] = useState(isPopoverVisible);\n  const [isMobileBreakPoint, setIsMobileBreakpoint] = useState(\n    getMobileBreakpoint(renderAsSheetOnMobile)\n  );\n  const internalTriggerRef = useRef<HTMLElement>(null);\n  const triggerRef = externalTriggerRef || internalTriggerRef;\n  const isOutsideClickOnTrigger = useRef(false);\n  const ariaAttributes = getAriaAttributes(restContentProps);\n\n  const toggleVisibility = useCallback(\n    (status: boolean, reason: string) => {\n      setVisible(status);\n\n      if (onVisibilityChange) {\n        onVisibilityChange(status, reason);\n      }\n    },\n    [onVisibilityChange]\n  );\n\n  // Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.\n  const handleTriggerClick = useCallback(() => {\n    if (!isOutsideClickOnTrigger.current) {\n      toggleVisibility(!isVisible, VisibilityChangeReason.triggerClick);\n    } else {\n      // reset this value so that Popover can open in next click\n      isOutsideClickOnTrigger.current = false;\n    }\n  }, [toggleVisibility, isVisible]);\n\n  const handleClickOutsideDeactivates = useCallback(\n    (evt: MouseEvent) => {\n      if (\n        triggerRef.current &&\n        triggerRef.current.contains(evt.target as Node)\n      ) {\n        isOutsideClickOnTrigger.current = true;\n      }\n      return true;\n    },\n    [triggerRef, isOutsideClickOnTrigger]\n  );\n\n  const handlePostDeactivate = useCallback(() => {\n    const reason = isOutsideClickOnTrigger.current\n      ? VisibilityChangeReason.triggerClick\n      : VisibilityChangeReason.outsideClick;\n\n    toggleVisibility(false, reason);\n  }, [toggleVisibility]);\n\n  useEffect(() => {\n    setVisible(isPopoverVisible);\n  }, [isPopoverVisible]);\n\n  useEffect(() => {\n    // Check if this is a mobile breakpoint\n    setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile));\n  }, [isVisible, renderAsSheetOnMobile]);\n\n  useEffect(() => {\n    const trigger = triggerRef.current;\n    if (!trigger) return undefined;\n\n    trigger.addEventListener(\"click\", handleTriggerClick);\n\n    return () => {\n      trigger.removeEventListener(\"click\", handleTriggerClick);\n    };\n  }, [handleTriggerClick, triggerRef]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n      const triggerTabIndex = trigger.getAttribute(\"tabindex\");\n\n      trigger.setAttribute(\"tabindex\", triggerTabIndex ?? \"0\");\n    }\n  }, [externalTriggerRef, children]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n\n      trigger.setAttribute(\"aria-haspopup\", getAriaPopupType(role));\n      if (isVisible) {\n        trigger.setAttribute(\"aria-expanded\", \"true\");\n        trigger.setAttribute(\"aria-controls\", tooltipId);\n      } else {\n        trigger.removeAttribute(\"aria-expanded\");\n        trigger.removeAttribute(\"aria-controls\");\n      }\n    }\n  }, [externalTriggerRef, children, role, tooltipId, isVisible]);\n\n  const triggerElm = children\n    ? React.cloneElement(children, {\n        ref: triggerRef,\n        ...(isVisible && {\n          \"aria-expanded\": true,\n          \"aria-controls\": tooltipId,\n        }),\n        tabIndex: children.props.tabIndex ?? 0,\n        \"aria-haspopup\": getAriaPopupType(role),\n      })\n    : null;\n\n  if (isMobileBreakPoint) {\n    // render as Sheet\n    const sheetElm = (\n      <Sheet\n        id={tooltipId}\n        isVisible={isVisible}\n        portalContainer={portalContainer}\n        dismissOnOutsideClick={dismissOnOutsideClick}\n        disableInitialFocus={disableInitialFocus}\n        disableReturnFocusToTrigger={disableReturnFocusToTrigger}\n        onClose={handlePostDeactivate}\n        onClickOutsideDeactivates={handleClickOutsideDeactivates}\n        role={role}\n        {...(sheetProps ?? {})}\n        {...ariaAttributes}\n      >\n        {content}\n      </Sheet>\n    );\n\n    return (\n      <>\n        {triggerElm}\n        {sheetElm}\n      </>\n    );\n  }\n\n  // render as Popover\n  const contentElm = (\n    <FocusTrapWrapper\n      active={isVisible}\n      focusTrapOptions={{\n        clickOutsideDeactivates:\n          dismissOnOutsideClick && handleClickOutsideDeactivates, // de-activate focus trap on outside click\n        allowOutsideClick: true,\n        escapeDeactivates: true,\n        fallbackFocus: `#${tooltipId}`, // set focus to tooltip content container if it has no focusable element\n        onPostDeactivate: handlePostDeactivate,\n        preventScroll: true,\n        initialFocus: () => !disableInitialFocus,\n        returnFocusOnDeactivate: !disableReturnFocusToTrigger,\n      }}\n    >\n      <FocusTrapContent>{content}</FocusTrapContent>\n    </FocusTrapWrapper>\n  );\n\n  const tooltipElm = (\n    <TooltipContent\n      {...restContentProps} // eslint-disable-line react/jsx-props-no-spreading\n      role={role}\n      defaultVerticalPlacement={defaultVerticalPlacement}\n      dataDSId={name}\n      content={contentElm}\n      contentPadding={contentPadding}\n      maxWidth={maxWidth}\n      placement={placement}\n      portalContainer={portalContainer}\n      dataE2eTestId={dataE2eTestId}\n      subTheme={subTheme}\n      isVisible={isVisible}\n      tooltipId={tooltipId}\n      triggerRef={triggerRef}\n      isHiddenOnInvisibleTrigger\n    />\n  );\n\n  return (\n    <>\n      {triggerElm}\n      {tooltipElm}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAyDwB"} */"),FocusTrapContent=React.forwardRef(({children},ref)=>React.createElement(StyledContainer,{ref:ref},children)),VisibilityChangeReason={triggerClick:"triggerClick",outsideClick:"outsideClick"};function getAriaPopupType(role){let popupType=String(role);return(role||(popupType="true"),"alertdialog"===role)?"dialog":popupType}function getMobileBreakpoint(renderAsSheetOnMobile){if(!window)return!1;let isMobileInPortrait=window.innerWidth<=breakpoints.m.value,isSmallHeight=window.innerHeight<=450,isLandscape=window.matchMedia?.("(orientation: landscape)").matches;return renderAsSheetOnMobile&&(isMobileInPortrait||isLandscape&&isSmallHeight)}export function BasePopover({placement="auto",content,children,contentPadding="m",maxWidth,externalTriggerRef,portalContainer,name="Popover",isVisible:isPopoverVisible,dismissOnOutsideClick=!0,"data-e2e-test-id":dataE2eTestId,subTheme,defaultVerticalPlacement,onVisibilityChange,disableInitialFocus=!1,disableReturnFocusToTrigger=!1,renderAsSheetOnMobile=!1,role,sheetProps,...restContentProps}){let tooltipId=useMemo(()=>`DS${name}_${Math.floor(Date.now()*Math.random())}`,[name]),[isVisible,setVisible]=useState(isPopoverVisible),[isMobileBreakPoint,setIsMobileBreakpoint]=useState(getMobileBreakpoint(renderAsSheetOnMobile)),internalTriggerRef=useRef(null),triggerRef=externalTriggerRef||internalTriggerRef,isOutsideClickOnTrigger=useRef(!1),ariaAttributes=getAriaAttributes(restContentProps),toggleVisibility=useCallback((status,reason)=>{setVisible(status),onVisibilityChange&&onVisibilityChange(status,reason)},[onVisibilityChange]),handleTriggerClick=useCallback(()=>{isOutsideClickOnTrigger.current?isOutsideClickOnTrigger.current=!1:toggleVisibility(!isVisible,VisibilityChangeReason.triggerClick)},[toggleVisibility,isVisible]),handleClickOutsideDeactivates=useCallback(evt=>(triggerRef.current&&triggerRef.current.contains(evt.target)&&(isOutsideClickOnTrigger.current=!0),!0),[triggerRef,isOutsideClickOnTrigger]),handlePostDeactivate=useCallback(()=>{toggleVisibility(!1,isOutsideClickOnTrigger.current?VisibilityChangeReason.triggerClick:VisibilityChangeReason.outsideClick)},[toggleVisibility]);useEffect(()=>{setVisible(isPopoverVisible)},[isPopoverVisible]),useEffect(()=>{setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile))},[isVisible,renderAsSheetOnMobile]),useEffect(()=>{let trigger=triggerRef.current;if(trigger)return trigger.addEventListener("click",handleTriggerClick),()=>{trigger.removeEventListener("click",handleTriggerClick)}},[handleTriggerClick,triggerRef]),useEffect(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current,triggerTabIndex=trigger.getAttribute("tabindex");trigger.setAttribute("tabindex",triggerTabIndex??"0")}},[externalTriggerRef,children]),useEffect(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current;trigger.setAttribute("aria-haspopup",getAriaPopupType(role)),isVisible?(trigger.setAttribute("aria-expanded","true"),trigger.setAttribute("aria-controls",tooltipId)):(trigger.removeAttribute("aria-expanded"),trigger.removeAttribute("aria-controls"))}},[externalTriggerRef,children,role,tooltipId,isVisible]);let triggerElm=children?React.cloneElement(children,{ref:triggerRef,...isVisible&&{"aria-expanded":!0,"aria-controls":tooltipId},tabIndex:children.props.tabIndex??0,"aria-haspopup":getAriaPopupType(role)}):null;if(isMobileBreakPoint){let sheetElm=React.createElement(Sheet,{id:tooltipId,isVisible:isVisible,portalContainer:portalContainer,dismissOnOutsideClick:dismissOnOutsideClick,disableInitialFocus:disableInitialFocus,disableReturnFocusToTrigger:disableReturnFocusToTrigger,onClose:handlePostDeactivate,onClickOutsideDeactivates:handleClickOutsideDeactivates,role:role,...sheetProps??{},...ariaAttributes},content);return React.createElement(React.Fragment,null,triggerElm,sheetElm)}let contentElm=React.createElement(FocusTrapWrapper,{active:isVisible,focusTrapOptions:{clickOutsideDeactivates:dismissOnOutsideClick&&handleClickOutsideDeactivates,allowOutsideClick:!0,escapeDeactivates:!0,fallbackFocus:`#${tooltipId}`,onPostDeactivate:handlePostDeactivate,preventScroll:!0,initialFocus:()=>!disableInitialFocus,returnFocusOnDeactivate:!disableReturnFocusToTrigger}},React.createElement(FocusTrapContent,null,content)),tooltipElm=React.createElement(TooltipContent,{...restContentProps,role:role,defaultVerticalPlacement:defaultVerticalPlacement,dataDSId:name,content:contentElm,contentPadding:contentPadding,maxWidth:maxWidth,placement:placement,portalContainer:portalContainer,dataE2eTestId:dataE2eTestId,subTheme:subTheme,isVisible:isVisible,tooltipId:tooltipId,triggerRef:triggerRef,isHiddenOnInvisibleTrigger:!0});return React.createElement(React.Fragment,null,triggerElm,tooltipElm)}
@@ -32,4 +32,4 @@ export type TooltipStyle = {
32
32
  verticalPlacement: "top" | "bottom";
33
33
  };
34
34
  /** This component is used to display the overlay for both Toggletip and Tooltip components */
35
- export declare function TooltipContent({ placement, content, tooltipId, triggerRef, portalContainer, dataE2eTestId, dataDSId, isVisible, "aria-hidden": ariaHidden, role, tabIndex, contentPadding, maxWidth, subTheme, defaultVerticalPlacement, hideArrow, isHiddenOnInvisibleTrigger, onTooltipPointerEnter, onTooltipPointerLeave, onOverflowViewport, }: TooltipContentProps): React.ReactElement;
35
+ export declare function TooltipContent({ placement, content, tooltipId, triggerRef, portalContainer, dataE2eTestId, dataDSId, isVisible, "aria-hidden": ariaHidden, role, tabIndex, contentPadding, maxWidth, subTheme, defaultVerticalPlacement, hideArrow, isHiddenOnInvisibleTrigger, onTooltipPointerEnter, onTooltipPointerLeave, onOverflowViewport, ...ariaAttributes }: TooltipContentProps): React.ReactElement;
@@ -1 +1 @@
1
- import React,{useCallback,useEffect,useLayoutEffect,useMemo,useRef,useState}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{useDocument}from"../../shared/useDocument";import{useWindow}from"../../shared/useWindow";import{SubThemeProvider}from"../SubThemeProvider/SubThemeProvider";import{Portal,usePortalChildZIndex}from"../Portal/Portal";import{ANIMATION_DISTANCE,ARROW_SIZE,ARROW_SIZE_BIG,DISTANCE_FROM_TRIGGER,getArrowOffset,getTooltipStyle}from"./utils";let StyledContainer=styled("div",{target:"erzswfk0",label:"StyledContainer"})(({theme,horizontalPlacement,verticalPlacement,maxWidth,contentPadding,subTheme,isHidden})=>{let animationDistance="top"===verticalPlacement?`${ANIMATION_DISTANCE}px`:`-${ANIMATION_DISTANCE}px`,animation=keyframes({to:{opacity:theme.variables.opacity.visible,transform:"center"===horizontalPlacement?`translate(-50%, ${animationDistance})`:`translateY(${animationDistance})`}}),contentPaddingMap={s:theme.variables.size.spacing.xxs,m:theme.variables.size.spacing.s},invertedSubThemeStyles={padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,...contentPadding&&{padding:contentPaddingMap[contentPadding]}};return{position:"absolute",zIndex:usePortalChildZIndex(theme.variables.zIndex.tooltip),opacity:theme.variables.opacity.hidden,animation:`200ms ease-out forwards ${animation}`,maxWidth,width:"max-content",boxSizing:"border-box",backgroundColor:subTheme?theme.values.color.background.primary.default:theme.values.color.background.elevated.default,borderRadius:subTheme?theme.variables.size.borderRadius.xs:theme.variables.size.borderRadius.s,...isHidden&&{visibility:"hidden"},...!!subTheme&&invertedSubThemeStyles,..."center"===horizontalPlacement&&{transform:"translate(-50%)"},...!subTheme&&{":after":{content:'" "',position:"absolute",top:0,left:0,width:"100%",height:"100%",pointerEvents:"none",borderRadius:"inherit",boxShadow:theme.values.elevation[3]}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tooltip/TooltipContent.tsx","sources":["src/components/Tooltip/TooltipContent.tsx"],"sourcesContent":["import type { AriaAttributes, MutableRefObject, ReactElement } from \"react\";\nimport React, {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport type { Property } from \"csstype\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport type { SubThemeTypes } from \"../../web-tokens/_subThemeType\";\nimport {\n  Portal,\n  usePortalChildZIndex,\n  type PortalProps,\n} from \"../Portal/Portal\";\n\nimport {\n  ANIMATION_DISTANCE,\n  ARROW_SIZE,\n  ARROW_SIZE_BIG,\n  DISTANCE_FROM_TRIGGER,\n  getArrowOffset,\n  getTooltipStyle,\n} from \"./utils\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  role?: string;\n  tabIndex?: number;\n  contentPadding?: \"s\" | \"m\";\n  subTheme?: SubThemeTypes;\n  maxWidth?: Property.MaxWidth | number;\n  defaultVerticalPlacement?: TooltipStyle[\"verticalPlacement\"];\n  hideArrow?: boolean;\n  /** Sets css visibility hidden when trigger is scrolled out of view */\n  isHiddenOnInvisibleTrigger?: boolean;\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n  /** This callback is triggered when content overflows the viewport both above and below trigger. Use this for tracking purposes or re-rendering Popover with a larger maxWidth */\n  onOverflowViewport?: (\n    triggerRect: DOMRect,\n    tooltipRect: DOMRect,\n    viewportHeight: number\n  ) => void;\n} & Pick<PortalProps, \"portalContainer\"> &\n  AriaAttributes;\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\" | \"subTheme\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  isHidden: boolean;\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n// Use 0.99 instead of 1.0 to handle sub-pixel rounding issues\n// that can cause intersectionRatio to report values like 0.99\nconst INTERSECTION_THRESHOLD = 0.99;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    maxWidth,\n    contentPadding,\n    subTheme,\n    isHidden,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: theme.variables.opacity.visible,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    const invertedSubThemeStyles = {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n    };\n\n    const zIndex = usePortalChildZIndex(theme.variables.zIndex.tooltip);\n\n    return {\n      position: \"absolute\",\n      zIndex,\n      opacity: theme.variables.opacity.hidden,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      maxWidth,\n      width: \"max-content\",\n      boxSizing: \"border-box\",\n      backgroundColor: subTheme\n        ? theme.values.color.background.primary.default\n        : theme.values.color.background.elevated.default,\n      borderRadius: subTheme\n        ? theme.variables.size.borderRadius.xs\n        : theme.variables.size.borderRadius.s,\n\n      ...(isHidden && {\n        visibility: \"hidden\",\n      }),\n\n      ...(!!subTheme && invertedSubThemeStyles),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(!subTheme && {\n        \":after\": {\n          content: '\" \"',\n          position: \"absolute\",\n          top: 0,\n          left: 0,\n          width: \"100%\",\n          height: \"100%\",\n          pointerEvents: \"none\",\n          borderRadius: \"inherit\",\n          boxShadow: theme.values.elevation[3],\n        },\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = Pick<TooltipContentProps, \"subTheme\"> & {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  size?: 0 | typeof ARROW_SIZE | typeof ARROW_SIZE_BIG;\n};\n\n// This container is large enough to contain the arrow shadow blur\nconst ARROW_CONTAINER_WIDTH = 40;\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({\n    theme,\n    subTheme,\n    verticalPlacement,\n    horizontalPlacement,\n    size = ARROW_SIZE,\n  }) => {\n    const offset = getArrowOffset(size);\n    const adjustmentForShadow = subTheme ? 0 : 1;\n    const arrowContainerHeight = size + DISTANCE_FROM_TRIGGER;\n    // Get arrow width and height using pythogoras theorem and add 1 to height to account for dark mode shadow.\n    const arrowSideLength = Math.sqrt(\n      size ** 2 + (size + adjustmentForShadow) ** 2\n    );\n\n    return {\n      position: \"absolute\",\n      width: ARROW_CONTAINER_WIDTH,\n      height: arrowContainerHeight,\n      zIndex: 1,\n      overflow: \"hidden\",\n\n      ...(verticalPlacement === \"top\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `calc(100% - ${adjustmentForShadow}px)`,\n      }),\n\n      ...(verticalPlacement === \"bottom\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `-${arrowContainerHeight - adjustmentForShadow}px`,\n      }),\n\n      ...(horizontalPlacement === \"center\" && {\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(horizontalPlacement === \"right\" && {\n        left: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      ...(horizontalPlacement === \"left\" && {\n        right: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      \"&::after\": {\n        content: '\" \"',\n        position: \"absolute\",\n        top: verticalPlacement === \"top\" ? 0 : \"100%\",\n        left: \"50%\",\n        width: arrowSideLength,\n        height: arrowSideLength,\n        backgroundColor: subTheme\n          ? theme.values.color.background.primary.default\n          : theme.values.color.background.elevated.default,\n        transform: \"translate(-50%, -50%) rotate(45deg)\",\n\n        ...(!subTheme && {\n          boxShadow: theme.values.elevation[3],\n        }),\n      },\n    };\n  }\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  subTheme,\n  defaultVerticalPlacement,\n  hideArrow = false,\n  isHiddenOnInvisibleTrigger = false,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n  onOverflowViewport,\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const [isHidden, setIsHidden] = useState(false); // css visibilty hidden\n  const tooltipRef = useRef(null);\n  const isOverflowCallbackCalledRef = useRef(false);\n  const document = useDocument();\n  const window = useWindow();\n\n  const arrowSize = useMemo(() => {\n    if (hideArrow) {\n      return 0;\n    }\n    return subTheme ? ARROW_SIZE : ARROW_SIZE_BIG;\n  }, [subTheme, hideArrow]);\n\n  const handleViewportOverflow = useCallback<\n    TooltipContentProps[\"onOverflowViewport\"]\n  >(\n    (triggerRect, tooltipRect, viewportHeight) => {\n      if (!isOverflowCallbackCalledRef.current) {\n        onOverflowViewport?.(triggerRect, tooltipRect, viewportHeight);\n        isOverflowCallbackCalledRef.current = true;\n      }\n    },\n    [onOverflowViewport, isOverflowCallbackCalledRef]\n  );\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle({\n          placement,\n          defaultVerticalPlacement,\n          triggerRef,\n          tooltipRef,\n          document,\n          window,\n          arrowSize,\n          onOverflowViewport: handleViewportOverflow,\n        })\n      );\n    }\n  }, [\n    triggerRef,\n    tooltipRef,\n    document,\n    window,\n    placement,\n    arrowSize,\n    defaultVerticalPlacement,\n    handleViewportOverflow,\n  ]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content, maxWidth]);\n\n  useEffect(() => {\n    if (isVisible && tooltipRef.current) {\n      window.addEventListener(\"resize\", calculateStyle);\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      window.removeEventListener(\"resize\", calculateStyle);\n    };\n  }, [isVisible, calculateStyle, window, tooltipRef]);\n\n  // Observe tooltip element size changes to recalculate positioning\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      isVisible &&\n      tooltipRef.current &&\n      typeof ResizeObserver !== \"undefined\"\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach((entry) => {\n          if (entry.contentRect.width > 0 && entry.contentRect.height > 0) {\n            calculateStyle();\n          }\n        });\n      });\n\n      resizeObserver.observe(tooltipRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [isVisible, calculateStyle, tooltipRef]);\n\n  // Recalculate position when the trigger moves without emitting scroll/resize\n  // events (e.g. CSS transforms, canvas zoom/pan).\n  useEffect(() => {\n    if (!isVisible) return undefined;\n\n    let requestAnimationFrameId: number;\n    let prevRect: DOMRect | undefined;\n\n    const recalculatePosition = () => {\n      const nextRect = triggerRef.current?.getBoundingClientRect();\n      if (\n        prevRect &&\n        nextRect &&\n        (prevRect.x !== nextRect.x ||\n          prevRect.y !== nextRect.y ||\n          prevRect.width !== nextRect.width ||\n          prevRect.height !== nextRect.height)\n      ) {\n        calculateStyle();\n      }\n      prevRect = nextRect;\n      requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    };\n\n    requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    return () => cancelAnimationFrame(requestAnimationFrameId);\n  }, [isVisible, calculateStyle, triggerRef]);\n\n  useEffect(() => {\n    isOverflowCallbackCalledRef.current = false;\n  }, [isVisible, isOverflowCallbackCalledRef]);\n\n  /* Hide (visibility: hidden) tooltip if trigger is scrolled out of view */\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      isHiddenOnInvisibleTrigger &&\n      triggerRef.current &&\n      isVisible &&\n      typeof IntersectionObserver !== \"undefined\"\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            const rect = entry.boundingClientRect;\n\n            // Ignore intersection changes when element has zero dimensions\n            // This can happen during DOM updates/portal rendering\n            if (rect?.width === 0 && rect?.height === 0) {\n              return;\n            }\n\n            setIsHidden(!entry.isIntersecting);\n          }),\n        {\n          root: null, // viewport\n          threshold: INTERSECTION_THRESHOLD,\n        }\n      );\n\n      observer.observe(triggerRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [triggerRef, isVisible, isHiddenOnInvisibleTrigger]);\n\n  if (!isVisible) return null;\n\n  const tooltipElm = (\n    <StyledContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id={dataDSId}\n      style={{\n        top: style.top,\n        left: style.left,\n        animationDuration: getAnimationDuration(),\n      }}\n      ref={tooltipRef}\n      id={tooltipId}\n      role={role}\n      aria-hidden={ariaHidden}\n      subTheme={subTheme}\n      tabIndex={tabIndex}\n      horizontalPlacement={style.horizontalPlacement}\n      verticalPlacement={style.verticalPlacement}\n      maxWidth={maxWidth}\n      contentPadding={contentPadding}\n      isHidden={isHidden}\n      onPointerEnter={onTooltipPointerEnter}\n      onPointerLeave={onTooltipPointerLeave}\n    >\n      {content}\n      {!hideArrow && (\n        <StyledArrow\n          data-e2e-test-id={`${dataE2eTestId}_arrow`}\n          subTheme={subTheme}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          size={arrowSize}\n        />\n      )}\n    </StyledContainer>\n  );\n\n  const wrapperElm = subTheme ? (\n    <SubThemeProvider name={subTheme}>{tooltipElm}</SubThemeProvider>\n  ) : (\n    tooltipElm\n  );\n\n  return <Portal portalContainer={portalContainer}>{wrapperElm}</Portal>;\n}\n"],"names":[],"mappings":"AAyFwB"} */"),StyledArrow=styled("div",{target:"erzswfk1",label:"StyledArrow"})(({theme,subTheme,verticalPlacement,horizontalPlacement,size=ARROW_SIZE})=>{let offset=getArrowOffset(size),adjustmentForShadow=+!subTheme,arrowContainerHeight=size+DISTANCE_FROM_TRIGGER,arrowSideLength=Math.sqrt(size**2+(size+adjustmentForShadow)**2);return{position:"absolute",width:40,height:arrowContainerHeight,zIndex:1,overflow:"hidden",..."top"===verticalPlacement&&{top:`calc(100% - ${adjustmentForShadow}px)`},..."bottom"===verticalPlacement&&{top:`-${arrowContainerHeight-adjustmentForShadow}px`},..."center"===horizontalPlacement&&{left:"50%",transform:"translate(-50%)"},..."right"===horizontalPlacement&&{left:`${offset-(20-size)}px`},..."left"===horizontalPlacement&&{right:`${offset-(20-size)}px`},"&::after":{content:'" "',position:"absolute",top:"top"===verticalPlacement?0:"100%",left:"50%",width:arrowSideLength,height:arrowSideLength,backgroundColor:subTheme?theme.values.color.background.primary.default:theme.values.color.background.elevated.default,transform:"translate(-50%, -50%) rotate(45deg)",...!subTheme&&{boxShadow:theme.values.elevation[3]}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tooltip/TooltipContent.tsx","sources":["src/components/Tooltip/TooltipContent.tsx"],"sourcesContent":["import type { AriaAttributes, MutableRefObject, ReactElement } from \"react\";\nimport React, {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport type { Property } from \"csstype\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport type { SubThemeTypes } from \"../../web-tokens/_subThemeType\";\nimport {\n  Portal,\n  usePortalChildZIndex,\n  type PortalProps,\n} from \"../Portal/Portal\";\n\nimport {\n  ANIMATION_DISTANCE,\n  ARROW_SIZE,\n  ARROW_SIZE_BIG,\n  DISTANCE_FROM_TRIGGER,\n  getArrowOffset,\n  getTooltipStyle,\n} from \"./utils\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  role?: string;\n  tabIndex?: number;\n  contentPadding?: \"s\" | \"m\";\n  subTheme?: SubThemeTypes;\n  maxWidth?: Property.MaxWidth | number;\n  defaultVerticalPlacement?: TooltipStyle[\"verticalPlacement\"];\n  hideArrow?: boolean;\n  /** Sets css visibility hidden when trigger is scrolled out of view */\n  isHiddenOnInvisibleTrigger?: boolean;\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n  /** This callback is triggered when content overflows the viewport both above and below trigger. Use this for tracking purposes or re-rendering Popover with a larger maxWidth */\n  onOverflowViewport?: (\n    triggerRect: DOMRect,\n    tooltipRect: DOMRect,\n    viewportHeight: number\n  ) => void;\n} & Pick<PortalProps, \"portalContainer\"> &\n  AriaAttributes;\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\" | \"subTheme\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  isHidden: boolean;\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n// Use 0.99 instead of 1.0 to handle sub-pixel rounding issues\n// that can cause intersectionRatio to report values like 0.99\nconst INTERSECTION_THRESHOLD = 0.99;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    maxWidth,\n    contentPadding,\n    subTheme,\n    isHidden,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: theme.variables.opacity.visible,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    const invertedSubThemeStyles = {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n    };\n\n    const zIndex = usePortalChildZIndex(theme.variables.zIndex.tooltip);\n\n    return {\n      position: \"absolute\",\n      zIndex,\n      opacity: theme.variables.opacity.hidden,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      maxWidth,\n      width: \"max-content\",\n      boxSizing: \"border-box\",\n      backgroundColor: subTheme\n        ? theme.values.color.background.primary.default\n        : theme.values.color.background.elevated.default,\n      borderRadius: subTheme\n        ? theme.variables.size.borderRadius.xs\n        : theme.variables.size.borderRadius.s,\n\n      ...(isHidden && {\n        visibility: \"hidden\",\n      }),\n\n      ...(!!subTheme && invertedSubThemeStyles),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(!subTheme && {\n        \":after\": {\n          content: '\" \"',\n          position: \"absolute\",\n          top: 0,\n          left: 0,\n          width: \"100%\",\n          height: \"100%\",\n          pointerEvents: \"none\",\n          borderRadius: \"inherit\",\n          boxShadow: theme.values.elevation[3],\n        },\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = Pick<TooltipContentProps, \"subTheme\"> & {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  size?: 0 | typeof ARROW_SIZE | typeof ARROW_SIZE_BIG;\n};\n\n// This container is large enough to contain the arrow shadow blur\nconst ARROW_CONTAINER_WIDTH = 40;\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({\n    theme,\n    subTheme,\n    verticalPlacement,\n    horizontalPlacement,\n    size = ARROW_SIZE,\n  }) => {\n    const offset = getArrowOffset(size);\n    const adjustmentForShadow = subTheme ? 0 : 1;\n    const arrowContainerHeight = size + DISTANCE_FROM_TRIGGER;\n    // Get arrow width and height using pythogoras theorem and add 1 to height to account for dark mode shadow.\n    const arrowSideLength = Math.sqrt(\n      size ** 2 + (size + adjustmentForShadow) ** 2\n    );\n\n    return {\n      position: \"absolute\",\n      width: ARROW_CONTAINER_WIDTH,\n      height: arrowContainerHeight,\n      zIndex: 1,\n      overflow: \"hidden\",\n\n      ...(verticalPlacement === \"top\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `calc(100% - ${adjustmentForShadow}px)`,\n      }),\n\n      ...(verticalPlacement === \"bottom\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `-${arrowContainerHeight - adjustmentForShadow}px`,\n      }),\n\n      ...(horizontalPlacement === \"center\" && {\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(horizontalPlacement === \"right\" && {\n        left: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      ...(horizontalPlacement === \"left\" && {\n        right: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      \"&::after\": {\n        content: '\" \"',\n        position: \"absolute\",\n        top: verticalPlacement === \"top\" ? 0 : \"100%\",\n        left: \"50%\",\n        width: arrowSideLength,\n        height: arrowSideLength,\n        backgroundColor: subTheme\n          ? theme.values.color.background.primary.default\n          : theme.values.color.background.elevated.default,\n        transform: \"translate(-50%, -50%) rotate(45deg)\",\n\n        ...(!subTheme && {\n          boxShadow: theme.values.elevation[3],\n        }),\n      },\n    };\n  }\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  subTheme,\n  defaultVerticalPlacement,\n  hideArrow = false,\n  isHiddenOnInvisibleTrigger = false,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n  onOverflowViewport,\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const [isHidden, setIsHidden] = useState(false); // css visibilty hidden\n  const tooltipRef = useRef(null);\n  const isOverflowCallbackCalledRef = useRef(false);\n  const document = useDocument();\n  const window = useWindow();\n\n  const arrowSize = useMemo(() => {\n    if (hideArrow) {\n      return 0;\n    }\n    return subTheme ? ARROW_SIZE : ARROW_SIZE_BIG;\n  }, [subTheme, hideArrow]);\n\n  const handleViewportOverflow = useCallback<\n    TooltipContentProps[\"onOverflowViewport\"]\n  >(\n    (triggerRect, tooltipRect, viewportHeight) => {\n      if (!isOverflowCallbackCalledRef.current) {\n        onOverflowViewport?.(triggerRect, tooltipRect, viewportHeight);\n        isOverflowCallbackCalledRef.current = true;\n      }\n    },\n    [onOverflowViewport, isOverflowCallbackCalledRef]\n  );\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle({\n          placement,\n          defaultVerticalPlacement,\n          triggerRef,\n          tooltipRef,\n          document,\n          window,\n          arrowSize,\n          onOverflowViewport: handleViewportOverflow,\n        })\n      );\n    }\n  }, [\n    triggerRef,\n    tooltipRef,\n    document,\n    window,\n    placement,\n    arrowSize,\n    defaultVerticalPlacement,\n    handleViewportOverflow,\n  ]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content, maxWidth]);\n\n  useEffect(() => {\n    if (isVisible && tooltipRef.current) {\n      window.addEventListener(\"resize\", calculateStyle);\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      window.removeEventListener(\"resize\", calculateStyle);\n    };\n  }, [isVisible, calculateStyle, window, tooltipRef]);\n\n  // Observe tooltip element size changes to recalculate positioning\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      isVisible &&\n      tooltipRef.current &&\n      typeof ResizeObserver !== \"undefined\"\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach((entry) => {\n          if (entry.contentRect.width > 0 && entry.contentRect.height > 0) {\n            calculateStyle();\n          }\n        });\n      });\n\n      resizeObserver.observe(tooltipRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [isVisible, calculateStyle, tooltipRef]);\n\n  // Recalculate position when the trigger moves without emitting scroll/resize\n  // events (e.g. CSS transforms, canvas zoom/pan).\n  useEffect(() => {\n    if (!isVisible) return undefined;\n\n    let requestAnimationFrameId: number;\n    let prevRect: DOMRect | undefined;\n\n    const recalculatePosition = () => {\n      const nextRect = triggerRef.current?.getBoundingClientRect();\n      if (\n        prevRect &&\n        nextRect &&\n        (prevRect.x !== nextRect.x ||\n          prevRect.y !== nextRect.y ||\n          prevRect.width !== nextRect.width ||\n          prevRect.height !== nextRect.height)\n      ) {\n        calculateStyle();\n      }\n      prevRect = nextRect;\n      requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    };\n\n    requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    return () => cancelAnimationFrame(requestAnimationFrameId);\n  }, [isVisible, calculateStyle, triggerRef]);\n\n  useEffect(() => {\n    isOverflowCallbackCalledRef.current = false;\n  }, [isVisible, isOverflowCallbackCalledRef]);\n\n  /* Hide (visibility: hidden) tooltip if trigger is scrolled out of view */\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      isHiddenOnInvisibleTrigger &&\n      triggerRef.current &&\n      isVisible &&\n      typeof IntersectionObserver !== \"undefined\"\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            const rect = entry.boundingClientRect;\n\n            // Ignore intersection changes when element has zero dimensions\n            // This can happen during DOM updates/portal rendering\n            if (rect?.width === 0 && rect?.height === 0) {\n              return;\n            }\n\n            setIsHidden(!entry.isIntersecting);\n          }),\n        {\n          root: null, // viewport\n          threshold: INTERSECTION_THRESHOLD,\n        }\n      );\n\n      observer.observe(triggerRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [triggerRef, isVisible, isHiddenOnInvisibleTrigger]);\n\n  if (!isVisible) return null;\n\n  const tooltipElm = (\n    <StyledContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id={dataDSId}\n      style={{\n        top: style.top,\n        left: style.left,\n        animationDuration: getAnimationDuration(),\n      }}\n      ref={tooltipRef}\n      id={tooltipId}\n      role={role}\n      aria-hidden={ariaHidden}\n      subTheme={subTheme}\n      tabIndex={tabIndex}\n      horizontalPlacement={style.horizontalPlacement}\n      verticalPlacement={style.verticalPlacement}\n      maxWidth={maxWidth}\n      contentPadding={contentPadding}\n      isHidden={isHidden}\n      onPointerEnter={onTooltipPointerEnter}\n      onPointerLeave={onTooltipPointerLeave}\n    >\n      {content}\n      {!hideArrow && (\n        <StyledArrow\n          data-e2e-test-id={`${dataE2eTestId}_arrow`}\n          subTheme={subTheme}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          size={arrowSize}\n        />\n      )}\n    </StyledContainer>\n  );\n\n  const wrapperElm = subTheme ? (\n    <SubThemeProvider name={subTheme}>{tooltipElm}</SubThemeProvider>\n  ) : (\n    tooltipElm\n  );\n\n  return <Portal portalContainer={portalContainer}>{wrapperElm}</Portal>;\n}\n"],"names":[],"mappings":"AAiLoB"} */"),initialStyle={top:0,left:0,verticalPlacement:"top",horizontalPlacement:"center"},lastTooltipHideTimestamp=0;export function TooltipContent({placement="auto",content,tooltipId,triggerRef,portalContainer,dataE2eTestId,dataDSId,isVisible,"aria-hidden":ariaHidden,role,tabIndex,contentPadding,maxWidth=224,subTheme,defaultVerticalPlacement,hideArrow=!1,isHiddenOnInvisibleTrigger=!1,onTooltipPointerEnter,onTooltipPointerLeave,onOverflowViewport}){let animationDuration,[style,setStyle]=useState(initialStyle),[isHidden,setIsHidden]=useState(!1),tooltipRef=useRef(null),isOverflowCallbackCalledRef=useRef(!1),document=useDocument(),window=useWindow(),arrowSize=useMemo(()=>hideArrow?0:subTheme?ARROW_SIZE:ARROW_SIZE_BIG,[subTheme,hideArrow]),handleViewportOverflow=useCallback((triggerRect,tooltipRect,viewportHeight)=>{isOverflowCallbackCalledRef.current||(onOverflowViewport?.(triggerRect,tooltipRect,viewportHeight),isOverflowCallbackCalledRef.current=!0)},[onOverflowViewport,isOverflowCallbackCalledRef]),calculateStyle=useCallback(()=>{triggerRef.current&&tooltipRef.current&&setStyle(getTooltipStyle({placement,defaultVerticalPlacement,triggerRef,tooltipRef,document,window,arrowSize,onOverflowViewport:handleViewportOverflow}))},[triggerRef,tooltipRef,document,window,placement,arrowSize,defaultVerticalPlacement,handleViewportOverflow]);if(useLayoutEffect(()=>{isVisible&&calculateStyle()},[isVisible,calculateStyle,contentPadding,content,maxWidth]),useEffect(()=>(isVisible&&tooltipRef.current?window.addEventListener("resize",calculateStyle):isVisible||(lastTooltipHideTimestamp=Date.now()),()=>{window.removeEventListener("resize",calculateStyle)}),[isVisible,calculateStyle,window,tooltipRef]),useEffect(()=>{let resizeObserver;return isVisible&&tooltipRef.current&&"undefined"!=typeof ResizeObserver&&(resizeObserver=new ResizeObserver(entries=>{entries.forEach(entry=>{entry.contentRect.width>0&&entry.contentRect.height>0&&calculateStyle()})})).observe(tooltipRef.current),()=>{resizeObserver&&resizeObserver.disconnect()}},[isVisible,calculateStyle,tooltipRef]),useEffect(()=>{let requestAnimationFrameId,prevRect;if(!isVisible)return;let recalculatePosition=()=>{let nextRect=triggerRef.current?.getBoundingClientRect();prevRect&&nextRect&&(prevRect.x!==nextRect.x||prevRect.y!==nextRect.y||prevRect.width!==nextRect.width||prevRect.height!==nextRect.height)&&calculateStyle(),prevRect=nextRect,requestAnimationFrameId=requestAnimationFrame(recalculatePosition)};return requestAnimationFrameId=requestAnimationFrame(recalculatePosition),()=>cancelAnimationFrame(requestAnimationFrameId)},[isVisible,calculateStyle,triggerRef]),useEffect(()=>{isOverflowCallbackCalledRef.current=!1},[isVisible,isOverflowCallbackCalledRef]),useEffect(()=>{let observer;return isHiddenOnInvisibleTrigger&&triggerRef.current&&isVisible&&"undefined"!=typeof IntersectionObserver&&(observer=new IntersectionObserver(entries=>entries.forEach(entry=>{let rect=entry.boundingClientRect;(rect?.width!==0||rect?.height!==0)&&setIsHidden(!entry.isIntersecting)}),{root:null,threshold:.99})).observe(triggerRef.current),()=>{observer&&observer.disconnect()}},[triggerRef,isVisible,isHiddenOnInvisibleTrigger]),!isVisible)return null;let tooltipElm=React.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDSId,style:{top:style.top,left:style.left,animationDuration:(animationDuration="200ms",lastTooltipHideTimestamp&&Date.now()-lastTooltipHideTimestamp<700&&(animationDuration="0ms"),animationDuration)},ref:tooltipRef,id:tooltipId,role:role,"aria-hidden":ariaHidden,subTheme:subTheme,tabIndex:tabIndex,horizontalPlacement:style.horizontalPlacement,verticalPlacement:style.verticalPlacement,maxWidth:maxWidth,contentPadding:contentPadding,isHidden:isHidden,onPointerEnter:onTooltipPointerEnter,onPointerLeave:onTooltipPointerLeave},content,!hideArrow&&React.createElement(StyledArrow,{"data-e2e-test-id":`${dataE2eTestId}_arrow`,subTheme:subTheme,horizontalPlacement:style.horizontalPlacement,verticalPlacement:style.verticalPlacement,size:arrowSize})),wrapperElm=subTheme?React.createElement(SubThemeProvider,{name:subTheme},tooltipElm):tooltipElm;return React.createElement(Portal,{portalContainer:portalContainer},wrapperElm)}
1
+ import React,{useCallback,useEffect,useLayoutEffect,useMemo,useRef,useState}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{useDocument}from"../../shared/useDocument";import{useWindow}from"../../shared/useWindow";import{SubThemeProvider}from"../SubThemeProvider/SubThemeProvider";import{Portal,usePortalChildZIndex}from"../Portal/Portal";import{ANIMATION_DISTANCE,ARROW_SIZE,ARROW_SIZE_BIG,DISTANCE_FROM_TRIGGER,getArrowOffset,getTooltipStyle}from"./utils";let StyledContainer=styled("div",{target:"ef71jkb0",label:"StyledContainer"})(({theme,horizontalPlacement,verticalPlacement,maxWidth,contentPadding,subTheme,isHidden})=>{let animationDistance="top"===verticalPlacement?`${ANIMATION_DISTANCE}px`:`-${ANIMATION_DISTANCE}px`,animation=keyframes({to:{opacity:theme.variables.opacity.visible,transform:"center"===horizontalPlacement?`translate(-50%, ${animationDistance})`:`translateY(${animationDistance})`}}),contentPaddingMap={s:theme.variables.size.spacing.xxs,m:theme.variables.size.spacing.s},invertedSubThemeStyles={padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,...contentPadding&&{padding:contentPaddingMap[contentPadding]}};return{position:"absolute",zIndex:usePortalChildZIndex(theme.variables.zIndex.tooltip),opacity:theme.variables.opacity.hidden,animation:`200ms ease-out forwards ${animation}`,maxWidth,width:"max-content",boxSizing:"border-box",backgroundColor:subTheme?theme.values.color.background.primary.default:theme.values.color.background.elevated.default,borderRadius:subTheme?theme.variables.size.borderRadius.xs:theme.variables.size.borderRadius.s,...isHidden&&{visibility:"hidden"},...!!subTheme&&invertedSubThemeStyles,..."center"===horizontalPlacement&&{transform:"translate(-50%)"},...!subTheme&&{":after":{content:'" "',position:"absolute",top:0,left:0,width:"100%",height:"100%",pointerEvents:"none",borderRadius:"inherit",boxShadow:theme.values.elevation[3]}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tooltip/TooltipContent.tsx","sources":["src/components/Tooltip/TooltipContent.tsx"],"sourcesContent":["import type { AriaAttributes, MutableRefObject, ReactElement } from \"react\";\nimport React, {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport type { Property } from \"csstype\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport type { SubThemeTypes } from \"../../web-tokens/_subThemeType\";\nimport {\n  Portal,\n  usePortalChildZIndex,\n  type PortalProps,\n} from \"../Portal/Portal\";\n\nimport {\n  ANIMATION_DISTANCE,\n  ARROW_SIZE,\n  ARROW_SIZE_BIG,\n  DISTANCE_FROM_TRIGGER,\n  getArrowOffset,\n  getTooltipStyle,\n} from \"./utils\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  role?: string;\n  tabIndex?: number;\n  contentPadding?: \"s\" | \"m\";\n  subTheme?: SubThemeTypes;\n  maxWidth?: Property.MaxWidth | number;\n  defaultVerticalPlacement?: TooltipStyle[\"verticalPlacement\"];\n  hideArrow?: boolean;\n  /** Sets css visibility hidden when trigger is scrolled out of view */\n  isHiddenOnInvisibleTrigger?: boolean;\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n  /** This callback is triggered when content overflows the viewport both above and below trigger. Use this for tracking purposes or re-rendering Popover with a larger maxWidth */\n  onOverflowViewport?: (\n    triggerRect: DOMRect,\n    tooltipRect: DOMRect,\n    viewportHeight: number\n  ) => void;\n} & Pick<PortalProps, \"portalContainer\"> &\n  AriaAttributes;\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\" | \"subTheme\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  isHidden: boolean;\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n// Use 0.99 instead of 1.0 to handle sub-pixel rounding issues\n// that can cause intersectionRatio to report values like 0.99\nconst INTERSECTION_THRESHOLD = 0.99;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    maxWidth,\n    contentPadding,\n    subTheme,\n    isHidden,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: theme.variables.opacity.visible,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    const invertedSubThemeStyles = {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n    };\n\n    const zIndex = usePortalChildZIndex(theme.variables.zIndex.tooltip);\n\n    return {\n      position: \"absolute\",\n      zIndex,\n      opacity: theme.variables.opacity.hidden,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      maxWidth,\n      width: \"max-content\",\n      boxSizing: \"border-box\",\n      backgroundColor: subTheme\n        ? theme.values.color.background.primary.default\n        : theme.values.color.background.elevated.default,\n      borderRadius: subTheme\n        ? theme.variables.size.borderRadius.xs\n        : theme.variables.size.borderRadius.s,\n\n      ...(isHidden && {\n        visibility: \"hidden\",\n      }),\n\n      ...(!!subTheme && invertedSubThemeStyles),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(!subTheme && {\n        \":after\": {\n          content: '\" \"',\n          position: \"absolute\",\n          top: 0,\n          left: 0,\n          width: \"100%\",\n          height: \"100%\",\n          pointerEvents: \"none\",\n          borderRadius: \"inherit\",\n          boxShadow: theme.values.elevation[3],\n        },\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = Pick<TooltipContentProps, \"subTheme\"> & {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  size?: 0 | typeof ARROW_SIZE | typeof ARROW_SIZE_BIG;\n};\n\n// This container is large enough to contain the arrow shadow blur\nconst ARROW_CONTAINER_WIDTH = 40;\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({\n    theme,\n    subTheme,\n    verticalPlacement,\n    horizontalPlacement,\n    size = ARROW_SIZE,\n  }) => {\n    const offset = getArrowOffset(size);\n    const adjustmentForShadow = subTheme ? 0 : 1;\n    const arrowContainerHeight = size + DISTANCE_FROM_TRIGGER;\n    // Get arrow width and height using pythogoras theorem and add 1 to height to account for dark mode shadow.\n    const arrowSideLength = Math.sqrt(\n      size ** 2 + (size + adjustmentForShadow) ** 2\n    );\n\n    return {\n      position: \"absolute\",\n      width: ARROW_CONTAINER_WIDTH,\n      height: arrowContainerHeight,\n      zIndex: 1,\n      overflow: \"hidden\",\n\n      ...(verticalPlacement === \"top\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `calc(100% - ${adjustmentForShadow}px)`,\n      }),\n\n      ...(verticalPlacement === \"bottom\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `-${arrowContainerHeight - adjustmentForShadow}px`,\n      }),\n\n      ...(horizontalPlacement === \"center\" && {\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(horizontalPlacement === \"right\" && {\n        left: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      ...(horizontalPlacement === \"left\" && {\n        right: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      \"&::after\": {\n        content: '\" \"',\n        position: \"absolute\",\n        top: verticalPlacement === \"top\" ? 0 : \"100%\",\n        left: \"50%\",\n        width: arrowSideLength,\n        height: arrowSideLength,\n        backgroundColor: subTheme\n          ? theme.values.color.background.primary.default\n          : theme.values.color.background.elevated.default,\n        transform: \"translate(-50%, -50%) rotate(45deg)\",\n\n        ...(!subTheme && {\n          boxShadow: theme.values.elevation[3],\n        }),\n      },\n    };\n  }\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  subTheme,\n  defaultVerticalPlacement,\n  hideArrow = false,\n  isHiddenOnInvisibleTrigger = false,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n  onOverflowViewport,\n  ...ariaAttributes\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const [isHidden, setIsHidden] = useState(false); // css visibilty hidden\n  const tooltipRef = useRef(null);\n  const isOverflowCallbackCalledRef = useRef(false);\n  const document = useDocument();\n  const window = useWindow();\n\n  const arrowSize = useMemo(() => {\n    if (hideArrow) {\n      return 0;\n    }\n    return subTheme ? ARROW_SIZE : ARROW_SIZE_BIG;\n  }, [subTheme, hideArrow]);\n\n  const handleViewportOverflow = useCallback<\n    TooltipContentProps[\"onOverflowViewport\"]\n  >(\n    (triggerRect, tooltipRect, viewportHeight) => {\n      if (!isOverflowCallbackCalledRef.current) {\n        onOverflowViewport?.(triggerRect, tooltipRect, viewportHeight);\n        isOverflowCallbackCalledRef.current = true;\n      }\n    },\n    [onOverflowViewport, isOverflowCallbackCalledRef]\n  );\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle({\n          placement,\n          defaultVerticalPlacement,\n          triggerRef,\n          tooltipRef,\n          document,\n          window,\n          arrowSize,\n          onOverflowViewport: handleViewportOverflow,\n        })\n      );\n    }\n  }, [\n    triggerRef,\n    tooltipRef,\n    document,\n    window,\n    placement,\n    arrowSize,\n    defaultVerticalPlacement,\n    handleViewportOverflow,\n  ]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content, maxWidth]);\n\n  useEffect(() => {\n    if (isVisible && tooltipRef.current) {\n      window.addEventListener(\"resize\", calculateStyle);\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      window.removeEventListener(\"resize\", calculateStyle);\n    };\n  }, [isVisible, calculateStyle, window, tooltipRef]);\n\n  // Observe tooltip element size changes to recalculate positioning\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      isVisible &&\n      tooltipRef.current &&\n      typeof ResizeObserver !== \"undefined\"\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach((entry) => {\n          if (entry.contentRect.width > 0 && entry.contentRect.height > 0) {\n            calculateStyle();\n          }\n        });\n      });\n\n      resizeObserver.observe(tooltipRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [isVisible, calculateStyle, tooltipRef]);\n\n  // Recalculate position when the trigger moves without emitting scroll/resize\n  // events (e.g. CSS transforms, canvas zoom/pan).\n  useEffect(() => {\n    if (!isVisible) return undefined;\n\n    let requestAnimationFrameId: number;\n    let prevRect: DOMRect | undefined;\n\n    const recalculatePosition = () => {\n      const nextRect = triggerRef.current?.getBoundingClientRect();\n      if (\n        prevRect &&\n        nextRect &&\n        (prevRect.x !== nextRect.x ||\n          prevRect.y !== nextRect.y ||\n          prevRect.width !== nextRect.width ||\n          prevRect.height !== nextRect.height)\n      ) {\n        calculateStyle();\n      }\n      prevRect = nextRect;\n      requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    };\n\n    requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    return () => cancelAnimationFrame(requestAnimationFrameId);\n  }, [isVisible, calculateStyle, triggerRef]);\n\n  useEffect(() => {\n    isOverflowCallbackCalledRef.current = false;\n  }, [isVisible, isOverflowCallbackCalledRef]);\n\n  /* Hide (visibility: hidden) tooltip if trigger is scrolled out of view */\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      isHiddenOnInvisibleTrigger &&\n      triggerRef.current &&\n      isVisible &&\n      typeof IntersectionObserver !== \"undefined\"\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            const rect = entry.boundingClientRect;\n\n            // Ignore intersection changes when element has zero dimensions\n            // This can happen during DOM updates/portal rendering\n            if (rect?.width === 0 && rect?.height === 0) {\n              return;\n            }\n\n            setIsHidden(!entry.isIntersecting);\n          }),\n        {\n          root: null, // viewport\n          threshold: INTERSECTION_THRESHOLD,\n        }\n      );\n\n      observer.observe(triggerRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [triggerRef, isVisible, isHiddenOnInvisibleTrigger]);\n\n  if (!isVisible) return null;\n\n  const tooltipElm = (\n    <StyledContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id={dataDSId}\n      style={{\n        top: style.top,\n        left: style.left,\n        animationDuration: getAnimationDuration(),\n      }}\n      ref={tooltipRef}\n      id={tooltipId}\n      role={role}\n      {...ariaAttributes}\n      aria-hidden={ariaHidden}\n      subTheme={subTheme}\n      tabIndex={tabIndex}\n      horizontalPlacement={style.horizontalPlacement}\n      verticalPlacement={style.verticalPlacement}\n      maxWidth={maxWidth}\n      contentPadding={contentPadding}\n      isHidden={isHidden}\n      onPointerEnter={onTooltipPointerEnter}\n      onPointerLeave={onTooltipPointerLeave}\n    >\n      {content}\n      {!hideArrow && (\n        <StyledArrow\n          data-e2e-test-id={`${dataE2eTestId}_arrow`}\n          subTheme={subTheme}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          size={arrowSize}\n        />\n      )}\n    </StyledContainer>\n  );\n\n  const wrapperElm = subTheme ? (\n    <SubThemeProvider name={subTheme}>{tooltipElm}</SubThemeProvider>\n  ) : (\n    tooltipElm\n  );\n\n  return <Portal portalContainer={portalContainer}>{wrapperElm}</Portal>;\n}\n"],"names":[],"mappings":"AAyFwB"} */"),StyledArrow=styled("div",{target:"ef71jkb1",label:"StyledArrow"})(({theme,subTheme,verticalPlacement,horizontalPlacement,size=ARROW_SIZE})=>{let offset=getArrowOffset(size),adjustmentForShadow=+!subTheme,arrowContainerHeight=size+DISTANCE_FROM_TRIGGER,arrowSideLength=Math.sqrt(size**2+(size+adjustmentForShadow)**2);return{position:"absolute",width:40,height:arrowContainerHeight,zIndex:1,overflow:"hidden",..."top"===verticalPlacement&&{top:`calc(100% - ${adjustmentForShadow}px)`},..."bottom"===verticalPlacement&&{top:`-${arrowContainerHeight-adjustmentForShadow}px`},..."center"===horizontalPlacement&&{left:"50%",transform:"translate(-50%)"},..."right"===horizontalPlacement&&{left:`${offset-(20-size)}px`},..."left"===horizontalPlacement&&{right:`${offset-(20-size)}px`},"&::after":{content:'" "',position:"absolute",top:"top"===verticalPlacement?0:"100%",left:"50%",width:arrowSideLength,height:arrowSideLength,backgroundColor:subTheme?theme.values.color.background.primary.default:theme.values.color.background.elevated.default,transform:"translate(-50%, -50%) rotate(45deg)",...!subTheme&&{boxShadow:theme.values.elevation[3]}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Tooltip/TooltipContent.tsx","sources":["src/components/Tooltip/TooltipContent.tsx"],"sourcesContent":["import type { AriaAttributes, MutableRefObject, ReactElement } from \"react\";\nimport React, {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport type { Property } from \"csstype\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport type { SubThemeTypes } from \"../../web-tokens/_subThemeType\";\nimport {\n  Portal,\n  usePortalChildZIndex,\n  type PortalProps,\n} from \"../Portal/Portal\";\n\nimport {\n  ANIMATION_DISTANCE,\n  ARROW_SIZE,\n  ARROW_SIZE_BIG,\n  DISTANCE_FROM_TRIGGER,\n  getArrowOffset,\n  getTooltipStyle,\n} from \"./utils\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  role?: string;\n  tabIndex?: number;\n  contentPadding?: \"s\" | \"m\";\n  subTheme?: SubThemeTypes;\n  maxWidth?: Property.MaxWidth | number;\n  defaultVerticalPlacement?: TooltipStyle[\"verticalPlacement\"];\n  hideArrow?: boolean;\n  /** Sets css visibility hidden when trigger is scrolled out of view */\n  isHiddenOnInvisibleTrigger?: boolean;\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n  /** This callback is triggered when content overflows the viewport both above and below trigger. Use this for tracking purposes or re-rendering Popover with a larger maxWidth */\n  onOverflowViewport?: (\n    triggerRect: DOMRect,\n    tooltipRect: DOMRect,\n    viewportHeight: number\n  ) => void;\n} & Pick<PortalProps, \"portalContainer\"> &\n  AriaAttributes;\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\" | \"subTheme\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  isHidden: boolean;\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n// Use 0.99 instead of 1.0 to handle sub-pixel rounding issues\n// that can cause intersectionRatio to report values like 0.99\nconst INTERSECTION_THRESHOLD = 0.99;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    maxWidth,\n    contentPadding,\n    subTheme,\n    isHidden,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: theme.variables.opacity.visible,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    const invertedSubThemeStyles = {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n    };\n\n    const zIndex = usePortalChildZIndex(theme.variables.zIndex.tooltip);\n\n    return {\n      position: \"absolute\",\n      zIndex,\n      opacity: theme.variables.opacity.hidden,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      maxWidth,\n      width: \"max-content\",\n      boxSizing: \"border-box\",\n      backgroundColor: subTheme\n        ? theme.values.color.background.primary.default\n        : theme.values.color.background.elevated.default,\n      borderRadius: subTheme\n        ? theme.variables.size.borderRadius.xs\n        : theme.variables.size.borderRadius.s,\n\n      ...(isHidden && {\n        visibility: \"hidden\",\n      }),\n\n      ...(!!subTheme && invertedSubThemeStyles),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(!subTheme && {\n        \":after\": {\n          content: '\" \"',\n          position: \"absolute\",\n          top: 0,\n          left: 0,\n          width: \"100%\",\n          height: \"100%\",\n          pointerEvents: \"none\",\n          borderRadius: \"inherit\",\n          boxShadow: theme.values.elevation[3],\n        },\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = Pick<TooltipContentProps, \"subTheme\"> & {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  size?: 0 | typeof ARROW_SIZE | typeof ARROW_SIZE_BIG;\n};\n\n// This container is large enough to contain the arrow shadow blur\nconst ARROW_CONTAINER_WIDTH = 40;\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({\n    theme,\n    subTheme,\n    verticalPlacement,\n    horizontalPlacement,\n    size = ARROW_SIZE,\n  }) => {\n    const offset = getArrowOffset(size);\n    const adjustmentForShadow = subTheme ? 0 : 1;\n    const arrowContainerHeight = size + DISTANCE_FROM_TRIGGER;\n    // Get arrow width and height using pythogoras theorem and add 1 to height to account for dark mode shadow.\n    const arrowSideLength = Math.sqrt(\n      size ** 2 + (size + adjustmentForShadow) ** 2\n    );\n\n    return {\n      position: \"absolute\",\n      width: ARROW_CONTAINER_WIDTH,\n      height: arrowContainerHeight,\n      zIndex: 1,\n      overflow: \"hidden\",\n\n      ...(verticalPlacement === \"top\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `calc(100% - ${adjustmentForShadow}px)`,\n      }),\n\n      ...(verticalPlacement === \"bottom\" && {\n        // place the arrow container 1px inside tooltip container to account for dark mode box-shadow\n        top: `-${arrowContainerHeight - adjustmentForShadow}px`,\n      }),\n\n      ...(horizontalPlacement === \"center\" && {\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(horizontalPlacement === \"right\" && {\n        left: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      ...(horizontalPlacement === \"left\" && {\n        right: `${offset - (ARROW_CONTAINER_WIDTH / 2 - size)}px`,\n      }),\n\n      \"&::after\": {\n        content: '\" \"',\n        position: \"absolute\",\n        top: verticalPlacement === \"top\" ? 0 : \"100%\",\n        left: \"50%\",\n        width: arrowSideLength,\n        height: arrowSideLength,\n        backgroundColor: subTheme\n          ? theme.values.color.background.primary.default\n          : theme.values.color.background.elevated.default,\n        transform: \"translate(-50%, -50%) rotate(45deg)\",\n\n        ...(!subTheme && {\n          boxShadow: theme.values.elevation[3],\n        }),\n      },\n    };\n  }\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  subTheme,\n  defaultVerticalPlacement,\n  hideArrow = false,\n  isHiddenOnInvisibleTrigger = false,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n  onOverflowViewport,\n  ...ariaAttributes\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const [isHidden, setIsHidden] = useState(false); // css visibilty hidden\n  const tooltipRef = useRef(null);\n  const isOverflowCallbackCalledRef = useRef(false);\n  const document = useDocument();\n  const window = useWindow();\n\n  const arrowSize = useMemo(() => {\n    if (hideArrow) {\n      return 0;\n    }\n    return subTheme ? ARROW_SIZE : ARROW_SIZE_BIG;\n  }, [subTheme, hideArrow]);\n\n  const handleViewportOverflow = useCallback<\n    TooltipContentProps[\"onOverflowViewport\"]\n  >(\n    (triggerRect, tooltipRect, viewportHeight) => {\n      if (!isOverflowCallbackCalledRef.current) {\n        onOverflowViewport?.(triggerRect, tooltipRect, viewportHeight);\n        isOverflowCallbackCalledRef.current = true;\n      }\n    },\n    [onOverflowViewport, isOverflowCallbackCalledRef]\n  );\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle({\n          placement,\n          defaultVerticalPlacement,\n          triggerRef,\n          tooltipRef,\n          document,\n          window,\n          arrowSize,\n          onOverflowViewport: handleViewportOverflow,\n        })\n      );\n    }\n  }, [\n    triggerRef,\n    tooltipRef,\n    document,\n    window,\n    placement,\n    arrowSize,\n    defaultVerticalPlacement,\n    handleViewportOverflow,\n  ]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content, maxWidth]);\n\n  useEffect(() => {\n    if (isVisible && tooltipRef.current) {\n      window.addEventListener(\"resize\", calculateStyle);\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      window.removeEventListener(\"resize\", calculateStyle);\n    };\n  }, [isVisible, calculateStyle, window, tooltipRef]);\n\n  // Observe tooltip element size changes to recalculate positioning\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      isVisible &&\n      tooltipRef.current &&\n      typeof ResizeObserver !== \"undefined\"\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach((entry) => {\n          if (entry.contentRect.width > 0 && entry.contentRect.height > 0) {\n            calculateStyle();\n          }\n        });\n      });\n\n      resizeObserver.observe(tooltipRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [isVisible, calculateStyle, tooltipRef]);\n\n  // Recalculate position when the trigger moves without emitting scroll/resize\n  // events (e.g. CSS transforms, canvas zoom/pan).\n  useEffect(() => {\n    if (!isVisible) return undefined;\n\n    let requestAnimationFrameId: number;\n    let prevRect: DOMRect | undefined;\n\n    const recalculatePosition = () => {\n      const nextRect = triggerRef.current?.getBoundingClientRect();\n      if (\n        prevRect &&\n        nextRect &&\n        (prevRect.x !== nextRect.x ||\n          prevRect.y !== nextRect.y ||\n          prevRect.width !== nextRect.width ||\n          prevRect.height !== nextRect.height)\n      ) {\n        calculateStyle();\n      }\n      prevRect = nextRect;\n      requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    };\n\n    requestAnimationFrameId = requestAnimationFrame(recalculatePosition);\n    return () => cancelAnimationFrame(requestAnimationFrameId);\n  }, [isVisible, calculateStyle, triggerRef]);\n\n  useEffect(() => {\n    isOverflowCallbackCalledRef.current = false;\n  }, [isVisible, isOverflowCallbackCalledRef]);\n\n  /* Hide (visibility: hidden) tooltip if trigger is scrolled out of view */\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      isHiddenOnInvisibleTrigger &&\n      triggerRef.current &&\n      isVisible &&\n      typeof IntersectionObserver !== \"undefined\"\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            const rect = entry.boundingClientRect;\n\n            // Ignore intersection changes when element has zero dimensions\n            // This can happen during DOM updates/portal rendering\n            if (rect?.width === 0 && rect?.height === 0) {\n              return;\n            }\n\n            setIsHidden(!entry.isIntersecting);\n          }),\n        {\n          root: null, // viewport\n          threshold: INTERSECTION_THRESHOLD,\n        }\n      );\n\n      observer.observe(triggerRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [triggerRef, isVisible, isHiddenOnInvisibleTrigger]);\n\n  if (!isVisible) return null;\n\n  const tooltipElm = (\n    <StyledContainer\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id={dataDSId}\n      style={{\n        top: style.top,\n        left: style.left,\n        animationDuration: getAnimationDuration(),\n      }}\n      ref={tooltipRef}\n      id={tooltipId}\n      role={role}\n      {...ariaAttributes}\n      aria-hidden={ariaHidden}\n      subTheme={subTheme}\n      tabIndex={tabIndex}\n      horizontalPlacement={style.horizontalPlacement}\n      verticalPlacement={style.verticalPlacement}\n      maxWidth={maxWidth}\n      contentPadding={contentPadding}\n      isHidden={isHidden}\n      onPointerEnter={onTooltipPointerEnter}\n      onPointerLeave={onTooltipPointerLeave}\n    >\n      {content}\n      {!hideArrow && (\n        <StyledArrow\n          data-e2e-test-id={`${dataE2eTestId}_arrow`}\n          subTheme={subTheme}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          size={arrowSize}\n        />\n      )}\n    </StyledContainer>\n  );\n\n  const wrapperElm = subTheme ? (\n    <SubThemeProvider name={subTheme}>{tooltipElm}</SubThemeProvider>\n  ) : (\n    tooltipElm\n  );\n\n  return <Portal portalContainer={portalContainer}>{wrapperElm}</Portal>;\n}\n"],"names":[],"mappings":"AAiLoB"} */"),initialStyle={top:0,left:0,verticalPlacement:"top",horizontalPlacement:"center"},lastTooltipHideTimestamp=0;export function TooltipContent({placement="auto",content,tooltipId,triggerRef,portalContainer,dataE2eTestId,dataDSId,isVisible,"aria-hidden":ariaHidden,role,tabIndex,contentPadding,maxWidth=224,subTheme,defaultVerticalPlacement,hideArrow=!1,isHiddenOnInvisibleTrigger=!1,onTooltipPointerEnter,onTooltipPointerLeave,onOverflowViewport,...ariaAttributes}){let animationDuration,[style,setStyle]=useState(initialStyle),[isHidden,setIsHidden]=useState(!1),tooltipRef=useRef(null),isOverflowCallbackCalledRef=useRef(!1),document=useDocument(),window=useWindow(),arrowSize=useMemo(()=>hideArrow?0:subTheme?ARROW_SIZE:ARROW_SIZE_BIG,[subTheme,hideArrow]),handleViewportOverflow=useCallback((triggerRect,tooltipRect,viewportHeight)=>{isOverflowCallbackCalledRef.current||(onOverflowViewport?.(triggerRect,tooltipRect,viewportHeight),isOverflowCallbackCalledRef.current=!0)},[onOverflowViewport,isOverflowCallbackCalledRef]),calculateStyle=useCallback(()=>{triggerRef.current&&tooltipRef.current&&setStyle(getTooltipStyle({placement,defaultVerticalPlacement,triggerRef,tooltipRef,document,window,arrowSize,onOverflowViewport:handleViewportOverflow}))},[triggerRef,tooltipRef,document,window,placement,arrowSize,defaultVerticalPlacement,handleViewportOverflow]);if(useLayoutEffect(()=>{isVisible&&calculateStyle()},[isVisible,calculateStyle,contentPadding,content,maxWidth]),useEffect(()=>(isVisible&&tooltipRef.current?window.addEventListener("resize",calculateStyle):isVisible||(lastTooltipHideTimestamp=Date.now()),()=>{window.removeEventListener("resize",calculateStyle)}),[isVisible,calculateStyle,window,tooltipRef]),useEffect(()=>{let resizeObserver;return isVisible&&tooltipRef.current&&"undefined"!=typeof ResizeObserver&&(resizeObserver=new ResizeObserver(entries=>{entries.forEach(entry=>{entry.contentRect.width>0&&entry.contentRect.height>0&&calculateStyle()})})).observe(tooltipRef.current),()=>{resizeObserver&&resizeObserver.disconnect()}},[isVisible,calculateStyle,tooltipRef]),useEffect(()=>{let requestAnimationFrameId,prevRect;if(!isVisible)return;let recalculatePosition=()=>{let nextRect=triggerRef.current?.getBoundingClientRect();prevRect&&nextRect&&(prevRect.x!==nextRect.x||prevRect.y!==nextRect.y||prevRect.width!==nextRect.width||prevRect.height!==nextRect.height)&&calculateStyle(),prevRect=nextRect,requestAnimationFrameId=requestAnimationFrame(recalculatePosition)};return requestAnimationFrameId=requestAnimationFrame(recalculatePosition),()=>cancelAnimationFrame(requestAnimationFrameId)},[isVisible,calculateStyle,triggerRef]),useEffect(()=>{isOverflowCallbackCalledRef.current=!1},[isVisible,isOverflowCallbackCalledRef]),useEffect(()=>{let observer;return isHiddenOnInvisibleTrigger&&triggerRef.current&&isVisible&&"undefined"!=typeof IntersectionObserver&&(observer=new IntersectionObserver(entries=>entries.forEach(entry=>{let rect=entry.boundingClientRect;(rect?.width!==0||rect?.height!==0)&&setIsHidden(!entry.isIntersecting)}),{root:null,threshold:.99})).observe(triggerRef.current),()=>{observer&&observer.disconnect()}},[triggerRef,isVisible,isHiddenOnInvisibleTrigger]),!isVisible)return null;let tooltipElm=React.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDSId,style:{top:style.top,left:style.left,animationDuration:(animationDuration="200ms",lastTooltipHideTimestamp&&Date.now()-lastTooltipHideTimestamp<700&&(animationDuration="0ms"),animationDuration)},ref:tooltipRef,id:tooltipId,role:role,...ariaAttributes,"aria-hidden":ariaHidden,subTheme:subTheme,tabIndex:tabIndex,horizontalPlacement:style.horizontalPlacement,verticalPlacement:style.verticalPlacement,maxWidth:maxWidth,contentPadding:contentPadding,isHidden:isHidden,onPointerEnter:onTooltipPointerEnter,onPointerLeave:onTooltipPointerLeave},content,!hideArrow&&React.createElement(StyledArrow,{"data-e2e-test-id":`${dataE2eTestId}_arrow`,subTheme:subTheme,horizontalPlacement:style.horizontalPlacement,verticalPlacement:style.verticalPlacement,size:arrowSize})),wrapperElm=subTheme?React.createElement(SubThemeProvider,{name:subTheme},tooltipElm):tooltipElm;return React.createElement(Portal,{portalContainer:portalContainer},wrapperElm)}
@@ -1 +1 @@
1
- import React,{forwardRef}from"react";import styled from"@emotion/styled";import{Text}from"../Text/Text";let Container=styled("span",{target:"e1ygqhdj0",label:"Container"})(({lines})=>({display:"-webkit-box",WebkitBoxOrient:"vertical",overflow:"hidden",WebkitLineClamp:lines}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVHlwb2dyYXBoeS9UZXh0Q2xhbXBlZC9UZXh0Q2xhbXBlZC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1R5cG9ncmFwaHkvVGV4dENsYW1wZWQvVGV4dENsYW1wZWQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB0eXBlIFJlZk9iamVjdCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFRleHRQcm9wcyB9IGZyb20gXCIuLi9UZXh0L1RleHRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVGV4dC9UZXh0XCI7XG5cbmV4cG9ydCB0eXBlIFRleHRDbGFtcGVkUHJvcHMgPSBUZXh0UHJvcHMgJiB7XG4gIC8qKiBUaGUgbWF4aW11bSBudW1iZXIgb2YgbGluZXMuIERlZmF1bHQgaXMgMS4gKi9cbiAgbGluZXM/OiBudW1iZXI7XG59O1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuc3BhbjxUZXh0Q2xhbXBlZFByb3BzPigoeyBsaW5lcyB9KSA9PiAoe1xuICBkaXNwbGF5OiBcIi13ZWJraXQtYm94XCIsXG4gIFdlYmtpdEJveE9yaWVudDogXCJ2ZXJ0aWNhbFwiLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgV2Via2l0TGluZUNsYW1wOiBsaW5lcyxcbn0pKTtcblxuZXhwb3J0IGNvbnN0IFRleHRDbGFtcGVkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHByb3BzOiBUZXh0Q2xhbXBlZFByb3BzLFxuICAgIHJlZjogUmVmT2JqZWN0PEhUTUxQYXJhZ3JhcGhFbGVtZW50PlxuICApOiBSZWFjdC5SZWFjdEVsZW1lbnQgPT4ge1xuICAgIGNvbnN0IHtcbiAgICAgIGxpbmVzID0gMSxcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gICAgICAuLi50ZXh0UHJvcHNcbiAgICB9ID0gcHJvcHM7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPFRleHRcbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIGRhdGEtZHMtaWQ9XCJUZXh0Q2xhbXBlZFwiXG4gICAgICAgIHsuLi50ZXh0UHJvcHN9XG4gICAgICA+XG4gICAgICAgIDxDb250YWluZXIgbGluZXM9e2xpbmVzfSBzaXplPXt0ZXh0UHJvcHMuc2l6ZX0+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L0NvbnRhaW5lcj5cbiAgICAgIDwvVGV4dD5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVdrQiJ9 */");export const TextClamped=forwardRef((props,ref)=>{let{lines=1,children,"data-e2e-test-id":dataE2eTestId,...textProps}=props;return React.createElement(Text,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"TextClamped",...textProps},React.createElement(Container,{lines:lines,size:textProps.size},children))});
1
+ import React,{forwardRef}from"react";import styled from"@emotion/styled";import{ContentText}from"../../Content/ContentText/ContentText";let Container=styled("span",{target:"e13smycx0",label:"Container"})(({lines})=>({display:"-webkit-box",WebkitBoxOrient:"vertical",overflow:"hidden",WebkitLineClamp:lines}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVHlwb2dyYXBoeS9UZXh0Q2xhbXBlZC9UZXh0Q2xhbXBlZC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1R5cG9ncmFwaHkvVGV4dENsYW1wZWQvVGV4dENsYW1wZWQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB0eXBlIFJlZk9iamVjdCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFRleHRQcm9wcyB9IGZyb20gXCIuLi9UZXh0L1RleHRcIjtcbmltcG9ydCB7IENvbnRlbnRUZXh0IH0gZnJvbSBcIi4uLy4uL0NvbnRlbnQvQ29udGVudFRleHQvQ29udGVudFRleHRcIjtcblxuZXhwb3J0IHR5cGUgVGV4dENsYW1wZWRQcm9wcyA9IFRleHRQcm9wcyAmIHtcbiAgLyoqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBsaW5lcy4gRGVmYXVsdCBpcyAxLiAqL1xuICBsaW5lcz86IG51bWJlcjtcbn07XG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5zcGFuPFRleHRDbGFtcGVkUHJvcHM+KCh7IGxpbmVzIH0pID0+ICh7XG4gIGRpc3BsYXk6IFwiLXdlYmtpdC1ib3hcIixcbiAgV2Via2l0Qm94T3JpZW50OiBcInZlcnRpY2FsXCIsXG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICBXZWJraXRMaW5lQ2xhbXA6IGxpbmVzLFxufSkpO1xuXG5leHBvcnQgY29uc3QgVGV4dENsYW1wZWQgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAgcHJvcHM6IFRleHRDbGFtcGVkUHJvcHMsXG4gICAgcmVmOiBSZWZPYmplY3Q8SFRNTFBhcmFncmFwaEVsZW1lbnQ+XG4gICk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiB7XG4gICAgY29uc3Qge1xuICAgICAgbGluZXMgPSAxLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgICAgIC4uLnRleHRQcm9wc1xuICAgIH0gPSBwcm9wcztcblxuICAgIHJldHVybiAoXG4gICAgICA8Q29udGVudFRleHRcbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIGRhdGEtZHMtaWQ9XCJUZXh0Q2xhbXBlZFwiXG4gICAgICAgIHsuLi50ZXh0UHJvcHN9XG4gICAgICA+XG4gICAgICAgIDxDb250YWluZXIgbGluZXM9e2xpbmVzfSBzaXplPXt0ZXh0UHJvcHMuc2l6ZX0+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L0NvbnRhaW5lcj5cbiAgICAgIDwvQ29udGVudFRleHQ+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXa0IifQ== */");export const TextClamped=forwardRef((props,ref)=>{let{lines=1,children,"data-e2e-test-id":dataE2eTestId,...textProps}=props;return React.createElement(ContentText,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"TextClamped",...textProps},React.createElement(Container,{lines:lines,size:textProps.size},children))});
@@ -93,6 +93,7 @@ export * from "./components/Utilities/ContainerQuery/ContainerQuery";
93
93
  export * from "./components/Utilities/Expandable/Expandable";
94
94
  export * from "./components/Utilities/ScreenReaderText/ScreenReaderText";
95
95
  export * from "./components/Patterns/EmptyState/EmptyState";
96
+ export * from "./components/Content/ContentBox/ContentBox";
96
97
  export * from "./components/Content/ContentFontResizer";
97
98
  export * from "./components/Content/ContentHeading/ContentHeading";
98
99
  export * from "./components/Content/ContentLink/ContentLink";
@@ -1 +1 @@
1
- import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Avatar/Avatar";export*from"./components/AvatarGroup/AvatarGroup";export*from"./components/Badge/Badge";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Box/Box";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Button/Button";export*from"./components/Callout/Callout";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/CatalogCard/CatalogCard";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/Collapsible/Collapsible";export*from"./components/ColorIndicator/ColorIndicator";export*from"./components/ColorPicker/ColorPicker";export*from"./components/Column/Columns";export*from"./components/Container";export*from"./components/CountButton/CountButton";export*from"./components/DataTable";export*from"./components/Divider/Divider";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/EntityList";export*from"./components/EntityTree";export*from"./components/Composite/FilterDialog/FilterDialog";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Combobox/Combobox";export*from"./components/Form/DateInput/DateInput";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Form/PasswordInput";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Form/Select";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/Grid/Grid";export*from"./components/Icon/Icon";export*from"./components/IconTile/IconTile";export*from"./components/Image/Image";export*from"./components/Inline/Inline";export*from"./components/InteractiveBox/InteractiveBox";export*from"./components/Lightbox/Lightbox";export*from"./components/Link/Link";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/NavBar";export*from"./components/Notification/Notification";export*from"./components/Pagination/Pagination";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Patterns/Modal/Modal";export*from"./components/PictogramButton/PictogramButton";export*from"./components/Popover/Popover";export*from"./components/ProgressBar/ProgressBar";export*from"./components/PromptInput/PromptInput";export*from"./components/SplashCard/SplashCard";export*from"./components/QBankRichText/QBankRichText";export*from"./components/RadioCard/RadioCard";export*from"./components/RoundButton/RoundButton";export*from"./components/SearchResult/SearchResult";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/Sheet/Sheet";export*from"./components/Stack/Stack";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/Tabs/Tabs";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toast";export*from"./components/Toggletip/Toggletip";export*from"./components/Tooltip/Tooltip";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/Typography/Header";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Utilities/AnimatedBorder/AnimatedBorder";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/Patterns/EmptyState/EmptyState";export*from"./components/Content/ContentFontResizer";export*from"./components/Content/ContentHeading/ContentHeading";export*from"./components/Content/ContentLink/ContentLink";export*from"./components/Content/ContentText/ContentText";export*from"./components/Content/ContentList";export*from"./components/Content/ContentTable";
1
+ import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Avatar/Avatar";export*from"./components/AvatarGroup/AvatarGroup";export*from"./components/Badge/Badge";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Box/Box";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Button/Button";export*from"./components/Callout/Callout";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/CatalogCard/CatalogCard";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/Collapsible/Collapsible";export*from"./components/ColorIndicator/ColorIndicator";export*from"./components/ColorPicker/ColorPicker";export*from"./components/Column/Columns";export*from"./components/Container";export*from"./components/CountButton/CountButton";export*from"./components/DataTable";export*from"./components/Divider/Divider";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/EntityList";export*from"./components/EntityTree";export*from"./components/Composite/FilterDialog/FilterDialog";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Combobox/Combobox";export*from"./components/Form/DateInput/DateInput";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Form/PasswordInput";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Form/Select";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/Grid/Grid";export*from"./components/Icon/Icon";export*from"./components/IconTile/IconTile";export*from"./components/Image/Image";export*from"./components/Inline/Inline";export*from"./components/InteractiveBox/InteractiveBox";export*from"./components/Lightbox/Lightbox";export*from"./components/Link/Link";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/NavBar";export*from"./components/Notification/Notification";export*from"./components/Pagination/Pagination";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Patterns/Modal/Modal";export*from"./components/PictogramButton/PictogramButton";export*from"./components/Popover/Popover";export*from"./components/ProgressBar/ProgressBar";export*from"./components/PromptInput/PromptInput";export*from"./components/SplashCard/SplashCard";export*from"./components/QBankRichText/QBankRichText";export*from"./components/RadioCard/RadioCard";export*from"./components/RoundButton/RoundButton";export*from"./components/SearchResult/SearchResult";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/Sheet/Sheet";export*from"./components/Stack/Stack";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/Tabs/Tabs";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toast";export*from"./components/Toggletip/Toggletip";export*from"./components/Tooltip/Tooltip";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/Typography/Header";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Utilities/AnimatedBorder/AnimatedBorder";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/Patterns/EmptyState/EmptyState";export*from"./components/Content/ContentBox/ContentBox";export*from"./components/Content/ContentFontResizer";export*from"./components/Content/ContentHeading/ContentHeading";export*from"./components/Content/ContentLink/ContentLink";export*from"./components/Content/ContentText/ContentText";export*from"./components/Content/ContentList";export*from"./components/Content/ContentTable";
@@ -145,8 +145,8 @@
145
145
  "minus": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"bevel\" stroke-width=\"2\" d=\"M4 8h8\"/></svg>",
146
146
  "monitor": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path fill-rule=\"evenodd\" d=\"M13.67 1A2.33 2.33 0 0 1 16 3.33v6.34A2.33 2.33 0 0 1 13.67 12H9v1h1.666a1 1 0 1 1 0 2H5.333a1 1 0 0 1 0-2H7v-1H2.33A2.33 2.33 0 0 1 0 9.67V3.33A2.33 2.33 0 0 1 2.33 1zM2.33 3a.33.33 0 0 0-.33.33v6.34c0 .182.148.33.33.33h11.34a.33.33 0 0 0 .33-.33V3.33a.33.33 0 0 0-.33-.33z\" clip-rule=\"evenodd\"/></svg>",
147
147
  "moon": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path d=\"M7.38 1.004a1.001 1.001 0 0 1 .897 1.59 3.666 3.666 0 0 0 5.128 5.129 1 1 0 0 1 1.591.896 7 7 0 1 1-7.615-7.615M5.693 3.552a5 5 0 0 0 2.18 9.42 5 5 0 0 0 4.575-2.665 5.666 5.666 0 0 1-6.755-6.755\"/></svg>",
148
- "more-horizontal": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" d=\"M4 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2m4 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2m4 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2\"/></svg>",
149
- "more-vertical": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" d=\"M8 5a1 1 0 1 0 0-2 1 1 0 0 0 0 2m0 4a1 1 0 1 0 0-2 1 1 0 0 0 0 2m0 4a1 1 0 1 0 0-2 1 1 0 0 0 0 2\"/></svg>",
148
+ "more-horizontal": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path d=\"M5 9H3V7h2zm4 0H7V7h2zm4 0h-2V7h2z\"/></svg>",
149
+ "more-vertical": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path d=\"M7 5V3h2v2zm0 4V7h2v2zm0 4v-2h2v2z\"/></svg>",
150
150
  "no-fill": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"currentColor\" stroke-width=\"2\"/><path stroke=\"currentColor\" stroke-width=\"2\" d=\"m13.633 3.774-11 9\"/></svg>",
151
151
  "note": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M9 14h6M10.45 3.438a1.494 1.494 0 1 1 2.113 2.112l-7.746 7.746L2 14l.704-2.817z\"/></svg>",
152
152
  "number-1": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path d=\"m7.671 4.847-2.296 2.12L4 5.304 7.736 2H10v12H7.671z\"/></svg>",