@commercetools-frontend-extensions/export-resources-modal 3.7.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.
@@ -7,14 +7,13 @@ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-st
7
7
  import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
8
8
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
- import React, { useContext, createContext } from 'react';
10
+ import { defineMessages, FormattedMessage, useIntl, IntlProvider } from 'react-intl';
11
+ import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
11
12
  import { Text, TextInput, Link, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, SearchTextInput, Grid } from '@commercetools-frontend/ui-kit';
12
13
  import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
13
14
  import '@commercetools-uikit/design-system';
14
- import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
15
15
  import _valuesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/values';
16
16
  import { FormDialog } from '@commercetools-frontend/application-components';
17
- import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
18
17
  import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
19
18
  import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
20
19
  import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
@@ -22,31 +21,37 @@ import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits';
22
21
  import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn';
23
22
  import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
24
23
  import _wrapNativeSuper from '@babel/runtime-corejs3/helpers/esm/wrapNativeSuper';
24
+ import React, { useContext, createContext, useState, useEffect } from 'react';
25
25
  import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
26
26
  import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
27
27
  import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
28
28
  import moment from 'moment';
29
+ import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
29
30
  import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
30
31
  import omitEmpty from 'omit-empty-es';
31
32
  import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
32
33
  import _flatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat';
33
- import _flatMapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat-map';
34
34
  import _Set from '@babel/runtime-corejs3/core-js-stable/set';
35
35
  import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort';
36
- import _startsWithInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
37
- import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
36
+ import '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
37
+ import _indexOfInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/index-of';
38
+ import { UnexpectedResourceTypeError, InvalidResponseError } from '@commercetools-local/shared';
38
39
  import { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
39
40
  import { useShowNotification } from '@commercetools-frontend/actions-global';
40
41
  import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants';
41
42
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
42
43
  import _styled from '@emotion/styled/base';
43
44
  import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
44
- import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
45
+ import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
45
46
  import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
47
+ import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
46
48
  import throttle from 'lodash/throttle';
47
49
  import { css } from '@emotion/react';
50
+ import get from 'lodash/get';
48
51
  import PropTypes from 'prop-types';
49
52
  import { useFormik } from 'formik';
53
+ import { reportErrorToSentry } from '@commercetools-frontend/sentry';
54
+ import { mapLocaleToIntlLocale } from '@commercetools-frontend/i18n';
50
55
 
51
56
  function getBold(msg) {
52
57
  return jsx(Text.Body, {
@@ -180,21 +185,6 @@ var messages = defineMessages({
180
185
  description: 'Label for "Field definitions" link',
181
186
  defaultMessage: 'Field definitions'
182
187
  },
183
- allGeneralFields: {
184
- id: 'ExportResourcesModal.allGeneralFields',
185
- description: 'Label for "All general fields" checkbox',
186
- defaultMessage: 'All general fields'
187
- },
188
- allCustomFields: {
189
- id: 'ExportResourcesModal.allCustomFields',
190
- description: 'Label for "All custom fields" checkbox',
191
- defaultMessage: 'All custom fields'
192
- },
193
- customTypeKeyAndTypeId: {
194
- id: 'ExportResourcesModal.customTypeKeyAndTypeId',
195
- description: 'Label for "Custom type key and typeId" checkbox',
196
- defaultMessage: 'Custom type key and typeId'
197
- },
198
188
  unexpectedError: {
199
189
  id: 'ExportResourcesModal.unexpectedError',
200
190
  description: 'Generic notification message when starting export process fails',
@@ -284,11 +274,11 @@ const FIELD_DEFINITIONS_URLS = {
284
274
  category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
285
275
  };
286
276
 
287
- 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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
288
- function _isNativeReflectConstruct$4() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$4 = function () { return !!t; })(); }
277
+ 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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
278
+ function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
289
279
  let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
290
280
  _inherits(UnexpectedExportTypeError, _Error);
291
- var _super = _createSuper$4(UnexpectedExportTypeError);
281
+ var _super = _createSuper$2(UnexpectedExportTypeError);
292
282
  function UnexpectedExportTypeError(exportType) {
293
283
  var _this;
294
284
  _classCallCheck(this, UnexpectedExportTypeError);
@@ -299,11 +289,11 @@ let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
299
289
  return _createClass(UnexpectedExportTypeError);
300
290
  }( /*#__PURE__*/_wrapNativeSuper(Error));
301
291
 
302
- 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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
303
- function _isNativeReflectConstruct$3() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$3 = function () { return !!t; })(); }
292
+ 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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
293
+ function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
304
294
  let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
305
295
  _inherits(MissingExportResourceProviderError, _Error);
306
- var _super = _createSuper$3(MissingExportResourceProviderError);
296
+ var _super = _createSuper$1(MissingExportResourceProviderError);
307
297
  function MissingExportResourceProviderError() {
308
298
  var _this;
309
299
  _classCallCheck(this, MissingExportResourceProviderError);
@@ -314,11 +304,11 @@ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
314
304
  return _createClass(MissingExportResourceProviderError);
315
305
  }( /*#__PURE__*/_wrapNativeSuper(Error));
316
306
 
317
- 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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
318
- function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
307
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
308
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
319
309
  let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
320
310
  _inherits(UnexpectedExportOperationStateError, _Error);
321
- var _super = _createSuper$2(UnexpectedExportOperationStateError);
311
+ var _super = _createSuper(UnexpectedExportOperationStateError);
322
312
  function UnexpectedExportOperationStateError(state) {
323
313
  var _this;
324
314
  _classCallCheck(this, UnexpectedExportOperationStateError);
@@ -329,36 +319,6 @@ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
329
319
  return _createClass(UnexpectedExportOperationStateError);
330
320
  }( /*#__PURE__*/_wrapNativeSuper(Error));
331
321
 
332
- 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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
333
- function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
334
- let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
335
- _inherits(UnexpectedResourceTypeError, _Error);
336
- var _super = _createSuper$1(UnexpectedResourceTypeError);
337
- function UnexpectedResourceTypeError(resourceType) {
338
- var _this;
339
- _classCallCheck(this, UnexpectedResourceTypeError);
340
- _this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
341
- _this.name = 'UnexpectedResourceTypeError';
342
- return _this;
343
- }
344
- return _createClass(UnexpectedResourceTypeError);
345
- }( /*#__PURE__*/_wrapNativeSuper(Error));
346
-
347
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
348
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
349
- let InvalidResponseError = /*#__PURE__*/function (_Error) {
350
- _inherits(InvalidResponseError, _Error);
351
- var _super = _createSuper(InvalidResponseError);
352
- function InvalidResponseError(message) {
353
- var _this;
354
- _classCallCheck(this, InvalidResponseError);
355
- _this = _super.call(this, message);
356
- _this.name = 'InvalidResponseError';
357
- return _this;
358
- }
359
- return _createClass(InvalidResponseError);
360
- }( /*#__PURE__*/_wrapNativeSuper(Error));
361
-
362
322
  function useExportResourcesContext() {
363
323
  const context = useContext(ExportResourcesContext);
364
324
  if (!context) {
@@ -367,33 +327,44 @@ function useExportResourcesContext() {
367
327
  return context;
368
328
  }
369
329
 
330
+ function checkAtLeastOneFieldChecked$1(fields) {
331
+ return _someInstanceProperty(fields).call(fields, field => {
332
+ if (field.fields) {
333
+ return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
334
+ }
335
+ return field.isChecked;
336
+ });
337
+ }
370
338
  function validate(_ref) {
371
339
  let values = _valuesInstanceProperty(_ref),
372
340
  step = _ref.step;
373
341
  const fileName = values.fileName,
374
342
  locales = values.locales,
375
- fields = values.fields,
376
- customFields = values.customFields;
343
+ groups = values.groups;
377
344
  const errors = {
378
345
  fileName: {},
379
346
  locales: {},
380
347
  fields: {}
381
348
  };
382
349
  if (TextInput.isEmpty(fileName)) {
350
+ // @ts-ignore
383
351
  errors.fileName.missing = true;
384
352
  } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
353
+ // @ts-ignore
385
354
  errors.fileName.invalidInput = true;
386
355
  }
387
356
  if (locales.length < 1) {
357
+ // @ts-ignore
388
358
  errors.locales.missing = true;
389
359
  }
390
360
  if (step === 2) {
391
- const checkedGeneralFieldsCount = _filterInstanceProperty(fields).call(fields, field => field.isChecked).length;
392
- const checkedCustomFieldsCount = _reduceInstanceProperty(customFields).call(customFields, (count, customType) => {
393
- var _context;
394
- return count + _filterInstanceProperty(_context = customType.fields).call(_context, field => field.isChecked).length;
395
- }, 0);
396
- if (checkedGeneralFieldsCount + checkedCustomFieldsCount < 2) {
361
+ const allFields = _reduceInstanceProperty(groups).call(groups, (acc, group) => _concatInstanceProperty(acc).call(acc, group.fields), []);
362
+ const checkedFieldsCount = _filterInstanceProperty(allFields).call(allFields, field => {
363
+ if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
364
+ return !field.isRequired && !field.isReadOnly && field.isChecked;
365
+ }).length;
366
+ if (checkedFieldsCount < 1) {
367
+ // @ts-ignore
397
368
  errors.fields.missing = true;
398
369
  }
399
370
  }
@@ -401,7 +372,7 @@ function validate(_ref) {
401
372
  }
402
373
 
403
374
  function ownKeys$5(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
404
- 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(_context8 = ownKeys$5(Object(t), !0)).call(_context8, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context9 = ownKeys$5(Object(t))).call(_context9, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
375
+ 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(_context5 = ownKeys$5(Object(t), !0)).call(_context5, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context6 = ownKeys$5(Object(t))).call(_context6, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
405
376
  function resourceTypeToDisplayName(_ref) {
406
377
  let resourceType = _ref.resourceType,
407
378
  _ref$isUpperCase = _ref.isUpperCase,
@@ -454,17 +425,6 @@ function flattenNestedFields(fields) {
454
425
  })) || [];
455
426
  return _flatInstanceProperty(result).call(result);
456
427
  }
457
- function getSelectedGeneralFields(fields) {
458
- return _filterInstanceProperty(fields).call(fields, field => field.isChecked);
459
- }
460
- function getSelectedCustomFields(customFields) {
461
- return _mapInstanceProperty(customFields).call(customFields, customType => {
462
- var _context4;
463
- return _objectSpread$5(_objectSpread$5({}, customType), {}, {
464
- fields: _filterInstanceProperty(_context4 = customType.fields).call(_context4, field => field.isChecked)
465
- });
466
- });
467
- }
468
428
  function checkRequiredFields(fields) {
469
429
  return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
470
430
  isChecked: true
@@ -478,45 +438,38 @@ function getExportLogsLink(projectKey, msg) {
478
438
  }
479
439
  function setInitialCheckedStateForCustomFields(customFields) {
480
440
  return _mapInstanceProperty(customFields).call(customFields, customType => {
481
- var _context5;
441
+ var _context4;
482
442
  return _objectSpread$5(_objectSpread$5({}, customType), {}, {
483
- fields: _mapInstanceProperty(_context5 = customType.fields).call(_context5, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
443
+ fields: _mapInstanceProperty(_context4 = customType.fields).call(_context4, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
484
444
  isChecked: false
485
445
  }))
486
446
  });
487
447
  });
488
448
  }
489
- function extractGeneralFieldNames(generalFields) {
490
- return _mapInstanceProperty(generalFields).call(generalFields, field => field.name);
491
- }
492
- function extractCustomFieldNamesWithPrefix(customFields) {
493
- const fields = _flatMapInstanceProperty(customFields).call(customFields, customType => {
494
- var _context6;
495
- return _flatMapInstanceProperty(_context6 = customType.fields).call(_context6, field => {
496
- return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
497
- });
498
- });
499
- return [...new _Set(fields)];
500
- }
501
- function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
502
- const prefixes = _mapInstanceProperty(resourceTypeIds).call(resourceTypeIds, type => {
503
- switch (type) {
504
- case 'asset':
505
- return 'assets.custom.fields.';
506
- default:
507
- return 'custom.fields.';
449
+ const extractFieldNamesAndAdditionalFieldExtensions = fields => {
450
+ const result = _reduceInstanceProperty(fields).call(fields, (acc, field) => {
451
+ if (field.additionalFieldExtensions) {
452
+ return [...acc, ...field.additionalFieldExtensions, field.name];
508
453
  }
509
- });
510
- return _mapInstanceProperty(prefixes).call(prefixes, prefix => {
511
- var _context7;
512
- return _concatInstanceProperty(_context7 = "".concat(prefix)).call(_context7, field.name);
513
- });
514
- }
454
+ return [...acc, field.name];
455
+ }, []);
456
+ return [...new _Set(result)];
457
+ };
458
+ function sortFieldsByFieldOrder(_ref2) {
459
+ let fields = _ref2.fields,
460
+ fieldOrder = _ref2.fieldOrder;
461
+ if (isFilledArray(fieldOrder)) {
462
+ return _sortInstanceProperty(fields).call(fields, (a, b) => {
463
+ let orderA = _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a) !== -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a) : _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a.split('.')[0]);
464
+ let orderB = _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b) !== -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b) : _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b.split('.')[0]);
515
465
 
516
- // Sorts an array of custom field names placing those starting with 'assets.custom.fields.' first
517
- // This function doesn't affect the order of other custom fields
518
- function sortCustomFields(fields) {
519
- return _sortInstanceProperty(fields).call(fields, (a, b) => _startsWithInstanceProperty(b).call(b, 'assets.custom.fields.') - _startsWithInstanceProperty(a).call(a, 'assets.custom.fields.'));
466
+ // If a field is not 'custom',then consider it as '*'
467
+ orderA = orderA === -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, '*') : orderA;
468
+ orderB = orderB === -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, '*') : orderB;
469
+ return orderA - orderB;
470
+ });
471
+ }
472
+ return fields;
520
473
  }
521
474
 
522
475
  // TODO: remove this function when filters are passed directly from parent views
@@ -529,43 +482,52 @@ function tmpBuildFilters(selectedResourceIds) {
529
482
  return ["id in (".concat(formattedIds, ")")];
530
483
  }
531
484
 
532
- const parentKeyExtension = ['parent.key', 'parent.typeId'];
533
- const customFieldsExtension = ['custom.type.key', 'custom.type.typeId'];
534
- const assetsCustomFieldsExtension = ['assets.custom.type.key', 'assets.custom.type.typeId'];
535
- 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'];
536
- const categoryFieldExtension = fields => {
537
- return _reduceInstanceProperty(fields).call(fields, (acc, field) => {
538
- if (field === 'parent.key') {
539
- return [...acc, ...parentKeyExtension];
540
- }
541
- if (_startsWithInstanceProperty(field).call(field, 'custom.fields.') && !_includesInstanceProperty(acc).call(acc, 'custom.type.key')) {
542
- return [...acc, ...customFieldsExtension, field];
543
- }
544
- if (field === 'assets') {
545
- return [...acc, ...assetsExtension];
546
- }
547
- if (_startsWithInstanceProperty(field).call(field, 'assets.custom.fields.') && !_includesInstanceProperty(acc).call(acc, 'assets.custom.type.key')) {
548
- return [...acc, ...assetsCustomFieldsExtension, field];
549
- }
550
- return [...acc, field];
551
- }, []);
552
- };
553
- const defaultFieldExtension = fields => fields;
554
- const fieldExtensionByResourceType = {
555
- default: defaultFieldExtension,
556
- category: categoryFieldExtension
485
+ function ownKeys$4(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
486
+ 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(_context = ownKeys$4(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$4(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
487
+ const updateFieldGroupsWithIsCheckedValue = groups => {
488
+ const updateFields = (fields, parentChecked) => {
489
+ return _mapInstanceProperty(fields).call(fields, field => {
490
+ var _field$isRequired;
491
+ let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
492
+ if (field.fields) {
493
+ const updatedFields = updateFields(field.fields, isChecked);
494
+ isChecked = false;
495
+ field.fields = updatedFields;
496
+ }
497
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
498
+ isChecked
499
+ });
500
+ });
501
+ };
502
+ return _mapInstanceProperty(groups).call(groups, group => {
503
+ const updatedFields = updateFields(group.fields, false);
504
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
505
+ fields: updatedFields
506
+ });
507
+ });
557
508
  };
558
-
559
- const extendFields = _ref => {
560
- let resourceType = _ref.resourceType,
561
- fields = _ref.fields;
562
- const extensionFunction = fieldExtensionByResourceType[resourceType] || fieldExtensionByResourceType.default;
563
- return extensionFunction(fields);
509
+ const updateFieldGroupWithAdditionalFieldExtensions = groups => {
510
+ function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
511
+ return _mapInstanceProperty(fields).call(fields, field => {
512
+ const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
513
+ if (field.fields) {
514
+ field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
515
+ }
516
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
517
+ additionalFieldExtensions: updatedAdditionalFieldExtensions
518
+ });
519
+ });
520
+ }
521
+ return _mapInstanceProperty(groups).call(groups, group => {
522
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
523
+ fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
524
+ });
525
+ });
564
526
  };
565
527
 
566
528
  const _excluded = ["isSelectedByDefault"];
567
- function ownKeys$4(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
568
- 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(_context3 = ownKeys$4(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$4(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
529
+ function ownKeys$3(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
530
+ 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(_context3 = ownKeys$3(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$3(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
569
531
  const useInitialValues = props => {
570
532
  var _context;
571
533
  const todayFormatted = moment().format('DD-MM-YY_HH-mm');
@@ -576,10 +538,11 @@ const useInitialValues = props => {
576
538
  const fields = _mapInstanceProperty(_context = flattenNestedFields(props.fields)).call(_context, _ref => {
577
539
  let isSelectedByDefault = _ref.isSelectedByDefault,
578
540
  field = _objectWithoutProperties(_ref, _excluded);
579
- return _objectSpread$4(_objectSpread$4({}, field), {}, {
541
+ return _objectSpread$3(_objectSpread$3({}, field), {}, {
580
542
  isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
581
543
  });
582
544
  });
545
+ const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
583
546
  return React.useMemo(() => {
584
547
  var _context2;
585
548
  return {
@@ -591,9 +554,10 @@ const useInitialValues = props => {
591
554
  }), "_Export_")).call(_context2, todayFormatted),
592
555
  locales: [locale],
593
556
  fields: checkRequiredFields(fields),
594
- customFields: setInitialCheckedStateForCustomFields(props.customFields)
557
+ customFields: setInitialCheckedStateForCustomFields(props.customFields),
558
+ groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
595
559
  };
596
- }, [props, locale, todayFormatted, fields]);
560
+ }, [props, locale, todayFormatted, fields, groups]);
597
561
  };
598
562
 
599
563
  async function createExportOperation(_ref) {
@@ -638,12 +602,29 @@ const useStartExportOperation = props => {
638
602
  };
639
603
  }),
640
604
  projectKey = _useApplicationContex.projectKey;
605
+ const extractFieldsFromGroups = groups => {
606
+ let selectedGeneralFields = [];
607
+ const getSelectedFields = fields => {
608
+ return _filterInstanceProperty(fields).call(fields, field => {
609
+ var _field$isChecked;
610
+ if (field.fields) {
611
+ return getSelectedFields(field.fields);
612
+ }
613
+ if (field.isChecked) selectedGeneralFields.push(field);
614
+ return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
615
+ });
616
+ };
617
+ _forEachInstanceProperty(groups).call(groups, group => {
618
+ getSelectedFields(group.fields);
619
+ });
620
+ return sortFieldsByFieldOrder({
621
+ fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
622
+ fieldOrder: props.fieldOrder
623
+ });
624
+ };
641
625
  const startExportOperation = async values => {
642
626
  try {
643
- const selectedGeneralFields = getSelectedGeneralFields(values.fields);
644
- const selectedCustomFields = getSelectedCustomFields(values.customFields);
645
- const generalFields = extractGeneralFieldNames(selectedGeneralFields);
646
- const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
627
+ const fields = extractFieldsFromGroups(values.groups);
647
628
  const filters = tmpBuildFilters(props.selectedResourceIds);
648
629
  const response = await createExportOperation({
649
630
  projectKey,
@@ -651,10 +632,7 @@ const useStartExportOperation = props => {
651
632
  fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
652
633
  fileFormat: values.outputFormat,
653
634
  locales: values.locales,
654
- fields: extendFields({
655
- resourceType: props.resourceType,
656
- fields: [...generalFields, ...customFields]
657
- }),
635
+ fields,
658
636
  filters,
659
637
  asyncDispatchFn: asyncDispatch
660
638
  });
@@ -664,6 +642,7 @@ const useStartExportOperation = props => {
664
642
  showNotification({
665
643
  kind: 'info',
666
644
  domain: DOMAINS.SIDE,
645
+ // @ts-ignore
667
646
  text: intl.formatMessage(messages.exportOperationSuccessMessage, {
668
647
  newline: getNewLine,
669
648
  logsLink: msg => getExportLogsLink(projectKey, msg),
@@ -693,8 +672,8 @@ const useStartExportOperation = props => {
693
672
  };
694
673
  };
695
674
 
696
- function ownKeys$3(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
697
- 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(_context = ownKeys$3(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$3(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
675
+ function ownKeys$2(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
676
+ 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(_context = ownKeys$2(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$2(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
698
677
  function ExportTextMessage() {
699
678
  const intl = useIntl();
700
679
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -722,7 +701,7 @@ function ExportTextMessage() {
722
701
  }
723
702
  return jsx(Text.Body, {
724
703
  "data-testid": "export-description",
725
- intlMessage: _objectSpread$3(_objectSpread$3({}, message), {}, {
704
+ intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
726
705
  values: {
727
706
  count: intl.formatNumber(count),
728
707
  resourceType: resourceTypePlural,
@@ -857,20 +836,161 @@ const NoSearchResults = () => {
857
836
  });
858
837
  };
859
838
 
860
- function ownKeys$2(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
861
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context22, _context23; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context22 = ownKeys$2(Object(t), !0)).call(_context22, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context23 = ownKeys$2(Object(t))).call(_context23, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
839
+ function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
840
+ 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(_context7 = ownKeys$1(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context8 = ownKeys$1(Object(t))).call(_context8, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
862
841
  const StyledGroupCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
863
- target: "e1ocu3bb1"
842
+ target: "e3xiyhb1"
864
843
  } : {
865
- target: "e1ocu3bb1",
844
+ target: "e3xiyhb1",
866
845
  label: "StyledGroupCard"
867
- })("border-right:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";background-color:", designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledGroupCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA8BO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAsBoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
846
+ })("border-right:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";background-color:", designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", 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"]} */"));
868
847
  const StyledFieldsCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
869
- target: "e1ocu3bb0"
848
+ target: "e3xiyhb0"
870
849
  } : {
871
- target: "e1ocu3bb0",
850
+ target: "e3xiyhb0",
872
851
  label: "StyledFieldsCard"
873
- })("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledFieldsCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAuCO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmCqC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
852
+ })("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", 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"]} */"));
853
+ const FieldSections = _ref => {
854
+ let fields = _ref.fields,
855
+ parentKeys = _ref.parentKeys,
856
+ formik = _ref.formik,
857
+ isAnySiblingChecked = _ref.isAnySiblingChecked;
858
+ return jsx(Spacings.Stack, {
859
+ scale: "s",
860
+ children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty(fields).call(fields, (field, index) => {
861
+ var _context, _field$fields3;
862
+ const isAtleastOneChildChecked = () => {
863
+ function checkAtLeastOneFieldChecked(fields) {
864
+ return fields === null || fields === void 0 ? void 0 : _someInstanceProperty(fields).call(fields, field => {
865
+ if (field.fields) {
866
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
867
+ }
868
+ return field.isChecked;
869
+ });
870
+ }
871
+ return checkAtLeastOneFieldChecked(field.fields);
872
+ };
873
+ const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
874
+ if (field.isHidden) return null;
875
+ return jsxs(React.Fragment, {
876
+ children: [jsxs(CheckboxInput, {
877
+ isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
878
+ isReadOnly: field.isReadOnly || field.isRequired,
879
+ onChange: e => {
880
+ var _context2, _field$fields2;
881
+ const path = _concatInstanceProperty(_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
882
+ // Update all child fields
883
+ const updateAllChildFieldsChecked = (path, checked) => {
884
+ const item = get(_valuesInstanceProperty(formik), path);
885
+ if (item && item.fields) {
886
+ var _context3;
887
+ _forEachInstanceProperty(_context3 = item.fields).call(_context3, (field, i) => {
888
+ var _context4, _field$fields;
889
+ const fieldPath = _concatInstanceProperty(_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
890
+ if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
891
+ formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
892
+ // pass `false` to avoid revalidating the form with intermediate values
893
+ false);
894
+ }
895
+ updateAllChildFieldsChecked(fieldPath, checked);
896
+ });
897
+ }
898
+ };
899
+ if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
900
+ formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
901
+ // pass `false` to avoid revalidating the form with intermediate values
902
+ false);
903
+ }
904
+ updateAllChildFieldsChecked(path, e.target.checked);
905
+ },
906
+ children: [field.label, " ", field.isRequired && '*']
907
+ }), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxs(Spacings.Inline, {
908
+ scale: "l",
909
+ children: [jsx("div", {}), jsx(FieldSections, {
910
+ fields: field.fields,
911
+ formik: formik,
912
+ parentKeys: [...parentKeys, "fields[".concat(index, "]")],
913
+ isAnySiblingChecked: isAnySiblingChecked
914
+ })]
915
+ })]
916
+ }, _concatInstanceProperty(_context = "".concat(field.name, "-")).call(_context, index));
917
+ })
918
+ });
919
+ };
920
+ function checkAllFieldsSelected(fields) {
921
+ return _everyInstanceProperty(fields).call(fields, field => {
922
+ if (field.fields) {
923
+ return checkAllFieldsSelected(field.fields);
924
+ }
925
+ return field.isChecked || field.isRequired || field.isReadOnly;
926
+ });
927
+ }
928
+ function checkAtLeastOneFieldChecked(fields) {
929
+ return _someInstanceProperty(fields).call(fields, field => {
930
+ if (field.fields) {
931
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
932
+ }
933
+ return field.isChecked;
934
+ });
935
+ }
936
+ const FieldGroupSection = _ref2 => {
937
+ let group = _ref2.group,
938
+ index = _ref2.index,
939
+ formik = _ref2.formik;
940
+ const allAllFieldsSelected = React.useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
941
+ const isAtleastOneFieldChecked = React.useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
942
+ const parentKey = "groups[".concat(index, "]");
943
+ const handleChangeAllFields = e => {
944
+ const item = get(_valuesInstanceProperty(formik), parentKey);
945
+ function updateAllFields(fields, checked) {
946
+ return _mapInstanceProperty(fields).call(fields, field => {
947
+ if (field.fields) {
948
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
949
+ fields: updateAllFields(field.fields, checked)
950
+ });
951
+ }
952
+ if (field.isReadOnly || field.isRequired) return field;
953
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
954
+ isChecked: checked
955
+ });
956
+ });
957
+ }
958
+ formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
959
+ fields: updateAllFields(item.fields, e.target.checked)
960
+ }));
961
+ };
962
+ if (group.isHidden) return null;
963
+ return jsxs(Fragment, {
964
+ children: [jsx(Grid.Item, {
965
+ children: jsx(StyledGroupCard, {
966
+ type: "flat",
967
+ insetScale: "l",
968
+ showTopBorder: true,
969
+ children: jsx(CheckboxInput, {
970
+ isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
971
+ isChecked: allAllFieldsSelected,
972
+ onChange: handleChangeAllFields,
973
+ children: group.groupLabel
974
+ })
975
+ })
976
+ }), jsx(Grid.Item, {
977
+ children: jsx(StyledFieldsCard, {
978
+ type: "flat",
979
+ insetScale: "l",
980
+ showTopBorder: true,
981
+ children: jsx(Spacings.Stack, {
982
+ scale: "s",
983
+ children: jsx(FieldSections, {
984
+ fields: group.fields,
985
+ formik: formik,
986
+ parentKeys: [parentKey],
987
+ isAnySiblingChecked: isAtleastOneFieldChecked
988
+ })
989
+ })
990
+ })
991
+ })]
992
+ });
993
+ };
874
994
  const ExportFieldsSelectionStep = () => {
875
995
  const intl = useIntl();
876
996
  const _React$useState = React.useState(''),
@@ -886,47 +1006,44 @@ const ExportFieldsSelectionStep = () => {
886
1006
  resourceType: resourceType,
887
1007
  isPlural: true
888
1008
  });
889
- const areAllGeneralFieldsChecked = React.useMemo(() => {
890
- var _context;
891
- return _everyInstanceProperty(_context = _valuesInstanceProperty(formik).fields).call(_context, field => field.isChecked);
892
- }, [_valuesInstanceProperty(formik).fields]);
893
- const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {
894
- var _context2;
895
- return _someInstanceProperty(_context2 = _valuesInstanceProperty(formik).fields).call(_context2, field => field.isChecked);
896
- }, [_valuesInstanceProperty(formik).fields]);
897
- const allCustomFields = React.useMemo(() => {
898
- var _context3;
899
- return _flatMapInstanceProperty(_context3 = _valuesInstanceProperty(formik).customFields).call(_context3, customType => customType.fields);
900
- }, [_valuesInstanceProperty(formik).customFields]);
901
- const areAllCustomFieldsChecked = React.useMemo(() => {
902
- return _everyInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
903
- }, [allCustomFields]);
904
- const isAtLeastOneCustomFieldChecked = React.useMemo(() => {
905
- return _someInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
906
- }, [allCustomFields]);
907
- const filteredGeneralFields = React.useMemo(() => {
908
- var _context4;
909
- return _filterInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => {
910
- var _context5;
911
- return _includesInstanceProperty(_context5 = field.label.toLowerCase()).call(_context5, _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
912
- });
913
- }, [_valuesInstanceProperty(formik).fields, fieldSearchTerm]);
914
- const filteredCustomFields = React.useMemo(() => {
915
- var _context6, _context7;
916
- return _filterInstanceProperty(_context6 = _mapInstanceProperty(_context7 = _valuesInstanceProperty(formik).customFields).call(_context7, customType => {
917
- var _context8, _context9;
918
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
919
- fields: _includesInstanceProperty(_context8 = customType.type.label.toLowerCase()).call(_context8, _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm).toLowerCase()) ? customType.fields : _filterInstanceProperty(_context9 = customType.fields).call(_context9, field => {
920
- var _context10;
921
- return _includesInstanceProperty(_context10 = field.label.toLowerCase()).call(_context10, _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
922
- })
1009
+ React.useEffect(() => {
1010
+ formik.validateForm();
1011
+ // eslint-disable-next-line react-hooks/exhaustive-deps
1012
+ }, [_valuesInstanceProperty(formik).groups]);
1013
+ // adds `isHidden` property to each field based on search term
1014
+ const filteredGroups = React.useMemo(() => {
1015
+ var _fieldSearchTerm$trim, _context6;
1016
+ const updateFields = (fields, parentMatches) => {
1017
+ return _mapInstanceProperty(fields).call(fields, field => {
1018
+ var _context5;
1019
+ const matches = _includesInstanceProperty(_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
1020
+ let isHidden = !matches && !parentMatches;
1021
+ if (field.fields) {
1022
+ const updatedFields = updateFields(field.fields, matches);
1023
+ isHidden = isHidden && _everyInstanceProperty(updatedFields).call(updatedFields, f => f.isHidden);
1024
+ field = _objectSpread$1(_objectSpread$1({}, field), {}, {
1025
+ fields: updatedFields
1026
+ });
1027
+ }
1028
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
1029
+ isHidden
1030
+ });
1031
+ });
1032
+ };
1033
+ if (!(fieldSearchTerm !== null && fieldSearchTerm !== void 0 && (_fieldSearchTerm$trim = _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm)) !== null && _fieldSearchTerm$trim !== void 0 && _fieldSearchTerm$trim.length)) return _valuesInstanceProperty(formik).groups;
1034
+ return _mapInstanceProperty(_context6 = _valuesInstanceProperty(formik).groups).call(_context6, group => {
1035
+ const updatedFields = updateFields(group.fields, false);
1036
+ const isHidden = _everyInstanceProperty(updatedFields).call(updatedFields, field => field.isHidden);
1037
+ return _objectSpread$1(_objectSpread$1({}, group), {}, {
1038
+ fields: updatedFields,
1039
+ isHidden
923
1040
  });
924
- })).call(_context6, customType => customType.fields.length > 0);
925
- }, [_valuesInstanceProperty(formik).customFields, fieldSearchTerm]);
1041
+ });
1042
+ }, [_valuesInstanceProperty(formik).groups, fieldSearchTerm]);
926
1043
  const onSearchChange = React.useCallback(event => {
927
1044
  setFieldSearchTerm(event.target.value);
928
1045
  }, [setFieldSearchTerm]);
929
- const hasResults = filteredGeneralFields.length > 0 || filteredCustomFields.length > 0;
1046
+ const hasResults = Boolean(_findInstanceProperty(filteredGroups).call(filteredGroups, group => !group.isHidden));
930
1047
  const onSearchChangeThrottled = React.useMemo(() => throttle(onSearchChange, 300), [onSearchChange]);
931
1048
  const onSearchReset = () => {
932
1049
  setFieldSearchTerm('');
@@ -962,157 +1079,25 @@ const ExportFieldsSelectionStep = () => {
962
1079
  value: fieldSearchTerm,
963
1080
  onChange: onSearchChangeThrottled,
964
1081
  onReset: onSearchReset
965
- }), !hasResults && jsx(NoSearchResults, {}), hasResults && jsx(Card, {
1082
+ // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
1083
+ ,
1084
+ onSubmit: () => {}
1085
+ }), hasResults ? jsx(Card, {
966
1086
  insetScale: "none",
967
- children: jsxs(Grid, {
1087
+ children: jsx(Grid, {
968
1088
  gridAutoFlow: "row",
969
1089
  gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
970
- children: [filteredGeneralFields.length > 0 && jsxs(Fragment, {
971
- children: [jsx(Grid.Item, {
972
- children: jsx(StyledGroupCard, {
973
- type: "flat",
974
- insetScale: "l",
975
- children: jsx(CheckboxInput, {
976
- isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
977
- isChecked: areAllGeneralFieldsChecked,
978
- onChange: e => {
979
- var _context11;
980
- formik.setFieldValue('fields', _mapInstanceProperty(_context11 = _valuesInstanceProperty(formik).fields).call(_context11, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
981
- isChecked: field.isRequired ? true : e.target.checked
982
- })));
983
- },
984
- children: jsx(FormattedMessage, _objectSpread$2({}, messages.allGeneralFields))
985
- })
986
- })
987
- }), jsx(Grid.Item, {
988
- children: jsx(StyledFieldsCard, {
989
- type: "flat",
990
- insetScale: "l",
991
- children: jsx(Spacings.Stack, {
992
- scale: "s",
993
- children: jsx(GeneralFieldsSelection, {
994
- fields: filteredGeneralFields,
995
- formik: formik
996
- })
997
- })
998
- })
999
- })]
1000
- }), filteredCustomFields.length > 0 && jsxs(Fragment, {
1001
- children: [jsx(Grid.Item, {
1002
- children: jsx(StyledGroupCard, {
1003
- type: "flat",
1004
- insetScale: "l",
1005
- showTopBorder: filteredGeneralFields.length > 0,
1006
- children: jsx(CheckboxInput, {
1007
- isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
1008
- isChecked: areAllCustomFieldsChecked,
1009
- onChange: e => {
1010
- var _context12;
1011
- formik.setFieldValue('customFields', _mapInstanceProperty(_context12 = _valuesInstanceProperty(formik).customFields).call(_context12, customType => {
1012
- var _context13;
1013
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
1014
- fields: _mapInstanceProperty(_context13 = customType.fields).call(_context13, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1015
- isChecked: e.target.checked
1016
- }))
1017
- });
1018
- }));
1019
- },
1020
- children: jsx(FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
1021
- })
1022
- })
1023
- }), jsx(Grid.Item, {
1024
- children: jsx(StyledFieldsCard, {
1025
- type: "flat",
1026
- insetScale: "l",
1027
- showTopBorder: filteredGeneralFields.length > 0,
1028
- children: jsxs(Spacings.Stack, {
1029
- scale: "s",
1030
- children: [jsxs(CheckboxInput, {
1031
- isReadOnly: true,
1032
- onChange: () => {},
1033
- isChecked: isAtLeastOneCustomFieldChecked,
1034
- children: [jsx(FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
1035
- }), jsx(CustomFieldsSelection, {
1036
- customFields: filteredCustomFields,
1037
- formik: formik
1038
- })]
1039
- })
1040
- })
1041
- })]
1042
- })]
1090
+ children: _mapInstanceProperty(filteredGroups).call(filteredGroups, (group, index) => jsx(FieldGroupSection, {
1091
+ group: group,
1092
+ index: index,
1093
+ formik: formik
1094
+ }, group.groupLabel))
1043
1095
  })
1044
- })]
1096
+ }) : jsx(NoSearchResults, {})]
1045
1097
  })
1046
1098
  })
1047
1099
  });
1048
1100
  };
1049
- const GeneralFieldsSelection = _ref => {
1050
- let fields = _ref.fields,
1051
- formik = _ref.formik;
1052
- return _mapInstanceProperty(fields).call(fields, field => jsxs(CheckboxInput, {
1053
- isChecked: field.isChecked,
1054
- isReadOnly: field.isRequired,
1055
- onChange: e => {
1056
- var _context14;
1057
- formik.setFieldValue('fields', _mapInstanceProperty(_context14 = _valuesInstanceProperty(formik).fields).call(_context14, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1058
- isChecked: e.target.checked
1059
- }) : _field));
1060
- },
1061
- children: [field.label, " ", field.isRequired && '*']
1062
- }, field.name));
1063
- };
1064
- const CustomFieldsSelection = _ref2 => {
1065
- let customFields = _ref2.customFields,
1066
- formik = _ref2.formik;
1067
- return _mapInstanceProperty(customFields).call(customFields, customType => {
1068
- var _context15, _context16, _context19;
1069
- const areAllFieldsChecked = _everyInstanceProperty(_context15 = customType.fields).call(_context15, field => field.isChecked);
1070
- const isAtLeastOneFieldChecked = _someInstanceProperty(_context16 = customType.fields).call(_context16, field => field.isChecked);
1071
- return jsxs(Spacings.Stack, {
1072
- scale: "s",
1073
- children: [jsx(CheckboxInput, {
1074
- isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
1075
- isChecked: areAllFieldsChecked,
1076
- onChange: e => {
1077
- var _context17;
1078
- formik.setFieldValue('customFields', _mapInstanceProperty(_context17 = _valuesInstanceProperty(formik).customFields).call(_context17, _customType => {
1079
- var _context18;
1080
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1081
- fields: _mapInstanceProperty(_context18 = _customType.fields).call(_context18, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1082
- isChecked: e.target.checked
1083
- }))
1084
- }) : _customType;
1085
- }));
1086
- },
1087
- children: jsx(Text.Body, {
1088
- children: customType.type.label
1089
- })
1090
- }), jsxs(Spacings.Inline, {
1091
- scale: "l",
1092
- children: [jsx("div", {}), jsx(Spacings.Stack, {
1093
- scale: "s",
1094
- children: _mapInstanceProperty(_context19 = customType.fields).call(_context19, field => jsx(CheckboxInput, {
1095
- isChecked: field.isChecked,
1096
- onChange: e => {
1097
- var _context20;
1098
- formik.setFieldValue('customFields', _mapInstanceProperty(_context20 = _valuesInstanceProperty(formik).customFields).call(_context20, _customType => {
1099
- var _context21;
1100
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1101
- fields: _mapInstanceProperty(_context21 = _customType.fields).call(_context21, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1102
- isChecked: e.target.checked
1103
- }) : _field)
1104
- }) : _customType;
1105
- }));
1106
- },
1107
- children: jsx(Text.Body, {
1108
- children: field.label
1109
- })
1110
- }, field.name))
1111
- })]
1112
- })]
1113
- }, customType.type.key);
1114
- });
1115
- };
1116
1101
 
1117
1102
  process.env.NODE_ENV !== "production" ? {
1118
1103
  renderProperties: PropTypes.func
@@ -1120,42 +1105,6 @@ process.env.NODE_ENV !== "production" ? {
1120
1105
 
1121
1106
  const ExportResourcesContext = /*#__PURE__*/createContext();
1122
1107
 
1123
- const ExportResourcesModalShape = PropTypes.shape({
1124
- isOpen: PropTypes.bool,
1125
- resourceType: PropTypes.string.isRequired,
1126
- outputFormat: PropTypes.string,
1127
- onClose: PropTypes.func,
1128
- onExportSuccess: PropTypes.func,
1129
- totalResourcesCount: PropTypes.number.isRequired,
1130
- selectedResourceIds: PropTypes.array,
1131
- // TODO: Circular reference
1132
- fields: PropTypes.arrayOf(PropTypes.shape({
1133
- name: PropTypes.string.isRequired,
1134
- label: PropTypes.string,
1135
- fields: PropTypes.arrayOf(PropTypes.shape({
1136
- name: PropTypes.string.isRequired,
1137
- label: PropTypes.string,
1138
- isSelectedByDefault: PropTypes.bool,
1139
- isRequired: PropTypes.bool
1140
- }))
1141
- })).isRequired,
1142
- customFields: PropTypes.shape({
1143
- type: PropTypes.shape({
1144
- key: PropTypes.string.isRequired,
1145
- label: PropTypes.string.isRequired,
1146
- resourceTypeIds: PropTypes.arrayOf(PropTypes.string)
1147
- }).isRequired,
1148
- fields: PropTypes.arrayOf(PropTypes.shape({
1149
- name: PropTypes.string.isRequired,
1150
- label: PropTypes.string
1151
- })).isRequired
1152
- }),
1153
- exportType: PropTypes.string,
1154
- renderProperties: PropTypes.func
1155
- }).isRequired;
1156
-
1157
- function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1158
- 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(_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1159
1108
  const ExportResourcesProvider = props => {
1160
1109
  const initialValues = useInitialValues(props);
1161
1110
  const _useStartExportOperat = useStartExportOperation(props),
@@ -1196,10 +1145,6 @@ const ExportResourcesProvider = props => {
1196
1145
  children: props.children
1197
1146
  });
1198
1147
  };
1199
- ExportResourcesProvider.displayName = 'ExportResourcesProvider';
1200
- ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
1201
- children: PropTypes.node
1202
- }) : {};
1203
1148
 
1204
1149
  const CurrentStep = () => {
1205
1150
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -1211,22 +1156,101 @@ const CurrentStep = () => {
1211
1156
  return steps[currentStep] || null;
1212
1157
  };
1213
1158
 
1159
+ const loadMessages = locale => {
1160
+ const intlLocale = mapLocaleToIntlLocale(locale);
1161
+ switch (intlLocale) {
1162
+ case 'de':
1163
+ return import( /* webpackChunkName: "export-resources-modal-i18n-de" */'./de-cd6c45d3.esm.js');
1164
+ case 'es':
1165
+ return import( /* webpackChunkName: "export-resources-modal-i18n-es" */'./es-e544023d.esm.js');
1166
+ case 'fr-FR':
1167
+ return import( /* webpackChunkName: "export-resources-modal-i18n-fr-FR" */'./fr-FR-9d9081ee.esm.js');
1168
+ case 'zh-CN':
1169
+ return import( /* webpackChunkName: "export-resources-modal-i18n-zh-CN" */'./zh-CN-4780d88e.esm.js');
1170
+ case 'ja':
1171
+ return import( /* webpackChunkName: "export-resources-modal-i18n-ja" */'./ja-73c088a7.esm.js');
1172
+ case 'pt-BR':
1173
+ return import( /* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-b37d730b.esm.js');
1174
+ default:
1175
+ return import( /* webpackChunkName: "export-resources-modal-i18n-en" */'./en-3a9aa2d4.esm.js');
1176
+ }
1177
+ };
1178
+
1179
+ // eslint-disable-next-line import/prefer-default-export
1180
+ const loadI18n = async locale => {
1181
+ try {
1182
+ const messages = await loadMessages(locale);
1183
+ return messages.default || messages;
1184
+ } catch (error) {
1185
+ // eslint-disable-next-line no-console
1186
+ console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
1187
+ reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
1188
+ extra: error
1189
+ });
1190
+ return {};
1191
+ }
1192
+ };
1193
+
1194
+ const useAsyncIntlMessages = (locale, loader) => {
1195
+ const _useState = useState({
1196
+ isLoading: true,
1197
+ messages: undefined,
1198
+ error: undefined
1199
+ }),
1200
+ _useState2 = _slicedToArray(_useState, 2),
1201
+ state = _useState2[0],
1202
+ setState = _useState2[1];
1203
+ useEffect(() => {
1204
+ let _isUnmounting = false;
1205
+ async function load() {
1206
+ try {
1207
+ if (!_isUnmounting) {
1208
+ const messages = await loader(locale);
1209
+ setState({
1210
+ isLoading: false,
1211
+ messages
1212
+ });
1213
+ }
1214
+ } catch (error) {
1215
+ setState({
1216
+ isLoading: false,
1217
+ error
1218
+ });
1219
+ }
1220
+ }
1221
+ if (locale) load();
1222
+ return () => {
1223
+ _isUnmounting = true;
1224
+ };
1225
+ }, [locale, loader]);
1226
+ return state;
1227
+ };
1228
+
1214
1229
  function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1215
1230
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1216
1231
  const ExportResourcesModal = props => {
1217
- if (!props.isOpen) return null;
1218
- return jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1219
- children: jsx(CurrentStep, {})
1220
- }));
1232
+ const _useApplicationContex = useApplicationContext(context => ({
1233
+ locale: context.user && context.user.locale
1234
+ })),
1235
+ locale = _useApplicationContex.locale;
1236
+ const messages = useAsyncIntlMessages('en', loadI18n);
1237
+ if (!props.isOpen || messages.isLoading) return null;
1238
+ return jsx(IntlProvider, {
1239
+ locale: locale,
1240
+ messages: messages.messages,
1241
+ children: jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1242
+ children: jsx(CurrentStep, {})
1243
+ }))
1244
+ });
1221
1245
  };
1222
1246
  ExportResourcesModal.displayName = 'ExportResourcesModal';
1223
- ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
1224
1247
  ExportResourcesModal.defaultProps = {
1225
1248
  isOpen: false,
1226
1249
  selectedResourceIds: [],
1227
1250
  exportType: EXPORT_TYPES.ALL,
1228
1251
  outputFormat: OUTPUT_FORMATS.CSV,
1229
- customFields: []
1252
+ customFields: [],
1253
+ fieldGroups: []
1230
1254
  };
1231
1255
 
1232
1256
  export { EXPORTABLE_RESOURCES, EXPORT_TYPES, ExportResourcesModal as default };