@commercetools-frontend/cookie-consent 2.2.0 → 2.4.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.
@@ -1,5 +1,5 @@
1
1
  import { useMemo, useState, useEffect, Fragment as Fragment$1, createRef } from 'react';
2
- import { getRawConsentCookie, getParsedConsentCookieGroups, setConsentCookie } from '../../core/dist/commercetools-frontend-cookie-consent-core.esm.js';
2
+ import { getRawConsentCookie, getParsedConsentCookieGroups, setConsentCookie, unsetConsentCookie } from '../../core/dist/commercetools-frontend-cookie-consent-core.esm.js';
3
3
  import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
4
4
  import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
5
5
  import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
@@ -13,18 +13,18 @@ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
13
13
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
14
14
  import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
15
15
  import _Object$values from '@babel/runtime-corejs3/core-js-stable/object/values';
16
- import { css } from '@emotion/react';
17
- import { defineMessages, useIntl, FormattedMessage } from 'react-intl';
16
+ import CollapsiblePanel from '@commercetools-uikit/collapsible-panel';
18
17
  import { designTokens } from '@commercetools-uikit/design-system';
18
+ import Grid from '@commercetools-uikit/grid';
19
19
  import Link from '@commercetools-uikit/link';
20
- import PrimaryButton from '@commercetools-uikit/primary-button';
21
20
  import Spacings from '@commercetools-uikit/spacings';
22
21
  import Text from '@commercetools-uikit/text';
22
+ import ToggleInput from '@commercetools-uikit/toggle-input';
23
+ import { css } from '@emotion/react';
24
+ import { defineMessages, useIntl, FormattedMessage } from 'react-intl';
23
25
  import { ConfirmationDialog, useModalState } from '@commercetools-frontend/application-components';
26
+ import PrimaryButton from '@commercetools-uikit/primary-button';
24
27
  import { jsxs, jsx, Fragment } from '@emotion/react/jsx-runtime';
25
- import CollapsiblePanel from '@commercetools-uikit/collapsible-panel';
26
- import Grid from '@commercetools-uikit/grid';
27
- import ToggleInput from '@commercetools-uikit/toggle-input';
28
28
  import '@babel/runtime-corejs3/core-js-stable/instance/find';
29
29
  import '@babel/runtime-corejs3/core-js-stable/object/from-entries';
30
30
  import '@babel/runtime-corejs3/core-js-stable/object/entries';
@@ -57,6 +57,11 @@ function useSkipCookieConsent() {
57
57
  return Boolean(skipCookieConsent);
58
58
  }
59
59
 
60
+ const COOKIE_CONSENT_LINKS = {
61
+ PRIVACY_POLICY: 'https://commercetools.com/privacy#website',
62
+ USER_GUIDING_COOKIE_POLICY: 'https://userguiding.com/cookie-policy/'
63
+ };
64
+
60
65
  const modalMessages = defineMessages({
61
66
  title: {
62
67
  id: 'CookieConsentModal.title',
@@ -231,11 +236,6 @@ const cookieDetailDescriptions = defineMessages({
231
236
  }
232
237
  });
233
238
 
234
- const COOKIE_CONSENT_LINKS = {
235
- PRIVACY_POLICY: 'https://commercetools.com/privacy#website',
236
- USER_GUIDING_COOKIE_POLICY: 'https://userguiding.com/cookie-policy/'
237
- };
238
-
239
239
  const HOSTNAME = 'commercetools.com';
240
240
  const createCookieLink = cookieName => "https://cookiepedia.co.uk/cookies/".concat(cookieName);
241
241
  const createFunctionalCookieDetails = intl => [{
@@ -426,7 +426,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
426
426
  } : {
427
427
  name: "4sjpj8-removeDefaultSvg",
428
428
  styles: "& svg{display:none;};label:removeDefaultSvg;",
429
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsD8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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      zIndex={1000000}\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    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          togglePerformanceValue={enablePerformanceCookies}\n          toggleFunctionalValue={enableFunctionalCookies}\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"]} */",
429
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsD8B","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 Link from '@commercetools-uikit/link';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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"]} */",
430
430
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
431
431
  };
432
432
  const InformationLink = _ref5 => {
@@ -448,7 +448,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
448
448
  } : {
449
449
  name: "4sjpj8-removeDefaultSvg",
450
450
  styles: "& svg{display:none;};label:removeDefaultSvg;",
451
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2E8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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      zIndex={1000000}\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    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          togglePerformanceValue={enablePerformanceCookies}\n          toggleFunctionalValue={enableFunctionalCookies}\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"]} */",
451
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2E8B","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 Link from '@commercetools-uikit/link';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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"]} */",
452
452
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
453
453
  };
454
454
  const DetailLink = _ref6 => {
@@ -473,7 +473,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
473
473
  } : {
474
474
  name: "ey0yn8-bumpToggle",
475
475
  styles: "padding-right:10px;label:bumpToggle;",
476
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAgHwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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      zIndex={1000000}\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    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          togglePerformanceValue={enablePerformanceCookies}\n          toggleFunctionalValue={enableFunctionalCookies}\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"]} */",
476
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAgHwB","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 Link from '@commercetools-uikit/link';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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"]} */",
477
477
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
478
478
  };
479
479
  const CookieConsentBodyPrimary = _ref7 => {
@@ -568,7 +568,7 @@ const CookieConsentBodyDetails = _ref8 => {
568
568
  return jsxs(Fragment, {
569
569
  children: [jsx("div", {
570
570
  ref: scrollRef,
571
- css: /*#__PURE__*/css("scroll-margin-top:", 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":"AA0NgB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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      zIndex={1000000}\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    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          togglePerformanceValue={enablePerformanceCookies}\n          toggleFunctionalValue={enableFunctionalCookies}\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"]} */")
571
+ css: /*#__PURE__*/css("scroll-margin-top:", 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":"AA0NgB","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 Link from '@commercetools-uikit/link';\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  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\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"]} */")
572
572
  }), jsxs(Spacings.Stack, {
573
573
  scale: "l",
574
574
  children: [jsx(NavigationLink, {
@@ -630,7 +630,6 @@ const CookieConsentModal = modalProps => {
630
630
  performanceCookies: performanceConsent
631
631
  });
632
632
  return jsxs(ConfirmationDialog, {
633
- zIndex: 1000000,
634
633
  isOpen: modalProps.isModalOpen,
635
634
  labelPrimary: intl.formatMessage(modalMessages.primaryButtonLabel),
636
635
  labelSecondary: intl.formatMessage(modalMessages.secondaryButtonLabel),
@@ -646,14 +645,15 @@ const CookieConsentModal = modalProps => {
646
645
  modalProps.closeModal();
647
646
  },
648
647
  title: intl.formatMessage(modalMessages.title),
648
+ zIndex: 1000000,
649
649
  children: [currentView === View.Primary && jsx(CookieConsentBodyPrimary, {
650
650
  onChangeView: view => setCurrentView(view),
651
- onTogglePerformance: value => setEnablePerformanceCookies(value),
652
651
  onToggleFunctional: value => setEnableFunctionalCookies(value),
652
+ onTogglePerformance: value => setEnablePerformanceCookies(value),
653
653
  panelState: panelState,
654
654
  setPanelState: state => setPanelState(state),
655
- togglePerformanceValue: enablePerformanceCookies,
656
- toggleFunctionalValue: enableFunctionalCookies
655
+ toggleFunctionalValue: enableFunctionalCookies,
656
+ togglePerformanceValue: enablePerformanceCookies
657
657
  }), currentView === View.Secondary && jsx(CookieConsentBodyDetails, {
658
658
  cookieDetails: createFunctionalCookieDetails(intl),
659
659
  onChangeView: view => setCurrentView(view)
@@ -691,16 +691,28 @@ function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymb
691
691
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
692
692
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
693
693
  const BANNER_HEIGHT = 64;
694
+
695
+ /**
696
+ * Define a fixed date to determine the validity of consent cookies. Update as required.
697
+ *
698
+ * Cookies set before this date are considered invalid due to new cookie regulations or changes.
699
+ */
700
+ const COOKIE_REVOCATION_DATE = 'Wed May 01 2024 12:00:00 GMT-0400 (Eastern Daylight Time)';
694
701
  var _ref = process.env.NODE_ENV === "production" ? {
695
702
  name: "1u6bcy9",
696
703
  styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999"
697
704
  } : {
698
705
  name: "t2qh0u-CookieConsentBanner",
699
706
  styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999;label:CookieConsentBanner;",
700
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0RjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEJBTk5FUl9IRUlHSFQgPSA2NDtcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */",
707
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOERjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgTGluayBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9saW5rJztcbmltcG9ydCBQcmltYXJ5QnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3ByaW1hcnktYnV0dG9uJztcbmltcG9ydCBTcGFjaW5ncyBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zcGFjaW5ncyc7XG5pbXBvcnQgVGV4dCBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC90ZXh0JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IHVzZU1vZGFsU3RhdGUgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IENPT0tJRV9DT05TRU5UX0xJTktTIH0gZnJvbSAnLi4vLi4vLi4vY29uc3RhbnRzL2xpbmtzJztcbmltcG9ydCB7IHVuc2V0Q29uc2VudENvb2tpZSB9IGZyb20gJy4uLy4uL2NvcmUnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBCQU5ORVJfSEVJR0hUID0gNjQ7XG5cbi8qKlxuICogRGVmaW5lIGEgZml4ZWQgZGF0ZSB0byBkZXRlcm1pbmUgdGhlIHZhbGlkaXR5IG9mIGNvbnNlbnQgY29va2llcy4gVXBkYXRlIGFzIHJlcXVpcmVkLlxuICpcbiAqIENvb2tpZXMgc2V0IGJlZm9yZSB0aGlzIGRhdGUgYXJlIGNvbnNpZGVyZWQgaW52YWxpZCBkdWUgdG8gbmV3IGNvb2tpZSByZWd1bGF0aW9ucyBvciBjaGFuZ2VzLlxuICovXG5jb25zdCBDT09LSUVfUkVWT0NBVElPTl9EQVRFID1cbiAgJ1dlZCBNYXkgMDEgMjAyNCAxMjowMDowMCBHTVQtMDQwMCAoRWFzdGVybiBEYXlsaWdodCBUaW1lKSc7XG5cbmNvbnN0IENvb2tpZUNvbnNlbnRCYW5uZXIgPSAoYmFubmVyUHJvcHM6IENvbnNlbnRCYW5uZXJQcm9wcykgPT4ge1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIFJldm9rZSBjb29raWVzIHByaW9yIHRvIGEgY2VydGFpbiBkYXRlIHRvIGVuc3VyZSB1c2VyIHByZWZlcmVuY2VzIGFyZSB1cC10by1kYXRlIHdpdGggY29va2llIGNvbmZpZ3VyYXRpb25cbiAgICB1bnNldENvbnNlbnRDb29raWUobmV3IERhdGUoQ09PS0lFX1JFVk9DQVRJT05fREFURSkpO1xuICB9LCBbXSk7XG5cbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfSA9IHVzZUNvb2tpZUNvbnNlbnQoXG4gICAgJ2Z1bmN0aW9uYWxDb29raWVzJyxcbiAgICB7IHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCB9XG4gICk7XG5cbiAgY29uc3QgY3JlYXRlQ29uc2VudEdyb3VwcyA9ICgpID0+ICh7XG4gICAgZnVuY3Rpb25hbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB8fFxuICAgIGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50XG4gIClcbiAgICByZXR1cm4gbnVsbDtcblxuICByZXR1cm4gKFxuICAgIC8vIFRPRE86IHVzZSBsb3dlciB6LWluZGV4LCBwcmVmZXIgcmFuZ2VzIHBlciB1c2UtY2FzZVxuICAgIDxkaXZcbiAgICAgIGNzcz17Y3NzYFxuICAgICAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgICAgIHRvcDogMDtcbiAgICAgICAgbGVmdDogMDtcbiAgICAgICAgYm90dG9tOiAwO1xuICAgICAgICByaWdodDogMDtcbiAgICAgICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICBgfVxuICAgID5cbiAgICAgIDxkaXZcbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgcG9zaXRpb246IHN0aWNreTtcbiAgICAgICAgICB0b3A6IGNhbGMoMTAwJSAtICR7QkFOTkVSX0hFSUdIVH1weCAtICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH0pO1xuICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgICAgcG9pbnRlci1ldmVudHM6IGF1dG87XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yQWNjZW50MTB9O1xuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNH07XG4gICAgICAgICAgICBib3gtc2hhZG93OiAke2Rlc2lnblRva2Vucy5zaGFkb3c4fTtcbiAgICAgICAgICAgIG1hcmdpbjogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICAgICAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ019ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgICAgICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgICAgICAgIHN2ZyB7XG4gICAgICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlXG4gICAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgICBwcml2YWN5TGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5wcml2YWN5UG9saWN5TGlua31cbiAgICAgICAgICAgICAgICAgICAgICBpc0V4dGVybmFsXG4gICAgICAgICAgICAgICAgICAgICAgdG89e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgbW9kYWxMaW5rOiAoXG4gICAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIG9wZW5Nb2RhbCgpO1xuICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgdG89XCJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */",
701
708
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
702
709
  };
703
710
  const CookieConsentBanner = bannerProps => {
711
+ useEffect(() => {
712
+ // Revoke cookies prior to a certain date to ensure user preferences are up-to-date with cookie configuration
713
+ unsetConsentCookie(new Date(COOKIE_REVOCATION_DATE));
714
+ }, []);
715
+
704
716
  // Hide the banner once the accept button is clicked, until we can subscribe to the cookie
705
717
  const _useState = useState(false),
706
718
  _useState2 = _slicedToArray(_useState, 2),
@@ -731,9 +743,9 @@ const CookieConsentBanner = bannerProps => {
731
743
  jsx("div", {
732
744
  css: _ref,
733
745
  children: jsxs("div", {
734
- css: /*#__PURE__*/css("position:sticky;top:calc(100% - ", BANNER_HEIGHT, "px - ", 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCBMaW5rIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2xpbmsnO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBCQU5ORVJfSEVJR0hUID0gNjQ7XG5cbmNvbnN0IENvb2tpZUNvbnNlbnRCYW5uZXIgPSAoYmFubmVyUHJvcHM6IENvbnNlbnRCYW5uZXJQcm9wcykgPT4ge1xuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgICAgc3ZnIHtcbiAgICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICBgfVxuICAgICAgICA+XG4gICAgICAgICAgPFNwYWNpbmdzLklubGluZSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgPFRleHQuQm9keSB0b25lPVwiaW52ZXJ0ZWRcIj5cbiAgICAgICAgICAgICAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICAgICAgICAgICAgICB7Li4ubWVzc2FnZXMuYmFubmVyTWVzc2FnZX1cbiAgICAgICAgICAgICAgICB2YWx1ZXM9e3tcbiAgICAgICAgICAgICAgICAgIHByaXZhY3lMaW5rOiAoXG4gICAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLnByaXZhY3lQb2xpY3lMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgICAgICAgICAgICB0bz17Q09PS0lFX0NPTlNFTlRfTElOS1MuUFJJVkFDWV9QT0xJQ1l9XG4gICAgICAgICAgICAgICAgICAgICAgdG9uZT1cImludmVydGVkXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMuYmFubmVyQ29va2llc01vZGFsTGlua31cbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgICB0bz1cIlwiXG4gICAgICAgICAgICAgICAgICAgICAgdG9uZT1cImludmVydGVkXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgICAgPFByaW1hcnlCdXR0b25cbiAgICAgICAgICAgICAgbGFiZWw9e2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYnV0dG9uTGFiZWwpfVxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgc2V0Q29uc2VudChjcmVhdGVDb25zZW50R3JvdXBzKCkpO1xuICAgICAgICAgICAgICAgIHNldEJhbm5lckNsb3NlZCh0cnVlKTtcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgc2l6ZT1cIm1lZGl1bVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPENvb2tpZUNvbnNlbnRNb2RhbFxuICAgICAgICAgIGNsb3NlTW9kYWw9e2Nsb3NlTW9kYWx9XG4gICAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICAgIHNldEJhbm5lckNsb3NlZD17c2V0QmFubmVyQ2xvc2VkfVxuICAgICAgICAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */"),
746
+ css: /*#__PURE__*/css("position:sticky;top:calc(100% - ", BANNER_HEIGHT, "px - ", 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUVnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgeyB1bnNldENvbnNlbnRDb29raWUgfSBmcm9tICcuLi8uLi9jb3JlJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQkFOTkVSX0hFSUdIVCA9IDY0O1xuXG4vKipcbiAqIERlZmluZSBhIGZpeGVkIGRhdGUgdG8gZGV0ZXJtaW5lIHRoZSB2YWxpZGl0eSBvZiBjb25zZW50IGNvb2tpZXMuIFVwZGF0ZSBhcyByZXF1aXJlZC5cbiAqXG4gKiBDb29raWVzIHNldCBiZWZvcmUgdGhpcyBkYXRlIGFyZSBjb25zaWRlcmVkIGludmFsaWQgZHVlIHRvIG5ldyBjb29raWUgcmVndWxhdGlvbnMgb3IgY2hhbmdlcy5cbiAqL1xuY29uc3QgQ09PS0lFX1JFVk9DQVRJT05fREFURSA9XG4gICdXZWQgTWF5IDAxIDIwMjQgMTI6MDA6MDAgR01ULTA0MDAgKEVhc3Rlcm4gRGF5bGlnaHQgVGltZSknO1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBSZXZva2UgY29va2llcyBwcmlvciB0byBhIGNlcnRhaW4gZGF0ZSB0byBlbnN1cmUgdXNlciBwcmVmZXJlbmNlcyBhcmUgdXAtdG8tZGF0ZSB3aXRoIGNvb2tpZSBjb25maWd1cmF0aW9uXG4gICAgdW5zZXRDb25zZW50Q29va2llKG5ldyBEYXRlKENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUpKTtcbiAgfSwgW10pO1xuXG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
735
747
  children: [jsx("div", {
736
- css: /*#__PURE__*/css("background-color:", designTokens.colorAccent10, ";border-radius:", designTokens.borderRadius4, ";box-shadow:", designTokens.shadow8, ";margin:0 ", designTokens.spacingXl, ";padding:", designTokens.spacingM, " ", designTokens.spacingL, ";width:fit-content;svg{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUVrQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCBMaW5rIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2xpbmsnO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBCQU5ORVJfSEVJR0hUID0gNjQ7XG5cbmNvbnN0IENvb2tpZUNvbnNlbnRCYW5uZXIgPSAoYmFubmVyUHJvcHM6IENvbnNlbnRCYW5uZXJQcm9wcykgPT4ge1xuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZnVuY3Rpb25hbENvb2tpZXMnLFxuICAgIHsgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50IH1cbiAgKTtcblxuICBjb25zdCBjcmVhdGVDb25zZW50R3JvdXBzID0gKCkgPT4gKHtcbiAgICBmdW5jdGlvbmFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtCQU5ORVJfSEVJR0hUfXB4IC0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfSk7XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgICBwb2ludGVyLWV2ZW50czogYXV0bztcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JBY2NlbnQxMH07XG4gICAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgICAgbWFyZ2luOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgICAgc3ZnIHtcbiAgICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICBgfVxuICAgICAgICA+XG4gICAgICAgICAgPFNwYWNpbmdzLklubGluZSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgICAgPFRleHQuQm9keSB0b25lPVwiaW52ZXJ0ZWRcIj5cbiAgICAgICAgICAgICAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICAgICAgICAgICAgICB7Li4ubWVzc2FnZXMuYmFubmVyTWVzc2FnZX1cbiAgICAgICAgICAgICAgICB2YWx1ZXM9e3tcbiAgICAgICAgICAgICAgICAgIHByaXZhY3lMaW5rOiAoXG4gICAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLnByaXZhY3lQb2xpY3lMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgICAgICAgICAgICB0bz17Q09PS0lFX0NPTlNFTlRfTElOS1MuUFJJVkFDWV9QT0xJQ1l9XG4gICAgICAgICAgICAgICAgICAgICAgdG9uZT1cImludmVydGVkXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICBtb2RhbExpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMuYmFubmVyQ29va2llc01vZGFsTGlua31cbiAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgICB0bz1cIlwiXG4gICAgICAgICAgICAgICAgICAgICAgdG9uZT1cImludmVydGVkXCJcbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgICAgPFByaW1hcnlCdXR0b25cbiAgICAgICAgICAgICAgbGFiZWw9e2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYnV0dG9uTGFiZWwpfVxuICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgc2V0Q29uc2VudChjcmVhdGVDb25zZW50R3JvdXBzKCkpO1xuICAgICAgICAgICAgICAgIHNldEJhbm5lckNsb3NlZCh0cnVlKTtcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgc2l6ZT1cIm1lZGl1bVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPENvb2tpZUNvbnNlbnRNb2RhbFxuICAgICAgICAgIGNsb3NlTW9kYWw9e2Nsb3NlTW9kYWx9XG4gICAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICAgIHNldEJhbm5lckNsb3NlZD17c2V0QmFubmVyQ2xvc2VkfVxuICAgICAgICAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */"),
748
+ css: /*#__PURE__*/css("background-color:", designTokens.colorAccent10, ";border-radius:", designTokens.borderRadius4, ";box-shadow:", designTokens.shadow8, ";margin:0 ", designTokens.spacingXl, ";padding:", designTokens.spacingM, " ", designTokens.spacingL, ";width:fit-content;svg{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUZrQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgeyB1bnNldENvbnNlbnRDb29raWUgfSBmcm9tICcuLi8uLi9jb3JlJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQkFOTkVSX0hFSUdIVCA9IDY0O1xuXG4vKipcbiAqIERlZmluZSBhIGZpeGVkIGRhdGUgdG8gZGV0ZXJtaW5lIHRoZSB2YWxpZGl0eSBvZiBjb25zZW50IGNvb2tpZXMuIFVwZGF0ZSBhcyByZXF1aXJlZC5cbiAqXG4gKiBDb29raWVzIHNldCBiZWZvcmUgdGhpcyBkYXRlIGFyZSBjb25zaWRlcmVkIGludmFsaWQgZHVlIHRvIG5ldyBjb29raWUgcmVndWxhdGlvbnMgb3IgY2hhbmdlcy5cbiAqL1xuY29uc3QgQ09PS0lFX1JFVk9DQVRJT05fREFURSA9XG4gICdXZWQgTWF5IDAxIDIwMjQgMTI6MDA6MDAgR01ULTA0MDAgKEVhc3Rlcm4gRGF5bGlnaHQgVGltZSknO1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBSZXZva2UgY29va2llcyBwcmlvciB0byBhIGNlcnRhaW4gZGF0ZSB0byBlbnN1cmUgdXNlciBwcmVmZXJlbmNlcyBhcmUgdXAtdG8tZGF0ZSB3aXRoIGNvb2tpZSBjb25maWd1cmF0aW9uXG4gICAgdW5zZXRDb25zZW50Q29va2llKG5ldyBEYXRlKENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUpKTtcbiAgfSwgW10pO1xuXG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
737
749
  children: jsxs(Spacings.Inline, {
738
750
  alignItems: "center",
739
751
  scale: "xl",