@commercetools-frontend/cookie-consent 1.3.0 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.dev.js +25 -27
- package/core/dist/commercetools-frontend-cookie-consent-core.cjs.prod.js +25 -27
- package/core/dist/commercetools-frontend-cookie-consent-core.esm.js +25 -27
- package/package.json +23 -16
- package/react/dist/commercetools-frontend-cookie-consent-react.cjs.dev.js +340 -358
- package/react/dist/commercetools-frontend-cookie-consent-react.cjs.prod.js +326 -350
- package/react/dist/commercetools-frontend-cookie-consent-react.esm.js +341 -359
|
@@ -55,18 +55,18 @@ var CollapsiblePanel__default = /*#__PURE__*/_interopDefault(CollapsiblePanel);
|
|
|
55
55
|
var Grid__default = /*#__PURE__*/_interopDefault(Grid);
|
|
56
56
|
var ToggleInput__default = /*#__PURE__*/_interopDefault(ToggleInput);
|
|
57
57
|
|
|
58
|
-
|
|
58
|
+
const defaultConsentOptions = {
|
|
59
59
|
skipConsent: false,
|
|
60
60
|
cookieName: 'OptanonConsent'
|
|
61
61
|
};
|
|
62
62
|
function useCookieConsent(consentGroup) {
|
|
63
|
-
|
|
63
|
+
let _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultConsentOptions,
|
|
64
64
|
skipConsent = _ref.skipConsent,
|
|
65
65
|
cookieName = _ref.cookieName;
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
skipConsent
|
|
66
|
+
const consentCookieGroups = react.useMemo(() => {
|
|
67
|
+
const rawConsentCookie = core_dist_commercetoolsFrontendCookieConsentCore.getRawConsentCookie(cookieName);
|
|
68
|
+
const consentCookieGroups = core_dist_commercetoolsFrontendCookieConsentCore.getParsedConsentCookieGroups(rawConsentCookie, {
|
|
69
|
+
skipConsent
|
|
70
70
|
});
|
|
71
71
|
return consentCookieGroups;
|
|
72
72
|
}, [cookieName, skipConsent]);
|
|
@@ -77,13 +77,11 @@ function useCookieConsent(consentGroup) {
|
|
|
77
77
|
}
|
|
78
78
|
|
|
79
79
|
function useSkipCookieConsent() {
|
|
80
|
-
|
|
81
|
-
return context.environment.skipCookieConsent;
|
|
82
|
-
});
|
|
80
|
+
const skipCookieConsent = applicationShellConnectors.useApplicationContext(context => context.environment.skipCookieConsent);
|
|
83
81
|
return Boolean(skipCookieConsent);
|
|
84
82
|
}
|
|
85
83
|
|
|
86
|
-
|
|
84
|
+
const modalMessages = reactIntl.defineMessages({
|
|
87
85
|
title: {
|
|
88
86
|
id: 'CookieConsentModal.title',
|
|
89
87
|
description: 'Confirmation dialog title',
|
|
@@ -145,7 +143,7 @@ var modalMessages = reactIntl.defineMessages({
|
|
|
145
143
|
defaultMessage: 'Back to Privacy Preference Center'
|
|
146
144
|
}
|
|
147
145
|
});
|
|
148
|
-
|
|
146
|
+
const cookieDetailLabels = reactIntl.defineMessages({
|
|
149
147
|
nameLabel: {
|
|
150
148
|
id: 'CookieConsentModal.cookieDetails.nameLabel',
|
|
151
149
|
description: 'Name - category identifier',
|
|
@@ -177,7 +175,7 @@ var cookieDetailLabels = reactIntl.defineMessages({
|
|
|
177
175
|
defaultMessage: 'Description'
|
|
178
176
|
}
|
|
179
177
|
});
|
|
180
|
-
|
|
178
|
+
const cookieDetailValues = reactIntl.defineMessages({
|
|
181
179
|
duration9Months: {
|
|
182
180
|
id: 'CookieConsentModal.cookieDetails.duration9Months',
|
|
183
181
|
description: 'Length of time',
|
|
@@ -219,7 +217,7 @@ var cookieDetailValues = reactIntl.defineMessages({
|
|
|
219
217
|
defaultMessage: 'Performance Cookies'
|
|
220
218
|
}
|
|
221
219
|
});
|
|
222
|
-
|
|
220
|
+
const cookieDetailDescriptions = reactIntl.defineMessages({
|
|
223
221
|
essentialCookieDescription1: {
|
|
224
222
|
id: 'CookieConsentModal.cookieDetails.essentialCookieDescription1',
|
|
225
223
|
description: 'Description of cookie',
|
|
@@ -257,207 +255,201 @@ var cookieDetailDescriptions = reactIntl.defineMessages({
|
|
|
257
255
|
}
|
|
258
256
|
});
|
|
259
257
|
|
|
260
|
-
|
|
258
|
+
const COOKIE_CONSENT_LINKS = {
|
|
261
259
|
PRIVACY_POLICY: 'https://commercetools.com/privacy#website'
|
|
262
260
|
};
|
|
263
261
|
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
},
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
},
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
},
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
description: {
|
|
451
|
-
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
452
|
-
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription4)
|
|
453
|
-
}
|
|
454
|
-
}];
|
|
455
|
-
};
|
|
262
|
+
const HOSTNAME = 'commercetools.com';
|
|
263
|
+
const createCookieLink = cookieName => "https://cookiepedia.co.uk/cookies/".concat(cookieName);
|
|
264
|
+
const createEssentialCookieDetails = intl => [{
|
|
265
|
+
name: {
|
|
266
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
267
|
+
value: 'intercom-device-id-b74wbpa8',
|
|
268
|
+
to: createCookieLink('intercom-device-id-b74wbpa8')
|
|
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.duration9Months)
|
|
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.categoryStrictlyNecessary)
|
|
285
|
+
},
|
|
286
|
+
description: {
|
|
287
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
288
|
+
value: intl.formatMessage(cookieDetailDescriptions.essentialCookieDescription1)
|
|
289
|
+
}
|
|
290
|
+
}, {
|
|
291
|
+
name: {
|
|
292
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
293
|
+
value: 'intercom-id-b74wbpa8',
|
|
294
|
+
to: createCookieLink('intercom-id-b74wbpa8')
|
|
295
|
+
},
|
|
296
|
+
host: {
|
|
297
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
298
|
+
value: HOSTNAME
|
|
299
|
+
},
|
|
300
|
+
duration: {
|
|
301
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
302
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
303
|
+
},
|
|
304
|
+
type: {
|
|
305
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
306
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
307
|
+
},
|
|
308
|
+
category: {
|
|
309
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
310
|
+
value: intl.formatMessage(cookieDetailValues.categoryStrictlyNecessary)
|
|
311
|
+
},
|
|
312
|
+
description: {
|
|
313
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
314
|
+
value: intl.formatMessage(cookieDetailDescriptions.essentialCookieDescription2)
|
|
315
|
+
}
|
|
316
|
+
}, {
|
|
317
|
+
name: {
|
|
318
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
319
|
+
value: 'intercom-session-b74wbpa8',
|
|
320
|
+
to: createCookieLink('intercom-session-b74wbpa8')
|
|
321
|
+
},
|
|
322
|
+
host: {
|
|
323
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
324
|
+
value: HOSTNAME
|
|
325
|
+
},
|
|
326
|
+
duration: {
|
|
327
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
328
|
+
value: intl.formatMessage(cookieDetailValues.duration1Week)
|
|
329
|
+
},
|
|
330
|
+
type: {
|
|
331
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
332
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
333
|
+
},
|
|
334
|
+
category: {
|
|
335
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
336
|
+
value: intl.formatMessage(cookieDetailValues.categoryStrictlyNecessary)
|
|
337
|
+
},
|
|
338
|
+
description: {
|
|
339
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
340
|
+
value: intl.formatMessage(cookieDetailDescriptions.essentialCookieDescription3)
|
|
341
|
+
}
|
|
342
|
+
}];
|
|
343
|
+
const createPerformanceCookieDetails = intl => [{
|
|
344
|
+
name: {
|
|
345
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
346
|
+
value: '_fs_tab_id',
|
|
347
|
+
to: createCookieLink('_fs_tab_id')
|
|
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.durationSession)
|
|
356
|
+
},
|
|
357
|
+
type: {
|
|
358
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
359
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
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.performanceCookieDescription1)
|
|
368
|
+
}
|
|
369
|
+
}, {
|
|
370
|
+
name: {
|
|
371
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
372
|
+
value: 'fs_cid',
|
|
373
|
+
to: createCookieLink('fs_cid')
|
|
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.duration1Year)
|
|
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.performanceCookieDescription2)
|
|
394
|
+
}
|
|
395
|
+
}, {
|
|
396
|
+
name: {
|
|
397
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
398
|
+
value: 'fs_lua',
|
|
399
|
+
to: createCookieLink('fs_lua')
|
|
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.duration1Day)
|
|
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.performanceCookieDescription3)
|
|
420
|
+
}
|
|
421
|
+
}, {
|
|
422
|
+
name: {
|
|
423
|
+
label: intl.formatMessage(cookieDetailLabels.nameLabel),
|
|
424
|
+
value: 'fs_uid',
|
|
425
|
+
to: createCookieLink('fs_uid')
|
|
426
|
+
},
|
|
427
|
+
host: {
|
|
428
|
+
label: intl.formatMessage(cookieDetailLabels.hostLabel),
|
|
429
|
+
value: HOSTNAME
|
|
430
|
+
},
|
|
431
|
+
duration: {
|
|
432
|
+
label: intl.formatMessage(cookieDetailLabels.durationLabel),
|
|
433
|
+
value: intl.formatMessage(cookieDetailValues.duration9Months)
|
|
434
|
+
},
|
|
435
|
+
type: {
|
|
436
|
+
label: intl.formatMessage(cookieDetailLabels.typeLabel),
|
|
437
|
+
value: intl.formatMessage(cookieDetailValues.typeFirstParty)
|
|
438
|
+
},
|
|
439
|
+
category: {
|
|
440
|
+
label: intl.formatMessage(cookieDetailLabels.categoryLabel),
|
|
441
|
+
value: intl.formatMessage(cookieDetailValues.categoryPerformance)
|
|
442
|
+
},
|
|
443
|
+
description: {
|
|
444
|
+
label: intl.formatMessage(cookieDetailLabels.descriptionLabel),
|
|
445
|
+
value: intl.formatMessage(cookieDetailDescriptions.performanceCookieDescription4)
|
|
446
|
+
}
|
|
447
|
+
}];
|
|
456
448
|
|
|
457
449
|
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
458
450
|
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$1(Object(source))).call(_context3, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
459
|
-
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)."; }
|
|
460
|
-
|
|
451
|
+
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)."; }
|
|
452
|
+
const View = {
|
|
461
453
|
Primary: 'Primary',
|
|
462
454
|
Secondary: 'Secondary',
|
|
463
455
|
Tertiary: 'Tertiary'
|
|
@@ -465,13 +457,13 @@ var View = {
|
|
|
465
457
|
/**
|
|
466
458
|
* The design spec warranted text that _looks_ like a link, but isn't
|
|
467
459
|
*/
|
|
468
|
-
|
|
469
|
-
|
|
460
|
+
const NavigationLink = _ref4 => {
|
|
461
|
+
let onClick = _ref4.onClick,
|
|
470
462
|
label = _ref4.label;
|
|
471
463
|
return jsxRuntime.jsx(Link__default["default"], {
|
|
472
|
-
onClick:
|
|
464
|
+
onClick: e => {
|
|
473
465
|
e.preventDefault();
|
|
474
|
-
|
|
466
|
+
onClick();
|
|
475
467
|
},
|
|
476
468
|
to: "",
|
|
477
469
|
children: label
|
|
@@ -483,13 +475,13 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
|
483
475
|
} : {
|
|
484
476
|
name: "4sjpj8-removeDefaultSvg",
|
|
485
477
|
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
486
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsD8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
487
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
478
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAsD8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      zIndex={1000000}\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
479
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
488
480
|
};
|
|
489
|
-
|
|
490
|
-
|
|
481
|
+
const InformationLink = _ref5 => {
|
|
482
|
+
let to = _ref5.to,
|
|
491
483
|
label = _ref5.label;
|
|
492
|
-
|
|
484
|
+
const removeDefaultSvg = _ref3;
|
|
493
485
|
return jsxRuntime.jsx("div", {
|
|
494
486
|
css: removeDefaultSvg,
|
|
495
487
|
children: jsxRuntime.jsx(Link__default["default"], {
|
|
@@ -505,13 +497,13 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
505
497
|
} : {
|
|
506
498
|
name: "4sjpj8-removeDefaultSvg",
|
|
507
499
|
styles: "& svg{display:none;};label:removeDefaultSvg;",
|
|
508
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2E8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
509
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
500
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA2E8B","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      zIndex={1000000}\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
501
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
510
502
|
};
|
|
511
|
-
|
|
512
|
-
|
|
503
|
+
const DetailLink = _ref6 => {
|
|
504
|
+
let to = _ref6.to,
|
|
513
505
|
label = _ref6.label;
|
|
514
|
-
|
|
506
|
+
const removeDefaultSvg = _ref2;
|
|
515
507
|
return jsxRuntime.jsx("div", {
|
|
516
508
|
css: removeDefaultSvg,
|
|
517
509
|
children: jsxRuntime.jsx(Link__default["default"], {
|
|
@@ -524,26 +516,26 @@ var DetailLink = function DetailLink(_ref6) {
|
|
|
524
516
|
})
|
|
525
517
|
});
|
|
526
518
|
};
|
|
527
|
-
var _ref = process.env.NODE_ENV === "production" ? {
|
|
519
|
+
var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
528
520
|
name: "qzmnd2",
|
|
529
521
|
styles: "padding-right:10px"
|
|
530
522
|
} : {
|
|
531
523
|
name: "ey0yn8-bumpToggle",
|
|
532
524
|
styles: "padding-right:10px;label:bumpToggle;",
|
|
533
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA4GwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
534
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
525
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AA4GwB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      zIndex={1000000}\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */",
|
|
526
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
535
527
|
};
|
|
536
|
-
|
|
537
|
-
|
|
528
|
+
const CookieConsentBodyPrimary = _ref7 => {
|
|
529
|
+
let toggleValue = _ref7.toggleValue,
|
|
538
530
|
onToggle = _ref7.onToggle,
|
|
539
531
|
onChangeView = _ref7.onChangeView,
|
|
540
532
|
panelState = _ref7.panelState,
|
|
541
533
|
setPanelState = _ref7.setPanelState;
|
|
542
|
-
|
|
534
|
+
const _useIntl = reactIntl.useIntl(),
|
|
543
535
|
formatMessage = _useIntl.formatMessage;
|
|
544
536
|
|
|
545
537
|
// The outline of the input is cut off; we shift it to the left to compensate
|
|
546
|
-
|
|
538
|
+
const bumpToggle = _ref$1;
|
|
547
539
|
return jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
548
540
|
scale: "xl",
|
|
549
541
|
children: [jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
@@ -564,11 +556,9 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
564
556
|
tone: "information"
|
|
565
557
|
}),
|
|
566
558
|
isClosed: panelState.essentialCookiesClosed,
|
|
567
|
-
onToggle:
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
}));
|
|
571
|
-
},
|
|
559
|
+
onToggle: () => setPanelState(_objectSpread$1(_objectSpread$1({}, panelState), {}, {
|
|
560
|
+
essentialCookiesClosed: !panelState.essentialCookiesClosed
|
|
561
|
+
})),
|
|
572
562
|
theme: "light",
|
|
573
563
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
574
564
|
scale: "m",
|
|
@@ -576,9 +566,7 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
576
566
|
intlMessage: modalMessages.necessaryCookiesDescription
|
|
577
567
|
}), jsxRuntime.jsx(NavigationLink, {
|
|
578
568
|
label: formatMessage(modalMessages.cookieInformationLink),
|
|
579
|
-
onClick:
|
|
580
|
-
return onChangeView(View.Secondary);
|
|
581
|
-
}
|
|
569
|
+
onClick: () => onChangeView(View.Secondary)
|
|
582
570
|
})]
|
|
583
571
|
})
|
|
584
572
|
}), jsxRuntime.jsx(CollapsiblePanel__default["default"], {
|
|
@@ -588,18 +576,14 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
588
576
|
css: bumpToggle,
|
|
589
577
|
children: jsxRuntime.jsx(ToggleInput__default["default"], {
|
|
590
578
|
isChecked: toggleValue,
|
|
591
|
-
onChange:
|
|
592
|
-
return onToggle(e.target.checked);
|
|
593
|
-
},
|
|
579
|
+
onChange: e => onToggle(e.target.checked),
|
|
594
580
|
size: "small"
|
|
595
581
|
})
|
|
596
582
|
}),
|
|
597
583
|
isClosed: panelState.performanceCookiesClosed,
|
|
598
|
-
onToggle:
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
}));
|
|
602
|
-
},
|
|
584
|
+
onToggle: () => setPanelState(_objectSpread$1(_objectSpread$1({}, panelState), {}, {
|
|
585
|
+
performanceCookiesClosed: !panelState.performanceCookiesClosed
|
|
586
|
+
})),
|
|
603
587
|
theme: "light",
|
|
604
588
|
children: jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
605
589
|
scale: "m",
|
|
@@ -607,129 +591,112 @@ var CookieConsentBodyPrimary = function CookieConsentBodyPrimary(_ref7) {
|
|
|
607
591
|
intlMessage: modalMessages.performanceCookiesDescription
|
|
608
592
|
}), jsxRuntime.jsx(NavigationLink, {
|
|
609
593
|
label: formatMessage(modalMessages.cookieInformationLink),
|
|
610
|
-
onClick:
|
|
611
|
-
return onChangeView(View.Tertiary);
|
|
612
|
-
}
|
|
594
|
+
onClick: () => onChangeView(View.Tertiary)
|
|
613
595
|
})]
|
|
614
596
|
})
|
|
615
597
|
})]
|
|
616
598
|
})]
|
|
617
599
|
});
|
|
618
600
|
};
|
|
619
|
-
|
|
620
|
-
|
|
601
|
+
const CookieConsentBodyDetails = _ref8 => {
|
|
602
|
+
let onChangeView = _ref8.onChangeView,
|
|
621
603
|
cookieDetails = _ref8.cookieDetails;
|
|
622
|
-
|
|
604
|
+
const _useIntl2 = reactIntl.useIntl(),
|
|
623
605
|
formatMessage = _useIntl2.formatMessage;
|
|
624
|
-
|
|
625
|
-
react.useEffect(
|
|
606
|
+
const scrollRef = /*#__PURE__*/react.createRef();
|
|
607
|
+
react.useEffect(() => {
|
|
626
608
|
var _scrollRef$current;
|
|
627
609
|
(_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 ? void 0 : _scrollRef$current.scrollIntoView();
|
|
628
610
|
}, [scrollRef]);
|
|
629
611
|
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
630
612
|
children: [jsxRuntime.jsx("div", {
|
|
631
613
|
ref: scrollRef,
|
|
632
|
-
css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAmNgB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */")
|
|
614
|
+
css: /*#__PURE__*/react$1.css("scroll-margin-top:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CookieConsentBodyDetails;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["cookie-consent-modal.tsx"],"names":[],"mappings":"AAmNgB","file":"cookie-consent-modal.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { createRef, Fragment, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useCookieConsent } from '../../react';\nimport CollapsiblePanel from '@commercetools-uikit/collapsible-panel';\nimport Grid from '@commercetools-uikit/grid';\nimport Link from '@commercetools-uikit/link';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport ToggleInput from '@commercetools-uikit/toggle-input';\nimport { ConfirmationDialog } from '@commercetools-frontend/application-components';\nimport { modalMessages } from './messages';\nimport { COOKIE_CONSENT_LINKS } from '../../../constants/links';\nimport {\n  CookieDetails,\n  createEssentialCookieDetails,\n  createPerformanceCookieDetails,\n} from './cookie-details';\nimport { designTokens } from '@commercetools-uikit/design-system';\n\nconst View = {\n  Primary: 'Primary',\n  Secondary: 'Secondary',\n  Tertiary: 'Tertiary',\n} as const;\n\ntype NavigationLinkProps = {\n  onClick: () => void;\n  label: string;\n};\n\n/**\n * The design spec warranted text that _looks_ like a link, but isn't\n */\nconst NavigationLink = ({ onClick, label }: NavigationLinkProps) => {\n  return (\n    <Link\n      onClick={(e) => {\n        e.preventDefault();\n        onClick();\n      }}\n      to=\"\"\n    >\n      {label}\n    </Link>\n  );\n};\n\ntype InformationLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst InformationLink = ({ to, label }: InformationLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        {label}\n      </Link>\n    </div>\n  );\n};\n\ntype DetailLinkProps = {\n  to: string;\n  label: string;\n};\n\nconst DetailLink = ({ to, label }: DetailLinkProps) => {\n  const removeDefaultSvg = css`\n    & svg {\n      display: none;\n    }\n  `;\n\n  return (\n    <div css={removeDefaultSvg}>\n      <Link isExternal to={to}>\n        <Text.Detail tone=\"primary\">{label}</Text.Detail>\n      </Link>\n    </div>\n  );\n};\n\ntype CookieConsentBodyPrimaryProps = {\n  toggleValue: boolean;\n  onToggle: (checked: boolean) => void;\n  onChangeView: (view: keyof typeof View) => void;\n  panelState: PanelState;\n  setPanelState: (state: PanelState) => void;\n};\n\nconst CookieConsentBodyPrimary = ({\n  toggleValue,\n  onToggle,\n  onChangeView,\n  panelState,\n  setPanelState,\n}: CookieConsentBodyPrimaryProps) => {\n  const { formatMessage } = useIntl();\n\n  // The outline of the input is cut off; we shift it to the left to compensate\n  const bumpToggle = css`\n    padding-right: 10px;\n  `;\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Text.Body intlMessage={modalMessages.mainDescription} />\n        <InformationLink\n          label={formatMessage(modalMessages.privacyPolicyLink)}\n          to={COOKIE_CONSENT_LINKS.PRIVACY_POLICY}\n        />\n      </Spacings.Stack>\n      <Spacings.Stack scale=\"l\">\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.necessaryCookiesHeader)}\n          headerControls={\n            <Text.Detail\n              intlMessage={modalMessages.necessaryCookiesHeaderState}\n              tone=\"information\"\n            />\n          }\n          isClosed={panelState.essentialCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              essentialCookiesClosed: !panelState.essentialCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.necessaryCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Secondary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n        <CollapsiblePanel\n          condensed\n          header={formatMessage(modalMessages.performanceCookiesHeader)}\n          headerControls={\n            <div css={bumpToggle}>\n              <ToggleInput\n                isChecked={toggleValue}\n                onChange={(e) => onToggle(e.target.checked)}\n                size=\"small\"\n              />\n            </div>\n          }\n          isClosed={panelState.performanceCookiesClosed}\n          onToggle={() =>\n            setPanelState({\n              ...panelState,\n              performanceCookiesClosed: !panelState.performanceCookiesClosed,\n            })\n          }\n          theme=\"light\"\n        >\n          <Spacings.Stack scale=\"m\">\n            <Text.Body\n              intlMessage={modalMessages.performanceCookiesDescription}\n            />\n            <NavigationLink\n              label={formatMessage(modalMessages.cookieInformationLink)}\n              onClick={() => onChangeView(View.Tertiary)}\n            />\n          </Spacings.Stack>\n        </CollapsiblePanel>\n      </Spacings.Stack>\n    </Spacings.Stack>\n  );\n};\n\ntype PanelState = {\n  essentialCookiesClosed: boolean;\n  performanceCookiesClosed: boolean;\n};\n\ntype CookieConsentBodyDetailsProps = {\n  onChangeView: (view: keyof typeof View) => void;\n  cookieDetails: Array<CookieDetails>;\n};\n\nconst CookieConsentBodyDetails = ({\n  onChangeView,\n  cookieDetails,\n}: CookieConsentBodyDetailsProps) => {\n  const { formatMessage } = useIntl();\n  const scrollRef = createRef<HTMLDivElement>();\n\n  useEffect(() => {\n    scrollRef.current?.scrollIntoView();\n  }, [scrollRef]);\n\n  return (\n    <>\n      <div\n        ref={scrollRef}\n        css={css`\n          scroll-margin-top: ${designTokens.spacing40};\n        `}\n      />\n      <Spacings.Stack scale=\"l\">\n        <NavigationLink\n          label={formatMessage(modalMessages.navigateBackLink)}\n          onClick={() => onChangeView(View.Primary)}\n        />\n        <Spacings.Stack scale=\"l\">\n          {cookieDetails.map((detail) => (\n            <Grid\n              key={detail.name.value}\n              gridGap={designTokens.spacing40}\n              gridRowGap=\"0px\"\n              gridTemplateColumns={`${designTokens.constraint2} 1fr`}\n            >\n              {Object.values(detail).map((value) => (\n                <Fragment key={value.value}>\n                  <Grid.Item>\n                    <Text.Detail>{value.label}</Text.Detail>\n                  </Grid.Item>\n                  <Grid.Item>\n                    {'to' in value ? (\n                      <DetailLink label={value.value} to={value.to} />\n                    ) : (\n                      <Text.Detail>{value.value}</Text.Detail>\n                    )}\n                  </Grid.Item>\n                </Fragment>\n              ))}\n            </Grid>\n          ))}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </>\n  );\n};\n\ntype ModalStateProps = {\n  isModalOpen: boolean;\n  closeModal: () => void;\n  setBannerClosed: (boolean: boolean) => void;\n};\n\nconst CookieConsentModal = (modalProps: ModalStateProps) => {\n  const intl = useIntl();\n  const { setConsent } = useCookieConsent('performanceCookies');\n  const [enablePerformanceCookies, setEnablePerformanceCookies] =\n    useState(false);\n  const [currentView, setCurrentView] = useState<keyof typeof View>(\n    View.Primary\n  );\n  const [panelState, setPanelState] = useState<PanelState>({\n    essentialCookiesClosed: true,\n    performanceCookiesClosed: true,\n  });\n\n  const createConsentGroups = (performanceConsent: boolean) => ({\n    essentialCookies: true,\n    performanceCookies: performanceConsent,\n  });\n\n  return (\n    <ConfirmationDialog\n      zIndex={1000000}\n      isOpen={modalProps.isModalOpen}\n      labelPrimary={intl.formatMessage(modalMessages.primaryButtonLabel)}\n      labelSecondary={intl.formatMessage(modalMessages.secondaryButtonLabel)}\n      onCancel={() => {\n        setConsent(createConsentGroups(enablePerformanceCookies));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      onClose={modalProps.closeModal}\n      onConfirm={() => {\n        setConsent(createConsentGroups(true));\n        modalProps.setBannerClosed(true);\n        modalProps.closeModal();\n      }}\n      title={intl.formatMessage(modalMessages.title)}\n    >\n      {currentView === View.Primary && (\n        <CookieConsentBodyPrimary\n          onChangeView={(view) => setCurrentView(view)}\n          onToggle={(value) => setEnablePerformanceCookies(value)}\n          panelState={panelState}\n          setPanelState={(state) => setPanelState(state)}\n          toggleValue={enablePerformanceCookies}\n        />\n      )}\n      {currentView === View.Secondary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createEssentialCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n      {currentView === View.Tertiary && (\n        <CookieConsentBodyDetails\n          cookieDetails={createPerformanceCookieDetails(intl)}\n          onChangeView={(view) => setCurrentView(view)}\n        />\n      )}\n    </ConfirmationDialog>\n  );\n};\n\nexport default CookieConsentModal;\n"]} */")
|
|
633
615
|
}), jsxRuntime.jsxs(Spacings__default["default"].Stack, {
|
|
634
616
|
scale: "l",
|
|
635
617
|
children: [jsxRuntime.jsx(NavigationLink, {
|
|
636
618
|
label: formatMessage(modalMessages.navigateBackLink),
|
|
637
|
-
onClick:
|
|
638
|
-
return onChangeView(View.Primary);
|
|
639
|
-
}
|
|
619
|
+
onClick: () => onChangeView(View.Primary)
|
|
640
620
|
}), jsxRuntime.jsx(Spacings__default["default"].Stack, {
|
|
641
621
|
scale: "l",
|
|
642
|
-
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails,
|
|
622
|
+
children: _mapInstanceProperty__default["default"](cookieDetails).call(cookieDetails, detail => {
|
|
643
623
|
var _context;
|
|
644
624
|
return jsxRuntime.jsx(Grid__default["default"], {
|
|
645
625
|
gridGap: designSystem.designTokens.spacing40,
|
|
646
626
|
gridRowGap: "0px",
|
|
647
627
|
gridTemplateColumns: "".concat(designSystem.designTokens.constraint2, " 1fr"),
|
|
648
|
-
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context,
|
|
649
|
-
|
|
650
|
-
children:
|
|
651
|
-
children:
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
}, value.value);
|
|
663
|
-
})
|
|
628
|
+
children: _mapInstanceProperty__default["default"](_context = _Object$values__default["default"](detail)).call(_context, value => jsxRuntime.jsxs(react.Fragment, {
|
|
629
|
+
children: [jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
630
|
+
children: jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
631
|
+
children: value.label
|
|
632
|
+
})
|
|
633
|
+
}), jsxRuntime.jsx(Grid__default["default"].Item, {
|
|
634
|
+
children: 'to' in value ? jsxRuntime.jsx(DetailLink, {
|
|
635
|
+
label: value.value,
|
|
636
|
+
to: value.to
|
|
637
|
+
}) : jsxRuntime.jsx(Text__default["default"].Detail, {
|
|
638
|
+
children: value.value
|
|
639
|
+
})
|
|
640
|
+
})]
|
|
641
|
+
}, value.value))
|
|
664
642
|
}, detail.name.value);
|
|
665
643
|
})
|
|
666
644
|
})]
|
|
667
645
|
})]
|
|
668
646
|
});
|
|
669
647
|
};
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
648
|
+
const CookieConsentModal = modalProps => {
|
|
649
|
+
const intl = reactIntl.useIntl();
|
|
650
|
+
const _useCookieConsent = useCookieConsent('performanceCookies'),
|
|
673
651
|
setConsent = _useCookieConsent.setConsent;
|
|
674
|
-
|
|
652
|
+
const _useState = react.useState(false),
|
|
675
653
|
_useState2 = _slicedToArray(_useState, 2),
|
|
676
654
|
enablePerformanceCookies = _useState2[0],
|
|
677
655
|
setEnablePerformanceCookies = _useState2[1];
|
|
678
|
-
|
|
656
|
+
const _useState3 = react.useState(View.Primary),
|
|
679
657
|
_useState4 = _slicedToArray(_useState3, 2),
|
|
680
658
|
currentView = _useState4[0],
|
|
681
659
|
setCurrentView = _useState4[1];
|
|
682
|
-
|
|
660
|
+
const _useState5 = react.useState({
|
|
683
661
|
essentialCookiesClosed: true,
|
|
684
662
|
performanceCookiesClosed: true
|
|
685
663
|
}),
|
|
686
664
|
_useState6 = _slicedToArray(_useState5, 2),
|
|
687
665
|
panelState = _useState6[0],
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
};
|
|
694
|
-
};
|
|
666
|
+
setPanelState = _useState6[1];
|
|
667
|
+
const createConsentGroups = performanceConsent => ({
|
|
668
|
+
essentialCookies: true,
|
|
669
|
+
performanceCookies: performanceConsent
|
|
670
|
+
});
|
|
695
671
|
return jsxRuntime.jsxs(applicationComponents.ConfirmationDialog, {
|
|
672
|
+
zIndex: 1000000,
|
|
696
673
|
isOpen: modalProps.isModalOpen,
|
|
697
674
|
labelPrimary: intl.formatMessage(modalMessages.primaryButtonLabel),
|
|
698
675
|
labelSecondary: intl.formatMessage(modalMessages.secondaryButtonLabel),
|
|
699
|
-
onCancel:
|
|
676
|
+
onCancel: () => {
|
|
700
677
|
setConsent(createConsentGroups(enablePerformanceCookies));
|
|
701
678
|
modalProps.setBannerClosed(true);
|
|
702
679
|
modalProps.closeModal();
|
|
703
680
|
},
|
|
704
681
|
onClose: modalProps.closeModal,
|
|
705
|
-
onConfirm:
|
|
682
|
+
onConfirm: () => {
|
|
706
683
|
setConsent(createConsentGroups(true));
|
|
707
684
|
modalProps.setBannerClosed(true);
|
|
708
685
|
modalProps.closeModal();
|
|
709
686
|
},
|
|
710
687
|
title: intl.formatMessage(modalMessages.title),
|
|
711
688
|
children: [currentView === View.Primary && jsxRuntime.jsx(CookieConsentBodyPrimary, {
|
|
712
|
-
onChangeView:
|
|
713
|
-
|
|
714
|
-
},
|
|
715
|
-
onToggle: function onToggle(value) {
|
|
716
|
-
return setEnablePerformanceCookies(value);
|
|
717
|
-
},
|
|
689
|
+
onChangeView: view => setCurrentView(view),
|
|
690
|
+
onToggle: value => setEnablePerformanceCookies(value),
|
|
718
691
|
panelState: panelState,
|
|
719
|
-
setPanelState:
|
|
720
|
-
return _setPanelState(state);
|
|
721
|
-
},
|
|
692
|
+
setPanelState: state => setPanelState(state),
|
|
722
693
|
toggleValue: enablePerformanceCookies
|
|
723
694
|
}), currentView === View.Secondary && jsxRuntime.jsx(CookieConsentBodyDetails, {
|
|
724
695
|
cookieDetails: createEssentialCookieDetails(intl),
|
|
725
|
-
onChangeView:
|
|
726
|
-
return setCurrentView(view);
|
|
727
|
-
}
|
|
696
|
+
onChangeView: view => setCurrentView(view)
|
|
728
697
|
}), currentView === View.Tertiary && jsxRuntime.jsx(CookieConsentBodyDetails, {
|
|
729
698
|
cookieDetails: createPerformanceCookieDetails(intl),
|
|
730
|
-
onChangeView:
|
|
731
|
-
return setCurrentView(view);
|
|
732
|
-
}
|
|
699
|
+
onChangeView: view => setCurrentView(view)
|
|
733
700
|
})]
|
|
734
701
|
});
|
|
735
702
|
};
|
|
@@ -759,78 +726,93 @@ var messages = reactIntl.defineMessages({
|
|
|
759
726
|
|
|
760
727
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
761
728
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
762
|
-
|
|
729
|
+
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)."; }
|
|
730
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
731
|
+
name: "1u6bcy9",
|
|
732
|
+
styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999"
|
|
733
|
+
} : {
|
|
734
|
+
name: "t2qh0u-CookieConsentBanner",
|
|
735
|
+
styles: "position:absolute;top:0;left:0;bottom:0;right:0;pointer-events:none;z-index:9999;label:CookieConsentBanner;",
|
|
736
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURjIiwiZmlsZSI6ImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHVzZUludGwsIEZvcm1hdHRlZE1lc3NhZ2UgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IGRlc2lnblRva2VucywgdXNlVGhlbWUgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCBMaW5rIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2xpbmsnO1xuaW1wb3J0IFByaW1hcnlCdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvcHJpbWFyeS1idXR0b24nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCBUZXh0IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3RleHQnO1xuaW1wb3J0IHsgdXNlTW9kYWxTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgdXNlQ29va2llQ29uc2VudCwgQ29va2llQ29uc2VudE1vZGFsIH0gZnJvbSAnLi4vLi4vcmVhY3QnO1xuaW1wb3J0IHsgQ09PS0lFX0NPTlNFTlRfTElOS1MgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvbGlua3MnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIENvbnNlbnRCYW5uZXJQcm9wcyA9IHtcbiAgc2tpcENvbnNlbnQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBDb29raWVDb25zZW50QmFubmVyID0gKGJhbm5lclByb3BzOiBDb25zZW50QmFubmVyUHJvcHMpID0+IHtcbiAgY29uc3QgeyB0aGVtZWRWYWx1ZSB9ID0gdXNlVGhlbWUoKTtcbiAgY29uc3QgYmFubmVySGVpZ2h0ID0gdGhlbWVkVmFsdWUoNTYsIDY0KTtcblxuICAvLyBIaWRlIHRoZSBiYW5uZXIgb25jZSB0aGUgYWNjZXB0IGJ1dHRvbiBpcyBjbGlja2VkLCB1bnRpbCB3ZSBjYW4gc3Vic2NyaWJlIHRvIHRoZSBjb29raWVcbiAgY29uc3QgW2Jhbm5lckNsb3NlZCwgc2V0QmFubmVyQ2xvc2VkXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgeyBjbG9zZU1vZGFsLCBvcGVuTW9kYWwsIGlzTW9kYWxPcGVuIH0gPSB1c2VNb2RhbFN0YXRlKCk7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuICBjb25zdCB7IHNldENvbnNlbnQsIGdpdmVuQ29uc2VudDogaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnQgfSA9XG4gICAgdXNlQ29va2llQ29uc2VudCgncGVyZm9ybWFuY2VDb29raWVzJywge1xuICAgICAgc2tpcENvbnNlbnQ6IGJhbm5lclByb3BzLnNraXBDb25zZW50LFxuICAgIH0pO1xuICBjb25zdCB7IGdpdmVuQ29uc2VudDogaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IH0gPSB1c2VDb29raWVDb25zZW50KFxuICAgICdlc3NlbnRpYWxDb29raWVzJyxcbiAgICB7IHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCB9XG4gICk7XG5cbiAgY29uc3QgY3JlYXRlQ29uc2VudEdyb3VwcyA9ICgpID0+ICh7XG4gICAgZXNzZW50aWFsQ29va2llczogdHJ1ZSxcbiAgICBwZXJmb3JtYW5jZUNvb2tpZXM6IHRydWUsXG4gIH0pO1xuXG4gIGlmIChcbiAgICBiYW5uZXJDbG9zZWQgfHxcbiAgICBoYXNHaXZlbkVzc2VudGlhbENvb2tpZUNvbnNlbnQgfHxcbiAgICBoYXNHaXZlblBlcmZvcm1hbmNlQ29va2llQ29uc2VudFxuICApXG4gICAgcmV0dXJuIG51bGw7XG5cbiAgcmV0dXJuIChcbiAgICAvLyBUT0RPOiB1c2UgbG93ZXIgei1pbmRleCwgcHJlZmVyIHJhbmdlcyBwZXIgdXNlLWNhc2VcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgYH1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIHBvc2l0aW9uOiBzdGlja3k7XG4gICAgICAgICAgdG9wOiBjYWxjKDEwMCUgLSAke2Jhbm5lckhlaWdodH1weCAtICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdYbH0pO1xuICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgIHotaW5kZXg6IDk5OTk7XG4gICAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgICAgcG9pbnRlci1ldmVudHM6IGF1dG87XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yQWNjZW50MTB9O1xuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNH07XG4gICAgICAgICAgICBib3gtc2hhZG93OiAke2Rlc2lnblRva2Vucy5zaGFkb3c4fTtcbiAgICAgICAgICAgIG1hcmdpbjogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9O1xuICAgICAgICAgICAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ019ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgICAgICAgICAgIHdpZHRoOiBmaXQtY29udGVudDtcbiAgICAgICAgICAgIHN2ZyB7XG4gICAgICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNjYWxlPVwieGxcIj5cbiAgICAgICAgICAgIDxUZXh0LkJvZHkgdG9uZT1cImludmVydGVkXCI+XG4gICAgICAgICAgICAgIDxGb3JtYXR0ZWRNZXNzYWdlXG4gICAgICAgICAgICAgICAgey4uLm1lc3NhZ2VzLmJhbm5lck1lc3NhZ2V9XG4gICAgICAgICAgICAgICAgdmFsdWVzPXt7XG4gICAgICAgICAgICAgICAgICBwcml2YWN5TGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5wcml2YWN5UG9saWN5TGlua31cbiAgICAgICAgICAgICAgICAgICAgICBpc0V4dGVybmFsXG4gICAgICAgICAgICAgICAgICAgICAgdG89e0NPT0tJRV9DT05TRU5UX0xJTktTLlBSSVZBQ1lfUE9MSUNZfVxuICAgICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgICAgbW9kYWxMaW5rOiAoXG4gICAgICAgICAgICAgICAgICAgIDxMaW5rXG4gICAgICAgICAgICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmJhbm5lckNvb2tpZXNNb2RhbExpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIG9wZW5Nb2RhbCgpO1xuICAgICAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICAgICAgdG89XCJcIlxuICAgICAgICAgICAgICAgICAgICAgIHRvbmU9XCJpbnZlcnRlZFwiXG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgICAgIGxhYmVsPXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHNldENvbnNlbnQoY3JlYXRlQ29uc2VudEdyb3VwcygpKTtcbiAgICAgICAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQodHJ1ZSk7XG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxDb29raWVDb25zZW50TW9kYWxcbiAgICAgICAgICBjbG9zZU1vZGFsPXtjbG9zZU1vZGFsfVxuICAgICAgICAgIGlzTW9kYWxPcGVuPXtpc01vZGFsT3Blbn1cbiAgICAgICAgICBzZXRCYW5uZXJDbG9zZWQ9e3NldEJhbm5lckNsb3NlZH1cbiAgICAgICAgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuQ29va2llQ29uc2VudEJhbm5lci5kaXNwbGF5TmFtZSA9ICdDb29raWVDb25zZW50QmFubmVyJztcblxuZXhwb3J0IHsgQ29va2llQ29uc2VudEJhbm5lciB9O1xuIl19 */",
|
|
737
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
738
|
+
};
|
|
739
|
+
const CookieConsentBanner = bannerProps => {
|
|
740
|
+
const _useTheme = designSystem.useTheme(),
|
|
741
|
+
themedValue = _useTheme.themedValue;
|
|
742
|
+
const bannerHeight = themedValue(56, 64);
|
|
743
|
+
|
|
763
744
|
// Hide the banner once the accept button is clicked, until we can subscribe to the cookie
|
|
764
|
-
|
|
745
|
+
const _useState = react.useState(false),
|
|
765
746
|
_useState2 = _slicedToArray(_useState, 2),
|
|
766
747
|
bannerClosed = _useState2[0],
|
|
767
748
|
setBannerClosed = _useState2[1];
|
|
768
|
-
|
|
749
|
+
const _useModalState = applicationComponents.useModalState(),
|
|
769
750
|
closeModal = _useModalState.closeModal,
|
|
770
751
|
openModal = _useModalState.openModal,
|
|
771
752
|
isModalOpen = _useModalState.isModalOpen;
|
|
772
|
-
|
|
753
|
+
const _useIntl = reactIntl.useIntl(),
|
|
773
754
|
formatMessage = _useIntl.formatMessage;
|
|
774
|
-
|
|
755
|
+
const _useCookieConsent = useCookieConsent('performanceCookies', {
|
|
775
756
|
skipConsent: bannerProps.skipConsent
|
|
776
757
|
}),
|
|
777
758
|
setConsent = _useCookieConsent.setConsent,
|
|
778
759
|
hasGivenPerformanceCookieConsent = _useCookieConsent.givenConsent;
|
|
779
|
-
|
|
760
|
+
const _useCookieConsent2 = useCookieConsent('essentialCookies', {
|
|
780
761
|
skipConsent: bannerProps.skipConsent
|
|
781
762
|
}),
|
|
782
763
|
hasGivenEssentialCookieConsent = _useCookieConsent2.givenConsent;
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
};
|
|
788
|
-
};
|
|
764
|
+
const createConsentGroups = () => ({
|
|
765
|
+
essentialCookies: true,
|
|
766
|
+
performanceCookies: true
|
|
767
|
+
});
|
|
789
768
|
if (bannerClosed || hasGivenEssentialCookieConsent || hasGivenPerformanceCookieConsent) return null;
|
|
790
769
|
return (
|
|
791
770
|
// TODO: use lower z-index, prefer ranges per use-case
|
|
792
|
-
jsxRuntime.
|
|
793
|
-
css:
|
|
794
|
-
children:
|
|
795
|
-
css: /*#__PURE__*/react$1.css("
|
|
796
|
-
children: jsxRuntime.
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
children: jsxRuntime.jsx(
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
830
|
-
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
771
|
+
jsxRuntime.jsx("div", {
|
|
772
|
+
css: _ref,
|
|
773
|
+
children: jsxRuntime.jsxs("div", {
|
|
774
|
+
css: /*#__PURE__*/react$1.css("position:sticky;top:calc(100% - ", bannerHeight, "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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNERnQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMsIHVzZVRoZW1lIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgTGluayBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9saW5rJztcbmltcG9ydCBQcmltYXJ5QnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3ByaW1hcnktYnV0dG9uJztcbmltcG9ydCBTcGFjaW5ncyBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zcGFjaW5ncyc7XG5pbXBvcnQgVGV4dCBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC90ZXh0JztcbmltcG9ydCB7IHVzZU1vZGFsU3RhdGUgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCB7IENPT0tJRV9DT05TRU5UX0xJTktTIH0gZnJvbSAnLi4vLi4vLi4vY29uc3RhbnRzL2xpbmtzJztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdGhlbWVkVmFsdWUgfSA9IHVzZVRoZW1lKCk7XG4gIGNvbnN0IGJhbm5lckhlaWdodCA9IHRoZW1lZFZhbHVlKDU2LCA2NCk7XG5cbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRXNzZW50aWFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZXNzZW50aWFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGVzc2VudGlhbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtiYW5uZXJIZWlnaHR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
|
|
775
|
+
children: [jsxRuntime.jsx("div", {
|
|
776
|
+
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvb2tpZS1jb25zZW50LWJhbm5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0VrQiIsImZpbGUiOiJjb29raWUtY29uc2VudC1iYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB1c2VJbnRsLCBGb3JtYXR0ZWRNZXNzYWdlIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMsIHVzZVRoZW1lIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgTGluayBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9saW5rJztcbmltcG9ydCBQcmltYXJ5QnV0dG9uIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3ByaW1hcnktYnV0dG9uJztcbmltcG9ydCBTcGFjaW5ncyBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zcGFjaW5ncyc7XG5pbXBvcnQgVGV4dCBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC90ZXh0JztcbmltcG9ydCB7IHVzZU1vZGFsU3RhdGUgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IHVzZUNvb2tpZUNvbnNlbnQsIENvb2tpZUNvbnNlbnRNb2RhbCB9IGZyb20gJy4uLy4uL3JlYWN0JztcbmltcG9ydCB7IENPT0tJRV9DT05TRU5UX0xJTktTIH0gZnJvbSAnLi4vLi4vLi4vY29uc3RhbnRzL2xpbmtzJztcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuL21lc3NhZ2VzJztcblxudHlwZSBDb25zZW50QmFubmVyUHJvcHMgPSB7XG4gIHNraXBDb25zZW50OiBib29sZWFuO1xufTtcblxuY29uc3QgQ29va2llQ29uc2VudEJhbm5lciA9IChiYW5uZXJQcm9wczogQ29uc2VudEJhbm5lclByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdGhlbWVkVmFsdWUgfSA9IHVzZVRoZW1lKCk7XG4gIGNvbnN0IGJhbm5lckhlaWdodCA9IHRoZW1lZFZhbHVlKDU2LCA2NCk7XG5cbiAgLy8gSGlkZSB0aGUgYmFubmVyIG9uY2UgdGhlIGFjY2VwdCBidXR0b24gaXMgY2xpY2tlZCwgdW50aWwgd2UgY2FuIHN1YnNjcmliZSB0byB0aGUgY29va2llXG4gIGNvbnN0IFtiYW5uZXJDbG9zZWQsIHNldEJhbm5lckNsb3NlZF0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHsgY2xvc2VNb2RhbCwgb3Blbk1vZGFsLCBpc01vZGFsT3BlbiB9ID0gdXNlTW9kYWxTdGF0ZSgpO1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBzZXRDb25zZW50LCBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuUGVyZm9ybWFuY2VDb29raWVDb25zZW50IH0gPVxuICAgIHVzZUNvb2tpZUNvbnNlbnQoJ3BlcmZvcm1hbmNlQ29va2llcycsIHtcbiAgICAgIHNraXBDb25zZW50OiBiYW5uZXJQcm9wcy5za2lwQ29uc2VudCxcbiAgICB9KTtcbiAgY29uc3QgeyBnaXZlbkNvbnNlbnQ6IGhhc0dpdmVuRXNzZW50aWFsQ29va2llQ29uc2VudCB9ID0gdXNlQ29va2llQ29uc2VudChcbiAgICAnZXNzZW50aWFsQ29va2llcycsXG4gICAgeyBza2lwQ29uc2VudDogYmFubmVyUHJvcHMuc2tpcENvbnNlbnQgfVxuICApO1xuXG4gIGNvbnN0IGNyZWF0ZUNvbnNlbnRHcm91cHMgPSAoKSA9PiAoe1xuICAgIGVzc2VudGlhbENvb2tpZXM6IHRydWUsXG4gICAgcGVyZm9ybWFuY2VDb29raWVzOiB0cnVlLFxuICB9KTtcblxuICBpZiAoXG4gICAgYmFubmVyQ2xvc2VkIHx8XG4gICAgaGFzR2l2ZW5Fc3NlbnRpYWxDb29raWVDb25zZW50IHx8XG4gICAgaGFzR2l2ZW5QZXJmb3JtYW5jZUNvb2tpZUNvbnNlbnRcbiAgKVxuICAgIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgLy8gVE9ETzogdXNlIGxvd2VyIHotaW5kZXgsIHByZWZlciByYW5nZXMgcGVyIHVzZS1jYXNlXG4gICAgPGRpdlxuICAgICAgY3NzPXtjc3NgXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICAgICAgdG9wOiAwO1xuICAgICAgICBsZWZ0OiAwO1xuICAgICAgICBib3R0b206IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgICAgei1pbmRleDogOTk5OTtcbiAgICAgIGB9XG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBwb3NpdGlvbjogc3RpY2t5O1xuICAgICAgICAgIHRvcDogY2FsYygxMDAlIC0gJHtiYW5uZXJIZWlnaHR9cHggLSAke2Rlc2lnblRva2Vucy5zcGFjaW5nWGx9KTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICB6LWluZGV4OiA5OTk5O1xuICAgICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICAgIHBvaW50ZXItZXZlbnRzOiBhdXRvO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvckFjY2VudDEwfTtcbiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9O1xuICAgICAgICAgICAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93OH07XG4gICAgICAgICAgICBtYXJnaW46IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ1hsfTtcbiAgICAgICAgICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdNfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nTH07XG4gICAgICAgICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIGB9XG4gICAgICAgID5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIGFsaWduSXRlbXM9XCJjZW50ZXJcIiBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgICA8VGV4dC5Cb2R5IHRvbmU9XCJpbnZlcnRlZFwiPlxuICAgICAgICAgICAgICA8Rm9ybWF0dGVkTWVzc2FnZVxuICAgICAgICAgICAgICAgIHsuLi5tZXNzYWdlcy5iYW5uZXJNZXNzYWdlfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17e1xuICAgICAgICAgICAgICAgICAgcHJpdmFjeUxpbms6IChcbiAgICAgICAgICAgICAgICAgICAgPExpbmtcbiAgICAgICAgICAgICAgICAgICAgICBpbnRsTWVzc2FnZT17bWVzc2FnZXMucHJpdmFjeVBvbGljeUxpbmt9XG4gICAgICAgICAgICAgICAgICAgICAgaXNFeHRlcm5hbFxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtDT09LSUVfQ09OU0VOVF9MSU5LUy5QUklWQUNZX1BPTElDWX1cbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgIG1vZGFsTGluazogKFxuICAgICAgICAgICAgICAgICAgICA8TGlua1xuICAgICAgICAgICAgICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy5iYW5uZXJDb29raWVzTW9kYWxMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgICAgICAgICAgICAgICBvcGVuTW9kYWwoKTtcbiAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgIHRvPVwiXCJcbiAgICAgICAgICAgICAgICAgICAgICB0b25lPVwiaW52ZXJ0ZWRcIlxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9UZXh0LkJvZHk+XG4gICAgICAgICAgICA8UHJpbWFyeUJ1dHRvblxuICAgICAgICAgICAgICBsYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5idXR0b25MYWJlbCl9XG4gICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRDb25zZW50KGNyZWF0ZUNvbnNlbnRHcm91cHMoKSk7XG4gICAgICAgICAgICAgICAgc2V0QmFubmVyQ2xvc2VkKHRydWUpO1xuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBzaXplPVwibWVkaXVtXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8Q29va2llQ29uc2VudE1vZGFsXG4gICAgICAgICAgY2xvc2VNb2RhbD17Y2xvc2VNb2RhbH1cbiAgICAgICAgICBpc01vZGFsT3Blbj17aXNNb2RhbE9wZW59XG4gICAgICAgICAgc2V0QmFubmVyQ2xvc2VkPXtzZXRCYW5uZXJDbG9zZWR9XG4gICAgICAgIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbkNvb2tpZUNvbnNlbnRCYW5uZXIuZGlzcGxheU5hbWUgPSAnQ29va2llQ29uc2VudEJhbm5lcic7XG5cbmV4cG9ydCB7IENvb2tpZUNvbnNlbnRCYW5uZXIgfTtcbiJdfQ== */"),
|
|
777
|
+
children: jsxRuntime.jsxs(Spacings__default["default"].Inline, {
|
|
778
|
+
alignItems: "center",
|
|
779
|
+
scale: "xl",
|
|
780
|
+
children: [jsxRuntime.jsx(Text__default["default"].Body, {
|
|
781
|
+
tone: "inverted",
|
|
782
|
+
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread(_objectSpread({}, messages.bannerMessage), {}, {
|
|
783
|
+
values: {
|
|
784
|
+
privacyLink: jsxRuntime.jsx(Link__default["default"], {
|
|
785
|
+
intlMessage: messages.privacyPolicyLink,
|
|
786
|
+
isExternal: true,
|
|
787
|
+
to: COOKIE_CONSENT_LINKS.PRIVACY_POLICY,
|
|
788
|
+
tone: "inverted"
|
|
789
|
+
}),
|
|
790
|
+
modalLink: jsxRuntime.jsx(Link__default["default"], {
|
|
791
|
+
intlMessage: messages.bannerCookiesModalLink,
|
|
792
|
+
onClick: e => {
|
|
793
|
+
e.preventDefault();
|
|
794
|
+
openModal();
|
|
795
|
+
},
|
|
796
|
+
to: "",
|
|
797
|
+
tone: "inverted"
|
|
798
|
+
})
|
|
799
|
+
}
|
|
800
|
+
}))
|
|
801
|
+
}), jsxRuntime.jsx(PrimaryButton__default["default"], {
|
|
802
|
+
label: formatMessage(messages.buttonLabel),
|
|
803
|
+
onClick: () => {
|
|
804
|
+
setConsent(createConsentGroups());
|
|
805
|
+
setBannerClosed(true);
|
|
806
|
+
},
|
|
807
|
+
size: "medium"
|
|
808
|
+
})]
|
|
809
|
+
})
|
|
810
|
+
}), jsxRuntime.jsx(CookieConsentModal, {
|
|
811
|
+
closeModal: closeModal,
|
|
812
|
+
isModalOpen: isModalOpen,
|
|
813
|
+
setBannerClosed: setBannerClosed
|
|
814
|
+
})]
|
|
815
|
+
})
|
|
834
816
|
})
|
|
835
817
|
);
|
|
836
818
|
};
|