@commercetools-frontend-extensions/export-resources-modal 3.6.0 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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,28 +25,37 @@ 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');
28
+ var React = require('react');
29
29
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
30
30
  var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
31
31
  var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
32
32
  var moment = require('moment');
33
+ var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
33
34
  var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
34
35
  var omitEmpty = require('omit-empty-es');
35
36
  var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
36
37
  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
38
  var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
39
39
  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');
40
+ require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
41
+ var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
42
+ var shared = require('@commercetools-local/shared');
42
43
  var sdk = require('@commercetools-frontend/sdk');
43
44
  var actionsGlobal = require('@commercetools-frontend/actions-global');
44
45
  var constants = require('@commercetools-frontend/constants');
46
+ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
45
47
  var _styled = require('@emotion/styled/base');
46
48
  var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
47
- var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
49
+ var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
50
+ var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
51
+ var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
52
+ var throttle = require('lodash/throttle');
53
+ var react = require('@emotion/react');
54
+ var get = require('lodash/get');
48
55
  var PropTypes = require('prop-types');
49
- var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
50
56
  var formik = require('formik');
57
+ var sentry = require('@commercetools-frontend/sentry');
58
+ var i18n = require('@commercetools-frontend/i18n');
51
59
 
52
60
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
53
61
 
@@ -59,24 +67,27 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
59
67
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
60
68
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
61
69
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
62
- var React__default = /*#__PURE__*/_interopDefault(React);
63
70
  var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
64
71
  var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
72
+ var React__default = /*#__PURE__*/_interopDefault(React);
65
73
  var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
66
74
  var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
67
75
  var moment__default = /*#__PURE__*/_interopDefault(moment);
76
+ var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
68
77
  var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
69
78
  var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
70
79
  var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
71
80
  var _flatInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatInstanceProperty);
72
- var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
73
81
  var _Set__default = /*#__PURE__*/_interopDefault(_Set);
74
82
  var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
75
- var _startsWithInstanceProperty__default = /*#__PURE__*/_interopDefault(_startsWithInstanceProperty);
76
- var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
83
+ var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
77
84
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
78
85
  var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
79
- var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
86
+ var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
87
+ var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
88
+ var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
89
+ var throttle__default = /*#__PURE__*/_interopDefault(throttle);
90
+ var get__default = /*#__PURE__*/_interopDefault(get);
80
91
  var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
81
92
 
82
93
  function getBold(msg) {
@@ -211,25 +222,35 @@ var messages = reactIntl.defineMessages({
211
222
  description: 'Label for "Field definitions" link',
212
223
  defaultMessage: 'Field definitions'
213
224
  },
214
- allGeneralFields: {
215
- id: 'ExportResourcesModal.allGeneralFields',
216
- description: 'Label for "All general fields" checkbox',
217
- defaultMessage: 'All general fields'
218
- },
219
- allCustomFields: {
220
- id: 'ExportResourcesModal.allCustomFields',
221
- description: 'Label for "All custom fields" checkbox',
222
- defaultMessage: 'All custom fields'
223
- },
224
- customTypeKeyAndTypeId: {
225
- id: 'ExportResourcesModal.customTypeKeyAndTypeId',
226
- description: 'Label for "Custom type key and typeId" checkbox',
227
- defaultMessage: 'Custom type key and typeId'
228
- },
229
225
  unexpectedError: {
230
226
  id: 'ExportResourcesModal.unexpectedError',
231
227
  description: 'Generic notification message when starting export process fails',
232
228
  defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
229
+ },
230
+ searchForFields: {
231
+ id: 'ExportResourcesModal.searchForFields',
232
+ description: 'Placeholder for "Search for fields" search input',
233
+ defaultMessage: 'Search for fields'
234
+ },
235
+ thereAreNoResults: {
236
+ id: 'ExportResourcesModal.thereAreNoResults',
237
+ description: 'No search results message',
238
+ defaultMessage: 'There are no results that match your search.'
239
+ },
240
+ suggestions: {
241
+ id: 'ExportResourcesModal.suggestions',
242
+ description: 'In Export fields selection - Suggestions message',
243
+ defaultMessage: 'Suggestions:'
244
+ },
245
+ checkTheSpelling: {
246
+ id: 'ExportResourcesModal.checkTheSpelling',
247
+ description: 'In Export fields selection - Check the spelling message',
248
+ defaultMessage: 'Check the spelling.'
249
+ },
250
+ searchByEnteringTheExactFieldName: {
251
+ id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
252
+ description: 'In Export fields selection - Search by entering the exact field name message',
253
+ defaultMessage: 'Try searching by entering the exact field name.'
233
254
  }
234
255
  });
235
256
 
@@ -290,11 +311,11 @@ const FIELD_DEFINITIONS_URLS = {
290
311
  category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
291
312
  };
292
313
 
293
- function _createSuper$4(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$4(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
294
- function _isNativeReflectConstruct$4() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$4 = function () { return !!t; })(); }
314
+ function _createSuper$2(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$2(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
315
+ function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
295
316
  let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
296
317
  _inherits(UnexpectedExportTypeError, _Error);
297
- var _super = _createSuper$4(UnexpectedExportTypeError);
318
+ var _super = _createSuper$2(UnexpectedExportTypeError);
298
319
  function UnexpectedExportTypeError(exportType) {
299
320
  var _this;
300
321
  _classCallCheck(this, UnexpectedExportTypeError);
@@ -305,11 +326,11 @@ let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
305
326
  return _createClass(UnexpectedExportTypeError);
306
327
  }( /*#__PURE__*/_wrapNativeSuper(Error));
307
328
 
308
- function _createSuper$3(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$3(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
309
- function _isNativeReflectConstruct$3() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$3 = function () { return !!t; })(); }
329
+ function _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
330
+ function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
310
331
  let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
311
332
  _inherits(MissingExportResourceProviderError, _Error);
312
- var _super = _createSuper$3(MissingExportResourceProviderError);
333
+ var _super = _createSuper$1(MissingExportResourceProviderError);
313
334
  function MissingExportResourceProviderError() {
314
335
  var _this;
315
336
  _classCallCheck(this, MissingExportResourceProviderError);
@@ -320,11 +341,11 @@ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
320
341
  return _createClass(MissingExportResourceProviderError);
321
342
  }( /*#__PURE__*/_wrapNativeSuper(Error));
322
343
 
323
- function _createSuper$2(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$2(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
324
- function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
344
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
345
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
325
346
  let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
326
347
  _inherits(UnexpectedExportOperationStateError, _Error);
327
- var _super = _createSuper$2(UnexpectedExportOperationStateError);
348
+ var _super = _createSuper(UnexpectedExportOperationStateError);
328
349
  function UnexpectedExportOperationStateError(state) {
329
350
  var _this;
330
351
  _classCallCheck(this, UnexpectedExportOperationStateError);
@@ -335,36 +356,6 @@ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
335
356
  return _createClass(UnexpectedExportOperationStateError);
336
357
  }( /*#__PURE__*/_wrapNativeSuper(Error));
337
358
 
338
- function _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
339
- function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
340
- let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
341
- _inherits(UnexpectedResourceTypeError, _Error);
342
- var _super = _createSuper$1(UnexpectedResourceTypeError);
343
- function UnexpectedResourceTypeError(resourceType) {
344
- var _this;
345
- _classCallCheck(this, UnexpectedResourceTypeError);
346
- _this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
347
- _this.name = 'UnexpectedResourceTypeError';
348
- return _this;
349
- }
350
- return _createClass(UnexpectedResourceTypeError);
351
- }( /*#__PURE__*/_wrapNativeSuper(Error));
352
-
353
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
354
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
355
- let InvalidResponseError = /*#__PURE__*/function (_Error) {
356
- _inherits(InvalidResponseError, _Error);
357
- var _super = _createSuper(InvalidResponseError);
358
- function InvalidResponseError(message) {
359
- var _this;
360
- _classCallCheck(this, InvalidResponseError);
361
- _this = _super.call(this, message);
362
- _this.name = 'InvalidResponseError';
363
- return _this;
364
- }
365
- return _createClass(InvalidResponseError);
366
- }( /*#__PURE__*/_wrapNativeSuper(Error));
367
-
368
359
  function useExportResourcesContext() {
369
360
  const context = React.useContext(ExportResourcesContext);
370
361
  if (!context) {
@@ -373,33 +364,44 @@ function useExportResourcesContext() {
373
364
  return context;
374
365
  }
375
366
 
367
+ function checkAtLeastOneFieldChecked$1(fields) {
368
+ return _someInstanceProperty__default["default"](fields).call(fields, field => {
369
+ if (field.fields) {
370
+ return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
371
+ }
372
+ return field.isChecked;
373
+ });
374
+ }
376
375
  function validate(_ref) {
377
376
  let values = _valuesInstanceProperty__default["default"](_ref),
378
377
  step = _ref.step;
379
378
  const fileName = values.fileName,
380
379
  locales = values.locales,
381
- fields = values.fields,
382
- customFields = values.customFields;
380
+ groups = values.groups;
383
381
  const errors = {
384
382
  fileName: {},
385
383
  locales: {},
386
384
  fields: {}
387
385
  };
388
386
  if (uiKit.TextInput.isEmpty(fileName)) {
387
+ // @ts-ignore
389
388
  errors.fileName.missing = true;
390
389
  } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
390
+ // @ts-ignore
391
391
  errors.fileName.invalidInput = true;
392
392
  }
393
393
  if (locales.length < 1) {
394
+ // @ts-ignore
394
395
  errors.locales.missing = true;
395
396
  }
396
397
  if (step === 2) {
397
- const checkedGeneralFieldsCount = _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked).length;
398
- const checkedCustomFieldsCount = _reduceInstanceProperty__default["default"](customFields).call(customFields, (count, customType) => {
399
- var _context;
400
- return count + _filterInstanceProperty__default["default"](_context = customType.fields).call(_context, field => field.isChecked).length;
401
- }, 0);
402
- if (checkedGeneralFieldsCount + checkedCustomFieldsCount < 2) {
398
+ const allFields = _reduceInstanceProperty__default["default"](groups).call(groups, (acc, group) => _concatInstanceProperty__default["default"](acc).call(acc, group.fields), []);
399
+ const checkedFieldsCount = _filterInstanceProperty__default["default"](allFields).call(allFields, field => {
400
+ if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
401
+ return !field.isRequired && !field.isReadOnly && field.isChecked;
402
+ }).length;
403
+ if (checkedFieldsCount < 1) {
404
+ // @ts-ignore
403
405
  errors.fields.missing = true;
404
406
  }
405
407
  }
@@ -407,7 +409,7 @@ function validate(_ref) {
407
409
  }
408
410
 
409
411
  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; }
410
- 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; }
412
+ function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context5, _context6; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context5 = ownKeys$5(Object(t), !0)).call(_context5, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context6 = ownKeys$5(Object(t))).call(_context6, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
411
413
  function resourceTypeToDisplayName(_ref) {
412
414
  let resourceType = _ref.resourceType,
413
415
  _ref$isUpperCase = _ref.isUpperCase,
@@ -426,7 +428,7 @@ function resourceTypeToDisplayName(_ref) {
426
428
  displayName = isPlural ? 'Discount codes' : 'Discount code';
427
429
  break;
428
430
  default:
429
- throw UnexpectedResourceTypeError(resourceType);
431
+ throw shared.UnexpectedResourceTypeError(resourceType);
430
432
  }
431
433
  return isUpperCase ? displayName : displayName.toLowerCase();
432
434
  }
@@ -460,17 +462,6 @@ function flattenNestedFields(fields) {
460
462
  })) || [];
461
463
  return _flatInstanceProperty__default["default"](result).call(result);
462
464
  }
463
- function getSelectedGeneralFields(fields) {
464
- return _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked);
465
- }
466
- function getSelectedCustomFields(customFields) {
467
- return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
468
- var _context4;
469
- return _objectSpread$5(_objectSpread$5({}, customType), {}, {
470
- fields: _filterInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => field.isChecked)
471
- });
472
- });
473
- }
474
465
  function checkRequiredFields(fields) {
475
466
  return _mapInstanceProperty__default["default"](fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
476
467
  isChecked: true
@@ -484,45 +475,38 @@ function getExportLogsLink(projectKey, msg) {
484
475
  }
485
476
  function setInitialCheckedStateForCustomFields(customFields) {
486
477
  return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
487
- var _context5;
478
+ var _context4;
488
479
  return _objectSpread$5(_objectSpread$5({}, customType), {}, {
489
- fields: _mapInstanceProperty__default["default"](_context5 = customType.fields).call(_context5, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
480
+ fields: _mapInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
490
481
  isChecked: false
491
482
  }))
492
483
  });
493
484
  });
494
485
  }
495
- function extractGeneralFieldNames(generalFields) {
496
- return _mapInstanceProperty__default["default"](generalFields).call(generalFields, field => field.name);
497
- }
498
- function extractCustomFieldNamesWithPrefix(customFields) {
499
- const fields = _flatMapInstanceProperty__default["default"](customFields).call(customFields, customType => {
500
- var _context6;
501
- return _flatMapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => {
502
- return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
503
- });
504
- });
505
- return [...new _Set__default["default"](fields)];
506
- }
507
- function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
508
- const prefixes = _mapInstanceProperty__default["default"](resourceTypeIds).call(resourceTypeIds, type => {
509
- switch (type) {
510
- case 'asset':
511
- return 'assets.custom.fields.';
512
- default:
513
- return 'custom.fields.';
486
+ const extractFieldNamesAndAdditionalFieldExtensions = fields => {
487
+ const result = _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
488
+ if (field.additionalFieldExtensions) {
489
+ return [...acc, ...field.additionalFieldExtensions, field.name];
514
490
  }
515
- });
516
- return _mapInstanceProperty__default["default"](prefixes).call(prefixes, prefix => {
517
- var _context7;
518
- return _concatInstanceProperty__default["default"](_context7 = "".concat(prefix)).call(_context7, field.name);
519
- });
520
- }
491
+ return [...acc, field.name];
492
+ }, []);
493
+ return [...new _Set__default["default"](result)];
494
+ };
495
+ function sortFieldsByFieldOrder(_ref2) {
496
+ let fields = _ref2.fields,
497
+ fieldOrder = _ref2.fieldOrder;
498
+ if (isFilledArray(fieldOrder)) {
499
+ return _sortInstanceProperty__default["default"](fields).call(fields, (a, b) => {
500
+ 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]);
501
+ 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]);
521
502
 
522
- // Sorts an array of custom field names placing those starting with 'assets.custom.fields.' first
523
- // This function doesn't affect the order of other custom fields
524
- function sortCustomFields(fields) {
525
- 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.'));
503
+ // If a field is not 'custom',then consider it as '*'
504
+ orderA = orderA === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderA;
505
+ orderB = orderB === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderB;
506
+ return orderA - orderB;
507
+ });
508
+ }
509
+ return fields;
526
510
  }
527
511
 
528
512
  // TODO: remove this function when filters are passed directly from parent views
@@ -535,43 +519,52 @@ function tmpBuildFilters(selectedResourceIds) {
535
519
  return ["id in (".concat(formattedIds, ")")];
536
520
  }
537
521
 
538
- const parentKeyExtension = ['parent.key', 'parent.typeId'];
539
- const customFieldsExtension = ['custom.type.key', 'custom.type.typeId'];
540
- const assetsCustomFieldsExtension = ['assets.custom.type.key', 'assets.custom.type.typeId'];
541
- 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'];
542
- const categoryFieldExtension = fields => {
543
- return _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
544
- if (field === 'parent.key') {
545
- return [...acc, ...parentKeyExtension];
546
- }
547
- if (_startsWithInstanceProperty__default["default"](field).call(field, 'custom.fields.') && !_includesInstanceProperty__default["default"](acc).call(acc, 'custom.type.key')) {
548
- return [...acc, ...customFieldsExtension, field];
549
- }
550
- if (field === 'assets') {
551
- return [...acc, ...assetsExtension];
552
- }
553
- if (_startsWithInstanceProperty__default["default"](field).call(field, 'assets.custom.fields.') && !_includesInstanceProperty__default["default"](acc).call(acc, 'assets.custom.type.key')) {
554
- return [...acc, ...assetsCustomFieldsExtension, field];
555
- }
556
- return [...acc, field];
557
- }, []);
558
- };
559
- const defaultFieldExtension = fields => fields;
560
- const fieldExtensionByResourceType = {
561
- default: defaultFieldExtension,
562
- category: categoryFieldExtension
522
+ 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; }
523
+ 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; }
524
+ const updateFieldGroupsWithIsCheckedValue = groups => {
525
+ const updateFields = (fields, parentChecked) => {
526
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
527
+ var _field$isRequired;
528
+ let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
529
+ if (field.fields) {
530
+ const updatedFields = updateFields(field.fields, isChecked);
531
+ isChecked = false;
532
+ field.fields = updatedFields;
533
+ }
534
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
535
+ isChecked
536
+ });
537
+ });
538
+ };
539
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
540
+ const updatedFields = updateFields(group.fields, false);
541
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
542
+ fields: updatedFields
543
+ });
544
+ });
563
545
  };
564
-
565
- const extendFields = _ref => {
566
- let resourceType = _ref.resourceType,
567
- fields = _ref.fields;
568
- const extensionFunction = fieldExtensionByResourceType[resourceType] || fieldExtensionByResourceType.default;
569
- return extensionFunction(fields);
546
+ const updateFieldGroupWithAdditionalFieldExtensions = groups => {
547
+ function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
548
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
549
+ const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
550
+ if (field.fields) {
551
+ field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
552
+ }
553
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
554
+ additionalFieldExtensions: updatedAdditionalFieldExtensions
555
+ });
556
+ });
557
+ }
558
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
559
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
560
+ fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
561
+ });
562
+ });
570
563
  };
571
564
 
572
565
  const _excluded = ["isSelectedByDefault"];
573
- 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; }
574
- 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; }
566
+ 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; }
567
+ function _objectSpread$3(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$3(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$3(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
575
568
  const useInitialValues = props => {
576
569
  var _context;
577
570
  const todayFormatted = moment__default["default"]().format('DD-MM-YY_HH-mm');
@@ -582,10 +575,11 @@ const useInitialValues = props => {
582
575
  const fields = _mapInstanceProperty__default["default"](_context = flattenNestedFields(props.fields)).call(_context, _ref => {
583
576
  let isSelectedByDefault = _ref.isSelectedByDefault,
584
577
  field = _objectWithoutProperties(_ref, _excluded);
585
- return _objectSpread$4(_objectSpread$4({}, field), {}, {
578
+ return _objectSpread$3(_objectSpread$3({}, field), {}, {
586
579
  isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
587
580
  });
588
581
  });
582
+ const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
589
583
  return React__default["default"].useMemo(() => {
590
584
  var _context2;
591
585
  return {
@@ -597,9 +591,10 @@ const useInitialValues = props => {
597
591
  }), "_Export_")).call(_context2, todayFormatted),
598
592
  locales: [locale],
599
593
  fields: checkRequiredFields(fields),
600
- customFields: setInitialCheckedStateForCustomFields(props.customFields)
594
+ customFields: setInitialCheckedStateForCustomFields(props.customFields),
595
+ groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
601
596
  };
602
- }, [props, locale, todayFormatted, fields]);
597
+ }, [props, locale, todayFormatted, fields, groups]);
603
598
  };
604
599
 
605
600
  async function createExportOperation(_ref) {
@@ -628,7 +623,7 @@ async function createExportOperation(_ref) {
628
623
  filters
629
624
  }
630
625
  }));
631
- if (!response.state) throw new InvalidResponseError('Invalid response');
626
+ if (!response.state) throw new shared.InvalidResponseError('Invalid response');
632
627
  return response;
633
628
  }
634
629
 
@@ -644,12 +639,29 @@ const useStartExportOperation = props => {
644
639
  };
645
640
  }),
646
641
  projectKey = _useApplicationContex.projectKey;
642
+ const extractFieldsFromGroups = groups => {
643
+ let selectedGeneralFields = [];
644
+ const getSelectedFields = fields => {
645
+ return _filterInstanceProperty__default["default"](fields).call(fields, field => {
646
+ var _field$isChecked;
647
+ if (field.fields) {
648
+ return getSelectedFields(field.fields);
649
+ }
650
+ if (field.isChecked) selectedGeneralFields.push(field);
651
+ return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
652
+ });
653
+ };
654
+ _forEachInstanceProperty__default["default"](groups).call(groups, group => {
655
+ getSelectedFields(group.fields);
656
+ });
657
+ return sortFieldsByFieldOrder({
658
+ fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
659
+ fieldOrder: props.fieldOrder
660
+ });
661
+ };
647
662
  const startExportOperation = async values => {
648
663
  try {
649
- const selectedGeneralFields = getSelectedGeneralFields(values.fields);
650
- const selectedCustomFields = getSelectedCustomFields(values.customFields);
651
- const generalFields = extractGeneralFieldNames(selectedGeneralFields);
652
- const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
664
+ const fields = extractFieldsFromGroups(values.groups);
653
665
  const filters = tmpBuildFilters(props.selectedResourceIds);
654
666
  const response = await createExportOperation({
655
667
  projectKey,
@@ -657,10 +669,7 @@ const useStartExportOperation = props => {
657
669
  fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
658
670
  fileFormat: values.outputFormat,
659
671
  locales: values.locales,
660
- fields: extendFields({
661
- resourceType: props.resourceType,
662
- fields: [...generalFields, ...customFields]
663
- }),
672
+ fields,
664
673
  filters,
665
674
  asyncDispatchFn: asyncDispatch
666
675
  });
@@ -670,6 +679,7 @@ const useStartExportOperation = props => {
670
679
  showNotification({
671
680
  kind: 'info',
672
681
  domain: constants.DOMAINS.SIDE,
682
+ // @ts-ignore
673
683
  text: intl.formatMessage(messages.exportOperationSuccessMessage, {
674
684
  newline: getNewLine,
675
685
  logsLink: msg => getExportLogsLink(projectKey, msg),
@@ -699,8 +709,8 @@ const useStartExportOperation = props => {
699
709
  };
700
710
  };
701
711
 
702
- 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; }
703
- 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; }
712
+ 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; }
713
+ 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; }
704
714
  function ExportTextMessage() {
705
715
  const intl = reactIntl.useIntl();
706
716
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -728,7 +738,7 @@ function ExportTextMessage() {
728
738
  }
729
739
  return jsxRuntime.jsx(uiKit.Text.Body, {
730
740
  "data-testid": "export-description",
731
- intlMessage: _objectSpread$3(_objectSpread$3({}, message), {}, {
741
+ intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
732
742
  values: {
733
743
  count: intl.formatNumber(count),
734
744
  resourceType: resourceTypePlural,
@@ -827,35 +837,203 @@ const ExportFileSettingsStep = () => {
827
837
  });
828
838
  };
829
839
 
830
- 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; }
831
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context12, _context13; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context12 = ownKeys$2(Object(t), !0)).call(_context12, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context13 = ownKeys$2(Object(t))).call(_context13, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
832
- const StyledCardLeft = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
833
- target: "e1ocu3bb1"
840
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
841
+ var _ref = process.env.NODE_ENV === "production" ? {
842
+ name: "ti75j2",
843
+ styles: "margin:0"
844
+ } : {
845
+ name: "ozey8m-NoSearchResults",
846
+ styles: "margin:0;label:NoSearchResults;",
847
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
848
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
849
+ };
850
+ const NoSearchResults = () => {
851
+ return jsxRuntime.jsxs(uiKit.Card, {
852
+ insetScale: "xl",
853
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
854
+ scale: "s",
855
+ children: [jsxRuntime.jsx(uiKit.Text.Body, {
856
+ fontWeight: "medium",
857
+ intlMessage: messages.thereAreNoResults
858
+ }), jsxRuntime.jsx(uiKit.Text.Body, {
859
+ intlMessage: messages.suggestions
860
+ })]
861
+ }), jsxRuntime.jsxs("ul", {
862
+ css: _ref,
863
+ children: [jsxRuntime.jsx("li", {
864
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
865
+ intlMessage: messages.checkTheSpelling
866
+ })
867
+ }), jsxRuntime.jsx("li", {
868
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
869
+ intlMessage: messages.searchByEnteringTheExactFieldName
870
+ })
871
+ })]
872
+ })]
873
+ });
874
+ };
875
+
876
+ 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; }
877
+ 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; }
878
+ const StyledGroupCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
879
+ target: "e3xiyhb1"
834
880
  } : {
835
- target: "e1ocu3bb1",
836
- label: "StyledCardLeft"
837
- })("height:100%;background-color:#f9f9fb;border-top:", _ref => {
838
- let isTopRow = _ref.isTopRow;
839
- return isTopRow ? uiKit.designTokens.borderForCardWhenRaised : 'none';
840
- }, ";border-radius:", _ref2 => {
841
- let isTopRow = _ref2.isTopRow;
842
- return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
843
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmBmC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\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'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\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\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          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow 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 ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\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                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\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={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          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, setFieldValue }) => {\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            setFieldValue(\n              'customFields',\n              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                  setFieldValue(\n                    'customFields',\n                    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"]} */"));
844
- const StyledCardRight = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
845
- target: "e1ocu3bb0"
881
+ target: "e3xiyhb1",
882
+ label: "StyledGroupCard"
883
+ })("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"]} */"));
884
+ const StyledFieldsCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
885
+ target: "e3xiyhb0"
846
886
  } : {
847
- target: "e1ocu3bb0",
848
- label: "StyledCardRight"
849
- })("height:100%;border-left:0;border-top:", _ref3 => {
850
- let isTopRow = _ref3.isTopRow;
851
- return isTopRow ? uiKit.designTokens.borderForCardWhenRaised : 'none';
852
- }, ";border-radius:", _ref4 => {
853
- let isTopRow = _ref4.isTopRow;
854
- return isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px';
855
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA2BoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\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'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\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\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          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow 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 ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\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                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\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={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          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, setFieldValue }) => {\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            setFieldValue(\n              'customFields',\n              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                  setFieldValue(\n                    'customFields',\n                    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"]} */"));
887
+ target: "e3xiyhb0",
888
+ label: "StyledFieldsCard"
889
+ })("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"]} */"));
890
+ const FieldSections = _ref => {
891
+ let fields = _ref.fields,
892
+ parentKeys = _ref.parentKeys,
893
+ formik = _ref.formik,
894
+ isAnySiblingChecked = _ref.isAnySiblingChecked;
895
+ return jsxRuntime.jsx(uiKit.Spacings.Stack, {
896
+ scale: "s",
897
+ children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, (field, index) => {
898
+ var _context, _field$fields3;
899
+ const isAtleastOneChildChecked = () => {
900
+ function checkAtLeastOneFieldChecked(fields) {
901
+ return fields === null || fields === void 0 ? void 0 : _someInstanceProperty__default["default"](fields).call(fields, field => {
902
+ if (field.fields) {
903
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
904
+ }
905
+ return field.isChecked;
906
+ });
907
+ }
908
+ return checkAtLeastOneFieldChecked(field.fields);
909
+ };
910
+ const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
911
+ if (field.isHidden) return null;
912
+ return jsxRuntime.jsxs(React__default["default"].Fragment, {
913
+ children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
914
+ isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
915
+ isReadOnly: field.isReadOnly || field.isRequired,
916
+ onChange: e => {
917
+ var _context2, _field$fields2;
918
+ const path = _concatInstanceProperty__default["default"](_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
919
+ // Update all child fields
920
+ const updateAllChildFieldsChecked = (path, checked) => {
921
+ const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), path);
922
+ if (item && item.fields) {
923
+ var _context3;
924
+ _forEachInstanceProperty__default["default"](_context3 = item.fields).call(_context3, (field, i) => {
925
+ var _context4, _field$fields;
926
+ const fieldPath = _concatInstanceProperty__default["default"](_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
927
+ if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
928
+ formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
929
+ // pass `false` to avoid revalidating the form with intermediate values
930
+ false);
931
+ }
932
+ updateAllChildFieldsChecked(fieldPath, checked);
933
+ });
934
+ }
935
+ };
936
+ if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
937
+ formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
938
+ // pass `false` to avoid revalidating the form with intermediate values
939
+ false);
940
+ }
941
+ updateAllChildFieldsChecked(path, e.target.checked);
942
+ },
943
+ children: [field.label, " ", field.isRequired && '*']
944
+ }), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxRuntime.jsxs(uiKit.Spacings.Inline, {
945
+ scale: "l",
946
+ children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(FieldSections, {
947
+ fields: field.fields,
948
+ formik: formik,
949
+ parentKeys: [...parentKeys, "fields[".concat(index, "]")],
950
+ isAnySiblingChecked: isAnySiblingChecked
951
+ })]
952
+ })]
953
+ }, _concatInstanceProperty__default["default"](_context = "".concat(field.name, "-")).call(_context, index));
954
+ })
955
+ });
956
+ };
957
+ function checkAllFieldsSelected(fields) {
958
+ return _everyInstanceProperty__default["default"](fields).call(fields, field => {
959
+ if (field.fields) {
960
+ return checkAllFieldsSelected(field.fields);
961
+ }
962
+ return field.isChecked || field.isRequired || field.isReadOnly;
963
+ });
964
+ }
965
+ function checkAtLeastOneFieldChecked(fields) {
966
+ return _someInstanceProperty__default["default"](fields).call(fields, field => {
967
+ if (field.fields) {
968
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
969
+ }
970
+ return field.isChecked;
971
+ });
972
+ }
973
+ const FieldGroupSection = _ref2 => {
974
+ let group = _ref2.group,
975
+ index = _ref2.index,
976
+ formik = _ref2.formik;
977
+ const allAllFieldsSelected = React__default["default"].useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
978
+ const isAtleastOneFieldChecked = React__default["default"].useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
979
+ const parentKey = "groups[".concat(index, "]");
980
+ const handleChangeAllFields = e => {
981
+ const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), parentKey);
982
+ function updateAllFields(fields, checked) {
983
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
984
+ if (field.fields) {
985
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
986
+ fields: updateAllFields(field.fields, checked)
987
+ });
988
+ }
989
+ if (field.isReadOnly || field.isRequired) return field;
990
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
991
+ isChecked: checked
992
+ });
993
+ });
994
+ }
995
+ formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
996
+ fields: updateAllFields(item.fields, e.target.checked)
997
+ }));
998
+ };
999
+ if (group.isHidden) return null;
1000
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
1001
+ children: [jsxRuntime.jsx(uiKit.Grid.Item, {
1002
+ children: jsxRuntime.jsx(StyledGroupCard, {
1003
+ type: "flat",
1004
+ insetScale: "l",
1005
+ showTopBorder: true,
1006
+ children: jsxRuntime.jsx(uiKit.CheckboxInput, {
1007
+ isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
1008
+ isChecked: allAllFieldsSelected,
1009
+ onChange: handleChangeAllFields,
1010
+ children: group.groupLabel
1011
+ })
1012
+ })
1013
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
1014
+ children: jsxRuntime.jsx(StyledFieldsCard, {
1015
+ type: "flat",
1016
+ insetScale: "l",
1017
+ showTopBorder: true,
1018
+ children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
1019
+ scale: "s",
1020
+ children: jsxRuntime.jsx(FieldSections, {
1021
+ fields: group.fields,
1022
+ formik: formik,
1023
+ parentKeys: [parentKey],
1024
+ isAnySiblingChecked: isAtleastOneFieldChecked
1025
+ })
1026
+ })
1027
+ })
1028
+ })]
1029
+ });
1030
+ };
856
1031
  const ExportFieldsSelectionStep = () => {
857
- var _formik$values$custom;
858
1032
  const intl = reactIntl.useIntl();
1033
+ const _React$useState = React__default["default"].useState(''),
1034
+ _React$useState2 = _slicedToArray(_React$useState, 2),
1035
+ fieldSearchTerm = _React$useState2[0],
1036
+ setFieldSearchTerm = _React$useState2[1];
859
1037
  const _useExportResourcesCo = useExportResourcesContext(),
860
1038
  formik = _useExportResourcesCo.formik,
861
1039
  setCurrentStep = _useExportResourcesCo.setCurrentStep,
@@ -865,24 +1043,48 @@ const ExportFieldsSelectionStep = () => {
865
1043
  resourceType: resourceType,
866
1044
  isPlural: true
867
1045
  });
868
- const areAllGeneralFieldsChecked = React__default["default"].useMemo(() => {
869
- var _context;
870
- return _everyInstanceProperty__default["default"](_context = _valuesInstanceProperty__default["default"](formik).fields).call(_context, field => field.isChecked);
871
- }, [_valuesInstanceProperty__default["default"](formik).fields]);
872
- const isAtLeastOneGeneralFieldChecked = React__default["default"].useMemo(() => {
873
- var _context2;
874
- return _someInstanceProperty__default["default"](_context2 = _valuesInstanceProperty__default["default"](formik).fields).call(_context2, field => field.isChecked);
875
- }, [_valuesInstanceProperty__default["default"](formik).fields]);
876
- const allCustomFields = React__default["default"].useMemo(() => {
877
- var _context3;
878
- return _flatMapInstanceProperty__default["default"](_context3 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context3, customType => customType.fields);
879
- }, [_valuesInstanceProperty__default["default"](formik).customFields]);
880
- const areAllCustomFieldsChecked = React__default["default"].useMemo(() => {
881
- return _everyInstanceProperty__default["default"](allCustomFields).call(allCustomFields, field => field.isChecked);
882
- }, [allCustomFields]);
883
- const isAtLeastOneCustomFieldChecked = React__default["default"].useMemo(() => {
884
- return _someInstanceProperty__default["default"](allCustomFields).call(allCustomFields, field => field.isChecked);
885
- }, [allCustomFields]);
1046
+ React__default["default"].useEffect(() => {
1047
+ formik.validateForm();
1048
+ // eslint-disable-next-line react-hooks/exhaustive-deps
1049
+ }, [_valuesInstanceProperty__default["default"](formik).groups]);
1050
+ // adds `isHidden` property to each field based on search term
1051
+ const filteredGroups = React__default["default"].useMemo(() => {
1052
+ var _fieldSearchTerm$trim, _context6;
1053
+ const updateFields = (fields, parentMatches) => {
1054
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
1055
+ var _context5;
1056
+ const matches = _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
1057
+ let isHidden = !matches && !parentMatches;
1058
+ if (field.fields) {
1059
+ const updatedFields = updateFields(field.fields, matches);
1060
+ isHidden = isHidden && _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, f => f.isHidden);
1061
+ field = _objectSpread$1(_objectSpread$1({}, field), {}, {
1062
+ fields: updatedFields
1063
+ });
1064
+ }
1065
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
1066
+ isHidden
1067
+ });
1068
+ });
1069
+ };
1070
+ 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;
1071
+ return _mapInstanceProperty__default["default"](_context6 = _valuesInstanceProperty__default["default"](formik).groups).call(_context6, group => {
1072
+ const updatedFields = updateFields(group.fields, false);
1073
+ const isHidden = _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, field => field.isHidden);
1074
+ return _objectSpread$1(_objectSpread$1({}, group), {}, {
1075
+ fields: updatedFields,
1076
+ isHidden
1077
+ });
1078
+ });
1079
+ }, [_valuesInstanceProperty__default["default"](formik).groups, fieldSearchTerm]);
1080
+ const onSearchChange = React__default["default"].useCallback(event => {
1081
+ setFieldSearchTerm(event.target.value);
1082
+ }, [setFieldSearchTerm]);
1083
+ const hasResults = Boolean(_findInstanceProperty__default["default"](filteredGroups).call(filteredGroups, group => !group.isHidden));
1084
+ const onSearchChangeThrottled = React__default["default"].useMemo(() => throttle__default["default"](onSearchChange, 300), [onSearchChange]);
1085
+ const onSearchReset = () => {
1086
+ setFieldSearchTerm('');
1087
+ };
886
1088
  return jsxRuntime.jsx(applicationComponents.FormDialog, {
887
1089
  isOpen: true,
888
1090
  title: intl.formatMessage(messages.modalTitle, {
@@ -909,145 +1111,30 @@ const ExportFieldsSelectionStep = () => {
909
1111
  intlMessage: messages.fieldDefinitions,
910
1112
  to: FIELD_DEFINITIONS_URLS[resourceType]
911
1113
  })]
912
- }), jsxRuntime.jsxs(uiKit.Grid, {
913
- gridAutoFlow: "row",
914
- gridTemplateColumns: "".concat(uiKit.designTokens.constraint5, " auto"),
915
- children: [jsxRuntime.jsx(uiKit.Grid.Item, {
916
- children: jsxRuntime.jsx(StyledCardLeft, {
917
- isTopRow: true,
918
- insetScale: "l",
919
- children: jsxRuntime.jsx(uiKit.CheckboxInput, {
920
- isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
921
- isChecked: areAllGeneralFieldsChecked,
922
- onChange: e => {
923
- var _context4;
924
- formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context4 = _valuesInstanceProperty__default["default"](formik).fields).call(_context4, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
925
- isChecked: field.isRequired ? true : e.target.checked
926
- })));
927
- },
928
- children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allGeneralFields))
929
- })
930
- })
931
- }), jsxRuntime.jsx(uiKit.Grid.Item, {
932
- children: jsxRuntime.jsx(StyledCardRight, {
933
- isTopRow: true,
934
- insetScale: "l",
935
- children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
936
- scale: "s",
937
- children: jsxRuntime.jsx(GeneralFieldsSelection, {
938
- fields: _valuesInstanceProperty__default["default"](formik).fields,
939
- setFieldValue: formik.setFieldValue
940
- })
941
- })
942
- })
943
- }), ((_formik$values$custom = _valuesInstanceProperty__default["default"](formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
944
- children: [jsxRuntime.jsx(uiKit.Grid.Item, {
945
- children: jsxRuntime.jsx(StyledCardLeft, {
946
- insetScale: "l",
947
- children: jsxRuntime.jsx(uiKit.CheckboxInput, {
948
- isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
949
- isChecked: areAllCustomFieldsChecked,
950
- onChange: e => {
951
- var _context5;
952
- formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context5 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context5, customType => {
953
- var _context6;
954
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
955
- fields: _mapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
956
- isChecked: e.target.checked
957
- }))
958
- });
959
- }));
960
- },
961
- children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
962
- })
963
- })
964
- }), jsxRuntime.jsx(uiKit.Grid.Item, {
965
- children: jsxRuntime.jsx(StyledCardRight, {
966
- insetScale: "l",
967
- children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
968
- scale: "s",
969
- children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
970
- isReadOnly: true,
971
- onChange: () => {},
972
- isChecked: isAtLeastOneCustomFieldChecked,
973
- children: [jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
974
- }), jsxRuntime.jsx(CustomFieldsSelection, {
975
- customFields: _valuesInstanceProperty__default["default"](formik).customFields,
976
- setFieldValue: formik.setFieldValue
977
- })]
978
- })
979
- })
980
- })]
981
- })]
982
- })]
1114
+ }), jsxRuntime.jsx(uiKit.SearchTextInput, {
1115
+ placeholder: intl.formatMessage(messages.searchForFields),
1116
+ value: fieldSearchTerm,
1117
+ onChange: onSearchChangeThrottled,
1118
+ onReset: onSearchReset
1119
+ // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
1120
+ ,
1121
+ onSubmit: () => {}
1122
+ }), hasResults ? jsxRuntime.jsx(uiKit.Card, {
1123
+ insetScale: "none",
1124
+ children: jsxRuntime.jsx(uiKit.Grid, {
1125
+ gridAutoFlow: "row",
1126
+ gridTemplateColumns: "".concat(uiKit.designTokens.constraint5, " auto"),
1127
+ children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) => jsxRuntime.jsx(FieldGroupSection, {
1128
+ group: group,
1129
+ index: index,
1130
+ formik: formik
1131
+ }, group.groupLabel))
1132
+ })
1133
+ }) : jsxRuntime.jsx(NoSearchResults, {})]
983
1134
  })
984
1135
  })
985
1136
  });
986
1137
  };
987
- const GeneralFieldsSelection = _ref5 => {
988
- let fields = _ref5.fields,
989
- setFieldValue = _ref5.setFieldValue;
990
- return _mapInstanceProperty__default["default"](fields).call(fields, field => jsxRuntime.jsxs(uiKit.CheckboxInput, {
991
- isChecked: field.isChecked,
992
- isReadOnly: field.isRequired,
993
- onChange: e => {
994
- setFieldValue('fields', _mapInstanceProperty__default["default"](fields).call(fields, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
995
- isChecked: e.target.checked
996
- }) : _field));
997
- },
998
- children: [field.label, " ", field.isRequired && '*']
999
- }, field.name));
1000
- };
1001
- const CustomFieldsSelection = _ref6 => {
1002
- let customFields = _ref6.customFields,
1003
- setFieldValue = _ref6.setFieldValue;
1004
- return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
1005
- var _context7, _context8, _context10;
1006
- const areAllFieldsChecked = _everyInstanceProperty__default["default"](_context7 = customType.fields).call(_context7, field => field.isChecked);
1007
- const isAtLeastOneFieldChecked = _someInstanceProperty__default["default"](_context8 = customType.fields).call(_context8, field => field.isChecked);
1008
- return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1009
- scale: "s",
1010
- children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
1011
- isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
1012
- isChecked: areAllFieldsChecked,
1013
- onChange: e => {
1014
- setFieldValue('customFields', _mapInstanceProperty__default["default"](customFields).call(customFields, _customType => {
1015
- var _context9;
1016
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1017
- fields: _mapInstanceProperty__default["default"](_context9 = _customType.fields).call(_context9, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1018
- isChecked: e.target.checked
1019
- }))
1020
- }) : _customType;
1021
- }));
1022
- },
1023
- children: jsxRuntime.jsx(uiKit.Text.Body, {
1024
- children: customType.type.label
1025
- })
1026
- }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
1027
- scale: "l",
1028
- children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(uiKit.Spacings.Stack, {
1029
- scale: "s",
1030
- children: _mapInstanceProperty__default["default"](_context10 = customType.fields).call(_context10, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
1031
- isChecked: field.isChecked,
1032
- onChange: e => {
1033
- setFieldValue('customFields', _mapInstanceProperty__default["default"](customFields).call(customFields, _customType => {
1034
- var _context11;
1035
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1036
- fields: _mapInstanceProperty__default["default"](_context11 = _customType.fields).call(_context11, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1037
- isChecked: e.target.checked
1038
- }) : _field)
1039
- }) : _customType;
1040
- }));
1041
- },
1042
- children: jsxRuntime.jsx(uiKit.Text.Body, {
1043
- children: field.label
1044
- })
1045
- }, field.name))
1046
- })]
1047
- })]
1048
- }, customType.type.key);
1049
- });
1050
- };
1051
1138
 
1052
1139
  process.env.NODE_ENV !== "production" ? {
1053
1140
  renderProperties: PropTypes__default["default"].func
@@ -1055,42 +1142,6 @@ process.env.NODE_ENV !== "production" ? {
1055
1142
 
1056
1143
  const ExportResourcesContext = /*#__PURE__*/React.createContext();
1057
1144
 
1058
- const ExportResourcesModalShape = PropTypes__default["default"].shape({
1059
- isOpen: PropTypes__default["default"].bool,
1060
- resourceType: PropTypes__default["default"].string.isRequired,
1061
- outputFormat: PropTypes__default["default"].string,
1062
- onClose: PropTypes__default["default"].func,
1063
- onExportSuccess: PropTypes__default["default"].func,
1064
- totalResourcesCount: PropTypes__default["default"].number.isRequired,
1065
- selectedResourceIds: PropTypes__default["default"].array,
1066
- // TODO: Circular reference
1067
- fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1068
- name: PropTypes__default["default"].string.isRequired,
1069
- label: PropTypes__default["default"].string,
1070
- fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1071
- name: PropTypes__default["default"].string.isRequired,
1072
- label: PropTypes__default["default"].string,
1073
- isSelectedByDefault: PropTypes__default["default"].bool,
1074
- isRequired: PropTypes__default["default"].bool
1075
- }))
1076
- })).isRequired,
1077
- customFields: PropTypes__default["default"].shape({
1078
- type: PropTypes__default["default"].shape({
1079
- key: PropTypes__default["default"].string.isRequired,
1080
- label: PropTypes__default["default"].string.isRequired,
1081
- resourceTypeIds: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string)
1082
- }).isRequired,
1083
- fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1084
- name: PropTypes__default["default"].string.isRequired,
1085
- label: PropTypes__default["default"].string
1086
- })).isRequired
1087
- }),
1088
- exportType: PropTypes__default["default"].string,
1089
- renderProperties: PropTypes__default["default"].func
1090
- }).isRequired;
1091
-
1092
- 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; }
1093
- 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; }
1094
1145
  const ExportResourcesProvider = props => {
1095
1146
  const initialValues = useInitialValues(props);
1096
1147
  const _useStartExportOperat = useStartExportOperation(props),
@@ -1131,10 +1182,6 @@ const ExportResourcesProvider = props => {
1131
1182
  children: props.children
1132
1183
  });
1133
1184
  };
1134
- ExportResourcesProvider.displayName = 'ExportResourcesProvider';
1135
- ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
1136
- children: PropTypes__default["default"].node
1137
- }) : {};
1138
1185
 
1139
1186
  const CurrentStep = () => {
1140
1187
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -1146,22 +1193,101 @@ const CurrentStep = () => {
1146
1193
  return steps[currentStep] || null;
1147
1194
  };
1148
1195
 
1196
+ const loadMessages = locale => {
1197
+ const intlLocale = i18n.mapLocaleToIntlLocale(locale);
1198
+ switch (intlLocale) {
1199
+ case 'de':
1200
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-de" */'./de-a34c5dd4.cjs.dev.js'); });
1201
+ case 'es':
1202
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-es" */'./es-8b3ecab1.cjs.dev.js'); });
1203
+ case 'fr-FR':
1204
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-fr-FR" */'./fr-FR-e7126fcc.cjs.dev.js'); });
1205
+ case 'zh-CN':
1206
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-zh-CN" */'./zh-CN-d4bc6d26.cjs.dev.js'); });
1207
+ case 'ja':
1208
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-ja" */'./ja-9bd5f452.cjs.dev.js'); });
1209
+ case 'pt-BR':
1210
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-ea6b3251.cjs.dev.js'); });
1211
+ default:
1212
+ return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-en" */'./en-6b3694f6.cjs.dev.js'); });
1213
+ }
1214
+ };
1215
+
1216
+ // eslint-disable-next-line import/prefer-default-export
1217
+ const loadI18n = async locale => {
1218
+ try {
1219
+ const messages = await loadMessages(locale);
1220
+ return messages.default || messages;
1221
+ } catch (error) {
1222
+ // eslint-disable-next-line no-console
1223
+ console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
1224
+ sentry.reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
1225
+ extra: error
1226
+ });
1227
+ return {};
1228
+ }
1229
+ };
1230
+
1231
+ const useAsyncIntlMessages = (locale, loader) => {
1232
+ const _useState = React.useState({
1233
+ isLoading: true,
1234
+ messages: undefined,
1235
+ error: undefined
1236
+ }),
1237
+ _useState2 = _slicedToArray(_useState, 2),
1238
+ state = _useState2[0],
1239
+ setState = _useState2[1];
1240
+ React.useEffect(() => {
1241
+ let _isUnmounting = false;
1242
+ async function load() {
1243
+ try {
1244
+ if (!_isUnmounting) {
1245
+ const messages = await loader(locale);
1246
+ setState({
1247
+ isLoading: false,
1248
+ messages
1249
+ });
1250
+ }
1251
+ } catch (error) {
1252
+ setState({
1253
+ isLoading: false,
1254
+ error
1255
+ });
1256
+ }
1257
+ }
1258
+ if (locale) load();
1259
+ return () => {
1260
+ _isUnmounting = true;
1261
+ };
1262
+ }, [locale, loader]);
1263
+ return state;
1264
+ };
1265
+
1149
1266
  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; }
1150
1267
  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; }
1151
1268
  const ExportResourcesModal = props => {
1152
- if (!props.isOpen) return null;
1153
- return jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1154
- children: jsxRuntime.jsx(CurrentStep, {})
1155
- }));
1269
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
1270
+ locale: context.user && context.user.locale
1271
+ })),
1272
+ locale = _useApplicationContex.locale;
1273
+ const messages = useAsyncIntlMessages('en', loadI18n);
1274
+ if (!props.isOpen || messages.isLoading) return null;
1275
+ return jsxRuntime.jsx(reactIntl.IntlProvider, {
1276
+ locale: locale,
1277
+ messages: messages.messages,
1278
+ children: jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1279
+ children: jsxRuntime.jsx(CurrentStep, {})
1280
+ }))
1281
+ });
1156
1282
  };
1157
1283
  ExportResourcesModal.displayName = 'ExportResourcesModal';
1158
- ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
1159
1284
  ExportResourcesModal.defaultProps = {
1160
1285
  isOpen: false,
1161
1286
  selectedResourceIds: [],
1162
1287
  exportType: EXPORT_TYPES.ALL,
1163
1288
  outputFormat: OUTPUT_FORMATS.CSV,
1164
- customFields: []
1289
+ customFields: [],
1290
+ fieldGroups: []
1165
1291
  };
1166
1292
 
1167
1293
  exports.EXPORTABLE_RESOURCES = EXPORTABLE_RESOURCES;