@commercetools-frontend-extensions/export-resources-modal 4.2.1 → 4.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +10 -1
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.dev.js +583 -254
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.prod.js +547 -236
- package/dist/commercetools-frontend-extensions-export-resources-modal.esm.js +580 -252
- package/dist/declarations/src/@constants/misc.d.ts +1 -0
- package/dist/declarations/src/@types/export-resources-modal-shape.d.ts +5 -0
- package/dist/declarations/src/@types/formik.d.ts +10 -0
- package/package.json +7 -7
|
@@ -16,19 +16,19 @@ var applicationShellConnectors = require('@commercetools-frontend/application-sh
|
|
|
16
16
|
var uiKit = require('@commercetools-frontend/ui-kit');
|
|
17
17
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
18
18
|
var _valuesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/values');
|
|
19
|
+
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
19
20
|
var applicationComponents = require('@commercetools-frontend/application-components');
|
|
20
21
|
var React = require('react');
|
|
21
22
|
var _Reflect$construct = require('@babel/runtime-corejs3/core-js-stable/reflect/construct');
|
|
22
23
|
var _createClass = require('@babel/runtime-corejs3/helpers/createClass');
|
|
23
24
|
var _classCallCheck = require('@babel/runtime-corejs3/helpers/classCallCheck');
|
|
25
|
+
var _inherits = require('@babel/runtime-corejs3/helpers/inherits');
|
|
24
26
|
var _possibleConstructorReturn = require('@babel/runtime-corejs3/helpers/possibleConstructorReturn');
|
|
25
27
|
var _getPrototypeOf = require('@babel/runtime-corejs3/helpers/getPrototypeOf');
|
|
26
|
-
var _inherits = require('@babel/runtime-corejs3/helpers/inherits');
|
|
27
28
|
var _wrapNativeSuper = require('@babel/runtime-corejs3/helpers/wrapNativeSuper');
|
|
28
29
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
29
|
-
var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
|
|
30
30
|
var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
31
|
-
var
|
|
31
|
+
var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
|
|
32
32
|
var omitEmpty = require('omit-empty-es');
|
|
33
33
|
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
34
34
|
var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
|
|
@@ -36,19 +36,20 @@ var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
|
|
|
36
36
|
var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
|
|
37
37
|
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
38
38
|
var moment = require('moment');
|
|
39
|
+
var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
40
|
+
var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
|
|
39
41
|
var experimentalComponents = require('@commercetools-frontend/experimental-components');
|
|
40
42
|
var sdk = require('@commercetools-frontend/sdk');
|
|
41
43
|
var actionsGlobal = require('@commercetools-frontend/actions-global');
|
|
42
44
|
var constants = require('@commercetools-frontend/constants');
|
|
43
45
|
var _styled = require('@emotion/styled/base');
|
|
44
|
-
var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
|
|
45
46
|
var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
|
|
46
|
-
var
|
|
47
|
+
var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
|
|
47
48
|
var throttle = require('lodash/throttle');
|
|
48
|
-
var react = require('@emotion/react');
|
|
49
|
-
var get = require('lodash/get');
|
|
50
49
|
var PropTypes = require('prop-types');
|
|
51
50
|
var formik = require('formik');
|
|
51
|
+
var react = require('@emotion/react');
|
|
52
|
+
var get = require('lodash/get');
|
|
52
53
|
var sentry = require('@commercetools-frontend/sentry');
|
|
53
54
|
var i18n = require('@commercetools-frontend/i18n');
|
|
54
55
|
|
|
@@ -63,11 +64,11 @@ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_O
|
|
|
63
64
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
64
65
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
65
66
|
var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
|
|
67
|
+
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
66
68
|
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
67
69
|
var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
|
|
68
|
-
var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
|
|
69
70
|
var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
|
|
70
|
-
var
|
|
71
|
+
var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
|
|
71
72
|
var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
|
|
72
73
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
73
74
|
var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
|
|
@@ -75,13 +76,14 @@ var _Set__default = /*#__PURE__*/_interopDefault(_Set);
|
|
|
75
76
|
var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
|
|
76
77
|
var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
|
|
77
78
|
var moment__default = /*#__PURE__*/_interopDefault(moment);
|
|
78
|
-
var
|
|
79
|
+
var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
|
|
79
80
|
var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
|
|
81
|
+
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
80
82
|
var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
|
|
81
|
-
var
|
|
83
|
+
var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
|
|
82
84
|
var throttle__default = /*#__PURE__*/_interopDefault(throttle);
|
|
83
|
-
var get__default = /*#__PURE__*/_interopDefault(get);
|
|
84
85
|
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
86
|
+
var get__default = /*#__PURE__*/_interopDefault(get);
|
|
85
87
|
|
|
86
88
|
function getBold(msg) {
|
|
87
89
|
return jsxRuntime.jsx(uiKit.Text.Body, {
|
|
@@ -269,17 +271,22 @@ var messages = reactIntl.defineMessages({
|
|
|
269
271
|
id: 'ExportResourcesModal.exportSettings',
|
|
270
272
|
description: 'Label for Export Settings',
|
|
271
273
|
defaultMessage: 'Settings'
|
|
274
|
+
},
|
|
275
|
+
selected: {
|
|
276
|
+
id: 'ExportResourcesModal.selected',
|
|
277
|
+
description: 'Label for total Selected',
|
|
278
|
+
defaultMessage: '{total} selected'
|
|
272
279
|
}
|
|
273
280
|
});
|
|
274
281
|
|
|
275
|
-
function ownKeys$
|
|
276
|
-
function _objectSpread$
|
|
282
|
+
function ownKeys$7(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
283
|
+
function _objectSpread$7(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$7(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$7(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
277
284
|
function renderFileNameError(key) {
|
|
278
285
|
switch (key) {
|
|
279
286
|
case 'missing':
|
|
280
|
-
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$
|
|
287
|
+
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$7({}, messages.missingFileNameError));
|
|
281
288
|
case 'invalidInput':
|
|
282
|
-
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$
|
|
289
|
+
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$7({}, messages.invalidFileNameError));
|
|
283
290
|
default:
|
|
284
291
|
return null;
|
|
285
292
|
}
|
|
@@ -287,65 +294,69 @@ function renderFileNameError(key) {
|
|
|
287
294
|
function renderLocaleError(key) {
|
|
288
295
|
switch (key) {
|
|
289
296
|
case 'missing':
|
|
290
|
-
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$
|
|
297
|
+
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$7({}, messages.missingLocaleError));
|
|
291
298
|
default:
|
|
292
299
|
return null;
|
|
293
300
|
}
|
|
294
301
|
}
|
|
295
302
|
|
|
296
|
-
function
|
|
303
|
+
function _createSuper$3(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$3(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
297
304
|
function _isNativeReflectConstruct$3() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$3 = function () { return !!t; })(); }
|
|
298
305
|
let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
|
|
306
|
+
_inherits(MissingExportResourceProviderError, _Error);
|
|
307
|
+
var _super = _createSuper$3(MissingExportResourceProviderError);
|
|
299
308
|
function MissingExportResourceProviderError() {
|
|
300
309
|
var _this;
|
|
301
310
|
_classCallCheck(this, MissingExportResourceProviderError);
|
|
302
|
-
_this =
|
|
311
|
+
_this = _super.call(this, 'useExportResourcesContext must be used within ExportResourcesProvider');
|
|
303
312
|
_this.name = 'MissingExportResourceProviderError';
|
|
304
313
|
return _this;
|
|
305
314
|
}
|
|
306
|
-
_inherits(MissingExportResourceProviderError, _Error);
|
|
307
315
|
return _createClass(MissingExportResourceProviderError);
|
|
308
316
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
309
317
|
|
|
310
|
-
function
|
|
318
|
+
function _createSuper$2(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$2(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
311
319
|
function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
|
|
312
320
|
let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
|
|
321
|
+
_inherits(UnexpectedExportOperationStateError, _Error);
|
|
322
|
+
var _super = _createSuper$2(UnexpectedExportOperationStateError);
|
|
313
323
|
function UnexpectedExportOperationStateError(state) {
|
|
314
324
|
var _this;
|
|
315
325
|
_classCallCheck(this, UnexpectedExportOperationStateError);
|
|
316
|
-
_this =
|
|
326
|
+
_this = _super.call(this, "Unexpected export operation state \"".concat(state, "\""));
|
|
317
327
|
_this.name = 'UnexpectedExportOperationStateError';
|
|
318
328
|
return _this;
|
|
319
329
|
}
|
|
320
|
-
_inherits(UnexpectedExportOperationStateError, _Error);
|
|
321
330
|
return _createClass(UnexpectedExportOperationStateError);
|
|
322
331
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
323
332
|
|
|
324
|
-
function
|
|
333
|
+
function _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
325
334
|
function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
|
|
326
335
|
let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
|
|
336
|
+
_inherits(UnexpectedResourceTypeError, _Error);
|
|
337
|
+
var _super = _createSuper$1(UnexpectedResourceTypeError);
|
|
327
338
|
function UnexpectedResourceTypeError(resourceType) {
|
|
328
339
|
var _this;
|
|
329
340
|
_classCallCheck(this, UnexpectedResourceTypeError);
|
|
330
|
-
_this =
|
|
341
|
+
_this = _super.call(this, "Unexpected resource type \"".concat(resourceType, "\""));
|
|
331
342
|
_this.name = 'UnexpectedResourceTypeError';
|
|
332
343
|
return _this;
|
|
333
344
|
}
|
|
334
|
-
_inherits(UnexpectedResourceTypeError, _Error);
|
|
335
345
|
return _createClass(UnexpectedResourceTypeError);
|
|
336
346
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
337
347
|
|
|
338
|
-
function
|
|
348
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
339
349
|
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
|
|
340
350
|
let InvalidResponseError = /*#__PURE__*/function (_Error) {
|
|
351
|
+
_inherits(InvalidResponseError, _Error);
|
|
352
|
+
var _super = _createSuper(InvalidResponseError);
|
|
341
353
|
function InvalidResponseError(message) {
|
|
342
354
|
var _this;
|
|
343
355
|
_classCallCheck(this, InvalidResponseError);
|
|
344
|
-
_this =
|
|
356
|
+
_this = _super.call(this, message);
|
|
345
357
|
_this.name = 'InvalidResponseError';
|
|
346
358
|
return _this;
|
|
347
359
|
}
|
|
348
|
-
_inherits(InvalidResponseError, _Error);
|
|
349
360
|
return _createClass(InvalidResponseError);
|
|
350
361
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
351
362
|
|
|
@@ -357,10 +368,10 @@ function useExportResourcesContext() {
|
|
|
357
368
|
return context;
|
|
358
369
|
}
|
|
359
370
|
|
|
360
|
-
function checkAtLeastOneFieldChecked
|
|
361
|
-
return _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
371
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
372
|
+
return fields === null || fields === void 0 ? void 0 : _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
362
373
|
if (field.fields) {
|
|
363
|
-
return field.isChecked || checkAtLeastOneFieldChecked
|
|
374
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
364
375
|
}
|
|
365
376
|
return field.isChecked;
|
|
366
377
|
});
|
|
@@ -390,7 +401,7 @@ function validate(_ref) {
|
|
|
390
401
|
if (step === 2) {
|
|
391
402
|
const allFields = _reduceInstanceProperty__default["default"](groups).call(groups, (acc, group) => _concatInstanceProperty__default["default"](acc).call(acc, group.fields), []);
|
|
392
403
|
const checkedFieldsCount = _filterInstanceProperty__default["default"](allFields).call(allFields, field => {
|
|
393
|
-
if (field.fields) return checkAtLeastOneFieldChecked
|
|
404
|
+
if (field.fields) return checkAtLeastOneFieldChecked(field.fields);
|
|
394
405
|
return !field.isRequired && !field.isReadOnly && field.isChecked;
|
|
395
406
|
}).length;
|
|
396
407
|
if (checkedFieldsCount < 1) {
|
|
@@ -403,6 +414,7 @@ function validate(_ref) {
|
|
|
403
414
|
|
|
404
415
|
const Z_INDEX_DROPDOWN = 30000;
|
|
405
416
|
const OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION = 'OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION';
|
|
417
|
+
const OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP = 'OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP';
|
|
406
418
|
|
|
407
419
|
const EXPORT_OPERATION_STATES = {
|
|
408
420
|
PROCESSING: 'processing',
|
|
@@ -436,12 +448,6 @@ const OUTPUT_FORMAT_OPTIONS = [{
|
|
|
436
448
|
label: 'JSON'
|
|
437
449
|
}];
|
|
438
450
|
|
|
439
|
-
const FIELD_DEFINITIONS_URLS = {
|
|
440
|
-
category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values',
|
|
441
|
-
product: 'https://docs.commercetools.com/merchant-center/import-products#supported-headers-and-values',
|
|
442
|
-
'inventory-entry': 'https://docs.commercetools.com/merchant-center/import-inventory#supported-headers-and-values'
|
|
443
|
-
};
|
|
444
|
-
|
|
445
451
|
const resourceTypeMessages = {
|
|
446
452
|
category: {
|
|
447
453
|
exportScopeAll: messages.exportScopeAllCategories,
|
|
@@ -458,6 +464,7 @@ const resourceTypeMessages = {
|
|
|
458
464
|
};
|
|
459
465
|
|
|
460
466
|
function resourceTypeToFileName(_ref) {
|
|
467
|
+
var _context;
|
|
461
468
|
let resourceType = _ref.resourceType,
|
|
462
469
|
_ref$isUpperCase = _ref.isUpperCase,
|
|
463
470
|
isUpperCase = _ref$isUpperCase === void 0 ? false : _ref$isUpperCase,
|
|
@@ -482,7 +489,7 @@ function resourceTypeToFileName(_ref) {
|
|
|
482
489
|
throw new UnexpectedResourceTypeError(resourceType);
|
|
483
490
|
}
|
|
484
491
|
const result = isUpperCase ? displayName : displayName.toLowerCase();
|
|
485
|
-
return
|
|
492
|
+
return _concatInstanceProperty__default["default"](_context = "".concat(result, "_Export_")).call(_context, todayFormatted);
|
|
486
493
|
}
|
|
487
494
|
function mapLocalesToOptions(locales) {
|
|
488
495
|
return _mapInstanceProperty__default["default"](locales).call(locales, locale => ({
|
|
@@ -494,13 +501,14 @@ function isFilledArray(maybeArray) {
|
|
|
494
501
|
return _Array$isArray__default["default"](maybeArray) && maybeArray.length;
|
|
495
502
|
}
|
|
496
503
|
function appendCsvOrJsonExtensionIfAbsent(fileName, fileFormat) {
|
|
504
|
+
var _context2;
|
|
497
505
|
const extensionRegex = /\.(csv|json)$/i;
|
|
498
|
-
if (!extensionRegex.test(fileName)) return
|
|
506
|
+
if (!extensionRegex.test(fileName)) return _concatInstanceProperty__default["default"](_context2 = "".concat(fileName, ".")).call(_context2, fileFormat);
|
|
499
507
|
return fileName;
|
|
500
508
|
}
|
|
501
509
|
function getExportLogsLink(projectKey, msg) {
|
|
502
510
|
return jsxRuntime.jsx(uiKit.Link, {
|
|
503
|
-
to:
|
|
511
|
+
to: "/".concat(projectKey, "/operations/export/logs"),
|
|
504
512
|
children: msg
|
|
505
513
|
});
|
|
506
514
|
}
|
|
@@ -535,13 +543,13 @@ function sortFieldsByFieldOrder(_ref2) {
|
|
|
535
543
|
// Later, filters will be passed directly from parent views (category, product...) instead of being built within the Export resources modal
|
|
536
544
|
// The `selectedResourceIds` prop will also be removed
|
|
537
545
|
function tmpBuildFilters(selectedResourceIds) {
|
|
538
|
-
if (!selectedResourceIds || selectedResourceIds
|
|
539
|
-
const formattedIds = _mapInstanceProperty__default["default"](selectedResourceIds).call(selectedResourceIds, id =>
|
|
540
|
-
return [
|
|
546
|
+
if (!selectedResourceIds || (selectedResourceIds === null || selectedResourceIds === void 0 ? void 0 : selectedResourceIds.length) === 0) return undefined;
|
|
547
|
+
const formattedIds = _mapInstanceProperty__default["default"](selectedResourceIds).call(selectedResourceIds, id => "\"".concat(id, "\"")).join(', ');
|
|
548
|
+
return ["id in (".concat(formattedIds, ")")];
|
|
541
549
|
}
|
|
542
550
|
|
|
543
|
-
function ownKeys$
|
|
544
|
-
function _objectSpread$
|
|
551
|
+
function ownKeys$6(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
552
|
+
function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var _context5, _context6; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context5 = ownKeys$6(Object(t), !0)).call(_context5, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context6 = ownKeys$6(Object(t))).call(_context6, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
545
553
|
const updateFieldGroupsWithIsCheckedValue = (groups, cachedSelectedGroups) => {
|
|
546
554
|
const updateFields = (fields, parentChecked, fieldName) => {
|
|
547
555
|
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
@@ -549,8 +557,10 @@ const updateFieldGroupsWithIsCheckedValue = (groups, cachedSelectedGroups) => {
|
|
|
549
557
|
if (field.isRequired) {
|
|
550
558
|
isChecked = true;
|
|
551
559
|
} else {
|
|
552
|
-
|
|
553
|
-
|
|
560
|
+
var _context;
|
|
561
|
+
if (cachedSelectedGroups[_concatInstanceProperty__default["default"](_context = "".concat(fieldName, ".")).call(_context, field.name)] !== undefined) {
|
|
562
|
+
var _context2;
|
|
563
|
+
isChecked = cachedSelectedGroups[_concatInstanceProperty__default["default"](_context2 = "".concat(fieldName, ".")).call(_context2, field.name)];
|
|
554
564
|
} else if (!field.isReadOnly && field.isSelectedByDefault) {
|
|
555
565
|
isChecked = true;
|
|
556
566
|
} else if (parentChecked) {
|
|
@@ -558,18 +568,19 @@ const updateFieldGroupsWithIsCheckedValue = (groups, cachedSelectedGroups) => {
|
|
|
558
568
|
}
|
|
559
569
|
}
|
|
560
570
|
if (field.fields) {
|
|
561
|
-
|
|
571
|
+
var _context3;
|
|
572
|
+
const updatedFields = updateFields(field.fields, isChecked, _concatInstanceProperty__default["default"](_context3 = "".concat(fieldName, ".")).call(_context3, field.name));
|
|
562
573
|
isChecked = false;
|
|
563
574
|
field.fields = updatedFields;
|
|
564
575
|
}
|
|
565
|
-
return _objectSpread$
|
|
576
|
+
return _objectSpread$6(_objectSpread$6({}, field), {}, {
|
|
566
577
|
isChecked
|
|
567
578
|
});
|
|
568
579
|
});
|
|
569
580
|
};
|
|
570
581
|
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
571
582
|
const updatedFields = updateFields(group.fields, false, group.groupLabel);
|
|
572
|
-
return _objectSpread$
|
|
583
|
+
return _objectSpread$6(_objectSpread$6({}, group), {}, {
|
|
573
584
|
fields: updatedFields
|
|
574
585
|
});
|
|
575
586
|
});
|
|
@@ -581,43 +592,121 @@ const updateFieldGroupWithAdditionalFieldExtensions = groups => {
|
|
|
581
592
|
if (field.fields) {
|
|
582
593
|
field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
|
|
583
594
|
}
|
|
584
|
-
return _objectSpread$
|
|
595
|
+
return _objectSpread$6(_objectSpread$6({}, field), {}, {
|
|
585
596
|
additionalFieldExtensions: updatedAdditionalFieldExtensions
|
|
586
597
|
});
|
|
587
598
|
});
|
|
588
599
|
}
|
|
600
|
+
function combineDependentGroupNames(fields) {
|
|
601
|
+
return _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
|
|
602
|
+
if (field.dependentGroupNames) {
|
|
603
|
+
acc = [...acc, ...field.dependentGroupNames];
|
|
604
|
+
}
|
|
605
|
+
if (field.fields) {
|
|
606
|
+
acc = [...acc, ...combineDependentGroupNames(field.fields)];
|
|
607
|
+
}
|
|
608
|
+
return acc;
|
|
609
|
+
}, []);
|
|
610
|
+
}
|
|
589
611
|
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
590
|
-
return _objectSpread$
|
|
612
|
+
return _objectSpread$6(_objectSpread$6({}, group), {}, {
|
|
613
|
+
dependentGroupNames: combineDependentGroupNames(group.fields),
|
|
591
614
|
fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
|
|
592
615
|
});
|
|
593
616
|
});
|
|
594
617
|
};
|
|
618
|
+
const updateFieldGroupsWithIsExpandedValue = (groups, cachedExpandedGroups) => {
|
|
619
|
+
function updateFields(fields, groupName) {
|
|
620
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
621
|
+
let isExpanded = null;
|
|
622
|
+
if (field.isExpandable) {
|
|
623
|
+
var _ref, _cachedExpandedGroups, _context4;
|
|
624
|
+
isExpanded = (_ref = (_cachedExpandedGroups = cachedExpandedGroups[_concatInstanceProperty__default["default"](_context4 = "".concat(groupName, ".")).call(_context4, field.name)]) !== null && _cachedExpandedGroups !== void 0 ? _cachedExpandedGroups : field.isExpanded) !== null && _ref !== void 0 ? _ref : false;
|
|
625
|
+
}
|
|
626
|
+
if (field.fields) {
|
|
627
|
+
field.fields = updateFields(field.fields, groupName);
|
|
628
|
+
}
|
|
629
|
+
if (isExpanded !== null) {
|
|
630
|
+
return _objectSpread$6(_objectSpread$6({}, field), {}, {
|
|
631
|
+
isExpanded
|
|
632
|
+
});
|
|
633
|
+
}
|
|
634
|
+
return field;
|
|
635
|
+
});
|
|
636
|
+
}
|
|
637
|
+
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
638
|
+
var _ref2, _cachedExpandedGroups2;
|
|
639
|
+
const updatedFields = updateFields(group.fields, group.groupName);
|
|
640
|
+
return _objectSpread$6(_objectSpread$6({}, group), {}, {
|
|
641
|
+
isExpanded: (_ref2 = (_cachedExpandedGroups2 = cachedExpandedGroups[group.groupName]) !== null && _cachedExpandedGroups2 !== void 0 ? _cachedExpandedGroups2 : group.isExpanded) !== null && _ref2 !== void 0 ? _ref2 : false,
|
|
642
|
+
fields: updatedFields
|
|
643
|
+
});
|
|
644
|
+
});
|
|
645
|
+
};
|
|
646
|
+
|
|
647
|
+
const isRequiredGroupChecked = function () {
|
|
648
|
+
let dependentGroupNames = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
649
|
+
let formik = arguments.length > 1 ? arguments[1] : undefined;
|
|
650
|
+
let result = false;
|
|
651
|
+
if (dependentGroupNames !== null && dependentGroupNames !== void 0 && dependentGroupNames.length) {
|
|
652
|
+
_someInstanceProperty__default["default"](dependentGroupNames).call(dependentGroupNames, dependentGroupName => {
|
|
653
|
+
var _context;
|
|
654
|
+
const dependentGroup = _findInstanceProperty__default["default"](_context = _valuesInstanceProperty__default["default"](formik).groups).call(_context, group => group.groupName === dependentGroupName);
|
|
655
|
+
if (dependentGroup) {
|
|
656
|
+
result = checkAtLeastOneFieldChecked(dependentGroup.fields);
|
|
657
|
+
}
|
|
658
|
+
return result;
|
|
659
|
+
});
|
|
660
|
+
}
|
|
661
|
+
return result;
|
|
662
|
+
};
|
|
663
|
+
const checkAllFieldsSelected = fields => {
|
|
664
|
+
return _everyInstanceProperty__default["default"](fields).call(fields, field => {
|
|
665
|
+
if (field.fields) {
|
|
666
|
+
return checkAllFieldsSelected(field.fields);
|
|
667
|
+
}
|
|
668
|
+
return field.isChecked || field.isRequired || field.isReadOnly;
|
|
669
|
+
});
|
|
670
|
+
};
|
|
595
671
|
|
|
596
672
|
const useInitialValues = props => {
|
|
673
|
+
var _context, _context2, _context3;
|
|
597
674
|
const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
|
|
598
675
|
locale: applicationContext.dataLocale
|
|
599
676
|
})),
|
|
600
677
|
locale = _useApplicationContex.locale;
|
|
601
|
-
const _useApplicationContex2 = applicationShellConnectors.useApplicationContext(context =>
|
|
602
|
-
|
|
603
|
-
|
|
678
|
+
const _useApplicationContex2 = applicationShellConnectors.useApplicationContext(context => {
|
|
679
|
+
var _context$project;
|
|
680
|
+
return {
|
|
681
|
+
projectKey: (_context$project = context.project) === null || _context$project === void 0 ? void 0 : _context$project.key
|
|
682
|
+
};
|
|
683
|
+
}),
|
|
604
684
|
projectKey = _useApplicationContex2.projectKey;
|
|
605
|
-
const _useStorage = experimentalComponents.useStorage(
|
|
685
|
+
const _useStorage = experimentalComponents.useStorage(_concatInstanceProperty__default["default"](_context = "".concat(projectKey, "/")).call(_context, OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION), {}),
|
|
606
686
|
_useStorage2 = _slicedToArray(_useStorage, 1),
|
|
607
687
|
cachedSelectedGroups = _useStorage2[0];
|
|
688
|
+
const _useStorage3 = experimentalComponents.useStorage(_concatInstanceProperty__default["default"](_context2 = "".concat(projectKey, "/")).call(_context2, OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP), {
|
|
689
|
+
[props.resourceType]: _reduceInstanceProperty__default["default"](_context3 = props.fieldGroups).call(_context3, (acc, group) => {
|
|
690
|
+
acc[group.groupName] = group.isExpanded;
|
|
691
|
+
return acc;
|
|
692
|
+
}, {})
|
|
693
|
+
}),
|
|
694
|
+
_useStorage4 = _slicedToArray(_useStorage3, 1),
|
|
695
|
+
cachedExpandedGroups = _useStorage4[0];
|
|
608
696
|
return React__default["default"].useMemo(() => {
|
|
609
|
-
|
|
697
|
+
let groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups, cachedSelectedGroups[props.resourceType] || {});
|
|
698
|
+
groups = updateFieldGroupsWithIsExpandedValue(groups, cachedExpandedGroups[props.resourceType] || {});
|
|
610
699
|
return {
|
|
611
700
|
outputFormat: props.outputFormat,
|
|
612
|
-
fileName:
|
|
701
|
+
fileName: "".concat(resourceTypeToFileName({
|
|
613
702
|
resourceType: props.resourceType,
|
|
614
703
|
isUpperCase: true,
|
|
615
704
|
isPlural: true
|
|
616
|
-
})
|
|
705
|
+
})),
|
|
617
706
|
locales: [locale],
|
|
618
707
|
groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
|
|
619
708
|
};
|
|
620
|
-
}, [props.fieldGroups, props.
|
|
709
|
+
}, [props.fieldGroups, props.resourceType, props.outputFormat, cachedSelectedGroups, cachedExpandedGroups, locale]);
|
|
621
710
|
};
|
|
622
711
|
|
|
623
712
|
async function createExportOperation(_ref) {
|
|
@@ -629,7 +718,7 @@ async function createExportOperation(_ref) {
|
|
|
629
718
|
locales = _ref.locales,
|
|
630
719
|
filters = _ref.filters,
|
|
631
720
|
asyncDispatchFn = _ref.asyncDispatchFn;
|
|
632
|
-
const uri =
|
|
721
|
+
const uri = "/".concat(projectKey, "/export-operations");
|
|
633
722
|
const response = await asyncDispatchFn(sdk.actions.post({
|
|
634
723
|
mcApiProxyTarget: constants.MC_API_PROXY_TARGETS.EXPORT,
|
|
635
724
|
uri: uri,
|
|
@@ -653,20 +742,24 @@ const useStartExportOperation = props => {
|
|
|
653
742
|
const intl = reactIntl.useIntl();
|
|
654
743
|
const asyncDispatch = sdk.useAsyncDispatch();
|
|
655
744
|
const showNotification = actionsGlobal.useShowNotification();
|
|
656
|
-
const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext =>
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
745
|
+
const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => {
|
|
746
|
+
var _applicationContext$p;
|
|
747
|
+
return {
|
|
748
|
+
locale: applicationContext.dataLocale,
|
|
749
|
+
projectKey: (_applicationContext$p = applicationContext.project) === null || _applicationContext$p === void 0 ? void 0 : _applicationContext$p.key
|
|
750
|
+
};
|
|
751
|
+
}),
|
|
660
752
|
projectKey = _useApplicationContex.projectKey;
|
|
661
753
|
const extractFieldsFromGroups = groups => {
|
|
662
754
|
let selectedGeneralFields = [];
|
|
663
755
|
const getSelectedFields = fields => {
|
|
664
756
|
return _filterInstanceProperty__default["default"](fields).call(fields, field => {
|
|
757
|
+
var _field$isChecked;
|
|
665
758
|
if (field.fields) {
|
|
666
759
|
return getSelectedFields(field.fields);
|
|
667
760
|
}
|
|
668
761
|
if (field.isChecked) selectedGeneralFields.push(field);
|
|
669
|
-
return field.isChecked
|
|
762
|
+
return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
|
|
670
763
|
});
|
|
671
764
|
};
|
|
672
765
|
_forEachInstanceProperty__default["default"](groups).call(groups, group => {
|
|
@@ -727,9 +820,10 @@ const useStartExportOperation = props => {
|
|
|
727
820
|
};
|
|
728
821
|
};
|
|
729
822
|
|
|
730
|
-
function ownKeys$
|
|
731
|
-
function _objectSpread$
|
|
823
|
+
function ownKeys$5(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
824
|
+
function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$5(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$5(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
732
825
|
function ExportScopeSection() {
|
|
826
|
+
var _originalSelectedReso;
|
|
733
827
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
734
828
|
exportType = _useExportResourcesCo.exportType,
|
|
735
829
|
totalResourcesCount = _useExportResourcesCo.totalResourcesCount,
|
|
@@ -750,7 +844,7 @@ function ExportScopeSection() {
|
|
|
750
844
|
children: [jsxRuntime.jsx(uiKit.RadioInput.Option, {
|
|
751
845
|
value: EXPORT_TYPES.ALL,
|
|
752
846
|
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
753
|
-
intlMessage: _objectSpread$
|
|
847
|
+
intlMessage: _objectSpread$5(_objectSpread$5({}, resourceTypeMessages[resourceType].exportScopeAll), {}, {
|
|
754
848
|
values: {
|
|
755
849
|
total: new Intl.NumberFormat().format(totalResourcesCount)
|
|
756
850
|
}
|
|
@@ -758,12 +852,12 @@ function ExportScopeSection() {
|
|
|
758
852
|
})
|
|
759
853
|
}), jsxRuntime.jsx(uiKit.RadioInput.Option, {
|
|
760
854
|
value: EXPORT_TYPES.SELECTED,
|
|
761
|
-
isDisabled: !originalSelectedResourceIds
|
|
855
|
+
isDisabled: !(originalSelectedResourceIds !== null && originalSelectedResourceIds !== void 0 && originalSelectedResourceIds.length),
|
|
762
856
|
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
763
|
-
tone: !originalSelectedResourceIds
|
|
764
|
-
intlMessage: originalSelectedResourceIds
|
|
857
|
+
tone: !(originalSelectedResourceIds !== null && originalSelectedResourceIds !== void 0 && originalSelectedResourceIds.length) ? 'tertiary' : undefined,
|
|
858
|
+
intlMessage: originalSelectedResourceIds !== null && originalSelectedResourceIds !== void 0 && originalSelectedResourceIds.length ? _objectSpread$5(_objectSpread$5({}, resourceTypeMessages[resourceType].exportScopeSelected), {}, {
|
|
765
859
|
values: {
|
|
766
|
-
total: new Intl.NumberFormat().format(originalSelectedResourceIds
|
|
860
|
+
total: new Intl.NumberFormat().format((_originalSelectedReso = originalSelectedResourceIds === null || originalSelectedResourceIds === void 0 ? void 0 : originalSelectedResourceIds.length) !== null && _originalSelectedReso !== void 0 ? _originalSelectedReso : 0)
|
|
767
861
|
}
|
|
768
862
|
}) : messages.exportScopeSelectedWithoutCount
|
|
769
863
|
})
|
|
@@ -773,21 +867,25 @@ function ExportScopeSection() {
|
|
|
773
867
|
}
|
|
774
868
|
|
|
775
869
|
const ExportFileSettingsStep = () => {
|
|
870
|
+
var _context;
|
|
776
871
|
const intl = reactIntl.useIntl();
|
|
777
872
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
778
873
|
formik = _useExportResourcesCo.formik,
|
|
779
874
|
resourceType = _useExportResourcesCo.resourceType,
|
|
780
875
|
onClose = _useExportResourcesCo.onClose;
|
|
781
|
-
const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext =>
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
876
|
+
const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => {
|
|
877
|
+
var _applicationContext$p;
|
|
878
|
+
return {
|
|
879
|
+
locale: applicationContext.dataLocale,
|
|
880
|
+
locales: ((_applicationContext$p = applicationContext.project) === null || _applicationContext$p === void 0 ? void 0 : _applicationContext$p.languages) || []
|
|
881
|
+
};
|
|
882
|
+
}),
|
|
785
883
|
locales = _useApplicationContex.locales,
|
|
786
884
|
locale = _useApplicationContex.locale;
|
|
787
885
|
const areAllLocalesChecked = _valuesInstanceProperty__default["default"](formik).locales.length === locales.length;
|
|
788
886
|
return jsxRuntime.jsx(applicationComponents.FormDialog, {
|
|
789
887
|
isOpen: true,
|
|
790
|
-
title: intl.formatMessage(messages[
|
|
888
|
+
title: intl.formatMessage(messages["modalTitle.".concat(resourceType)]),
|
|
791
889
|
labelPrimary: intl.formatMessage(messages.continue),
|
|
792
890
|
onPrimaryButtonClick: formik.submitForm,
|
|
793
891
|
isPrimaryButtonDisabled: !formik.isValid,
|
|
@@ -800,7 +898,7 @@ const ExportFileSettingsStep = () => {
|
|
|
800
898
|
scale: "l",
|
|
801
899
|
children: jsxRuntime.jsxs(uiKit.Grid, {
|
|
802
900
|
gridRowGap: uiKit.designTokens.spacingL,
|
|
803
|
-
gridTemplateColumns:
|
|
901
|
+
gridTemplateColumns: _concatInstanceProperty__default["default"](_context = "calc(".concat(uiKit.designTokens.constraint3, " + ")).call(_context, uiKit.designTokens.spacingL, ") auto"),
|
|
804
902
|
children: [jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
805
903
|
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
806
904
|
intlMessage: messages.exportScope
|
|
@@ -862,15 +960,15 @@ const ExportFileSettingsStep = () => {
|
|
|
862
960
|
});
|
|
863
961
|
};
|
|
864
962
|
|
|
865
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
866
|
-
var _ref = process.env.NODE_ENV === "production" ? {
|
|
963
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$3() { 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)."; }
|
|
964
|
+
var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
867
965
|
name: "ti75j2",
|
|
868
966
|
styles: "margin:0"
|
|
869
967
|
} : {
|
|
870
968
|
name: "ozey8m-NoSearchResults",
|
|
871
969
|
styles: "margin:0;label:NoSearchResults;",
|
|
872
970
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
|
|
873
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
971
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
874
972
|
};
|
|
875
973
|
const NoSearchResults = () => {
|
|
876
974
|
return jsxRuntime.jsxs(uiKit.Card, {
|
|
@@ -884,7 +982,7 @@ const NoSearchResults = () => {
|
|
|
884
982
|
intlMessage: messages.suggestions
|
|
885
983
|
})]
|
|
886
984
|
}), jsxRuntime.jsxs("ul", {
|
|
887
|
-
css: _ref,
|
|
985
|
+
css: _ref$1,
|
|
888
986
|
children: [jsxRuntime.jsx("li", {
|
|
889
987
|
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
890
988
|
intlMessage: messages.checkTheSpelling
|
|
@@ -898,184 +996,419 @@ const NoSearchResults = () => {
|
|
|
898
996
|
});
|
|
899
997
|
};
|
|
900
998
|
|
|
901
|
-
function ownKeys$
|
|
902
|
-
function _objectSpread$
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
999
|
+
function ownKeys$4(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1000
|
+
function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$4(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$4(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
1001
|
+
const exportFieldSelectionContextDefaultValues = {
|
|
1002
|
+
updateExpandedGroups: (_name, _value) => {}
|
|
1003
|
+
};
|
|
1004
|
+
const ExportFieldSelectionContext = /*#__PURE__*/React.createContext(exportFieldSelectionContextDefaultValues);
|
|
1005
|
+
const ExportFieldSelectionProvider = _ref => {
|
|
1006
|
+
var _context;
|
|
1007
|
+
let resourceType = _ref.resourceType,
|
|
1008
|
+
children = _ref.children;
|
|
1009
|
+
const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => {
|
|
1010
|
+
var _context$project;
|
|
1011
|
+
return {
|
|
1012
|
+
projectKey: (_context$project = context.project) === null || _context$project === void 0 ? void 0 : _context$project.key
|
|
1013
|
+
};
|
|
1014
|
+
}),
|
|
1015
|
+
projectKey = _useApplicationContex.projectKey;
|
|
1016
|
+
const _useStorage = experimentalComponents.useStorage(_concatInstanceProperty__default["default"](_context = "".concat(projectKey, "/")).call(_context, OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP), {}),
|
|
1017
|
+
_useStorage2 = _slicedToArray(_useStorage, 2),
|
|
1018
|
+
cachedExpandedGroups = _useStorage2[0],
|
|
1019
|
+
setCachedExpandedGroups = _useStorage2[1];
|
|
1020
|
+
const updateExpandedGroups = React.useCallback((name, value) => {
|
|
1021
|
+
setCachedExpandedGroups({
|
|
1022
|
+
[resourceType]: _objectSpread$4(_objectSpread$4({}, cachedExpandedGroups[resourceType] || {}), {}, {
|
|
1023
|
+
[name]: value
|
|
1024
|
+
})
|
|
1025
|
+
});
|
|
1026
|
+
}, [cachedExpandedGroups, resourceType, setCachedExpandedGroups]);
|
|
1027
|
+
return jsxRuntime.jsx(ExportFieldSelectionContext.Provider, {
|
|
1028
|
+
value: {
|
|
1029
|
+
updateExpandedGroups
|
|
1030
|
+
},
|
|
1031
|
+
children: children
|
|
1032
|
+
});
|
|
1033
|
+
};
|
|
1034
|
+
const useExportFieldSelectionContext = () => {
|
|
1035
|
+
return React.useContext(ExportFieldSelectionContext);
|
|
1036
|
+
};
|
|
1037
|
+
|
|
1038
|
+
const calculateTotalSelectedFields = (group, formik) => {
|
|
1039
|
+
let result = 0;
|
|
1040
|
+
// Check `isChecked` fields
|
|
1041
|
+
function countSelectedFields(fields) {
|
|
1042
|
+
_forEachInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1043
|
+
if (field.fields) {
|
|
1044
|
+
countSelectedFields(field.fields);
|
|
1045
|
+
} else if (field.isChecked) {
|
|
1046
|
+
result += 1;
|
|
1047
|
+
}
|
|
1048
|
+
});
|
|
1049
|
+
}
|
|
1050
|
+
countSelectedFields(group.fields);
|
|
1051
|
+
// check `isReadOnly` fields
|
|
1052
|
+
function countReadOnlyDependentFields(fields) {
|
|
1053
|
+
_forEachInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1054
|
+
var _field$dependentGroup;
|
|
1055
|
+
if (field.fields) {
|
|
1056
|
+
countReadOnlyDependentFields(field.fields);
|
|
1057
|
+
} else if ((_field$dependentGroup = field.dependentGroupNames) !== null && _field$dependentGroup !== void 0 && _field$dependentGroup.length && isRequiredGroupChecked(field.dependentGroupNames, formik)) {
|
|
1058
|
+
result += 1;
|
|
1059
|
+
}
|
|
1060
|
+
});
|
|
1061
|
+
}
|
|
1062
|
+
function countReadOnlyFields(fields) {
|
|
1063
|
+
_forEachInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1064
|
+
var _field$dependentGroup2;
|
|
1065
|
+
if (field.fields) {
|
|
1066
|
+
countReadOnlyFields(field.fields);
|
|
1067
|
+
} else if (field.isReadOnly && !((_field$dependentGroup2 = field.dependentGroupNames) !== null && _field$dependentGroup2 !== void 0 && _field$dependentGroup2.length)) {
|
|
1068
|
+
result += 1;
|
|
1069
|
+
}
|
|
1070
|
+
});
|
|
1071
|
+
}
|
|
1072
|
+
if (result > 0) {
|
|
1073
|
+
countReadOnlyFields(group.fields);
|
|
1074
|
+
}
|
|
1075
|
+
if (group.dependentGroupNames) {
|
|
1076
|
+
countReadOnlyDependentFields(group.fields);
|
|
1077
|
+
}
|
|
1078
|
+
return result;
|
|
1079
|
+
};
|
|
1080
|
+
const ExportFieldSelectionStamp = _ref => {
|
|
1081
|
+
let group = _ref.group;
|
|
1082
|
+
const _useExportResourcesCo = useExportResourcesContext(),
|
|
1083
|
+
formik = _useExportResourcesCo.formik;
|
|
1084
|
+
const _useIntl = reactIntl.useIntl(),
|
|
1085
|
+
formatMessage = _useIntl.formatMessage;
|
|
1086
|
+
return jsxRuntime.jsx(uiKit.Card, {
|
|
1087
|
+
type: "flat",
|
|
1088
|
+
insetScale: "m",
|
|
1089
|
+
children: jsxRuntime.jsx(uiKit.Spacings.Inline, {
|
|
1090
|
+
justifyContent: "flex-end",
|
|
1091
|
+
children: jsxRuntime.jsx(uiKit.Stamp, {
|
|
1092
|
+
tone: "secondary",
|
|
1093
|
+
isCondensed: true,
|
|
1094
|
+
label: formatMessage(messages.selected, {
|
|
1095
|
+
total: calculateTotalSelectedFields(group, formik)
|
|
1096
|
+
})
|
|
1097
|
+
})
|
|
1098
|
+
})
|
|
1099
|
+
});
|
|
1100
|
+
};
|
|
1101
|
+
|
|
1102
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { 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)."; }
|
|
1103
|
+
const FieldWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
1104
|
+
target: "e1judmlm0"
|
|
906
1105
|
} : {
|
|
907
|
-
target: "
|
|
908
|
-
label: "
|
|
1106
|
+
target: "e1judmlm0",
|
|
1107
|
+
label: "FieldWrapper"
|
|
909
1108
|
})(process.env.NODE_ENV === "production" ? {
|
|
910
|
-
name: "
|
|
911
|
-
styles: "
|
|
1109
|
+
name: "bjn8wh",
|
|
1110
|
+
styles: "position:relative"
|
|
912
1111
|
} : {
|
|
913
|
-
name: "
|
|
914
|
-
styles: "
|
|
915
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AA4BmC","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport {\n  OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION,\n  FIELD_DEFINITIONS_URLS,\n} from '../@constants'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\nimport { useStorage } from '@commercetools-frontend/experimental-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\n\nconst StyledGridCard = styled(Card)`\n  max-height: 50vh;\n  overflow: auto;\n`\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { projectKey } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n  }))\n  const [_, setCachedSelectedGroups] = useStorage(\n    `${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`,\n    {}\n  )\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n\n  React.useEffect(() => {\n    formik.validateForm()\n    const selectedFields = {}\n    function getSelectedFields(field, groupName) {\n      const fieldName = field.name ? `${groupName}.${field.name}` : groupName\n      if (field.fields) {\n        return field.fields.forEach((f) => getSelectedFields(f, fieldName))\n      }\n\n      selectedFields[fieldName] = field.isChecked\n    }\n    formik.values.groups.forEach((group) =>\n      getSelectedFields(group, group.groupLabel)\n    )\n    setCachedSelectedGroups({\n      [resourceType]: selectedFields,\n    })\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages[`modalTitle.${resourceType}`])}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <StyledGridCard insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </StyledGridCard>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */",
|
|
916
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
1112
|
+
name: "bjn8wh",
|
|
1113
|
+
styles: "position:relative",
|
|
1114
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAqB+B","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport { FilteredField, FormikField } from '../../@types'\nimport get from 'lodash/get'\nimport {\n  checkAllFieldsSelected,\n  checkAtLeastOneFieldChecked,\n  isRequiredGroupChecked,\n} from '../../@utils'\nimport { StyledExpandableContent } from './field-group-section'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport styled from '@emotion/styled'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormikField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => JSX.Element\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n  isForceExpanded?: boolean\n  groupName: string\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isForceExpanded,\n  groupName,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAnyOfTheChildFieldsChecked = checkAtLeastOneFieldChecked(\n          field.fields\n        )\n        const allAllFieldsSelected = checkAllFieldsSelected(field.fields || [])\n        const checkIsChecked = () => {\n          if (field.isExpandable) {\n            return allAllFieldsSelected\n          }\n          if (field.isReadOnly) {\n            if (field.dependentGroupNames) {\n              return isRequiredGroupChecked(field.dependentGroupNames, formik)\n            }\n            return isAnySiblingChecked\n          }\n          if (isAnyOfTheChildFieldsChecked) {\n            return field.isChecked\n          }\n          return false\n        }\n        if (field.isHidden) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isForceExpanded}\n            field={field}\n            key={`${field.name}.${isForceExpanded}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isForceExpanded) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allAllFieldsSelected &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={checkIsChecked()}\n                      isReadOnly={field.isReadOnly || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path)\n                          if (item && item.fields) {\n                            item.fields.forEach((field, i) => {\n                              const fieldPath = `${path}.fields[${i}]`\n                              if (!field.fields?.length) {\n                                formik.setFieldValue(\n                                  `${fieldPath}.isChecked`,\n                                  checked,\n                                  // pass `false` to avoid revalidating the form with intermediate values\n                                  false\n                                )\n                              }\n                              updateAllChildFieldsChecked(fieldPath, checked)\n                            })\n                          }\n                        }\n                        if (!field.fields?.length) {\n                          formik.setFieldValue(\n                            `${path}.isChecked`,\n                            e.target.checked,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, e.target.checked)\n                      }}\n                    >\n                      {field.label} {field.isRequired && '*'}\n                    </CheckboxInput>\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields?.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    <Spacings.Inline scale=\"xl\">\n                      <div />\n                      <FieldSection\n                        fields={field.fields}\n                        formik={formik}\n                        parentKeys={[...parentKeys, `fields[${index}]`]}\n                        isAnySiblingChecked={isAnySiblingChecked}\n                        isForceExpanded={isForceExpanded}\n                        groupName={groupName}\n                      />\n                    </Spacings.Inline>\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n"]} */",
|
|
1115
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
917
1116
|
});
|
|
918
|
-
const
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
})("border-right:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";background-color:", uiKit.designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledGroupCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AAyCO","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport {\n  OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION,\n  FIELD_DEFINITIONS_URLS,\n} from '../@constants'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\nimport { useStorage } from '@commercetools-frontend/experimental-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\n\nconst StyledGridCard = styled(Card)`\n  max-height: 50vh;\n  overflow: auto;\n`\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { projectKey } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n  }))\n  const [_, setCachedSelectedGroups] = useStorage(\n    `${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`,\n    {}\n  )\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n\n  React.useEffect(() => {\n    formik.validateForm()\n    const selectedFields = {}\n    function getSelectedFields(field, groupName) {\n      const fieldName = field.name ? `${groupName}.${field.name}` : groupName\n      if (field.fields) {\n        return field.fields.forEach((f) => getSelectedFields(f, fieldName))\n      }\n\n      selectedFields[fieldName] = field.isChecked\n    }\n    formik.values.groups.forEach((group) =>\n      getSelectedFields(group, group.groupLabel)\n    )\n    setCachedSelectedGroups({\n      [resourceType]: selectedFields,\n    })\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages[`modalTitle.${resourceType}`])}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <StyledGridCard insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </StyledGridCard>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AAiCiE","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport {\n  OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION,\n  FIELD_DEFINITIONS_URLS,\n} from '../@constants'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\nimport { useStorage } from '@commercetools-frontend/experimental-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\n\nconst StyledGridCard = styled(Card)`\n  max-height: 50vh;\n  overflow: auto;\n`\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { projectKey } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n  }))\n  const [_, setCachedSelectedGroups] = useStorage(\n    `${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`,\n    {}\n  )\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n\n  React.useEffect(() => {\n    formik.validateForm()\n    const selectedFields = {}\n    function getSelectedFields(field, groupName) {\n      const fieldName = field.name ? `${groupName}.${field.name}` : groupName\n      if (field.fields) {\n        return field.fields.forEach((f) => getSelectedFields(f, fieldName))\n      }\n\n      selectedFields[fieldName] = field.isChecked\n    }\n    formik.values.groups.forEach((group) =>\n      getSelectedFields(group, group.groupLabel)\n    )\n    setCachedSelectedGroups({\n      [resourceType]: selectedFields,\n    })\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages[`modalTitle.${resourceType}`])}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <StyledGridCard insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </StyledGridCard>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"));
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
})("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledFieldsCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AAmDO","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport {\n  OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION,\n  FIELD_DEFINITIONS_URLS,\n} from '../@constants'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\nimport { useStorage } from '@commercetools-frontend/experimental-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\n\nconst StyledGridCard = styled(Card)`\n  max-height: 50vh;\n  overflow: auto;\n`\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { projectKey } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n  }))\n  const [_, setCachedSelectedGroups] = useStorage(\n    `${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`,\n    {}\n  )\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n\n  React.useEffect(() => {\n    formik.validateForm()\n    const selectedFields = {}\n    function getSelectedFields(field, groupName) {\n      const fieldName = field.name ? `${groupName}.${field.name}` : groupName\n      if (field.fields) {\n        return field.fields.forEach((f) => getSelectedFields(f, fieldName))\n      }\n\n      selectedFields[fieldName] = field.isChecked\n    }\n    formik.values.groups.forEach((group) =>\n      getSelectedFields(group, group.groupLabel)\n    )\n    setCachedSelectedGroups({\n      [resourceType]: selectedFields,\n    })\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages[`modalTitle.${resourceType}`])}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <StyledGridCard insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </StyledGridCard>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AA+CkE","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport {\n  OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION,\n  FIELD_DEFINITIONS_URLS,\n} from '../@constants'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\nimport { useStorage } from '@commercetools-frontend/experimental-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\n\nconst StyledGridCard = styled(Card)`\n  max-height: 50vh;\n  overflow: auto;\n`\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { projectKey } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n  }))\n  const [_, setCachedSelectedGroups] = useStorage(\n    `${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`,\n    {}\n  )\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n\n  React.useEffect(() => {\n    formik.validateForm()\n    const selectedFields = {}\n    function getSelectedFields(field, groupName) {\n      const fieldName = field.name ? `${groupName}.${field.name}` : groupName\n      if (field.fields) {\n        return field.fields.forEach((f) => getSelectedFields(f, fieldName))\n      }\n\n      selectedFields[fieldName] = field.isChecked\n    }\n    formik.values.groups.forEach((group) =>\n      getSelectedFields(group, group.groupLabel)\n    )\n    setCachedSelectedGroups({\n      [resourceType]: selectedFields,\n    })\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages[`modalTitle.${resourceType}`])}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <StyledGridCard insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </StyledGridCard>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"));
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
1117
|
+
const CollapsibleFieldWrapper = _ref => {
|
|
1118
|
+
let isForceExpanded = _ref.isForceExpanded,
|
|
1119
|
+
field = _ref.field,
|
|
1120
|
+
children = _ref.children;
|
|
1121
|
+
if (field.isExpandable) return jsxRuntime.jsx(uiKit.CollapsibleMotion, {
|
|
1122
|
+
isDefaultClosed: isForceExpanded ? false : !field.isExpanded,
|
|
1123
|
+
children: _ref2 => {
|
|
1124
|
+
let isOpen = _ref2.isOpen,
|
|
1125
|
+
toggle = _ref2.toggle,
|
|
1126
|
+
registerContentNode = _ref2.registerContentNode;
|
|
1127
|
+
return children({
|
|
1128
|
+
isOpen,
|
|
1129
|
+
toggle,
|
|
1130
|
+
registerContentNode
|
|
1131
|
+
});
|
|
1132
|
+
}
|
|
1133
|
+
}, "".concat(isForceExpanded));
|
|
1134
|
+
return children({
|
|
1135
|
+
isOpen: true,
|
|
1136
|
+
toggle: () => {},
|
|
1137
|
+
registerContentNode: () => {}
|
|
1138
|
+
});
|
|
1139
|
+
};
|
|
1140
|
+
const FieldSection = _ref3 => {
|
|
1141
|
+
let fields = _ref3.fields,
|
|
1142
|
+
parentKeys = _ref3.parentKeys,
|
|
1143
|
+
formik = _ref3.formik,
|
|
1144
|
+
isAnySiblingChecked = _ref3.isAnySiblingChecked,
|
|
1145
|
+
isForceExpanded = _ref3.isForceExpanded,
|
|
1146
|
+
groupName = _ref3.groupName;
|
|
1147
|
+
const _useExportFieldSelect = useExportFieldSelectionContext(),
|
|
1148
|
+
updateExpandedGroups = _useExportFieldSelect.updateExpandedGroups;
|
|
935
1149
|
return jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
936
1150
|
scale: "s",
|
|
937
|
-
children: fields
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
1151
|
+
children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, (field, index) => {
|
|
1152
|
+
var _context;
|
|
1153
|
+
const isAnyOfTheChildFieldsChecked = checkAtLeastOneFieldChecked(field.fields);
|
|
1154
|
+
const allAllFieldsSelected = checkAllFieldsSelected(field.fields || []);
|
|
1155
|
+
const checkIsChecked = () => {
|
|
1156
|
+
if (field.isExpandable) {
|
|
1157
|
+
return allAllFieldsSelected;
|
|
1158
|
+
}
|
|
1159
|
+
if (field.isReadOnly) {
|
|
1160
|
+
if (field.dependentGroupNames) {
|
|
1161
|
+
return isRequiredGroupChecked(field.dependentGroupNames, formik);
|
|
1162
|
+
}
|
|
1163
|
+
return isAnySiblingChecked;
|
|
946
1164
|
}
|
|
947
|
-
|
|
1165
|
+
if (isAnyOfTheChildFieldsChecked) {
|
|
1166
|
+
return field.isChecked;
|
|
1167
|
+
}
|
|
1168
|
+
return false;
|
|
948
1169
|
};
|
|
949
|
-
const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
|
|
950
1170
|
if (field.isHidden) return null;
|
|
951
|
-
return jsxRuntime.
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
967
|
-
|
|
1171
|
+
return jsxRuntime.jsx(CollapsibleFieldWrapper, {
|
|
1172
|
+
isForceExpanded: isForceExpanded,
|
|
1173
|
+
field: field,
|
|
1174
|
+
children: _ref4 => {
|
|
1175
|
+
var _context2, _field$fields3;
|
|
1176
|
+
let isOpen = _ref4.isOpen,
|
|
1177
|
+
toggle = _ref4.toggle,
|
|
1178
|
+
registerContentNode = _ref4.registerContentNode;
|
|
1179
|
+
return jsxRuntime.jsxs(React.Fragment, {
|
|
1180
|
+
children: [jsxRuntime.jsxs(FieldWrapper, {
|
|
1181
|
+
children: [field.isExpandable && jsxRuntime.jsx(uiKit.IconButton, {
|
|
1182
|
+
size: "20",
|
|
1183
|
+
style: {
|
|
1184
|
+
position: 'absolute',
|
|
1185
|
+
left: "calc(-1 * ".concat(uiKit.designTokens.spacingXl, ")")
|
|
1186
|
+
},
|
|
1187
|
+
onClick: () => {
|
|
1188
|
+
if (!isForceExpanded) {
|
|
1189
|
+
var _context3;
|
|
1190
|
+
updateExpandedGroups(_concatInstanceProperty__default["default"](_context3 = "".concat(groupName, ".")).call(_context3, field.name), !isOpen);
|
|
968
1191
|
}
|
|
969
|
-
|
|
970
|
-
}
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
1192
|
+
toggle();
|
|
1193
|
+
},
|
|
1194
|
+
icon: isOpen ? jsxRuntime.jsx(uiKit.AngleDownIcon, {}) : jsxRuntime.jsx(uiKit.AngleRightIcon, {}),
|
|
1195
|
+
label: ""
|
|
1196
|
+
}), jsxRuntime.jsx(uiKit.Spacings.Inline, {
|
|
1197
|
+
scale: "s",
|
|
1198
|
+
alignItems: "center",
|
|
1199
|
+
children: jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
1200
|
+
isIndeterminate: field.isExpandable && !allAllFieldsSelected && isAnyOfTheChildFieldsChecked,
|
|
1201
|
+
isChecked: checkIsChecked(),
|
|
1202
|
+
isReadOnly: field.isReadOnly || field.isRequired,
|
|
1203
|
+
onChange: e => {
|
|
1204
|
+
var _context4, _field$fields2;
|
|
1205
|
+
const path = _concatInstanceProperty__default["default"](_context4 = "".concat(parentKeys.join('.'), ".fields[")).call(_context4, index, "]");
|
|
1206
|
+
// Update all child fields
|
|
1207
|
+
const updateAllChildFieldsChecked = (path, checked) => {
|
|
1208
|
+
const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), path);
|
|
1209
|
+
if (item && item.fields) {
|
|
1210
|
+
var _context5;
|
|
1211
|
+
_forEachInstanceProperty__default["default"](_context5 = item.fields).call(_context5, (field, i) => {
|
|
1212
|
+
var _context6, _field$fields;
|
|
1213
|
+
const fieldPath = _concatInstanceProperty__default["default"](_context6 = "".concat(path, ".fields[")).call(_context6, i, "]");
|
|
1214
|
+
if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
|
|
1215
|
+
formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
|
|
1216
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
1217
|
+
false);
|
|
1218
|
+
}
|
|
1219
|
+
updateAllChildFieldsChecked(fieldPath, checked);
|
|
1220
|
+
});
|
|
1221
|
+
}
|
|
1222
|
+
};
|
|
1223
|
+
if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
|
|
1224
|
+
formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
|
|
1225
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
1226
|
+
false);
|
|
1227
|
+
}
|
|
1228
|
+
updateAllChildFieldsChecked(path, e.target.checked);
|
|
1229
|
+
},
|
|
1230
|
+
children: [field.label, " ", field.isRequired && '*']
|
|
1231
|
+
})
|
|
1232
|
+
})]
|
|
1233
|
+
}), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxRuntime.jsx(StyledExpandableContent, {
|
|
1234
|
+
ref: registerContentNode,
|
|
1235
|
+
isOpen: isOpen,
|
|
1236
|
+
children: jsxRuntime.jsxs(uiKit.Spacings.Inline, {
|
|
1237
|
+
scale: "xl",
|
|
1238
|
+
children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(FieldSection, {
|
|
1239
|
+
fields: field.fields,
|
|
1240
|
+
formik: formik,
|
|
1241
|
+
parentKeys: [...parentKeys, "fields[".concat(index, "]")],
|
|
1242
|
+
isAnySiblingChecked: isAnySiblingChecked,
|
|
1243
|
+
isForceExpanded: isForceExpanded,
|
|
1244
|
+
groupName: groupName
|
|
1245
|
+
})]
|
|
1246
|
+
})
|
|
1247
|
+
})]
|
|
1248
|
+
}, _concatInstanceProperty__default["default"](_context2 = "".concat(field.name, "-")).call(_context2, index));
|
|
1249
|
+
}
|
|
1250
|
+
}, _concatInstanceProperty__default["default"](_context = "".concat(field.name, ".")).call(_context, isForceExpanded));
|
|
991
1251
|
})
|
|
992
1252
|
});
|
|
993
1253
|
};
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
return _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
}
|
|
1254
|
+
|
|
1255
|
+
function ownKeys$3(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1256
|
+
function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$3(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$3(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
1257
|
+
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)."; }
|
|
1258
|
+
const StyledGroupCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
1259
|
+
target: "e1igkh7t2"
|
|
1260
|
+
} : {
|
|
1261
|
+
target: "e1igkh7t2",
|
|
1262
|
+
label: "StyledGroupCard"
|
|
1263
|
+
})("height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledGroupCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCTyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpbHRlcmVkR3JvdXAgfSBmcm9tICcuLi8uLi9AdHlwZXMnXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgRXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tc3RhbXAnXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQge1xuICBjaGVja0FsbEZpZWxkc1NlbGVjdGVkLFxuICBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQsXG4gIGlzUmVxdWlyZWRHcm91cENoZWNrZWQsXG59IGZyb20gJy4uLy4uL0B1dGlscydcblxuY29uc3QgU3R5bGVkR3JvdXBDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGhlaWdodDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5jb25zdCBTdHlsZWRGaWVsZHNDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQgPSBzdHlsZWQuZGl2PHtcbiAgaXNPcGVuPzogYm9vbGVhblxuICBzaG93VG9wQm9yZGVyPzogYm9vbGVhblxufT5gXG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBjc3NgXG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgaGVpZ2h0OiAwO1xuICAgICAgbWFyZ2luLXRvcDogMCAhaW1wb3J0YW50O1xuICAgIGB9XG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxudHlwZSBGaWVsZEdyb3VwU2VjdGlvblByb3BzID0ge1xuICBpbmRleDogbnVtYmVyXG4gIGdyb3VwOiBGaWx0ZXJlZEdyb3VwXG4gIGZvcm1pazogYW55XG4gIGlzRm9yY2VFeHBhbmRlZD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEZpZWxkR3JvdXBTZWN0aW9uID0gKHtcbiAgZ3JvdXAsXG4gIGluZGV4LFxuICBmb3JtaWssXG4gIGlzRm9yY2VFeHBhbmRlZCxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsQWxsRmllbGRzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGNoZWNrQWxsRmllbGRzU2VsZWN0ZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBdGxlYXN0T25lRmllbGRDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzLCBjaGVja2VkKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlYWRPbmx5IHx8IGZpZWxkLmlzUmVxdWlyZWQpIHJldHVybiBmaWVsZFxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIC4uLmZpZWxkLFxuICAgICAgICAgIGlzQ2hlY2tlZDogY2hlY2tlZCxcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG5cbiAgICBmb3JtaWsuc2V0RmllbGRWYWx1ZShwYXJlbnRLZXksIHtcbiAgICAgIC4uLml0ZW0sXG4gICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhpdGVtLmZpZWxkcywgZS50YXJnZXQuY2hlY2tlZCksXG4gICAgfSlcbiAgfVxuXG4gIGlmIChncm91cC5pc0hpZGRlbikgcmV0dXJuIG51bGxcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvblxuICAgICAgaXNEZWZhdWx0Q2xvc2VkPXtpc0ZvcmNlRXhwYW5kZWQgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAga2V5PXtgJHtpc0ZvcmNlRXhwYW5kZWR9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzRm9yY2VFeHBhbmRlZCkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxBbGxGaWVsZHNTZWxlY3RlZCAmJlxuICAgICAgICAgICAgICAgICAgICAoaXNBdGxlYXN0T25lRmllbGRDaGVja2VkIHx8XG4gICAgICAgICAgICAgICAgICAgICAgaXNSZXF1aXJlZEdyb3VwQ2hlY2tlZChncm91cC5kZXBlbmRlbnRHcm91cE5hbWVzLCBmb3JtaWspKVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxBbGxGaWVsZHNTZWxlY3RlZH1cbiAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2VBbGxGaWVsZHN9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge2dyb3VwLmdyb3VwTGFiZWx9XG4gICAgICAgICAgICAgICAgPC9DaGVja2JveElucHV0PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDwvU3R5bGVkR3JvdXBDYXJkPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICA8U3R5bGVkRXhwYW5kYWJsZUNvbnRlbnRcbiAgICAgICAgICAgICAgICByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9XG4gICAgICAgICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEZpZWxkc0NhcmRcbiAgICAgICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e3RydWV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBdGxlYXN0T25lRmllbGRDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRm9yY2VFeHBhbmRlZD17aXNGb3JjZUV4cGFuZGVkfVxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgICAgICA8L1N0eWxlZEZpZWxkc0NhcmQ+XG4gICAgICAgICAgICAgIDwvU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQ+XG4gICAgICAgICAgICAgIHshaXNPcGVuICYmIDxFeHBvcnRGaWVsZFNlbGVjdGlvblN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCaUUiLCJmaWxlIjoiZmllbGQtZ3JvdXAtc2VjdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJlZEdyb3VwIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRXhwb3J0RmllbGRTZWxlY3Rpb25Db250ZXh0IH0gZnJvbSAnLi9leHBvcnQtZmllbGQtc2VsZWN0aW9uLXByb3ZpZGVyJ1xuaW1wb3J0IGdldCBmcm9tICdsb2Rhc2gvZ2V0J1xuaW1wb3J0IHtcbiAgQW5nbGVEb3duSWNvbixcbiAgQW5nbGVSaWdodEljb24sXG4gIENhcmQsXG4gIENoZWNrYm94SW5wdXQsXG4gIENvbGxhcHNpYmxlTW90aW9uLFxuICBHcmlkLFxuICBJY29uQnV0dG9uLFxuICBTcGFjaW5ncyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IEV4cG9ydEZpZWxkU2VsZWN0aW9uU3RhbXAgZnJvbSAnLi9leHBvcnQtZmllbGQtc2VsZWN0aW9uLXN0YW1wJ1xuaW1wb3J0IHsgRmllbGRTZWN0aW9uIH0gZnJvbSAnLi9maWVsZC1zZWN0aW9uJ1xuaW1wb3J0IHtcbiAgY2hlY2tBbGxGaWVsZHNTZWxlY3RlZCxcbiAgY2hlY2tBdExlYXN0T25lRmllbGRDaGVja2VkLFxuICBpc1JlcXVpcmVkR3JvdXBDaGVja2VkLFxufSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRmlsdGVyZWRHcm91cFxuICBmb3JtaWs6IGFueVxuICBpc0ZvcmNlRXhwYW5kZWQ/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc0ZvcmNlRXhwYW5kZWQsXG59OiBGaWVsZEdyb3VwU2VjdGlvblByb3BzKSA9PiB7XG4gIGNvbnN0IGFsbEFsbEZpZWxkc1NlbGVjdGVkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0FsbEZpZWxkc1NlbGVjdGVkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IGlzQXRsZWFzdE9uZUZpZWxkQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gY2hlY2tBdExlYXN0T25lRmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuICBjb25zdCB7IHVwZGF0ZUV4cGFuZGVkR3JvdXBzIH0gPSB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQoKVxuXG4gIGNvbnN0IHBhcmVudEtleSA9IGBncm91cHNbJHtpbmRleH1dYFxuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZUFsbEZpZWxkcyA9IChlKSA9PiB7XG4gICAgY29uc3QgaXRlbSA9IGdldChmb3JtaWsudmFsdWVzLCBwYXJlbnRLZXkpXG4gICAgZnVuY3Rpb24gdXBkYXRlQWxsRmllbGRzKGZpZWxkcywgY2hlY2tlZCkge1xuICAgICAgcmV0dXJuIGZpZWxkcy5tYXAoKGZpZWxkKSA9PiB7XG4gICAgICAgIGlmIChmaWVsZC5maWVsZHMpIHtcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgLi4uZmllbGQsXG4gICAgICAgICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhmaWVsZC5maWVsZHMsIGNoZWNrZWQpLFxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoZmllbGQuaXNSZWFkT25seSB8fCBmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNGb3JjZUV4cGFuZGVkID8gZmFsc2UgOiAhZ3JvdXAuaXNFeHBhbmRlZH1cbiAgICAgIGtleT17YCR7aXNGb3JjZUV4cGFuZGVkfWB9XG4gICAgPlxuICAgICAgeyh7IGlzT3BlbiwgdG9nZ2xlLCByZWdpc3RlckNvbnRlbnROb2RlIH0pID0+IChcbiAgICAgICAgPD5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPFN0eWxlZEdyb3VwQ2FyZFxuICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwic1wiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblxuICAgICAgICAgICAgICAgICAgc2l6ZT1cIjIwXCJcbiAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCFpc0ZvcmNlRXhwYW5kZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgICB1cGRhdGVFeHBhbmRlZEdyb3Vwcyhncm91cC5ncm91cE5hbWUsICFpc09wZW4pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdG9nZ2xlKClcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICBpY29uPXtpc09wZW4gPyA8QW5nbGVEb3duSWNvbiAvPiA6IDxBbmdsZVJpZ2h0SWNvbiAvPn1cbiAgICAgICAgICAgICAgICAgIGxhYmVsPVwiXCJcbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxDaGVja2JveElucHV0XG4gICAgICAgICAgICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e1xuICAgICAgICAgICAgICAgICAgICAhYWxsQWxsRmllbGRzU2VsZWN0ZWQgJiZcbiAgICAgICAgICAgICAgICAgICAgKGlzQXRsZWFzdE9uZUZpZWxkQ2hlY2tlZCB8fFxuICAgICAgICAgICAgICAgICAgICAgIGlzUmVxdWlyZWRHcm91cENoZWNrZWQoZ3JvdXAuZGVwZW5kZW50R3JvdXBOYW1lcywgZm9ybWlrKSlcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17YWxsQWxsRmllbGRzU2VsZWN0ZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgICAgICAgICAgICAgPEZpZWxkU2VjdGlvblxuICAgICAgICAgICAgICAgICAgICAgIGZpZWxkcz17Z3JvdXAuZmllbGRzfVxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1paz17Zm9ybWlrfVxuICAgICAgICAgICAgICAgICAgICAgIHBhcmVudEtleXM9e1twYXJlbnRLZXldfVxuICAgICAgICAgICAgICAgICAgICAgIGlzQW55U2libGluZ0NoZWNrZWQ9e2lzQXRsZWFzdE9uZUZpZWxkQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICAgICAgICBncm91cE5hbWU9e2dyb3VwLmdyb3VwTmFtZX1cbiAgICAgICAgICAgICAgICAgICAgICBpc0ZvcmNlRXhwYW5kZWQ9e2lzRm9yY2VFeHBhbmRlZH1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8RXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBncm91cD17Z3JvdXB9IC8+fVxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgIDwvPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApXG59XG4iXX0= */"));
|
|
1264
|
+
const StyledFieldsCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
1265
|
+
target: "e1igkh7t1"
|
|
1266
|
+
} : {
|
|
1267
|
+
target: "e1igkh7t1",
|
|
1268
|
+
label: "StyledFieldsCard"
|
|
1269
|
+
})("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledFieldsCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVDTyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpbHRlcmVkR3JvdXAgfSBmcm9tICcuLi8uLi9AdHlwZXMnXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgRXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tc3RhbXAnXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQge1xuICBjaGVja0FsbEZpZWxkc1NlbGVjdGVkLFxuICBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQsXG4gIGlzUmVxdWlyZWRHcm91cENoZWNrZWQsXG59IGZyb20gJy4uLy4uL0B1dGlscydcblxuY29uc3QgU3R5bGVkR3JvdXBDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGhlaWdodDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5jb25zdCBTdHlsZWRGaWVsZHNDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQgPSBzdHlsZWQuZGl2PHtcbiAgaXNPcGVuPzogYm9vbGVhblxuICBzaG93VG9wQm9yZGVyPzogYm9vbGVhblxufT5gXG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBjc3NgXG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgaGVpZ2h0OiAwO1xuICAgICAgbWFyZ2luLXRvcDogMCAhaW1wb3J0YW50O1xuICAgIGB9XG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxudHlwZSBGaWVsZEdyb3VwU2VjdGlvblByb3BzID0ge1xuICBpbmRleDogbnVtYmVyXG4gIGdyb3VwOiBGaWx0ZXJlZEdyb3VwXG4gIGZvcm1pazogYW55XG4gIGlzRm9yY2VFeHBhbmRlZD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEZpZWxkR3JvdXBTZWN0aW9uID0gKHtcbiAgZ3JvdXAsXG4gIGluZGV4LFxuICBmb3JtaWssXG4gIGlzRm9yY2VFeHBhbmRlZCxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsQWxsRmllbGRzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGNoZWNrQWxsRmllbGRzU2VsZWN0ZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBdGxlYXN0T25lRmllbGRDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzLCBjaGVja2VkKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlYWRPbmx5IHx8IGZpZWxkLmlzUmVxdWlyZWQpIHJldHVybiBmaWVsZFxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIC4uLmZpZWxkLFxuICAgICAgICAgIGlzQ2hlY2tlZDogY2hlY2tlZCxcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG5cbiAgICBmb3JtaWsuc2V0RmllbGRWYWx1ZShwYXJlbnRLZXksIHtcbiAgICAgIC4uLml0ZW0sXG4gICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhpdGVtLmZpZWxkcywgZS50YXJnZXQuY2hlY2tlZCksXG4gICAgfSlcbiAgfVxuXG4gIGlmIChncm91cC5pc0hpZGRlbikgcmV0dXJuIG51bGxcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvblxuICAgICAgaXNEZWZhdWx0Q2xvc2VkPXtpc0ZvcmNlRXhwYW5kZWQgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAga2V5PXtgJHtpc0ZvcmNlRXhwYW5kZWR9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzRm9yY2VFeHBhbmRlZCkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxBbGxGaWVsZHNTZWxlY3RlZCAmJlxuICAgICAgICAgICAgICAgICAgICAoaXNBdGxlYXN0T25lRmllbGRDaGVja2VkIHx8XG4gICAgICAgICAgICAgICAgICAgICAgaXNSZXF1aXJlZEdyb3VwQ2hlY2tlZChncm91cC5kZXBlbmRlbnRHcm91cE5hbWVzLCBmb3JtaWspKVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxBbGxGaWVsZHNTZWxlY3RlZH1cbiAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2VBbGxGaWVsZHN9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge2dyb3VwLmdyb3VwTGFiZWx9XG4gICAgICAgICAgICAgICAgPC9DaGVja2JveElucHV0PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDwvU3R5bGVkR3JvdXBDYXJkPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICA8U3R5bGVkRXhwYW5kYWJsZUNvbnRlbnRcbiAgICAgICAgICAgICAgICByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9XG4gICAgICAgICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEZpZWxkc0NhcmRcbiAgICAgICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e3RydWV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBdGxlYXN0T25lRmllbGRDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRm9yY2VFeHBhbmRlZD17aXNGb3JjZUV4cGFuZGVkfVxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgICAgICA8L1N0eWxlZEZpZWxkc0NhcmQ+XG4gICAgICAgICAgICAgIDwvU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQ+XG4gICAgICAgICAgICAgIHshaXNPcGVuICYmIDxFeHBvcnRGaWVsZFNlbGVjdGlvblN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Da0UiLCJmaWxlIjoiZmllbGQtZ3JvdXAtc2VjdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJlZEdyb3VwIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRXhwb3J0RmllbGRTZWxlY3Rpb25Db250ZXh0IH0gZnJvbSAnLi9leHBvcnQtZmllbGQtc2VsZWN0aW9uLXByb3ZpZGVyJ1xuaW1wb3J0IGdldCBmcm9tICdsb2Rhc2gvZ2V0J1xuaW1wb3J0IHtcbiAgQW5nbGVEb3duSWNvbixcbiAgQW5nbGVSaWdodEljb24sXG4gIENhcmQsXG4gIENoZWNrYm94SW5wdXQsXG4gIENvbGxhcHNpYmxlTW90aW9uLFxuICBHcmlkLFxuICBJY29uQnV0dG9uLFxuICBTcGFjaW5ncyxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IEV4cG9ydEZpZWxkU2VsZWN0aW9uU3RhbXAgZnJvbSAnLi9leHBvcnQtZmllbGQtc2VsZWN0aW9uLXN0YW1wJ1xuaW1wb3J0IHsgRmllbGRTZWN0aW9uIH0gZnJvbSAnLi9maWVsZC1zZWN0aW9uJ1xuaW1wb3J0IHtcbiAgY2hlY2tBbGxGaWVsZHNTZWxlY3RlZCxcbiAgY2hlY2tBdExlYXN0T25lRmllbGRDaGVja2VkLFxuICBpc1JlcXVpcmVkR3JvdXBDaGVja2VkLFxufSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRmlsdGVyZWRHcm91cFxuICBmb3JtaWs6IGFueVxuICBpc0ZvcmNlRXhwYW5kZWQ/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc0ZvcmNlRXhwYW5kZWQsXG59OiBGaWVsZEdyb3VwU2VjdGlvblByb3BzKSA9PiB7XG4gIGNvbnN0IGFsbEFsbEZpZWxkc1NlbGVjdGVkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0FsbEZpZWxkc1NlbGVjdGVkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IGlzQXRsZWFzdE9uZUZpZWxkQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gY2hlY2tBdExlYXN0T25lRmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuICBjb25zdCB7IHVwZGF0ZUV4cGFuZGVkR3JvdXBzIH0gPSB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQoKVxuXG4gIGNvbnN0IHBhcmVudEtleSA9IGBncm91cHNbJHtpbmRleH1dYFxuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZUFsbEZpZWxkcyA9IChlKSA9PiB7XG4gICAgY29uc3QgaXRlbSA9IGdldChmb3JtaWsudmFsdWVzLCBwYXJlbnRLZXkpXG4gICAgZnVuY3Rpb24gdXBkYXRlQWxsRmllbGRzKGZpZWxkcywgY2hlY2tlZCkge1xuICAgICAgcmV0dXJuIGZpZWxkcy5tYXAoKGZpZWxkKSA9PiB7XG4gICAgICAgIGlmIChmaWVsZC5maWVsZHMpIHtcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgLi4uZmllbGQsXG4gICAgICAgICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhmaWVsZC5maWVsZHMsIGNoZWNrZWQpLFxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoZmllbGQuaXNSZWFkT25seSB8fCBmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNGb3JjZUV4cGFuZGVkID8gZmFsc2UgOiAhZ3JvdXAuaXNFeHBhbmRlZH1cbiAgICAgIGtleT17YCR7aXNGb3JjZUV4cGFuZGVkfWB9XG4gICAgPlxuICAgICAgeyh7IGlzT3BlbiwgdG9nZ2xlLCByZWdpc3RlckNvbnRlbnROb2RlIH0pID0+IChcbiAgICAgICAgPD5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPFN0eWxlZEdyb3VwQ2FyZFxuICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwic1wiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblxuICAgICAgICAgICAgICAgICAgc2l6ZT1cIjIwXCJcbiAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCFpc0ZvcmNlRXhwYW5kZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgICB1cGRhdGVFeHBhbmRlZEdyb3Vwcyhncm91cC5ncm91cE5hbWUsICFpc09wZW4pXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgdG9nZ2xlKClcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgICBpY29uPXtpc09wZW4gPyA8QW5nbGVEb3duSWNvbiAvPiA6IDxBbmdsZVJpZ2h0SWNvbiAvPn1cbiAgICAgICAgICAgICAgICAgIGxhYmVsPVwiXCJcbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgIDxDaGVja2JveElucHV0XG4gICAgICAgICAgICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e1xuICAgICAgICAgICAgICAgICAgICAhYWxsQWxsRmllbGRzU2VsZWN0ZWQgJiZcbiAgICAgICAgICAgICAgICAgICAgKGlzQXRsZWFzdE9uZUZpZWxkQ2hlY2tlZCB8fFxuICAgICAgICAgICAgICAgICAgICAgIGlzUmVxdWlyZWRHcm91cENoZWNrZWQoZ3JvdXAuZGVwZW5kZW50R3JvdXBOYW1lcywgZm9ybWlrKSlcbiAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17YWxsQWxsRmllbGRzU2VsZWN0ZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgICAgICAgICAgICAgPEZpZWxkU2VjdGlvblxuICAgICAgICAgICAgICAgICAgICAgIGZpZWxkcz17Z3JvdXAuZmllbGRzfVxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1paz17Zm9ybWlrfVxuICAgICAgICAgICAgICAgICAgICAgIHBhcmVudEtleXM9e1twYXJlbnRLZXldfVxuICAgICAgICAgICAgICAgICAgICAgIGlzQW55U2libGluZ0NoZWNrZWQ9e2lzQXRsZWFzdE9uZUZpZWxkQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICAgICAgICBncm91cE5hbWU9e2dyb3VwLmdyb3VwTmFtZX1cbiAgICAgICAgICAgICAgICAgICAgICBpc0ZvcmNlRXhwYW5kZWQ9e2lzRm9yY2VFeHBhbmRlZH1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8RXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBncm91cD17Z3JvdXB9IC8+fVxuICAgICAgICAgICAgPC8+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgIDwvPlxuICAgICAgKX1cbiAgICA8L0NvbGxhcHNpYmxlTW90aW9uPlxuICApXG59XG4iXX0= */"));
|
|
1270
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
1271
|
+
name: "2ce4ng",
|
|
1272
|
+
styles: "overflow:hidden;height:0;margin-top:0!important"
|
|
1273
|
+
} : {
|
|
1274
|
+
name: "14qt8ie-StyledExpandableContent",
|
|
1275
|
+
styles: "overflow:hidden;height:0;margin-top:0!important;label:StyledExpandableContent;",
|
|
1276
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1ETyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpbHRlcmVkR3JvdXAgfSBmcm9tICcuLi8uLi9AdHlwZXMnXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgRXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tc3RhbXAnXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQge1xuICBjaGVja0FsbEZpZWxkc1NlbGVjdGVkLFxuICBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQsXG4gIGlzUmVxdWlyZWRHcm91cENoZWNrZWQsXG59IGZyb20gJy4uLy4uL0B1dGlscydcblxuY29uc3QgU3R5bGVkR3JvdXBDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGhlaWdodDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5jb25zdCBTdHlsZWRGaWVsZHNDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQgPSBzdHlsZWQuZGl2PHtcbiAgaXNPcGVuPzogYm9vbGVhblxuICBzaG93VG9wQm9yZGVyPzogYm9vbGVhblxufT5gXG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBjc3NgXG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgaGVpZ2h0OiAwO1xuICAgICAgbWFyZ2luLXRvcDogMCAhaW1wb3J0YW50O1xuICAgIGB9XG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxudHlwZSBGaWVsZEdyb3VwU2VjdGlvblByb3BzID0ge1xuICBpbmRleDogbnVtYmVyXG4gIGdyb3VwOiBGaWx0ZXJlZEdyb3VwXG4gIGZvcm1pazogYW55XG4gIGlzRm9yY2VFeHBhbmRlZD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEZpZWxkR3JvdXBTZWN0aW9uID0gKHtcbiAgZ3JvdXAsXG4gIGluZGV4LFxuICBmb3JtaWssXG4gIGlzRm9yY2VFeHBhbmRlZCxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsQWxsRmllbGRzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGNoZWNrQWxsRmllbGRzU2VsZWN0ZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBdGxlYXN0T25lRmllbGRDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzLCBjaGVja2VkKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlYWRPbmx5IHx8IGZpZWxkLmlzUmVxdWlyZWQpIHJldHVybiBmaWVsZFxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIC4uLmZpZWxkLFxuICAgICAgICAgIGlzQ2hlY2tlZDogY2hlY2tlZCxcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG5cbiAgICBmb3JtaWsuc2V0RmllbGRWYWx1ZShwYXJlbnRLZXksIHtcbiAgICAgIC4uLml0ZW0sXG4gICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhpdGVtLmZpZWxkcywgZS50YXJnZXQuY2hlY2tlZCksXG4gICAgfSlcbiAgfVxuXG4gIGlmIChncm91cC5pc0hpZGRlbikgcmV0dXJuIG51bGxcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvblxuICAgICAgaXNEZWZhdWx0Q2xvc2VkPXtpc0ZvcmNlRXhwYW5kZWQgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAga2V5PXtgJHtpc0ZvcmNlRXhwYW5kZWR9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzRm9yY2VFeHBhbmRlZCkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxBbGxGaWVsZHNTZWxlY3RlZCAmJlxuICAgICAgICAgICAgICAgICAgICAoaXNBdGxlYXN0T25lRmllbGRDaGVja2VkIHx8XG4gICAgICAgICAgICAgICAgICAgICAgaXNSZXF1aXJlZEdyb3VwQ2hlY2tlZChncm91cC5kZXBlbmRlbnRHcm91cE5hbWVzLCBmb3JtaWspKVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxBbGxGaWVsZHNTZWxlY3RlZH1cbiAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2VBbGxGaWVsZHN9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge2dyb3VwLmdyb3VwTGFiZWx9XG4gICAgICAgICAgICAgICAgPC9DaGVja2JveElucHV0PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDwvU3R5bGVkR3JvdXBDYXJkPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICA8U3R5bGVkRXhwYW5kYWJsZUNvbnRlbnRcbiAgICAgICAgICAgICAgICByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9XG4gICAgICAgICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEZpZWxkc0NhcmRcbiAgICAgICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e3RydWV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBdGxlYXN0T25lRmllbGRDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRm9yY2VFeHBhbmRlZD17aXNGb3JjZUV4cGFuZGVkfVxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgICAgICA8L1N0eWxlZEZpZWxkc0NhcmQ+XG4gICAgICAgICAgICAgIDwvU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQ+XG4gICAgICAgICAgICAgIHshaXNPcGVuICYmIDxFeHBvcnRGaWVsZFNlbGVjdGlvblN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */",
|
|
1277
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
1278
|
+
};
|
|
1279
|
+
const StyledExpandableContent = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
1280
|
+
target: "e1igkh7t0"
|
|
1281
|
+
} : {
|
|
1282
|
+
target: "e1igkh7t0",
|
|
1283
|
+
label: "StyledExpandableContent"
|
|
1284
|
+
})(props => !props.isOpen && _ref, " ", props => !props.isOpen && props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledExpandableContent;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJETyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpbHRlcmVkR3JvdXAgfSBmcm9tICcuLi8uLi9AdHlwZXMnXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgRXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tc3RhbXAnXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQge1xuICBjaGVja0FsbEZpZWxkc1NlbGVjdGVkLFxuICBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQsXG4gIGlzUmVxdWlyZWRHcm91cENoZWNrZWQsXG59IGZyb20gJy4uLy4uL0B1dGlscydcblxuY29uc3QgU3R5bGVkR3JvdXBDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGhlaWdodDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5jb25zdCBTdHlsZWRGaWVsZHNDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQgPSBzdHlsZWQuZGl2PHtcbiAgaXNPcGVuPzogYm9vbGVhblxuICBzaG93VG9wQm9yZGVyPzogYm9vbGVhblxufT5gXG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBjc3NgXG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgaGVpZ2h0OiAwO1xuICAgICAgbWFyZ2luLXRvcDogMCAhaW1wb3J0YW50O1xuICAgIGB9XG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxudHlwZSBGaWVsZEdyb3VwU2VjdGlvblByb3BzID0ge1xuICBpbmRleDogbnVtYmVyXG4gIGdyb3VwOiBGaWx0ZXJlZEdyb3VwXG4gIGZvcm1pazogYW55XG4gIGlzRm9yY2VFeHBhbmRlZD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEZpZWxkR3JvdXBTZWN0aW9uID0gKHtcbiAgZ3JvdXAsXG4gIGluZGV4LFxuICBmb3JtaWssXG4gIGlzRm9yY2VFeHBhbmRlZCxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsQWxsRmllbGRzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGNoZWNrQWxsRmllbGRzU2VsZWN0ZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBdGxlYXN0T25lRmllbGRDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzLCBjaGVja2VkKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlYWRPbmx5IHx8IGZpZWxkLmlzUmVxdWlyZWQpIHJldHVybiBmaWVsZFxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIC4uLmZpZWxkLFxuICAgICAgICAgIGlzQ2hlY2tlZDogY2hlY2tlZCxcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG5cbiAgICBmb3JtaWsuc2V0RmllbGRWYWx1ZShwYXJlbnRLZXksIHtcbiAgICAgIC4uLml0ZW0sXG4gICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhpdGVtLmZpZWxkcywgZS50YXJnZXQuY2hlY2tlZCksXG4gICAgfSlcbiAgfVxuXG4gIGlmIChncm91cC5pc0hpZGRlbikgcmV0dXJuIG51bGxcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvblxuICAgICAgaXNEZWZhdWx0Q2xvc2VkPXtpc0ZvcmNlRXhwYW5kZWQgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAga2V5PXtgJHtpc0ZvcmNlRXhwYW5kZWR9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzRm9yY2VFeHBhbmRlZCkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxBbGxGaWVsZHNTZWxlY3RlZCAmJlxuICAgICAgICAgICAgICAgICAgICAoaXNBdGxlYXN0T25lRmllbGRDaGVja2VkIHx8XG4gICAgICAgICAgICAgICAgICAgICAgaXNSZXF1aXJlZEdyb3VwQ2hlY2tlZChncm91cC5kZXBlbmRlbnRHcm91cE5hbWVzLCBmb3JtaWspKVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxBbGxGaWVsZHNTZWxlY3RlZH1cbiAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2VBbGxGaWVsZHN9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge2dyb3VwLmdyb3VwTGFiZWx9XG4gICAgICAgICAgICAgICAgPC9DaGVja2JveElucHV0PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDwvU3R5bGVkR3JvdXBDYXJkPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICA8U3R5bGVkRXhwYW5kYWJsZUNvbnRlbnRcbiAgICAgICAgICAgICAgICByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9XG4gICAgICAgICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEZpZWxkc0NhcmRcbiAgICAgICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e3RydWV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBdGxlYXN0T25lRmllbGRDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRm9yY2VFeHBhbmRlZD17aXNGb3JjZUV4cGFuZGVkfVxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgICAgICA8L1N0eWxlZEZpZWxkc0NhcmQ+XG4gICAgICAgICAgICAgIDwvU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQ+XG4gICAgICAgICAgICAgIHshaXNPcGVuICYmIDxFeHBvcnRGaWVsZFNlbGVjdGlvblN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdERSIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpbHRlcmVkR3JvdXAgfSBmcm9tICcuLi8uLi9AdHlwZXMnXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgRXhwb3J0RmllbGRTZWxlY3Rpb25TdGFtcCBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tc3RhbXAnXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQge1xuICBjaGVja0FsbEZpZWxkc1NlbGVjdGVkLFxuICBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQsXG4gIGlzUmVxdWlyZWRHcm91cENoZWNrZWQsXG59IGZyb20gJy4uLy4uL0B1dGlscydcblxuY29uc3QgU3R5bGVkR3JvdXBDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGhlaWdodDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5jb25zdCBTdHlsZWRGaWVsZHNDYXJkID0gc3R5bGVkKENhcmQpPHsgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW4gfT5gXG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG5leHBvcnQgY29uc3QgU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQgPSBzdHlsZWQuZGl2PHtcbiAgaXNPcGVuPzogYm9vbGVhblxuICBzaG93VG9wQm9yZGVyPzogYm9vbGVhblxufT5gXG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBjc3NgXG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgaGVpZ2h0OiAwO1xuICAgICAgbWFyZ2luLXRvcDogMCAhaW1wb3J0YW50O1xuICAgIGB9XG4gICR7KHByb3BzKSA9PlxuICAgICFwcm9wcy5pc09wZW4gJiZcbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxudHlwZSBGaWVsZEdyb3VwU2VjdGlvblByb3BzID0ge1xuICBpbmRleDogbnVtYmVyXG4gIGdyb3VwOiBGaWx0ZXJlZEdyb3VwXG4gIGZvcm1pazogYW55XG4gIGlzRm9yY2VFeHBhbmRlZD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEZpZWxkR3JvdXBTZWN0aW9uID0gKHtcbiAgZ3JvdXAsXG4gIGluZGV4LFxuICBmb3JtaWssXG4gIGlzRm9yY2VFeHBhbmRlZCxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsQWxsRmllbGRzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGNoZWNrQWxsRmllbGRzU2VsZWN0ZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBdGxlYXN0T25lRmllbGRDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBjaGVja0F0TGVhc3RPbmVGaWVsZENoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzLCBjaGVja2VkKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlYWRPbmx5IHx8IGZpZWxkLmlzUmVxdWlyZWQpIHJldHVybiBmaWVsZFxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIC4uLmZpZWxkLFxuICAgICAgICAgIGlzQ2hlY2tlZDogY2hlY2tlZCxcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9XG5cbiAgICBmb3JtaWsuc2V0RmllbGRWYWx1ZShwYXJlbnRLZXksIHtcbiAgICAgIC4uLml0ZW0sXG4gICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhpdGVtLmZpZWxkcywgZS50YXJnZXQuY2hlY2tlZCksXG4gICAgfSlcbiAgfVxuXG4gIGlmIChncm91cC5pc0hpZGRlbikgcmV0dXJuIG51bGxcblxuICByZXR1cm4gKFxuICAgIDxDb2xsYXBzaWJsZU1vdGlvblxuICAgICAgaXNEZWZhdWx0Q2xvc2VkPXtpc0ZvcmNlRXhwYW5kZWQgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAga2V5PXtgJHtpc0ZvcmNlRXhwYW5kZWR9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzRm9yY2VFeHBhbmRlZCkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxBbGxGaWVsZHNTZWxlY3RlZCAmJlxuICAgICAgICAgICAgICAgICAgICAoaXNBdGxlYXN0T25lRmllbGRDaGVja2VkIHx8XG4gICAgICAgICAgICAgICAgICAgICAgaXNSZXF1aXJlZEdyb3VwQ2hlY2tlZChncm91cC5kZXBlbmRlbnRHcm91cE5hbWVzLCBmb3JtaWspKVxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxBbGxGaWVsZHNTZWxlY3RlZH1cbiAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2VBbGxGaWVsZHN9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAge2dyb3VwLmdyb3VwTGFiZWx9XG4gICAgICAgICAgICAgICAgPC9DaGVja2JveElucHV0PlxuICAgICAgICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDwvU3R5bGVkR3JvdXBDYXJkPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8PlxuICAgICAgICAgICAgICA8U3R5bGVkRXhwYW5kYWJsZUNvbnRlbnRcbiAgICAgICAgICAgICAgICByZWY9e3JlZ2lzdGVyQ29udGVudE5vZGV9XG4gICAgICAgICAgICAgICAgaXNPcGVuPXtpc09wZW59XG4gICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPFN0eWxlZEZpZWxkc0NhcmRcbiAgICAgICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e3RydWV9XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwic1wiPlxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBdGxlYXN0T25lRmllbGRDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzRm9yY2VFeHBhbmRlZD17aXNGb3JjZUV4cGFuZGVkfVxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgICAgICAgICAgICAgICA8L1N0eWxlZEZpZWxkc0NhcmQ+XG4gICAgICAgICAgICAgIDwvU3R5bGVkRXhwYW5kYWJsZUNvbnRlbnQ+XG4gICAgICAgICAgICAgIHshaXNPcGVuICYmIDxFeHBvcnRGaWVsZFNlbGVjdGlvblN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */"));
|
|
1010
1285
|
const FieldGroupSection = _ref2 => {
|
|
1011
1286
|
let group = _ref2.group,
|
|
1012
1287
|
index = _ref2.index,
|
|
1013
|
-
formik = _ref2.formik
|
|
1014
|
-
|
|
1015
|
-
const
|
|
1016
|
-
const
|
|
1288
|
+
formik = _ref2.formik,
|
|
1289
|
+
isForceExpanded = _ref2.isForceExpanded;
|
|
1290
|
+
const allAllFieldsSelected = React.useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
|
|
1291
|
+
const isAtleastOneFieldChecked = React.useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
|
|
1292
|
+
const _useExportFieldSelect = useExportFieldSelectionContext(),
|
|
1293
|
+
updateExpandedGroups = _useExportFieldSelect.updateExpandedGroups;
|
|
1294
|
+
const parentKey = "groups[".concat(index, "]");
|
|
1017
1295
|
const handleChangeAllFields = e => {
|
|
1018
1296
|
const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), parentKey);
|
|
1019
1297
|
function updateAllFields(fields, checked) {
|
|
1020
1298
|
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1021
1299
|
if (field.fields) {
|
|
1022
|
-
return _objectSpread$
|
|
1300
|
+
return _objectSpread$3(_objectSpread$3({}, field), {}, {
|
|
1023
1301
|
fields: updateAllFields(field.fields, checked)
|
|
1024
1302
|
});
|
|
1025
1303
|
}
|
|
1026
1304
|
if (field.isReadOnly || field.isRequired) return field;
|
|
1027
|
-
return _objectSpread$
|
|
1305
|
+
return _objectSpread$3(_objectSpread$3({}, field), {}, {
|
|
1028
1306
|
isChecked: checked
|
|
1029
1307
|
});
|
|
1030
1308
|
});
|
|
1031
1309
|
}
|
|
1032
|
-
formik.setFieldValue(parentKey, _objectSpread$
|
|
1310
|
+
formik.setFieldValue(parentKey, _objectSpread$3(_objectSpread$3({}, item), {}, {
|
|
1033
1311
|
fields: updateAllFields(item.fields, e.target.checked)
|
|
1034
1312
|
}));
|
|
1035
1313
|
};
|
|
1036
1314
|
if (group.isHidden) return null;
|
|
1037
|
-
return jsxRuntime.
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
|
|
1047
|
-
|
|
1048
|
-
|
|
1049
|
-
|
|
1050
|
-
|
|
1051
|
-
|
|
1052
|
-
|
|
1053
|
-
|
|
1054
|
-
|
|
1055
|
-
|
|
1056
|
-
|
|
1057
|
-
|
|
1058
|
-
|
|
1059
|
-
|
|
1060
|
-
|
|
1061
|
-
|
|
1315
|
+
return jsxRuntime.jsx(uiKit.CollapsibleMotion, {
|
|
1316
|
+
isDefaultClosed: isForceExpanded ? false : !group.isExpanded,
|
|
1317
|
+
children: _ref3 => {
|
|
1318
|
+
let isOpen = _ref3.isOpen,
|
|
1319
|
+
toggle = _ref3.toggle,
|
|
1320
|
+
registerContentNode = _ref3.registerContentNode;
|
|
1321
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
1322
|
+
children: [jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1323
|
+
children: jsxRuntime.jsx(StyledGroupCard, {
|
|
1324
|
+
type: "flat",
|
|
1325
|
+
insetScale: "m",
|
|
1326
|
+
showTopBorder: index > 0,
|
|
1327
|
+
children: jsxRuntime.jsxs(uiKit.Spacings.Inline, {
|
|
1328
|
+
scale: "s",
|
|
1329
|
+
alignItems: "center",
|
|
1330
|
+
children: [jsxRuntime.jsx(uiKit.IconButton, {
|
|
1331
|
+
size: "20",
|
|
1332
|
+
onClick: () => {
|
|
1333
|
+
if (!isForceExpanded) {
|
|
1334
|
+
updateExpandedGroups(group.groupName, !isOpen);
|
|
1335
|
+
}
|
|
1336
|
+
toggle();
|
|
1337
|
+
},
|
|
1338
|
+
icon: isOpen ? jsxRuntime.jsx(uiKit.AngleDownIcon, {}) : jsxRuntime.jsx(uiKit.AngleRightIcon, {}),
|
|
1339
|
+
label: ""
|
|
1340
|
+
}), jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1341
|
+
isIndeterminate: !allAllFieldsSelected && (isAtleastOneFieldChecked || isRequiredGroupChecked(group.dependentGroupNames, formik)),
|
|
1342
|
+
isChecked: allAllFieldsSelected,
|
|
1343
|
+
onChange: handleChangeAllFields,
|
|
1344
|
+
children: group.groupLabel
|
|
1345
|
+
})]
|
|
1346
|
+
})
|
|
1062
1347
|
})
|
|
1063
|
-
})
|
|
1064
|
-
|
|
1065
|
-
|
|
1066
|
-
|
|
1348
|
+
}), jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1349
|
+
children: jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
1350
|
+
children: [jsxRuntime.jsx(StyledExpandableContent, {
|
|
1351
|
+
ref: registerContentNode,
|
|
1352
|
+
isOpen: isOpen,
|
|
1353
|
+
showTopBorder: index > 0,
|
|
1354
|
+
children: jsxRuntime.jsx(StyledFieldsCard, {
|
|
1355
|
+
type: "flat",
|
|
1356
|
+
insetScale: "m",
|
|
1357
|
+
showTopBorder: true,
|
|
1358
|
+
children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
1359
|
+
scale: "s",
|
|
1360
|
+
children: jsxRuntime.jsx(FieldSection, {
|
|
1361
|
+
fields: group.fields,
|
|
1362
|
+
formik: formik,
|
|
1363
|
+
parentKeys: [parentKey],
|
|
1364
|
+
isAnySiblingChecked: isAtleastOneFieldChecked,
|
|
1365
|
+
groupName: group.groupName,
|
|
1366
|
+
isForceExpanded: isForceExpanded
|
|
1367
|
+
})
|
|
1368
|
+
})
|
|
1369
|
+
})
|
|
1370
|
+
}), !isOpen && jsxRuntime.jsx(ExportFieldSelectionStamp, {
|
|
1371
|
+
group: group
|
|
1372
|
+
})]
|
|
1373
|
+
})
|
|
1374
|
+
})]
|
|
1375
|
+
});
|
|
1376
|
+
}
|
|
1377
|
+
}, "".concat(isForceExpanded));
|
|
1067
1378
|
};
|
|
1379
|
+
|
|
1380
|
+
function ownKeys$2(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1381
|
+
function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context9, _context10; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context9 = ownKeys$2(Object(t), !0)).call(_context9, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context10 = ownKeys$2(Object(t))).call(_context10, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
1382
|
+
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)."; }
|
|
1383
|
+
const StyledGridCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
1384
|
+
target: "e5mvpn60"
|
|
1385
|
+
} : {
|
|
1386
|
+
target: "e5mvpn60",
|
|
1387
|
+
label: "StyledGridCard"
|
|
1388
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
1389
|
+
name: "1lf8z6",
|
|
1390
|
+
styles: "max-height:50vh;overflow:auto"
|
|
1391
|
+
} : {
|
|
1392
|
+
name: "1lf8z6",
|
|
1393
|
+
styles: "max-height:50vh;overflow:auto",
|
|
1394
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImV4cG9ydC1maWVsZHMtc2VsZWN0aW9uLXN0ZXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCbUMiLCJmaWxlIjoiZXhwb3J0LWZpZWxkcy1zZWxlY3Rpb24tc3RlcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VJbnRsIH0gZnJvbSAncmVhY3QtaW50bCdcbmltcG9ydCB0aHJvdHRsZSBmcm9tICdsb2Rhc2gvdGhyb3R0bGUnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEZvcm1EaWFsb2cgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJ1xuaW1wb3J0IHtcbiAgQ2FyZCxcbiAgR3JpZCxcbiAgU3BhY2luZ3MsXG4gIFNlYXJjaFRleHRJbnB1dCxcbiAgZGVzaWduVG9rZW5zLFxufSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi4vLi4vbWVzc2FnZXMnXG5pbXBvcnQgeyB1c2VFeHBvcnRSZXNvdXJjZXNDb250ZXh0IH0gZnJvbSAnLi4vLi4vQGhvb2tzJ1xuaW1wb3J0IHsgT1BFUkFUSU9OU19FWFBPUlRfUkVTT1VSQ0VTX01PREFMX1NFTEVDVElPTiB9IGZyb20gJy4uLy4uL0Bjb25zdGFudHMnXG5pbXBvcnQgeyBOb1NlYXJjaFJlc3VsdHMgfSBmcm9tICcuLi9uby1zZWFyY2gtcmVzdWx0cydcbmltcG9ydCB7IHVzZVN0b3JhZ2UgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9leHBlcmltZW50YWwtY29tcG9uZW50cydcbmltcG9ydCB7IHVzZUFwcGxpY2F0aW9uQ29udGV4dCB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLXNoZWxsLWNvbm5lY3RvcnMnXG5pbXBvcnQgRXhwb3J0RmllbGRTZWxlY3Rpb25Qcm92aWRlciBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgeyBGaWVsZEdyb3VwU2VjdGlvbiB9IGZyb20gJy4vZmllbGQtZ3JvdXAtc2VjdGlvbidcblxuY29uc3QgU3R5bGVkR3JpZENhcmQgPSBzdHlsZWQoQ2FyZClgXG4gIG1heC1oZWlnaHQ6IDUwdmg7XG4gIG92ZXJmbG93OiBhdXRvO1xuYFxuXG5leHBvcnQgY29uc3QgRXhwb3J0RmllbGRzU2VsZWN0aW9uU3RlcCA9ICgpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKVxuICBjb25zdCBbZmllbGRTZWFyY2hUZXJtLCBzZXRGaWVsZFNlYXJjaFRlcm1dID0gUmVhY3QudXNlU3RhdGUoJycpXG4gIGNvbnN0IHsgcHJvamVjdEtleSB9ID0gdXNlQXBwbGljYXRpb25Db250ZXh0KChjb250ZXh0KSA9PiAoe1xuICAgIHByb2plY3RLZXk6IGNvbnRleHQucHJvamVjdD8ua2V5LFxuICB9KSlcbiAgY29uc3QgW18sIHNldENhY2hlZFNlbGVjdGVkR3JvdXBzXSA9IHVzZVN0b3JhZ2UoXG4gICAgYCR7cHJvamVjdEtleX0vJHtPUEVSQVRJT05TX0VYUE9SVF9SRVNPVVJDRVNfTU9EQUxfU0VMRUNUSU9OfWAsXG4gICAge31cbiAgKVxuICBjb25zdCB7IGZvcm1paywgc2V0Q3VycmVudFN0ZXAsIHJlc291cmNlVHlwZSwgb25DbG9zZSB9ID1cbiAgICB1c2VFeHBvcnRSZXNvdXJjZXNDb250ZXh0KClcblxuICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xuICAgIGZvcm1pay52YWxpZGF0ZUZvcm0oKVxuICAgIGNvbnN0IHNlbGVjdGVkRmllbGRzID0ge31cbiAgICBmdW5jdGlvbiBnZXRTZWxlY3RlZEZpZWxkcyhmaWVsZCwgZ3JvdXBOYW1lKSB7XG4gICAgICBjb25zdCBmaWVsZE5hbWUgPSBmaWVsZC5uYW1lID8gYCR7Z3JvdXBOYW1lfS4ke2ZpZWxkLm5hbWV9YCA6IGdyb3VwTmFtZVxuICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICByZXR1cm4gZmllbGQuZmllbGRzLmZvckVhY2goKGYpID0+IGdldFNlbGVjdGVkRmllbGRzKGYsIGZpZWxkTmFtZSkpXG4gICAgICB9XG5cbiAgICAgIHNlbGVjdGVkRmllbGRzW2ZpZWxkTmFtZV0gPSBmaWVsZC5pc0NoZWNrZWRcbiAgICB9XG4gICAgZm9ybWlrLnZhbHVlcy5ncm91cHMuZm9yRWFjaCgoZ3JvdXApID0+XG4gICAgICBnZXRTZWxlY3RlZEZpZWxkcyhncm91cCwgZ3JvdXAuZ3JvdXBMYWJlbClcbiAgICApXG4gICAgc2V0Q2FjaGVkU2VsZWN0ZWRHcm91cHMoe1xuICAgICAgW3Jlc291cmNlVHlwZV06IHNlbGVjdGVkRmllbGRzLFxuICAgIH0pXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0LWhvb2tzL2V4aGF1c3RpdmUtZGVwc1xuICB9LCBbZm9ybWlrLnZhbHVlcy5ncm91cHNdKVxuICAvLyBhZGRzIGBpc0hpZGRlbmAgcHJvcGVydHkgdG8gZWFjaCBmaWVsZCBiYXNlZCBvbiBzZWFyY2ggdGVybVxuICBjb25zdCBmaWx0ZXJlZEdyb3VwcyA9IFJlYWN0LnVzZU1lbW8oKCkgPT4ge1xuICAgIGNvbnN0IHVwZGF0ZUZpZWxkcyA9IChmaWVsZHMsIHBhcmVudE1hdGNoZXM6IGJvb2xlYW4pID0+IHtcbiAgICAgIHJldHVybiBmaWVsZHMubWFwKChmaWVsZCkgPT4ge1xuICAgICAgICBjb25zdCBtYXRjaGVzID0gZmllbGQubGFiZWxcbiAgICAgICAgICAudG9Mb3dlckNhc2UoKVxuICAgICAgICAgIC5pbmNsdWRlcyhmaWVsZFNlYXJjaFRlcm0udG9Mb3dlckNhc2UoKSlcbiAgICAgICAgbGV0IGlzSGlkZGVuID0gIW1hdGNoZXMgJiYgIXBhcmVudE1hdGNoZXNcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIGNvbnN0IHVwZGF0ZWRGaWVsZHMgPSB1cGRhdGVGaWVsZHMoZmllbGQuZmllbGRzLCBtYXRjaGVzKVxuICAgICAgICAgIGlzSGlkZGVuID0gaXNIaWRkZW4gJiYgdXBkYXRlZEZpZWxkcy5ldmVyeSgoZikgPT4gZi5pc0hpZGRlbilcbiAgICAgICAgICBmaWVsZCA9IHtcbiAgICAgICAgICAgIC4uLmZpZWxkLFxuICAgICAgICAgICAgZmllbGRzOiB1cGRhdGVkRmllbGRzLFxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyAuLi5maWVsZCwgaXNIaWRkZW4gfVxuICAgICAgfSlcbiAgICB9XG4gICAgaWYgKCFmaWVsZFNlYXJjaFRlcm0/LnRyaW0oKT8ubGVuZ3RoKSByZXR1cm4gZm9ybWlrLnZhbHVlcy5ncm91cHNcblxuICAgIHJldHVybiBmb3JtaWsudmFsdWVzLmdyb3Vwcy5tYXAoKGdyb3VwKSA9PiB7XG4gICAgICBjb25zdCB1cGRhdGVkRmllbGRzID0gdXBkYXRlRmllbGRzKGdyb3VwLmZpZWxkcywgZmFsc2UpXG4gICAgICBjb25zdCBpc0hpZGRlbiA9IHVwZGF0ZWRGaWVsZHMuZXZlcnkoKGZpZWxkKSA9PiBmaWVsZC5pc0hpZGRlbilcbiAgICAgIHJldHVybiB7IC4uLmdyb3VwLCBmaWVsZHM6IHVwZGF0ZWRGaWVsZHMsIGlzSGlkZGVuIH1cbiAgICB9KVxuICB9LCBbZm9ybWlrLnZhbHVlcy5ncm91cHMsIGZpZWxkU2VhcmNoVGVybV0pXG5cbiAgY29uc3Qgb25TZWFyY2hDaGFuZ2UgPSBSZWFjdC51c2VDYWxsYmFjayhcbiAgICAoZXZlbnQpID0+IHtcbiAgICAgIHNldEZpZWxkU2VhcmNoVGVybShldmVudC50YXJnZXQudmFsdWUpXG4gICAgfSxcbiAgICBbc2V0RmllbGRTZWFyY2hUZXJtXVxuICApXG5cbiAgY29uc3QgaGFzUmVzdWx0cyA9IEJvb2xlYW4oZmlsdGVyZWRHcm91cHMuZmluZCgoZ3JvdXApID0+ICFncm91cC5pc0hpZGRlbikpXG5cbiAgY29uc3Qgb25TZWFyY2hDaGFuZ2VUaHJvdHRsZWQgPSBSZWFjdC51c2VNZW1vKFxuICAgICgpID0+IHRocm90dGxlKG9uU2VhcmNoQ2hhbmdlLCAzMDApLFxuICAgIFtvblNlYXJjaENoYW5nZV1cbiAgKVxuXG4gIGNvbnN0IG9uU2VhcmNoUmVzZXQgPSAoKSA9PiB7XG4gICAgc2V0RmllbGRTZWFyY2hUZXJtKCcnKVxuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybURpYWxvZ1xuICAgICAgaXNPcGVuXG4gICAgICB0aXRsZT17aW50bC5mb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLnNlbGVjdEZpZWxkc1RvRXhwb3J0KX1cbiAgICAgIGxhYmVsUHJpbWFyeT17aW50bC5mb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLnN0YXJ0RXhwb3J0KX1cbiAgICAgIG9uUHJpbWFyeUJ1dHRvbkNsaWNrPXtmb3JtaWsuc3VibWl0Rm9ybX1cbiAgICAgIGlzUHJpbWFyeUJ1dHRvbkRpc2FibGVkPXshZm9ybWlrLmlzVmFsaWR9XG4gICAgICBsYWJlbFNlY29uZGFyeT17aW50bC5mb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmJhY2spfVxuICAgICAgb25TZWNvbmRhcnlCdXR0b25DbGljaz17KCkgPT4gc2V0Q3VycmVudFN0ZXAoMSl9XG4gICAgICBvbkNsb3NlPXtvbkNsb3NlfVxuICAgICAgc2l6ZT17MTZ9XG4gICAgPlxuICAgICAgPEV4cG9ydEZpZWxkU2VsZWN0aW9uUHJvdmlkZXIgcmVzb3VyY2VUeXBlPXtyZXNvdXJjZVR5cGV9PlxuICAgICAgICA8U3BhY2luZ3MuU3RhY2sgc2NhbGU9XCJtXCI+XG4gICAgICAgICAgPFNlYXJjaFRleHRJbnB1dFxuICAgICAgICAgICAgcGxhY2Vob2xkZXI9e2ludGwuZm9ybWF0TWVzc2FnZShtZXNzYWdlcy5zZWFyY2hGb3JGaWVsZHMpfVxuICAgICAgICAgICAgdmFsdWU9e2ZpZWxkU2VhcmNoVGVybX1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtvblNlYXJjaENoYW5nZVRocm90dGxlZH1cbiAgICAgICAgICAgIG9uUmVzZXQ9e29uU2VhcmNoUmVzZXR9XG4gICAgICAgICAgICAvLyBUT0RPOiBgU2VhcmNoVGV4dElucHV0YCBwcm9wcyB0byBiZSBpbXByb3ZlZC4gVGhlIGBvblN1Ym1pdGAgY2FsbGJhY2sgc2hvdWxkbid0IGJlIG1hbmRhdG9yeVxuICAgICAgICAgICAgb25TdWJtaXQ9eygpID0+IHt9fVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2hhc1Jlc3VsdHMgPyAoXG4gICAgICAgICAgICA8U3R5bGVkR3JpZENhcmQgaW5zZXRTY2FsZT1cIm5vbmVcIj5cbiAgICAgICAgICAgICAgPEdyaWRcbiAgICAgICAgICAgICAgICBncmlkQXV0b0Zsb3c9XCJyb3dcIlxuICAgICAgICAgICAgICAgIGdyaWRUZW1wbGF0ZUNvbHVtbnM9e2BjYWxjKCR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfSArICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ1fSArICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfSkgYXV0b2B9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7ZmlsdGVyZWRHcm91cHMubWFwKChncm91cCwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgICAgIDxGaWVsZEdyb3VwU2VjdGlvblxuICAgICAgICAgICAgICAgICAgICBrZXk9e2dyb3VwLmdyb3VwTGFiZWx9XG4gICAgICAgICAgICAgICAgICAgIGdyb3VwPXtncm91cH1cbiAgICAgICAgICAgICAgICAgICAgaW5kZXg9e2luZGV4fVxuICAgICAgICAgICAgICAgICAgICBmb3JtaWs9e2Zvcm1pa31cbiAgICAgICAgICAgICAgICAgICAgaXNGb3JjZUV4cGFuZGVkPXtmaWVsZFNlYXJjaFRlcm0/LnRyaW0oKT8ubGVuZ3RoID4gMH1cbiAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgKSl9XG4gICAgICAgICAgICAgIDwvR3JpZD5cbiAgICAgICAgICAgIDwvU3R5bGVkR3JpZENhcmQ+XG4gICAgICAgICAgKSA6IChcbiAgICAgICAgICAgIDxOb1NlYXJjaFJlc3VsdHMgLz5cbiAgICAgICAgICApfVxuICAgICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPC9FeHBvcnRGaWVsZFNlbGVjdGlvblByb3ZpZGVyPlxuICAgIDwvRm9ybURpYWxvZz5cbiAgKVxufVxuIl19 */",
|
|
1395
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
1396
|
+
});
|
|
1068
1397
|
const ExportFieldsSelectionStep = () => {
|
|
1398
|
+
var _context, _context7, _context8;
|
|
1069
1399
|
const intl = reactIntl.useIntl();
|
|
1070
1400
|
const _React$useState = React__default["default"].useState(''),
|
|
1071
1401
|
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
1072
1402
|
fieldSearchTerm = _React$useState2[0],
|
|
1073
1403
|
setFieldSearchTerm = _React$useState2[1];
|
|
1074
|
-
const _useApplicationContex = applicationShellConnectors.useApplicationContext(context =>
|
|
1075
|
-
|
|
1076
|
-
|
|
1404
|
+
const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => {
|
|
1405
|
+
var _context$project;
|
|
1406
|
+
return {
|
|
1407
|
+
projectKey: (_context$project = context.project) === null || _context$project === void 0 ? void 0 : _context$project.key
|
|
1408
|
+
};
|
|
1409
|
+
}),
|
|
1077
1410
|
projectKey = _useApplicationContex.projectKey;
|
|
1078
|
-
const _useStorage = experimentalComponents.useStorage(
|
|
1411
|
+
const _useStorage = experimentalComponents.useStorage(_concatInstanceProperty__default["default"](_context = "".concat(projectKey, "/")).call(_context, OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION), {}),
|
|
1079
1412
|
_useStorage2 = _slicedToArray(_useStorage, 2);
|
|
1080
1413
|
_useStorage2[0];
|
|
1081
1414
|
const setCachedSelectedGroups = _useStorage2[1];
|
|
@@ -1085,18 +1418,19 @@ const ExportFieldsSelectionStep = () => {
|
|
|
1085
1418
|
resourceType = _useExportResourcesCo.resourceType,
|
|
1086
1419
|
onClose = _useExportResourcesCo.onClose;
|
|
1087
1420
|
React__default["default"].useEffect(() => {
|
|
1088
|
-
var
|
|
1421
|
+
var _context4;
|
|
1089
1422
|
formik.validateForm();
|
|
1090
1423
|
const selectedFields = {};
|
|
1091
1424
|
function getSelectedFields(field, groupName) {
|
|
1092
|
-
|
|
1425
|
+
var _context2;
|
|
1426
|
+
const fieldName = field.name ? _concatInstanceProperty__default["default"](_context2 = "".concat(groupName, ".")).call(_context2, field.name) : groupName;
|
|
1093
1427
|
if (field.fields) {
|
|
1094
|
-
var
|
|
1095
|
-
return _forEachInstanceProperty__default["default"](
|
|
1428
|
+
var _context3;
|
|
1429
|
+
return _forEachInstanceProperty__default["default"](_context3 = field.fields).call(_context3, f => getSelectedFields(f, fieldName));
|
|
1096
1430
|
}
|
|
1097
1431
|
selectedFields[fieldName] = field.isChecked;
|
|
1098
1432
|
}
|
|
1099
|
-
_forEachInstanceProperty__default["default"](
|
|
1433
|
+
_forEachInstanceProperty__default["default"](_context4 = _valuesInstanceProperty__default["default"](formik).groups).call(_context4, group => getSelectedFields(group, group.groupLabel));
|
|
1100
1434
|
setCachedSelectedGroups({
|
|
1101
1435
|
[resourceType]: selectedFields
|
|
1102
1436
|
});
|
|
@@ -1104,11 +1438,11 @@ const ExportFieldsSelectionStep = () => {
|
|
|
1104
1438
|
}, [_valuesInstanceProperty__default["default"](formik).groups]);
|
|
1105
1439
|
// adds `isHidden` property to each field based on search term
|
|
1106
1440
|
const filteredGroups = React__default["default"].useMemo(() => {
|
|
1107
|
-
var
|
|
1441
|
+
var _fieldSearchTerm$trim, _context6;
|
|
1108
1442
|
const updateFields = (fields, parentMatches) => {
|
|
1109
1443
|
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1110
|
-
var
|
|
1111
|
-
const matches = _includesInstanceProperty__default["default"](
|
|
1444
|
+
var _context5;
|
|
1445
|
+
const matches = _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
|
|
1112
1446
|
let isHidden = !matches && !parentMatches;
|
|
1113
1447
|
if (field.fields) {
|
|
1114
1448
|
const updatedFields = updateFields(field.fields, matches);
|
|
@@ -1122,8 +1456,8 @@ const ExportFieldsSelectionStep = () => {
|
|
|
1122
1456
|
});
|
|
1123
1457
|
});
|
|
1124
1458
|
};
|
|
1125
|
-
if (!fieldSearchTerm
|
|
1126
|
-
return _mapInstanceProperty__default["default"](
|
|
1459
|
+
if (!(fieldSearchTerm !== null && fieldSearchTerm !== void 0 && (_fieldSearchTerm$trim = _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm)) !== null && _fieldSearchTerm$trim !== void 0 && _fieldSearchTerm$trim.length)) return _valuesInstanceProperty__default["default"](formik).groups;
|
|
1460
|
+
return _mapInstanceProperty__default["default"](_context6 = _valuesInstanceProperty__default["default"](formik).groups).call(_context6, group => {
|
|
1127
1461
|
const updatedFields = updateFields(group.fields, false);
|
|
1128
1462
|
const isHidden = _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, field => field.isHidden);
|
|
1129
1463
|
return _objectSpread$2(_objectSpread$2({}, group), {}, {
|
|
@@ -1142,7 +1476,7 @@ const ExportFieldsSelectionStep = () => {
|
|
|
1142
1476
|
};
|
|
1143
1477
|
return jsxRuntime.jsx(applicationComponents.FormDialog, {
|
|
1144
1478
|
isOpen: true,
|
|
1145
|
-
title: intl.formatMessage(messages
|
|
1479
|
+
title: intl.formatMessage(messages.selectFieldsToExport),
|
|
1146
1480
|
labelPrimary: intl.formatMessage(messages.startExport),
|
|
1147
1481
|
onPrimaryButtonClick: formik.submitForm,
|
|
1148
1482
|
isPrimaryButtonDisabled: !formik.isValid,
|
|
@@ -1150,21 +1484,11 @@ const ExportFieldsSelectionStep = () => {
|
|
|
1150
1484
|
onSecondaryButtonClick: () => setCurrentStep(1),
|
|
1151
1485
|
onClose: onClose,
|
|
1152
1486
|
size: 16,
|
|
1153
|
-
children: jsxRuntime.jsx(
|
|
1154
|
-
|
|
1487
|
+
children: jsxRuntime.jsx(ExportFieldSelectionProvider, {
|
|
1488
|
+
resourceType: resourceType,
|
|
1155
1489
|
children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
|
|
1156
1490
|
scale: "m",
|
|
1157
|
-
children: [jsxRuntime.
|
|
1158
|
-
justifyContent: "space-between",
|
|
1159
|
-
children: [jsxRuntime.jsx(uiKit.Text.Body, {
|
|
1160
|
-
intlMessage: messages.selectFieldsToExport
|
|
1161
|
-
}), jsxRuntime.jsx(uiKit.Link, {
|
|
1162
|
-
isExternal: true,
|
|
1163
|
-
tone: "secondary",
|
|
1164
|
-
intlMessage: messages.fieldDefinitions,
|
|
1165
|
-
to: FIELD_DEFINITIONS_URLS[resourceType]
|
|
1166
|
-
})]
|
|
1167
|
-
}), jsxRuntime.jsx(uiKit.SearchTextInput, {
|
|
1491
|
+
children: [jsxRuntime.jsx(uiKit.SearchTextInput, {
|
|
1168
1492
|
placeholder: intl.formatMessage(messages.searchForFields),
|
|
1169
1493
|
value: fieldSearchTerm,
|
|
1170
1494
|
onChange: onSearchChangeThrottled,
|
|
@@ -1176,12 +1500,16 @@ const ExportFieldsSelectionStep = () => {
|
|
|
1176
1500
|
insetScale: "none",
|
|
1177
1501
|
children: jsxRuntime.jsx(uiKit.Grid, {
|
|
1178
1502
|
gridAutoFlow: "row",
|
|
1179
|
-
gridTemplateColumns:
|
|
1180
|
-
children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) =>
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1503
|
+
gridTemplateColumns: _concatInstanceProperty__default["default"](_context7 = _concatInstanceProperty__default["default"](_context8 = "calc(".concat(uiKit.designTokens.spacingL, " + ")).call(_context8, uiKit.designTokens.constraint5, " + ")).call(_context7, uiKit.designTokens.spacingL, ") auto"),
|
|
1504
|
+
children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) => {
|
|
1505
|
+
var _fieldSearchTerm$trim2;
|
|
1506
|
+
return jsxRuntime.jsx(FieldGroupSection, {
|
|
1507
|
+
group: group,
|
|
1508
|
+
index: index,
|
|
1509
|
+
formik: formik,
|
|
1510
|
+
isForceExpanded: (fieldSearchTerm === null || fieldSearchTerm === void 0 || (_fieldSearchTerm$trim2 = _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm)) === null || _fieldSearchTerm$trim2 === void 0 ? void 0 : _fieldSearchTerm$trim2.length) > 0
|
|
1511
|
+
}, group.groupLabel);
|
|
1512
|
+
})
|
|
1185
1513
|
})
|
|
1186
1514
|
}) : jsxRuntime.jsx(NoSearchResults, {})]
|
|
1187
1515
|
})
|
|
@@ -1198,13 +1526,14 @@ const ExportResourcesContext = /*#__PURE__*/React.createContext();
|
|
|
1198
1526
|
function ownKeys$1(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1199
1527
|
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
1200
1528
|
const ExportResourcesProvider = props => {
|
|
1529
|
+
var _props$selectedResour;
|
|
1201
1530
|
const initialValues = useInitialValues(props);
|
|
1202
1531
|
const _React$useState = React__default["default"].useState(1),
|
|
1203
1532
|
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
1204
1533
|
currentStep = _React$useState2[0],
|
|
1205
1534
|
setCurrentStep = _React$useState2[1];
|
|
1206
1535
|
const _React$useState3 = React__default["default"].useState({
|
|
1207
|
-
exportType: props.selectedResourceIds
|
|
1536
|
+
exportType: (_props$selectedResour = props.selectedResourceIds) !== null && _props$selectedResour !== void 0 && _props$selectedResour.length ? EXPORT_TYPES.SELECTED : EXPORT_TYPES.ALL,
|
|
1208
1537
|
selectedResourceIds: props.selectedResourceIds
|
|
1209
1538
|
}),
|
|
1210
1539
|
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
|
@@ -1295,8 +1624,8 @@ const loadMessages = async locale => {
|
|
|
1295
1624
|
return i18n.parseChunkImport(chunkImport);
|
|
1296
1625
|
} catch (error) {
|
|
1297
1626
|
// eslint-disable-next-line no-console
|
|
1298
|
-
console.warn(
|
|
1299
|
-
sentry.reportErrorToSentry(new Error(
|
|
1627
|
+
console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
|
|
1628
|
+
sentry.reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
|
|
1300
1629
|
extra: error
|
|
1301
1630
|
});
|
|
1302
1631
|
return {};
|