@commercetools-frontend/cookie-consent 3.2.3 → 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -434,7 +434,7 @@ var _ref4 = process.env.NODE_ENV === "production" ? {
434
434
  styles: "text-decoration:underline"
435
435
  } : {
436
436
  name: "8ke99t-underline",
437
- styles: "text-decoration:underline;label:underline;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAkCuB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      href=\"\"\n      css={underline}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
437
+ styles: "text-decoration:underline;label:underline;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAkCuB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  type CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      css={underline}\n      href=\"\"\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
438
438
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
439
439
  };
440
440
  const NavigationLink = _ref5 => {
@@ -442,12 +442,12 @@ const NavigationLink = _ref5 => {
442
442
  label = _ref5.label;
443
443
  const underline = _ref4;
444
444
  return jsxRuntime.jsx("a", {
445
+ css: underline,
446
+ href: "",
445
447
  onClick: e => {
446
448
  e.preventDefault();
447
449
  onClick();
448
450
  },
449
- href: "",
450
- css: underline,
451
451
  children: label
452
452
  });
453
453
  };
@@ -456,7 +456,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
456
456
  styles: "text-decoration:underline"
457
457
  } : {
458
458
  name: "8ke99t-underline",
459
- styles: "text-decoration:underline;label:underline;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA0DuB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      href=\"\"\n      css={underline}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
459
+ styles: "text-decoration:underline;label:underline;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA0DuB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  type CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      css={underline}\n      href=\"\"\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
460
460
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
461
461
  };
462
462
  const InformationLink = _ref6 => {
@@ -466,8 +466,8 @@ const InformationLink = _ref6 => {
466
466
  return jsxRuntime.jsx("a", {
467
467
  css: underline,
468
468
  href: to,
469
- target: "_blank",
470
469
  rel: "noopener noreferrer",
470
+ target: "_blank",
471
471
  children: label
472
472
  });
473
473
  };
@@ -476,7 +476,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
476
476
  styles: "text-decoration:underline"
477
477
  } : {
478
478
  name: "8ke99t-underline",
479
- styles: "text-decoration:underline;label:underline;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2EuB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      href=\"\"\n      css={underline}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
479
+ styles: "text-decoration:underline;label:underline;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2EuB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  type CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      css={underline}\n      href=\"\"\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
480
480
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
481
481
  };
482
482
  const DetailLink = _ref7 => {
@@ -486,8 +486,8 @@ const DetailLink = _ref7 => {
486
486
  return jsxRuntime.jsx("a", {
487
487
  css: underline,
488
488
  href: to,
489
- target: "_blank",
490
489
  rel: "noopener noreferrer",
490
+ target: "_blank",
491
491
  children: jsxRuntime.jsx(Text__default["default"].Detail, {
492
492
  tone: "primary",
493
493
  children: label
@@ -499,7 +499,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
499
499
  styles: "padding-right:10px"
500
500
  } : {
501
501
  name: "ey0yn8-bumpToggle",
502
- styles: "padding-right:10px;label:bumpToggle;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA4GwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      href=\"\"\n      css={underline}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
502
+ styles: "padding-right:10px;label:bumpToggle;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA4GwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  type CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      css={underline}\n      href=\"\"\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
503
503
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
504
504
  };
505
505
  const CookieConsentBodyPrimary = _ref8 => {
@@ -593,7 +593,7 @@ const CookieConsentBodyDetails = _ref9 => {
593
593
  return jsxRuntime.jsxs(jsxRuntime.Fragment, {
594
594
  children: [jsxRuntime.jsx("div", {
595
595
  ref: scrollRef,
596
- css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsNgB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      href=\"\"\n      css={underline}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} target=\"_blank\" rel=\"noopener noreferrer\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */")
596
+ css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsNgB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  type CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a\n      css={underline}\n      href=\"\"\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n    >\n      {label}\n    </a>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      {label}\n    </a>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const underline = css`\n    text-decoration: underline;\n  `;\n\n  return (\n    <a css={underline} href={to} rel=\"noopener noreferrer\" target=\"_blank\">\n      <Text.Detail tone=\"primary\">{label}</Text.Detail>\n    </a>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */")
597
597
  }), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
598
598
  scale: "l",
599
599
  children: [jsxRuntime.jsx(NavigationLink, {
@@ -728,7 +728,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
728
728
  styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999"
729
729
  } : {
730
730
  name: "t2qh0u-CookieConsentBanner",
731
- styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999;label:CookieConsentBanner;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0VjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgeyB1bnNldENvbnNlbnRDb29raWUgfSBmcm9tICcuLi8uLi9jb3JlJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQkFOTkVSX0hFSUdIVCA9IDY0O1xuXG4vKipcbiAqIERlZmluZSBhIGZpeGVkIGRhdGUgdG8gZGV0ZXJtaW5lIHRoZSB2YWxpZGl0eSBvZiBjb25zZW50IGNvb2tpZXMuIFVwZGF0ZSBhcyByZXF1aXJlZC5cbiAqXG4gKiBDb29raWVzIHNldCBiZWZvcmUgdGhpcyBkYXRlIGFyZSBjb25zaWRlcmVkIGludmFsaWQgZHVlIHRvIG5ldyBjb29raWUgcmVndWxhdGlvbnMgb3IgY2hhbmdlcy5cbiAqL1xuY29uc3QgQ09PS0lFX1JFVk9DQVRJT05fREFURSA9XG4gICdXZWQgTWF5IDAxIDIwMjQgMTI6MDA6MDAgR01ULTA0MDAgKEVhc3Rlcm4gRGF5bGlnaHQgVGltZSknO1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBSZXZva2UgY29va2llcyBwcmlvciB0byBhIGNlcnRhaW4gZGF0ZSB0byBlbnN1cmUgdXNlciBwcmVmZXJlbmNlcyBhcmUgdXAtdG8tZGF0ZSB3aXRoIGNvb2tpZSBjb25maWd1cmF0aW9uXG4gICAgdW5zZXRDb25zZW50Q29va2llKG5ldyBEYXRlKENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUpKTtcbiAgfSwgW10pO1xuXG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgY29uc3QgdW5kZXJsaW5lID0gY3NzYFxuICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH07XG4gIGA7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlXG4gICAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgICBwcml2YWN5TGluazogKFxuICAgICAgICAgICAgICAgICAgICA8YVxuICAgICAgICAgICAgICAgICAgICAgIGtleT1cInByaXZhY3ktbGlua1wiXG4gICAgICAgICAgICAgICAgICAgICAgY3NzPXt1bmRlcmxpbmV9XG4gICAgICAgICAgICAgICAgICAgICAgaHJlZj17Q09PS0lFX0NPTlNFTlRfTElOS1MuUFJJVkFDWV9QT0xJQ1l9XG4gICAgICAgICAgICAgICAgICAgICAgcmVsPVwibm9vcGVuZXIgbm9yZWZlcnJlclwiXG4gICAgICAgICAgICAgICAgICAgICAgdGFyZ2V0PVwiX2JsYW5rXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLnByaXZhY3lQb2xpY3lMaW5rKX1cbiAgICAgICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8YVxuICAgICAgICAgICAgICAgICAgICAgIGtleT1cIm1vZGFsLWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9XCJcIlxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAge2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYmFubmVyQ29va2llc01vZGFsTGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgICAgPFByaW1hcnlCdXR0b25cbiAgICAgICAgICAgICAgbGFiZWw9e2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYnV0dG9uTGFiZWwpfVxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgc2V0Q29uc2VudChjcmVhdGVDb25zZW50R3JvdXBzKCkpO1xuICAgICAgICAgICAgICAgIHNldEJhbm5lckNsb3NlZCh0cnVlKTtcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgc2l6ZT1cIm1lZGl1bVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPENvb2tpZUNvbnNlbnRNb2RhbFxuICAgICAgICAgIGNsb3NlTW9kYWw9e2Nsb3NlTW9kYWx9XG4gICAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICAgIHNldEJhbm5lckNsb3NlZD17c2V0QmFubmVyQ2xvc2VkfVxuICAgICAgICAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */",
731
+ styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999;label:CookieConsentBanner;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0VjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgeyB1bnNldENvbnNlbnRDb29raWUgfSBmcm9tICcuLi8uLi9jb3JlJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQkFOTkVSX0hFSUdIVCA9IDY0O1xuXG4vKipcbiAqIERlZmluZSBhIGZpeGVkIGRhdGUgdG8gZGV0ZXJtaW5lIHRoZSB2YWxpZGl0eSBvZiBjb25zZW50IGNvb2tpZXMuIFVwZGF0ZSBhcyByZXF1aXJlZC5cbiAqXG4gKiBDb29raWVzIHNldCBiZWZvcmUgdGhpcyBkYXRlIGFyZSBjb25zaWRlcmVkIGludmFsaWQgZHVlIHRvIG5ldyBjb29raWUgcmVndWxhdGlvbnMgb3IgY2hhbmdlcy5cbiAqL1xuY29uc3QgQ09PS0lFX1JFVk9DQVRJT05fREFURSA9XG4gICdXZWQgTWF5IDAxIDIwMjQgMTI6MDA6MDAgR01ULTA0MDAgKEVhc3Rlcm4gRGF5bGlnaHQgVGltZSknO1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBSZXZva2UgY29va2llcyBwcmlvciB0byBhIGNlcnRhaW4gZGF0ZSB0byBlbnN1cmUgdXNlciBwcmVmZXJlbmNlcyBhcmUgdXAtdG8tZGF0ZSB3aXRoIGNvb2tpZSBjb25maWd1cmF0aW9uXG4gICAgdW5zZXRDb25zZW50Q29va2llKG5ldyBEYXRlKENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUpKTtcbiAgfSwgW10pO1xuXG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgY29uc3QgdW5kZXJsaW5lID0gY3NzYFxuICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH07XG4gIGA7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlXG4gICAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgICBwcml2YWN5TGluazogKFxuICAgICAgICAgICAgICAgICAgICA8YVxuICAgICAgICAgICAgICAgICAgICAgIGtleT1cInByaXZhY3ktbGlua1wiXG4gICAgICAgICAgICAgICAgICAgICAgY3NzPXt1bmRlcmxpbmV9XG4gICAgICAgICAgICAgICAgICAgICAgaHJlZj17Q09PS0lFX0NPTlNFTlRfTElOS1MuUFJJVkFDWV9QT0xJQ1l9XG4gICAgICAgICAgICAgICAgICAgICAgcmVsPVwibm9vcGVuZXIgbm9yZWZlcnJlclwiXG4gICAgICAgICAgICAgICAgICAgICAgdGFyZ2V0PVwiX2JsYW5rXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLnByaXZhY3lQb2xpY3lMaW5rKX1cbiAgICAgICAgICAgICAgICAgICAgPC9hPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8YVxuICAgICAgICAgICAgICAgICAgICAgIGtleT1cIm1vZGFsLWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9XCJcIlxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAge2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYmFubmVyQ29va2llc01vZGFsTGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgICAgPFByaW1hcnlCdXR0b25cbiAgICAgICAgICAgICAgbGFiZWw9e2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYnV0dG9uTGFiZWwpfVxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgc2V0Q29uc2VudChjcmVhdGVDb25zZW50R3JvdXBzKCkpO1xuICAgICAgICAgICAgICAgIHNldEJhbm5lckNsb3NlZCh0cnVlKTtcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgc2l6ZT1cIm1lZGl1bVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPENvb2tpZUNvbnNlbnRNb2RhbFxuICAgICAgICAgIGNsb3NlTW9kYWw9e2Nsb3NlTW9kYWx9XG4gICAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICAgIHNldEJhbm5lckNsb3NlZD17c2V0QmFubmVyQ2xvc2VkfVxuICAgICAgICAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */",
732
732
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
733
733
  };
734
734
  const CookieConsentBanner = bannerProps => {
@@ -761,16 +761,16 @@ const CookieConsentBanner = bannerProps => {
761
761
  functionalCookies: true,
762
762
  performanceCookies: true
763
763
  });
764
- const underline = /*#__PURE__*/react$1.css("text-decoration:underline;color:", designSystem.designTokens.colorPrimary98, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:underline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUR1QiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdXNlSW50bCwgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IHsgdW5zZXRDb25zZW50Q29va2llIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuLyoqXG4gKiBEZWZpbmUgYSBmaXhlZCBkYXRlIHRvIGRldGVybWluZSB0aGUgdmFsaWRpdHkgb2YgY29uc2VudCBjb29raWVzLiBVcGRhdGUgYXMgcmVxdWlyZWQuXG4gKlxuICogQ29va2llcyBzZXQgYmVmb3JlIHRoaXMgZGF0ZSBhcmUgY29uc2lkZXJlZCBpbnZhbGlkIGR1ZSB0byBuZXcgY29va2llIHJlZ3VsYXRpb25zIG9yIGNoYW5nZXMuXG4gKi9cbmNvbnN0IENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUgPVxuICAnV2VkIE1heSAwMSAyMDI0IDEyOjAwOjAwIEdNVC0wNDAwIChFYXN0ZXJuIERheWxpZ2h0IFRpbWUpJztcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgLy8gUmV2b2tlIGNvb2tpZXMgcHJpb3IgdG8gYSBjZXJ0YWluIGRhdGUgdG8gZW5zdXJlIHVzZXIgcHJlZmVyZW5jZXMgYXJlIHVwLXRvLWRhdGUgd2l0aCBjb29raWUgY29uZmlndXJhdGlvblxuICAgIHVuc2V0Q29uc2VudENvb2tpZShuZXcgRGF0ZShDT09LSUVfUkVWT0NBVElPTl9EQVRFKSk7XG4gIH0sIFtdKTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0IHVuZGVybGluZSA9IGNzc2BcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICBgO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJwcml2YWN5LWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5wcml2YWN5UG9saWN5TGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJtb2RhbC1saW5rXCJcbiAgICAgICAgICAgICAgICAgICAgICBjc3M9e3VuZGVybGluZX1cbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgICBocmVmPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmspfVxuICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */");
764
+ const underline = /*#__PURE__*/react$1.css("text-decoration:underline;color:", designSystem.designTokens.colorPrimary98, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:underline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUR1QiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdXNlSW50bCwgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IHsgdW5zZXRDb25zZW50Q29va2llIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuLyoqXG4gKiBEZWZpbmUgYSBmaXhlZCBkYXRlIHRvIGRldGVybWluZSB0aGUgdmFsaWRpdHkgb2YgY29uc2VudCBjb29raWVzLiBVcGRhdGUgYXMgcmVxdWlyZWQuXG4gKlxuICogQ29va2llcyBzZXQgYmVmb3JlIHRoaXMgZGF0ZSBhcmUgY29uc2lkZXJlZCBpbnZhbGlkIGR1ZSB0byBuZXcgY29va2llIHJlZ3VsYXRpb25zIG9yIGNoYW5nZXMuXG4gKi9cbmNvbnN0IENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUgPVxuICAnV2VkIE1heSAwMSAyMDI0IDEyOjAwOjAwIEdNVC0wNDAwIChFYXN0ZXJuIERheWxpZ2h0IFRpbWUpJztcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgLy8gUmV2b2tlIGNvb2tpZXMgcHJpb3IgdG8gYSBjZXJ0YWluIGRhdGUgdG8gZW5zdXJlIHVzZXIgcHJlZmVyZW5jZXMgYXJlIHVwLXRvLWRhdGUgd2l0aCBjb29raWUgY29uZmlndXJhdGlvblxuICAgIHVuc2V0Q29uc2VudENvb2tpZShuZXcgRGF0ZShDT09LSUVfUkVWT0NBVElPTl9EQVRFKSk7XG4gIH0sIFtdKTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0IHVuZGVybGluZSA9IGNzc2BcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICBgO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJwcml2YWN5LWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5wcml2YWN5UG9saWN5TGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJtb2RhbC1saW5rXCJcbiAgICAgICAgICAgICAgICAgICAgICBjc3M9e3VuZGVybGluZX1cbiAgICAgICAgICAgICAgICAgICAgICBocmVmPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmspfVxuICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */");
765
765
  if (bannerClosed || hasGivenFunctionalCookieConsent || hasGivenPerformanceCookieConsent) return null;
766
766
  return (
767
767
  // TODO: use lower z-index, prefer ranges per use-case
768
768
  jsxRuntime.jsx("div", {
769
769
  css: _ref,
770
770
  children: jsxRuntime.jsxs("div", {
771
- css: /*#__PURE__*/react$1.css("position:sticky;top:calc(100% - ", BANNER_HEIGHT, "px - ", designSystem.designTokens.spacingXl, ");display:flex;flex-direction:column;align-items:center;z-index:9999;width:100%;pointer-events:auto;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkVnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdXNlSW50bCwgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IHsgdW5zZXRDb25zZW50Q29va2llIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuLyoqXG4gKiBEZWZpbmUgYSBmaXhlZCBkYXRlIHRvIGRldGVybWluZSB0aGUgdmFsaWRpdHkgb2YgY29uc2VudCBjb29raWVzLiBVcGRhdGUgYXMgcmVxdWlyZWQuXG4gKlxuICogQ29va2llcyBzZXQgYmVmb3JlIHRoaXMgZGF0ZSBhcmUgY29uc2lkZXJlZCBpbnZhbGlkIGR1ZSB0byBuZXcgY29va2llIHJlZ3VsYXRpb25zIG9yIGNoYW5nZXMuXG4gKi9cbmNvbnN0IENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUgPVxuICAnV2VkIE1heSAwMSAyMDI0IDEyOjAwOjAwIEdNVC0wNDAwIChFYXN0ZXJuIERheWxpZ2h0IFRpbWUpJztcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgLy8gUmV2b2tlIGNvb2tpZXMgcHJpb3IgdG8gYSBjZXJ0YWluIGRhdGUgdG8gZW5zdXJlIHVzZXIgcHJlZmVyZW5jZXMgYXJlIHVwLXRvLWRhdGUgd2l0aCBjb29raWUgY29uZmlndXJhdGlvblxuICAgIHVuc2V0Q29uc2VudENvb2tpZShuZXcgRGF0ZShDT09LSUVfUkVWT0NBVElPTl9EQVRFKSk7XG4gIH0sIFtdKTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0IHVuZGVybGluZSA9IGNzc2BcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICBgO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJwcml2YWN5LWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5wcml2YWN5UG9saWN5TGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJtb2RhbC1saW5rXCJcbiAgICAgICAgICAgICAgICAgICAgICBjc3M9e3VuZGVybGluZX1cbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgICBocmVmPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmspfVxuICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */"),
771
+ css: /*#__PURE__*/react$1.css("position:sticky;top:calc(100% - ", BANNER_HEIGHT, "px - ", designSystem.designTokens.spacingXl, ");display:flex;flex-direction:column;align-items:center;z-index:9999;width:100%;pointer-events:auto;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkVnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdXNlSW50bCwgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IHsgdW5zZXRDb25zZW50Q29va2llIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuLyoqXG4gKiBEZWZpbmUgYSBmaXhlZCBkYXRlIHRvIGRldGVybWluZSB0aGUgdmFsaWRpdHkgb2YgY29uc2VudCBjb29raWVzLiBVcGRhdGUgYXMgcmVxdWlyZWQuXG4gKlxuICogQ29va2llcyBzZXQgYmVmb3JlIHRoaXMgZGF0ZSBhcmUgY29uc2lkZXJlZCBpbnZhbGlkIGR1ZSB0byBuZXcgY29va2llIHJlZ3VsYXRpb25zIG9yIGNoYW5nZXMuXG4gKi9cbmNvbnN0IENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUgPVxuICAnV2VkIE1heSAwMSAyMDI0IDEyOjAwOjAwIEdNVC0wNDAwIChFYXN0ZXJuIERheWxpZ2h0IFRpbWUpJztcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgLy8gUmV2b2tlIGNvb2tpZXMgcHJpb3IgdG8gYSBjZXJ0YWluIGRhdGUgdG8gZW5zdXJlIHVzZXIgcHJlZmVyZW5jZXMgYXJlIHVwLXRvLWRhdGUgd2l0aCBjb29raWUgY29uZmlndXJhdGlvblxuICAgIHVuc2V0Q29uc2VudENvb2tpZShuZXcgRGF0ZShDT09LSUVfUkVWT0NBVElPTl9EQVRFKSk7XG4gIH0sIFtdKTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0IHVuZGVybGluZSA9IGNzc2BcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICBgO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJwcml2YWN5LWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5wcml2YWN5UG9saWN5TGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJtb2RhbC1saW5rXCJcbiAgICAgICAgICAgICAgICAgICAgICBjc3M9e3VuZGVybGluZX1cbiAgICAgICAgICAgICAgICAgICAgICBocmVmPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmspfVxuICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */"),
772
772
  children: [jsxRuntime.jsx("div", {
773
- css: /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorAccent10, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow8, ";margin:0 ", designSystem.designTokens.spacingXl, ";padding:", designSystem.designTokens.spacingM, " ", designSystem.designTokens.spacingL, ";width:fit-content;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUZrQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdXNlSW50bCwgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IHsgdW5zZXRDb25zZW50Q29va2llIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuLyoqXG4gKiBEZWZpbmUgYSBmaXhlZCBkYXRlIHRvIGRldGVybWluZSB0aGUgdmFsaWRpdHkgb2YgY29uc2VudCBjb29raWVzLiBVcGRhdGUgYXMgcmVxdWlyZWQuXG4gKlxuICogQ29va2llcyBzZXQgYmVmb3JlIHRoaXMgZGF0ZSBhcmUgY29uc2lkZXJlZCBpbnZhbGlkIGR1ZSB0byBuZXcgY29va2llIHJlZ3VsYXRpb25zIG9yIGNoYW5nZXMuXG4gKi9cbmNvbnN0IENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUgPVxuICAnV2VkIE1heSAwMSAyMDI0IDEyOjAwOjAwIEdNVC0wNDAwIChFYXN0ZXJuIERheWxpZ2h0IFRpbWUpJztcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgLy8gUmV2b2tlIGNvb2tpZXMgcHJpb3IgdG8gYSBjZXJ0YWluIGRhdGUgdG8gZW5zdXJlIHVzZXIgcHJlZmVyZW5jZXMgYXJlIHVwLXRvLWRhdGUgd2l0aCBjb29raWUgY29uZmlndXJhdGlvblxuICAgIHVuc2V0Q29uc2VudENvb2tpZShuZXcgRGF0ZShDT09LSUVfUkVWT0NBVElPTl9EQVRFKSk7XG4gIH0sIFtdKTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0IHVuZGVybGluZSA9IGNzc2BcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICBgO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJwcml2YWN5LWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5wcml2YWN5UG9saWN5TGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJtb2RhbC1saW5rXCJcbiAgICAgICAgICAgICAgICAgICAgICBjc3M9e3VuZGVybGluZX1cbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgICBocmVmPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmspfVxuICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */"),
773
+ css: /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorAccent10, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow8, ";margin:0 ", designSystem.designTokens.spacingXl, ";padding:", designSystem.designTokens.spacingM, " ", designSystem.designTokens.spacingL, ";width:fit-content;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUZrQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdXNlSW50bCwgRm9ybWF0dGVkTWVzc2FnZSB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IHsgdW5zZXRDb25zZW50Q29va2llIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuLyoqXG4gKiBEZWZpbmUgYSBmaXhlZCBkYXRlIHRvIGRldGVybWluZSB0aGUgdmFsaWRpdHkgb2YgY29uc2VudCBjb29raWVzLiBVcGRhdGUgYXMgcmVxdWlyZWQuXG4gKlxuICogQ29va2llcyBzZXQgYmVmb3JlIHRoaXMgZGF0ZSBhcmUgY29uc2lkZXJlZCBpbnZhbGlkIGR1ZSB0byBuZXcgY29va2llIHJlZ3VsYXRpb25zIG9yIGNoYW5nZXMuXG4gKi9cbmNvbnN0IENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUgPVxuICAnV2VkIE1heSAwMSAyMDI0IDEyOjAwOjAwIEdNVC0wNDAwIChFYXN0ZXJuIERheWxpZ2h0IFRpbWUpJztcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgLy8gUmV2b2tlIGNvb2tpZXMgcHJpb3IgdG8gYSBjZXJ0YWluIGRhdGUgdG8gZW5zdXJlIHVzZXIgcHJlZmVyZW5jZXMgYXJlIHVwLXRvLWRhdGUgd2l0aCBjb29raWUgY29uZmlndXJhdGlvblxuICAgIHVuc2V0Q29uc2VudENvb2tpZShuZXcgRGF0ZShDT09LSUVfUkVWT0NBVElPTl9EQVRFKSk7XG4gIH0sIFtdKTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0IHVuZGVybGluZSA9IGNzc2BcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICBgO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJwcml2YWN5LWxpbmtcIlxuICAgICAgICAgICAgICAgICAgICAgIGNzcz17dW5kZXJsaW5lfVxuICAgICAgICAgICAgICAgICAgICAgIGhyZWY9e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRhcmdldD1cIl9ibGFua1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5wcml2YWN5UG9saWN5TGluayl9XG4gICAgICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJtb2RhbC1saW5rXCJcbiAgICAgICAgICAgICAgICAgICAgICBjc3M9e3VuZGVybGluZX1cbiAgICAgICAgICAgICAgICAgICAgICBocmVmPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmspfVxuICAgICAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */"),
774
774
  children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
775
775
  alignItems: "center",
776
776
  scale: "xl",
@@ -787,11 +787,11 @@ const CookieConsentBanner = bannerProps => {
787
787
  }, "privacy-link"),
788
788
  modalLink: jsxRuntime.jsx("a", {
789
789
  css: underline,
790
+ href: "",
790
791
  onClick: e => {
791
792
  e.preventDefault();
792
793
  openModal();
793
794
  },
794
- href: "",
795
795
  children: formatMessage(messages.bannerCookiesModalLink)
796
796
  }, "modal-link")
797
797
  }
@@ -437,12 +437,12 @@ const NavigationLink = _ref5 => {
437
437
  label = _ref5.label;
438
438
  const underline = _ref4;
439
439
  return jsxRuntime.jsx("a", {
440
+ css: underline,
441
+ href: "",
440
442
  onClick: e => {
441
443
  e.preventDefault();
442
444
  onClick();
443
445
  },
444
- href: "",
445
- css: underline,
446
446
  children: label
447
447
  });
448
448
  };
@@ -457,8 +457,8 @@ const InformationLink = _ref6 => {
457
457
  return jsxRuntime.jsx("a", {
458
458
  css: underline,
459
459
  href: to,
460
- target: "_blank",
461
460
  rel: "noopener noreferrer",
461
+ target: "_blank",
462
462
  children: label
463
463
  });
464
464
  };
@@ -473,8 +473,8 @@ const DetailLink = _ref7 => {
473
473
  return jsxRuntime.jsx("a", {
474
474
  css: underline,
475
475
  href: to,
476
- target: "_blank",
477
476
  rel: "noopener noreferrer",
477
+ target: "_blank",
478
478
  children: jsxRuntime.jsx(Text__default["default"].Detail, {
479
479
  tone: "primary",
480
480
  children: label
@@ -765,11 +765,11 @@ const CookieConsentBanner = bannerProps => {
765
765
  }, "privacy-link"),
766
766
  modalLink: jsxRuntime.jsx("a", {
767
767
  css: underline,
768
+ href: "",
768
769
  onClick: e => {
769
770
  e.preventDefault();
770
771
  openModal();
771
772
  },
772
- href: "",
773
773
  children: formatMessage(messages.bannerCookiesModalLink)
774
774
  }, "modal-link")
775
775
  }