@commercetools-frontend-extensions/export-resources-modal 3.7.0 → 4.0.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.
Files changed (40) hide show
  1. package/README.md +166 -138
  2. package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.d.ts +3 -0
  3. package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.dev.js +417 -412
  4. package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.prod.js +410 -402
  5. package/dist/commercetools-frontend-extensions-export-resources-modal.esm.js +410 -405
  6. package/dist/de-a34c5dd4.cjs.dev.js +6 -0
  7. package/dist/de-cd6c45d3.esm.js +4 -0
  8. package/dist/de-d954fe3d.cjs.prod.js +6 -0
  9. package/dist/declarations/src/@constants/delimiters.d.ts +4 -0
  10. package/dist/declarations/src/@constants/export-operation-states.d.ts +5 -0
  11. package/dist/declarations/src/@constants/export-types.d.ts +5 -0
  12. package/dist/declarations/src/@constants/exportable-resources.d.ts +5 -0
  13. package/dist/declarations/src/@constants/index.d.ts +7 -0
  14. package/dist/declarations/src/@constants/misc.d.ts +1 -0
  15. package/dist/declarations/src/@constants/output-formats.d.ts +8 -0
  16. package/dist/declarations/src/@constants/urls.d.ts +3 -0
  17. package/dist/declarations/src/@types/export-resources-modal-shape.d.ts +27 -0
  18. package/dist/declarations/src/@types/formik.d.ts +11 -0
  19. package/dist/declarations/src/@types/index.d.ts +2 -0
  20. package/dist/declarations/src/export-resources-modal.d.ts +13 -0
  21. package/dist/declarations/src/index.d.ts +3 -0
  22. package/dist/en-3a9aa2d4.esm.js +4 -0
  23. package/dist/en-6b3694f6.cjs.dev.js +6 -0
  24. package/dist/en-c7757448.cjs.prod.js +6 -0
  25. package/dist/es-042343bd.cjs.prod.js +6 -0
  26. package/dist/es-8b3ecab1.cjs.dev.js +6 -0
  27. package/dist/es-e544023d.esm.js +4 -0
  28. package/dist/fr-FR-9d9081ee.esm.js +4 -0
  29. package/dist/fr-FR-e7126fcc.cjs.dev.js +6 -0
  30. package/dist/fr-FR-fce1ca96.cjs.prod.js +6 -0
  31. package/dist/ja-37632763.cjs.prod.js +6 -0
  32. package/dist/ja-73c088a7.esm.js +4 -0
  33. package/dist/ja-9bd5f452.cjs.dev.js +6 -0
  34. package/dist/pt-BR-b37d730b.esm.js +4 -0
  35. package/dist/pt-BR-ea6b3251.cjs.dev.js +6 -0
  36. package/dist/pt-BR-ec2a1a11.cjs.prod.js +6 -0
  37. package/dist/zh-CN-4780d88e.esm.js +4 -0
  38. package/dist/zh-CN-52baa549.cjs.prod.js +6 -0
  39. package/dist/zh-CN-d4bc6d26.cjs.dev.js +6 -0
  40. package/package.json +30 -19
@@ -11,14 +11,13 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
11
11
  var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
12
12
  var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
13
13
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
- var React = require('react');
14
+ var reactIntl = require('react-intl');
15
+ var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
15
16
  var uiKit = require('@commercetools-frontend/ui-kit');
16
17
  var jsxRuntime = require('@emotion/react/jsx-runtime');
17
18
  require('@commercetools-uikit/design-system');
18
- var reactIntl = require('react-intl');
19
19
  var _valuesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/values');
20
20
  var applicationComponents = require('@commercetools-frontend/application-components');
21
- var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
22
21
  var _Reflect$construct = require('@babel/runtime-corejs3/core-js-stable/reflect/construct');
23
22
  var _createClass = require('@babel/runtime-corejs3/helpers/createClass');
24
23
  var _classCallCheck = require('@babel/runtime-corejs3/helpers/classCallCheck');
@@ -26,31 +25,33 @@ var _inherits = require('@babel/runtime-corejs3/helpers/inherits');
26
25
  var _possibleConstructorReturn = require('@babel/runtime-corejs3/helpers/possibleConstructorReturn');
27
26
  var _getPrototypeOf = require('@babel/runtime-corejs3/helpers/getPrototypeOf');
28
27
  var _wrapNativeSuper = require('@babel/runtime-corejs3/helpers/wrapNativeSuper');
29
- var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
30
- var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
28
+ var React = require('react');
31
29
  var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
32
30
  var moment = require('moment');
31
+ var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
33
32
  var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
34
33
  var omitEmpty = require('omit-empty-es');
34
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
35
35
  var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
36
- var _flatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat');
37
- var _flatMapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat-map');
38
36
  var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
39
37
  var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
40
- var _startsWithInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
41
- var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
38
+ var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
42
39
  var sdk = require('@commercetools-frontend/sdk');
43
40
  var actionsGlobal = require('@commercetools-frontend/actions-global');
44
41
  var constants = require('@commercetools-frontend/constants');
45
42
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
46
43
  var _styled = require('@emotion/styled/base');
47
44
  var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
48
- var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
45
+ var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
49
46
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
47
+ var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
50
48
  var throttle = require('lodash/throttle');
51
49
  var react = require('@emotion/react');
50
+ var get = require('lodash/get');
52
51
  var PropTypes = require('prop-types');
53
52
  var formik = require('formik');
53
+ var sentry = require('@commercetools-frontend/sentry');
54
+ var i18n = require('@commercetools-frontend/i18n');
54
55
 
55
56
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
56
57
 
@@ -62,26 +63,26 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
62
63
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
63
64
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
64
65
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
65
- var React__default = /*#__PURE__*/_interopDefault(React);
66
66
  var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
67
67
  var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
68
- var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
68
+ var React__default = /*#__PURE__*/_interopDefault(React);
69
69
  var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
70
70
  var moment__default = /*#__PURE__*/_interopDefault(moment);
71
+ var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
71
72
  var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
72
73
  var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
74
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
73
75
  var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
74
- var _flatInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatInstanceProperty);
75
- var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
76
76
  var _Set__default = /*#__PURE__*/_interopDefault(_Set);
77
77
  var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
78
- var _startsWithInstanceProperty__default = /*#__PURE__*/_interopDefault(_startsWithInstanceProperty);
79
- var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
78
+ var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
80
79
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
81
80
  var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
82
- var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
81
+ var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
83
82
  var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
83
+ var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
84
84
  var throttle__default = /*#__PURE__*/_interopDefault(throttle);
85
+ var get__default = /*#__PURE__*/_interopDefault(get);
85
86
  var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
86
87
 
87
88
  function getBold(msg) {
@@ -216,21 +217,6 @@ var messages = reactIntl.defineMessages({
216
217
  description: 'Label for "Field definitions" link',
217
218
  defaultMessage: 'Field definitions'
218
219
  },
219
- allGeneralFields: {
220
- id: 'ExportResourcesModal.allGeneralFields',
221
- description: 'Label for "All general fields" checkbox',
222
- defaultMessage: 'All general fields'
223
- },
224
- allCustomFields: {
225
- id: 'ExportResourcesModal.allCustomFields',
226
- description: 'Label for "All custom fields" checkbox',
227
- defaultMessage: 'All custom fields'
228
- },
229
- customTypeKeyAndTypeId: {
230
- id: 'ExportResourcesModal.customTypeKeyAndTypeId',
231
- description: 'Label for "Custom type key and typeId" checkbox',
232
- defaultMessage: 'Custom type key and typeId'
233
- },
234
220
  unexpectedError: {
235
221
  id: 'ExportResourcesModal.unexpectedError',
236
222
  description: 'Generic notification message when starting export process fails',
@@ -263,14 +249,14 @@ var messages = reactIntl.defineMessages({
263
249
  }
264
250
  });
265
251
 
266
- 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; }
267
- function _objectSpread$6(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$6(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$6(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
252
+ 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; }
253
+ function _objectSpread$4(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$4(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$4(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
268
254
  function renderFileNameError(key) {
269
255
  switch (key) {
270
256
  case 'missing':
271
- return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$6({}, messages.missingFileNameError));
257
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$4({}, messages.missingFileNameError));
272
258
  case 'invalidInput':
273
- return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$6({}, messages.invalidFileNameError));
259
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$4({}, messages.invalidFileNameError));
274
260
  default:
275
261
  return null;
276
262
  }
@@ -278,7 +264,7 @@ function renderFileNameError(key) {
278
264
  function renderLocaleError(key) {
279
265
  switch (key) {
280
266
  case 'missing':
281
- return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$6({}, messages.missingLocaleError));
267
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$4({}, messages.missingLocaleError));
282
268
  default:
283
269
  return null;
284
270
  }
@@ -373,7 +359,7 @@ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
373
359
  function UnexpectedResourceTypeError(resourceType) {
374
360
  var _this;
375
361
  _classCallCheck(this, UnexpectedResourceTypeError);
376
- _this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
362
+ _this = _super.call(this, "Unexpected resource type \"".concat(resourceType, "\""));
377
363
  _this.name = 'UnexpectedResourceTypeError';
378
364
  return _this;
379
365
  }
@@ -403,41 +389,50 @@ function useExportResourcesContext() {
403
389
  return context;
404
390
  }
405
391
 
392
+ function checkAtLeastOneFieldChecked$1(fields) {
393
+ return _someInstanceProperty__default["default"](fields).call(fields, field => {
394
+ if (field.fields) {
395
+ return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
396
+ }
397
+ return field.isChecked;
398
+ });
399
+ }
406
400
  function validate(_ref) {
407
401
  let values = _valuesInstanceProperty__default["default"](_ref),
408
402
  step = _ref.step;
409
403
  const fileName = values.fileName,
410
404
  locales = values.locales,
411
- fields = values.fields,
412
- customFields = values.customFields;
405
+ groups = values.groups;
413
406
  const errors = {
414
407
  fileName: {},
415
408
  locales: {},
416
409
  fields: {}
417
410
  };
418
411
  if (uiKit.TextInput.isEmpty(fileName)) {
412
+ // @ts-ignore
419
413
  errors.fileName.missing = true;
420
414
  } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
415
+ // @ts-ignore
421
416
  errors.fileName.invalidInput = true;
422
417
  }
423
418
  if (locales.length < 1) {
419
+ // @ts-ignore
424
420
  errors.locales.missing = true;
425
421
  }
426
422
  if (step === 2) {
427
- const checkedGeneralFieldsCount = _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked).length;
428
- const checkedCustomFieldsCount = _reduceInstanceProperty__default["default"](customFields).call(customFields, (count, customType) => {
429
- var _context;
430
- return count + _filterInstanceProperty__default["default"](_context = customType.fields).call(_context, field => field.isChecked).length;
431
- }, 0);
432
- if (checkedGeneralFieldsCount + checkedCustomFieldsCount < 2) {
423
+ const allFields = _reduceInstanceProperty__default["default"](groups).call(groups, (acc, group) => _concatInstanceProperty__default["default"](acc).call(acc, group.fields), []);
424
+ const checkedFieldsCount = _filterInstanceProperty__default["default"](allFields).call(allFields, field => {
425
+ if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
426
+ return !field.isRequired && !field.isReadOnly && field.isChecked;
427
+ }).length;
428
+ if (checkedFieldsCount < 1) {
429
+ // @ts-ignore
433
430
  errors.fields.missing = true;
434
431
  }
435
432
  }
436
433
  return omitEmpty__default["default"](errors);
437
434
  }
438
435
 
439
- 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; }
440
- function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context8, _context9; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context8 = ownKeys$5(Object(t), !0)).call(_context8, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context9 = ownKeys$5(Object(t))).call(_context9, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
441
436
  function resourceTypeToDisplayName(_ref) {
442
437
  let resourceType = _ref.resourceType,
443
438
  _ref$isUpperCase = _ref.isUpperCase,
@@ -456,7 +451,7 @@ function resourceTypeToDisplayName(_ref) {
456
451
  displayName = isPlural ? 'Discount codes' : 'Discount code';
457
452
  break;
458
453
  default:
459
- throw UnexpectedResourceTypeError(resourceType);
454
+ throw new UnexpectedResourceTypeError(resourceType);
460
455
  }
461
456
  return isUpperCase ? displayName : displayName.toLowerCase();
462
457
  }
@@ -475,84 +470,36 @@ function appendCsvOrJsonExtensionIfAbsent(fileName, fileFormat) {
475
470
  if (!extensionRegex.test(fileName)) return _concatInstanceProperty__default["default"](_context = "".concat(fileName, ".")).call(_context, fileFormat);
476
471
  return fileName;
477
472
  }
478
- function flattenNestedFields(fields) {
479
- const result = (fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, field => {
480
- if (isFilledArray(field.fields)) {
481
- var _context2;
482
- return _mapInstanceProperty__default["default"](_context2 = flattenNestedFields(field.fields)).call(_context2, nestedField => {
483
- var _context3;
484
- return _objectSpread$5(_objectSpread$5({}, nestedField), {}, {
485
- name: _concatInstanceProperty__default["default"](_context3 = "".concat(field.name, ".")).call(_context3, nestedField.name)
486
- });
487
- });
488
- }
489
- return field;
490
- })) || [];
491
- return _flatInstanceProperty__default["default"](result).call(result);
492
- }
493
- function getSelectedGeneralFields(fields) {
494
- return _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked);
495
- }
496
- function getSelectedCustomFields(customFields) {
497
- return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
498
- var _context4;
499
- return _objectSpread$5(_objectSpread$5({}, customType), {}, {
500
- fields: _filterInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => field.isChecked)
501
- });
502
- });
503
- }
504
- function checkRequiredFields(fields) {
505
- return _mapInstanceProperty__default["default"](fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
506
- isChecked: true
507
- }) : field);
508
- }
509
473
  function getExportLogsLink(projectKey, msg) {
510
474
  return jsxRuntime.jsx(uiKit.Link, {
511
475
  to: "/".concat(projectKey, "/operations/export/logs"),
512
476
  children: msg
513
477
  });
514
478
  }
515
- function setInitialCheckedStateForCustomFields(customFields) {
516
- return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
517
- var _context5;
518
- return _objectSpread$5(_objectSpread$5({}, customType), {}, {
519
- fields: _mapInstanceProperty__default["default"](_context5 = customType.fields).call(_context5, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
520
- isChecked: false
521
- }))
522
- });
523
- });
524
- }
525
- function extractGeneralFieldNames(generalFields) {
526
- return _mapInstanceProperty__default["default"](generalFields).call(generalFields, field => field.name);
527
- }
528
- function extractCustomFieldNamesWithPrefix(customFields) {
529
- const fields = _flatMapInstanceProperty__default["default"](customFields).call(customFields, customType => {
530
- var _context6;
531
- return _flatMapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => {
532
- return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
533
- });
534
- });
535
- return [...new _Set__default["default"](fields)];
536
- }
537
- function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
538
- const prefixes = _mapInstanceProperty__default["default"](resourceTypeIds).call(resourceTypeIds, type => {
539
- switch (type) {
540
- case 'asset':
541
- return 'assets.custom.fields.';
542
- default:
543
- return 'custom.fields.';
479
+ const extractFieldNamesAndAdditionalFieldExtensions = fields => {
480
+ const result = _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
481
+ if (field.additionalFieldExtensions) {
482
+ return [...acc, ...field.additionalFieldExtensions, field.name];
544
483
  }
545
- });
546
- return _mapInstanceProperty__default["default"](prefixes).call(prefixes, prefix => {
547
- var _context7;
548
- return _concatInstanceProperty__default["default"](_context7 = "".concat(prefix)).call(_context7, field.name);
549
- });
550
- }
484
+ return [...acc, field.name];
485
+ }, []);
486
+ return [...new _Set__default["default"](result)];
487
+ };
488
+ function sortFieldsByFieldOrder(_ref2) {
489
+ let fields = _ref2.fields,
490
+ fieldOrder = _ref2.fieldOrder;
491
+ if (isFilledArray(fieldOrder)) {
492
+ return _sortInstanceProperty__default["default"](fields).call(fields, (a, b) => {
493
+ let orderA = _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, a) !== -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, a) : _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, a.split('.')[0]);
494
+ let orderB = _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, b) !== -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, b) : _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, b.split('.')[0]);
551
495
 
552
- // Sorts an array of custom field names placing those starting with 'assets.custom.fields.' first
553
- // This function doesn't affect the order of other custom fields
554
- function sortCustomFields(fields) {
555
- return _sortInstanceProperty__default["default"](fields).call(fields, (a, b) => _startsWithInstanceProperty__default["default"](b).call(b, 'assets.custom.fields.') - _startsWithInstanceProperty__default["default"](a).call(a, 'assets.custom.fields.'));
496
+ // If a field is not 'custom',then consider it as '*'
497
+ orderA = orderA === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderA;
498
+ orderB = orderB === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderB;
499
+ return orderA - orderB;
500
+ });
501
+ }
502
+ return fields;
556
503
  }
557
504
 
558
505
  // TODO: remove this function when filters are passed directly from parent views
@@ -565,71 +512,69 @@ function tmpBuildFilters(selectedResourceIds) {
565
512
  return ["id in (".concat(formattedIds, ")")];
566
513
  }
567
514
 
568
- const parentKeyExtension = ['parent.key', 'parent.typeId'];
569
- const customFieldsExtension = ['custom.type.key', 'custom.type.typeId'];
570
- const assetsCustomFieldsExtension = ['assets.custom.type.key', 'assets.custom.type.typeId'];
571
- const assetsExtension = ['assets.key', 'assets.name', 'assets.sources.key', 'assets.sources.uri', 'assets.sources.contentType', 'assets.sources.dimensions.w', 'assets.sources.dimensions.h', 'assets.description', 'assets.tags'];
572
- const categoryFieldExtension = fields => {
573
- return _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
574
- if (field === 'parent.key') {
575
- return [...acc, ...parentKeyExtension];
576
- }
577
- if (_startsWithInstanceProperty__default["default"](field).call(field, 'custom.fields.') && !_includesInstanceProperty__default["default"](acc).call(acc, 'custom.type.key')) {
578
- return [...acc, ...customFieldsExtension, field];
579
- }
580
- if (field === 'assets') {
581
- return [...acc, ...assetsExtension];
582
- }
583
- if (_startsWithInstanceProperty__default["default"](field).call(field, 'assets.custom.fields.') && !_includesInstanceProperty__default["default"](acc).call(acc, 'assets.custom.type.key')) {
584
- return [...acc, ...assetsCustomFieldsExtension, field];
585
- }
586
- return [...acc, field];
587
- }, []);
588
- };
589
- const defaultFieldExtension = fields => fields;
590
- const fieldExtensionByResourceType = {
591
- default: defaultFieldExtension,
592
- category: categoryFieldExtension
515
+ 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; }
516
+ 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; }
517
+ const updateFieldGroupsWithIsCheckedValue = groups => {
518
+ const updateFields = (fields, parentChecked) => {
519
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
520
+ var _field$isRequired;
521
+ let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
522
+ if (field.fields) {
523
+ const updatedFields = updateFields(field.fields, isChecked);
524
+ isChecked = false;
525
+ field.fields = updatedFields;
526
+ }
527
+ return _objectSpread$3(_objectSpread$3({}, field), {}, {
528
+ isChecked
529
+ });
530
+ });
531
+ };
532
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
533
+ const updatedFields = updateFields(group.fields, false);
534
+ return _objectSpread$3(_objectSpread$3({}, group), {}, {
535
+ fields: updatedFields
536
+ });
537
+ });
593
538
  };
594
-
595
- const extendFields = _ref => {
596
- let resourceType = _ref.resourceType,
597
- fields = _ref.fields;
598
- const extensionFunction = fieldExtensionByResourceType[resourceType] || fieldExtensionByResourceType.default;
599
- return extensionFunction(fields);
539
+ const updateFieldGroupWithAdditionalFieldExtensions = groups => {
540
+ function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
541
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
542
+ const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
543
+ if (field.fields) {
544
+ field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
545
+ }
546
+ return _objectSpread$3(_objectSpread$3({}, field), {}, {
547
+ additionalFieldExtensions: updatedAdditionalFieldExtensions
548
+ });
549
+ });
550
+ }
551
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
552
+ return _objectSpread$3(_objectSpread$3({}, group), {}, {
553
+ fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
554
+ });
555
+ });
600
556
  };
601
557
 
602
- const _excluded = ["isSelectedByDefault"];
603
- 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; }
604
- function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys$4(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys$4(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
605
558
  const useInitialValues = props => {
606
- var _context;
607
559
  const todayFormatted = moment__default["default"]().format('DD-MM-YY_HH-mm');
608
560
  const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
609
561
  locale: applicationContext.dataLocale
610
562
  })),
611
563
  locale = _useApplicationContex.locale;
612
- const fields = _mapInstanceProperty__default["default"](_context = flattenNestedFields(props.fields)).call(_context, _ref => {
613
- let isSelectedByDefault = _ref.isSelectedByDefault,
614
- field = _objectWithoutProperties(_ref, _excluded);
615
- return _objectSpread$4(_objectSpread$4({}, field), {}, {
616
- isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
617
- });
618
- });
564
+ const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
619
565
  return React__default["default"].useMemo(() => {
620
- var _context2;
566
+ var _context;
621
567
  return {
622
568
  outputFormat: props.outputFormat,
623
- fileName: _concatInstanceProperty__default["default"](_context2 = "".concat(resourceTypeToDisplayName({
569
+ fileName: _concatInstanceProperty__default["default"](_context = "".concat(resourceTypeToDisplayName({
624
570
  resourceType: props.resourceType,
625
571
  isUpperCase: true,
626
572
  isPlural: true
627
- }), "_Export_")).call(_context2, todayFormatted),
573
+ }), "_Export_")).call(_context, todayFormatted),
628
574
  locales: [locale],
629
- fields: checkRequiredFields(fields),
630
- customFields: setInitialCheckedStateForCustomFields(props.customFields)
575
+ groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
631
576
  };
632
- }, [props, locale, todayFormatted, fields]);
577
+ }, [props, locale, todayFormatted, groups]);
633
578
  };
634
579
 
635
580
  async function createExportOperation(_ref) {
@@ -644,6 +589,7 @@ async function createExportOperation(_ref) {
644
589
  const uri = "/proxy/export/".concat(projectKey, "/export-operations");
645
590
  const response = await asyncDispatchFn(sdk.actions.post({
646
591
  // FIXME: EXPORT is undefined
592
+ // @ts-ignore
647
593
  mcApiProxyTarget: constants.MC_API_PROXY_TARGETS.EXPORT,
648
594
  uri: uri,
649
595
  headers: {
@@ -674,12 +620,29 @@ const useStartExportOperation = props => {
674
620
  };
675
621
  }),
676
622
  projectKey = _useApplicationContex.projectKey;
623
+ const extractFieldsFromGroups = groups => {
624
+ let selectedGeneralFields = [];
625
+ const getSelectedFields = fields => {
626
+ return _filterInstanceProperty__default["default"](fields).call(fields, field => {
627
+ var _field$isChecked;
628
+ if (field.fields) {
629
+ return getSelectedFields(field.fields);
630
+ }
631
+ if (field.isChecked) selectedGeneralFields.push(field);
632
+ return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
633
+ });
634
+ };
635
+ _forEachInstanceProperty__default["default"](groups).call(groups, group => {
636
+ getSelectedFields(group.fields);
637
+ });
638
+ return sortFieldsByFieldOrder({
639
+ fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
640
+ fieldOrder: props.fieldOrder
641
+ });
642
+ };
677
643
  const startExportOperation = async values => {
678
644
  try {
679
- const selectedGeneralFields = getSelectedGeneralFields(values.fields);
680
- const selectedCustomFields = getSelectedCustomFields(values.customFields);
681
- const generalFields = extractGeneralFieldNames(selectedGeneralFields);
682
- const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
645
+ const fields = extractFieldsFromGroups(values.groups);
683
646
  const filters = tmpBuildFilters(props.selectedResourceIds);
684
647
  const response = await createExportOperation({
685
648
  projectKey,
@@ -687,10 +650,7 @@ const useStartExportOperation = props => {
687
650
  fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
688
651
  fileFormat: values.outputFormat,
689
652
  locales: values.locales,
690
- fields: extendFields({
691
- resourceType: props.resourceType,
692
- fields: [...generalFields, ...customFields]
693
- }),
653
+ fields,
694
654
  filters,
695
655
  asyncDispatchFn: asyncDispatch
696
656
  });
@@ -700,6 +660,7 @@ const useStartExportOperation = props => {
700
660
  showNotification({
701
661
  kind: 'info',
702
662
  domain: constants.DOMAINS.SIDE,
663
+ // @ts-ignore
703
664
  text: intl.formatMessage(messages.exportOperationSuccessMessage, {
704
665
  newline: getNewLine,
705
666
  logsLink: msg => getExportLogsLink(projectKey, msg),
@@ -729,8 +690,8 @@ const useStartExportOperation = props => {
729
690
  };
730
691
  };
731
692
 
732
- 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; }
733
- 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; }
693
+ 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; }
694
+ function _objectSpread$2(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$2(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$2(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
734
695
  function ExportTextMessage() {
735
696
  const intl = reactIntl.useIntl();
736
697
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -758,7 +719,7 @@ function ExportTextMessage() {
758
719
  }
759
720
  return jsxRuntime.jsx(uiKit.Text.Body, {
760
721
  "data-testid": "export-description",
761
- intlMessage: _objectSpread$3(_objectSpread$3({}, message), {}, {
722
+ intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
762
723
  values: {
763
724
  count: intl.formatNumber(count),
764
725
  resourceType: resourceTypePlural,
@@ -893,20 +854,161 @@ const NoSearchResults = () => {
893
854
  });
894
855
  };
895
856
 
896
- 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; }
897
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context22, _context23; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context22 = ownKeys$2(Object(t), !0)).call(_context22, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context23 = ownKeys$2(Object(t))).call(_context23, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
857
+ 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; }
858
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context7, _context8; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context7 = ownKeys$1(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context8 = ownKeys$1(Object(t))).call(_context8, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
898
859
  const StyledGroupCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
899
- target: "e1ocu3bb1"
860
+ target: "e3xiyhb1"
900
861
  } : {
901
- target: "e1ocu3bb1",
862
+ target: "e3xiyhb1",
902
863
  label: "StyledGroupCard"
903
- })("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.jsx"],"names":[],"mappings":"AA8BO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, 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 messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\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`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\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, {\n        resourceType: resourceTypePlural,\n      })}\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          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAsBoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, 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 messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\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`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\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, {\n        resourceType: resourceTypePlural,\n      })}\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          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
864
+ })("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":"AAgCO","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 { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\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 { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\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, {\n        resourceType: resourceTypePlural,\n      })}\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            <Card 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            </Card>\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":"AAwBiE","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 { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\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 { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\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, {\n        resourceType: resourceTypePlural,\n      })}\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            <Card 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            </Card>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"));
904
865
  const StyledFieldsCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
905
- target: "e1ocu3bb0"
866
+ target: "e3xiyhb0"
906
867
  } : {
907
- target: "e1ocu3bb0",
868
+ target: "e3xiyhb0",
908
869
  label: "StyledFieldsCard"
909
- })("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.jsx"],"names":[],"mappings":"AAuCO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, 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 messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\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`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\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, {\n        resourceType: resourceTypePlural,\n      })}\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          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmCqC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, 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 messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\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`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\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, {\n        resourceType: resourceTypePlural,\n      })}\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          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
870
+ })("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":"AA0CO","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 { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\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 { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\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, {\n        resourceType: resourceTypePlural,\n      })}\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            <Card 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            </Card>\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":"AAsCkE","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 { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\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 { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\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, {\n        resourceType: resourceTypePlural,\n      })}\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            <Card 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            </Card>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"));
871
+ const FieldSections = _ref => {
872
+ let fields = _ref.fields,
873
+ parentKeys = _ref.parentKeys,
874
+ formik = _ref.formik,
875
+ isAnySiblingChecked = _ref.isAnySiblingChecked;
876
+ return jsxRuntime.jsx(uiKit.Spacings.Stack, {
877
+ scale: "s",
878
+ children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, (field, index) => {
879
+ var _context, _field$fields3;
880
+ const isAtleastOneChildChecked = () => {
881
+ function checkAtLeastOneFieldChecked(fields) {
882
+ return fields === null || fields === void 0 ? void 0 : _someInstanceProperty__default["default"](fields).call(fields, field => {
883
+ if (field.fields) {
884
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
885
+ }
886
+ return field.isChecked;
887
+ });
888
+ }
889
+ return checkAtLeastOneFieldChecked(field.fields);
890
+ };
891
+ const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
892
+ if (field.isHidden) return null;
893
+ return jsxRuntime.jsxs(React__default["default"].Fragment, {
894
+ children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
895
+ isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
896
+ isReadOnly: field.isReadOnly || field.isRequired,
897
+ onChange: e => {
898
+ var _context2, _field$fields2;
899
+ const path = _concatInstanceProperty__default["default"](_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
900
+ // Update all child fields
901
+ const updateAllChildFieldsChecked = (path, checked) => {
902
+ const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), path);
903
+ if (item && item.fields) {
904
+ var _context3;
905
+ _forEachInstanceProperty__default["default"](_context3 = item.fields).call(_context3, (field, i) => {
906
+ var _context4, _field$fields;
907
+ const fieldPath = _concatInstanceProperty__default["default"](_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
908
+ if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
909
+ formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
910
+ // pass `false` to avoid revalidating the form with intermediate values
911
+ false);
912
+ }
913
+ updateAllChildFieldsChecked(fieldPath, checked);
914
+ });
915
+ }
916
+ };
917
+ if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
918
+ formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
919
+ // pass `false` to avoid revalidating the form with intermediate values
920
+ false);
921
+ }
922
+ updateAllChildFieldsChecked(path, e.target.checked);
923
+ },
924
+ children: [field.label, " ", field.isRequired && '*']
925
+ }), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxRuntime.jsxs(uiKit.Spacings.Inline, {
926
+ scale: "l",
927
+ children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(FieldSections, {
928
+ fields: field.fields,
929
+ formik: formik,
930
+ parentKeys: [...parentKeys, "fields[".concat(index, "]")],
931
+ isAnySiblingChecked: isAnySiblingChecked
932
+ })]
933
+ })]
934
+ }, _concatInstanceProperty__default["default"](_context = "".concat(field.name, "-")).call(_context, index));
935
+ })
936
+ });
937
+ };
938
+ function checkAllFieldsSelected(fields) {
939
+ return _everyInstanceProperty__default["default"](fields).call(fields, field => {
940
+ if (field.fields) {
941
+ return checkAllFieldsSelected(field.fields);
942
+ }
943
+ return field.isChecked || field.isRequired || field.isReadOnly;
944
+ });
945
+ }
946
+ function checkAtLeastOneFieldChecked(fields) {
947
+ return _someInstanceProperty__default["default"](fields).call(fields, field => {
948
+ if (field.fields) {
949
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
950
+ }
951
+ return field.isChecked;
952
+ });
953
+ }
954
+ const FieldGroupSection = _ref2 => {
955
+ let group = _ref2.group,
956
+ index = _ref2.index,
957
+ formik = _ref2.formik;
958
+ const allAllFieldsSelected = React__default["default"].useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
959
+ const isAtleastOneFieldChecked = React__default["default"].useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
960
+ const parentKey = "groups[".concat(index, "]");
961
+ const handleChangeAllFields = e => {
962
+ const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), parentKey);
963
+ function updateAllFields(fields, checked) {
964
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
965
+ if (field.fields) {
966
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
967
+ fields: updateAllFields(field.fields, checked)
968
+ });
969
+ }
970
+ if (field.isReadOnly || field.isRequired) return field;
971
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
972
+ isChecked: checked
973
+ });
974
+ });
975
+ }
976
+ formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
977
+ fields: updateAllFields(item.fields, e.target.checked)
978
+ }));
979
+ };
980
+ if (group.isHidden) return null;
981
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
982
+ children: [jsxRuntime.jsx(uiKit.Grid.Item, {
983
+ children: jsxRuntime.jsx(StyledGroupCard, {
984
+ type: "flat",
985
+ insetScale: "l",
986
+ showTopBorder: true,
987
+ children: jsxRuntime.jsx(uiKit.CheckboxInput, {
988
+ isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
989
+ isChecked: allAllFieldsSelected,
990
+ onChange: handleChangeAllFields,
991
+ children: group.groupLabel
992
+ })
993
+ })
994
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
995
+ children: jsxRuntime.jsx(StyledFieldsCard, {
996
+ type: "flat",
997
+ insetScale: "l",
998
+ showTopBorder: true,
999
+ children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
1000
+ scale: "s",
1001
+ children: jsxRuntime.jsx(FieldSections, {
1002
+ fields: group.fields,
1003
+ formik: formik,
1004
+ parentKeys: [parentKey],
1005
+ isAnySiblingChecked: isAtleastOneFieldChecked
1006
+ })
1007
+ })
1008
+ })
1009
+ })]
1010
+ });
1011
+ };
910
1012
  const ExportFieldsSelectionStep = () => {
911
1013
  const intl = reactIntl.useIntl();
912
1014
  const _React$useState = React__default["default"].useState(''),
@@ -922,47 +1024,44 @@ const ExportFieldsSelectionStep = () => {
922
1024
  resourceType: resourceType,
923
1025
  isPlural: true
924
1026
  });
925
- const areAllGeneralFieldsChecked = React__default["default"].useMemo(() => {
926
- var _context;
927
- return _everyInstanceProperty__default["default"](_context = _valuesInstanceProperty__default["default"](formik).fields).call(_context, field => field.isChecked);
928
- }, [_valuesInstanceProperty__default["default"](formik).fields]);
929
- const isAtLeastOneGeneralFieldChecked = React__default["default"].useMemo(() => {
930
- var _context2;
931
- return _someInstanceProperty__default["default"](_context2 = _valuesInstanceProperty__default["default"](formik).fields).call(_context2, field => field.isChecked);
932
- }, [_valuesInstanceProperty__default["default"](formik).fields]);
933
- const allCustomFields = React__default["default"].useMemo(() => {
934
- var _context3;
935
- return _flatMapInstanceProperty__default["default"](_context3 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context3, customType => customType.fields);
936
- }, [_valuesInstanceProperty__default["default"](formik).customFields]);
937
- const areAllCustomFieldsChecked = React__default["default"].useMemo(() => {
938
- return _everyInstanceProperty__default["default"](allCustomFields).call(allCustomFields, field => field.isChecked);
939
- }, [allCustomFields]);
940
- const isAtLeastOneCustomFieldChecked = React__default["default"].useMemo(() => {
941
- return _someInstanceProperty__default["default"](allCustomFields).call(allCustomFields, field => field.isChecked);
942
- }, [allCustomFields]);
943
- const filteredGeneralFields = React__default["default"].useMemo(() => {
944
- var _context4;
945
- return _filterInstanceProperty__default["default"](_context4 = _valuesInstanceProperty__default["default"](formik).fields).call(_context4, field => {
946
- var _context5;
947
- return _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
948
- });
949
- }, [_valuesInstanceProperty__default["default"](formik).fields, fieldSearchTerm]);
950
- const filteredCustomFields = React__default["default"].useMemo(() => {
951
- var _context6, _context7;
952
- return _filterInstanceProperty__default["default"](_context6 = _mapInstanceProperty__default["default"](_context7 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context7, customType => {
953
- var _context8, _context9;
954
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
955
- fields: _includesInstanceProperty__default["default"](_context8 = customType.type.label.toLowerCase()).call(_context8, _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm).toLowerCase()) ? customType.fields : _filterInstanceProperty__default["default"](_context9 = customType.fields).call(_context9, field => {
956
- var _context10;
957
- return _includesInstanceProperty__default["default"](_context10 = field.label.toLowerCase()).call(_context10, _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
958
- })
1027
+ React__default["default"].useEffect(() => {
1028
+ formik.validateForm();
1029
+ // eslint-disable-next-line react-hooks/exhaustive-deps
1030
+ }, [_valuesInstanceProperty__default["default"](formik).groups]);
1031
+ // adds `isHidden` property to each field based on search term
1032
+ const filteredGroups = React__default["default"].useMemo(() => {
1033
+ var _fieldSearchTerm$trim, _context6;
1034
+ const updateFields = (fields, parentMatches) => {
1035
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
1036
+ var _context5;
1037
+ const matches = _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
1038
+ let isHidden = !matches && !parentMatches;
1039
+ if (field.fields) {
1040
+ const updatedFields = updateFields(field.fields, matches);
1041
+ isHidden = isHidden && _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, f => f.isHidden);
1042
+ field = _objectSpread$1(_objectSpread$1({}, field), {}, {
1043
+ fields: updatedFields
1044
+ });
1045
+ }
1046
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
1047
+ isHidden
1048
+ });
959
1049
  });
960
- })).call(_context6, customType => customType.fields.length > 0);
961
- }, [_valuesInstanceProperty__default["default"](formik).customFields, fieldSearchTerm]);
1050
+ };
1051
+ 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;
1052
+ return _mapInstanceProperty__default["default"](_context6 = _valuesInstanceProperty__default["default"](formik).groups).call(_context6, group => {
1053
+ const updatedFields = updateFields(group.fields, false);
1054
+ const isHidden = _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, field => field.isHidden);
1055
+ return _objectSpread$1(_objectSpread$1({}, group), {}, {
1056
+ fields: updatedFields,
1057
+ isHidden
1058
+ });
1059
+ });
1060
+ }, [_valuesInstanceProperty__default["default"](formik).groups, fieldSearchTerm]);
962
1061
  const onSearchChange = React__default["default"].useCallback(event => {
963
1062
  setFieldSearchTerm(event.target.value);
964
1063
  }, [setFieldSearchTerm]);
965
- const hasResults = filteredGeneralFields.length > 0 || filteredCustomFields.length > 0;
1064
+ const hasResults = Boolean(_findInstanceProperty__default["default"](filteredGroups).call(filteredGroups, group => !group.isHidden));
966
1065
  const onSearchChangeThrottled = React__default["default"].useMemo(() => throttle__default["default"](onSearchChange, 300), [onSearchChange]);
967
1066
  const onSearchReset = () => {
968
1067
  setFieldSearchTerm('');
@@ -998,157 +1097,25 @@ const ExportFieldsSelectionStep = () => {
998
1097
  value: fieldSearchTerm,
999
1098
  onChange: onSearchChangeThrottled,
1000
1099
  onReset: onSearchReset
1001
- }), !hasResults && jsxRuntime.jsx(NoSearchResults, {}), hasResults && jsxRuntime.jsx(uiKit.Card, {
1100
+ // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
1101
+ ,
1102
+ onSubmit: () => {}
1103
+ }), hasResults ? jsxRuntime.jsx(uiKit.Card, {
1002
1104
  insetScale: "none",
1003
- children: jsxRuntime.jsxs(uiKit.Grid, {
1105
+ children: jsxRuntime.jsx(uiKit.Grid, {
1004
1106
  gridAutoFlow: "row",
1005
1107
  gridTemplateColumns: "".concat(uiKit.designTokens.constraint5, " auto"),
1006
- children: [filteredGeneralFields.length > 0 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
1007
- children: [jsxRuntime.jsx(uiKit.Grid.Item, {
1008
- children: jsxRuntime.jsx(StyledGroupCard, {
1009
- type: "flat",
1010
- insetScale: "l",
1011
- children: jsxRuntime.jsx(uiKit.CheckboxInput, {
1012
- isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
1013
- isChecked: areAllGeneralFieldsChecked,
1014
- onChange: e => {
1015
- var _context11;
1016
- formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context11 = _valuesInstanceProperty__default["default"](formik).fields).call(_context11, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1017
- isChecked: field.isRequired ? true : e.target.checked
1018
- })));
1019
- },
1020
- children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allGeneralFields))
1021
- })
1022
- })
1023
- }), jsxRuntime.jsx(uiKit.Grid.Item, {
1024
- children: jsxRuntime.jsx(StyledFieldsCard, {
1025
- type: "flat",
1026
- insetScale: "l",
1027
- children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
1028
- scale: "s",
1029
- children: jsxRuntime.jsx(GeneralFieldsSelection, {
1030
- fields: filteredGeneralFields,
1031
- formik: formik
1032
- })
1033
- })
1034
- })
1035
- })]
1036
- }), filteredCustomFields.length > 0 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
1037
- children: [jsxRuntime.jsx(uiKit.Grid.Item, {
1038
- children: jsxRuntime.jsx(StyledGroupCard, {
1039
- type: "flat",
1040
- insetScale: "l",
1041
- showTopBorder: filteredGeneralFields.length > 0,
1042
- children: jsxRuntime.jsx(uiKit.CheckboxInput, {
1043
- isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
1044
- isChecked: areAllCustomFieldsChecked,
1045
- onChange: e => {
1046
- var _context12;
1047
- formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context12 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context12, customType => {
1048
- var _context13;
1049
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
1050
- fields: _mapInstanceProperty__default["default"](_context13 = customType.fields).call(_context13, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1051
- isChecked: e.target.checked
1052
- }))
1053
- });
1054
- }));
1055
- },
1056
- children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
1057
- })
1058
- })
1059
- }), jsxRuntime.jsx(uiKit.Grid.Item, {
1060
- children: jsxRuntime.jsx(StyledFieldsCard, {
1061
- type: "flat",
1062
- insetScale: "l",
1063
- showTopBorder: filteredGeneralFields.length > 0,
1064
- children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1065
- scale: "s",
1066
- children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
1067
- isReadOnly: true,
1068
- onChange: () => {},
1069
- isChecked: isAtLeastOneCustomFieldChecked,
1070
- children: [jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
1071
- }), jsxRuntime.jsx(CustomFieldsSelection, {
1072
- customFields: filteredCustomFields,
1073
- formik: formik
1074
- })]
1075
- })
1076
- })
1077
- })]
1078
- })]
1108
+ children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) => jsxRuntime.jsx(FieldGroupSection, {
1109
+ group: group,
1110
+ index: index,
1111
+ formik: formik
1112
+ }, group.groupLabel))
1079
1113
  })
1080
- })]
1114
+ }) : jsxRuntime.jsx(NoSearchResults, {})]
1081
1115
  })
1082
1116
  })
1083
1117
  });
1084
1118
  };
1085
- const GeneralFieldsSelection = _ref => {
1086
- let fields = _ref.fields,
1087
- formik = _ref.formik;
1088
- return _mapInstanceProperty__default["default"](fields).call(fields, field => jsxRuntime.jsxs(uiKit.CheckboxInput, {
1089
- isChecked: field.isChecked,
1090
- isReadOnly: field.isRequired,
1091
- onChange: e => {
1092
- var _context14;
1093
- formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context14 = _valuesInstanceProperty__default["default"](formik).fields).call(_context14, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1094
- isChecked: e.target.checked
1095
- }) : _field));
1096
- },
1097
- children: [field.label, " ", field.isRequired && '*']
1098
- }, field.name));
1099
- };
1100
- const CustomFieldsSelection = _ref2 => {
1101
- let customFields = _ref2.customFields,
1102
- formik = _ref2.formik;
1103
- return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
1104
- var _context15, _context16, _context19;
1105
- const areAllFieldsChecked = _everyInstanceProperty__default["default"](_context15 = customType.fields).call(_context15, field => field.isChecked);
1106
- const isAtLeastOneFieldChecked = _someInstanceProperty__default["default"](_context16 = customType.fields).call(_context16, field => field.isChecked);
1107
- return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1108
- scale: "s",
1109
- children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
1110
- isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
1111
- isChecked: areAllFieldsChecked,
1112
- onChange: e => {
1113
- var _context17;
1114
- formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context17 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context17, _customType => {
1115
- var _context18;
1116
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1117
- fields: _mapInstanceProperty__default["default"](_context18 = _customType.fields).call(_context18, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1118
- isChecked: e.target.checked
1119
- }))
1120
- }) : _customType;
1121
- }));
1122
- },
1123
- children: jsxRuntime.jsx(uiKit.Text.Body, {
1124
- children: customType.type.label
1125
- })
1126
- }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
1127
- scale: "l",
1128
- children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(uiKit.Spacings.Stack, {
1129
- scale: "s",
1130
- children: _mapInstanceProperty__default["default"](_context19 = customType.fields).call(_context19, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
1131
- isChecked: field.isChecked,
1132
- onChange: e => {
1133
- var _context20;
1134
- formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context20 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context20, _customType => {
1135
- var _context21;
1136
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1137
- fields: _mapInstanceProperty__default["default"](_context21 = _customType.fields).call(_context21, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1138
- isChecked: e.target.checked
1139
- }) : _field)
1140
- }) : _customType;
1141
- }));
1142
- },
1143
- children: jsxRuntime.jsx(uiKit.Text.Body, {
1144
- children: field.label
1145
- })
1146
- }, field.name))
1147
- })]
1148
- })]
1149
- }, customType.type.key);
1150
- });
1151
- };
1152
1119
 
1153
1120
  process.env.NODE_ENV !== "production" ? {
1154
1121
  renderProperties: PropTypes__default["default"].func
@@ -1156,42 +1123,6 @@ process.env.NODE_ENV !== "production" ? {
1156
1123
 
1157
1124
  const ExportResourcesContext = /*#__PURE__*/React.createContext();
1158
1125
 
1159
- const ExportResourcesModalShape = PropTypes__default["default"].shape({
1160
- isOpen: PropTypes__default["default"].bool,
1161
- resourceType: PropTypes__default["default"].string.isRequired,
1162
- outputFormat: PropTypes__default["default"].string,
1163
- onClose: PropTypes__default["default"].func,
1164
- onExportSuccess: PropTypes__default["default"].func,
1165
- totalResourcesCount: PropTypes__default["default"].number.isRequired,
1166
- selectedResourceIds: PropTypes__default["default"].array,
1167
- // TODO: Circular reference
1168
- fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1169
- name: PropTypes__default["default"].string.isRequired,
1170
- label: PropTypes__default["default"].string,
1171
- fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1172
- name: PropTypes__default["default"].string.isRequired,
1173
- label: PropTypes__default["default"].string,
1174
- isSelectedByDefault: PropTypes__default["default"].bool,
1175
- isRequired: PropTypes__default["default"].bool
1176
- }))
1177
- })).isRequired,
1178
- customFields: PropTypes__default["default"].shape({
1179
- type: PropTypes__default["default"].shape({
1180
- key: PropTypes__default["default"].string.isRequired,
1181
- label: PropTypes__default["default"].string.isRequired,
1182
- resourceTypeIds: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string)
1183
- }).isRequired,
1184
- fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1185
- name: PropTypes__default["default"].string.isRequired,
1186
- label: PropTypes__default["default"].string
1187
- })).isRequired
1188
- }),
1189
- exportType: PropTypes__default["default"].string,
1190
- renderProperties: PropTypes__default["default"].func
1191
- }).isRequired;
1192
-
1193
- 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; }
1194
- 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; }
1195
1126
  const ExportResourcesProvider = props => {
1196
1127
  const initialValues = useInitialValues(props);
1197
1128
  const _useStartExportOperat = useStartExportOperation(props),
@@ -1232,10 +1163,6 @@ const ExportResourcesProvider = props => {
1232
1163
  children: props.children
1233
1164
  });
1234
1165
  };
1235
- ExportResourcesProvider.displayName = 'ExportResourcesProvider';
1236
- ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
1237
- children: PropTypes__default["default"].node
1238
- }) : {};
1239
1166
 
1240
1167
  const CurrentStep = () => {
1241
1168
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -1247,22 +1174,100 @@ const CurrentStep = () => {
1247
1174
  return steps[currentStep] || null;
1248
1175
  };
1249
1176
 
1177
+ const loadMessages = locale => {
1178
+ const intlLocale = i18n.mapLocaleToIntlLocale(locale);
1179
+ switch (intlLocale) {
1180
+ case 'de':
1181
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-de" */'./de-a34c5dd4.cjs.dev.js'); });
1182
+ case 'es':
1183
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-es" */'./es-8b3ecab1.cjs.dev.js'); });
1184
+ case 'fr-FR':
1185
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-fr-FR" */'./fr-FR-e7126fcc.cjs.dev.js'); });
1186
+ case 'zh-CN':
1187
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-zh-CN" */'./zh-CN-d4bc6d26.cjs.dev.js'); });
1188
+ case 'ja':
1189
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-ja" */'./ja-9bd5f452.cjs.dev.js'); });
1190
+ case 'pt-BR':
1191
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-ea6b3251.cjs.dev.js'); });
1192
+ default:
1193
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-en" */'./en-6b3694f6.cjs.dev.js'); });
1194
+ }
1195
+ };
1196
+
1197
+ // eslint-disable-next-line import/prefer-default-export
1198
+ const loadI18n = async locale => {
1199
+ try {
1200
+ const messages = await loadMessages(locale);
1201
+ return messages.default || messages;
1202
+ } catch (error) {
1203
+ // eslint-disable-next-line no-console
1204
+ console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
1205
+ sentry.reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
1206
+ extra: error
1207
+ });
1208
+ return {};
1209
+ }
1210
+ };
1211
+
1212
+ const useAsyncIntlMessages = (locale, loader) => {
1213
+ const _useState = React.useState({
1214
+ isLoading: true,
1215
+ messages: undefined,
1216
+ error: undefined
1217
+ }),
1218
+ _useState2 = _slicedToArray(_useState, 2),
1219
+ state = _useState2[0],
1220
+ setState = _useState2[1];
1221
+ React.useEffect(() => {
1222
+ let _isUnmounting = false;
1223
+ async function load() {
1224
+ try {
1225
+ if (!_isUnmounting) {
1226
+ const messages = await loader(locale);
1227
+ setState({
1228
+ isLoading: false,
1229
+ messages
1230
+ });
1231
+ }
1232
+ } catch (error) {
1233
+ setState({
1234
+ isLoading: false,
1235
+ error
1236
+ });
1237
+ }
1238
+ }
1239
+ if (locale) load();
1240
+ return () => {
1241
+ _isUnmounting = true;
1242
+ };
1243
+ }, [locale, loader]);
1244
+ return state;
1245
+ };
1246
+
1250
1247
  function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
1251
1248
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1252
1249
  const ExportResourcesModal = props => {
1253
- if (!props.isOpen) return null;
1254
- return jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1255
- children: jsxRuntime.jsx(CurrentStep, {})
1256
- }));
1250
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
1251
+ locale: context.user && context.user.locale
1252
+ })),
1253
+ locale = _useApplicationContex.locale;
1254
+ const messages = useAsyncIntlMessages('en', loadI18n);
1255
+ if (!props.isOpen || messages.isLoading) return null;
1256
+ return jsxRuntime.jsx(reactIntl.IntlProvider, {
1257
+ locale: locale,
1258
+ messages: messages.messages,
1259
+ children: jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1260
+ children: jsxRuntime.jsx(CurrentStep, {})
1261
+ }))
1262
+ });
1257
1263
  };
1258
1264
  ExportResourcesModal.displayName = 'ExportResourcesModal';
1259
- ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
1260
1265
  ExportResourcesModal.defaultProps = {
1261
1266
  isOpen: false,
1262
1267
  selectedResourceIds: [],
1263
1268
  exportType: EXPORT_TYPES.ALL,
1264
1269
  outputFormat: OUTPUT_FORMATS.CSV,
1265
- customFields: []
1270
+ fieldGroups: []
1266
1271
  };
1267
1272
 
1268
1273
  exports.EXPORTABLE_RESOURCES = EXPORTABLE_RESOURCES;