@commercetools-frontend/cookie-consent 1.2.2 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.dev.js +6 -3
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.prod.js +6 -3
- package/core/dist/commercetools-frontend-cookie-consent-core.esm.js +119 -0
- package/core/package.json +2 -1
- package/dist/declarations/src/core/index.d.ts +5 -2
- package/package.json +1 -1
- package/react/dist/commercetools-frontend-cookie-consent-react.esm.js +815 -0
- package/react/package.json +2 -1
|
@@ -46,9 +46,10 @@ var COOKIE_CONSENT_GROUPS = {
|
|
|
46
46
|
targetingCookies: 'C0004',
|
|
47
47
|
socialMediaCookies: 'C0005'
|
|
48
48
|
};
|
|
49
|
+
var CONSENT_COOKIE_NAME = 'OptanonConsent';
|
|
49
50
|
function getRawConsentCookie() {
|
|
50
51
|
var _context;
|
|
51
|
-
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] :
|
|
52
|
+
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : CONSENT_COOKIE_NAME;
|
|
52
53
|
var escapedCookies = decodeURIComponent(document.cookie);
|
|
53
54
|
var consentCookie = _findInstanceProperty__default["default"](_context = escapedCookies.split('; ')).call(_context, function (rawCookie) {
|
|
54
55
|
var _rawCookie$split = rawCookie.split('='),
|
|
@@ -77,7 +78,7 @@ function getParsedConsentCookieGroups() {
|
|
|
77
78
|
var _context4;
|
|
78
79
|
var parsedConsentCookieValue = new _URLSearchParams__default["default"](cookieValue);
|
|
79
80
|
var rawConsentCookieGroups = parsedConsentCookieValue.get('groups');
|
|
80
|
-
var parsedConsentCookieGroupEntries = rawConsentCookieGroups
|
|
81
|
+
var parsedConsentCookieGroupEntries = rawConsentCookieGroups && _mapInstanceProperty__default["default"](_context4 = rawConsentCookieGroups.split(',')).call(_context4, function (consentGroup) {
|
|
81
82
|
var _consentGroup$split = consentGroup.split(':'),
|
|
82
83
|
_consentGroup$split2 = _slicedToArray(_consentGroup$split, 2),
|
|
83
84
|
encodedConsentGroupName = _consentGroup$split2[0],
|
|
@@ -133,10 +134,12 @@ function setConsentCookie(consentGroups) {
|
|
|
133
134
|
var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '.commercetools.com';
|
|
134
135
|
var expiresAt = new Date();
|
|
135
136
|
expiresAt.setFullYear(expiresAt.getFullYear() + 11);
|
|
136
|
-
document.cookie = _concatInstanceProperty__default["default"](_context8 = _concatInstanceProperty__default["default"](_context9 = "
|
|
137
|
+
document.cookie = _concatInstanceProperty__default["default"](_context8 = _concatInstanceProperty__default["default"](_context9 = "".concat(CONSENT_COOKIE_NAME, "=").concat(generateConsentCookie(consentGroups), "; domain=")).call(_context9, domain, "; expires=")).call(_context8, expiresAt.toUTCString(), "; SameSite=Lax; path=/; ");
|
|
137
138
|
}
|
|
138
139
|
|
|
140
|
+
exports.CONSENT_COOKIE_NAME = CONSENT_COOKIE_NAME;
|
|
139
141
|
exports.COOKIE_CONSENT_GROUPS = COOKIE_CONSENT_GROUPS;
|
|
142
|
+
exports.generateConsentCookie = generateConsentCookie;
|
|
140
143
|
exports.getParsedConsentCookieGroups = getParsedConsentCookieGroups;
|
|
141
144
|
exports.getRawConsentCookie = getRawConsentCookie;
|
|
142
145
|
exports.setConsentCookie = setConsentCookie;
|
|
@@ -46,9 +46,10 @@ var COOKIE_CONSENT_GROUPS = {
|
|
|
46
46
|
targetingCookies: 'C0004',
|
|
47
47
|
socialMediaCookies: 'C0005'
|
|
48
48
|
};
|
|
49
|
+
var CONSENT_COOKIE_NAME = 'OptanonConsent';
|
|
49
50
|
function getRawConsentCookie() {
|
|
50
51
|
var _context;
|
|
51
|
-
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] :
|
|
52
|
+
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : CONSENT_COOKIE_NAME;
|
|
52
53
|
var escapedCookies = decodeURIComponent(document.cookie);
|
|
53
54
|
var consentCookie = _findInstanceProperty__default["default"](_context = escapedCookies.split('; ')).call(_context, function (rawCookie) {
|
|
54
55
|
var _rawCookie$split = rawCookie.split('='),
|
|
@@ -77,7 +78,7 @@ function getParsedConsentCookieGroups() {
|
|
|
77
78
|
var _context4;
|
|
78
79
|
var parsedConsentCookieValue = new _URLSearchParams__default["default"](cookieValue);
|
|
79
80
|
var rawConsentCookieGroups = parsedConsentCookieValue.get('groups');
|
|
80
|
-
var parsedConsentCookieGroupEntries = rawConsentCookieGroups
|
|
81
|
+
var parsedConsentCookieGroupEntries = rawConsentCookieGroups && _mapInstanceProperty__default["default"](_context4 = rawConsentCookieGroups.split(',')).call(_context4, function (consentGroup) {
|
|
81
82
|
var _consentGroup$split = consentGroup.split(':'),
|
|
82
83
|
_consentGroup$split2 = _slicedToArray(_consentGroup$split, 2),
|
|
83
84
|
encodedConsentGroupName = _consentGroup$split2[0],
|
|
@@ -133,10 +134,12 @@ function setConsentCookie(consentGroups) {
|
|
|
133
134
|
var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '.commercetools.com';
|
|
134
135
|
var expiresAt = new Date();
|
|
135
136
|
expiresAt.setFullYear(expiresAt.getFullYear() + 11);
|
|
136
|
-
document.cookie = _concatInstanceProperty__default["default"](_context8 = _concatInstanceProperty__default["default"](_context9 = "
|
|
137
|
+
document.cookie = _concatInstanceProperty__default["default"](_context8 = _concatInstanceProperty__default["default"](_context9 = "".concat(CONSENT_COOKIE_NAME, "=").concat(generateConsentCookie(consentGroups), "; domain=")).call(_context9, domain, "; expires=")).call(_context8, expiresAt.toUTCString(), "; SameSite=Lax; path=/; ");
|
|
137
138
|
}
|
|
138
139
|
|
|
140
|
+
exports.CONSENT_COOKIE_NAME = CONSENT_COOKIE_NAME;
|
|
139
141
|
exports.COOKIE_CONSENT_GROUPS = COOKIE_CONSENT_GROUPS;
|
|
142
|
+
exports.generateConsentCookie = generateConsentCookie;
|
|
140
143
|
exports.getParsedConsentCookieGroups = getParsedConsentCookieGroups;
|
|
141
144
|
exports.getRawConsentCookie = getRawConsentCookie;
|
|
142
145
|
exports.setConsentCookie = setConsentCookie;
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
2
|
+
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
3
|
+
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
4
|
+
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
5
|
+
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
6
|
+
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
7
|
+
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
8
|
+
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
9
|
+
import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
|
|
10
|
+
import _Object$fromEntries from '@babel/runtime-corejs3/core-js-stable/object/from-entries';
|
|
11
|
+
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
12
|
+
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
13
|
+
import _Object$entries from '@babel/runtime-corejs3/core-js-stable/object/entries';
|
|
14
|
+
import _URLSearchParams from '@babel/runtime-corejs3/core-js-stable/url-search-params';
|
|
15
|
+
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
16
|
+
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
17
|
+
|
|
18
|
+
var _context2;
|
|
19
|
+
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
20
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context10, _context11; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context10 = ownKeys(Object(source), !0)).call(_context10, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context11 = ownKeys(Object(source))).call(_context11, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
21
|
+
var COOKIE_CONSENT_GROUPS = {
|
|
22
|
+
essentialCookies: 'C0001',
|
|
23
|
+
performanceCookies: 'C0002',
|
|
24
|
+
functionalCookies: 'C0003',
|
|
25
|
+
targetingCookies: 'C0004',
|
|
26
|
+
socialMediaCookies: 'C0005'
|
|
27
|
+
};
|
|
28
|
+
var CONSENT_COOKIE_NAME = 'OptanonConsent';
|
|
29
|
+
function getRawConsentCookie() {
|
|
30
|
+
var _context;
|
|
31
|
+
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : CONSENT_COOKIE_NAME;
|
|
32
|
+
var escapedCookies = decodeURIComponent(document.cookie);
|
|
33
|
+
var consentCookie = _findInstanceProperty(_context = escapedCookies.split('; ')).call(_context, function (rawCookie) {
|
|
34
|
+
var _rawCookie$split = rawCookie.split('='),
|
|
35
|
+
_rawCookie$split2 = _slicedToArray(_rawCookie$split, 1),
|
|
36
|
+
cookieName = _rawCookie$split2[0];
|
|
37
|
+
return cookieName === name;
|
|
38
|
+
});
|
|
39
|
+
return consentCookie;
|
|
40
|
+
}
|
|
41
|
+
var defaultConsentGroups = _Object$fromEntries(_mapInstanceProperty(_context2 = _Object$keys(COOKIE_CONSENT_GROUPS)).call(_context2, function (consentGroup) {
|
|
42
|
+
return [consentGroup, false];
|
|
43
|
+
}));
|
|
44
|
+
function getParsedConsentCookieGroups() {
|
|
45
|
+
var _context3;
|
|
46
|
+
var cookieValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getRawConsentCookie();
|
|
47
|
+
var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
|
|
48
|
+
skipConsent = _ref.skipConsent;
|
|
49
|
+
var parsedConsentCookieGroups = {};
|
|
50
|
+
var encodedConsentGroupToConsentGroup = _Object$fromEntries(_mapInstanceProperty(_context3 = _Object$entries(COOKIE_CONSENT_GROUPS)).call(_context3, function (_ref2) {
|
|
51
|
+
var _ref3 = _slicedToArray(_ref2, 2),
|
|
52
|
+
encodedConsentGroupName = _ref3[0],
|
|
53
|
+
decodedConsentGroupName = _ref3[1];
|
|
54
|
+
return [decodedConsentGroupName, encodedConsentGroupName];
|
|
55
|
+
}));
|
|
56
|
+
try {
|
|
57
|
+
var _context4;
|
|
58
|
+
var parsedConsentCookieValue = new _URLSearchParams(cookieValue);
|
|
59
|
+
var rawConsentCookieGroups = parsedConsentCookieValue.get('groups');
|
|
60
|
+
var parsedConsentCookieGroupEntries = rawConsentCookieGroups && _mapInstanceProperty(_context4 = rawConsentCookieGroups.split(',')).call(_context4, function (consentGroup) {
|
|
61
|
+
var _consentGroup$split = consentGroup.split(':'),
|
|
62
|
+
_consentGroup$split2 = _slicedToArray(_consentGroup$split, 2),
|
|
63
|
+
encodedConsentGroupName = _consentGroup$split2[0],
|
|
64
|
+
consentGroupValue = _consentGroup$split2[1];
|
|
65
|
+
return [encodedConsentGroupToConsentGroup[encodedConsentGroupName], skipConsent === true ? true : consentGroupValue === '1'];
|
|
66
|
+
});
|
|
67
|
+
parsedConsentCookieGroups = parsedConsentCookieGroupEntries ? _Object$fromEntries(parsedConsentCookieGroupEntries) : null;
|
|
68
|
+
} catch (error) {}
|
|
69
|
+
return _objectSpread(_objectSpread({}, defaultConsentGroups), parsedConsentCookieGroups);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Copied from GitHub to make this library not have a UUID library dependency.
|
|
74
|
+
* This implementation is good enough for the purposes here.
|
|
75
|
+
*/
|
|
76
|
+
function generateUuid(prefix) {
|
|
77
|
+
return prefix ? ((Number(prefix) ^ Math.random() * 16) >> Number(prefix) / 4).toString(16) : "".concat(1e7, "-", 1e3, "-", 4e3, "-", 8e3, "-", 1e11).replace(/[018]/g, generateUuid);
|
|
78
|
+
}
|
|
79
|
+
function generateEncodedConsentGroups(consentGroups) {
|
|
80
|
+
var _context5, _context6;
|
|
81
|
+
return _filterInstanceProperty(_context5 = _mapInstanceProperty(_context6 = _Object$entries(consentGroups)).call(_context6, function (_ref4) {
|
|
82
|
+
var _context7;
|
|
83
|
+
var _ref5 = _slicedToArray(_ref4, 2),
|
|
84
|
+
consentGroupName = _ref5[0],
|
|
85
|
+
consentGroupValue = _ref5[1];
|
|
86
|
+
var encodedConsentGroup = COOKIE_CONSENT_GROUPS[consentGroupName];
|
|
87
|
+
if (!encodedConsentGroup) {
|
|
88
|
+
return null;
|
|
89
|
+
}
|
|
90
|
+
return _concatInstanceProperty(_context7 = "".concat(encodedConsentGroup, ":")).call(_context7, consentGroupValue && '1' || '0');
|
|
91
|
+
})).call(_context5, Boolean).join(',');
|
|
92
|
+
}
|
|
93
|
+
function generateConsentCookie(consentGroups) {
|
|
94
|
+
var existingConsentGroups = getParsedConsentCookieGroups();
|
|
95
|
+
var encodedConsentGroups = generateEncodedConsentGroups(_objectSpread(_objectSpread({}, existingConsentGroups), consentGroups));
|
|
96
|
+
var consentValues = {
|
|
97
|
+
isGpcEnabled: '0',
|
|
98
|
+
datestamp: new Date().toString(),
|
|
99
|
+
version: '202209.1.0',
|
|
100
|
+
isIABGlobal: 'false',
|
|
101
|
+
hosts: '',
|
|
102
|
+
consentId: generateUuid(),
|
|
103
|
+
interactionCount: '1',
|
|
104
|
+
landingPath: 'NotLandingPage',
|
|
105
|
+
groups: encodedConsentGroups,
|
|
106
|
+
AwaitingReconsent: 'false'
|
|
107
|
+
};
|
|
108
|
+
var consentCookieValue = new _URLSearchParams(consentValues);
|
|
109
|
+
return consentCookieValue.toString();
|
|
110
|
+
}
|
|
111
|
+
function setConsentCookie(consentGroups) {
|
|
112
|
+
var _context8, _context9;
|
|
113
|
+
var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '.commercetools.com';
|
|
114
|
+
var expiresAt = new Date();
|
|
115
|
+
expiresAt.setFullYear(expiresAt.getFullYear() + 11);
|
|
116
|
+
document.cookie = _concatInstanceProperty(_context8 = _concatInstanceProperty(_context9 = "".concat(CONSENT_COOKIE_NAME, "=").concat(generateConsentCookie(consentGroups), "; domain=")).call(_context9, domain, "; expires=")).call(_context8, expiresAt.toUTCString(), "; SameSite=Lax; path=/; ");
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
export { CONSENT_COOKIE_NAME, COOKIE_CONSENT_GROUPS, generateConsentCookie, getParsedConsentCookieGroups, getRawConsentCookie, setConsentCookie };
|
package/core/package.json
CHANGED
|
@@ -6,6 +6,8 @@ declare const COOKIE_CONSENT_GROUPS: {
|
|
|
6
6
|
readonly socialMediaCookies: "C0005";
|
|
7
7
|
};
|
|
8
8
|
type TConsentGroupNames = keyof typeof COOKIE_CONSENT_GROUPS;
|
|
9
|
+
type TConsentGroups = Record<TConsentGroupNames, boolean>;
|
|
10
|
+
declare const CONSENT_COOKIE_NAME = "OptanonConsent";
|
|
9
11
|
declare function getRawConsentCookie(name?: string): string | undefined;
|
|
10
12
|
type TGetParsedConsentCookieGroupsOptions = {
|
|
11
13
|
skipConsent?: boolean;
|
|
@@ -17,5 +19,6 @@ declare function getParsedConsentCookieGroups(cookieValue?: string | undefined,
|
|
|
17
19
|
targetingCookies: boolean;
|
|
18
20
|
socialMediaCookies: boolean;
|
|
19
21
|
};
|
|
20
|
-
declare function
|
|
21
|
-
|
|
22
|
+
declare function generateConsentCookie(consentGroups: Partial<TConsentGroups>): string;
|
|
23
|
+
declare function setConsentCookie(consentGroups: Partial<TConsentGroups>, domain?: string): void;
|
|
24
|
+
export { type TConsentGroups, CONSENT_COOKIE_NAME, getRawConsentCookie, getParsedConsentCookieGroups, setConsentCookie, generateConsentCookie, COOKIE_CONSENT_GROUPS, };
|
package/package.json
CHANGED
|
@@ -0,0 +1,815 @@
|
|
|
1
|
+
import { useMemo, useState, useEffect, Fragment as Fragment$1, createRef } from 'react';
|
|
2
|
+
import { getRawConsentCookie, getParsedConsentCookieGroups, setConsentCookie } from '../../core/dist/commercetools-frontend-cookie-consent-core.esm.js';
|
|
3
|
+
import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
|
|
4
|
+
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
5
|
+
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
6
|
+
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
7
|
+
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
8
|
+
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
9
|
+
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
10
|
+
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
11
|
+
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
12
|
+
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
13
|
+
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
14
|
+
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
15
|
+
import _Object$values from '@babel/runtime-corejs3/core-js-stable/object/values';
|
|
16
|
+
import { css } from '@emotion/react';
|
|
17
|
+
import { defineMessages, useIntl, FormattedMessage } from 'react-intl';
|
|
18
|
+
import { designTokens } from '@commercetools-uikit/design-system';
|
|
19
|
+
import Link from '@commercetools-uikit/link';
|
|
20
|
+
import PrimaryButton from '@commercetools-uikit/primary-button';
|
|
21
|
+
import Spacings from '@commercetools-uikit/spacings';
|
|
22
|
+
import Text from '@commercetools-uikit/text';
|
|
23
|
+
import { ConfirmationDialog, useModalState } from '@commercetools-frontend/application-components';
|
|
24
|
+
import { jsxs, jsx, Fragment } from '@emotion/react/jsx-runtime';
|
|
25
|
+
import CollapsiblePanel from '@commercetools-uikit/collapsible-panel';
|
|
26
|
+
import Grid from '@commercetools-uikit/grid';
|
|
27
|
+
import ToggleInput from '@commercetools-uikit/toggle-input';
|
|
28
|
+
import '@babel/runtime-corejs3/core-js-stable/instance/find';
|
|
29
|
+
import '@babel/runtime-corejs3/core-js-stable/object/from-entries';
|
|
30
|
+
import '@babel/runtime-corejs3/core-js-stable/object/entries';
|
|
31
|
+
import '@babel/runtime-corejs3/core-js-stable/url-search-params';
|
|
32
|
+
import '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
33
|
+
|
|
34
|
+
var defaultConsentOptions = {
|
|
35
|
+
skipConsent: false,
|
|
36
|
+
cookieName: 'OptanonConsent'
|
|
37
|
+
};
|
|
38
|
+
function useCookieConsent(consentGroup) {
|
|
39
|
+
var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultConsentOptions,
|
|
40
|
+
skipConsent = _ref.skipConsent,
|
|
41
|
+
cookieName = _ref.cookieName;
|
|
42
|
+
var consentCookieGroups = useMemo(function () {
|
|
43
|
+
var rawConsentCookie = getRawConsentCookie(cookieName);
|
|
44
|
+
var consentCookieGroups = getParsedConsentCookieGroups(rawConsentCookie, {
|
|
45
|
+
skipConsent: skipConsent
|
|
46
|
+
});
|
|
47
|
+
return consentCookieGroups;
|
|
48
|
+
}, [cookieName, skipConsent]);
|
|
49
|
+
return {
|
|
50
|
+
givenConsent: skipConsent || Boolean(consentCookieGroups[consentGroup]),
|
|
51
|
+
setConsent: setConsentCookie
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function useSkipCookieConsent() {
|
|
56
|
+
var skipCookieConsent = useApplicationContext(function (context) {
|
|
57
|
+
return context.environment.skipCookieConsent;
|
|
58
|
+
});
|
|
59
|
+
return Boolean(skipCookieConsent);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
var modalMessages = defineMessages({
|
|
63
|
+
title: {
|
|
64
|
+
id: 'CookieConsentModal.title',
|
|
65
|
+
description: 'Confirmation dialog title',
|
|
66
|
+
defaultMessage: 'Privacy Preference Center'
|
|
67
|
+
},
|
|
68
|
+
primaryButtonLabel: {
|
|
69
|
+
id: 'CookieConsentModal.primaryButtonLabel',
|
|
70
|
+
description: 'Primary button text',
|
|
71
|
+
defaultMessage: 'Accept all cookies'
|
|
72
|
+
},
|
|
73
|
+
secondaryButtonLabel: {
|
|
74
|
+
id: 'CookieConsentModal.secondaryButtonLabel',
|
|
75
|
+
description: 'Secondary button text',
|
|
76
|
+
defaultMessage: 'Confirm my choices'
|
|
77
|
+
},
|
|
78
|
+
mainDescription: {
|
|
79
|
+
id: 'CookieConsentModal.primary.mainDescription',
|
|
80
|
+
description: 'Main body copy',
|
|
81
|
+
defaultMessage: 'When you visit any website, it may store or retrieve information on your browser, mostly in the form of cookies. This information might be about you, your preferences or your device and is mostly used to make the site work as you expect it to. The information does not usually directly identify you, but it can give you a more personalized web experience. Because we respect your right to privacy, you can choose not to allow some types of cookies. Click on the different category headings to find out more and change our default settings. However, blocking some types of cookies may impact your experience of the site and the services we are able to offer.'
|
|
82
|
+
},
|
|
83
|
+
privacyPolicyLink: {
|
|
84
|
+
id: 'CookieConsentModal.primary.privacyPolicyLink',
|
|
85
|
+
description: 'Link to privacy policy',
|
|
86
|
+
defaultMessage: 'More information'
|
|
87
|
+
},
|
|
88
|
+
necessaryCookiesHeader: {
|
|
89
|
+
id: 'CookieConsentModal.primary.necessaryCookiesHeader',
|
|
90
|
+
description: 'Header for first collapsible content block',
|
|
91
|
+
defaultMessage: 'Strictly necessary cookies'
|
|
92
|
+
},
|
|
93
|
+
necessaryCookiesDescription: {
|
|
94
|
+
id: 'CookieConsentModal.primary.necessaryCookiesDescription',
|
|
95
|
+
description: 'Description of content from first collapsible header',
|
|
96
|
+
defaultMessage: 'These cookies are necessary for the website to function and cannot be switched off in our systems. They are usually only set in response to actions made by you which amount to a request for services, such as setting your privacy preferences, logging in or filling in forms. You can set your browser to block or alert you about these cookies, but some parts of the site will not then work. These cookies do not store any personally identifiable information.'
|
|
97
|
+
},
|
|
98
|
+
necessaryCookiesHeaderState: {
|
|
99
|
+
id: 'CookieConsentModal.primary.necessaryCookiesHeaderState',
|
|
100
|
+
description: 'State of the cookies described in the header',
|
|
101
|
+
defaultMessage: 'Always active'
|
|
102
|
+
},
|
|
103
|
+
performanceCookiesHeader: {
|
|
104
|
+
id: 'CookieConsentModal.primary.performanceCookiesHeader',
|
|
105
|
+
description: 'Header for second collapsible content block',
|
|
106
|
+
defaultMessage: 'Performance cookies'
|
|
107
|
+
},
|
|
108
|
+
performanceCookiesDescription: {
|
|
109
|
+
id: 'CookieConsentModal.primary.performanceCookiesDescription',
|
|
110
|
+
description: 'Description of content from second collapsible header',
|
|
111
|
+
defaultMessage: 'These cookies allow us to count visits and traffic sources so we can measure and improve the performance of our site. They help us to know which pages are the most and least popular and see how visitors move around the site. All information these cookies collect is aggregated and therefore anonymous. If you do not allow these cookies we will not know when you have visited our site, and will not be able to monitor its performance.'
|
|
112
|
+
},
|
|
113
|
+
cookieInformationLink: {
|
|
114
|
+
id: 'CookieConsentModal.primary.cookieInformationLink',
|
|
115
|
+
description: 'Link to additional cookie information',
|
|
116
|
+
defaultMessage: 'Cookies details'
|
|
117
|
+
},
|
|
118
|
+
navigateBackLink: {
|
|
119
|
+
id: 'CookieConsentModal.primary.navigateBackLink',
|
|
120
|
+
description: 'Link to go back to primary view',
|
|
121
|
+
defaultMessage: 'Back to Privacy Preference Center'
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
var cookieDetailLabels = defineMessages({
|
|
125
|
+
nameLabel: {
|
|
126
|
+
id: 'CookieConsentModal.cookieDetails.nameLabel',
|
|
127
|
+
description: 'Name - category identifier',
|
|
128
|
+
defaultMessage: 'Name'
|
|
129
|
+
},
|
|
130
|
+
hostLabel: {
|
|
131
|
+
id: 'CookieConsentModal.cookieDetails.hostLabel',
|
|
132
|
+
description: 'Host - category identifier',
|
|
133
|
+
defaultMessage: 'Host'
|
|
134
|
+
},
|
|
135
|
+
durationLabel: {
|
|
136
|
+
id: 'CookieConsentModal.cookieDetails.durationLabel',
|
|
137
|
+
description: 'Duration - category identifier',
|
|
138
|
+
defaultMessage: 'Duration'
|
|
139
|
+
},
|
|
140
|
+
typeLabel: {
|
|
141
|
+
id: 'CookieConsentModal.cookieDetails.typeLabel',
|
|
142
|
+
description: 'Type - category identifier',
|
|
143
|
+
defaultMessage: 'Type'
|
|
144
|
+
},
|
|
145
|
+
categoryLabel: {
|
|
146
|
+
id: 'CookieConsentModal.cookieDetails.categoryLabel',
|
|
147
|
+
description: 'Category - category identifier',
|
|
148
|
+
defaultMessage: 'Category'
|
|
149
|
+
},
|
|
150
|
+
descriptionLabel: {
|
|
151
|
+
id: 'CookieConsentModal.cookieDetails.descriptionLabel',
|
|
152
|
+
description: 'Description - category identifier',
|
|
153
|
+
defaultMessage: 'Description'
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
var cookieDetailValues = defineMessages({
|
|
157
|
+
duration9Months: {
|
|
158
|
+
id: 'CookieConsentModal.cookieDetails.duration9Months',
|
|
159
|
+
description: 'Length of time',
|
|
160
|
+
defaultMessage: '9 Months'
|
|
161
|
+
},
|
|
162
|
+
duration1Week: {
|
|
163
|
+
id: 'CookieConsentModal.cookieDetails.duration1Week',
|
|
164
|
+
description: 'Length of time',
|
|
165
|
+
defaultMessage: '1 Week'
|
|
166
|
+
},
|
|
167
|
+
durationSession: {
|
|
168
|
+
id: 'CookieConsentModal.cookieDetails.durationSession',
|
|
169
|
+
description: 'Length of time for cookie to expire in the browser',
|
|
170
|
+
defaultMessage: 'Session'
|
|
171
|
+
},
|
|
172
|
+
duration1Year: {
|
|
173
|
+
id: 'CookieConsentModal.cookieDetails.duration1Year',
|
|
174
|
+
description: 'Length of time',
|
|
175
|
+
defaultMessage: '1 Year'
|
|
176
|
+
},
|
|
177
|
+
duration1Day: {
|
|
178
|
+
id: 'CookieConsentModal.cookieDetails.duration1Day',
|
|
179
|
+
description: 'Length of time',
|
|
180
|
+
defaultMessage: '1 Day'
|
|
181
|
+
},
|
|
182
|
+
typeFirstParty: {
|
|
183
|
+
id: 'CookieConsentModal.cookieDetails.typeFirstParty',
|
|
184
|
+
description: 'Type of cookie',
|
|
185
|
+
defaultMessage: 'First party'
|
|
186
|
+
},
|
|
187
|
+
categoryStrictlyNecessary: {
|
|
188
|
+
id: 'CookieConsentModal.cookieDetails.categoryStrictlyNecessary',
|
|
189
|
+
description: 'Type of cookie',
|
|
190
|
+
defaultMessage: 'Strictly Necessary Cookies'
|
|
191
|
+
},
|
|
192
|
+
categoryPerformance: {
|
|
193
|
+
id: 'CookieConsentModal.cookieDetails.categoryPerformance',
|
|
194
|
+
description: 'Type of cookie',
|
|
195
|
+
defaultMessage: 'Performance Cookies'
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
var cookieDetailDescriptions = defineMessages({
|
|
199
|
+
essentialCookieDescription1: {
|
|
200
|
+
id: 'CookieConsentModal.cookieDetails.essentialCookieDescription1',
|
|
201
|
+
description: 'Description of cookie',
|
|
202
|
+
defaultMessage: 'Identifier for each unique device that interacts with Intercom. It is refreshed on each successful ping, extending it another 9 months. Set by Intercom Messenger within the commercetools Merchant Center.'
|
|
203
|
+
},
|
|
204
|
+
essentialCookieDescription2: {
|
|
205
|
+
id: 'CookieConsentModal.cookieDetails.essentialCookieDescription2',
|
|
206
|
+
description: 'Description of cookie',
|
|
207
|
+
defaultMessage: 'Anonymous visitor identifier cookie. Set by Intercom Messenger within the commercetools Merchant Center.'
|
|
208
|
+
},
|
|
209
|
+
essentialCookieDescription3: {
|
|
210
|
+
id: 'CookieConsentModal.cookieDetails.essentialCookieDescription3',
|
|
211
|
+
description: 'Description of cookie',
|
|
212
|
+
defaultMessage: 'Identifier for each unique browser session. This session cookie is refreshed on each successfully logged-in ping, extending it one week from this moment. Set by Intercom Messenger within the commercetools Merchant Center.'
|
|
213
|
+
},
|
|
214
|
+
performanceCookieDescription1: {
|
|
215
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription1',
|
|
216
|
+
description: 'Description of cookie',
|
|
217
|
+
defaultMessage: 'Support multi-tab playback, provides a unique ID to each tab. Note that this is technically not a cookie, but a form of sessionStorage: https://developer.mozilla.org/en-US/docs/Web/API/Window/sessionStorage Set by FullStory within the commercetools Merchant Center.'
|
|
218
|
+
},
|
|
219
|
+
performanceCookieDescription2: {
|
|
220
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription2',
|
|
221
|
+
description: 'Description of cookie',
|
|
222
|
+
defaultMessage: 'Stores the consent state for this device. For more on consent state see: https://help.fullstory.com/hc/en-us/articles/360020623254-FS-consent-Capture-elements-with-consent Set by FullStory within the commercetools Merchant Center.'
|
|
223
|
+
},
|
|
224
|
+
performanceCookieDescription3: {
|
|
225
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription3',
|
|
226
|
+
description: 'Description of cookie',
|
|
227
|
+
defaultMessage: 'Captures the timestamp of the last user action. It is used to assist with the FullStory session lifecycle, ensuring user activity extends the session. See "What defines a session in FullStory?" for more info on the session lifecycle: https://help.fullstory.com/hc/en-us/articles/360020624614-What-defines-a-session-in-FullStory- Set by FullStory within the commercetools Merchant Center.'
|
|
228
|
+
},
|
|
229
|
+
performanceCookieDescription4: {
|
|
230
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription4',
|
|
231
|
+
description: 'Description of cookie',
|
|
232
|
+
defaultMessage: "The 'fs_uid' cookie can be thought of as the capture cookie. When an end-user visits a customer's site, that cookie is used to track the user across sessions and pages. The same user may visit a site multiple times and may navigate to many pages within a single session. This cookie ensures that all captured session traffic is associated with one user. A session cannot be captured without this cookie and the users anonymized visit will not be logged. Set by FullStory within the commercetools Merchant Center."
|
|
233
|
+
}
|
|
234
|
+
});
|
|
235
|
+
|
|
236
|
+
var COOKIE_CONSENT_LINKS = {
|
|
237
|
+
PRIVACY_POLICY: 'https://commercetools.com/privacy#website'
|
|
238
|
+
};
|
|
239
|
+
|
|
240
|
+
var HOSTNAME = 'commercetools.com';
|
|
241
|
+
var createCookieLink = function createCookieLink(cookieName) {
|
|
242
|
+
return "https://cookiepedia.co.uk/cookies/".concat(cookieName);
|
|
243
|
+
};
|
|
244
|
+
var createEssentialCookieDetails = function createEssentialCookieDetails(intl) {
|
|
245
|
+
return [{
|
|
246
|
+
name: {
|
|
247
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
248
|
+
value: 'intercom-device-id-b74wbpa8',
|
|
249
|
+
to: createCookieLink('intercom-device-id-b74wbpa8')
|
|
250
|
+
},
|
|
251
|
+
host: {
|
|
252
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
253
|
+
value: HOSTNAME
|
|
254
|
+
},
|
|
255
|
+
duration: {
|
|
256
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
257
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
258
|
+
},
|
|
259
|
+
type: {
|
|
260
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
261
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
262
|
+
},
|
|
263
|
+
category: {
|
|
264
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
265
|
+
value: intl.formatMessage(cookieDetailValues.categoryStrictlyNecessary)
|
|
266
|
+
},
|
|
267
|
+
description: {
|
|
268
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
269
|
+
value: intl.formatMessage(cookieDetailDescriptions.essentialCookieDescription1)
|
|
270
|
+
}
|
|
271
|
+
}, {
|
|
272
|
+
name: {
|
|
273
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
274
|
+
value: 'intercom-id-b74wbpa8',
|
|
275
|
+
to: createCookieLink('intercom-id-b74wbpa8')
|
|
276
|
+
},
|
|
277
|
+
host: {
|
|
278
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
279
|
+
value: HOSTNAME
|
|
280
|
+
},
|
|
281
|
+
duration: {
|
|
282
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
283
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
284
|
+
},
|
|
285
|
+
type: {
|
|
286
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
287
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
288
|
+
},
|
|
289
|
+
category: {
|
|
290
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
291
|
+
value: intl.formatMessage(cookieDetailValues.categoryStrictlyNecessary)
|
|
292
|
+
},
|
|
293
|
+
description: {
|
|
294
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
295
|
+
value: intl.formatMessage(cookieDetailDescriptions.essentialCookieDescription2)
|
|
296
|
+
}
|
|
297
|
+
}, {
|
|
298
|
+
name: {
|
|
299
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
300
|
+
value: 'intercom-session-b74wbpa8',
|
|
301
|
+
to: createCookieLink('intercom-session-b74wbpa8')
|
|
302
|
+
},
|
|
303
|
+
host: {
|
|
304
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
305
|
+
value: HOSTNAME
|
|
306
|
+
},
|
|
307
|
+
duration: {
|
|
308
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
309
|
+
value: intl.formatMessage(cookieDetailValues.duration1Week)
|
|
310
|
+
},
|
|
311
|
+
type: {
|
|
312
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
313
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
314
|
+
},
|
|
315
|
+
category: {
|
|
316
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
317
|
+
value: intl.formatMessage(cookieDetailValues.categoryStrictlyNecessary)
|
|
318
|
+
},
|
|
319
|
+
description: {
|
|
320
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
321
|
+
value: intl.formatMessage(cookieDetailDescriptions.essentialCookieDescription3)
|
|
322
|
+
}
|
|
323
|
+
}];
|
|
324
|
+
};
|
|
325
|
+
var createPerformanceCookieDetails = function createPerformanceCookieDetails(intl) {
|
|
326
|
+
return [{
|
|
327
|
+
name: {
|
|
328
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
329
|
+
value: '_fs_tab_id',
|
|
330
|
+
to: createCookieLink('_fs_tab_id')
|
|
331
|
+
},
|
|
332
|
+
host: {
|
|
333
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
334
|
+
value: HOSTNAME
|
|
335
|
+
},
|
|
336
|
+
duration: {
|
|
337
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
338
|
+
value: intl.formatMessage(cookieDetailValues.durationSession)
|
|
339
|
+
},
|
|
340
|
+
type: {
|
|
341
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
342
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
343
|
+
},
|
|
344
|
+
category: {
|
|
345
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
346
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
347
|
+
},
|
|
348
|
+
description: {
|
|
349
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
350
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription1)
|
|
351
|
+
}
|
|
352
|
+
}, {
|
|
353
|
+
name: {
|
|
354
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
355
|
+
value: 'fs_cid',
|
|
356
|
+
to: createCookieLink('fs_cid')
|
|
357
|
+
},
|
|
358
|
+
host: {
|
|
359
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
360
|
+
value: HOSTNAME
|
|
361
|
+
},
|
|
362
|
+
duration: {
|
|
363
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
364
|
+
value: intl.formatMessage(cookieDetailValues.duration1Year)
|
|
365
|
+
},
|
|
366
|
+
type: {
|
|
367
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
368
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
369
|
+
},
|
|
370
|
+
category: {
|
|
371
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
372
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
373
|
+
},
|
|
374
|
+
description: {
|
|
375
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
376
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription2)
|
|
377
|
+
}
|
|
378
|
+
}, {
|
|
379
|
+
name: {
|
|
380
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
381
|
+
value: 'fs_lua',
|
|
382
|
+
to: createCookieLink('fs_lua')
|
|
383
|
+
},
|
|
384
|
+
host: {
|
|
385
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
386
|
+
value: HOSTNAME
|
|
387
|
+
},
|
|
388
|
+
duration: {
|
|
389
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
390
|
+
value: intl.formatMessage(cookieDetailValues.duration1Day)
|
|
391
|
+
},
|
|
392
|
+
type: {
|
|
393
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
394
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
395
|
+
},
|
|
396
|
+
category: {
|
|
397
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
398
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
399
|
+
},
|
|
400
|
+
description: {
|
|
401
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
402
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription3)
|
|
403
|
+
}
|
|
404
|
+
}, {
|
|
405
|
+
name: {
|
|
406
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
407
|
+
value: 'fs_uid',
|
|
408
|
+
to: createCookieLink('fs_uid')
|
|
409
|
+
},
|
|
410
|
+
host: {
|
|
411
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
412
|
+
value: HOSTNAME
|
|
413
|
+
},
|
|
414
|
+
duration: {
|
|
415
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
416
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
417
|
+
},
|
|
418
|
+
type: {
|
|
419
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
420
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
421
|
+
},
|
|
422
|
+
category: {
|
|
423
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
424
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
425
|
+
},
|
|
426
|
+
description: {
|
|
427
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
428
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription4)
|
|
429
|
+
}
|
|
430
|
+
}];
|
|
431
|
+
};
|
|
432
|
+
|
|
433
|
+
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
434
|
+
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context2 = ownKeys$1(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context3 = ownKeys$1(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
435
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
436
|
+
var View = {
|
|
437
|
+
Primary: 'Primary',
|
|
438
|
+
Secondary: 'Secondary',
|
|
439
|
+
Tertiary: 'Tertiary'
|
|
440
|
+
};
|
|
441
|
+
/**
|
|
442
|
+
* The design spec warranted text that _looks_ like a link, but isn't
|
|
443
|
+
*/
|
|
444
|
+
var NavigationLink = function NavigationLink(_ref4) {
|
|
445
|
+
var _onClick = _ref4.onClick,
|
|
446
|
+
label = _ref4.label;
|
|
447
|
+
return jsx(Link, {
|
|
448
|
+
onClick: function onClick(e) {
|
|
449
|
+
e.preventDefault();
|
|
450
|
+
_onClick();
|
|
451
|
+
},
|
|
452
|
+
to: "",
|
|
453
|
+
children: label
|
|
454
|
+
});
|
|
455
|
+
};
|
|
456
|
+
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
457
|
+
name: "1u8ems1",
|
|
458
|
+
styles: "& svg{display:none;}"
|
|
459
|
+
} : {
|
|
460
|
+
name: "4sjpj8-removeDefaultSvg",
|
|
461
|
+
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
462
|
+
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"]} */",
|
|
463
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
464
|
+
};
|
|
465
|
+
var InformationLink = function InformationLink(_ref5) {
|
|
466
|
+
var to = _ref5.to,
|
|
467
|
+
label = _ref5.label;
|
|
468
|
+
var removeDefaultSvg = _ref3;
|
|
469
|
+
return jsx("div", {
|
|
470
|
+
css: removeDefaultSvg,
|
|
471
|
+
children: jsx(Link, {
|
|
472
|
+
isExternal: true,
|
|
473
|
+
to: to,
|
|
474
|
+
children: label
|
|
475
|
+
})
|
|
476
|
+
});
|
|
477
|
+
};
|
|
478
|
+
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
479
|
+
name: "1u8ems1",
|
|
480
|
+
styles: "& svg{display:none;}"
|
|
481
|
+
} : {
|
|
482
|
+
name: "4sjpj8-removeDefaultSvg",
|
|
483
|
+
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
484
|
+
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"]} */",
|
|
485
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
486
|
+
};
|
|
487
|
+
var DetailLink = function DetailLink(_ref6) {
|
|
488
|
+
var to = _ref6.to,
|
|
489
|
+
label = _ref6.label;
|
|
490
|
+
var removeDefaultSvg = _ref2;
|
|
491
|
+
return jsx("div", {
|
|
492
|
+
css: removeDefaultSvg,
|
|
493
|
+
children: jsx(Link, {
|
|
494
|
+
isExternal: true,
|
|
495
|
+
to: to,
|
|
496
|
+
children: jsx(Text.Detail, {
|
|
497
|
+
tone: "primary",
|
|
498
|
+
children: label
|
|
499
|
+
})
|
|
500
|
+
})
|
|
501
|
+
});
|
|
502
|
+
};
|
|
503
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
504
|
+
name: "qzmnd2",
|
|
505
|
+
styles: "padding-right:10px"
|
|
506
|
+
} : {
|
|
507
|
+
name: "ey0yn8-bumpToggle",
|
|
508
|
+
styles: "padding-right:10px;label:bumpToggle;",
|
|
509
|
+
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"]} */",
|
|
510
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
511
|
+
};
|
|
512
|
+
var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
513
|
+
var toggleValue = _ref7.toggleValue,
|
|
514
|
+
onToggle = _ref7.onToggle,
|
|
515
|
+
onChangeView = _ref7.onChangeView,
|
|
516
|
+
panelState = _ref7.panelState,
|
|
517
|
+
setPanelState = _ref7.setPanelState;
|
|
518
|
+
var _useIntl = useIntl(),
|
|
519
|
+
formatMessage = _useIntl.formatMessage;
|
|
520
|
+
|
|
521
|
+
// The outline of the input is cut off; we shift it to the left to compensate
|
|
522
|
+
var bumpToggle = _ref;
|
|
523
|
+
return jsxs(Spacings.Stack, {
|
|
524
|
+
scale: "xl",
|
|
525
|
+
children: [jsxs(Spacings.Stack, {
|
|
526
|
+
scale: "m",
|
|
527
|
+
children: [jsx(Text.Body, {
|
|
528
|
+
intlMessage: modalMessages.mainDescription
|
|
529
|
+
}), jsx(InformationLink, {
|
|
530
|
+
label: formatMessage(modalMessages.privacyPolicyLink),
|
|
531
|
+
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY
|
|
532
|
+
})]
|
|
533
|
+
}), jsxs(Spacings.Stack, {
|
|
534
|
+
scale: "l",
|
|
535
|
+
children: [jsx(CollapsiblePanel, {
|
|
536
|
+
condensed: true,
|
|
537
|
+
header: formatMessage(modalMessages.necessaryCookiesHeader),
|
|
538
|
+
headerControls: jsx(Text.Detail, {
|
|
539
|
+
intlMessage: modalMessages.necessaryCookiesHeaderState,
|
|
540
|
+
tone: "information"
|
|
541
|
+
}),
|
|
542
|
+
isClosed: panelState.essentialCookiesClosed,
|
|
543
|
+
onToggle: function onToggle() {
|
|
544
|
+
return setPanelState(_objectSpread$1(_objectSpread$1({}, panelState), {}, {
|
|
545
|
+
essentialCookiesClosed: !panelState.essentialCookiesClosed
|
|
546
|
+
}));
|
|
547
|
+
},
|
|
548
|
+
theme: "light",
|
|
549
|
+
children: jsxs(Spacings.Stack, {
|
|
550
|
+
scale: "m",
|
|
551
|
+
children: [jsx(Text.Body, {
|
|
552
|
+
intlMessage: modalMessages.necessaryCookiesDescription
|
|
553
|
+
}), jsx(NavigationLink, {
|
|
554
|
+
label: formatMessage(modalMessages.cookieInformationLink),
|
|
555
|
+
onClick: function onClick() {
|
|
556
|
+
return onChangeView(View.Secondary);
|
|
557
|
+
}
|
|
558
|
+
})]
|
|
559
|
+
})
|
|
560
|
+
}), jsx(CollapsiblePanel, {
|
|
561
|
+
condensed: true,
|
|
562
|
+
header: formatMessage(modalMessages.performanceCookiesHeader),
|
|
563
|
+
headerControls: jsx("div", {
|
|
564
|
+
css: bumpToggle,
|
|
565
|
+
children: jsx(ToggleInput, {
|
|
566
|
+
isChecked: toggleValue,
|
|
567
|
+
onChange: function onChange(e) {
|
|
568
|
+
return onToggle(e.target.checked);
|
|
569
|
+
},
|
|
570
|
+
size: "small"
|
|
571
|
+
})
|
|
572
|
+
}),
|
|
573
|
+
isClosed: panelState.performanceCookiesClosed,
|
|
574
|
+
onToggle: function onToggle() {
|
|
575
|
+
return setPanelState(_objectSpread$1(_objectSpread$1({}, panelState), {}, {
|
|
576
|
+
performanceCookiesClosed: !panelState.performanceCookiesClosed
|
|
577
|
+
}));
|
|
578
|
+
},
|
|
579
|
+
theme: "light",
|
|
580
|
+
children: jsxs(Spacings.Stack, {
|
|
581
|
+
scale: "m",
|
|
582
|
+
children: [jsx(Text.Body, {
|
|
583
|
+
intlMessage: modalMessages.performanceCookiesDescription
|
|
584
|
+
}), jsx(NavigationLink, {
|
|
585
|
+
label: formatMessage(modalMessages.cookieInformationLink),
|
|
586
|
+
onClick: function onClick() {
|
|
587
|
+
return onChangeView(View.Tertiary);
|
|
588
|
+
}
|
|
589
|
+
})]
|
|
590
|
+
})
|
|
591
|
+
})]
|
|
592
|
+
})]
|
|
593
|
+
});
|
|
594
|
+
};
|
|
595
|
+
var CookieConsentBodyDetails = function CookieConsentBodyDetails(_ref8) {
|
|
596
|
+
var onChangeView = _ref8.onChangeView,
|
|
597
|
+
cookieDetails = _ref8.cookieDetails;
|
|
598
|
+
var _useIntl2 = useIntl(),
|
|
599
|
+
formatMessage = _useIntl2.formatMessage;
|
|
600
|
+
var scrollRef = /*#__PURE__*/createRef();
|
|
601
|
+
useEffect(function () {
|
|
602
|
+
var _scrollRef$current;
|
|
603
|
+
(_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 ? void 0 : _scrollRef$current.scrollIntoView();
|
|
604
|
+
}, [scrollRef]);
|
|
605
|
+
return jsxs(Fragment, {
|
|
606
|
+
children: [jsx("div", {
|
|
607
|
+
ref: scrollRef,
|
|
608
|
+
css: /*#__PURE__*/css("scroll-margin-top:", designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"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"]} */")
|
|
609
|
+
}), jsxs(Spacings.Stack, {
|
|
610
|
+
scale: "l",
|
|
611
|
+
children: [jsx(NavigationLink, {
|
|
612
|
+
label: formatMessage(modalMessages.navigateBackLink),
|
|
613
|
+
onClick: function onClick() {
|
|
614
|
+
return onChangeView(View.Primary);
|
|
615
|
+
}
|
|
616
|
+
}), jsx(Spacings.Stack, {
|
|
617
|
+
scale: "l",
|
|
618
|
+
children: _mapInstanceProperty(cookieDetails).call(cookieDetails, function (detail) {
|
|
619
|
+
var _context;
|
|
620
|
+
return jsx(Grid, {
|
|
621
|
+
gridGap: designTokens.spacing40,
|
|
622
|
+
gridRowGap: "0px",
|
|
623
|
+
gridTemplateColumns: "".concat(designTokens.constraint2, " 1fr"),
|
|
624
|
+
children: _mapInstanceProperty(_context = _Object$values(detail)).call(_context, function (value) {
|
|
625
|
+
return jsxs(Fragment$1, {
|
|
626
|
+
children: [jsx(Grid.Item, {
|
|
627
|
+
children: jsx(Text.Detail, {
|
|
628
|
+
children: value.label
|
|
629
|
+
})
|
|
630
|
+
}), jsx(Grid.Item, {
|
|
631
|
+
children: 'to' in value ? jsx(DetailLink, {
|
|
632
|
+
label: value.value,
|
|
633
|
+
to: value.to
|
|
634
|
+
}) : jsx(Text.Detail, {
|
|
635
|
+
children: value.value
|
|
636
|
+
})
|
|
637
|
+
})]
|
|
638
|
+
}, value.value);
|
|
639
|
+
})
|
|
640
|
+
}, detail.name.value);
|
|
641
|
+
})
|
|
642
|
+
})]
|
|
643
|
+
})]
|
|
644
|
+
});
|
|
645
|
+
};
|
|
646
|
+
var CookieConsentModal = function CookieConsentModal(modalProps) {
|
|
647
|
+
var intl = useIntl();
|
|
648
|
+
var _useCookieConsent = useCookieConsent('performanceCookies'),
|
|
649
|
+
setConsent = _useCookieConsent.setConsent;
|
|
650
|
+
var _useState = useState(false),
|
|
651
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
652
|
+
enablePerformanceCookies = _useState2[0],
|
|
653
|
+
setEnablePerformanceCookies = _useState2[1];
|
|
654
|
+
var _useState3 = useState(View.Primary),
|
|
655
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
656
|
+
currentView = _useState4[0],
|
|
657
|
+
setCurrentView = _useState4[1];
|
|
658
|
+
var _useState5 = useState({
|
|
659
|
+
essentialCookiesClosed: true,
|
|
660
|
+
performanceCookiesClosed: true
|
|
661
|
+
}),
|
|
662
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
663
|
+
panelState = _useState6[0],
|
|
664
|
+
_setPanelState = _useState6[1];
|
|
665
|
+
var createConsentGroups = function createConsentGroups(performanceConsent) {
|
|
666
|
+
return {
|
|
667
|
+
essentialCookies: true,
|
|
668
|
+
performanceCookies: performanceConsent
|
|
669
|
+
};
|
|
670
|
+
};
|
|
671
|
+
return jsxs(ConfirmationDialog, {
|
|
672
|
+
isOpen: modalProps.isModalOpen,
|
|
673
|
+
labelPrimary: intl.formatMessage(modalMessages.primaryButtonLabel),
|
|
674
|
+
labelSecondary: intl.formatMessage(modalMessages.secondaryButtonLabel),
|
|
675
|
+
onCancel: function onCancel() {
|
|
676
|
+
setConsent(createConsentGroups(enablePerformanceCookies));
|
|
677
|
+
modalProps.setBannerClosed(true);
|
|
678
|
+
modalProps.closeModal();
|
|
679
|
+
},
|
|
680
|
+
onClose: modalProps.closeModal,
|
|
681
|
+
onConfirm: function onConfirm() {
|
|
682
|
+
setConsent(createConsentGroups(true));
|
|
683
|
+
modalProps.setBannerClosed(true);
|
|
684
|
+
modalProps.closeModal();
|
|
685
|
+
},
|
|
686
|
+
title: intl.formatMessage(modalMessages.title),
|
|
687
|
+
children: [currentView === View.Primary && jsx(CookieConsentBodyPrimary, {
|
|
688
|
+
onChangeView: function onChangeView(view) {
|
|
689
|
+
return setCurrentView(view);
|
|
690
|
+
},
|
|
691
|
+
onToggle: function onToggle(value) {
|
|
692
|
+
return setEnablePerformanceCookies(value);
|
|
693
|
+
},
|
|
694
|
+
panelState: panelState,
|
|
695
|
+
setPanelState: function setPanelState(state) {
|
|
696
|
+
return _setPanelState(state);
|
|
697
|
+
},
|
|
698
|
+
toggleValue: enablePerformanceCookies
|
|
699
|
+
}), currentView === View.Secondary && jsx(CookieConsentBodyDetails, {
|
|
700
|
+
cookieDetails: createEssentialCookieDetails(intl),
|
|
701
|
+
onChangeView: function onChangeView(view) {
|
|
702
|
+
return setCurrentView(view);
|
|
703
|
+
}
|
|
704
|
+
}), currentView === View.Tertiary && jsx(CookieConsentBodyDetails, {
|
|
705
|
+
cookieDetails: createPerformanceCookieDetails(intl),
|
|
706
|
+
onChangeView: function onChangeView(view) {
|
|
707
|
+
return setCurrentView(view);
|
|
708
|
+
}
|
|
709
|
+
})]
|
|
710
|
+
});
|
|
711
|
+
};
|
|
712
|
+
|
|
713
|
+
var messages = defineMessages({
|
|
714
|
+
bannerMessage: {
|
|
715
|
+
id: 'CookieConsentBanner.bannerMessage',
|
|
716
|
+
description: 'Text of the cookie consent banner.',
|
|
717
|
+
defaultMessage: 'This site uses cookies. See our {privacyLink} or manage your {modalLink} here.'
|
|
718
|
+
},
|
|
719
|
+
privacyPolicyLink: {
|
|
720
|
+
id: 'CookieConsentBanner.privacyPolicyLink',
|
|
721
|
+
description: 'Privacy policy link text in the cookie consent banner.',
|
|
722
|
+
defaultMessage: 'privacy policy'
|
|
723
|
+
},
|
|
724
|
+
bannerCookiesModalLink: {
|
|
725
|
+
id: 'CookieConsentBanner.bannerCookiesModalLink',
|
|
726
|
+
description: 'Cookie settings modal link text in the cookie consent banner.',
|
|
727
|
+
defaultMessage: 'cookies settings'
|
|
728
|
+
},
|
|
729
|
+
buttonLabel: {
|
|
730
|
+
id: 'CookieConsentBanner.buttonLabel',
|
|
731
|
+
description: 'Button text allowing the user to accept all ct cookies',
|
|
732
|
+
defaultMessage: 'Accept all cookies'
|
|
733
|
+
}
|
|
734
|
+
});
|
|
735
|
+
|
|
736
|
+
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
737
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
738
|
+
var CookieConsentBanner = function CookieConsentBanner(bannerProps) {
|
|
739
|
+
// Hide the banner once the accept button is clicked, until we can subscribe to the cookie
|
|
740
|
+
var _useState = useState(false),
|
|
741
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
742
|
+
bannerClosed = _useState2[0],
|
|
743
|
+
setBannerClosed = _useState2[1];
|
|
744
|
+
var _useModalState = useModalState(),
|
|
745
|
+
closeModal = _useModalState.closeModal,
|
|
746
|
+
openModal = _useModalState.openModal,
|
|
747
|
+
isModalOpen = _useModalState.isModalOpen;
|
|
748
|
+
var _useIntl = useIntl(),
|
|
749
|
+
formatMessage = _useIntl.formatMessage;
|
|
750
|
+
var _useCookieConsent = useCookieConsent('performanceCookies', {
|
|
751
|
+
skipConsent: bannerProps.skipConsent
|
|
752
|
+
}),
|
|
753
|
+
setConsent = _useCookieConsent.setConsent,
|
|
754
|
+
hasGivenPerformanceCookieConsent = _useCookieConsent.givenConsent;
|
|
755
|
+
var _useCookieConsent2 = useCookieConsent('essentialCookies', {
|
|
756
|
+
skipConsent: bannerProps.skipConsent
|
|
757
|
+
}),
|
|
758
|
+
hasGivenEssentialCookieConsent = _useCookieConsent2.givenConsent;
|
|
759
|
+
var createConsentGroups = function createConsentGroups() {
|
|
760
|
+
return {
|
|
761
|
+
essentialCookies: true,
|
|
762
|
+
performanceCookies: true
|
|
763
|
+
};
|
|
764
|
+
};
|
|
765
|
+
if (bannerClosed || hasGivenEssentialCookieConsent || hasGivenPerformanceCookieConsent) return null;
|
|
766
|
+
return (
|
|
767
|
+
// TODO: use lower z-index, prefer ranges per use-case
|
|
768
|
+
jsxs("div", {
|
|
769
|
+
css: /*#__PURE__*/css("display:flex;flex-direction:column;align-items:center;position:absolute;bottom:", 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== */"),
|
|
770
|
+
children: [jsx("div", {
|
|
771
|
+
css: /*#__PURE__*/css("background-color:", designTokens.colorAccent10, ";border-radius:", designTokens.borderRadius4, ";box-shadow:", designTokens.shadow8, ";margin:0 ", designTokens.spacingXl, ";padding:", designTokens.spacingM, " ", designTokens.spacingL, ";width:fit-content;svg{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeURnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCBMaW5rIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2xpbmsnO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRXNzZW50aWFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZXNzZW50aWFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGVzc2VudGlhbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM0fTtcbiAgICAgICAgICBib3gtc2hhZG93OiAke2Rlc2lnblRva2Vucy5zaGFkb3c4fTtcbiAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nTX0gJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICAgICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgICB9XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgPEZvcm1hdHRlZE1lc3NhZ2VcbiAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgIHByaXZhY3lMaW5rOiAoXG4gICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgICAgICAgICAgdG89e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmt9XG4gICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgICAgICAgICAgIG9wZW5Nb2RhbCgpO1xuICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICB0bz1cIlwiXG4gICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVGV4dC5Cb2R5PlxuICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgaXNNb2RhbE9wZW49e2lzTW9kYWxPcGVufVxuICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5Db29raWVDb25zZW50QmFubmVyLmRpc3BsYXlOYW1lID0gJ0Nvb2tpZUNvbnNlbnRCYW5uZXInO1xuXG5leHBvcnQgeyBDb29raWVDb25zZW50QmFubmVyIH07XG4iXX0= */"),
|
|
772
|
+
children: jsxs(Spacings.Inline, {
|
|
773
|
+
alignItems: "center",
|
|
774
|
+
scale: "xl",
|
|
775
|
+
children: [jsx(Text.Body, {
|
|
776
|
+
tone: "inverted",
|
|
777
|
+
children: jsx(FormattedMessage, _objectSpread(_objectSpread({}, messages.bannerMessage), {}, {
|
|
778
|
+
values: {
|
|
779
|
+
privacyLink: jsx(Link, {
|
|
780
|
+
intlMessage: messages.privacyPolicyLink,
|
|
781
|
+
isExternal: true,
|
|
782
|
+
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY,
|
|
783
|
+
tone: "inverted"
|
|
784
|
+
}),
|
|
785
|
+
modalLink: jsx(Link, {
|
|
786
|
+
intlMessage: messages.bannerCookiesModalLink,
|
|
787
|
+
onClick: function onClick(e) {
|
|
788
|
+
e.preventDefault();
|
|
789
|
+
openModal();
|
|
790
|
+
},
|
|
791
|
+
to: "",
|
|
792
|
+
tone: "inverted"
|
|
793
|
+
})
|
|
794
|
+
}
|
|
795
|
+
}))
|
|
796
|
+
}), jsx(PrimaryButton, {
|
|
797
|
+
label: formatMessage(messages.buttonLabel),
|
|
798
|
+
onClick: function onClick() {
|
|
799
|
+
setConsent(createConsentGroups());
|
|
800
|
+
setBannerClosed(true);
|
|
801
|
+
},
|
|
802
|
+
size: "small"
|
|
803
|
+
})]
|
|
804
|
+
})
|
|
805
|
+
}), jsx(CookieConsentModal, {
|
|
806
|
+
closeModal: closeModal,
|
|
807
|
+
isModalOpen: isModalOpen,
|
|
808
|
+
setBannerClosed: setBannerClosed
|
|
809
|
+
})]
|
|
810
|
+
})
|
|
811
|
+
);
|
|
812
|
+
};
|
|
813
|
+
CookieConsentBanner.displayName = 'CookieConsentBanner';
|
|
814
|
+
|
|
815
|
+
export { CookieConsentBanner, CookieConsentModal, useCookieConsent, useSkipCookieConsent };
|
package/react/package.json
CHANGED