@amboss/design-system 2.3.3 → 2.3.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,3 @@
1
+ export * from "./BaseEntityTree";
2
+ export * from "./EntityTree";
3
+ export * from "./types";
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});const _export_star=require("@swc/helpers/_/_export_star");_export_star._(require("./BaseEntityTree"),exports),_export_star._(require("./EntityTree"),exports),_export_star._(require("./types"),exports);
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControl",{enumerable:!0,get:function(){return SegmentedControl}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_FormField=require("../FormField/FormField"),_SegmentedControlOption=require("./SegmentedControlOption"),_breakpointsjson=_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),StyledDivider=(0,_styled.default)("div",{target:"e22z0k30",label:"StyledDivider"})(({theme,isChecked,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,baseStyles={backgroundColor:theme.values.color.background.primary.default},checkedStyle=isChecked&&{borderColor:theme.values.color.border.accentSubtle.default},borderRightStyle={borderRight:border,...baseStyles,...checkedStyle};return justified?{[`@media (min-width: ${_breakpointsjson.default.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${_breakpointsjson.default.medium.value}px)`]:{borderBottom:border,...baseStyles,...checkedStyle}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgfTtcblxuICAgIGNvbnN0IGJvcmRlclJpZ2h0U3R5bGUgPSB7XG4gICAgICBib3JkZXJSaWdodDogYm9yZGVyLFxuICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLmJhc2VTdHlsZXMsXG4gICAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxudHlwZSBTdHlsZWRDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFNlZ21lbnRlZENvbnRyb2xQcm9wcyxcbiAgXCJqdXN0aWZpZWRcIiB8IFwib3B0aW9uc1wiXG4+O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0eWxlZENvbnRhaW5lclByb3BzPihcbiAgKHsganVzdGlmaWVkLCBvcHRpb25zIH0pID0+IHtcbiAgICBjb25zdCBiYXNlU3R5bGUgPSB7XG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBiYXNlU3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VTdHlsZSxcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG5cbiAgICAgIFwiJiA+ICpcIjoge1xuICAgICAgICBmbGV4OiBgMSAxICR7MTAwIC8gb3B0aW9ucy5sZW5ndGh9JWAsXG4gICAgICB9LFxuXG4gICAgICBbYCYgPiAke1N0eWxlZERpdmlkZXJ9YF06IHtcbiAgICAgICAgZmxleDogXCIwIDAgYXV0b1wiLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIHRhYmxldCBhbmQgZGVza3RvcFxuICAgICAgW2BAbWVkaWEgKG1pbi13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZENvbnRyb2woe1xuICBvcHRpb25zLFxuICB2YWx1ZSxcbiAganVzdGlmaWVkLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2hhbmdlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXIgaXNDaGVja2VkPXtpc0NoZWNrZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXNCIn0= */"),StyledContainer=(0,_styled.default)("div",{target:"e22z0k31",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${_breakpointsjson.default.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgfTtcblxuICAgIGNvbnN0IGJvcmRlclJpZ2h0U3R5bGUgPSB7XG4gICAgICBib3JkZXJSaWdodDogYm9yZGVyLFxuICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLmJhc2VTdHlsZXMsXG4gICAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxudHlwZSBTdHlsZWRDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFNlZ21lbnRlZENvbnRyb2xQcm9wcyxcbiAgXCJqdXN0aWZpZWRcIiB8IFwib3B0aW9uc1wiXG4+O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0eWxlZENvbnRhaW5lclByb3BzPihcbiAgKHsganVzdGlmaWVkLCBvcHRpb25zIH0pID0+IHtcbiAgICBjb25zdCBiYXNlU3R5bGUgPSB7XG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBiYXNlU3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VTdHlsZSxcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG5cbiAgICAgIFwiJiA+ICpcIjoge1xuICAgICAgICBmbGV4OiBgMSAxICR7MTAwIC8gb3B0aW9ucy5sZW5ndGh9JWAsXG4gICAgICB9LFxuXG4gICAgICBbYCYgPiAke1N0eWxlZERpdmlkZXJ9YF06IHtcbiAgICAgICAgZmxleDogXCIwIDAgYXV0b1wiLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIHRhYmxldCBhbmQgZGVza3RvcFxuICAgICAgW2BAbWVkaWEgKG1pbi13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZENvbnRyb2woe1xuICBvcHRpb25zLFxuICB2YWx1ZSxcbiAganVzdGlmaWVkLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2hhbmdlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXIgaXNDaGVja2VkPXtpc0NoZWNrZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0R3QiJ9 */");function SegmentedControl({options,value,justified,size="m",onChange,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?_react.default.createElement(StyledDivider,{isChecked:isChecked,justified:justified}):null;return _react.default.createElement(_react.Fragment,{key:optionValue},dividerElm,_react.default.createElement(_SegmentedControlOption.SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return _react.default.createElement(_FormField.FormField,{"data-ds-id":"SegmentedControl",...rest},_react.default.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControl",{enumerable:!0,get:function(){return SegmentedControl}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_FormField=require("../FormField/FormField"),_SegmentedControlOption=require("./SegmentedControlOption"),_breakpointsjson=_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),StyledDivider=(0,_styled.default)("div",{target:"e1rz2g6z0",label:"StyledDivider"})(({theme,isChecked,isDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,baseStyles={backgroundColor:theme.values.color.background.primary.default},checkedStyle=isChecked&&{borderColor:theme.values.color.border.accentSubtle.default,...isDisabled&&{opacity:theme.variables.opacity.form.disabled}},borderRightStyle={borderRight:border,...baseStyles,...checkedStyle};return justified?{[`@media (min-width: ${_breakpointsjson.default.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${_breakpointsjson.default.medium.value}px)`]:{borderBottom:border,...baseStyles,...checkedStyle}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGlzRGlzYWJsZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmZvcm0uZGlzYWJsZWQsXG4gICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5iYXNlU3R5bGVzLFxuICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJvcmRlclJpZ2h0U3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubWVkaXVtLnZhbHVlfXB4KWBdOiB7XG4gICAgICAgIC4uLmJvcmRlclJpZ2h0U3R5bGUsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gbW9iaWxlXG4gICAgICBbYEBtZWRpYSAobWF4LXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIC4uLnJlc3Rcbn06IFNlZ21lbnRlZENvbnRyb2xQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBvbkNoYW5nZSgoZXZ0LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZSk7XG4gIH07XG5cbiAgY29uc3Qgb3B0aW9uRWxtcyA9IG9wdGlvbnMubWFwKFxuICAgICh7IHZhbHVlOiBvcHRpb25WYWx1ZSwgZGlzYWJsZWQsIC4uLm90aGVyUHJvcHMgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGlzQ2hlY2tlZCA9IHZhbHVlID09PSBvcHRpb25WYWx1ZTtcbiAgICAgIGNvbnN0IGRpdmlkZXJFbG0gPVxuICAgICAgICBpbmRleCAhPT0gMCA/IChcbiAgICAgICAgICA8U3R5bGVkRGl2aWRlciBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH0gaXNEaXNhYmxlZD17ZGlzYWJsZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjc0IifQ== */"),StyledContainer=(0,_styled.default)("div",{target:"e1rz2g6z1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${_breakpointsjson.default.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGlzRGlzYWJsZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmZvcm0uZGlzYWJsZWQsXG4gICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5iYXNlU3R5bGVzLFxuICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJvcmRlclJpZ2h0U3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubWVkaXVtLnZhbHVlfXB4KWBdOiB7XG4gICAgICAgIC4uLmJvcmRlclJpZ2h0U3R5bGUsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gbW9iaWxlXG4gICAgICBbYEBtZWRpYSAobWF4LXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIC4uLnJlc3Rcbn06IFNlZ21lbnRlZENvbnRyb2xQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBvbkNoYW5nZSgoZXZ0LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZSk7XG4gIH07XG5cbiAgY29uc3Qgb3B0aW9uRWxtcyA9IG9wdGlvbnMubWFwKFxuICAgICh7IHZhbHVlOiBvcHRpb25WYWx1ZSwgZGlzYWJsZWQsIC4uLm90aGVyUHJvcHMgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGlzQ2hlY2tlZCA9IHZhbHVlID09PSBvcHRpb25WYWx1ZTtcbiAgICAgIGNvbnN0IGRpdmlkZXJFbG0gPVxuICAgICAgICBpbmRleCAhPT0gMCA/IChcbiAgICAgICAgICA8U3R5bGVkRGl2aWRlciBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH0gaXNEaXNhYmxlZD17ZGlzYWJsZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRHdCIn0= */");function SegmentedControl({options,value,justified,size="m",onChange,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?_react.default.createElement(StyledDivider,{isChecked:isChecked,isDisabled:disabled,justified:justified}):null;return _react.default.createElement(_react.Fragment,{key:optionValue},dividerElm,_react.default.createElement(_SegmentedControlOption.SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return _react.default.createElement(_FormField.FormField,{"data-ds-id":"SegmentedControl",...rest},_react.default.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControlOption",{enumerable:!0,get:function(){return SegmentedControlOption}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_Text=require("../../Typography/Text/Text"),_breakpointsjson=_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),_Icon=require("../../Icon/Icon"),_ScreenReaderText=require("../../../shared/ScreenReaderText"),_Tooltip=require("../../Tooltip/Tooltip"),_Inline=require("../../Inline/Inline"),StyledInput=(0,_styled.default)("input",{target:"evohud50",label:"StyledInput"})(()=>({opacity:0,height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=(0,_styled.default)(_Text.Text,{target:"evohud51",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkBoB"} */"),StyledSublabel=(0,_styled.default)(_Text.Text,{target:"evohud52",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${_breakpointsjson.default.medium.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA2BuB"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"evohud53",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiD4B"} */"),StyledContainer=(0,_styled.default)("label",{target:"evohud54",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},baseStyle={cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",padding:iconOnly?theme.variables.size.spacing.xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",position:"relative",...("m"===size||"l"===size)&&{padding:iconOnly?theme.variables.size.spacing.s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},...iconOnly&&"l"===size&&{padding:theme.variables.size.spacing.m},...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.form.disabled},...checked&&{backgroundColor:theme.values.color.background.accentSubtle.default,borderColor:theme.values.color.border.accentSubtle.default,"& + div":{borderColor:theme.values.color.border.accentSubtle.default}},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"input:focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${_breakpointsjson.default.medium.value}px)`]:{...borderStyle},[`@media (max-width: ${_breakpointsjson.default.medium.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8DwB"} */");function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus}){let containerRef=(0,_react.useRef)(),iconElm=iconName?_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=_react.default.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?_react.default.createElement(_react.default.Fragment,null,iconElm,_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label)):_react.default.createElement(_Inline.Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?_react.default.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled},_react.default.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&_react.default.createElement(_Tooltip.Tooltip,{content:tooltipContent,externalTriggerRef:containerRef}))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControlOption",{enumerable:!0,get:function(){return SegmentedControlOption}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_Text=require("../../Typography/Text/Text"),_breakpointsjson=_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),_Icon=require("../../Icon/Icon"),_ScreenReaderText=require("../../../shared/ScreenReaderText"),_Tooltip=require("../../Tooltip/Tooltip"),_Inline=require("../../Inline/Inline"),StyledInput=(0,_styled.default)("input",{target:"e7ej1qg0",label:"StyledInput"})(()=>({opacity:0,height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=(0,_styled.default)(_Text.Text,{target:"e7ej1qg1",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkBoB"} */"),StyledSublabel=(0,_styled.default)(_Text.Text,{target:"e7ej1qg2",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${_breakpointsjson.default.medium.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA2BuB"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"e7ej1qg3",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiD4B"} */"),StyledContainer=(0,_styled.default)("label",{target:"e7ej1qg4",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},baseStyle={cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",padding:iconOnly?theme.variables.size.spacing.xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",position:"relative",...("m"===size||"l"===size)&&{padding:iconOnly?theme.variables.size.spacing.s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},...iconOnly&&"l"===size&&{padding:theme.variables.size.spacing.m},...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.form.disabled},...checked&&{backgroundColor:theme.values.color.background.accentSubtle.default,borderColor:theme.values.color.border.accentSubtle.default,"& + div":{borderColor:theme.values.color.border.accentSubtle.default,...disabled&&{opacity:theme.variables.opacity.form.disabled}}},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"input:focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${_breakpointsjson.default.medium.value}px)`]:{...borderStyle},[`@media (max-width: ${_breakpointsjson.default.medium.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8DwB"} */");function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus}){let containerRef=(0,_react.useRef)(),iconElm=iconName?_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=_react.default.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?_react.default.createElement(_react.default.Fragment,null,iconElm,_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label)):_react.default.createElement(_Inline.Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?_react.default.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled},_react.default.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&_react.default.createElement(_Tooltip.Tooltip,{content:tooltipContent,externalTriggerRef:containerRef}))}
@@ -10,6 +10,7 @@ export type PictogramButtonProps = {
10
10
  /** Size */
11
11
  size?: "xs" | "s" | "m";
12
12
  variant?: PictogramVariations;
13
+ label?: string;
13
14
  } & Omit<ButtonProps, "variant" | "size" | "leftIcon" | "rightIcon" | "fullWidth" | "destructive" | "privateProps" | "loading">;
14
15
  type PictogramButtonComponent = <C extends React.ElementType = "button">(props: PolymorphicComponentPropsWithRef<C, PictogramButtonProps>) => React.ReactElement | null;
15
16
  export declare const PictogramButton: PictogramButtonComponent;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PictogramButton",{enumerable:!0,get:function(){return PictogramButton}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Inline=require("../Inline/Inline"),StyledPictogramButton=(0,_styled.default)("button",{target:"e1rqkdtj0",label:"StyledPictogramButton"})(({theme,variant,size,squareCorners})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},border:0,display:"inline-block",textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,padding:theme.variables.size.spacing.xxs,cursor:"pointer","&[disabled], &:disabled":{opacity:theme.variables.opacity.button.disabled,pointerEvents:"none"},..."secondary"===variant&&{border:"1px solid",borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.default,padding:parseInt(theme.variables.size.spacing.xxs,10)-1,color:theme.values.color.icon.secondary,"&:hover":{color:theme.values.color.icon.primary,borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{borderColor:theme.values.color.border.primary.active,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."tertiary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.secondary,"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},"&:active":{color:theme.values.color.icon.primary,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."quaternary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.tertiary,":hover":{backgroundColor:theme.values.color.background.transparent.hover},":active":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.active},":disabled":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.default}},...squareCorners&&{borderRadius:"0"},...("s"===size||"m"===size)&&{padding:theme.variables.size.spacing.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUGljdG9ncmFtQnV0dG9uL1BpY3RvZ3JhbUJ1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjayB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEljb25OYW1lIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgdHlwZSB7IEJ1dHRvblByb3BzIH0gZnJvbSBcIi4uL0J1dHRvbi9CdXR0b25cIjtcbmltcG9ydCB0eXBlIHtcbiAgUGljdG9ncmFtVmFyaWF0aW9ucyxcbiAgUG9seW1vcnBoaWNDb21wb25lbnRQcm9wc1dpdGhSZWYsXG4gIFBvbHltb3JwaGljUmVmLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkUGljdG9ncmFtQnV0dG9uID0gc3R5bGVkLmJ1dHRvbjxQYXJ0aWFsPFBpY3RvZ3JhbUJ1dHRvblByb3BzPj4oXG4gICh7IHRoZW1lLCB2YXJpYW50LCBzaXplLCBzcXVhcmVDb3JuZXJzIH0pID0+ICh7XG4gICAgXCImW3R5cGU9J2J1dHRvbiddXCI6IHtcbiAgICAgIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICAgICAgTW96QXBwZWFyYW5jZTogXCJub25lXCIsXG4gICAgICBXZWJraXRBcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICB9LFxuICAgIGJvcmRlcjogMCxcbiAgICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICAgIHRleHRUcmFuc2Zvcm06IFwibm9uZVwiLFxuICAgIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgICBmb250V2VpZ2h0OiB0aGVtZS52YXJpYWJsZXMud2VpZ2h0LmJvbGQsXG4gICAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiZbZGlzYWJsZWRdLCAmOmRpc2FibGVkXCI6IHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmJ1dHRvbi5kaXNhYmxlZCxcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgIH0sXG5cbiAgICAuLi4odmFyaWFudCA9PT0gXCJzZWNvbmRhcnlcIiAmJiB7XG4gICAgICBib3JkZXI6IFwiMXB4IHNvbGlkXCIsXG4gICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHQsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBwYWRkaW5nOiBwYXJzZUludCh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cywgMTApIC0gMSxcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi5zZWNvbmRhcnksXG4gICAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmljb24ucHJpbWFyeSxcbiAgICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmFjdGl2ZSxcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5hY3RpdmUsXG4gICAgICB9LFxuICAgICAgXCImOmRpc2FibGVkXCI6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgICAgfSxcbiAgICB9KSxcblxuICAgIC4uLih2YXJpYW50ID09PSBcInRlcnRpYXJ5XCIgJiYge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5pY29uLnNlY29uZGFyeSxcbiAgICAgIFwiJjpob3ZlclwiOiB7XG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgICB9LFxuICAgICAgXCImOmFjdGl2ZVwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi5wcmltYXJ5LFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgICAgIH0sXG4gICAgICBcIiY6ZGlzYWJsZWRcIjoge1xuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICB9LFxuICAgIH0pLFxuXG4gICAgLi4uKHZhcmlhbnQgPT09IFwicXVhdGVybmFyeVwiICYmIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi50ZXJ0aWFyeSxcbiAgICAgIFwiOmhvdmVyXCI6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICAgIH0sXG4gICAgICBcIjphY3RpdmVcIjoge1xuICAgICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmljb24uc2Vjb25kYXJ5LFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgICAgIH0sXG4gICAgICBcIjpkaXNhYmxlZFwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi5zZWNvbmRhcnksXG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICAgIH0sXG4gICAgfSksXG5cbiAgICAuLi4oc3F1YXJlQ29ybmVycyAmJiB7XG4gICAgICBib3JkZXJSYWRpdXM6IFwiMFwiLFxuICAgIH0pLFxuICAgIC4uLigoc2l6ZSA9PT0gXCJzXCIgfHwgc2l6ZSA9PT0gXCJtXCIpICYmIHtcbiAgICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBQaWN0b2dyYW1CdXR0b25Qcm9wcyA9IHtcbiAgLyoqIFRoZSBjZW50ZXJlZCBpY29uIHRvIGJlIGRpc3BsYXllZC4gKi9cbiAgaWNvbjogSWNvbk5hbWU7XG4gIC8qKiBJZiB0cnVlLCB0aGUgYnV0dG9uIGhhcyBzcXVhcmUgY29ybmVycy4gKi9cbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG4gIC8qKiBTaXplICovXG4gIHNpemU/OiBcInhzXCIgfCBcInNcIiB8IFwibVwiO1xuICB2YXJpYW50PzogUGljdG9ncmFtVmFyaWF0aW9ucztcbn0gJiBPbWl0PFxuICBCdXR0b25Qcm9wcyxcbiAgfCBcInZhcmlhbnRcIlxuICB8IFwic2l6ZVwiXG4gIHwgXCJsZWZ0SWNvblwiXG4gIHwgXCJyaWdodEljb25cIlxuICB8IFwiZnVsbFdpZHRoXCJcbiAgfCBcImRlc3RydWN0aXZlXCJcbiAgfCBcInByaXZhdGVQcm9wc1wiXG4gIHwgXCJsb2FkaW5nXCJcbj47XG5cbnR5cGUgUGljdG9ncmFtQnV0dG9uQ29tcG9uZW50ID0gPEMgZXh0ZW5kcyBSZWFjdC5FbGVtZW50VHlwZSA9IFwiYnV0dG9uXCI+KFxuICBwcm9wczogUG9seW1vcnBoaWNDb21wb25lbnRQcm9wc1dpdGhSZWY8QywgUGljdG9ncmFtQnV0dG9uUHJvcHM+XG4pID0+IFJlYWN0LlJlYWN0RWxlbWVudCB8IG51bGw7XG5cbmV4cG9ydCBjb25zdCBQaWN0b2dyYW1CdXR0b246IFBpY3RvZ3JhbUJ1dHRvbkNvbXBvbmVudCA9IFJlYWN0LmZvcndhcmRSZWYoXG4gIDxDIGV4dGVuZHMgUmVhY3QuRWxlbWVudFR5cGUgPSBcImJ1dHRvblwiPihcbiAgICB7XG4gICAgICBhcmlhQXR0cmlidXRlcyxcbiAgICAgIHR5cGUgPSBcImJ1dHRvblwiLFxuICAgICAgc2l6ZSA9IFwieHNcIixcbiAgICAgIHZhcmlhbnQgPSBcInRlcnRpYXJ5XCIsXG4gICAgICBkaXNhYmxlZCA9IGZhbHNlLFxuICAgICAgb25DbGljayxcbiAgICAgIG9uRm9jdXMsXG4gICAgICBvbkJsdXIsXG4gICAgICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgICAgIGFzLFxuICAgICAgaWNvbixcbiAgICAgIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgICAgIC4uLnJlc3RcbiAgICB9OiBQb2x5bW9ycGhpY0NvbXBvbmVudFByb3BzV2l0aFJlZjxDLCBQaWN0b2dyYW1CdXR0b25Qcm9wcz4sXG4gICAgcmVmPzogUG9seW1vcnBoaWNSZWY8Qz5cbiAgKSA9PiB7XG4gICAgY29uc3QgaGFuZGxlQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAgIChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChkaXNhYmxlZCkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAob25DbGljaykge1xuICAgICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBbZGlzYWJsZWQsIG9uQ2xpY2tdXG4gICAgKTtcbiAgICBjb25zdCBpY29uU2l6ZSA9IHNpemUgPT09IFwibVwiID8gXCJtXCIgOiBcInNcIjtcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkUGljdG9ncmFtQnV0dG9uXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgICBkYXRhLWRzLWlkPVwiUGljdG9ncmFtQnV0dG9uXCJcbiAgICAgICAgYXM9e2FzfVxuICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgIHR5cGU9e2FzICYmIGFzICE9PSBcImJ1dHRvblwiID8gdW5kZWZpbmVkIDogdHlwZX1cbiAgICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgc3F1YXJlQ29ybmVycz17c3F1YXJlQ29ybmVyc31cbiAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2t9XG4gICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgPlxuICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBzaXplPXtpY29uU2l6ZX1cbiAgICAgICAgICAgIG5hbWU9e2ljb259XG4gICAgICAgICAgICBkYXRhLXRlc3RpZD17aWNvbn1cbiAgICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2ljb259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9JbmxpbmU+XG4gICAgICA8L1N0eWxlZFBpY3RvZ3JhbUJ1dHRvbj5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWE4QiJ9 */"),PictogramButton=_react.default.forwardRef(({ariaAttributes,type="button",size="xs",variant="tertiary",disabled=!1,onClick,onFocus,onBlur,"data-e2e-test-id":dataE2eTestId,as,icon,squareCorners=!1,...rest},ref)=>{let handleClick=(0,_react.useCallback)(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]);return _react.default.createElement(StyledPictogramButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PictogramButton",as:as,disabled:disabled,type:as&&"button"!==as?void 0:type,variant:variant,size:size,squareCorners:squareCorners,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:"center",space:"xxs",noWrap:!0},_react.default.createElement(_Icon.Icon,{size:"m"===size?"m":"s",name:icon,"data-testid":icon,"data-e2e-test-id":icon})))});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PictogramButton",{enumerable:!0,get:function(){return PictogramButton}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Inline=require("../Inline/Inline"),_Tooltip=require("../Tooltip/Tooltip"),StyledPictogramButton=(0,_styled.default)("button",{target:"e4iatcg0",label:"StyledPictogramButton"})(({theme,variant,size,squareCorners})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},border:0,display:"inline-block",textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,padding:theme.variables.size.spacing.xxs,cursor:"pointer","&[disabled], &:disabled":{opacity:theme.variables.opacity.button.disabled,pointerEvents:"none"},..."secondary"===variant&&{border:"1px solid",borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.default,padding:parseInt(theme.variables.size.spacing.xxs,10)-1,color:theme.values.color.icon.secondary,"&:hover":{color:theme.values.color.icon.primary,borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{borderColor:theme.values.color.border.primary.active,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."tertiary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.secondary,"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},"&:active":{color:theme.values.color.icon.primary,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."quaternary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.tertiary,":hover":{backgroundColor:theme.values.color.background.transparent.hover},":active":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.active},":disabled":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.default}},...squareCorners&&{borderRadius:"0"},...("s"===size||"m"===size)&&{padding:theme.variables.size.spacing.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PictogramButton/PictogramButton.tsx","sources":["src/components/PictogramButton/PictogramButton.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { ButtonProps } from \"../Button/Button\";\nimport type {\n  PictogramVariations,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\n\nconst StyledPictogramButton = styled.button<Partial<PictogramButtonProps>>(\n  ({ theme, variant, size, squareCorners }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    border: 0,\n    display: \"inline-block\",\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    padding: theme.variables.size.spacing.xxs,\n    cursor: \"pointer\",\n    \"&[disabled], &:disabled\": {\n      opacity: theme.variables.opacity.button.disabled,\n      pointerEvents: \"none\",\n    },\n\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      borderColor: theme.values.color.border.primary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      padding: parseInt(theme.variables.size.spacing.xxs, 10) - 1,\n      color: theme.values.color.icon.secondary,\n      \"&:hover\": {\n        color: theme.values.color.icon.primary,\n        borderColor: theme.values.color.border.primary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \"&:active\": {\n        borderColor: theme.values.color.border.primary.active,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \"&:disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n      },\n    }),\n\n    ...(variant === \"tertiary\" && {\n      backgroundColor: theme.values.color.background.transparent.default,\n      color: theme.values.color.icon.secondary,\n      \"&:hover\": {\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \"&:active\": {\n        color: theme.values.color.icon.primary,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \"&:disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n      },\n    }),\n\n    ...(variant === \"quaternary\" && {\n      backgroundColor: theme.values.color.background.transparent.default,\n      color: theme.values.color.icon.tertiary,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":active\": {\n        color: theme.values.color.icon.secondary,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \":disabled\": {\n        color: theme.values.color.icon.secondary,\n        backgroundColor: theme.values.color.background.transparent.default,\n      },\n    }),\n\n    ...(squareCorners && {\n      borderRadius: \"0\",\n    }),\n    ...((size === \"s\" || size === \"m\") && {\n      padding: theme.variables.size.spacing.xs,\n    }),\n  })\n);\n\nexport type PictogramButtonProps = {\n  /** The centered icon to be displayed. */\n  icon: IconName;\n  /** If true, the button has square corners. */\n  squareCorners?: boolean;\n  /** Size */\n  size?: \"xs\" | \"s\" | \"m\";\n  variant?: PictogramVariations;\n  label?: string\n} & Omit<\n  ButtonProps,\n  | \"variant\"\n  | \"size\"\n  | \"leftIcon\"\n  | \"rightIcon\"\n  | \"fullWidth\"\n  | \"destructive\"\n  | \"privateProps\"\n  | \"loading\"\n>;\n\ntype PictogramButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, PictogramButtonProps>\n) => React.ReactElement | null;\n\nexport const PictogramButton: PictogramButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      ariaAttributes,\n      type = \"button\",\n      size = \"xs\",\n      variant = \"tertiary\",\n      disabled = false,\n      onClick,\n      onFocus,\n      onBlur,\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      icon,\n      label,\n      squareCorners = false,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, PictogramButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n    const iconSize = size === \"m\" ? \"m\" : \"s\";\n    const pictogramContent = \n        <StyledPictogramButton\n            ref={ref}\n            data-e2e-test-id={dataE2eTestId}\n            data-ds-id=\"PictogramButton\"\n            as={as}\n            disabled={disabled}\n            type={as && as !== \"button\" ? undefined : type}\n            variant={variant}\n            size={size}\n            squareCorners={squareCorners}\n            onClick={handleClick}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            {...ariaAttributes}\n            {...rest}\n            >\n              <Inline vAlignItems=\"center\" alignItems=\"center\" space=\"xxs\" noWrap>\n                <Icon\n                    size={iconSize}\n                    name={icon}\n                    data-testid={icon}\n                    data-e2e-test-id={icon}\n                />\n              </Inline>\n        </StyledPictogramButton>\n\n    return (\n      label\n      ? <Tooltip content={label}>\n          { pictogramContent }\n        </Tooltip>\n      : pictogramContent\n    );\n  }\n);\n"],"names":[],"mappings":"AAc8B"} */"),PictogramButton=_react.default.forwardRef(({ariaAttributes,type="button",size="xs",variant="tertiary",disabled=!1,onClick,onFocus,onBlur,"data-e2e-test-id":dataE2eTestId,as,icon,label,squareCorners=!1,...rest},ref)=>{let handleClick=(0,_react.useCallback)(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]),pictogramContent=_react.default.createElement(StyledPictogramButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PictogramButton",as:as,disabled:disabled,type:as&&"button"!==as?void 0:type,variant:variant,size:size,squareCorners:squareCorners,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:"center",space:"xxs",noWrap:!0},_react.default.createElement(_Icon.Icon,{size:"m"===size?"m":"s",name:icon,"data-testid":icon,"data-e2e-test-id":icon})));return label?_react.default.createElement(_Tooltip.Tooltip,{content:label},pictogramContent):pictogramContent});
@@ -64,4 +64,4 @@ export * from "./components/Form/MaskedInput/MaskedInput";
64
64
  export * from "./components/Utilities/Expandable/Expandable";
65
65
  export * from "./components/QBankRichText/QBankRichText";
66
66
  export * from "./components/Tutorialtip/Tutorialtip";
67
- export * from "./components/EntityTree/EntityTree";
67
+ export * from "./components/EntityTree";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{CacheProvider:function(){return _react.CacheProvider},ThemeProvider:function(){return _react.ThemeProvider},createCache:function(){return _cache.default},dark:function(){return dark},light:function(){return light}});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/Typography/Header/Header"),exports),_export_star._(require("./components/Typography/Text/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Select/Select"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/Container/Container"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem/MediaItem"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/EntityTree/EntityTree"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{CacheProvider:function(){return _react.CacheProvider},ThemeProvider:function(){return _react.ThemeProvider},createCache:function(){return _cache.default},dark:function(){return dark},light:function(){return light}});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/Typography/Header/Header"),exports),_export_star._(require("./components/Typography/Text/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Select/Select"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/Container/Container"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem/MediaItem"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/EntityTree"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
@@ -90,6 +90,7 @@
90
90
  "illustration": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M2 4a2 2 0 012-2h8a2 2 0 012 2v8a2 2 0 01-2 2H4a2 2 0 01-2-2z\" clip-rule=\"evenodd\" />\n <g fill=\"currentColor\">\n <path d=\"M10 12a2 2 0 100-4 2 2 0 000 4z\" />\n <path fill-rule=\"evenodd\" d=\"M8.92 7.2L7 4 4 9h3.17a3.009 3.009 0 011.75-1.8z\" clip-rule=\"evenodd\" />\n </g>\n</svg>",
91
91
  "image": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M2 4a2 2 0 012-2h8a2 2 0 012 2v8a2 2 0 01-2 2H4a2 2 0 01-2-2z\" clip-rule=\"evenodd\" />\n <path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M5.5 7a1.5 1.5 0 100-3 1.5 1.5 0 000 3z\" clip-rule=\"evenodd\" />\n <path stroke=\"currentColor\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M14 11l-4-4-7 7\" />\n</svg>",
92
92
  "info": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-info\">\n <circle cx=\"8\" cy=\"8\" r=\"7\"/>\n <path d=\"M8 11V8M8 5h.01\"/>\n</svg>\n",
93
+ "institution": "<svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<path d=\"M7 9V7H9V9H7Z\" fill=\"currentColor\"/>\n<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M9 1V1.18018L9.80383 1.01941C10.3454 0.911101 10.8722 1.26232 10.9805 1.80388C11.0888 2.34544 10.7376 2.87226 10.1961 2.98058L9.58932 3.10192L12.1396 4.87009C12.6785 5.24375 13 5.85789 13 6.51369V7H14C15.1046 7 16 7.89543 16 9V13C16 14.1046 15.1046 15 14 15H2C0.89543 15 0 14.1046 0 13V9C0 7.89543 0.89543 7 2 7H3V6.51369C3 5.85789 3.32151 5.24375 3.86044 4.87009L6.86044 2.79009C6.90602 2.75849 6.95258 2.72899 7 2.70159V1C7 0.447717 7.44772 0 8 0C8.55229 0 9 0.447717 9 1ZM11 13V6.51369L8 4.43368L5 6.51369V13H7V10H9V13H11ZM2 9H3V13L2 13V9ZM14 13L13 13V9H14V13Z\" fill=\"currentColor\"/>\n</svg>\n",
93
94
  "layers": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path d=\"M8 1.5l-7 3 7 3 7-3z\" clip-rule=\"evenodd\" />\n <path d=\"M1 8l7 3 7-3M1 11.5l7 3 7-3\" />\n </g>\n</svg>",
94
95
  "link": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path d=\"M6.667 8.605a3.478 3.478 0 005.244.376l2.087-2.087A3.478 3.478 0 009.08 1.976l-1.196 1.19\" />\n <path d=\"M9.308 7.391a3.478 3.478 0 00-5.245-.375L1.976 9.102a3.478 3.478 0 004.918 4.918l1.19-1.19\" />\n </g>\n</svg>",
95
96
  "link2": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path\n d=\"M10 5h1.875c.829 0 1.624.316 2.21.879A2.94 2.94 0 0115 8c0 1.657-1.4 3-3.125 3H10M6 11H4.125a3.192 3.192 0 01-2.21-.879A2.94 2.94 0 011 8c0-1.657 1.4-3 3.125-3H6M5.333 8h5.334\" />\n </g>\n</svg>",
@@ -0,0 +1,3 @@
1
+ export * from "./BaseEntityTree";
2
+ export * from "./EntityTree";
3
+ export * from "./types";
@@ -0,0 +1 @@
1
+ export*from"./BaseEntityTree";export*from"./EntityTree";export*from"./types";
@@ -1 +1 @@
1
- import React,{Fragment}from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{SegmentedControlOption}from"./SegmentedControlOption";import breakpoints from"../../../web-tokens/_breakpoints.json";let StyledDivider=styled("div",{target:"e22z0k30",label:"StyledDivider"})(({theme,isChecked,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,baseStyles={backgroundColor:theme.values.color.background.primary.default},checkedStyle=isChecked&&{borderColor:theme.values.color.border.accentSubtle.default},borderRightStyle={borderRight:border,...baseStyles,...checkedStyle};return justified?{[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{borderBottom:border,...baseStyles,...checkedStyle}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgfTtcblxuICAgIGNvbnN0IGJvcmRlclJpZ2h0U3R5bGUgPSB7XG4gICAgICBib3JkZXJSaWdodDogYm9yZGVyLFxuICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLmJhc2VTdHlsZXMsXG4gICAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxudHlwZSBTdHlsZWRDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFNlZ21lbnRlZENvbnRyb2xQcm9wcyxcbiAgXCJqdXN0aWZpZWRcIiB8IFwib3B0aW9uc1wiXG4+O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0eWxlZENvbnRhaW5lclByb3BzPihcbiAgKHsganVzdGlmaWVkLCBvcHRpb25zIH0pID0+IHtcbiAgICBjb25zdCBiYXNlU3R5bGUgPSB7XG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBiYXNlU3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VTdHlsZSxcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG5cbiAgICAgIFwiJiA+ICpcIjoge1xuICAgICAgICBmbGV4OiBgMSAxICR7MTAwIC8gb3B0aW9ucy5sZW5ndGh9JWAsXG4gICAgICB9LFxuXG4gICAgICBbYCYgPiAke1N0eWxlZERpdmlkZXJ9YF06IHtcbiAgICAgICAgZmxleDogXCIwIDAgYXV0b1wiLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIHRhYmxldCBhbmQgZGVza3RvcFxuICAgICAgW2BAbWVkaWEgKG1pbi13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZENvbnRyb2woe1xuICBvcHRpb25zLFxuICB2YWx1ZSxcbiAganVzdGlmaWVkLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2hhbmdlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXIgaXNDaGVja2VkPXtpc0NoZWNrZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXNCIn0= */"),StyledContainer=styled("div",{target:"e22z0k31",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgfTtcblxuICAgIGNvbnN0IGJvcmRlclJpZ2h0U3R5bGUgPSB7XG4gICAgICBib3JkZXJSaWdodDogYm9yZGVyLFxuICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLmJhc2VTdHlsZXMsXG4gICAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxudHlwZSBTdHlsZWRDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFNlZ21lbnRlZENvbnRyb2xQcm9wcyxcbiAgXCJqdXN0aWZpZWRcIiB8IFwib3B0aW9uc1wiXG4+O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0eWxlZENvbnRhaW5lclByb3BzPihcbiAgKHsganVzdGlmaWVkLCBvcHRpb25zIH0pID0+IHtcbiAgICBjb25zdCBiYXNlU3R5bGUgPSB7XG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBiYXNlU3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VTdHlsZSxcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG5cbiAgICAgIFwiJiA+ICpcIjoge1xuICAgICAgICBmbGV4OiBgMSAxICR7MTAwIC8gb3B0aW9ucy5sZW5ndGh9JWAsXG4gICAgICB9LFxuXG4gICAgICBbYCYgPiAke1N0eWxlZERpdmlkZXJ9YF06IHtcbiAgICAgICAgZmxleDogXCIwIDAgYXV0b1wiLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIHRhYmxldCBhbmQgZGVza3RvcFxuICAgICAgW2BAbWVkaWEgKG1pbi13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZENvbnRyb2woe1xuICBvcHRpb25zLFxuICB2YWx1ZSxcbiAganVzdGlmaWVkLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2hhbmdlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXIgaXNDaGVja2VkPXtpc0NoZWNrZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0R3QiJ9 */");export function SegmentedControl({options,value,justified,size="m",onChange,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?React.createElement(StyledDivider,{isChecked:isChecked,justified:justified}):null;return React.createElement(Fragment,{key:optionValue},dividerElm,React.createElement(SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return React.createElement(FormField,{"data-ds-id":"SegmentedControl",...rest},React.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
1
+ import React,{Fragment}from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{SegmentedControlOption}from"./SegmentedControlOption";import breakpoints from"../../../web-tokens/_breakpoints.json";let StyledDivider=styled("div",{target:"e1rz2g6z0",label:"StyledDivider"})(({theme,isChecked,isDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,baseStyles={backgroundColor:theme.values.color.background.primary.default},checkedStyle=isChecked&&{borderColor:theme.values.color.border.accentSubtle.default,...isDisabled&&{opacity:theme.variables.opacity.form.disabled}},borderRightStyle={borderRight:border,...baseStyles,...checkedStyle};return justified?{[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{borderBottom:border,...baseStyles,...checkedStyle}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGlzRGlzYWJsZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmZvcm0uZGlzYWJsZWQsXG4gICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5iYXNlU3R5bGVzLFxuICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJvcmRlclJpZ2h0U3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubWVkaXVtLnZhbHVlfXB4KWBdOiB7XG4gICAgICAgIC4uLmJvcmRlclJpZ2h0U3R5bGUsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gbW9iaWxlXG4gICAgICBbYEBtZWRpYSAobWF4LXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIC4uLnJlc3Rcbn06IFNlZ21lbnRlZENvbnRyb2xQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBvbkNoYW5nZSgoZXZ0LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZSk7XG4gIH07XG5cbiAgY29uc3Qgb3B0aW9uRWxtcyA9IG9wdGlvbnMubWFwKFxuICAgICh7IHZhbHVlOiBvcHRpb25WYWx1ZSwgZGlzYWJsZWQsIC4uLm90aGVyUHJvcHMgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGlzQ2hlY2tlZCA9IHZhbHVlID09PSBvcHRpb25WYWx1ZTtcbiAgICAgIGNvbnN0IGRpdmlkZXJFbG0gPVxuICAgICAgICBpbmRleCAhPT0gMCA/IChcbiAgICAgICAgICA8U3R5bGVkRGl2aWRlciBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH0gaXNEaXNhYmxlZD17ZGlzYWJsZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjc0IifQ== */"),StyledContainer=styled("div",{target:"e1rz2g6z1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGlzRGlzYWJsZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmZvcm0uZGlzYWJsZWQsXG4gICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5iYXNlU3R5bGVzLFxuICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJvcmRlclJpZ2h0U3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubWVkaXVtLnZhbHVlfXB4KWBdOiB7XG4gICAgICAgIC4uLmJvcmRlclJpZ2h0U3R5bGUsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gbW9iaWxlXG4gICAgICBbYEBtZWRpYSAobWF4LXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgICAgLi4uY2hlY2tlZFN0eWxlLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIC4uLnJlc3Rcbn06IFNlZ21lbnRlZENvbnRyb2xQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBvbkNoYW5nZSgoZXZ0LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZSk7XG4gIH07XG5cbiAgY29uc3Qgb3B0aW9uRWxtcyA9IG9wdGlvbnMubWFwKFxuICAgICh7IHZhbHVlOiBvcHRpb25WYWx1ZSwgZGlzYWJsZWQsIC4uLm90aGVyUHJvcHMgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGlzQ2hlY2tlZCA9IHZhbHVlID09PSBvcHRpb25WYWx1ZTtcbiAgICAgIGNvbnN0IGRpdmlkZXJFbG0gPVxuICAgICAgICBpbmRleCAhPT0gMCA/IChcbiAgICAgICAgICA8U3R5bGVkRGl2aWRlciBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH0gaXNEaXNhYmxlZD17ZGlzYWJsZWR9IGp1c3RpZmllZD17anVzdGlmaWVkfSAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRHdCIn0= */");export function SegmentedControl({options,value,justified,size="m",onChange,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?React.createElement(StyledDivider,{isChecked:isChecked,isDisabled:disabled,justified:justified}):null;return React.createElement(Fragment,{key:optionValue},dividerElm,React.createElement(SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return React.createElement(FormField,{"data-ds-id":"SegmentedControl",...rest},React.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
@@ -1 +1 @@
1
- import React,{useRef}from"react";import styled from"@emotion/styled";import{Text}from"../../Typography/Text/Text";import breakpoints from"../../../web-tokens/_breakpoints.json";import{Icon}from"../../Icon/Icon";import{ScreenReaderText}from"../../../shared/ScreenReaderText";import{Tooltip}from"../../Tooltip/Tooltip";import{Inline}from"../../Inline/Inline";let StyledInput=styled("input",{target:"evohud50",label:"StyledInput"})(()=>({opacity:0,height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=styled(Text,{target:"evohud51",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkBoB"} */"),StyledSublabel=styled(Text,{target:"evohud52",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${breakpoints.medium.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA2BuB"} */"),StyledIconContainer=styled("div",{target:"evohud53",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiD4B"} */"),StyledContainer=styled("label",{target:"evohud54",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},baseStyle={cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",padding:iconOnly?theme.variables.size.spacing.xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",position:"relative",...("m"===size||"l"===size)&&{padding:iconOnly?theme.variables.size.spacing.s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},...iconOnly&&"l"===size&&{padding:theme.variables.size.spacing.m},...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.form.disabled},...checked&&{backgroundColor:theme.values.color.background.accentSubtle.default,borderColor:theme.values.color.border.accentSubtle.default,"& + div":{borderColor:theme.values.color.border.accentSubtle.default}},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"input:focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8DwB"} */");export function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus}){let containerRef=useRef(),iconElm=iconName?React.createElement(StyledIconContainer,null,React.createElement(Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=React.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?React.createElement(React.Fragment,null,iconElm,React.createElement(ScreenReaderText,null,label)):React.createElement(Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?React.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return React.createElement(React.Fragment,null,React.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled},React.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&React.createElement(Tooltip,{content:tooltipContent,externalTriggerRef:containerRef}))}
1
+ import React,{useRef}from"react";import styled from"@emotion/styled";import{Text}from"../../Typography/Text/Text";import breakpoints from"../../../web-tokens/_breakpoints.json";import{Icon}from"../../Icon/Icon";import{ScreenReaderText}from"../../../shared/ScreenReaderText";import{Tooltip}from"../../Tooltip/Tooltip";import{Inline}from"../../Inline/Inline";let StyledInput=styled("input",{target:"e7ej1qg0",label:"StyledInput"})(()=>({opacity:0,height:0,width:0,position:"absolute"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=styled(Text,{target:"e7ej1qg1",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkBoB"} */"),StyledSublabel=styled(Text,{target:"e7ej1qg2",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${breakpoints.medium.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA2BuB"} */"),StyledIconContainer=styled("div",{target:"e7ej1qg3",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiD4B"} */"),StyledContainer=styled("label",{target:"e7ej1qg4",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},baseStyle={cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",padding:iconOnly?theme.variables.size.spacing.xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",position:"relative",...("m"===size||"l"===size)&&{padding:iconOnly?theme.variables.size.spacing.s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},...iconOnly&&"l"===size&&{padding:theme.variables.size.spacing.m},...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.form.disabled},...checked&&{backgroundColor:theme.values.color.background.accentSubtle.default,borderColor:theme.values.color.border.accentSubtle.default,"& + div":{borderColor:theme.values.color.border.accentSubtle.default,...disabled&&{opacity:theme.variables.opacity.form.disabled}}},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"input:focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.form.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.form.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8DwB"} */");export function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus}){let containerRef=useRef(),iconElm=iconName?React.createElement(StyledIconContainer,null,React.createElement(Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=React.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?React.createElement(React.Fragment,null,iconElm,React.createElement(ScreenReaderText,null,label)):React.createElement(Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?React.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return React.createElement(React.Fragment,null,React.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled},React.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&React.createElement(Tooltip,{content:tooltipContent,externalTriggerRef:containerRef}))}
@@ -10,6 +10,7 @@ export type PictogramButtonProps = {
10
10
  /** Size */
11
11
  size?: "xs" | "s" | "m";
12
12
  variant?: PictogramVariations;
13
+ label?: string;
13
14
  } & Omit<ButtonProps, "variant" | "size" | "leftIcon" | "rightIcon" | "fullWidth" | "destructive" | "privateProps" | "loading">;
14
15
  type PictogramButtonComponent = <C extends React.ElementType = "button">(props: PolymorphicComponentPropsWithRef<C, PictogramButtonProps>) => React.ReactElement | null;
15
16
  export declare const PictogramButton: PictogramButtonComponent;
@@ -1 +1 @@
1
- import React,{useCallback}from"react";import styled from"@emotion/styled";import{Icon}from"../Icon/Icon";import{Inline}from"../Inline/Inline";let StyledPictogramButton=styled("button",{target:"e1rqkdtj0",label:"StyledPictogramButton"})(({theme,variant,size,squareCorners})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},border:0,display:"inline-block",textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,padding:theme.variables.size.spacing.xxs,cursor:"pointer","&[disabled], &:disabled":{opacity:theme.variables.opacity.button.disabled,pointerEvents:"none"},..."secondary"===variant&&{border:"1px solid",borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.default,padding:parseInt(theme.variables.size.spacing.xxs,10)-1,color:theme.values.color.icon.secondary,"&:hover":{color:theme.values.color.icon.primary,borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{borderColor:theme.values.color.border.primary.active,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."tertiary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.secondary,"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},"&:active":{color:theme.values.color.icon.primary,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."quaternary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.tertiary,":hover":{backgroundColor:theme.values.color.background.transparent.hover},":active":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.active},":disabled":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.default}},...squareCorners&&{borderRadius:"0"},...("s"===size||"m"===size)&&{padding:theme.variables.size.spacing.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUGljdG9ncmFtQnV0dG9uL1BpY3RvZ3JhbUJ1dHRvbi50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjayB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEljb25OYW1lIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgdHlwZSB7IEJ1dHRvblByb3BzIH0gZnJvbSBcIi4uL0J1dHRvbi9CdXR0b25cIjtcbmltcG9ydCB0eXBlIHtcbiAgUGljdG9ncmFtVmFyaWF0aW9ucyxcbiAgUG9seW1vcnBoaWNDb21wb25lbnRQcm9wc1dpdGhSZWYsXG4gIFBvbHltb3JwaGljUmVmLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgU3R5bGVkUGljdG9ncmFtQnV0dG9uID0gc3R5bGVkLmJ1dHRvbjxQYXJ0aWFsPFBpY3RvZ3JhbUJ1dHRvblByb3BzPj4oXG4gICh7IHRoZW1lLCB2YXJpYW50LCBzaXplLCBzcXVhcmVDb3JuZXJzIH0pID0+ICh7XG4gICAgXCImW3R5cGU9J2J1dHRvbiddXCI6IHtcbiAgICAgIGFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICAgICAgTW96QXBwZWFyYW5jZTogXCJub25lXCIsXG4gICAgICBXZWJraXRBcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICB9LFxuICAgIGJvcmRlcjogMCxcbiAgICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICAgIHRleHRUcmFuc2Zvcm06IFwibm9uZVwiLFxuICAgIHRleHREZWNvcmF0aW9uOiBcIm5vbmVcIixcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250LnMsXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54cyxcbiAgICBmb250V2VpZ2h0OiB0aGVtZS52YXJpYWJsZXMud2VpZ2h0LmJvbGQsXG4gICAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiZbZGlzYWJsZWRdLCAmOmRpc2FibGVkXCI6IHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmJ1dHRvbi5kaXNhYmxlZCxcbiAgICAgIHBvaW50ZXJFdmVudHM6IFwibm9uZVwiLFxuICAgIH0sXG5cbiAgICAuLi4odmFyaWFudCA9PT0gXCJzZWNvbmRhcnlcIiAmJiB7XG4gICAgICBib3JkZXI6IFwiMXB4IHNvbGlkXCIsXG4gICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHQsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICBwYWRkaW5nOiBwYXJzZUludCh0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4cywgMTApIC0gMSxcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi5zZWNvbmRhcnksXG4gICAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmljb24ucHJpbWFyeSxcbiAgICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmFjdGl2ZSxcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5hY3RpdmUsXG4gICAgICB9LFxuICAgICAgXCImOmRpc2FibGVkXCI6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgICAgfSxcbiAgICB9KSxcblxuICAgIC4uLih2YXJpYW50ID09PSBcInRlcnRpYXJ5XCIgJiYge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5kZWZhdWx0LFxuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5pY29uLnNlY29uZGFyeSxcbiAgICAgIFwiJjpob3ZlclwiOiB7XG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgICB9LFxuICAgICAgXCImOmFjdGl2ZVwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi5wcmltYXJ5LFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgICAgIH0sXG4gICAgICBcIiY6ZGlzYWJsZWRcIjoge1xuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmRlZmF1bHQsXG4gICAgICB9LFxuICAgIH0pLFxuXG4gICAgLi4uKHZhcmlhbnQgPT09IFwicXVhdGVybmFyeVwiICYmIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi50ZXJ0aWFyeSxcbiAgICAgIFwiOmhvdmVyXCI6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICAgIH0sXG4gICAgICBcIjphY3RpdmVcIjoge1xuICAgICAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmljb24uc2Vjb25kYXJ5LFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnRyYW5zcGFyZW50LmFjdGl2ZSxcbiAgICAgIH0sXG4gICAgICBcIjpkaXNhYmxlZFwiOiB7XG4gICAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuaWNvbi5zZWNvbmRhcnksXG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICAgIH0sXG4gICAgfSksXG5cbiAgICAuLi4oc3F1YXJlQ29ybmVycyAmJiB7XG4gICAgICBib3JkZXJSYWRpdXM6IFwiMFwiLFxuICAgIH0pLFxuICAgIC4uLigoc2l6ZSA9PT0gXCJzXCIgfHwgc2l6ZSA9PT0gXCJtXCIpICYmIHtcbiAgICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgdHlwZSBQaWN0b2dyYW1CdXR0b25Qcm9wcyA9IHtcbiAgLyoqIFRoZSBjZW50ZXJlZCBpY29uIHRvIGJlIGRpc3BsYXllZC4gKi9cbiAgaWNvbjogSWNvbk5hbWU7XG4gIC8qKiBJZiB0cnVlLCB0aGUgYnV0dG9uIGhhcyBzcXVhcmUgY29ybmVycy4gKi9cbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG4gIC8qKiBTaXplICovXG4gIHNpemU/OiBcInhzXCIgfCBcInNcIiB8IFwibVwiO1xuICB2YXJpYW50PzogUGljdG9ncmFtVmFyaWF0aW9ucztcbn0gJiBPbWl0PFxuICBCdXR0b25Qcm9wcyxcbiAgfCBcInZhcmlhbnRcIlxuICB8IFwic2l6ZVwiXG4gIHwgXCJsZWZ0SWNvblwiXG4gIHwgXCJyaWdodEljb25cIlxuICB8IFwiZnVsbFdpZHRoXCJcbiAgfCBcImRlc3RydWN0aXZlXCJcbiAgfCBcInByaXZhdGVQcm9wc1wiXG4gIHwgXCJsb2FkaW5nXCJcbj47XG5cbnR5cGUgUGljdG9ncmFtQnV0dG9uQ29tcG9uZW50ID0gPEMgZXh0ZW5kcyBSZWFjdC5FbGVtZW50VHlwZSA9IFwiYnV0dG9uXCI+KFxuICBwcm9wczogUG9seW1vcnBoaWNDb21wb25lbnRQcm9wc1dpdGhSZWY8QywgUGljdG9ncmFtQnV0dG9uUHJvcHM+XG4pID0+IFJlYWN0LlJlYWN0RWxlbWVudCB8IG51bGw7XG5cbmV4cG9ydCBjb25zdCBQaWN0b2dyYW1CdXR0b246IFBpY3RvZ3JhbUJ1dHRvbkNvbXBvbmVudCA9IFJlYWN0LmZvcndhcmRSZWYoXG4gIDxDIGV4dGVuZHMgUmVhY3QuRWxlbWVudFR5cGUgPSBcImJ1dHRvblwiPihcbiAgICB7XG4gICAgICBhcmlhQXR0cmlidXRlcyxcbiAgICAgIHR5cGUgPSBcImJ1dHRvblwiLFxuICAgICAgc2l6ZSA9IFwieHNcIixcbiAgICAgIHZhcmlhbnQgPSBcInRlcnRpYXJ5XCIsXG4gICAgICBkaXNhYmxlZCA9IGZhbHNlLFxuICAgICAgb25DbGljayxcbiAgICAgIG9uRm9jdXMsXG4gICAgICBvbkJsdXIsXG4gICAgICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgICAgIGFzLFxuICAgICAgaWNvbixcbiAgICAgIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgICAgIC4uLnJlc3RcbiAgICB9OiBQb2x5bW9ycGhpY0NvbXBvbmVudFByb3BzV2l0aFJlZjxDLCBQaWN0b2dyYW1CdXR0b25Qcm9wcz4sXG4gICAgcmVmPzogUG9seW1vcnBoaWNSZWY8Qz5cbiAgKSA9PiB7XG4gICAgY29uc3QgaGFuZGxlQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAgIChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGlmIChkaXNhYmxlZCkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAob25DbGljaykge1xuICAgICAgICAgIG9uQ2xpY2soZSk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBbZGlzYWJsZWQsIG9uQ2xpY2tdXG4gICAgKTtcbiAgICBjb25zdCBpY29uU2l6ZSA9IHNpemUgPT09IFwibVwiID8gXCJtXCIgOiBcInNcIjtcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkUGljdG9ncmFtQnV0dG9uXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgICBkYXRhLWRzLWlkPVwiUGljdG9ncmFtQnV0dG9uXCJcbiAgICAgICAgYXM9e2FzfVxuICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgIHR5cGU9e2FzICYmIGFzICE9PSBcImJ1dHRvblwiID8gdW5kZWZpbmVkIDogdHlwZX1cbiAgICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgc3F1YXJlQ29ybmVycz17c3F1YXJlQ29ybmVyc31cbiAgICAgICAgb25DbGljaz17aGFuZGxlQ2xpY2t9XG4gICAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICAgIG9uQmx1cj17b25CbHVyfVxuICAgICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgICAgIHsuLi5yZXN0fVxuICAgICAgPlxuICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBzaXplPXtpY29uU2l6ZX1cbiAgICAgICAgICAgIG5hbWU9e2ljb259XG4gICAgICAgICAgICBkYXRhLXRlc3RpZD17aWNvbn1cbiAgICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2ljb259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9JbmxpbmU+XG4gICAgICA8L1N0eWxlZFBpY3RvZ3JhbUJ1dHRvbj5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWE4QiJ9 */");export const PictogramButton=React.forwardRef(({ariaAttributes,type="button",size="xs",variant="tertiary",disabled=!1,onClick,onFocus,onBlur,"data-e2e-test-id":dataE2eTestId,as,icon,squareCorners=!1,...rest},ref)=>{let handleClick=useCallback(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]);return React.createElement(StyledPictogramButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PictogramButton",as:as,disabled:disabled,type:as&&"button"!==as?void 0:type,variant:variant,size:size,squareCorners:squareCorners,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},React.createElement(Inline,{vAlignItems:"center",alignItems:"center",space:"xxs",noWrap:!0},React.createElement(Icon,{size:"m"===size?"m":"s",name:icon,"data-testid":icon,"data-e2e-test-id":icon})))});
1
+ import React,{useCallback}from"react";import styled from"@emotion/styled";import{Icon}from"../Icon/Icon";import{Inline}from"../Inline/Inline";import{Tooltip}from"../Tooltip/Tooltip";let StyledPictogramButton=styled("button",{target:"e4iatcg0",label:"StyledPictogramButton"})(({theme,variant,size,squareCorners})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},border:0,display:"inline-block",textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,padding:theme.variables.size.spacing.xxs,cursor:"pointer","&[disabled], &:disabled":{opacity:theme.variables.opacity.button.disabled,pointerEvents:"none"},..."secondary"===variant&&{border:"1px solid",borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.default,padding:parseInt(theme.variables.size.spacing.xxs,10)-1,color:theme.values.color.icon.secondary,"&:hover":{color:theme.values.color.icon.primary,borderColor:theme.values.color.border.primary.default,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{borderColor:theme.values.color.border.primary.active,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."tertiary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.secondary,"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},"&:active":{color:theme.values.color.icon.primary,backgroundColor:theme.values.color.background.transparent.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default}},..."quaternary"===variant&&{backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.icon.tertiary,":hover":{backgroundColor:theme.values.color.background.transparent.hover},":active":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.active},":disabled":{color:theme.values.color.icon.secondary,backgroundColor:theme.values.color.background.transparent.default}},...squareCorners&&{borderRadius:"0"},...("s"===size||"m"===size)&&{padding:theme.variables.size.spacing.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PictogramButton/PictogramButton.tsx","sources":["src/components/PictogramButton/PictogramButton.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { ButtonProps } from \"../Button/Button\";\nimport type {\n  PictogramVariations,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\n\nconst StyledPictogramButton = styled.button<Partial<PictogramButtonProps>>(\n  ({ theme, variant, size, squareCorners }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    border: 0,\n    display: \"inline-block\",\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    padding: theme.variables.size.spacing.xxs,\n    cursor: \"pointer\",\n    \"&[disabled], &:disabled\": {\n      opacity: theme.variables.opacity.button.disabled,\n      pointerEvents: \"none\",\n    },\n\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      borderColor: theme.values.color.border.primary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      padding: parseInt(theme.variables.size.spacing.xxs, 10) - 1,\n      color: theme.values.color.icon.secondary,\n      \"&:hover\": {\n        color: theme.values.color.icon.primary,\n        borderColor: theme.values.color.border.primary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \"&:active\": {\n        borderColor: theme.values.color.border.primary.active,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \"&:disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n      },\n    }),\n\n    ...(variant === \"tertiary\" && {\n      backgroundColor: theme.values.color.background.transparent.default,\n      color: theme.values.color.icon.secondary,\n      \"&:hover\": {\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \"&:active\": {\n        color: theme.values.color.icon.primary,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \"&:disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n      },\n    }),\n\n    ...(variant === \"quaternary\" && {\n      backgroundColor: theme.values.color.background.transparent.default,\n      color: theme.values.color.icon.tertiary,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":active\": {\n        color: theme.values.color.icon.secondary,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \":disabled\": {\n        color: theme.values.color.icon.secondary,\n        backgroundColor: theme.values.color.background.transparent.default,\n      },\n    }),\n\n    ...(squareCorners && {\n      borderRadius: \"0\",\n    }),\n    ...((size === \"s\" || size === \"m\") && {\n      padding: theme.variables.size.spacing.xs,\n    }),\n  })\n);\n\nexport type PictogramButtonProps = {\n  /** The centered icon to be displayed. */\n  icon: IconName;\n  /** If true, the button has square corners. */\n  squareCorners?: boolean;\n  /** Size */\n  size?: \"xs\" | \"s\" | \"m\";\n  variant?: PictogramVariations;\n  label?: string\n} & Omit<\n  ButtonProps,\n  | \"variant\"\n  | \"size\"\n  | \"leftIcon\"\n  | \"rightIcon\"\n  | \"fullWidth\"\n  | \"destructive\"\n  | \"privateProps\"\n  | \"loading\"\n>;\n\ntype PictogramButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, PictogramButtonProps>\n) => React.ReactElement | null;\n\nexport const PictogramButton: PictogramButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      ariaAttributes,\n      type = \"button\",\n      size = \"xs\",\n      variant = \"tertiary\",\n      disabled = false,\n      onClick,\n      onFocus,\n      onBlur,\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      icon,\n      label,\n      squareCorners = false,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, PictogramButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n    const iconSize = size === \"m\" ? \"m\" : \"s\";\n    const pictogramContent = \n        <StyledPictogramButton\n            ref={ref}\n            data-e2e-test-id={dataE2eTestId}\n            data-ds-id=\"PictogramButton\"\n            as={as}\n            disabled={disabled}\n            type={as && as !== \"button\" ? undefined : type}\n            variant={variant}\n            size={size}\n            squareCorners={squareCorners}\n            onClick={handleClick}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            {...ariaAttributes}\n            {...rest}\n            >\n              <Inline vAlignItems=\"center\" alignItems=\"center\" space=\"xxs\" noWrap>\n                <Icon\n                    size={iconSize}\n                    name={icon}\n                    data-testid={icon}\n                    data-e2e-test-id={icon}\n                />\n              </Inline>\n        </StyledPictogramButton>\n\n    return (\n      label\n      ? <Tooltip content={label}>\n          { pictogramContent }\n        </Tooltip>\n      : pictogramContent\n    );\n  }\n);\n"],"names":[],"mappings":"AAc8B"} */");export const PictogramButton=React.forwardRef(({ariaAttributes,type="button",size="xs",variant="tertiary",disabled=!1,onClick,onFocus,onBlur,"data-e2e-test-id":dataE2eTestId,as,icon,label,squareCorners=!1,...rest},ref)=>{let handleClick=useCallback(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]),pictogramContent=React.createElement(StyledPictogramButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PictogramButton",as:as,disabled:disabled,type:as&&"button"!==as?void 0:type,variant:variant,size:size,squareCorners:squareCorners,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},React.createElement(Inline,{vAlignItems:"center",alignItems:"center",space:"xxs",noWrap:!0},React.createElement(Icon,{size:"m"===size?"m":"s",name:icon,"data-testid":icon,"data-e2e-test-id":icon})));return label?React.createElement(Tooltip,{content:label},pictogramContent):pictogramContent});
@@ -64,4 +64,4 @@ export * from "./components/Form/MaskedInput/MaskedInput";
64
64
  export * from "./components/Utilities/Expandable/Expandable";
65
65
  export * from "./components/QBankRichText/QBankRichText";
66
66
  export * from "./components/Tutorialtip/Tutorialtip";
67
- export * from "./components/EntityTree/EntityTree";
67
+ export * from "./components/EntityTree";
@@ -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/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header/Header";export*from"./components/Typography/Text/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Select/Select";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree/EntityTree";
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/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header/Header";export*from"./components/Typography/Text/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Select/Select";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";
@@ -90,6 +90,7 @@
90
90
  "illustration": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M2 4a2 2 0 012-2h8a2 2 0 012 2v8a2 2 0 01-2 2H4a2 2 0 01-2-2z\" clip-rule=\"evenodd\" />\n <g fill=\"currentColor\">\n <path d=\"M10 12a2 2 0 100-4 2 2 0 000 4z\" />\n <path fill-rule=\"evenodd\" d=\"M8.92 7.2L7 4 4 9h3.17a3.009 3.009 0 011.75-1.8z\" clip-rule=\"evenodd\" />\n </g>\n</svg>",
91
91
  "image": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"\n d=\"M2 4a2 2 0 012-2h8a2 2 0 012 2v8a2 2 0 01-2 2H4a2 2 0 01-2-2z\" clip-rule=\"evenodd\" />\n <path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M5.5 7a1.5 1.5 0 100-3 1.5 1.5 0 000 3z\" clip-rule=\"evenodd\" />\n <path stroke=\"currentColor\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M14 11l-4-4-7 7\" />\n</svg>",
92
92
  "info": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-info\">\n <circle cx=\"8\" cy=\"8\" r=\"7\"/>\n <path d=\"M8 11V8M8 5h.01\"/>\n</svg>\n",
93
+ "institution": "<svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<path d=\"M7 9V7H9V9H7Z\" fill=\"currentColor\"/>\n<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M9 1V1.18018L9.80383 1.01941C10.3454 0.911101 10.8722 1.26232 10.9805 1.80388C11.0888 2.34544 10.7376 2.87226 10.1961 2.98058L9.58932 3.10192L12.1396 4.87009C12.6785 5.24375 13 5.85789 13 6.51369V7H14C15.1046 7 16 7.89543 16 9V13C16 14.1046 15.1046 15 14 15H2C0.89543 15 0 14.1046 0 13V9C0 7.89543 0.89543 7 2 7H3V6.51369C3 5.85789 3.32151 5.24375 3.86044 4.87009L6.86044 2.79009C6.90602 2.75849 6.95258 2.72899 7 2.70159V1C7 0.447717 7.44772 0 8 0C8.55229 0 9 0.447717 9 1ZM11 13V6.51369L8 4.43368L5 6.51369V13H7V10H9V13H11ZM2 9H3V13L2 13V9ZM14 13L13 13V9H14V13Z\" fill=\"currentColor\"/>\n</svg>\n",
93
94
  "layers": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path d=\"M8 1.5l-7 3 7 3 7-3z\" clip-rule=\"evenodd\" />\n <path d=\"M1 8l7 3 7-3M1 11.5l7 3 7-3\" />\n </g>\n</svg>",
94
95
  "link": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path d=\"M6.667 8.605a3.478 3.478 0 005.244.376l2.087-2.087A3.478 3.478 0 009.08 1.976l-1.196 1.19\" />\n <path d=\"M9.308 7.391a3.478 3.478 0 00-5.245-.375L1.976 9.102a3.478 3.478 0 004.918 4.918l1.19-1.19\" />\n </g>\n</svg>",
95
96
  "link2": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path\n d=\"M10 5h1.875c.829 0 1.624.316 2.21.879A2.94 2.94 0 0115 8c0 1.657-1.4 3-3.125 3H10M6 11H4.125a3.192 3.192 0 01-2.21-.879A2.94 2.94 0 011 8c0-1.657 1.4-3 3.125-3H6M5.333 8h5.334\" />\n </g>\n</svg>",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "2.3.3",
3
+ "version": "2.3.4",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",