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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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';
11
- import { Text, TextInput, Link, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, Grid } from '@commercetools-frontend/ui-kit';
10
+ import { defineMessages, FormattedMessage, useIntl, IntlProvider } from 'react-intl';
11
+ import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
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,28 +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';
42
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
41
43
  import _styled from '@emotion/styled/base';
42
44
  import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
43
- import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
45
+ import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
46
+ import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
47
+ import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
48
+ import throttle from 'lodash/throttle';
49
+ import { css } from '@emotion/react';
50
+ import get from 'lodash/get';
44
51
  import PropTypes from 'prop-types';
45
- import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
46
52
  import { useFormik } from 'formik';
53
+ import { reportErrorToSentry } from '@commercetools-frontend/sentry';
54
+ import { mapLocaleToIntlLocale } from '@commercetools-frontend/i18n';
47
55
 
48
56
  function getBold(msg) {
49
57
  return jsx(Text.Body, {
@@ -177,25 +185,35 @@ var messages = defineMessages({
177
185
  description: 'Label for "Field definitions" link',
178
186
  defaultMessage: 'Field definitions'
179
187
  },
180
- allGeneralFields: {
181
- id: 'ExportResourcesModal.allGeneralFields',
182
- description: 'Label for "All general fields" checkbox',
183
- defaultMessage: 'All general fields'
184
- },
185
- allCustomFields: {
186
- id: 'ExportResourcesModal.allCustomFields',
187
- description: 'Label for "All custom fields" checkbox',
188
- defaultMessage: 'All custom fields'
189
- },
190
- customTypeKeyAndTypeId: {
191
- id: 'ExportResourcesModal.customTypeKeyAndTypeId',
192
- description: 'Label for "Custom type key and typeId" checkbox',
193
- defaultMessage: 'Custom type key and typeId'
194
- },
195
188
  unexpectedError: {
196
189
  id: 'ExportResourcesModal.unexpectedError',
197
190
  description: 'Generic notification message when starting export process fails',
198
191
  defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
192
+ },
193
+ searchForFields: {
194
+ id: 'ExportResourcesModal.searchForFields',
195
+ description: 'Placeholder for "Search for fields" search input',
196
+ defaultMessage: 'Search for fields'
197
+ },
198
+ thereAreNoResults: {
199
+ id: 'ExportResourcesModal.thereAreNoResults',
200
+ description: 'No search results message',
201
+ defaultMessage: 'There are no results that match your search.'
202
+ },
203
+ suggestions: {
204
+ id: 'ExportResourcesModal.suggestions',
205
+ description: 'In Export fields selection - Suggestions message',
206
+ defaultMessage: 'Suggestions:'
207
+ },
208
+ checkTheSpelling: {
209
+ id: 'ExportResourcesModal.checkTheSpelling',
210
+ description: 'In Export fields selection - Check the spelling message',
211
+ defaultMessage: 'Check the spelling.'
212
+ },
213
+ searchByEnteringTheExactFieldName: {
214
+ id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
215
+ description: 'In Export fields selection - Search by entering the exact field name message',
216
+ defaultMessage: 'Try searching by entering the exact field name.'
199
217
  }
200
218
  });
201
219
 
@@ -256,11 +274,11 @@ const FIELD_DEFINITIONS_URLS = {
256
274
  category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
257
275
  };
258
276
 
259
- 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); }; }
260
- 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; })(); }
261
279
  let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
262
280
  _inherits(UnexpectedExportTypeError, _Error);
263
- var _super = _createSuper$4(UnexpectedExportTypeError);
281
+ var _super = _createSuper$2(UnexpectedExportTypeError);
264
282
  function UnexpectedExportTypeError(exportType) {
265
283
  var _this;
266
284
  _classCallCheck(this, UnexpectedExportTypeError);
@@ -271,11 +289,11 @@ let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
271
289
  return _createClass(UnexpectedExportTypeError);
272
290
  }( /*#__PURE__*/_wrapNativeSuper(Error));
273
291
 
274
- 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); }; }
275
- 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; })(); }
276
294
  let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
277
295
  _inherits(MissingExportResourceProviderError, _Error);
278
- var _super = _createSuper$3(MissingExportResourceProviderError);
296
+ var _super = _createSuper$1(MissingExportResourceProviderError);
279
297
  function MissingExportResourceProviderError() {
280
298
  var _this;
281
299
  _classCallCheck(this, MissingExportResourceProviderError);
@@ -286,11 +304,11 @@ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
286
304
  return _createClass(MissingExportResourceProviderError);
287
305
  }( /*#__PURE__*/_wrapNativeSuper(Error));
288
306
 
289
- 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); }; }
290
- 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; })(); }
291
309
  let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
292
310
  _inherits(UnexpectedExportOperationStateError, _Error);
293
- var _super = _createSuper$2(UnexpectedExportOperationStateError);
311
+ var _super = _createSuper(UnexpectedExportOperationStateError);
294
312
  function UnexpectedExportOperationStateError(state) {
295
313
  var _this;
296
314
  _classCallCheck(this, UnexpectedExportOperationStateError);
@@ -301,36 +319,6 @@ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
301
319
  return _createClass(UnexpectedExportOperationStateError);
302
320
  }( /*#__PURE__*/_wrapNativeSuper(Error));
303
321
 
304
- 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); }; }
305
- function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
306
- let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
307
- _inherits(UnexpectedResourceTypeError, _Error);
308
- var _super = _createSuper$1(UnexpectedResourceTypeError);
309
- function UnexpectedResourceTypeError(resourceType) {
310
- var _this;
311
- _classCallCheck(this, UnexpectedResourceTypeError);
312
- _this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
313
- _this.name = 'UnexpectedResourceTypeError';
314
- return _this;
315
- }
316
- return _createClass(UnexpectedResourceTypeError);
317
- }( /*#__PURE__*/_wrapNativeSuper(Error));
318
-
319
- 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); }; }
320
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
321
- let InvalidResponseError = /*#__PURE__*/function (_Error) {
322
- _inherits(InvalidResponseError, _Error);
323
- var _super = _createSuper(InvalidResponseError);
324
- function InvalidResponseError(message) {
325
- var _this;
326
- _classCallCheck(this, InvalidResponseError);
327
- _this = _super.call(this, message);
328
- _this.name = 'InvalidResponseError';
329
- return _this;
330
- }
331
- return _createClass(InvalidResponseError);
332
- }( /*#__PURE__*/_wrapNativeSuper(Error));
333
-
334
322
  function useExportResourcesContext() {
335
323
  const context = useContext(ExportResourcesContext);
336
324
  if (!context) {
@@ -339,33 +327,44 @@ function useExportResourcesContext() {
339
327
  return context;
340
328
  }
341
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
+ }
342
338
  function validate(_ref) {
343
339
  let values = _valuesInstanceProperty(_ref),
344
340
  step = _ref.step;
345
341
  const fileName = values.fileName,
346
342
  locales = values.locales,
347
- fields = values.fields,
348
- customFields = values.customFields;
343
+ groups = values.groups;
349
344
  const errors = {
350
345
  fileName: {},
351
346
  locales: {},
352
347
  fields: {}
353
348
  };
354
349
  if (TextInput.isEmpty(fileName)) {
350
+ // @ts-ignore
355
351
  errors.fileName.missing = true;
356
352
  } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
353
+ // @ts-ignore
357
354
  errors.fileName.invalidInput = true;
358
355
  }
359
356
  if (locales.length < 1) {
357
+ // @ts-ignore
360
358
  errors.locales.missing = true;
361
359
  }
362
360
  if (step === 2) {
363
- const checkedGeneralFieldsCount = _filterInstanceProperty(fields).call(fields, field => field.isChecked).length;
364
- const checkedCustomFieldsCount = _reduceInstanceProperty(customFields).call(customFields, (count, customType) => {
365
- var _context;
366
- return count + _filterInstanceProperty(_context = customType.fields).call(_context, field => field.isChecked).length;
367
- }, 0);
368
- 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
369
368
  errors.fields.missing = true;
370
369
  }
371
370
  }
@@ -373,7 +372,7 @@ function validate(_ref) {
373
372
  }
374
373
 
375
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; }
376
- 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; }
377
376
  function resourceTypeToDisplayName(_ref) {
378
377
  let resourceType = _ref.resourceType,
379
378
  _ref$isUpperCase = _ref.isUpperCase,
@@ -426,17 +425,6 @@ function flattenNestedFields(fields) {
426
425
  })) || [];
427
426
  return _flatInstanceProperty(result).call(result);
428
427
  }
429
- function getSelectedGeneralFields(fields) {
430
- return _filterInstanceProperty(fields).call(fields, field => field.isChecked);
431
- }
432
- function getSelectedCustomFields(customFields) {
433
- return _mapInstanceProperty(customFields).call(customFields, customType => {
434
- var _context4;
435
- return _objectSpread$5(_objectSpread$5({}, customType), {}, {
436
- fields: _filterInstanceProperty(_context4 = customType.fields).call(_context4, field => field.isChecked)
437
- });
438
- });
439
- }
440
428
  function checkRequiredFields(fields) {
441
429
  return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
442
430
  isChecked: true
@@ -450,45 +438,38 @@ function getExportLogsLink(projectKey, msg) {
450
438
  }
451
439
  function setInitialCheckedStateForCustomFields(customFields) {
452
440
  return _mapInstanceProperty(customFields).call(customFields, customType => {
453
- var _context5;
441
+ var _context4;
454
442
  return _objectSpread$5(_objectSpread$5({}, customType), {}, {
455
- 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), {}, {
456
444
  isChecked: false
457
445
  }))
458
446
  });
459
447
  });
460
448
  }
461
- function extractGeneralFieldNames(generalFields) {
462
- return _mapInstanceProperty(generalFields).call(generalFields, field => field.name);
463
- }
464
- function extractCustomFieldNamesWithPrefix(customFields) {
465
- const fields = _flatMapInstanceProperty(customFields).call(customFields, customType => {
466
- var _context6;
467
- return _flatMapInstanceProperty(_context6 = customType.fields).call(_context6, field => {
468
- return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
469
- });
470
- });
471
- return [...new _Set(fields)];
472
- }
473
- function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
474
- const prefixes = _mapInstanceProperty(resourceTypeIds).call(resourceTypeIds, type => {
475
- switch (type) {
476
- case 'asset':
477
- return 'assets.custom.fields.';
478
- default:
479
- 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];
480
453
  }
481
- });
482
- return _mapInstanceProperty(prefixes).call(prefixes, prefix => {
483
- var _context7;
484
- return _concatInstanceProperty(_context7 = "".concat(prefix)).call(_context7, field.name);
485
- });
486
- }
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]);
487
465
 
488
- // Sorts an array of custom field names placing those starting with 'assets.custom.fields.' first
489
- // This function doesn't affect the order of other custom fields
490
- function sortCustomFields(fields) {
491
- 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;
492
473
  }
493
474
 
494
475
  // TODO: remove this function when filters are passed directly from parent views
@@ -501,43 +482,52 @@ function tmpBuildFilters(selectedResourceIds) {
501
482
  return ["id in (".concat(formattedIds, ")")];
502
483
  }
503
484
 
504
- const parentKeyExtension = ['parent.key', 'parent.typeId'];
505
- const customFieldsExtension = ['custom.type.key', 'custom.type.typeId'];
506
- const assetsCustomFieldsExtension = ['assets.custom.type.key', 'assets.custom.type.typeId'];
507
- 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'];
508
- const categoryFieldExtension = fields => {
509
- return _reduceInstanceProperty(fields).call(fields, (acc, field) => {
510
- if (field === 'parent.key') {
511
- return [...acc, ...parentKeyExtension];
512
- }
513
- if (_startsWithInstanceProperty(field).call(field, 'custom.fields.') && !_includesInstanceProperty(acc).call(acc, 'custom.type.key')) {
514
- return [...acc, ...customFieldsExtension, field];
515
- }
516
- if (field === 'assets') {
517
- return [...acc, ...assetsExtension];
518
- }
519
- if (_startsWithInstanceProperty(field).call(field, 'assets.custom.fields.') && !_includesInstanceProperty(acc).call(acc, 'assets.custom.type.key')) {
520
- return [...acc, ...assetsCustomFieldsExtension, field];
521
- }
522
- return [...acc, field];
523
- }, []);
524
- };
525
- const defaultFieldExtension = fields => fields;
526
- const fieldExtensionByResourceType = {
527
- default: defaultFieldExtension,
528
- 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
+ });
529
508
  };
530
-
531
- const extendFields = _ref => {
532
- let resourceType = _ref.resourceType,
533
- fields = _ref.fields;
534
- const extensionFunction = fieldExtensionByResourceType[resourceType] || fieldExtensionByResourceType.default;
535
- 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
+ });
536
526
  };
537
527
 
538
528
  const _excluded = ["isSelectedByDefault"];
539
- 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; }
540
- 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; }
541
531
  const useInitialValues = props => {
542
532
  var _context;
543
533
  const todayFormatted = moment().format('DD-MM-YY_HH-mm');
@@ -548,10 +538,11 @@ const useInitialValues = props => {
548
538
  const fields = _mapInstanceProperty(_context = flattenNestedFields(props.fields)).call(_context, _ref => {
549
539
  let isSelectedByDefault = _ref.isSelectedByDefault,
550
540
  field = _objectWithoutProperties(_ref, _excluded);
551
- return _objectSpread$4(_objectSpread$4({}, field), {}, {
541
+ return _objectSpread$3(_objectSpread$3({}, field), {}, {
552
542
  isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
553
543
  });
554
544
  });
545
+ const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
555
546
  return React.useMemo(() => {
556
547
  var _context2;
557
548
  return {
@@ -563,9 +554,10 @@ const useInitialValues = props => {
563
554
  }), "_Export_")).call(_context2, todayFormatted),
564
555
  locales: [locale],
565
556
  fields: checkRequiredFields(fields),
566
- customFields: setInitialCheckedStateForCustomFields(props.customFields)
557
+ customFields: setInitialCheckedStateForCustomFields(props.customFields),
558
+ groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
567
559
  };
568
- }, [props, locale, todayFormatted, fields]);
560
+ }, [props, locale, todayFormatted, fields, groups]);
569
561
  };
570
562
 
571
563
  async function createExportOperation(_ref) {
@@ -610,12 +602,29 @@ const useStartExportOperation = props => {
610
602
  };
611
603
  }),
612
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
+ };
613
625
  const startExportOperation = async values => {
614
626
  try {
615
- const selectedGeneralFields = getSelectedGeneralFields(values.fields);
616
- const selectedCustomFields = getSelectedCustomFields(values.customFields);
617
- const generalFields = extractGeneralFieldNames(selectedGeneralFields);
618
- const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
627
+ const fields = extractFieldsFromGroups(values.groups);
619
628
  const filters = tmpBuildFilters(props.selectedResourceIds);
620
629
  const response = await createExportOperation({
621
630
  projectKey,
@@ -623,10 +632,7 @@ const useStartExportOperation = props => {
623
632
  fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
624
633
  fileFormat: values.outputFormat,
625
634
  locales: values.locales,
626
- fields: extendFields({
627
- resourceType: props.resourceType,
628
- fields: [...generalFields, ...customFields]
629
- }),
635
+ fields,
630
636
  filters,
631
637
  asyncDispatchFn: asyncDispatch
632
638
  });
@@ -636,6 +642,7 @@ const useStartExportOperation = props => {
636
642
  showNotification({
637
643
  kind: 'info',
638
644
  domain: DOMAINS.SIDE,
645
+ // @ts-ignore
639
646
  text: intl.formatMessage(messages.exportOperationSuccessMessage, {
640
647
  newline: getNewLine,
641
648
  logsLink: msg => getExportLogsLink(projectKey, msg),
@@ -665,8 +672,8 @@ const useStartExportOperation = props => {
665
672
  };
666
673
  };
667
674
 
668
- 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; }
669
- 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; }
670
677
  function ExportTextMessage() {
671
678
  const intl = useIntl();
672
679
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -694,7 +701,7 @@ function ExportTextMessage() {
694
701
  }
695
702
  return jsx(Text.Body, {
696
703
  "data-testid": "export-description",
697
- intlMessage: _objectSpread$3(_objectSpread$3({}, message), {}, {
704
+ intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
698
705
  values: {
699
706
  count: intl.formatNumber(count),
700
707
  resourceType: resourceTypePlural,
@@ -793,35 +800,203 @@ const ExportFileSettingsStep = () => {
793
800
  });
794
801
  };
795
802
 
796
- 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; }
797
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context12, _context13; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context12 = ownKeys$2(Object(t), !0)).call(_context12, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context13 = ownKeys$2(Object(t))).call(_context13, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
798
- const StyledCardLeft = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
799
- target: "e1ocu3bb1"
803
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
804
+ var _ref = process.env.NODE_ENV === "production" ? {
805
+ name: "ti75j2",
806
+ styles: "margin:0"
800
807
  } : {
801
- target: "e1ocu3bb1",
802
- label: "StyledCardLeft"
803
- })("height:100%;background-color:#f9f9fb;border-top:", _ref => {
804
- let isTopRow = _ref.isTopRow;
805
- return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
806
- }, ";border-radius:", _ref2 => {
807
- let isTopRow = _ref2.isTopRow;
808
- return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
809
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmBmC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow insetScale=\"l\">\n                <CheckboxInput\n                  isIndeterminate={\n                    !areAllGeneralFieldsChecked &&\n                    isAtLeastOneGeneralFieldChecked\n                  }\n                  isChecked={areAllGeneralFieldsChecked}\n                  onChange={(e) => {\n                    formik.setFieldValue(\n                      'fields',\n                      formik.values.fields.map((field) => ({\n                        ...field,\n                        isChecked: field.isRequired ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <FormattedMessage {...messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <FormattedMessage\n                          {...messages.customTypeKeyAndTypeId}\n                        />{' '}\n                        *\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
810
- const StyledCardRight = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
811
- target: "e1ocu3bb0"
808
+ name: "ozey8m-NoSearchResults",
809
+ styles: "margin:0;label:NoSearchResults;",
810
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
811
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
812
+ };
813
+ const NoSearchResults = () => {
814
+ return jsxs(Card, {
815
+ insetScale: "xl",
816
+ children: [jsxs(Spacings.Stack, {
817
+ scale: "s",
818
+ children: [jsx(Text.Body, {
819
+ fontWeight: "medium",
820
+ intlMessage: messages.thereAreNoResults
821
+ }), jsx(Text.Body, {
822
+ intlMessage: messages.suggestions
823
+ })]
824
+ }), jsxs("ul", {
825
+ css: _ref,
826
+ children: [jsx("li", {
827
+ children: jsx(Text.Body, {
828
+ intlMessage: messages.checkTheSpelling
829
+ })
830
+ }), jsx("li", {
831
+ children: jsx(Text.Body, {
832
+ intlMessage: messages.searchByEnteringTheExactFieldName
833
+ })
834
+ })]
835
+ })]
836
+ });
837
+ };
838
+
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; }
841
+ const StyledGroupCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
842
+ target: "e3xiyhb1"
843
+ } : {
844
+ target: "e3xiyhb1",
845
+ label: "StyledGroupCard"
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"]} */"));
847
+ const StyledFieldsCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
848
+ target: "e3xiyhb0"
812
849
  } : {
813
- target: "e1ocu3bb0",
814
- label: "StyledCardRight"
815
- })("height:100%;border-left:0;border-top:", _ref3 => {
816
- let isTopRow = _ref3.isTopRow;
817
- return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
818
- }, ";border-radius:", _ref4 => {
819
- let isTopRow = _ref4.isTopRow;
820
- return isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px';
821
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA2BoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow insetScale=\"l\">\n                <CheckboxInput\n                  isIndeterminate={\n                    !areAllGeneralFieldsChecked &&\n                    isAtLeastOneGeneralFieldChecked\n                  }\n                  isChecked={areAllGeneralFieldsChecked}\n                  onChange={(e) => {\n                    formik.setFieldValue(\n                      'fields',\n                      formik.values.fields.map((field) => ({\n                        ...field,\n                        isChecked: field.isRequired ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <FormattedMessage {...messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <FormattedMessage\n                          {...messages.customTypeKeyAndTypeId}\n                        />{' '}\n                        *\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
850
+ target: "e3xiyhb0",
851
+ label: "StyledFieldsCard"
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
+ };
822
994
  const ExportFieldsSelectionStep = () => {
823
- var _formik$values$custom;
824
995
  const intl = useIntl();
996
+ const _React$useState = React.useState(''),
997
+ _React$useState2 = _slicedToArray(_React$useState, 2),
998
+ fieldSearchTerm = _React$useState2[0],
999
+ setFieldSearchTerm = _React$useState2[1];
825
1000
  const _useExportResourcesCo = useExportResourcesContext(),
826
1001
  formik = _useExportResourcesCo.formik,
827
1002
  setCurrentStep = _useExportResourcesCo.setCurrentStep,
@@ -831,24 +1006,48 @@ const ExportFieldsSelectionStep = () => {
831
1006
  resourceType: resourceType,
832
1007
  isPlural: true
833
1008
  });
834
- const areAllGeneralFieldsChecked = React.useMemo(() => {
835
- var _context;
836
- return _everyInstanceProperty(_context = _valuesInstanceProperty(formik).fields).call(_context, field => field.isChecked);
837
- }, [_valuesInstanceProperty(formik).fields]);
838
- const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {
839
- var _context2;
840
- return _someInstanceProperty(_context2 = _valuesInstanceProperty(formik).fields).call(_context2, field => field.isChecked);
841
- }, [_valuesInstanceProperty(formik).fields]);
842
- const allCustomFields = React.useMemo(() => {
843
- var _context3;
844
- return _flatMapInstanceProperty(_context3 = _valuesInstanceProperty(formik).customFields).call(_context3, customType => customType.fields);
845
- }, [_valuesInstanceProperty(formik).customFields]);
846
- const areAllCustomFieldsChecked = React.useMemo(() => {
847
- return _everyInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
848
- }, [allCustomFields]);
849
- const isAtLeastOneCustomFieldChecked = React.useMemo(() => {
850
- return _someInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
851
- }, [allCustomFields]);
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
1040
+ });
1041
+ });
1042
+ }, [_valuesInstanceProperty(formik).groups, fieldSearchTerm]);
1043
+ const onSearchChange = React.useCallback(event => {
1044
+ setFieldSearchTerm(event.target.value);
1045
+ }, [setFieldSearchTerm]);
1046
+ const hasResults = Boolean(_findInstanceProperty(filteredGroups).call(filteredGroups, group => !group.isHidden));
1047
+ const onSearchChangeThrottled = React.useMemo(() => throttle(onSearchChange, 300), [onSearchChange]);
1048
+ const onSearchReset = () => {
1049
+ setFieldSearchTerm('');
1050
+ };
852
1051
  return jsx(FormDialog, {
853
1052
  isOpen: true,
854
1053
  title: intl.formatMessage(messages.modalTitle, {
@@ -875,145 +1074,30 @@ const ExportFieldsSelectionStep = () => {
875
1074
  intlMessage: messages.fieldDefinitions,
876
1075
  to: FIELD_DEFINITIONS_URLS[resourceType]
877
1076
  })]
878
- }), jsxs(Grid, {
879
- gridAutoFlow: "row",
880
- gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
881
- children: [jsx(Grid.Item, {
882
- children: jsx(StyledCardLeft, {
883
- isTopRow: true,
884
- insetScale: "l",
885
- children: jsx(CheckboxInput, {
886
- isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
887
- isChecked: areAllGeneralFieldsChecked,
888
- onChange: e => {
889
- var _context4;
890
- formik.setFieldValue('fields', _mapInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
891
- isChecked: field.isRequired ? true : e.target.checked
892
- })));
893
- },
894
- children: jsx(FormattedMessage, _objectSpread$2({}, messages.allGeneralFields))
895
- })
896
- })
897
- }), jsx(Grid.Item, {
898
- children: jsx(StyledCardRight, {
899
- isTopRow: true,
900
- insetScale: "l",
901
- children: jsx(Spacings.Stack, {
902
- scale: "s",
903
- children: jsx(GeneralFieldsSelection, {
904
- fields: _valuesInstanceProperty(formik).fields,
905
- setFieldValue: formik.setFieldValue
906
- })
907
- })
908
- })
909
- }), ((_formik$values$custom = _valuesInstanceProperty(formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxs(Fragment, {
910
- children: [jsx(Grid.Item, {
911
- children: jsx(StyledCardLeft, {
912
- insetScale: "l",
913
- children: jsx(CheckboxInput, {
914
- isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
915
- isChecked: areAllCustomFieldsChecked,
916
- onChange: e => {
917
- var _context5;
918
- formik.setFieldValue('customFields', _mapInstanceProperty(_context5 = _valuesInstanceProperty(formik).customFields).call(_context5, customType => {
919
- var _context6;
920
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
921
- fields: _mapInstanceProperty(_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
922
- isChecked: e.target.checked
923
- }))
924
- });
925
- }));
926
- },
927
- children: jsx(FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
928
- })
929
- })
930
- }), jsx(Grid.Item, {
931
- children: jsx(StyledCardRight, {
932
- insetScale: "l",
933
- children: jsxs(Spacings.Stack, {
934
- scale: "s",
935
- children: [jsxs(CheckboxInput, {
936
- isReadOnly: true,
937
- onChange: () => {},
938
- isChecked: isAtLeastOneCustomFieldChecked,
939
- children: [jsx(FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
940
- }), jsx(CustomFieldsSelection, {
941
- customFields: _valuesInstanceProperty(formik).customFields,
942
- setFieldValue: formik.setFieldValue
943
- })]
944
- })
945
- })
946
- })]
947
- })]
948
- })]
1077
+ }), jsx(SearchTextInput, {
1078
+ placeholder: intl.formatMessage(messages.searchForFields),
1079
+ value: fieldSearchTerm,
1080
+ onChange: onSearchChangeThrottled,
1081
+ onReset: onSearchReset
1082
+ // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
1083
+ ,
1084
+ onSubmit: () => {}
1085
+ }), hasResults ? jsx(Card, {
1086
+ insetScale: "none",
1087
+ children: jsx(Grid, {
1088
+ gridAutoFlow: "row",
1089
+ gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
1090
+ children: _mapInstanceProperty(filteredGroups).call(filteredGroups, (group, index) => jsx(FieldGroupSection, {
1091
+ group: group,
1092
+ index: index,
1093
+ formik: formik
1094
+ }, group.groupLabel))
1095
+ })
1096
+ }) : jsx(NoSearchResults, {})]
949
1097
  })
950
1098
  })
951
1099
  });
952
1100
  };
953
- const GeneralFieldsSelection = _ref5 => {
954
- let fields = _ref5.fields,
955
- setFieldValue = _ref5.setFieldValue;
956
- return _mapInstanceProperty(fields).call(fields, field => jsxs(CheckboxInput, {
957
- isChecked: field.isChecked,
958
- isReadOnly: field.isRequired,
959
- onChange: e => {
960
- setFieldValue('fields', _mapInstanceProperty(fields).call(fields, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
961
- isChecked: e.target.checked
962
- }) : _field));
963
- },
964
- children: [field.label, " ", field.isRequired && '*']
965
- }, field.name));
966
- };
967
- const CustomFieldsSelection = _ref6 => {
968
- let customFields = _ref6.customFields,
969
- setFieldValue = _ref6.setFieldValue;
970
- return _mapInstanceProperty(customFields).call(customFields, customType => {
971
- var _context7, _context8, _context10;
972
- const areAllFieldsChecked = _everyInstanceProperty(_context7 = customType.fields).call(_context7, field => field.isChecked);
973
- const isAtLeastOneFieldChecked = _someInstanceProperty(_context8 = customType.fields).call(_context8, field => field.isChecked);
974
- return jsxs(Spacings.Stack, {
975
- scale: "s",
976
- children: [jsx(CheckboxInput, {
977
- isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
978
- isChecked: areAllFieldsChecked,
979
- onChange: e => {
980
- setFieldValue('customFields', _mapInstanceProperty(customFields).call(customFields, _customType => {
981
- var _context9;
982
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
983
- fields: _mapInstanceProperty(_context9 = _customType.fields).call(_context9, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
984
- isChecked: e.target.checked
985
- }))
986
- }) : _customType;
987
- }));
988
- },
989
- children: jsx(Text.Body, {
990
- children: customType.type.label
991
- })
992
- }), jsxs(Spacings.Inline, {
993
- scale: "l",
994
- children: [jsx("div", {}), jsx(Spacings.Stack, {
995
- scale: "s",
996
- children: _mapInstanceProperty(_context10 = customType.fields).call(_context10, field => jsx(CheckboxInput, {
997
- isChecked: field.isChecked,
998
- onChange: e => {
999
- setFieldValue('customFields', _mapInstanceProperty(customFields).call(customFields, _customType => {
1000
- var _context11;
1001
- return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1002
- fields: _mapInstanceProperty(_context11 = _customType.fields).call(_context11, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1003
- isChecked: e.target.checked
1004
- }) : _field)
1005
- }) : _customType;
1006
- }));
1007
- },
1008
- children: jsx(Text.Body, {
1009
- children: field.label
1010
- })
1011
- }, field.name))
1012
- })]
1013
- })]
1014
- }, customType.type.key);
1015
- });
1016
- };
1017
1101
 
1018
1102
  process.env.NODE_ENV !== "production" ? {
1019
1103
  renderProperties: PropTypes.func
@@ -1021,42 +1105,6 @@ process.env.NODE_ENV !== "production" ? {
1021
1105
 
1022
1106
  const ExportResourcesContext = /*#__PURE__*/createContext();
1023
1107
 
1024
- const ExportResourcesModalShape = PropTypes.shape({
1025
- isOpen: PropTypes.bool,
1026
- resourceType: PropTypes.string.isRequired,
1027
- outputFormat: PropTypes.string,
1028
- onClose: PropTypes.func,
1029
- onExportSuccess: PropTypes.func,
1030
- totalResourcesCount: PropTypes.number.isRequired,
1031
- selectedResourceIds: PropTypes.array,
1032
- // TODO: Circular reference
1033
- fields: PropTypes.arrayOf(PropTypes.shape({
1034
- name: PropTypes.string.isRequired,
1035
- label: PropTypes.string,
1036
- fields: PropTypes.arrayOf(PropTypes.shape({
1037
- name: PropTypes.string.isRequired,
1038
- label: PropTypes.string,
1039
- isSelectedByDefault: PropTypes.bool,
1040
- isRequired: PropTypes.bool
1041
- }))
1042
- })).isRequired,
1043
- customFields: PropTypes.shape({
1044
- type: PropTypes.shape({
1045
- key: PropTypes.string.isRequired,
1046
- label: PropTypes.string.isRequired,
1047
- resourceTypeIds: PropTypes.arrayOf(PropTypes.string)
1048
- }).isRequired,
1049
- fields: PropTypes.arrayOf(PropTypes.shape({
1050
- name: PropTypes.string.isRequired,
1051
- label: PropTypes.string
1052
- })).isRequired
1053
- }),
1054
- exportType: PropTypes.string,
1055
- renderProperties: PropTypes.func
1056
- }).isRequired;
1057
-
1058
- 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; }
1059
- 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; }
1060
1108
  const ExportResourcesProvider = props => {
1061
1109
  const initialValues = useInitialValues(props);
1062
1110
  const _useStartExportOperat = useStartExportOperation(props),
@@ -1097,10 +1145,6 @@ const ExportResourcesProvider = props => {
1097
1145
  children: props.children
1098
1146
  });
1099
1147
  };
1100
- ExportResourcesProvider.displayName = 'ExportResourcesProvider';
1101
- ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
1102
- children: PropTypes.node
1103
- }) : {};
1104
1148
 
1105
1149
  const CurrentStep = () => {
1106
1150
  const _useExportResourcesCo = useExportResourcesContext(),
@@ -1112,22 +1156,101 @@ const CurrentStep = () => {
1112
1156
  return steps[currentStep] || null;
1113
1157
  };
1114
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
+
1115
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; }
1116
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; }
1117
1231
  const ExportResourcesModal = props => {
1118
- if (!props.isOpen) return null;
1119
- return jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1120
- children: jsx(CurrentStep, {})
1121
- }));
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
+ });
1122
1245
  };
1123
1246
  ExportResourcesModal.displayName = 'ExportResourcesModal';
1124
- ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
1125
1247
  ExportResourcesModal.defaultProps = {
1126
1248
  isOpen: false,
1127
1249
  selectedResourceIds: [],
1128
1250
  exportType: EXPORT_TYPES.ALL,
1129
1251
  outputFormat: OUTPUT_FORMATS.CSV,
1130
- customFields: []
1252
+ customFields: [],
1253
+ fieldGroups: []
1131
1254
  };
1132
1255
 
1133
1256
  export { EXPORTABLE_RESOURCES, EXPORT_TYPES, ExportResourcesModal as default };