@commercetools-frontend/cookie-consent 1.1.0 → 1.2.1
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
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-frontend/cookie-consent",
|
|
3
|
-
"version": "1.1
|
|
3
|
+
"version": "1.2.1",
|
|
4
4
|
"description": "A package integrating with OneTrust cookie consent",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"main": "dist/commercetools-frontend-cookie-consent.cjs.js",
|
|
@@ -19,17 +19,24 @@
|
|
|
19
19
|
"dependencies": {
|
|
20
20
|
"@babel/runtime": "^7.21.0",
|
|
21
21
|
"@babel/runtime-corejs3": "^7.21.0",
|
|
22
|
+
"@commercetools-frontend/application-components": "^21.23.10",
|
|
23
|
+
"@commercetools-uikit/collapsible-panel": "^15.13.2",
|
|
24
|
+
"@commercetools-uikit/design-system": "^15.13.2",
|
|
25
|
+
"@commercetools-uikit/grid": "^15.13.2",
|
|
26
|
+
"@commercetools-uikit/link": "^15.13.2",
|
|
27
|
+
"@commercetools-uikit/primary-button": "^15.13.2",
|
|
28
|
+
"@commercetools-uikit/spacings": "^15.13.2",
|
|
29
|
+
"@commercetools-uikit/text": "^15.13.2",
|
|
30
|
+
"@commercetools-uikit/toggle-input": "^15.13.2",
|
|
22
31
|
"@emotion/react": "^11.10.6"
|
|
23
32
|
},
|
|
24
33
|
"devDependencies": {
|
|
25
|
-
"@types/node": "18.
|
|
34
|
+
"@types/node": "18.15.3",
|
|
26
35
|
"typescript": "4.9.5"
|
|
27
36
|
},
|
|
28
37
|
"peerDependencies": {
|
|
29
|
-
"@commercetools-frontend/application-components": "21.x",
|
|
30
38
|
"@commercetools-frontend/application-shell": "21.x",
|
|
31
39
|
"@commercetools-frontend/application-shell-connectors": "21.x",
|
|
32
|
-
"@commercetools-frontend/ui-kit": "15.x",
|
|
33
40
|
"react": "17.x",
|
|
34
41
|
"react-intl": "5.x"
|
|
35
42
|
},
|
|
@@ -19,9 +19,16 @@ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instan
|
|
|
19
19
|
var _Object$values = require('@babel/runtime-corejs3/core-js-stable/object/values');
|
|
20
20
|
var react$1 = require('@emotion/react');
|
|
21
21
|
var reactIntl = require('react-intl');
|
|
22
|
-
var
|
|
22
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
23
|
+
var Link = require('@commercetools-uikit/link');
|
|
24
|
+
var PrimaryButton = require('@commercetools-uikit/primary-button');
|
|
25
|
+
var Spacings = require('@commercetools-uikit/spacings');
|
|
26
|
+
var Text = require('@commercetools-uikit/text');
|
|
23
27
|
var applicationComponents = require('@commercetools-frontend/application-components');
|
|
24
28
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
29
|
+
var CollapsiblePanel = require('@commercetools-uikit/collapsible-panel');
|
|
30
|
+
var Grid = require('@commercetools-uikit/grid');
|
|
31
|
+
var ToggleInput = require('@commercetools-uikit/toggle-input');
|
|
25
32
|
require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
26
33
|
require('@babel/runtime-corejs3/core-js-stable/object/from-entries');
|
|
27
34
|
require('@babel/runtime-corejs3/core-js-stable/object/entries');
|
|
@@ -40,6 +47,13 @@ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$def
|
|
|
40
47
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
41
48
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
42
49
|
var _Object$values__default = /*#__PURE__*/_interopDefault(_Object$values);
|
|
50
|
+
var Link__default = /*#__PURE__*/_interopDefault(Link);
|
|
51
|
+
var PrimaryButton__default = /*#__PURE__*/_interopDefault(PrimaryButton);
|
|
52
|
+
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
53
|
+
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
54
|
+
var CollapsiblePanel__default = /*#__PURE__*/_interopDefault(CollapsiblePanel);
|
|
55
|
+
var Grid__default = /*#__PURE__*/_interopDefault(Grid);
|
|
56
|
+
var ToggleInput__default = /*#__PURE__*/_interopDefault(ToggleInput);
|
|
43
57
|
|
|
44
58
|
var defaultConsentOptions = {
|
|
45
59
|
skipConsent: false,
|
|
@@ -454,7 +468,7 @@ var View = {
|
|
|
454
468
|
var NavigationLink = function NavigationLink(_ref4) {
|
|
455
469
|
var _onClick = _ref4.onClick,
|
|
456
470
|
label = _ref4.label;
|
|
457
|
-
return jsxRuntime.jsx(
|
|
471
|
+
return jsxRuntime.jsx(Link__default["default"], {
|
|
458
472
|
onClick: function onClick(e) {
|
|
459
473
|
e.preventDefault();
|
|
460
474
|
_onClick();
|
|
@@ -469,7 +483,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
|
469
483
|
} : {
|
|
470
484
|
name: "4sjpj8-removeDefaultSvg",
|
|
471
485
|
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
472
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAuD8B","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 {\n  Link,\n  Spacings,\n  Text,\n  ToggleInput,\n  CollapsiblePanel,\n  Grid,\n} from '@commercetools-frontend/ui-kit';\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":"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"]} */",
|
|
473
487
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
474
488
|
};
|
|
475
489
|
var InformationLink = function InformationLink(_ref5) {
|
|
@@ -478,7 +492,7 @@ var InformationLink = function InformationLink(_ref5) {
|
|
|
478
492
|
var removeDefaultSvg = _ref3;
|
|
479
493
|
return jsxRuntime.jsx("div", {
|
|
480
494
|
css: removeDefaultSvg,
|
|
481
|
-
children: jsxRuntime.jsx(
|
|
495
|
+
children: jsxRuntime.jsx(Link__default["default"], {
|
|
482
496
|
isExternal: true,
|
|
483
497
|
to: to,
|
|
484
498
|
children: label
|
|
@@ -491,7 +505,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
491
505
|
} : {
|
|
492
506
|
name: "4sjpj8-removeDefaultSvg",
|
|
493
507
|
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
494
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA4E8B","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 {\n  Link,\n  Spacings,\n  Text,\n  ToggleInput,\n  CollapsiblePanel,\n  Grid,\n} from '@commercetools-frontend/ui-kit';\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":"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"]} */",
|
|
495
509
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
496
510
|
};
|
|
497
511
|
var DetailLink = function DetailLink(_ref6) {
|
|
@@ -500,10 +514,10 @@ var DetailLink = function DetailLink(_ref6) {
|
|
|
500
514
|
var removeDefaultSvg = _ref2;
|
|
501
515
|
return jsxRuntime.jsx("div", {
|
|
502
516
|
css: removeDefaultSvg,
|
|
503
|
-
children: jsxRuntime.jsx(
|
|
517
|
+
children: jsxRuntime.jsx(Link__default["default"], {
|
|
504
518
|
isExternal: true,
|
|
505
519
|
to: to,
|
|
506
|
-
children: jsxRuntime.jsx(
|
|
520
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
507
521
|
tone: "primary",
|
|
508
522
|
children: label
|
|
509
523
|
})
|
|
@@ -516,7 +530,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
516
530
|
} : {
|
|
517
531
|
name: "ey0yn8-bumpToggle",
|
|
518
532
|
styles: "padding-right:10px;label:bumpToggle;",
|
|
519
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA6GwB","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 {\n  Link,\n  Spacings,\n  Text,\n  ToggleInput,\n  CollapsiblePanel,\n  Grid,\n} from '@commercetools-frontend/ui-kit';\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":"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"]} */",
|
|
520
534
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
521
535
|
};
|
|
522
536
|
var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
@@ -530,22 +544,22 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
530
544
|
|
|
531
545
|
// The outline of the input is cut off; we shift it to the left to compensate
|
|
532
546
|
var bumpToggle = _ref;
|
|
533
|
-
return jsxRuntime.jsxs(
|
|
547
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
534
548
|
scale: "xl",
|
|
535
|
-
children: [jsxRuntime.jsxs(
|
|
549
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
536
550
|
scale: "m",
|
|
537
|
-
children: [jsxRuntime.jsx(
|
|
551
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
538
552
|
intlMessage: modalMessages.mainDescription
|
|
539
553
|
}), jsxRuntime.jsx(InformationLink, {
|
|
540
554
|
label: formatMessage(modalMessages.privacyPolicyLink),
|
|
541
555
|
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY
|
|
542
556
|
})]
|
|
543
|
-
}), jsxRuntime.jsxs(
|
|
557
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
544
558
|
scale: "l",
|
|
545
|
-
children: [jsxRuntime.jsx(
|
|
559
|
+
children: [jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
546
560
|
condensed: true,
|
|
547
561
|
header: formatMessage(modalMessages.necessaryCookiesHeader),
|
|
548
|
-
headerControls: jsxRuntime.jsx(
|
|
562
|
+
headerControls: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
549
563
|
intlMessage: modalMessages.necessaryCookiesHeaderState,
|
|
550
564
|
tone: "information"
|
|
551
565
|
}),
|
|
@@ -556,9 +570,9 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
556
570
|
}));
|
|
557
571
|
},
|
|
558
572
|
theme: "light",
|
|
559
|
-
children: jsxRuntime.jsxs(
|
|
573
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
560
574
|
scale: "m",
|
|
561
|
-
children: [jsxRuntime.jsx(
|
|
575
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
562
576
|
intlMessage: modalMessages.necessaryCookiesDescription
|
|
563
577
|
}), jsxRuntime.jsx(NavigationLink, {
|
|
564
578
|
label: formatMessage(modalMessages.cookieInformationLink),
|
|
@@ -567,12 +581,12 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
567
581
|
}
|
|
568
582
|
})]
|
|
569
583
|
})
|
|
570
|
-
}), jsxRuntime.jsx(
|
|
584
|
+
}), jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
571
585
|
condensed: true,
|
|
572
586
|
header: formatMessage(modalMessages.performanceCookiesHeader),
|
|
573
587
|
headerControls: jsxRuntime.jsx("div", {
|
|
574
588
|
css: bumpToggle,
|
|
575
|
-
children: jsxRuntime.jsx(
|
|
589
|
+
children: jsxRuntime.jsx(ToggleInput__default["default"], {
|
|
576
590
|
isChecked: toggleValue,
|
|
577
591
|
onChange: function onChange(e) {
|
|
578
592
|
return onToggle(e.target.checked);
|
|
@@ -587,9 +601,9 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
587
601
|
}));
|
|
588
602
|
},
|
|
589
603
|
theme: "light",
|
|
590
|
-
children: jsxRuntime.jsxs(
|
|
604
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
591
605
|
scale: "m",
|
|
592
|
-
children: [jsxRuntime.jsx(
|
|
606
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
593
607
|
intlMessage: modalMessages.performanceCookiesDescription
|
|
594
608
|
}), jsxRuntime.jsx(NavigationLink, {
|
|
595
609
|
label: formatMessage(modalMessages.cookieInformationLink),
|
|
@@ -607,32 +621,32 @@ var CookieConsentBodyDetails = function CookieConsentBodyDetails(_ref8) {
|
|
|
607
621
|
cookieDetails = _ref8.cookieDetails;
|
|
608
622
|
var _useIntl2 = reactIntl.useIntl(),
|
|
609
623
|
formatMessage = _useIntl2.formatMessage;
|
|
610
|
-
return jsxRuntime.jsxs(
|
|
624
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
611
625
|
scale: "l",
|
|
612
626
|
children: [jsxRuntime.jsx(NavigationLink, {
|
|
613
627
|
label: formatMessage(modalMessages.navigateBackLink),
|
|
614
628
|
onClick: function onClick() {
|
|
615
629
|
return onChangeView(View.Primary);
|
|
616
630
|
}
|
|
617
|
-
}), jsxRuntime.jsx(
|
|
631
|
+
}), jsxRuntime.jsx(Spacings__default["default"].Stack, {
|
|
618
632
|
scale: "l",
|
|
619
633
|
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails, function (detail) {
|
|
620
634
|
var _context;
|
|
621
|
-
return jsxRuntime.jsx(
|
|
635
|
+
return jsxRuntime.jsx(Grid__default["default"], {
|
|
622
636
|
gridGap: "24px",
|
|
623
637
|
gridRowGap: "0px",
|
|
624
638
|
gridTemplateColumns: "80px 1fr",
|
|
625
639
|
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context, function (value) {
|
|
626
640
|
return jsxRuntime.jsxs(react.Fragment, {
|
|
627
|
-
children: [jsxRuntime.jsx(
|
|
628
|
-
children: jsxRuntime.jsx(
|
|
641
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
642
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
629
643
|
children: value.label
|
|
630
644
|
})
|
|
631
|
-
}), jsxRuntime.jsx(
|
|
645
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
632
646
|
children: 'to' in value ? jsxRuntime.jsx(DetailLink, {
|
|
633
647
|
label: value.value,
|
|
634
648
|
to: value.to
|
|
635
|
-
}) : jsxRuntime.jsx(
|
|
649
|
+
}) : jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
636
650
|
children: value.value
|
|
637
651
|
})
|
|
638
652
|
})]
|
|
@@ -766,23 +780,23 @@ var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
|
766
780
|
return (
|
|
767
781
|
// TODO: use lower z-index, prefer ranges per use-case
|
|
768
782
|
jsxRuntime.jsxs("div", {
|
|
769
|
-
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:",
|
|
783
|
+
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", designSystem.designTokens.spacingXl, ";z-index:1000000;width:100%;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOENjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyB1c2VDb29raWVDb25zZW50LCBDb29raWVDb25zZW50TW9kYWwgfSBmcm9tICcuLi8uLi9yZWFjdCc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcyc7XG5cbnR5cGUgQ29uc2VudEJhbm5lclByb3BzID0ge1xuICBza2lwQ29uc2VudDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IENvb2tpZUNvbnNlbnRCYW5uZXIgPSAoYmFubmVyUHJvcHM6IENvbnNlbnRCYW5uZXJQcm9wcykgPT4ge1xuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdlc3NlbnRpYWxDb29raWVzJyxcbiAgICB7IHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCB9XG4gICk7XG5cbiAgY29uc3QgY3JlYXRlQ29uc2VudEdyb3VwcyA9ICgpID0+ICh7XG4gICAgZXNzZW50aWFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkVzc2VudGlhbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICBib3R0b206ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH07XG4gICAgICAgIHotaW5kZXg6IDEwMDAwMDA7XG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yQWNjZW50MTB9O1xuICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgIGJveC1zaGFkb3c6ICR7ZGVzaWduVG9rZW5zLnNoYWRvdzh9O1xuICAgICAgICAgIG1hcmdpbjogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgICAgIHN2ZyB7XG4gICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgIH1cbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPFNwYWNpbmdzLklubGluZSBhbGlnbkl0ZW1zPVwiY2VudGVyXCIgc2NhbGU9XCJ4bFwiPlxuICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICB7Li4ubWVzc2FnZXMuYmFubmVyTWVzc2FnZX1cbiAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5wcml2YWN5UG9saWN5TGlua31cbiAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICB0bz17Q09PS0lFX0NPTlNFTlRfTElOS1MuUFJJVkFDWV9QT0xJQ1l9XG4gICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgbW9kYWxMaW5rOiAoXG4gICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMuYmFubmVyQ29va2llc01vZGFsTGlua31cbiAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgb3Blbk1vZGFsKCk7XG4gICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgdG9uZT1cImludmVydGVkXCJcbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgPFByaW1hcnlCdXR0b25cbiAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgc2V0Q29uc2VudChjcmVhdGVDb25zZW50R3JvdXBzKCkpO1xuICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICB9fVxuICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAvPlxuICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPENvb2tpZUNvbnNlbnRNb2RhbFxuICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgIHNldEJhbm5lckNsb3NlZD17c2V0QmFubmVyQ2xvc2VkfVxuICAgICAgLz5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
|
|
770
784
|
children: [jsxRuntime.jsx("div", {
|
|
771
|
-
css: /*#__PURE__*/react$1.css("background-color:",
|
|
772
|
-
children: jsxRuntime.jsxs(
|
|
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+IHtcbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRXNzZW50aWFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZXNzZW50aWFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGVzc2VudGlhbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICB6LWluZGV4OiAxMDAwMDAwO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICBib3gtc2hhZG93OiAke2Rlc2lnblRva2Vucy5zaGFkb3c4fTtcbiAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgICB9XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgIHByaXZhY3lMaW5rOiAoXG4gICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgICAgICAgICAgdG89e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmt9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgIG9wZW5Nb2RhbCgpO1xuICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICB0bz1cIlwiXG4gICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */"),
|
|
786
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
773
787
|
alignItems: "center",
|
|
774
788
|
scale: "xl",
|
|
775
|
-
children: [jsxRuntime.jsx(
|
|
789
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
776
790
|
tone: "inverted",
|
|
777
791
|
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread(_objectSpread({}, messages.bannerMessage), {}, {
|
|
778
792
|
values: {
|
|
779
|
-
privacyLink: jsxRuntime.jsx(
|
|
793
|
+
privacyLink: jsxRuntime.jsx(Link__default["default"], {
|
|
780
794
|
intlMessage: messages.privacyPolicyLink,
|
|
781
795
|
isExternal: true,
|
|
782
796
|
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY,
|
|
783
797
|
tone: "inverted"
|
|
784
798
|
}),
|
|
785
|
-
modalLink: jsxRuntime.jsx(
|
|
799
|
+
modalLink: jsxRuntime.jsx(Link__default["default"], {
|
|
786
800
|
intlMessage: messages.bannerCookiesModalLink,
|
|
787
801
|
onClick: function onClick(e) {
|
|
788
802
|
e.preventDefault();
|
|
@@ -793,7 +807,7 @@ var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
|
793
807
|
})
|
|
794
808
|
}
|
|
795
809
|
}))
|
|
796
|
-
}), jsxRuntime.jsx(
|
|
810
|
+
}), jsxRuntime.jsx(PrimaryButton__default["default"], {
|
|
797
811
|
label: formatMessage(messages.buttonLabel),
|
|
798
812
|
onClick: function onClick() {
|
|
799
813
|
setConsent(createConsentGroups());
|
|
@@ -19,9 +19,16 @@ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instan
|
|
|
19
19
|
var _Object$values = require('@babel/runtime-corejs3/core-js-stable/object/values');
|
|
20
20
|
var react$1 = require('@emotion/react');
|
|
21
21
|
var reactIntl = require('react-intl');
|
|
22
|
-
var
|
|
22
|
+
var CollapsiblePanel = require('@commercetools-uikit/collapsible-panel');
|
|
23
|
+
var Grid = require('@commercetools-uikit/grid');
|
|
24
|
+
var Link = require('@commercetools-uikit/link');
|
|
25
|
+
var Spacings = require('@commercetools-uikit/spacings');
|
|
26
|
+
var Text = require('@commercetools-uikit/text');
|
|
27
|
+
var ToggleInput = require('@commercetools-uikit/toggle-input');
|
|
23
28
|
var applicationComponents = require('@commercetools-frontend/application-components');
|
|
24
29
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
30
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
31
|
+
var PrimaryButton = require('@commercetools-uikit/primary-button');
|
|
25
32
|
require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
26
33
|
require('@babel/runtime-corejs3/core-js-stable/object/from-entries');
|
|
27
34
|
require('@babel/runtime-corejs3/core-js-stable/object/entries');
|
|
@@ -40,6 +47,13 @@ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$def
|
|
|
40
47
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
41
48
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
42
49
|
var _Object$values__default = /*#__PURE__*/_interopDefault(_Object$values);
|
|
50
|
+
var CollapsiblePanel__default = /*#__PURE__*/_interopDefault(CollapsiblePanel);
|
|
51
|
+
var Grid__default = /*#__PURE__*/_interopDefault(Grid);
|
|
52
|
+
var Link__default = /*#__PURE__*/_interopDefault(Link);
|
|
53
|
+
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
54
|
+
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
55
|
+
var ToggleInput__default = /*#__PURE__*/_interopDefault(ToggleInput);
|
|
56
|
+
var PrimaryButton__default = /*#__PURE__*/_interopDefault(PrimaryButton);
|
|
43
57
|
|
|
44
58
|
var defaultConsentOptions = {
|
|
45
59
|
skipConsent: false,
|
|
@@ -453,7 +467,7 @@ var View = {
|
|
|
453
467
|
var NavigationLink = function NavigationLink(_ref4) {
|
|
454
468
|
var _onClick = _ref4.onClick,
|
|
455
469
|
label = _ref4.label;
|
|
456
|
-
return jsxRuntime.jsx(
|
|
470
|
+
return jsxRuntime.jsx(Link__default["default"], {
|
|
457
471
|
onClick: function onClick(e) {
|
|
458
472
|
e.preventDefault();
|
|
459
473
|
_onClick();
|
|
@@ -472,7 +486,7 @@ var InformationLink = function InformationLink(_ref5) {
|
|
|
472
486
|
var removeDefaultSvg = _ref3;
|
|
473
487
|
return jsxRuntime.jsx("div", {
|
|
474
488
|
css: removeDefaultSvg,
|
|
475
|
-
children: jsxRuntime.jsx(
|
|
489
|
+
children: jsxRuntime.jsx(Link__default["default"], {
|
|
476
490
|
isExternal: true,
|
|
477
491
|
to: to,
|
|
478
492
|
children: label
|
|
@@ -489,10 +503,10 @@ var DetailLink = function DetailLink(_ref6) {
|
|
|
489
503
|
var removeDefaultSvg = _ref2;
|
|
490
504
|
return jsxRuntime.jsx("div", {
|
|
491
505
|
css: removeDefaultSvg,
|
|
492
|
-
children: jsxRuntime.jsx(
|
|
506
|
+
children: jsxRuntime.jsx(Link__default["default"], {
|
|
493
507
|
isExternal: true,
|
|
494
508
|
to: to,
|
|
495
|
-
children: jsxRuntime.jsx(
|
|
509
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
496
510
|
tone: "primary",
|
|
497
511
|
children: label
|
|
498
512
|
})
|
|
@@ -514,22 +528,22 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
514
528
|
|
|
515
529
|
// The outline of the input is cut off; we shift it to the left to compensate
|
|
516
530
|
var bumpToggle = _ref;
|
|
517
|
-
return jsxRuntime.jsxs(
|
|
531
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
518
532
|
scale: "xl",
|
|
519
|
-
children: [jsxRuntime.jsxs(
|
|
533
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
520
534
|
scale: "m",
|
|
521
|
-
children: [jsxRuntime.jsx(
|
|
535
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
522
536
|
intlMessage: modalMessages.mainDescription
|
|
523
537
|
}), jsxRuntime.jsx(InformationLink, {
|
|
524
538
|
label: formatMessage(modalMessages.privacyPolicyLink),
|
|
525
539
|
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY
|
|
526
540
|
})]
|
|
527
|
-
}), jsxRuntime.jsxs(
|
|
541
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
528
542
|
scale: "l",
|
|
529
|
-
children: [jsxRuntime.jsx(
|
|
543
|
+
children: [jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
530
544
|
condensed: true,
|
|
531
545
|
header: formatMessage(modalMessages.necessaryCookiesHeader),
|
|
532
|
-
headerControls: jsxRuntime.jsx(
|
|
546
|
+
headerControls: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
533
547
|
intlMessage: modalMessages.necessaryCookiesHeaderState,
|
|
534
548
|
tone: "information"
|
|
535
549
|
}),
|
|
@@ -540,9 +554,9 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
540
554
|
}));
|
|
541
555
|
},
|
|
542
556
|
theme: "light",
|
|
543
|
-
children: jsxRuntime.jsxs(
|
|
557
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
544
558
|
scale: "m",
|
|
545
|
-
children: [jsxRuntime.jsx(
|
|
559
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
546
560
|
intlMessage: modalMessages.necessaryCookiesDescription
|
|
547
561
|
}), jsxRuntime.jsx(NavigationLink, {
|
|
548
562
|
label: formatMessage(modalMessages.cookieInformationLink),
|
|
@@ -551,12 +565,12 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
551
565
|
}
|
|
552
566
|
})]
|
|
553
567
|
})
|
|
554
|
-
}), jsxRuntime.jsx(
|
|
568
|
+
}), jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
555
569
|
condensed: true,
|
|
556
570
|
header: formatMessage(modalMessages.performanceCookiesHeader),
|
|
557
571
|
headerControls: jsxRuntime.jsx("div", {
|
|
558
572
|
css: bumpToggle,
|
|
559
|
-
children: jsxRuntime.jsx(
|
|
573
|
+
children: jsxRuntime.jsx(ToggleInput__default["default"], {
|
|
560
574
|
isChecked: toggleValue,
|
|
561
575
|
onChange: function onChange(e) {
|
|
562
576
|
return onToggle(e.target.checked);
|
|
@@ -571,9 +585,9 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
571
585
|
}));
|
|
572
586
|
},
|
|
573
587
|
theme: "light",
|
|
574
|
-
children: jsxRuntime.jsxs(
|
|
588
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
575
589
|
scale: "m",
|
|
576
|
-
children: [jsxRuntime.jsx(
|
|
590
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
577
591
|
intlMessage: modalMessages.performanceCookiesDescription
|
|
578
592
|
}), jsxRuntime.jsx(NavigationLink, {
|
|
579
593
|
label: formatMessage(modalMessages.cookieInformationLink),
|
|
@@ -591,32 +605,32 @@ var CookieConsentBodyDetails = function CookieConsentBodyDetails(_ref8) {
|
|
|
591
605
|
cookieDetails = _ref8.cookieDetails;
|
|
592
606
|
var _useIntl2 = reactIntl.useIntl(),
|
|
593
607
|
formatMessage = _useIntl2.formatMessage;
|
|
594
|
-
return jsxRuntime.jsxs(
|
|
608
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
595
609
|
scale: "l",
|
|
596
610
|
children: [jsxRuntime.jsx(NavigationLink, {
|
|
597
611
|
label: formatMessage(modalMessages.navigateBackLink),
|
|
598
612
|
onClick: function onClick() {
|
|
599
613
|
return onChangeView(View.Primary);
|
|
600
614
|
}
|
|
601
|
-
}), jsxRuntime.jsx(
|
|
615
|
+
}), jsxRuntime.jsx(Spacings__default["default"].Stack, {
|
|
602
616
|
scale: "l",
|
|
603
617
|
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails, function (detail) {
|
|
604
618
|
var _context;
|
|
605
|
-
return jsxRuntime.jsx(
|
|
619
|
+
return jsxRuntime.jsx(Grid__default["default"], {
|
|
606
620
|
gridGap: "24px",
|
|
607
621
|
gridRowGap: "0px",
|
|
608
622
|
gridTemplateColumns: "80px 1fr",
|
|
609
623
|
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context, function (value) {
|
|
610
624
|
return jsxRuntime.jsxs(react.Fragment, {
|
|
611
|
-
children: [jsxRuntime.jsx(
|
|
612
|
-
children: jsxRuntime.jsx(
|
|
625
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
626
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
613
627
|
children: value.label
|
|
614
628
|
})
|
|
615
|
-
}), jsxRuntime.jsx(
|
|
629
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
616
630
|
children: 'to' in value ? jsxRuntime.jsx(DetailLink, {
|
|
617
631
|
label: value.value,
|
|
618
632
|
to: value.to
|
|
619
|
-
}) : jsxRuntime.jsx(
|
|
633
|
+
}) : jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
620
634
|
children: value.value
|
|
621
635
|
})
|
|
622
636
|
})]
|
|
@@ -750,23 +764,23 @@ var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
|
750
764
|
return (
|
|
751
765
|
// TODO: use lower z-index, prefer ranges per use-case
|
|
752
766
|
jsxRuntime.jsxs("div", {
|
|
753
|
-
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:",
|
|
767
|
+
css: /*#__PURE__*/react$1.css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", designSystem.designTokens.spacingXl, ";z-index:1000000;width:100%;" + ("" ), "" ),
|
|
754
768
|
children: [jsxRuntime.jsx("div", {
|
|
755
|
-
css: /*#__PURE__*/react$1.css("background-color:",
|
|
756
|
-
children: jsxRuntime.jsxs(
|
|
769
|
+
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
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
757
771
|
alignItems: "center",
|
|
758
772
|
scale: "xl",
|
|
759
|
-
children: [jsxRuntime.jsx(
|
|
773
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
760
774
|
tone: "inverted",
|
|
761
775
|
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread(_objectSpread({}, messages.bannerMessage), {}, {
|
|
762
776
|
values: {
|
|
763
|
-
privacyLink: jsxRuntime.jsx(
|
|
777
|
+
privacyLink: jsxRuntime.jsx(Link__default["default"], {
|
|
764
778
|
intlMessage: messages.privacyPolicyLink,
|
|
765
779
|
isExternal: true,
|
|
766
780
|
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY,
|
|
767
781
|
tone: "inverted"
|
|
768
782
|
}),
|
|
769
|
-
modalLink: jsxRuntime.jsx(
|
|
783
|
+
modalLink: jsxRuntime.jsx(Link__default["default"], {
|
|
770
784
|
intlMessage: messages.bannerCookiesModalLink,
|
|
771
785
|
onClick: function onClick(e) {
|
|
772
786
|
e.preventDefault();
|
|
@@ -777,7 +791,7 @@ var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
|
777
791
|
})
|
|
778
792
|
}
|
|
779
793
|
}))
|
|
780
|
-
}), jsxRuntime.jsx(
|
|
794
|
+
}), jsxRuntime.jsx(PrimaryButton__default["default"], {
|
|
781
795
|
label: formatMessage(messages.buttonLabel),
|
|
782
796
|
onClick: function onClick() {
|
|
783
797
|
setConsent(createConsentGroups());
|