@commercetools-frontend/cookie-consent 0.0.0-FEC-212-react19-20250122084835
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/LICENSE +21 -0
- package/README.md +143 -0
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.d.ts +2 -0
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.dev.js +190 -0
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.js +7 -0
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.prod.js +190 -0
- package/core/dist/commercetools-frontend-cookie-consent-core.esm.js +164 -0
- package/core/package.json +4 -0
- package/dist/declarations/src/core/index.d.ts +35 -0
- package/dist/declarations/src/react/cookie-consent-banner/cookie-consent-banner.d.ts +8 -0
- package/dist/declarations/src/react/cookie-consent-banner/index.d.ts +1 -0
- package/dist/declarations/src/react/cookie-consent-modal/cookie-consent-modal.d.ts +7 -0
- package/dist/declarations/src/react/cookie-consent-modal/index.d.ts +1 -0
- package/dist/declarations/src/react/index.d.ts +4 -0
- package/dist/declarations/src/react/use-cookie-consent/index.d.ts +1 -0
- package/dist/declarations/src/react/use-cookie-consent/use-cookie-consent.d.ts +10 -0
- package/dist/declarations/src/react/use-skip-cookie-consent/index.d.ts +1 -0
- package/dist/declarations/src/react/use-skip-cookie-consent/use-skip-cookie-consent.d.ts +2 -0
- package/package.json +67 -0
- package/react/dist/commercetools-frontend-cookie-consent-react.cjs.d.ts +2 -0
- package/react/dist/commercetools-frontend-cookie-consent-react.cjs.dev.js +818 -0
- package/react/dist/commercetools-frontend-cookie-consent-react.cjs.js +7 -0
- package/react/dist/commercetools-frontend-cookie-consent-react.cjs.prod.js +796 -0
- package/react/dist/commercetools-frontend-cookie-consent-react.esm.js +791 -0
- package/react/package.json +4 -0
|
@@ -0,0 +1,818 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var react = require('react');
|
|
6
|
+
var core_dist_commercetoolsFrontendCookieConsentCore = require('../../core/dist/commercetools-frontend-cookie-consent-core.cjs.dev.js');
|
|
7
|
+
var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
|
|
8
|
+
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
9
|
+
var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
10
|
+
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
11
|
+
var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
12
|
+
var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
|
|
13
|
+
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
14
|
+
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
15
|
+
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
16
|
+
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
17
|
+
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
18
|
+
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
19
|
+
var _Object$values = require('@babel/runtime-corejs3/core-js-stable/object/values');
|
|
20
|
+
var CollapsiblePanel = require('@commercetools-uikit/collapsible-panel');
|
|
21
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
22
|
+
var Grid = require('@commercetools-uikit/grid');
|
|
23
|
+
var Link = require('@commercetools-uikit/link');
|
|
24
|
+
var Spacings = require('@commercetools-uikit/spacings');
|
|
25
|
+
var Text = require('@commercetools-uikit/text');
|
|
26
|
+
var ToggleInput = require('@commercetools-uikit/toggle-input');
|
|
27
|
+
var react$1 = require('@emotion/react');
|
|
28
|
+
var reactIntl = require('react-intl');
|
|
29
|
+
var applicationComponents = require('@commercetools-frontend/application-components');
|
|
30
|
+
var PrimaryButton = require('@commercetools-uikit/primary-button');
|
|
31
|
+
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
32
|
+
require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
33
|
+
require('@babel/runtime-corejs3/core-js-stable/object/from-entries');
|
|
34
|
+
require('@babel/runtime-corejs3/core-js-stable/object/entries');
|
|
35
|
+
require('@babel/runtime-corejs3/core-js-stable/url-search-params');
|
|
36
|
+
|
|
37
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
38
|
+
|
|
39
|
+
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
40
|
+
var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
|
|
41
|
+
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
42
|
+
var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
|
|
43
|
+
var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
|
|
44
|
+
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
45
|
+
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
46
|
+
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
47
|
+
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
48
|
+
var _Object$values__default = /*#__PURE__*/_interopDefault(_Object$values);
|
|
49
|
+
var CollapsiblePanel__default = /*#__PURE__*/_interopDefault(CollapsiblePanel);
|
|
50
|
+
var Grid__default = /*#__PURE__*/_interopDefault(Grid);
|
|
51
|
+
var Link__default = /*#__PURE__*/_interopDefault(Link);
|
|
52
|
+
var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
|
|
53
|
+
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
54
|
+
var ToggleInput__default = /*#__PURE__*/_interopDefault(ToggleInput);
|
|
55
|
+
var PrimaryButton__default = /*#__PURE__*/_interopDefault(PrimaryButton);
|
|
56
|
+
|
|
57
|
+
const defaultConsentOptions = {
|
|
58
|
+
skipConsent: false,
|
|
59
|
+
cookieName: 'OptanonConsent'
|
|
60
|
+
};
|
|
61
|
+
function useCookieConsent(consentGroup) {
|
|
62
|
+
let _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultConsentOptions,
|
|
63
|
+
skipConsent = _ref.skipConsent,
|
|
64
|
+
cookieName = _ref.cookieName;
|
|
65
|
+
const consentCookieGroups = react.useMemo(() => {
|
|
66
|
+
const rawConsentCookie = core_dist_commercetoolsFrontendCookieConsentCore.getRawConsentCookie(cookieName);
|
|
67
|
+
const consentCookieGroups = core_dist_commercetoolsFrontendCookieConsentCore.getParsedConsentCookieGroups(rawConsentCookie, {
|
|
68
|
+
skipConsent
|
|
69
|
+
});
|
|
70
|
+
return consentCookieGroups;
|
|
71
|
+
}, [cookieName, skipConsent]);
|
|
72
|
+
return {
|
|
73
|
+
givenConsent: skipConsent || Boolean(consentCookieGroups[consentGroup]),
|
|
74
|
+
setConsent: core_dist_commercetoolsFrontendCookieConsentCore.setConsentCookie
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function useSkipCookieConsent() {
|
|
79
|
+
const skipCookieConsent = applicationShellConnectors.useApplicationContext(context => context.environment.skipCookieConsent);
|
|
80
|
+
return Boolean(skipCookieConsent);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
const COOKIE_CONSENT_LINKS = {
|
|
84
|
+
PRIVACY_POLICY: 'https://commercetools.com/privacy#website',
|
|
85
|
+
USER_GUIDING_COOKIE_POLICY: 'https://userguiding.com/cookie-policy/'
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
const modalMessages = reactIntl.defineMessages({
|
|
89
|
+
title: {
|
|
90
|
+
id: 'CookieConsentModal.title',
|
|
91
|
+
description: 'Confirmation dialog title',
|
|
92
|
+
defaultMessage: 'Privacy Preference Center'
|
|
93
|
+
},
|
|
94
|
+
primaryButtonLabel: {
|
|
95
|
+
id: 'CookieConsentModal.primaryButtonLabel',
|
|
96
|
+
description: 'Primary button text',
|
|
97
|
+
defaultMessage: 'Accept all cookies'
|
|
98
|
+
},
|
|
99
|
+
secondaryButtonLabel: {
|
|
100
|
+
id: 'CookieConsentModal.secondaryButtonLabel',
|
|
101
|
+
description: 'Secondary button text',
|
|
102
|
+
defaultMessage: 'Confirm my choices'
|
|
103
|
+
},
|
|
104
|
+
mainDescription: {
|
|
105
|
+
id: 'CookieConsentModal.primary.mainDescription',
|
|
106
|
+
description: 'Main body copy',
|
|
107
|
+
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.'
|
|
108
|
+
},
|
|
109
|
+
privacyPolicyLink: {
|
|
110
|
+
id: 'CookieConsentModal.primary.privacyPolicyLink',
|
|
111
|
+
description: 'Link to privacy policy',
|
|
112
|
+
defaultMessage: 'More information'
|
|
113
|
+
},
|
|
114
|
+
necessaryCookiesHeader: {
|
|
115
|
+
id: 'CookieConsentModal.primary.necessaryCookiesHeader',
|
|
116
|
+
description: 'Header for first collapsible content block',
|
|
117
|
+
defaultMessage: 'Strictly necessary cookies'
|
|
118
|
+
},
|
|
119
|
+
functionalCookiesHeader: {
|
|
120
|
+
id: 'CookieConsentModal.primary.functionalCookiesHeader',
|
|
121
|
+
description: 'Header for first collapsible content block',
|
|
122
|
+
defaultMessage: 'Functional cookies'
|
|
123
|
+
},
|
|
124
|
+
functionalCookiesDescription: {
|
|
125
|
+
id: 'CookieConsentModal.primary.functionalCookiesDescription',
|
|
126
|
+
description: 'Description of content from first collapsible header',
|
|
127
|
+
defaultMessage: 'These cookies enable the website to provide enhanced functionality and personalisation. They may be set by us or by third party providers whose services we have added to our pages. If you do not allow these cookies then some or all of these services may not function properly.'
|
|
128
|
+
},
|
|
129
|
+
performanceCookiesHeader: {
|
|
130
|
+
id: 'CookieConsentModal.primary.performanceCookiesHeader',
|
|
131
|
+
description: 'Header for second collapsible content block',
|
|
132
|
+
defaultMessage: 'Performance cookies'
|
|
133
|
+
},
|
|
134
|
+
performanceCookiesDescription: {
|
|
135
|
+
id: 'CookieConsentModal.primary.performanceCookiesDescription',
|
|
136
|
+
description: 'Description of content from second collapsible header',
|
|
137
|
+
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.'
|
|
138
|
+
},
|
|
139
|
+
cookieInformationLink: {
|
|
140
|
+
id: 'CookieConsentModal.primary.cookieInformationLink',
|
|
141
|
+
description: 'Link to additional cookie information',
|
|
142
|
+
defaultMessage: 'Cookies details'
|
|
143
|
+
},
|
|
144
|
+
navigateBackLink: {
|
|
145
|
+
id: 'CookieConsentModal.primary.navigateBackLink',
|
|
146
|
+
description: 'Link to go back to primary view',
|
|
147
|
+
defaultMessage: 'Back to Privacy Preference Center'
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
const cookieDetailLabels = reactIntl.defineMessages({
|
|
151
|
+
nameLabel: {
|
|
152
|
+
id: 'CookieConsentModal.cookieDetails.nameLabel',
|
|
153
|
+
description: 'Name - category identifier',
|
|
154
|
+
defaultMessage: 'Name'
|
|
155
|
+
},
|
|
156
|
+
hostLabel: {
|
|
157
|
+
id: 'CookieConsentModal.cookieDetails.hostLabel',
|
|
158
|
+
description: 'Host - category identifier',
|
|
159
|
+
defaultMessage: 'Host'
|
|
160
|
+
},
|
|
161
|
+
durationLabel: {
|
|
162
|
+
id: 'CookieConsentModal.cookieDetails.durationLabel',
|
|
163
|
+
description: 'Duration - category identifier',
|
|
164
|
+
defaultMessage: 'Duration'
|
|
165
|
+
},
|
|
166
|
+
typeLabel: {
|
|
167
|
+
id: 'CookieConsentModal.cookieDetails.typeLabel',
|
|
168
|
+
description: 'Type - category identifier',
|
|
169
|
+
defaultMessage: 'Type'
|
|
170
|
+
},
|
|
171
|
+
categoryLabel: {
|
|
172
|
+
id: 'CookieConsentModal.cookieDetails.categoryLabel',
|
|
173
|
+
description: 'Category - category identifier',
|
|
174
|
+
defaultMessage: 'Category'
|
|
175
|
+
},
|
|
176
|
+
descriptionLabel: {
|
|
177
|
+
id: 'CookieConsentModal.cookieDetails.descriptionLabel',
|
|
178
|
+
description: 'Description - category identifier',
|
|
179
|
+
defaultMessage: 'Description'
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
const cookieDetailValues = reactIntl.defineMessages({
|
|
183
|
+
duration9Months: {
|
|
184
|
+
id: 'CookieConsentModal.cookieDetails.duration9Months',
|
|
185
|
+
description: 'Length of time',
|
|
186
|
+
defaultMessage: '9 Months'
|
|
187
|
+
},
|
|
188
|
+
duration1Week: {
|
|
189
|
+
id: 'CookieConsentModal.cookieDetails.duration1Week',
|
|
190
|
+
description: 'Length of time',
|
|
191
|
+
defaultMessage: '1 Week'
|
|
192
|
+
},
|
|
193
|
+
durationSession: {
|
|
194
|
+
id: 'CookieConsentModal.cookieDetails.durationSession',
|
|
195
|
+
description: 'Length of time for cookie to expire in the browser',
|
|
196
|
+
defaultMessage: 'Session'
|
|
197
|
+
},
|
|
198
|
+
duration1Year: {
|
|
199
|
+
id: 'CookieConsentModal.cookieDetails.duration1Year',
|
|
200
|
+
description: 'Length of time',
|
|
201
|
+
defaultMessage: '1 Year'
|
|
202
|
+
},
|
|
203
|
+
duration1Day: {
|
|
204
|
+
id: 'CookieConsentModal.cookieDetails.duration1Day',
|
|
205
|
+
description: 'Length of time',
|
|
206
|
+
defaultMessage: '1 Day'
|
|
207
|
+
},
|
|
208
|
+
typeFirstParty: {
|
|
209
|
+
id: 'CookieConsentModal.cookieDetails.typeFirstParty',
|
|
210
|
+
description: 'Type of cookie',
|
|
211
|
+
defaultMessage: 'First party'
|
|
212
|
+
},
|
|
213
|
+
categoryStrictlyNecessary: {
|
|
214
|
+
id: 'CookieConsentModal.cookieDetails.categoryStrictlyNecessary',
|
|
215
|
+
description: 'Type of cookie',
|
|
216
|
+
defaultMessage: 'Strictly Necessary Cookies'
|
|
217
|
+
},
|
|
218
|
+
categoryFunctional: {
|
|
219
|
+
id: 'CookieConsentModal.cookieDetails.categoryFunctional',
|
|
220
|
+
description: 'Type of cookie',
|
|
221
|
+
defaultMessage: 'Functional Cookies'
|
|
222
|
+
},
|
|
223
|
+
categoryPerformance: {
|
|
224
|
+
id: 'CookieConsentModal.cookieDetails.categoryPerformance',
|
|
225
|
+
description: 'Type of cookie',
|
|
226
|
+
defaultMessage: 'Performance Cookies'
|
|
227
|
+
}
|
|
228
|
+
});
|
|
229
|
+
const cookieDetailDescriptions = reactIntl.defineMessages({
|
|
230
|
+
functionalCookieDescription1: {
|
|
231
|
+
id: 'CookieConsentModal.cookieDetails.functionalCookieDescription1',
|
|
232
|
+
description: 'Description of cookie',
|
|
233
|
+
defaultMessage: 'Set by UserGuiding (Merchant Center). As per UserGuiding Cookie Policy: This cookie contains pages the user has seen. Its purpose is to improve the user guidance experience, like showing guides only once for each user, segmenting based on page view history, etc.'
|
|
234
|
+
},
|
|
235
|
+
performanceCookieDescription1: {
|
|
236
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription1',
|
|
237
|
+
description: 'Description of cookie',
|
|
238
|
+
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.'
|
|
239
|
+
},
|
|
240
|
+
performanceCookieDescription2: {
|
|
241
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription2',
|
|
242
|
+
description: 'Description of cookie',
|
|
243
|
+
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.'
|
|
244
|
+
},
|
|
245
|
+
performanceCookieDescription3: {
|
|
246
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription3',
|
|
247
|
+
description: 'Description of cookie',
|
|
248
|
+
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.'
|
|
249
|
+
},
|
|
250
|
+
performanceCookieDescription4: {
|
|
251
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription4',
|
|
252
|
+
description: 'Description of cookie',
|
|
253
|
+
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."
|
|
254
|
+
},
|
|
255
|
+
performanceCookieDescription5: {
|
|
256
|
+
id: 'CookieConsentModal.cookieDetails.performanceCookieDescription5',
|
|
257
|
+
description: 'Description of cookie',
|
|
258
|
+
defaultMessage: "Set by UserGuiding (Merchant Center). As per UserGuiding Cookie Policy: This cookie is for storing in the current browser a long living random unique id, which is created at first load of the UserGuiding snippet. This ID is created randomly based on the timestamp of the first visit and does not relate to the user’s personal information including IP. The stated purpose of the cookie is to track UserGuiding users' monthly active user quota, storing users' usage history to UserGuiding databases, etc."
|
|
259
|
+
}
|
|
260
|
+
});
|
|
261
|
+
|
|
262
|
+
const HOSTNAME = 'commercetools.com';
|
|
263
|
+
const createCookieLink = cookieName => `https://cookiepedia.co.uk/cookies/${cookieName}`;
|
|
264
|
+
const createFunctionalCookieDetails = intl => [{
|
|
265
|
+
name: {
|
|
266
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
267
|
+
value: '__ug__',
|
|
268
|
+
to: COOKIE_CONSENT_LINKS.USER_GUIDING_COOKIE_POLICY
|
|
269
|
+
},
|
|
270
|
+
host: {
|
|
271
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
272
|
+
value: HOSTNAME
|
|
273
|
+
},
|
|
274
|
+
duration: {
|
|
275
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
276
|
+
value: intl.formatMessage(cookieDetailValues.durationSession)
|
|
277
|
+
},
|
|
278
|
+
type: {
|
|
279
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
280
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
281
|
+
},
|
|
282
|
+
category: {
|
|
283
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
284
|
+
value: intl.formatMessage(cookieDetailValues.categoryFunctional)
|
|
285
|
+
},
|
|
286
|
+
description: {
|
|
287
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
288
|
+
value: intl.formatMessage(cookieDetailDescriptions.functionalCookieDescription1)
|
|
289
|
+
}
|
|
290
|
+
}];
|
|
291
|
+
const createPerformanceCookieDetails = intl => [{
|
|
292
|
+
name: {
|
|
293
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
294
|
+
value: '_fs_tab_id',
|
|
295
|
+
to: createCookieLink('_fs_tab_id')
|
|
296
|
+
},
|
|
297
|
+
host: {
|
|
298
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
299
|
+
value: HOSTNAME
|
|
300
|
+
},
|
|
301
|
+
duration: {
|
|
302
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
303
|
+
value: intl.formatMessage(cookieDetailValues.durationSession)
|
|
304
|
+
},
|
|
305
|
+
type: {
|
|
306
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
307
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
308
|
+
},
|
|
309
|
+
category: {
|
|
310
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
311
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
312
|
+
},
|
|
313
|
+
description: {
|
|
314
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
315
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription1)
|
|
316
|
+
}
|
|
317
|
+
}, {
|
|
318
|
+
name: {
|
|
319
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
320
|
+
value: 'fs_cid',
|
|
321
|
+
to: createCookieLink('fs_cid')
|
|
322
|
+
},
|
|
323
|
+
host: {
|
|
324
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
325
|
+
value: HOSTNAME
|
|
326
|
+
},
|
|
327
|
+
duration: {
|
|
328
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
329
|
+
value: intl.formatMessage(cookieDetailValues.duration1Year)
|
|
330
|
+
},
|
|
331
|
+
type: {
|
|
332
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
333
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
334
|
+
},
|
|
335
|
+
category: {
|
|
336
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
337
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
338
|
+
},
|
|
339
|
+
description: {
|
|
340
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
341
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription2)
|
|
342
|
+
}
|
|
343
|
+
}, {
|
|
344
|
+
name: {
|
|
345
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
346
|
+
value: 'fs_lua',
|
|
347
|
+
to: createCookieLink('fs_lua')
|
|
348
|
+
},
|
|
349
|
+
host: {
|
|
350
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
351
|
+
value: HOSTNAME
|
|
352
|
+
},
|
|
353
|
+
duration: {
|
|
354
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
355
|
+
value: intl.formatMessage(cookieDetailValues.duration1Day)
|
|
356
|
+
},
|
|
357
|
+
type: {
|
|
358
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
359
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
360
|
+
},
|
|
361
|
+
category: {
|
|
362
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
363
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
364
|
+
},
|
|
365
|
+
description: {
|
|
366
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
367
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription3)
|
|
368
|
+
}
|
|
369
|
+
}, {
|
|
370
|
+
name: {
|
|
371
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
372
|
+
value: 'fs_uid',
|
|
373
|
+
to: createCookieLink('fs_uid')
|
|
374
|
+
},
|
|
375
|
+
host: {
|
|
376
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
377
|
+
value: HOSTNAME
|
|
378
|
+
},
|
|
379
|
+
duration: {
|
|
380
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
381
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
382
|
+
},
|
|
383
|
+
type: {
|
|
384
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
385
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
386
|
+
},
|
|
387
|
+
category: {
|
|
388
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
389
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
390
|
+
},
|
|
391
|
+
description: {
|
|
392
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
393
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription4)
|
|
394
|
+
}
|
|
395
|
+
}, {
|
|
396
|
+
name: {
|
|
397
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
398
|
+
value: '__UGS__uid',
|
|
399
|
+
to: COOKIE_CONSENT_LINKS.USER_GUIDING_COOKIE_POLICY
|
|
400
|
+
},
|
|
401
|
+
host: {
|
|
402
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
403
|
+
value: HOSTNAME
|
|
404
|
+
},
|
|
405
|
+
duration: {
|
|
406
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
407
|
+
value: intl.formatMessage(cookieDetailValues.durationSession)
|
|
408
|
+
},
|
|
409
|
+
type: {
|
|
410
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
411
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
412
|
+
},
|
|
413
|
+
category: {
|
|
414
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
415
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
416
|
+
},
|
|
417
|
+
description: {
|
|
418
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
419
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription5)
|
|
420
|
+
}
|
|
421
|
+
}];
|
|
422
|
+
|
|
423
|
+
function ownKeys$1(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
424
|
+
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$1(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
425
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { 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)."; }
|
|
426
|
+
const View = {
|
|
427
|
+
Primary: 'Primary',
|
|
428
|
+
Secondary: 'Secondary',
|
|
429
|
+
Tertiary: 'Tertiary'
|
|
430
|
+
};
|
|
431
|
+
/**
|
|
432
|
+
* The design spec warranted text that _looks_ like a link, but isn't
|
|
433
|
+
*/
|
|
434
|
+
const NavigationLink = _ref4 => {
|
|
435
|
+
let onClick = _ref4.onClick,
|
|
436
|
+
label = _ref4.label;
|
|
437
|
+
return jsxRuntime.jsx(Link__default["default"], {
|
|
438
|
+
onClick: e => {
|
|
439
|
+
e.preventDefault();
|
|
440
|
+
onClick();
|
|
441
|
+
},
|
|
442
|
+
to: "",
|
|
443
|
+
children: label
|
|
444
|
+
});
|
|
445
|
+
};
|
|
446
|
+
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
447
|
+
name: "1u8ems1",
|
|
448
|
+
styles: "& svg{display:none;}"
|
|
449
|
+
} : {
|
|
450
|
+
name: "4sjpj8-removeDefaultSvg",
|
|
451
|
+
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
452
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsD8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
453
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
454
|
+
};
|
|
455
|
+
const InformationLink = _ref5 => {
|
|
456
|
+
let to = _ref5.to,
|
|
457
|
+
label = _ref5.label;
|
|
458
|
+
const removeDefaultSvg = _ref3;
|
|
459
|
+
return jsxRuntime.jsx("div", {
|
|
460
|
+
css: removeDefaultSvg,
|
|
461
|
+
children: jsxRuntime.jsx(Link__default["default"], {
|
|
462
|
+
isExternal: true,
|
|
463
|
+
to: to,
|
|
464
|
+
children: label
|
|
465
|
+
})
|
|
466
|
+
});
|
|
467
|
+
};
|
|
468
|
+
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
469
|
+
name: "1u8ems1",
|
|
470
|
+
styles: "& svg{display:none;}"
|
|
471
|
+
} : {
|
|
472
|
+
name: "4sjpj8-removeDefaultSvg",
|
|
473
|
+
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
474
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2E8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
475
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
476
|
+
};
|
|
477
|
+
const DetailLink = _ref6 => {
|
|
478
|
+
let to = _ref6.to,
|
|
479
|
+
label = _ref6.label;
|
|
480
|
+
const removeDefaultSvg = _ref2;
|
|
481
|
+
return jsxRuntime.jsx("div", {
|
|
482
|
+
css: removeDefaultSvg,
|
|
483
|
+
children: jsxRuntime.jsx(Link__default["default"], {
|
|
484
|
+
isExternal: true,
|
|
485
|
+
to: to,
|
|
486
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
487
|
+
tone: "primary",
|
|
488
|
+
children: label
|
|
489
|
+
})
|
|
490
|
+
})
|
|
491
|
+
});
|
|
492
|
+
};
|
|
493
|
+
var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
494
|
+
name: "qzmnd2",
|
|
495
|
+
styles: "padding-right:10px"
|
|
496
|
+
} : {
|
|
497
|
+
name: "ey0yn8-bumpToggle",
|
|
498
|
+
styles: "padding-right:10px;label:bumpToggle;",
|
|
499
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAgHwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
500
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
501
|
+
};
|
|
502
|
+
const CookieConsentBodyPrimary = _ref7 => {
|
|
503
|
+
let togglePerformanceValue = _ref7.togglePerformanceValue,
|
|
504
|
+
toggleFunctionalValue = _ref7.toggleFunctionalValue,
|
|
505
|
+
onTogglePerformance = _ref7.onTogglePerformance,
|
|
506
|
+
onToggleFunctional = _ref7.onToggleFunctional,
|
|
507
|
+
onChangeView = _ref7.onChangeView,
|
|
508
|
+
panelState = _ref7.panelState,
|
|
509
|
+
setPanelState = _ref7.setPanelState;
|
|
510
|
+
const _useIntl = reactIntl.useIntl(),
|
|
511
|
+
formatMessage = _useIntl.formatMessage;
|
|
512
|
+
|
|
513
|
+
// The outline of the input is cut off; we shift it to the left to compensate
|
|
514
|
+
const bumpToggle = _ref$1;
|
|
515
|
+
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
516
|
+
scale: "xl",
|
|
517
|
+
children: [jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
518
|
+
scale: "m",
|
|
519
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
520
|
+
intlMessage: modalMessages.mainDescription
|
|
521
|
+
}), jsxRuntime.jsx(InformationLink, {
|
|
522
|
+
label: formatMessage(modalMessages.privacyPolicyLink),
|
|
523
|
+
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY
|
|
524
|
+
})]
|
|
525
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
526
|
+
scale: "l",
|
|
527
|
+
children: [jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
528
|
+
condensed: true,
|
|
529
|
+
header: formatMessage(modalMessages.functionalCookiesHeader),
|
|
530
|
+
headerControls: jsxRuntime.jsx("div", {
|
|
531
|
+
css: bumpToggle,
|
|
532
|
+
children: jsxRuntime.jsx(ToggleInput__default["default"], {
|
|
533
|
+
isChecked: toggleFunctionalValue,
|
|
534
|
+
onChange: e => onToggleFunctional(e.target.checked),
|
|
535
|
+
size: "small"
|
|
536
|
+
})
|
|
537
|
+
}),
|
|
538
|
+
isClosed: panelState.functionalCookiesClosed,
|
|
539
|
+
onToggle: () => setPanelState(_objectSpread$1(_objectSpread$1({}, panelState), {}, {
|
|
540
|
+
functionalCookiesClosed: !panelState.functionalCookiesClosed
|
|
541
|
+
})),
|
|
542
|
+
theme: "light",
|
|
543
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
544
|
+
scale: "m",
|
|
545
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
546
|
+
intlMessage: modalMessages.functionalCookiesDescription
|
|
547
|
+
}), jsxRuntime.jsx(NavigationLink, {
|
|
548
|
+
label: formatMessage(modalMessages.cookieInformationLink),
|
|
549
|
+
onClick: () => onChangeView(View.Secondary)
|
|
550
|
+
})]
|
|
551
|
+
})
|
|
552
|
+
}), jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
553
|
+
condensed: true,
|
|
554
|
+
header: formatMessage(modalMessages.performanceCookiesHeader),
|
|
555
|
+
headerControls: jsxRuntime.jsx("div", {
|
|
556
|
+
css: bumpToggle,
|
|
557
|
+
children: jsxRuntime.jsx(ToggleInput__default["default"], {
|
|
558
|
+
isChecked: togglePerformanceValue,
|
|
559
|
+
onChange: e => onTogglePerformance(e.target.checked),
|
|
560
|
+
size: "small"
|
|
561
|
+
})
|
|
562
|
+
}),
|
|
563
|
+
isClosed: panelState.performanceCookiesClosed,
|
|
564
|
+
onToggle: () => setPanelState(_objectSpread$1(_objectSpread$1({}, panelState), {}, {
|
|
565
|
+
performanceCookiesClosed: !panelState.performanceCookiesClosed
|
|
566
|
+
})),
|
|
567
|
+
theme: "light",
|
|
568
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
569
|
+
scale: "m",
|
|
570
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
571
|
+
intlMessage: modalMessages.performanceCookiesDescription
|
|
572
|
+
}), jsxRuntime.jsx(NavigationLink, {
|
|
573
|
+
label: formatMessage(modalMessages.cookieInformationLink),
|
|
574
|
+
onClick: () => onChangeView(View.Tertiary)
|
|
575
|
+
})]
|
|
576
|
+
})
|
|
577
|
+
})]
|
|
578
|
+
})]
|
|
579
|
+
});
|
|
580
|
+
};
|
|
581
|
+
const CookieConsentBodyDetails = _ref8 => {
|
|
582
|
+
let onChangeView = _ref8.onChangeView,
|
|
583
|
+
cookieDetails = _ref8.cookieDetails;
|
|
584
|
+
const _useIntl2 = reactIntl.useIntl(),
|
|
585
|
+
formatMessage = _useIntl2.formatMessage;
|
|
586
|
+
const scrollRef = /*#__PURE__*/react.createRef();
|
|
587
|
+
react.useEffect(() => {
|
|
588
|
+
scrollRef.current?.scrollIntoView();
|
|
589
|
+
}, [scrollRef]);
|
|
590
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
591
|
+
children: [jsxRuntime.jsx("div", {
|
|
592
|
+
ref: scrollRef,
|
|
593
|
+
css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA0NgB","file":"cookie-consent-modal.tsx","sourcesContent":["import { createRef, Fragment, useEffect, useState } from 'react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { css } from '@emotion/react';\nimport { useIntl } from 'react-intl';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport { useCookieConsent } from '../../react';\nimport {\n  CookieDetails,\n  createFunctionalCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { modalMessages } from './messages';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  togglePerformanceValue: boolean;\n  toggleFunctionalValue: boolean;\n  onTogglePerformance: (checked: boolean) => void;\n  onToggleFunctional: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  togglePerformanceValue,\n  toggleFunctionalValue,\n  onTogglePerformance,\n  onToggleFunctional,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.functionalCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleFunctionalValue}\n                onChange={(e) => onToggleFunctional(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.functionalCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              functionalCookiesClosed: !panelState.functionalCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.functionalCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={togglePerformanceValue}\n                onChange={(e) => onTogglePerformance(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  functionalCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [enableFunctionalCookies, setEnableFunctionalCookies] = useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    functionalCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (\n    functionalConsent: boolean,\n    performanceConsent: boolean\n  ) => ({\n    functionalCookies: functionalConsent,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(\n          createConsentGroups(enableFunctionalCookies, enablePerformanceCookies)\n        );\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true, true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n      zIndex={1000000}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggleFunctional={(value) => setEnableFunctionalCookies(value)}\n          onTogglePerformance={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleFunctionalValue={enableFunctionalCookies}\n          togglePerformanceValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createFunctionalCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */")
|
|
594
|
+
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
595
|
+
scale: "l",
|
|
596
|
+
children: [jsxRuntime.jsx(NavigationLink, {
|
|
597
|
+
label: formatMessage(modalMessages.navigateBackLink),
|
|
598
|
+
onClick: () => onChangeView(View.Primary)
|
|
599
|
+
}), jsxRuntime.jsx(Spacings__default["default"].Stack, {
|
|
600
|
+
scale: "l",
|
|
601
|
+
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails, detail => {
|
|
602
|
+
var _context;
|
|
603
|
+
return jsxRuntime.jsx(Grid__default["default"], {
|
|
604
|
+
gridGap: designSystem.designTokens.spacing40,
|
|
605
|
+
gridRowGap: "0px",
|
|
606
|
+
gridTemplateColumns: `${designSystem.designTokens.constraint2} 1fr`,
|
|
607
|
+
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context, value => jsxRuntime.jsxs(react.Fragment, {
|
|
608
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
609
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
610
|
+
children: value.label
|
|
611
|
+
})
|
|
612
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
613
|
+
children: 'to' in value ? jsxRuntime.jsx(DetailLink, {
|
|
614
|
+
label: value.value,
|
|
615
|
+
to: value.to
|
|
616
|
+
}) : jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
617
|
+
children: value.value
|
|
618
|
+
})
|
|
619
|
+
})]
|
|
620
|
+
}, value.value))
|
|
621
|
+
}, detail.name.value);
|
|
622
|
+
})
|
|
623
|
+
})]
|
|
624
|
+
})]
|
|
625
|
+
});
|
|
626
|
+
};
|
|
627
|
+
const CookieConsentModal = modalProps => {
|
|
628
|
+
const intl = reactIntl.useIntl();
|
|
629
|
+
const _useCookieConsent = useCookieConsent('performanceCookies'),
|
|
630
|
+
setConsent = _useCookieConsent.setConsent;
|
|
631
|
+
const _useState = react.useState(false),
|
|
632
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
633
|
+
enablePerformanceCookies = _useState2[0],
|
|
634
|
+
setEnablePerformanceCookies = _useState2[1];
|
|
635
|
+
const _useState3 = react.useState(false),
|
|
636
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
637
|
+
enableFunctionalCookies = _useState4[0],
|
|
638
|
+
setEnableFunctionalCookies = _useState4[1];
|
|
639
|
+
const _useState5 = react.useState(View.Primary),
|
|
640
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
641
|
+
currentView = _useState6[0],
|
|
642
|
+
setCurrentView = _useState6[1];
|
|
643
|
+
const _useState7 = react.useState({
|
|
644
|
+
functionalCookiesClosed: true,
|
|
645
|
+
performanceCookiesClosed: true
|
|
646
|
+
}),
|
|
647
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
648
|
+
panelState = _useState8[0],
|
|
649
|
+
setPanelState = _useState8[1];
|
|
650
|
+
const createConsentGroups = (functionalConsent, performanceConsent) => ({
|
|
651
|
+
functionalCookies: functionalConsent,
|
|
652
|
+
performanceCookies: performanceConsent
|
|
653
|
+
});
|
|
654
|
+
return jsxRuntime.jsxs(applicationComponents.ConfirmationDialog, {
|
|
655
|
+
isOpen: modalProps.isModalOpen,
|
|
656
|
+
labelPrimary: intl.formatMessage(modalMessages.primaryButtonLabel),
|
|
657
|
+
labelSecondary: intl.formatMessage(modalMessages.secondaryButtonLabel),
|
|
658
|
+
onCancel: () => {
|
|
659
|
+
setConsent(createConsentGroups(enableFunctionalCookies, enablePerformanceCookies));
|
|
660
|
+
modalProps.setBannerClosed(true);
|
|
661
|
+
modalProps.closeModal();
|
|
662
|
+
},
|
|
663
|
+
onClose: modalProps.closeModal,
|
|
664
|
+
onConfirm: () => {
|
|
665
|
+
setConsent(createConsentGroups(true, true));
|
|
666
|
+
modalProps.setBannerClosed(true);
|
|
667
|
+
modalProps.closeModal();
|
|
668
|
+
},
|
|
669
|
+
title: intl.formatMessage(modalMessages.title),
|
|
670
|
+
zIndex: 1000000,
|
|
671
|
+
children: [currentView === View.Primary && jsxRuntime.jsx(CookieConsentBodyPrimary, {
|
|
672
|
+
onChangeView: view => setCurrentView(view),
|
|
673
|
+
onToggleFunctional: value => setEnableFunctionalCookies(value),
|
|
674
|
+
onTogglePerformance: value => setEnablePerformanceCookies(value),
|
|
675
|
+
panelState: panelState,
|
|
676
|
+
setPanelState: state => setPanelState(state),
|
|
677
|
+
toggleFunctionalValue: enableFunctionalCookies,
|
|
678
|
+
togglePerformanceValue: enablePerformanceCookies
|
|
679
|
+
}), currentView === View.Secondary && jsxRuntime.jsx(CookieConsentBodyDetails, {
|
|
680
|
+
cookieDetails: createFunctionalCookieDetails(intl),
|
|
681
|
+
onChangeView: view => setCurrentView(view)
|
|
682
|
+
}), currentView === View.Tertiary && jsxRuntime.jsx(CookieConsentBodyDetails, {
|
|
683
|
+
cookieDetails: createPerformanceCookieDetails(intl),
|
|
684
|
+
onChangeView: view => setCurrentView(view)
|
|
685
|
+
})]
|
|
686
|
+
});
|
|
687
|
+
};
|
|
688
|
+
|
|
689
|
+
var messages = reactIntl.defineMessages({
|
|
690
|
+
bannerMessage: {
|
|
691
|
+
id: 'CookieConsentBanner.bannerMessage',
|
|
692
|
+
description: 'Text of the cookie consent banner.',
|
|
693
|
+
defaultMessage: 'This site uses cookies. See our {privacyLink} or manage your {modalLink} here.'
|
|
694
|
+
},
|
|
695
|
+
privacyPolicyLink: {
|
|
696
|
+
id: 'CookieConsentBanner.privacyPolicyLink',
|
|
697
|
+
description: 'Privacy policy link text in the cookie consent banner.',
|
|
698
|
+
defaultMessage: 'privacy policy'
|
|
699
|
+
},
|
|
700
|
+
bannerCookiesModalLink: {
|
|
701
|
+
id: 'CookieConsentBanner.bannerCookiesModalLink',
|
|
702
|
+
description: 'Cookie settings modal link text in the cookie consent banner.',
|
|
703
|
+
defaultMessage: 'cookies settings'
|
|
704
|
+
},
|
|
705
|
+
buttonLabel: {
|
|
706
|
+
id: 'CookieConsentBanner.buttonLabel',
|
|
707
|
+
description: 'Button text allowing the user to accept all ct cookies',
|
|
708
|
+
defaultMessage: 'Accept all cookies'
|
|
709
|
+
}
|
|
710
|
+
});
|
|
711
|
+
|
|
712
|
+
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
713
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
714
|
+
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)."; }
|
|
715
|
+
const BANNER_HEIGHT = 64;
|
|
716
|
+
|
|
717
|
+
/**
|
|
718
|
+
* Define a fixed date to determine the validity of consent cookies. Update as required.
|
|
719
|
+
*
|
|
720
|
+
* Cookies set before this date are considered invalid due to new cookie regulations or changes.
|
|
721
|
+
*/
|
|
722
|
+
const COOKIE_REVOCATION_DATE = 'Wed May 01 2024 12:00:00 GMT-0400 (Eastern Daylight Time)';
|
|
723
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
724
|
+
name: "1u6bcy9",
|
|
725
|
+
styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999"
|
|
726
|
+
} : {
|
|
727
|
+
name: "t2qh0u-CookieConsentBanner",
|
|
728
|
+
styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999;label:CookieConsentBanner;",
|
|
729
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOERjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgTGluayBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9saW5rJztcbmltcG9ydCBQcmltYXJ5QnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3ByaW1hcnktYnV0dG9uJztcbmltcG9ydCBTcGFjaW5ncyBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zcGFjaW5ncyc7XG5pbXBvcnQgVGV4dCBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC90ZXh0JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IHVzZU1vZGFsU3RhdGUgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IENPT0tJRV9DT05TRU5UX0xJTktTIH0gZnJvbSAnLi4vLi4vLi4vY29uc3RhbnRzL2xpbmtzJztcbmltcG9ydCB7IHVuc2V0Q29uc2VudENvb2tpZSB9IGZyb20gJy4uLy4uL2NvcmUnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBCQU5ORVJfSEVJR0hUID0gNjQ7XG5cbi8qKlxuICogRGVmaW5lIGEgZml4ZWQgZGF0ZSB0byBkZXRlcm1pbmUgdGhlIHZhbGlkaXR5IG9mIGNvbnNlbnQgY29va2llcy4gVXBkYXRlIGFzIHJlcXVpcmVkLlxuICpcbiAqIENvb2tpZXMgc2V0IGJlZm9yZSB0aGlzIGRhdGUgYXJlIGNvbnNpZGVyZWQgaW52YWxpZCBkdWUgdG8gbmV3IGNvb2tpZSByZWd1bGF0aW9ucyBvciBjaGFuZ2VzLlxuICovXG5jb25zdCBDT09LSUVfUkVWT0NBVElPTl9EQVRFID1cbiAgJ1dlZCBNYXkgMDEgMjAyNCAxMjowMDowMCBHTVQtMDQwMCAoRWFzdGVybiBEYXlsaWdodCBUaW1lKSc7XG5cbmNvbnN0IENvb2tpZUNvbnNlbnRCYW5uZXIgPSAoYmFubmVyUHJvcHM6IENvbnNlbnRCYW5uZXJQcm9wcykgPT4ge1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIFJldm9rZSBjb29raWVzIHByaW9yIHRvIGEgY2VydGFpbiBkYXRlIHRvIGVuc3VyZSB1c2VyIHByZWZlcmVuY2VzIGFyZSB1cC10by1kYXRlIHdpdGggY29va2llIGNvbmZpZ3VyYXRpb25cbiAgICB1bnNldENvbnNlbnRDb29raWUobmV3IERhdGUoQ09PS0lFX1JFVk9DQVRJT05fREFURSkpO1xuICB9LCBbXSk7XG5cbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfSA9IHVzZUNvb2tpZUNvbnNlbnQoXG4gICAgJ2Z1bmN0aW9uYWxDb29raWVzJyxcbiAgICB7IHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCB9XG4gICk7XG5cbiAgY29uc3QgY3JlYXRlQ29uc2VudEdyb3VwcyA9ICgpID0+ICh7XG4gICAgZnVuY3Rpb25hbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5GdW5jdGlvbmFsQ29va2llQ29uc2VudCB8fFxuICAgIGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50XG4gIClcbiAgICByZXR1cm4gbnVsbDtcblxuICByZXR1cm4gKFxuICAgIC8vIFRPRE86IHVzZSBsb3dlciB6LWluZGV4LCBwcmVmZXIgcmFuZ2VzIHBlciB1c2UtY2FzZVxuICAgIDxkaXZcbiAgICAgIGNzcz17Y3NzYFxuICAgICAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgICAgIHRvcDogMDtcbiAgICAgICAgbGVmdDogMDtcbiAgICAgICAgYm90dG9tOiAwO1xuICAgICAgICByaWdodDogMDtcbiAgICAgICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICBgfVxuICAgID5cbiAgICAgIDxkaXZcbiAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgcG9zaXRpb246IHN0aWNreTtcbiAgICAgICAgICB0b3A6IGNhbGMoMTAwJSAtICR7QkFOTkVSX0hFSUdIVH1weCAtICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH0pO1xuICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgICAgcG9pbnRlci1ldmVudHM6IGF1dG87XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yQWNjZW50MTB9O1xuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNH07XG4gICAgICAgICAgICBib3gtc2hhZG93OiAke2Rlc2lnblRva2Vucy5zaGFkb3c4fTtcbiAgICAgICAgICAgIG1hcmdpbjogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICAgICAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ019ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgICAgICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgICAgICAgIHN2ZyB7XG4gICAgICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlXG4gICAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgICBwcml2YWN5TGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5wcml2YWN5UG9saWN5TGlua31cbiAgICAgICAgICAgICAgICAgICAgICBpc0V4dGVybmFsXG4gICAgICAgICAgICAgICAgICAgICAgdG89e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgbW9kYWxMaW5rOiAoXG4gICAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIG9wZW5Nb2RhbCgpO1xuICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgdG89XCJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */",
|
|
730
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
731
|
+
};
|
|
732
|
+
const CookieConsentBanner = bannerProps => {
|
|
733
|
+
react.useEffect(() => {
|
|
734
|
+
// Revoke cookies prior to a certain date to ensure user preferences are up-to-date with cookie configuration
|
|
735
|
+
core_dist_commercetoolsFrontendCookieConsentCore.unsetConsentCookie(new Date(COOKIE_REVOCATION_DATE));
|
|
736
|
+
}, []);
|
|
737
|
+
|
|
738
|
+
// Hide the banner once the accept button is clicked, until we can subscribe to the cookie
|
|
739
|
+
const _useState = react.useState(false),
|
|
740
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
741
|
+
bannerClosed = _useState2[0],
|
|
742
|
+
setBannerClosed = _useState2[1];
|
|
743
|
+
const _useModalState = applicationComponents.useModalState(),
|
|
744
|
+
closeModal = _useModalState.closeModal,
|
|
745
|
+
openModal = _useModalState.openModal,
|
|
746
|
+
isModalOpen = _useModalState.isModalOpen;
|
|
747
|
+
const _useIntl = reactIntl.useIntl(),
|
|
748
|
+
formatMessage = _useIntl.formatMessage;
|
|
749
|
+
const _useCookieConsent = useCookieConsent('performanceCookies', {
|
|
750
|
+
skipConsent: bannerProps.skipConsent
|
|
751
|
+
}),
|
|
752
|
+
setConsent = _useCookieConsent.setConsent,
|
|
753
|
+
hasGivenPerformanceCookieConsent = _useCookieConsent.givenConsent;
|
|
754
|
+
const _useCookieConsent2 = useCookieConsent('functionalCookies', {
|
|
755
|
+
skipConsent: bannerProps.skipConsent
|
|
756
|
+
}),
|
|
757
|
+
hasGivenFunctionalCookieConsent = _useCookieConsent2.givenConsent;
|
|
758
|
+
const createConsentGroups = () => ({
|
|
759
|
+
functionalCookies: true,
|
|
760
|
+
performanceCookies: true
|
|
761
|
+
});
|
|
762
|
+
if (bannerClosed || hasGivenFunctionalCookieConsent || hasGivenPerformanceCookieConsent) return null;
|
|
763
|
+
return (
|
|
764
|
+
// TODO: use lower z-index, prefer ranges per use-case
|
|
765
|
+
jsxRuntime.jsx("div", {
|
|
766
|
+
css: _ref,
|
|
767
|
+
children: jsxRuntime.jsxs("div", {
|
|
768
|
+
css: /*#__PURE__*/react$1.css("position:sticky;top:calc(100% - ", BANNER_HEIGHT, "px - ", designSystem.designTokens.spacingXl, ");display:flex;flex-direction:column;align-items:center;z-index:9999;width:100%;pointer-events:auto;" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUVnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgeyB1bnNldENvbnNlbnRDb29raWUgfSBmcm9tICcuLi8uLi9jb3JlJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQkFOTkVSX0hFSUdIVCA9IDY0O1xuXG4vKipcbiAqIERlZmluZSBhIGZpeGVkIGRhdGUgdG8gZGV0ZXJtaW5lIHRoZSB2YWxpZGl0eSBvZiBjb25zZW50IGNvb2tpZXMuIFVwZGF0ZSBhcyByZXF1aXJlZC5cbiAqXG4gKiBDb29raWVzIHNldCBiZWZvcmUgdGhpcyBkYXRlIGFyZSBjb25zaWRlcmVkIGludmFsaWQgZHVlIHRvIG5ldyBjb29raWUgcmVndWxhdGlvbnMgb3IgY2hhbmdlcy5cbiAqL1xuY29uc3QgQ09PS0lFX1JFVk9DQVRJT05fREFURSA9XG4gICdXZWQgTWF5IDAxIDIwMjQgMTI6MDA6MDAgR01ULTA0MDAgKEVhc3Rlcm4gRGF5bGlnaHQgVGltZSknO1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBSZXZva2UgY29va2llcyBwcmlvciB0byBhIGNlcnRhaW4gZGF0ZSB0byBlbnN1cmUgdXNlciBwcmVmZXJlbmNlcyBhcmUgdXAtdG8tZGF0ZSB3aXRoIGNvb2tpZSBjb25maWd1cmF0aW9uXG4gICAgdW5zZXRDb25zZW50Q29va2llKG5ldyBEYXRlKENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUpKTtcbiAgfSwgW10pO1xuXG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
|
|
769
|
+
children: [jsxRuntime.jsx("div", {
|
|
770
|
+
css: /*#__PURE__*/react$1.css("background-color:", designSystem.designTokens.colorAccent10, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow8, ";margin:0 ", designSystem.designTokens.spacingXl, ";padding:", designSystem.designTokens.spacingM, " ", designSystem.designTokens.spacingL, ";width:fit-content;svg{display:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBanner;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUZrQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IExpbmsgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvbGluayc7XG5pbXBvcnQgUHJpbWFyeUJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9wcmltYXJ5LWJ1dHRvbic7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IFRleHQgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvdGV4dCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyB1c2VNb2RhbFN0YXRlIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDT09LSUVfQ09OU0VOVF9MSU5LUyB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9saW5rcyc7XG5pbXBvcnQgeyB1bnNldENvbnNlbnRDb29raWUgfSBmcm9tICcuLi8uLi9jb3JlJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQkFOTkVSX0hFSUdIVCA9IDY0O1xuXG4vKipcbiAqIERlZmluZSBhIGZpeGVkIGRhdGUgdG8gZGV0ZXJtaW5lIHRoZSB2YWxpZGl0eSBvZiBjb25zZW50IGNvb2tpZXMuIFVwZGF0ZSBhcyByZXF1aXJlZC5cbiAqXG4gKiBDb29raWVzIHNldCBiZWZvcmUgdGhpcyBkYXRlIGFyZSBjb25zaWRlcmVkIGludmFsaWQgZHVlIHRvIG5ldyBjb29raWUgcmVndWxhdGlvbnMgb3IgY2hhbmdlcy5cbiAqL1xuY29uc3QgQ09PS0lFX1JFVk9DQVRJT05fREFURSA9XG4gICdXZWQgTWF5IDAxIDIwMjQgMTI6MDA6MDAgR01ULTA0MDAgKEVhc3Rlcm4gRGF5bGlnaHQgVGltZSknO1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBSZXZva2UgY29va2llcyBwcmlvciB0byBhIGNlcnRhaW4gZGF0ZSB0byBlbnN1cmUgdXNlciBwcmVmZXJlbmNlcyBhcmUgdXAtdG8tZGF0ZSB3aXRoIGNvb2tpZSBjb25maWd1cmF0aW9uXG4gICAgdW5zZXRDb25zZW50Q29va2llKG5ldyBEYXRlKENPT0tJRV9SRVZPQ0FUSU9OX0RBVEUpKTtcbiAgfSwgW10pO1xuXG4gIC8vIEhpZGUgdGhlIGJhbm5lciBvbmNlIHRoZSBhY2NlcHQgYnV0dG9uIGlzIGNsaWNrZWQsIHVudGlsIHdlIGNhbiBzdWJzY3JpYmUgdG8gdGhlIGNvb2tpZVxuICBjb25zdCBbYmFubmVyQ2xvc2VkLCBzZXRCYW5uZXJDbG9zZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCB7IGNsb3NlTW9kYWwsIG9wZW5Nb2RhbCwgaXNNb2RhbE9wZW4gfSA9IHVzZU1vZGFsU3RhdGUoKTtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHsgc2V0Q29uc2VudCwgZ2l2ZW5Db25zZW50OiBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudCB9ID1cbiAgICB1c2VDb29raWVDb25zZW50KCdwZXJmb3JtYW5jZUNvb2tpZXMnLCB7XG4gICAgICBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQsXG4gICAgfSk7XG4gIGNvbnN0IHsgZ2l2ZW5Db25zZW50OiBoYXNHaXZlbkZ1bmN0aW9uYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdmdW5jdGlvbmFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGZ1bmN0aW9uYWxDb29raWVzOiB0cnVlLFxuICAgIHBlcmZvcm1hbmNlQ29va2llczogdHJ1ZSxcbiAgfSk7XG5cbiAgaWYgKFxuICAgIGJhbm5lckNsb3NlZCB8fFxuICAgIGhhc0dpdmVuRnVuY3Rpb25hbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke0JBTk5FUl9IRUlHSFR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
|
|
771
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
772
|
+
alignItems: "center",
|
|
773
|
+
scale: "xl",
|
|
774
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
775
|
+
tone: "inverted",
|
|
776
|
+
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread(_objectSpread({}, messages.bannerMessage), {}, {
|
|
777
|
+
values: {
|
|
778
|
+
privacyLink: jsxRuntime.jsx(Link__default["default"], {
|
|
779
|
+
intlMessage: messages.privacyPolicyLink,
|
|
780
|
+
isExternal: true,
|
|
781
|
+
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY,
|
|
782
|
+
tone: "inverted"
|
|
783
|
+
}),
|
|
784
|
+
modalLink: jsxRuntime.jsx(Link__default["default"], {
|
|
785
|
+
intlMessage: messages.bannerCookiesModalLink,
|
|
786
|
+
onClick: e => {
|
|
787
|
+
e.preventDefault();
|
|
788
|
+
openModal();
|
|
789
|
+
},
|
|
790
|
+
to: "",
|
|
791
|
+
tone: "inverted"
|
|
792
|
+
})
|
|
793
|
+
}
|
|
794
|
+
}))
|
|
795
|
+
}), jsxRuntime.jsx(PrimaryButton__default["default"], {
|
|
796
|
+
label: formatMessage(messages.buttonLabel),
|
|
797
|
+
onClick: () => {
|
|
798
|
+
setConsent(createConsentGroups());
|
|
799
|
+
setBannerClosed(true);
|
|
800
|
+
},
|
|
801
|
+
size: "medium"
|
|
802
|
+
})]
|
|
803
|
+
})
|
|
804
|
+
}), jsxRuntime.jsx(CookieConsentModal, {
|
|
805
|
+
closeModal: closeModal,
|
|
806
|
+
isModalOpen: isModalOpen,
|
|
807
|
+
setBannerClosed: setBannerClosed
|
|
808
|
+
})]
|
|
809
|
+
})
|
|
810
|
+
})
|
|
811
|
+
);
|
|
812
|
+
};
|
|
813
|
+
CookieConsentBanner.displayName = 'CookieConsentBanner';
|
|
814
|
+
|
|
815
|
+
exports.CookieConsentBanner = CookieConsentBanner;
|
|
816
|
+
exports.CookieConsentModal = CookieConsentModal;
|
|
817
|
+
exports.useCookieConsent = useCookieConsent;
|
|
818
|
+
exports.useSkipCookieConsent = useSkipCookieConsent;
|