@commercetools-frontend/cookie-consent 1.2.1 → 1.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json
CHANGED
|
@@ -483,7 +483,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
|
483
483
|
} : {
|
|
484
484
|
name: "4sjpj8-removeDefaultSvg",
|
|
485
485
|
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
486
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAqD8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Fragment, 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  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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\n  return (\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=\"24px\"\n            gridRowGap=\"0px\"\n            gridTemplateColumns=\"80px 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\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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */",
|
|
486
|
+
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  createEssentialCookieDetails,\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */",
|
|
487
487
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
488
488
|
};
|
|
489
489
|
var InformationLink = function InformationLink(_ref5) {
|
|
@@ -505,7 +505,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
505
505
|
} : {
|
|
506
506
|
name: "4sjpj8-removeDefaultSvg",
|
|
507
507
|
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
508
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA0E8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Fragment, 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  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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\n  return (\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=\"24px\"\n            gridRowGap=\"0px\"\n            gridTemplateColumns=\"80px 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\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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */",
|
|
508
|
+
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  createEssentialCookieDetails,\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */",
|
|
509
509
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
510
510
|
};
|
|
511
511
|
var DetailLink = function DetailLink(_ref6) {
|
|
@@ -530,7 +530,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
530
530
|
} : {
|
|
531
531
|
name: "ey0yn8-bumpToggle",
|
|
532
532
|
styles: "padding-right:10px;label:bumpToggle;",
|
|
533
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2GwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Fragment, 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  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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\n  return (\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=\"24px\"\n            gridRowGap=\"0px\"\n            gridTemplateColumns=\"80px 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\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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */",
|
|
533
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA4GwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { 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  createEssentialCookieDetails,\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */",
|
|
534
534
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
535
535
|
};
|
|
536
536
|
var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
@@ -621,39 +621,49 @@ var CookieConsentBodyDetails = function CookieConsentBodyDetails(_ref8) {
|
|
|
621
621
|
cookieDetails = _ref8.cookieDetails;
|
|
622
622
|
var _useIntl2 = reactIntl.useIntl(),
|
|
623
623
|
formatMessage = _useIntl2.formatMessage;
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
624
|
+
var scrollRef = /*#__PURE__*/react.createRef();
|
|
625
|
+
react.useEffect(function () {
|
|
626
|
+
var _scrollRef$current;
|
|
627
|
+
(_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 ? void 0 : _scrollRef$current.scrollIntoView();
|
|
628
|
+
}, [scrollRef]);
|
|
629
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
630
|
+
children: [jsxRuntime.jsx("div", {
|
|
631
|
+
ref: scrollRef,
|
|
632
|
+
css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAmNgB","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  createEssentialCookieDetails,\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  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\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.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\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={toggleValue}\n                onChange={(e) => onToggle(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  essentialCookiesClosed: 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 [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\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(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(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          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(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"]} */")
|
|
633
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
632
634
|
scale: "l",
|
|
633
|
-
children:
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
635
|
+
children: [jsxRuntime.jsx(NavigationLink, {
|
|
636
|
+
label: formatMessage(modalMessages.navigateBackLink),
|
|
637
|
+
onClick: function onClick() {
|
|
638
|
+
return onChangeView(View.Primary);
|
|
639
|
+
}
|
|
640
|
+
}), jsxRuntime.jsx(Spacings__default["default"].Stack, {
|
|
641
|
+
scale: "l",
|
|
642
|
+
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails, function (detail) {
|
|
643
|
+
var _context;
|
|
644
|
+
return jsxRuntime.jsx(Grid__default["default"], {
|
|
645
|
+
gridGap: designSystem.designTokens.spacing40,
|
|
646
|
+
gridRowGap: "0px",
|
|
647
|
+
gridTemplateColumns: "".concat(designSystem.designTokens.constraint2, " 1fr"),
|
|
648
|
+
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context, function (value) {
|
|
649
|
+
return jsxRuntime.jsxs(react.Fragment, {
|
|
650
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
651
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
652
|
+
children: value.label
|
|
653
|
+
})
|
|
654
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
655
|
+
children: 'to' in value ? jsxRuntime.jsx(DetailLink, {
|
|
656
|
+
label: value.value,
|
|
657
|
+
to: value.to
|
|
658
|
+
}) : jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
659
|
+
children: value.value
|
|
660
|
+
})
|
|
661
|
+
})]
|
|
662
|
+
}, value.value);
|
|
663
|
+
})
|
|
664
|
+
}, detail.name.value);
|
|
665
|
+
})
|
|
666
|
+
})]
|
|
657
667
|
})]
|
|
658
668
|
});
|
|
659
669
|
};
|
|
@@ -780,9 +790,9 @@ var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
|
780
790
|
return (
|
|
781
791
|
// TODO: use lower z-index, prefer ranges per use-case
|
|
782
792
|
jsxRuntime.jsxs("div", {
|
|
783
|
-
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", designSystem.designTokens.spacingXl, ";z-index:
|
|
793
|
+
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", designSystem.designTokens.spacingXl, ";z-index:9999;width:100%;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOENjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IENvb2tpZUNvbnNlbnRCYW5uZXIgPSAoYmFubmVyUHJvcHM6IENvbnNlbnRCYW5uZXJQcm9wcykgPT4ge1xuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdlc3NlbnRpYWxDb29raWVzJyxcbiAgICB7IHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCB9XG4gICk7XG5cbiAgY29uc3QgY3JlYXRlQ29uc2VudEdyb3VwcyA9ICgpID0+ICh7XG4gICAgZXNzZW50aWFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkVzc2VudGlhbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICBib3R0b206ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yQWNjZW50MTB9O1xuICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgIG1hcmdpbjogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIHN2ZyB7XG4gICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgIH1cbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPFNwYWNpbmdzLklubGluZSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICB7Li4ubWVzc2FnZXMuYmFubmVyTWVzc2FnZX1cbiAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5wcml2YWN5UG9saWN5TGlua31cbiAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICB0bz17Q09PS0lFX0NPTlNFTlRfTElOS1MuUFJJVkFDWV9QT0xJQ1l9XG4gICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgbW9kYWxMaW5rOiAoXG4gICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMuYmFubmVyQ29va2llc01vZGFsTGlua31cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgdG9uZT1cImludmVydGVkXCJcbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgPFByaW1hcnlCdXR0b25cbiAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgc2V0Q29uc2VudChjcmVhdGVDb25zZW50R3JvdXBzKCkpO1xuICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICB9fVxuICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAvPlxuICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPENvb2tpZUNvbnNlbnRNb2RhbFxuICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgIHNldEJhbm5lckNsb3NlZD17c2V0QmFubmVyQ2xvc2VkfVxuICAgICAgLz5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
|
|
784
794
|
children: [jsxRuntime.jsx("div", {
|
|
785
|
-
css: /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorAccent10, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow8, ";margin:0 ", designSystem.designTokens.spacingXl, ";padding:", designSystem.designTokens.spacingM, " ", designSystem.designTokens.spacingL, ";width:fit-content;svg{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeURnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCBMaW5rIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2xpbmsnO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+
|
|
795
|
+
css: /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorAccent10, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow8, ";margin:0 ", designSystem.designTokens.spacingXl, ";padding:", designSystem.designTokens.spacingM, " ", designSystem.designTokens.spacingL, ";width:fit-content;svg{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeURnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCBMaW5rIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2xpbmsnO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRXNzZW50aWFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZXNzZW50aWFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGVzc2VudGlhbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICBib3gtc2hhZG93OiAke2Rlc2lnblRva2Vucy5zaGFkb3c4fTtcbiAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgICB9XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgIHByaXZhY3lMaW5rOiAoXG4gICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgICAgICAgICAgdG89e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmt9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgIG9wZW5Nb2RhbCgpO1xuICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICB0bz1cIlwiXG4gICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */"),
|
|
786
796
|
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
787
797
|
alignItems: "center",
|
|
788
798
|
scale: "xl",
|
|
@@ -26,8 +26,8 @@ var Spacings = require('@commercetools-uikit/spacings');
|
|
|
26
26
|
var Text = require('@commercetools-uikit/text');
|
|
27
27
|
var ToggleInput = require('@commercetools-uikit/toggle-input');
|
|
28
28
|
var applicationComponents = require('@commercetools-frontend/application-components');
|
|
29
|
-
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
30
29
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
30
|
+
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
31
31
|
var PrimaryButton = require('@commercetools-uikit/primary-button');
|
|
32
32
|
require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
33
33
|
require('@babel/runtime-corejs3/core-js-stable/object/from-entries');
|
|
@@ -605,39 +605,49 @@ var CookieConsentBodyDetails = function CookieConsentBodyDetails(_ref8) {
|
|
|
605
605
|
cookieDetails = _ref8.cookieDetails;
|
|
606
606
|
var _useIntl2 = reactIntl.useIntl(),
|
|
607
607
|
formatMessage = _useIntl2.formatMessage;
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
608
|
+
var scrollRef = /*#__PURE__*/react.createRef();
|
|
609
|
+
react.useEffect(function () {
|
|
610
|
+
var _scrollRef$current;
|
|
611
|
+
(_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 ? void 0 : _scrollRef$current.scrollIntoView();
|
|
612
|
+
}, [scrollRef]);
|
|
613
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
614
|
+
children: [jsxRuntime.jsx("div", {
|
|
615
|
+
ref: scrollRef,
|
|
616
|
+
css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + ("" ), "" )
|
|
617
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
616
618
|
scale: "l",
|
|
617
|
-
children:
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
619
|
+
children: [jsxRuntime.jsx(NavigationLink, {
|
|
620
|
+
label: formatMessage(modalMessages.navigateBackLink),
|
|
621
|
+
onClick: function onClick() {
|
|
622
|
+
return onChangeView(View.Primary);
|
|
623
|
+
}
|
|
624
|
+
}), jsxRuntime.jsx(Spacings__default["default"].Stack, {
|
|
625
|
+
scale: "l",
|
|
626
|
+
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails, function (detail) {
|
|
627
|
+
var _context;
|
|
628
|
+
return jsxRuntime.jsx(Grid__default["default"], {
|
|
629
|
+
gridGap: designSystem.designTokens.spacing40,
|
|
630
|
+
gridRowGap: "0px",
|
|
631
|
+
gridTemplateColumns: "".concat(designSystem.designTokens.constraint2, " 1fr"),
|
|
632
|
+
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context, function (value) {
|
|
633
|
+
return jsxRuntime.jsxs(react.Fragment, {
|
|
634
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
635
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
636
|
+
children: value.label
|
|
637
|
+
})
|
|
638
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
639
|
+
children: 'to' in value ? jsxRuntime.jsx(DetailLink, {
|
|
640
|
+
label: value.value,
|
|
641
|
+
to: value.to
|
|
642
|
+
}) : jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
643
|
+
children: value.value
|
|
644
|
+
})
|
|
645
|
+
})]
|
|
646
|
+
}, value.value);
|
|
647
|
+
})
|
|
648
|
+
}, detail.name.value);
|
|
649
|
+
})
|
|
650
|
+
})]
|
|
641
651
|
})]
|
|
642
652
|
});
|
|
643
653
|
};
|
|
@@ -764,7 +774,7 @@ var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
|
764
774
|
return (
|
|
765
775
|
// TODO: use lower z-index, prefer ranges per use-case
|
|
766
776
|
jsxRuntime.jsxs("div", {
|
|
767
|
-
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", designSystem.designTokens.spacingXl, ";z-index:
|
|
777
|
+
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", designSystem.designTokens.spacingXl, ";z-index:9999;width:100%;" + ("" ), "" ),
|
|
768
778
|
children: [jsxRuntime.jsx("div", {
|
|
769
779
|
css: /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorAccent10, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow8, ";margin:0 ", designSystem.designTokens.spacingXl, ";padding:", designSystem.designTokens.spacingM, " ", designSystem.designTokens.spacingL, ";width:fit-content;svg{display:none;}" + ("" ), "" ),
|
|
770
780
|
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|