@commercetools-frontend-extensions/export-resources-modal 3.2.1 → 3.3.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.
@@ -29,12 +29,16 @@ var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWit
29
29
  var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
30
30
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
31
31
  var _Object$assign = require('@babel/runtime-corejs3/core-js-stable/object/assign');
32
+ var _flatMapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat-map');
33
+ var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
32
34
  var uiKit = require('@commercetools-frontend/ui-kit');
33
35
  var jsxRuntime = require('@emotion/react/jsx-runtime');
34
36
  var _valuesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/values');
37
+ var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
35
38
  var omitEmpty = require('omit-empty-es');
36
39
  var _findIndexInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find-index');
37
40
  var _spliceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/splice');
41
+ var _startsWithInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
38
42
  require('@commercetools-uikit/design-system');
39
43
  var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
40
44
  var moment = require('moment');
@@ -66,10 +70,14 @@ var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construc
66
70
  var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
67
71
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
68
72
  var _Object$assign__default = /*#__PURE__*/_interopDefault(_Object$assign);
73
+ var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
74
+ var _Set__default = /*#__PURE__*/_interopDefault(_Set);
69
75
  var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
76
+ var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
70
77
  var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
71
78
  var _findIndexInstanceProperty__default = /*#__PURE__*/_interopDefault(_findIndexInstanceProperty);
72
79
  var _spliceInstanceProperty__default = /*#__PURE__*/_interopDefault(_spliceInstanceProperty);
80
+ var _startsWithInstanceProperty__default = /*#__PURE__*/_interopDefault(_startsWithInstanceProperty);
73
81
  var moment__default = /*#__PURE__*/_interopDefault(moment);
74
82
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
75
83
  var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
@@ -106,7 +114,7 @@ const OUTPUT_FORMAT_OPTIONS = [{
106
114
  label: 'JSON'
107
115
  }];
108
116
 
109
- const COLUMN_DEFINITIONS_URLS = {
117
+ const FIELD_DEFINITIONS_URLS = {
110
118
  category: 'https://docs-proxy-sarm-product-import-csv.commercetools.vercel.app/merchant-center/import-categories#supported-headers-and-values'
111
119
  };
112
120
 
@@ -172,21 +180,28 @@ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
172
180
 
173
181
  const _excluded$1 = ["name"];
174
182
  function ownKeys$6(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
175
- function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var _context4, _context5; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context4 = ownKeys$6(Object(t), !0)).call(_context4, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context5 = ownKeys$6(Object(t))).call(_context5, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
176
- function resourceTypeToPlural(_ref) {
183
+ function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var _context7, _context8; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context7 = ownKeys$6(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context8 = ownKeys$6(Object(t))).call(_context8, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
184
+ function resourceTypeToDisplayName(_ref) {
177
185
  let resourceType = _ref.resourceType,
178
186
  _ref$isUpperCase = _ref.isUpperCase,
179
- isUpperCase = _ref$isUpperCase === void 0 ? false : _ref$isUpperCase;
187
+ isUpperCase = _ref$isUpperCase === void 0 ? false : _ref$isUpperCase,
188
+ _ref$isPlural = _ref.isPlural,
189
+ isPlural = _ref$isPlural === void 0 ? false : _ref$isPlural;
190
+ let displayName;
180
191
  switch (resourceType) {
181
192
  case EXPORTABLE_RESOURCES.CATEGORY:
182
- return isUpperCase ? 'Categories' : 'categories';
193
+ displayName = isPlural ? 'Categories' : 'Category';
194
+ break;
183
195
  case EXPORTABLE_RESOURCES.PRODUCT:
184
- return isUpperCase ? 'Products' : 'products';
196
+ displayName = isPlural ? 'Products' : 'Product';
197
+ break;
185
198
  case EXPORTABLE_RESOURCES.DISCOUNT_CODE:
186
- return isUpperCase ? 'Discount codes' : 'discount codes';
199
+ displayName = isPlural ? 'Discount codes' : 'Discount code';
200
+ break;
187
201
  default:
188
202
  throw UnexpectedResourceTypeError(resourceType);
189
203
  }
204
+ return isUpperCase ? displayName : displayName.toLowerCase();
190
205
  }
191
206
  function resourceTypeToOperationName(resourceType) {
192
207
  switch (resourceType) {
@@ -258,21 +273,51 @@ function unflattenNestedFields(flattenedFields) {
258
273
  });
259
274
  return reconstructed;
260
275
  }
261
- function getSelectedFields(fields) {
276
+ function getSelectedGeneralFields(fields) {
262
277
  return _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked);
263
278
  }
264
- function getFieldNames(fields) {
265
- return _mapInstanceProperty__default["default"](fields).call(fields, field => field.name);
279
+ function getSelectedCustomFields(customFields) {
280
+ return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
281
+ var _context4;
282
+ return _objectSpread$6(_objectSpread$6({}, customType), {}, {
283
+ fields: _filterInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => field.isChecked)
284
+ });
285
+ });
286
+ }
287
+ function flattenCustomFields(customFields) {
288
+ return _flatMapInstanceProperty__default["default"](customFields).call(customFields, customType => customType.fields);
266
289
  }
267
290
  function checkRequiredFields(fields) {
268
291
  return _mapInstanceProperty__default["default"](fields).call(fields, field => field.isRequired ? _objectSpread$6(_objectSpread$6({}, field), {}, {
269
292
  isChecked: true
270
293
  }) : field);
271
294
  }
272
- const getExportLogsLink = (projectKey, msg) => jsxRuntime.jsx(uiKit.Link, {
273
- to: "/".concat(projectKey, "/operations/export/logs"),
274
- children: msg
275
- });
295
+ function getExportLogsLink(projectKey, msg) {
296
+ return jsxRuntime.jsx(uiKit.Link, {
297
+ to: "/".concat(projectKey, "/operations/export/logs"),
298
+ children: msg
299
+ });
300
+ }
301
+ function setInitialCheckedStateForCustomFields(customFields) {
302
+ return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
303
+ var _context5;
304
+ return _objectSpread$6(_objectSpread$6({}, customType), {}, {
305
+ fields: _mapInstanceProperty__default["default"](_context5 = customType.fields).call(_context5, field => _objectSpread$6(_objectSpread$6({}, field), {}, {
306
+ isChecked: false
307
+ }))
308
+ });
309
+ });
310
+ }
311
+ function buildGeneralFieldColumns(generalFields) {
312
+ return _mapInstanceProperty__default["default"](generalFields).call(generalFields, field => field.name);
313
+ }
314
+ function buildCustomFieldColumns(customFields) {
315
+ const columns = _flatMapInstanceProperty__default["default"](customFields).call(customFields, customType => {
316
+ var _context6;
317
+ return _mapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => "custom.fields.".concat(field.name));
318
+ });
319
+ return [...new _Set__default["default"](columns)];
320
+ }
276
321
 
277
322
  /*
278
323
  * This function is responsible for constructing the GraphQL query based on the export settings
@@ -282,18 +327,28 @@ const getExportLogsLink = (projectKey, msg) => jsxRuntime.jsx(uiKit.Link, {
282
327
  * - For 'selected', it creates a query that fetches only the fields and locales of the selected resources. The ids of the selected resources are included in the query.
283
328
  * - The 'filtered' case is a placeholder for future development where a query will be constructed based on certain filtering criteria using the `where` parameter.
284
329
  */
285
- function buildGraphQuery(exportSettings) {
330
+ function buildGraphQLQuery(exportSettings) {
286
331
  var _context;
287
332
  const operation = resourceTypeToOperationName(exportSettings.resourceType);
333
+ const generalFields = buildGeneralFieldsForGraphQLQuery({
334
+ fields: exportSettings.fields,
335
+ locales: exportSettings.locales
336
+ });
337
+ const results = [...generalFields];
338
+ if (exportSettings.customFields && exportSettings.customFields.length > 0) {
339
+ const customFields = buildCustomFieldsForGraphQLQuery({
340
+ customFields: exportSettings.customFields
341
+ });
342
+ results.push({
343
+ custom: customFields
344
+ });
345
+ }
288
346
  switch (exportSettings.exportType) {
289
347
  case EXPORT_TYPES.ALL:
290
348
  return gqlQueryBuilder.query({
291
349
  operation,
292
350
  fields: [{
293
- results: buildFields({
294
- fields: exportSettings.fields,
295
- locales: exportSettings.locales
296
- })
351
+ results
297
352
  }],
298
353
  variables: {}
299
354
  });
@@ -301,10 +356,7 @@ function buildGraphQuery(exportSettings) {
301
356
  return gqlQueryBuilder.query({
302
357
  operation,
303
358
  fields: [{
304
- results: buildFields({
305
- fields: exportSettings.fields,
306
- locales: exportSettings.locales
307
- })
359
+ results
308
360
  }],
309
361
  variables: {
310
362
  where: "id in (".concat(_mapInstanceProperty__default["default"](_context = exportSettings.selectedResourceIds).call(_context, id => "\"".concat(id, "\"")).join(', '), ")")
@@ -332,7 +384,7 @@ function buildGraphQuery(exportSettings) {
332
384
  * More details can be found in the related PR: https://github.com/commercetools/commercetools-exporter/pull/103
333
385
  */
334
386
 
335
- function buildFields(_ref) {
387
+ function buildGeneralFieldsForGraphQLQuery(_ref) {
336
388
  var _context2;
337
389
  let fields = _ref.fields,
338
390
  locales = _ref.locales;
@@ -344,7 +396,7 @@ function buildFields(_ref) {
344
396
  });else {
345
397
  if (isFilledArray(field.fields)) {
346
398
  return {
347
- [field.name]: buildFields({
399
+ [field.name]: buildGeneralFieldsForGraphQLQuery({
348
400
  fields: field.fields,
349
401
  locales
350
402
  })
@@ -354,31 +406,48 @@ function buildFields(_ref) {
354
406
  }
355
407
  })).call(_context2);
356
408
  }
409
+ function buildCustomFieldsForGraphQLQuery(_ref2) {
410
+ _ref2.customFields;
411
+ // const customFieldNames = customFields.map((customField) => customField.name)
412
+ return [{
413
+ type: ['key']
414
+ }, {
415
+ operation: 'customFieldsRaw',
416
+ fields: ['name', 'value'],
417
+ // TODO: Add custom fields filter to the variables when they are supported on the Export API side
418
+ variables: {
419
+ // includeNames: customFieldNames,
420
+ }
421
+ }];
422
+ }
357
423
 
358
424
  function validate(_ref) {
359
425
  let values = _valuesInstanceProperty__default["default"](_ref),
360
426
  step = _ref.step;
427
+ const fileName = values.fileName,
428
+ locales = values.locales,
429
+ fields = values.fields,
430
+ customFields = values.customFields;
361
431
  const errors = {
362
432
  fileName: {},
363
433
  locales: {},
364
434
  fields: {}
365
435
  };
366
- // Always validate these fields (first and second steps)
367
- if (uiKit.TextInput.isEmpty(values.fileName)) {
436
+ if (uiKit.TextInput.isEmpty(fileName)) {
368
437
  errors.fileName.missing = true;
369
- } else if (!/^[a-zA-Z0-9-_.]+$/.test(values.fileName)) {
438
+ } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
370
439
  errors.fileName.invalidInput = true;
371
440
  }
372
- if (values.locales.length < 1) {
441
+ if (locales.length < 1) {
373
442
  errors.locales.missing = true;
374
443
  }
375
- //
376
-
377
- // Only validate these fields on the 2nd step
378
444
  if (step === 2) {
379
- var _context;
380
- const checkedFields = _filterInstanceProperty__default["default"](_context = values.fields).call(_context, field => field.isChecked);
381
- if (checkedFields.length < 2) {
445
+ const checkedGeneralFieldsCount = _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked).length;
446
+ const checkedCustomFieldsCount = _reduceInstanceProperty__default["default"](customFields).call(customFields, (count, customType) => {
447
+ var _context;
448
+ return count + _filterInstanceProperty__default["default"](_context = customType.fields).call(_context, field => field.isChecked).length;
449
+ }, 0);
450
+ if (checkedGeneralFieldsCount + checkedCustomFieldsCount < 2) {
382
451
  errors.fields.missing = true;
383
452
  }
384
453
  }
@@ -391,6 +460,10 @@ const categoryColumnExtension = columns => {
391
460
  if (parentKeyIndex !== -1) {
392
461
  _spliceInstanceProperty__default["default"](extendedColumns).call(extendedColumns, parentKeyIndex + 1, 0, 'parent.typeId');
393
462
  }
463
+ const firstCustomFieldIndex = _findIndexInstanceProperty__default["default"](extendedColumns).call(extendedColumns, column => _startsWithInstanceProperty__default["default"](column).call(column, 'custom.fields.'));
464
+ if (firstCustomFieldIndex !== -1) {
465
+ _spliceInstanceProperty__default["default"](extendedColumns).call(extendedColumns, firstCustomFieldIndex, 0, 'custom.type.key', 'custom.type.typeId');
466
+ }
394
467
  return extendedColumns;
395
468
  };
396
469
  const defaultColumnExtension = columns => columns;
@@ -399,7 +472,9 @@ const columnExtensionByResourceType = {
399
472
  category: categoryColumnExtension
400
473
  };
401
474
 
402
- const extendColumns = (columns, resourceType) => {
475
+ const extendColumns = _ref => {
476
+ let resourceType = _ref.resourceType,
477
+ columns = _ref.columns;
403
478
  const extensionFunction = columnExtensionByResourceType[resourceType] || columnExtensionByResourceType.default;
404
479
  return extensionFunction(columns);
405
480
  };
@@ -455,11 +530,6 @@ var messages = reactIntl.defineMessages({
455
530
  description: 'resources are selected and will be exported',
456
531
  defaultMessage: '<b>{count}</b> {resourceType} are selected and will be exported.'
457
532
  },
458
- columnsMessage: {
459
- id: 'ExportResourcesModal.columnsMessage',
460
- description: 'Exported columns and attributes based on table settings',
461
- defaultMessage: 'Exported columns/attributes based on table settings: {columnsCount}'
462
- },
463
533
  exportBasedOnMyViewsMessage: {
464
534
  id: 'ExportResourcesModal.exportBasedOnMyViewsMessage',
465
535
  description: 'Select Export setttings based on my views',
@@ -505,9 +575,9 @@ var messages = reactIntl.defineMessages({
505
575
  description: 'Label for "My Views" Select Field',
506
576
  defaultMessage: 'My Views'
507
577
  },
508
- selectColumnsToExport: {
509
- id: 'ExportResourcesModal.selectColumnsToExport',
510
- defaultMessage: 'Select columns to export'
578
+ selectFieldsToExport: {
579
+ id: 'ExportResourcesModal.selectFieldsToExport',
580
+ defaultMessage: 'Select fields to export'
511
581
  },
512
582
  back: {
513
583
  id: 'ExportResourcesModal.back',
@@ -524,15 +594,25 @@ var messages = reactIntl.defineMessages({
524
594
  description: 'Label for "Continue" button',
525
595
  defaultMessage: 'Continue'
526
596
  },
527
- columnDefinitions: {
528
- id: 'ExportResourcesModal.columnDefinitions',
529
- description: 'Label for "Column Definitions" link',
530
- defaultMessage: 'Column definitions'
597
+ fieldDefinitions: {
598
+ id: 'ExportResourcesModal.fieldDefinitions',
599
+ description: 'Label for "Field definitions" link',
600
+ defaultMessage: 'Field definitions'
531
601
  },
532
602
  allGeneralFields: {
533
603
  id: 'ExportResourcesModal.allGeneralFields',
534
604
  description: 'Label for "All general fields" checkbox',
535
605
  defaultMessage: 'All general fields'
606
+ },
607
+ allCustomFields: {
608
+ id: 'ExportResourcesModal.allCustomFields',
609
+ description: 'Label for "All custom fields" checkbox',
610
+ defaultMessage: 'All custom fields'
611
+ },
612
+ customTypeKeyAndTypeId: {
613
+ id: 'ExportResourcesModal.customTypeKeyAndTypeId',
614
+ description: 'Label for "Custom type key and typeId" checkbox',
615
+ defaultMessage: 'Custom type key and typeId'
536
616
  }
537
617
  });
538
618
 
@@ -598,12 +678,14 @@ const useInitialValues = props => {
598
678
  var _context2;
599
679
  return {
600
680
  outputFormat: props.outputFormat,
601
- fileName: _concatInstanceProperty__default["default"](_context2 = "".concat(resourceTypeToPlural({
681
+ fileName: _concatInstanceProperty__default["default"](_context2 = "".concat(resourceTypeToDisplayName({
602
682
  resourceType: props.resourceType,
603
- isUpperCase: true
683
+ isUpperCase: true,
684
+ isPlural: true
604
685
  }), "_Export_")).call(_context2, todayFormatted),
605
686
  locales: [locale],
606
- fields: checkRequiredFields(fields)
687
+ fields: checkRequiredFields(fields),
688
+ customFields: setInitialCheckedStateForCustomFields(props.customFields)
607
689
  };
608
690
  }, [props, locale, todayFormatted, fields]);
609
691
  };
@@ -648,19 +730,27 @@ const useStartExportOperation = props => {
648
730
  }),
649
731
  projectKey = _useApplicationContex.projectKey;
650
732
  const startExportOperation = async values => {
651
- const graphQuery = buildGraphQuery({
652
- resourceType: props.resourceType,
653
- exportType: props.exportType,
654
- selectedResourceIds: props.selectedResourceIds,
655
- fields: unflattenNestedFields(getSelectedFields(values.fields)),
656
- locales: values.locales
657
- });
658
733
  try {
734
+ const selectedGeneralFields = getSelectedGeneralFields(values.fields);
735
+ const selectedCustomFields = getSelectedCustomFields(values.customFields);
736
+ const generalColumns = buildGeneralFieldColumns(selectedGeneralFields);
737
+ const customColumns = buildCustomFieldColumns(selectedCustomFields);
738
+ const graphQuery = buildGraphQLQuery({
739
+ resourceType: props.resourceType,
740
+ exportType: props.exportType,
741
+ selectedResourceIds: props.selectedResourceIds,
742
+ fields: unflattenNestedFields(selectedGeneralFields),
743
+ customFields: flattenCustomFields(selectedCustomFields),
744
+ locales: values.locales
745
+ });
659
746
  const response = await createExportOperation({
660
747
  fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
661
748
  fileFormat: values.outputFormat,
662
749
  locales: values.locales,
663
- columns: extendColumns(getFieldNames(getSelectedFields(values.fields)), props.resourceType),
750
+ columns: extendColumns({
751
+ resourceType: props.resourceType,
752
+ columns: [...generalColumns, ...customColumns]
753
+ }),
664
754
  projectKey,
665
755
  graphQuery,
666
756
  asyncDispatchFn: asyncDispatch
@@ -701,13 +791,15 @@ const useStartExportOperation = props => {
701
791
  function ownKeys$3(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
702
792
  function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$3(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$3(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
703
793
  function ExportTextMessage() {
794
+ const intl = reactIntl.useIntl();
704
795
  const _useExportResourcesCo = useExportResourcesContext(),
705
796
  resourceType = _useExportResourcesCo.resourceType,
706
797
  totalResourcesCount = _useExportResourcesCo.totalResourcesCount,
707
798
  selectedResourceIds = _useExportResourcesCo.selectedResourceIds,
708
799
  exportType = _useExportResourcesCo.exportType;
709
- const resourceTypePlural = resourceTypeToPlural({
710
- resourceType: resourceType
800
+ const resourceTypePlural = resourceTypeToDisplayName({
801
+ resourceType: resourceType,
802
+ isPlural: true
711
803
  });
712
804
  let message;
713
805
  let count;
@@ -727,7 +819,7 @@ function ExportTextMessage() {
727
819
  "data-testid": "export-description",
728
820
  intlMessage: _objectSpread$3(_objectSpread$3({}, message), {}, {
729
821
  values: {
730
- count: count,
822
+ count: intl.formatNumber(count),
731
823
  resourceType: resourceTypePlural,
732
824
  b: getBold
733
825
  }
@@ -812,7 +904,7 @@ const ExportFileSettingsStep = () => {
812
904
  };
813
905
 
814
906
  function ownKeys$2(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
815
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context6, _context7; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context6 = ownKeys$2(Object(t), !0)).call(_context6, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context7 = ownKeys$2(Object(t))).call(_context7, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
907
+ function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context12, _context13; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context12 = ownKeys$2(Object(t), !0)).call(_context12, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context13 = ownKeys$2(Object(t))).call(_context13, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
816
908
  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)."; }
817
909
  const StyledCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
818
910
  target: "e1ocu3bb2"
@@ -820,12 +912,12 @@ const StyledCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.
820
912
  target: "e1ocu3bb2",
821
913
  label: "StyledCard"
822
914
  })(process.env.NODE_ENV === "production" ? {
823
- name: "1jtoq3b",
824
- styles: "border-radius:4px 0px 0px 4px;&>div{height:490px;overflow-y:auto;}"
915
+ name: "yqmzw4",
916
+ styles: "&>div{height:490px;overflow-y:auto;}"
825
917
  } : {
826
- name: "1jtoq3b",
827
- styles: "border-radius:4px 0px 0px 4px;&>div{height:490px;overflow-y:auto;}",
828
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImV4cG9ydC1maWVsZHMtc2VsZWN0aW9uLXN0ZXAuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1CK0IiLCJmaWxlIjoiZXhwb3J0LWZpZWxkcy1zZWxlY3Rpb24tc3RlcC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VJbnRsIH0gZnJvbSAncmVhY3QtaW50bCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHtcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgR3JpZCxcbiAgTGluayxcbiAgUHJpbWFyeUJ1dHRvbixcbiAgU2Vjb25kYXJ5QnV0dG9uLFxuICBTcGFjaW5ncyxcbiAgVGV4dCxcbiAgY3VzdG9tUHJvcGVydGllcyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4uL21lc3NhZ2VzJ1xuaW1wb3J0IHsgdXNlRXhwb3J0UmVzb3VyY2VzQ29udGV4dCB9IGZyb20gJy4uL0Bob29rcydcbmltcG9ydCB7IENPTFVNTl9ERUZJTklUSU9OU19VUkxTIH0gZnJvbSAnLi4vQGNvbnN0YW50cydcblxuLy8gVE9ETzogUmVtb3ZlIHRoZXNlIHN0eWxlZCBjb21wb25lbnRzIGFzIGl0J3Mgbm90IGEgcmVjb21tZW5kZWQgcHJhY3RpY2UgdG8gdXNlIHRoZW0uIFdlIHNob3VsZCBhbGlnbiB3aXRoIE1DIFVJIEtpdC9wYXR0ZXJucyBpbiB0ZXJtcyBvZiBzdHlsaW5nICh0byBiZSBkaXNjdXNzZWQgd2l0aCB0aGUgVUkvVVgpLlxuY29uc3QgU3R5bGVkQ2FyZCA9IHN0eWxlZChDYXJkKWBcbiAgYm9yZGVyLXJhZGl1czogNHB4IDBweCAwcHggNHB4O1xuICAmID4gZGl2IHtcbiAgICBoZWlnaHQ6IDQ5MHB4O1xuICAgIG92ZXJmbG93LXk6IGF1dG87XG4gIH1cbmBcbmNvbnN0IFN0eWxlZENhcmRMZWZ0ID0gc3R5bGVkKFN0eWxlZENhcmQpYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjlmOWZiO1xuYFxuY29uc3QgU3R5bGVkQ2FyZFJpZ2h0ID0gc3R5bGVkKFN0eWxlZENhcmQpYFxuICBib3JkZXItcmFkaXVzOiAwcHggNHB4IDRweCAwcHg7XG4gIGJvcmRlci1sZWZ0OiAwO1xuYFxuXG5leHBvcnQgY29uc3QgRXhwb3J0RmllbGRzU2VsZWN0aW9uU3RlcCA9ICgpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKVxuICBjb25zdCB7IGZvcm1paywgc2V0Q3VycmVudFN0ZXAsIHJlc291cmNlVHlwZSB9ID0gdXNlRXhwb3J0UmVzb3VyY2VzQ29udGV4dCgpXG4gIGNvbnN0IGFyZUFsbEZpZWxkc0NoZWNrZWQgPSBmb3JtaWsudmFsdWVzLmZpZWxkcy5ldmVyeShcbiAgICAoZmllbGQpID0+IGZpZWxkLmlzQ2hlY2tlZFxuICApXG4gIGNvbnN0IGlzQXRMZWFzdE9uZUZpZWxkQ2hlY2tlZCA9IGZvcm1pay52YWx1ZXMuZmllbGRzLnNvbWUoXG4gICAgKGZpZWxkKSA9PiBmaWVsZC5pc0NoZWNrZWRcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cIm1cIj5cbiAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWxlY3RDb2x1bW5zVG9FeHBvcnR9IC8+XG4gICAgICAgICAgPExpbmtcbiAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgIHRvbmU9XCJzZWNvbmRhcnlcIlxuICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNvbHVtbkRlZmluaXRpb25zfVxuICAgICAgICAgICAgdG89e0NPTFVNTl9ERUZJTklUSU9OU19VUkxTW3Jlc291cmNlVHlwZV19XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDxHcmlkXG4gICAgICAgICAgZ3JpZEF1dG9GbG93PVwiY29sdW1uXCJcbiAgICAgICAgICBncmlkVGVtcGxhdGVDb2x1bW5zPXtgJHtjdXN0b21Qcm9wZXJ0aWVzLmNvbnN0cmFpbnQ1fSBhdXRvYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkQ2FyZExlZnQgaW5zZXRTY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e1xuICAgICAgICAgICAgICAgICAgIWFyZUFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBdExlYXN0T25lRmllbGRDaGVja2VkXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17YXJlQWxsRmllbGRzQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICBvbkNoYW5nZT17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKFxuICAgICAgICAgICAgICAgICAgICAnZmllbGRzJyxcbiAgICAgICAgICAgICAgICAgICAgZm9ybWlrLnZhbHVlcy5maWVsZHMubWFwKChmaWVsZCkgPT4gKHtcbiAgICAgICAgICAgICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ6IGZpZWxkLmlzUmVxdWlyZWQgPyB0cnVlIDogZS50YXJnZXQuY2hlY2tlZCxcbiAgICAgICAgICAgICAgICAgICAgfSkpXG4gICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmFsbEdlbmVyYWxGaWVsZHN9IC8+XG4gICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgIDwvU3R5bGVkQ2FyZExlZnQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgICAgPEdyaWQuSXRlbT5cbiAgICAgICAgICAgIDxTdHlsZWRDYXJkUmlnaHQgaW5zZXRTY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAge2Zvcm1pay52YWx1ZXMuZmllbGRzLm1hcCgoZmllbGQpID0+IChcbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAga2V5PXtmaWVsZC5uYW1lfVxuICAgICAgICAgICAgICAgICAgaXNSZWFkT25seT17ZmllbGQuaXNSZXF1aXJlZH1cbiAgICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17ZmllbGQuaXNDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgb25DaGFuZ2U9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKFxuICAgICAgICAgICAgICAgICAgICAgICdmaWVsZHMnLFxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1pay52YWx1ZXMuZmllbGRzLm1hcCgoX2ZpZWxkKSA9PlxuICAgICAgICAgICAgICAgICAgICAgICAgZmllbGQubmFtZSA9PT0gX2ZpZWxkLm5hbWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgPyB7IC4uLl9maWVsZCwgaXNDaGVja2VkOiBlLnRhcmdldC5jaGVja2VkIH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgOiBfZmllbGRcbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFRleHQuQm9keT5cbiAgICAgICAgICAgICAgICAgICAge2ZpZWxkLmxhYmVsfSB7ZmllbGQuaXNSZXF1aXJlZCAmJiAnKid9XG4gICAgICAgICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgICAgICA8L0NoZWNrYm94SW5wdXQ+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TdHlsZWRDYXJkUmlnaHQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgIDwvR3JpZD5cbiAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgPFNlY29uZGFyeUJ1dHRvblxuICAgICAgICAgIGxhYmVsPXtpbnRsLmZvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYmFjayl9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gc2V0Q3VycmVudFN0ZXAoMSl9XG4gICAgICAgIC8+XG4gICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShtZXNzYWdlcy5zdGFydEV4cG9ydCl9XG4gICAgICAgICAgb25DbGljaz17Zm9ybWlrLnN1Ym1pdEZvcm19XG4gICAgICAgICAgaXNEaXNhYmxlZD17IWZvcm1pay5pc1ZhbGlkfVxuICAgICAgICAvPlxuICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgKVxufVxuIl19 */",
918
+ name: "yqmzw4",
919
+ styles: "&>div{height:490px;overflow-y:auto;}",
920
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmB+B","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  PrimaryButton,\n  SecondaryButton,\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'\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 StyledCard = styled(Card)`\n  & > div {\n    height: 490px;\n    overflow-y: auto;\n  }\n`\nconst StyledCardLeft = styled(StyledCard)`\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`\n\nconst StyledCardRight = styled(StyledCard)`\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 } = useExportResourcesContext()\n  const areAllGeneralFieldsChecked = formik.values.fields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneGeneralFieldChecked = formik.values.fields.some(\n    (field) => field.isChecked\n  )\n  const allCustomFields = formik.values.customFields.flatMap(\n    (customType) => customType.fields\n  )\n  const areAllCustomFieldsChecked = allCustomFields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneCustomFieldChecked = allCustomFields.some(\n    (field) => field.isChecked\n  )\n\n  return (\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 && 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                <Text.Body intlMessage={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                    <Text.Body intlMessage={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                      <Text.Body>\n                        {intl.formatMessage(messages.customTypeKeyAndTypeId)} *\n                      </Text.Body>\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.Inline scale=\"m\" justifyContent=\"flex-end\">\n        <SecondaryButton\n          label={intl.formatMessage(messages.back)}\n          onClick={() => setCurrentStep(1)}\n        />\n        <PrimaryButton\n          label={intl.formatMessage(messages.startExport)}\n          onClick={formik.submitForm}\n          isDisabled={!formik.isValid}\n        />\n      </Spacings.Inline>\n    </Spacings.Stack>\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      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\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.typeKey} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.typeKey === customType.typeKey\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.typeLabel}</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.typeKey === customType.typeKey\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"]} */",
829
921
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
830
922
  });
831
923
  const StyledCardLeft = /*#__PURE__*/_styled__default["default"](StyledCard, process.env.NODE_ENV === "production" ? {
@@ -833,38 +925,37 @@ const StyledCardLeft = /*#__PURE__*/_styled__default["default"](StyledCard, proc
833
925
  } : {
834
926
  target: "e1ocu3bb1",
835
927
  label: "StyledCardLeft"
836
- })(process.env.NODE_ENV === "production" ? {
837
- name: "65buvr",
838
- styles: "background-color:#f9f9fb"
839
- } : {
840
- name: "65buvr",
841
- styles: "background-color:#f9f9fb",
842
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImV4cG9ydC1maWVsZHMtc2VsZWN0aW9uLXN0ZXAuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCeUMiLCJmaWxlIjoiZXhwb3J0LWZpZWxkcy1zZWxlY3Rpb24tc3RlcC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VJbnRsIH0gZnJvbSAncmVhY3QtaW50bCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHtcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgR3JpZCxcbiAgTGluayxcbiAgUHJpbWFyeUJ1dHRvbixcbiAgU2Vjb25kYXJ5QnV0dG9uLFxuICBTcGFjaW5ncyxcbiAgVGV4dCxcbiAgY3VzdG9tUHJvcGVydGllcyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4uL21lc3NhZ2VzJ1xuaW1wb3J0IHsgdXNlRXhwb3J0UmVzb3VyY2VzQ29udGV4dCB9IGZyb20gJy4uL0Bob29rcydcbmltcG9ydCB7IENPTFVNTl9ERUZJTklUSU9OU19VUkxTIH0gZnJvbSAnLi4vQGNvbnN0YW50cydcblxuLy8gVE9ETzogUmVtb3ZlIHRoZXNlIHN0eWxlZCBjb21wb25lbnRzIGFzIGl0J3Mgbm90IGEgcmVjb21tZW5kZWQgcHJhY3RpY2UgdG8gdXNlIHRoZW0uIFdlIHNob3VsZCBhbGlnbiB3aXRoIE1DIFVJIEtpdC9wYXR0ZXJucyBpbiB0ZXJtcyBvZiBzdHlsaW5nICh0byBiZSBkaXNjdXNzZWQgd2l0aCB0aGUgVUkvVVgpLlxuY29uc3QgU3R5bGVkQ2FyZCA9IHN0eWxlZChDYXJkKWBcbiAgYm9yZGVyLXJhZGl1czogNHB4IDBweCAwcHggNHB4O1xuICAmID4gZGl2IHtcbiAgICBoZWlnaHQ6IDQ5MHB4O1xuICAgIG92ZXJmbG93LXk6IGF1dG87XG4gIH1cbmBcbmNvbnN0IFN0eWxlZENhcmRMZWZ0ID0gc3R5bGVkKFN0eWxlZENhcmQpYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjlmOWZiO1xuYFxuY29uc3QgU3R5bGVkQ2FyZFJpZ2h0ID0gc3R5bGVkKFN0eWxlZENhcmQpYFxuICBib3JkZXItcmFkaXVzOiAwcHggNHB4IDRweCAwcHg7XG4gIGJvcmRlci1sZWZ0OiAwO1xuYFxuXG5leHBvcnQgY29uc3QgRXhwb3J0RmllbGRzU2VsZWN0aW9uU3RlcCA9ICgpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKVxuICBjb25zdCB7IGZvcm1paywgc2V0Q3VycmVudFN0ZXAsIHJlc291cmNlVHlwZSB9ID0gdXNlRXhwb3J0UmVzb3VyY2VzQ29udGV4dCgpXG4gIGNvbnN0IGFyZUFsbEZpZWxkc0NoZWNrZWQgPSBmb3JtaWsudmFsdWVzLmZpZWxkcy5ldmVyeShcbiAgICAoZmllbGQpID0+IGZpZWxkLmlzQ2hlY2tlZFxuICApXG4gIGNvbnN0IGlzQXRMZWFzdE9uZUZpZWxkQ2hlY2tlZCA9IGZvcm1pay52YWx1ZXMuZmllbGRzLnNvbWUoXG4gICAgKGZpZWxkKSA9PiBmaWVsZC5pc0NoZWNrZWRcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cIm1cIj5cbiAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWxlY3RDb2x1bW5zVG9FeHBvcnR9IC8+XG4gICAgICAgICAgPExpbmtcbiAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgIHRvbmU9XCJzZWNvbmRhcnlcIlxuICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNvbHVtbkRlZmluaXRpb25zfVxuICAgICAgICAgICAgdG89e0NPTFVNTl9ERUZJTklUSU9OU19VUkxTW3Jlc291cmNlVHlwZV19XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDxHcmlkXG4gICAgICAgICAgZ3JpZEF1dG9GbG93PVwiY29sdW1uXCJcbiAgICAgICAgICBncmlkVGVtcGxhdGVDb2x1bW5zPXtgJHtjdXN0b21Qcm9wZXJ0aWVzLmNvbnN0cmFpbnQ1fSBhdXRvYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkQ2FyZExlZnQgaW5zZXRTY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e1xuICAgICAgICAgICAgICAgICAgIWFyZUFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBdExlYXN0T25lRmllbGRDaGVja2VkXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17YXJlQWxsRmllbGRzQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICBvbkNoYW5nZT17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKFxuICAgICAgICAgICAgICAgICAgICAnZmllbGRzJyxcbiAgICAgICAgICAgICAgICAgICAgZm9ybWlrLnZhbHVlcy5maWVsZHMubWFwKChmaWVsZCkgPT4gKHtcbiAgICAgICAgICAgICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ6IGZpZWxkLmlzUmVxdWlyZWQgPyB0cnVlIDogZS50YXJnZXQuY2hlY2tlZCxcbiAgICAgICAgICAgICAgICAgICAgfSkpXG4gICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmFsbEdlbmVyYWxGaWVsZHN9IC8+XG4gICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgIDwvU3R5bGVkQ2FyZExlZnQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgICAgPEdyaWQuSXRlbT5cbiAgICAgICAgICAgIDxTdHlsZWRDYXJkUmlnaHQgaW5zZXRTY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAge2Zvcm1pay52YWx1ZXMuZmllbGRzLm1hcCgoZmllbGQpID0+IChcbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAga2V5PXtmaWVsZC5uYW1lfVxuICAgICAgICAgICAgICAgICAgaXNSZWFkT25seT17ZmllbGQuaXNSZXF1aXJlZH1cbiAgICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17ZmllbGQuaXNDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgb25DaGFuZ2U9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKFxuICAgICAgICAgICAgICAgICAgICAgICdmaWVsZHMnLFxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1pay52YWx1ZXMuZmllbGRzLm1hcCgoX2ZpZWxkKSA9PlxuICAgICAgICAgICAgICAgICAgICAgICAgZmllbGQubmFtZSA9PT0gX2ZpZWxkLm5hbWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgPyB7IC4uLl9maWVsZCwgaXNDaGVja2VkOiBlLnRhcmdldC5jaGVja2VkIH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgOiBfZmllbGRcbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFRleHQuQm9keT5cbiAgICAgICAgICAgICAgICAgICAge2ZpZWxkLmxhYmVsfSB7ZmllbGQuaXNSZXF1aXJlZCAmJiAnKid9XG4gICAgICAgICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgICAgICA8L0NoZWNrYm94SW5wdXQ+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TdHlsZWRDYXJkUmlnaHQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgIDwvR3JpZD5cbiAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgPFNlY29uZGFyeUJ1dHRvblxuICAgICAgICAgIGxhYmVsPXtpbnRsLmZvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYmFjayl9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gc2V0Q3VycmVudFN0ZXAoMSl9XG4gICAgICAgIC8+XG4gICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShtZXNzYWdlcy5zdGFydEV4cG9ydCl9XG4gICAgICAgICAgb25DbGljaz17Zm9ybWlrLnN1Ym1pdEZvcm19XG4gICAgICAgICAgaXNEaXNhYmxlZD17IWZvcm1pay5pc1ZhbGlkfVxuICAgICAgICAvPlxuICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgKVxufVxuIl19 */",
843
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
844
- });
928
+ })("background-color:#f9f9fb;border-top:", _ref => {
929
+ let isTopRow = _ref.isTopRow;
930
+ return isTopRow ? uiKit.designTokens.borderForCardWhenRaised : 'none';
931
+ }, ";border-radius:", _ref2 => {
932
+ let isTopRow = _ref2.isTopRow;
933
+ return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
934
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAyByC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  PrimaryButton,\n  SecondaryButton,\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'\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 StyledCard = styled(Card)`\n  & > div {\n    height: 490px;\n    overflow-y: auto;\n  }\n`\nconst StyledCardLeft = styled(StyledCard)`\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`\n\nconst StyledCardRight = styled(StyledCard)`\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 } = useExportResourcesContext()\n  const areAllGeneralFieldsChecked = formik.values.fields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneGeneralFieldChecked = formik.values.fields.some(\n    (field) => field.isChecked\n  )\n  const allCustomFields = formik.values.customFields.flatMap(\n    (customType) => customType.fields\n  )\n  const areAllCustomFieldsChecked = allCustomFields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneCustomFieldChecked = allCustomFields.some(\n    (field) => field.isChecked\n  )\n\n  return (\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 && 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                <Text.Body intlMessage={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                    <Text.Body intlMessage={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                      <Text.Body>\n                        {intl.formatMessage(messages.customTypeKeyAndTypeId)} *\n                      </Text.Body>\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.Inline scale=\"m\" justifyContent=\"flex-end\">\n        <SecondaryButton\n          label={intl.formatMessage(messages.back)}\n          onClick={() => setCurrentStep(1)}\n        />\n        <PrimaryButton\n          label={intl.formatMessage(messages.startExport)}\n          onClick={formik.submitForm}\n          isDisabled={!formik.isValid}\n        />\n      </Spacings.Inline>\n    </Spacings.Stack>\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      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\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.typeKey} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.typeKey === customType.typeKey\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.typeLabel}</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.typeKey === customType.typeKey\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"]} */"));
845
935
  const StyledCardRight = /*#__PURE__*/_styled__default["default"](StyledCard, process.env.NODE_ENV === "production" ? {
846
936
  target: "e1ocu3bb0"
847
937
  } : {
848
938
  target: "e1ocu3bb0",
849
939
  label: "StyledCardRight"
850
- })(process.env.NODE_ENV === "production" ? {
851
- name: "1oktwfs",
852
- styles: "border-radius:0px 4px 4px 0px;border-left:0"
853
- } : {
854
- name: "1oktwfs",
855
- styles: "border-radius:0px 4px 4px 0px;border-left:0",
856
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImV4cG9ydC1maWVsZHMtc2VsZWN0aW9uLXN0ZXAuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZCMEMiLCJmaWxlIjoiZXhwb3J0LWZpZWxkcy1zZWxlY3Rpb24tc3RlcC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VJbnRsIH0gZnJvbSAncmVhY3QtaW50bCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHtcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgR3JpZCxcbiAgTGluayxcbiAgUHJpbWFyeUJ1dHRvbixcbiAgU2Vjb25kYXJ5QnV0dG9uLFxuICBTcGFjaW5ncyxcbiAgVGV4dCxcbiAgY3VzdG9tUHJvcGVydGllcyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4uL21lc3NhZ2VzJ1xuaW1wb3J0IHsgdXNlRXhwb3J0UmVzb3VyY2VzQ29udGV4dCB9IGZyb20gJy4uL0Bob29rcydcbmltcG9ydCB7IENPTFVNTl9ERUZJTklUSU9OU19VUkxTIH0gZnJvbSAnLi4vQGNvbnN0YW50cydcblxuLy8gVE9ETzogUmVtb3ZlIHRoZXNlIHN0eWxlZCBjb21wb25lbnRzIGFzIGl0J3Mgbm90IGEgcmVjb21tZW5kZWQgcHJhY3RpY2UgdG8gdXNlIHRoZW0uIFdlIHNob3VsZCBhbGlnbiB3aXRoIE1DIFVJIEtpdC9wYXR0ZXJucyBpbiB0ZXJtcyBvZiBzdHlsaW5nICh0byBiZSBkaXNjdXNzZWQgd2l0aCB0aGUgVUkvVVgpLlxuY29uc3QgU3R5bGVkQ2FyZCA9IHN0eWxlZChDYXJkKWBcbiAgYm9yZGVyLXJhZGl1czogNHB4IDBweCAwcHggNHB4O1xuICAmID4gZGl2IHtcbiAgICBoZWlnaHQ6IDQ5MHB4O1xuICAgIG92ZXJmbG93LXk6IGF1dG87XG4gIH1cbmBcbmNvbnN0IFN0eWxlZENhcmRMZWZ0ID0gc3R5bGVkKFN0eWxlZENhcmQpYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjlmOWZiO1xuYFxuY29uc3QgU3R5bGVkQ2FyZFJpZ2h0ID0gc3R5bGVkKFN0eWxlZENhcmQpYFxuICBib3JkZXItcmFkaXVzOiAwcHggNHB4IDRweCAwcHg7XG4gIGJvcmRlci1sZWZ0OiAwO1xuYFxuXG5leHBvcnQgY29uc3QgRXhwb3J0RmllbGRzU2VsZWN0aW9uU3RlcCA9ICgpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKVxuICBjb25zdCB7IGZvcm1paywgc2V0Q3VycmVudFN0ZXAsIHJlc291cmNlVHlwZSB9ID0gdXNlRXhwb3J0UmVzb3VyY2VzQ29udGV4dCgpXG4gIGNvbnN0IGFyZUFsbEZpZWxkc0NoZWNrZWQgPSBmb3JtaWsudmFsdWVzLmZpZWxkcy5ldmVyeShcbiAgICAoZmllbGQpID0+IGZpZWxkLmlzQ2hlY2tlZFxuICApXG4gIGNvbnN0IGlzQXRMZWFzdE9uZUZpZWxkQ2hlY2tlZCA9IGZvcm1pay52YWx1ZXMuZmllbGRzLnNvbWUoXG4gICAgKGZpZWxkKSA9PiBmaWVsZC5pc0NoZWNrZWRcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPFNwYWNpbmdzLlN0YWNrIHNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cIm1cIj5cbiAgICAgICAgPFNwYWNpbmdzLklubGluZSBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWxlY3RDb2x1bW5zVG9FeHBvcnR9IC8+XG4gICAgICAgICAgPExpbmtcbiAgICAgICAgICAgIGlzRXh0ZXJuYWxcbiAgICAgICAgICAgIHRvbmU9XCJzZWNvbmRhcnlcIlxuICAgICAgICAgICAgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNvbHVtbkRlZmluaXRpb25zfVxuICAgICAgICAgICAgdG89e0NPTFVNTl9ERUZJTklUSU9OU19VUkxTW3Jlc291cmNlVHlwZV19XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDxHcmlkXG4gICAgICAgICAgZ3JpZEF1dG9GbG93PVwiY29sdW1uXCJcbiAgICAgICAgICBncmlkVGVtcGxhdGVDb2x1bW5zPXtgJHtjdXN0b21Qcm9wZXJ0aWVzLmNvbnN0cmFpbnQ1fSBhdXRvYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkQ2FyZExlZnQgaW5zZXRTY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e1xuICAgICAgICAgICAgICAgICAgIWFyZUFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBdExlYXN0T25lRmllbGRDaGVja2VkXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17YXJlQWxsRmllbGRzQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICBvbkNoYW5nZT17KGUpID0+IHtcbiAgICAgICAgICAgICAgICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKFxuICAgICAgICAgICAgICAgICAgICAnZmllbGRzJyxcbiAgICAgICAgICAgICAgICAgICAgZm9ybWlrLnZhbHVlcy5maWVsZHMubWFwKChmaWVsZCkgPT4gKHtcbiAgICAgICAgICAgICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ6IGZpZWxkLmlzUmVxdWlyZWQgPyB0cnVlIDogZS50YXJnZXQuY2hlY2tlZCxcbiAgICAgICAgICAgICAgICAgICAgfSkpXG4gICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmFsbEdlbmVyYWxGaWVsZHN9IC8+XG4gICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgIDwvU3R5bGVkQ2FyZExlZnQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgICAgPEdyaWQuSXRlbT5cbiAgICAgICAgICAgIDxTdHlsZWRDYXJkUmlnaHQgaW5zZXRTY2FsZT1cImxcIj5cbiAgICAgICAgICAgICAge2Zvcm1pay52YWx1ZXMuZmllbGRzLm1hcCgoZmllbGQpID0+IChcbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAga2V5PXtmaWVsZC5uYW1lfVxuICAgICAgICAgICAgICAgICAgaXNSZWFkT25seT17ZmllbGQuaXNSZXF1aXJlZH1cbiAgICAgICAgICAgICAgICAgIGlzQ2hlY2tlZD17ZmllbGQuaXNDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgb25DaGFuZ2U9eyhlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKFxuICAgICAgICAgICAgICAgICAgICAgICdmaWVsZHMnLFxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1pay52YWx1ZXMuZmllbGRzLm1hcCgoX2ZpZWxkKSA9PlxuICAgICAgICAgICAgICAgICAgICAgICAgZmllbGQubmFtZSA9PT0gX2ZpZWxkLm5hbWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgPyB7IC4uLl9maWVsZCwgaXNDaGVja2VkOiBlLnRhcmdldC5jaGVja2VkIH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgOiBfZmllbGRcbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgPFRleHQuQm9keT5cbiAgICAgICAgICAgICAgICAgICAge2ZpZWxkLmxhYmVsfSB7ZmllbGQuaXNSZXF1aXJlZCAmJiAnKid9XG4gICAgICAgICAgICAgICAgICA8L1RleHQuQm9keT5cbiAgICAgICAgICAgICAgICA8L0NoZWNrYm94SW5wdXQ+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgPC9TdHlsZWRDYXJkUmlnaHQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgIDwvR3JpZD5cbiAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGp1c3RpZnlDb250ZW50PVwiZmxleC1lbmRcIj5cbiAgICAgICAgPFNlY29uZGFyeUJ1dHRvblxuICAgICAgICAgIGxhYmVsPXtpbnRsLmZvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYmFjayl9XG4gICAgICAgICAgb25DbGljaz17KCkgPT4gc2V0Q3VycmVudFN0ZXAoMSl9XG4gICAgICAgIC8+XG4gICAgICAgIDxQcmltYXJ5QnV0dG9uXG4gICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShtZXNzYWdlcy5zdGFydEV4cG9ydCl9XG4gICAgICAgICAgb25DbGljaz17Zm9ybWlrLnN1Ym1pdEZvcm19XG4gICAgICAgICAgaXNEaXNhYmxlZD17IWZvcm1pay5pc1ZhbGlkfVxuICAgICAgICAvPlxuICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgPC9TcGFjaW5ncy5TdGFjaz5cbiAgKVxufVxuIl19 */",
857
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
858
- });
940
+ })("border-left:0;border-top:", _ref3 => {
941
+ let isTopRow = _ref3.isTopRow;
942
+ return isTopRow ? uiKit.designTokens.borderForCardWhenRaised : 'none';
943
+ }, ";border-radius:", _ref4 => {
944
+ let isTopRow = _ref4.isTopRow;
945
+ return isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px';
946
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAiC0C","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  PrimaryButton,\n  SecondaryButton,\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'\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 StyledCard = styled(Card)`\n  & > div {\n    height: 490px;\n    overflow-y: auto;\n  }\n`\nconst StyledCardLeft = styled(StyledCard)`\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`\n\nconst StyledCardRight = styled(StyledCard)`\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 } = useExportResourcesContext()\n  const areAllGeneralFieldsChecked = formik.values.fields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneGeneralFieldChecked = formik.values.fields.some(\n    (field) => field.isChecked\n  )\n  const allCustomFields = formik.values.customFields.flatMap(\n    (customType) => customType.fields\n  )\n  const areAllCustomFieldsChecked = allCustomFields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneCustomFieldChecked = allCustomFields.some(\n    (field) => field.isChecked\n  )\n\n  return (\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 && 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                <Text.Body intlMessage={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                    <Text.Body intlMessage={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                      <Text.Body>\n                        {intl.formatMessage(messages.customTypeKeyAndTypeId)} *\n                      </Text.Body>\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.Inline scale=\"m\" justifyContent=\"flex-end\">\n        <SecondaryButton\n          label={intl.formatMessage(messages.back)}\n          onClick={() => setCurrentStep(1)}\n        />\n        <PrimaryButton\n          label={intl.formatMessage(messages.startExport)}\n          onClick={formik.submitForm}\n          isDisabled={!formik.isValid}\n        />\n      </Spacings.Inline>\n    </Spacings.Stack>\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      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\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.typeKey} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.typeKey === customType.typeKey\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.typeLabel}</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.typeKey === customType.typeKey\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"]} */"));
859
947
  const ExportFieldsSelectionStep = () => {
860
- var _context, _context2, _context4;
948
+ var _context, _context2, _context3, _formik$values$custom;
861
949
  const intl = reactIntl.useIntl();
862
950
  const _useExportResourcesCo = useExportResourcesContext(),
863
951
  formik = _useExportResourcesCo.formik,
864
952
  setCurrentStep = _useExportResourcesCo.setCurrentStep,
865
953
  resourceType = _useExportResourcesCo.resourceType;
866
- const areAllFieldsChecked = _everyInstanceProperty__default["default"](_context = _valuesInstanceProperty__default["default"](formik).fields).call(_context, field => field.isChecked);
867
- const isAtLeastOneFieldChecked = _someInstanceProperty__default["default"](_context2 = _valuesInstanceProperty__default["default"](formik).fields).call(_context2, field => field.isChecked);
954
+ const areAllGeneralFieldsChecked = _everyInstanceProperty__default["default"](_context = _valuesInstanceProperty__default["default"](formik).fields).call(_context, field => field.isChecked);
955
+ const isAtLeastOneGeneralFieldChecked = _someInstanceProperty__default["default"](_context2 = _valuesInstanceProperty__default["default"](formik).fields).call(_context2, field => field.isChecked);
956
+ const allCustomFields = _flatMapInstanceProperty__default["default"](_context3 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context3, customType => customType.fields);
957
+ const areAllCustomFieldsChecked = _everyInstanceProperty__default["default"](allCustomFields).call(allCustomFields, field => field.isChecked);
958
+ const isAtLeastOneCustomFieldChecked = _someInstanceProperty__default["default"](allCustomFields).call(allCustomFields, field => field.isChecked);
868
959
  return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
869
960
  scale: "xl",
870
961
  children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
@@ -872,25 +963,26 @@ const ExportFieldsSelectionStep = () => {
872
963
  children: [jsxRuntime.jsxs(uiKit.Spacings.Inline, {
873
964
  justifyContent: "space-between",
874
965
  children: [jsxRuntime.jsx(uiKit.Text.Body, {
875
- intlMessage: messages.selectColumnsToExport
966
+ intlMessage: messages.selectFieldsToExport
876
967
  }), jsxRuntime.jsx(uiKit.Link, {
877
968
  isExternal: true,
878
969
  tone: "secondary",
879
- intlMessage: messages.columnDefinitions,
880
- to: COLUMN_DEFINITIONS_URLS[resourceType]
970
+ intlMessage: messages.fieldDefinitions,
971
+ to: FIELD_DEFINITIONS_URLS[resourceType]
881
972
  })]
882
973
  }), jsxRuntime.jsxs(uiKit.Grid, {
883
- gridAutoFlow: "column",
884
- gridTemplateColumns: "".concat(uiKit.customProperties.constraint5, " auto"),
974
+ gridAutoFlow: "row",
975
+ gridTemplateColumns: "".concat(uiKit.designTokens.constraint5, " auto"),
885
976
  children: [jsxRuntime.jsx(uiKit.Grid.Item, {
886
977
  children: jsxRuntime.jsx(StyledCardLeft, {
978
+ isTopRow: true,
887
979
  insetScale: "l",
888
980
  children: jsxRuntime.jsx(uiKit.CheckboxInput, {
889
- isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
890
- isChecked: areAllFieldsChecked,
981
+ isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
982
+ isChecked: areAllGeneralFieldsChecked,
891
983
  onChange: e => {
892
- var _context3;
893
- formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context3 = _valuesInstanceProperty__default["default"](formik).fields).call(_context3, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
984
+ var _context4;
985
+ formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context4 = _valuesInstanceProperty__default["default"](formik).fields).call(_context4, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
894
986
  isChecked: field.isRequired ? true : e.target.checked
895
987
  })));
896
988
  },
@@ -901,21 +993,58 @@ const ExportFieldsSelectionStep = () => {
901
993
  })
902
994
  }), jsxRuntime.jsx(uiKit.Grid.Item, {
903
995
  children: jsxRuntime.jsx(StyledCardRight, {
996
+ isTopRow: true,
904
997
  insetScale: "l",
905
- children: _mapInstanceProperty__default["default"](_context4 = _valuesInstanceProperty__default["default"](formik).fields).call(_context4, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
906
- isReadOnly: field.isRequired,
907
- isChecked: field.isChecked,
908
- onChange: e => {
909
- var _context5;
910
- formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context5 = _valuesInstanceProperty__default["default"](formik).fields).call(_context5, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
911
- isChecked: e.target.checked
912
- }) : _field));
913
- },
914
- children: jsxRuntime.jsxs(uiKit.Text.Body, {
915
- children: [field.label, " ", field.isRequired && '*']
998
+ children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
999
+ scale: "s",
1000
+ children: jsxRuntime.jsx(GeneralFieldsSelection, {
1001
+ fields: _valuesInstanceProperty__default["default"](formik).fields,
1002
+ setFieldValue: formik.setFieldValue
916
1003
  })
917
- }, field.name))
1004
+ })
918
1005
  })
1006
+ }), ((_formik$values$custom = _valuesInstanceProperty__default["default"](formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
1007
+ children: [jsxRuntime.jsx(uiKit.Grid.Item, {
1008
+ children: jsxRuntime.jsx(StyledCardLeft, {
1009
+ insetScale: "l",
1010
+ children: jsxRuntime.jsx(uiKit.CheckboxInput, {
1011
+ isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
1012
+ isChecked: areAllCustomFieldsChecked,
1013
+ onChange: e => {
1014
+ var _context5;
1015
+ formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context5 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context5, customType => {
1016
+ var _context6;
1017
+ return _objectSpread$2(_objectSpread$2({}, customType), {}, {
1018
+ fields: _mapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1019
+ isChecked: e.target.checked
1020
+ }))
1021
+ });
1022
+ }));
1023
+ },
1024
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
1025
+ intlMessage: messages.allCustomFields
1026
+ })
1027
+ })
1028
+ })
1029
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
1030
+ children: jsxRuntime.jsx(StyledCardRight, {
1031
+ insetScale: "l",
1032
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1033
+ scale: "s",
1034
+ children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
1035
+ isReadOnly: true,
1036
+ onChange: () => {},
1037
+ isChecked: isAtLeastOneCustomFieldChecked,
1038
+ children: jsxRuntime.jsxs(uiKit.Text.Body, {
1039
+ children: [intl.formatMessage(messages.customTypeKeyAndTypeId), " *"]
1040
+ })
1041
+ }), jsxRuntime.jsx(CustomFieldsSelection, {
1042
+ customFields: _valuesInstanceProperty__default["default"](formik).customFields,
1043
+ setFieldValue: formik.setFieldValue
1044
+ })]
1045
+ })
1046
+ })
1047
+ })]
919
1048
  })]
920
1049
  })]
921
1050
  }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
@@ -932,6 +1061,72 @@ const ExportFieldsSelectionStep = () => {
932
1061
  })]
933
1062
  });
934
1063
  };
1064
+ const GeneralFieldsSelection = _ref5 => {
1065
+ let fields = _ref5.fields,
1066
+ setFieldValue = _ref5.setFieldValue;
1067
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
1068
+ isChecked: field.isChecked,
1069
+ isReadOnly: field.isRequired,
1070
+ onChange: e => {
1071
+ setFieldValue('fields', _mapInstanceProperty__default["default"](fields).call(fields, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1072
+ isChecked: e.target.checked
1073
+ }) : _field));
1074
+ },
1075
+ children: jsxRuntime.jsxs(uiKit.Text.Body, {
1076
+ children: [field.label, " ", field.isRequired && '*']
1077
+ })
1078
+ }, field.name));
1079
+ };
1080
+ const CustomFieldsSelection = _ref6 => {
1081
+ let customFields = _ref6.customFields,
1082
+ setFieldValue = _ref6.setFieldValue;
1083
+ return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
1084
+ var _context7, _context8, _context10;
1085
+ const areAllFieldsChecked = _everyInstanceProperty__default["default"](_context7 = customType.fields).call(_context7, field => field.isChecked);
1086
+ const isAtLeastOneFieldChecked = _someInstanceProperty__default["default"](_context8 = customType.fields).call(_context8, field => field.isChecked);
1087
+ return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1088
+ scale: "s",
1089
+ children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
1090
+ isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
1091
+ isChecked: areAllFieldsChecked,
1092
+ onChange: e => {
1093
+ setFieldValue('customFields', _mapInstanceProperty__default["default"](customFields).call(customFields, _customType => {
1094
+ var _context9;
1095
+ return _customType.typeKey === customType.typeKey ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1096
+ fields: _mapInstanceProperty__default["default"](_context9 = _customType.fields).call(_context9, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1097
+ isChecked: e.target.checked
1098
+ }))
1099
+ }) : _customType;
1100
+ }));
1101
+ },
1102
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
1103
+ children: customType.typeLabel
1104
+ })
1105
+ }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
1106
+ scale: "l",
1107
+ children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(uiKit.Spacings.Stack, {
1108
+ scale: "s",
1109
+ children: _mapInstanceProperty__default["default"](_context10 = customType.fields).call(_context10, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
1110
+ isChecked: field.isChecked,
1111
+ onChange: e => {
1112
+ setFieldValue('customFields', _mapInstanceProperty__default["default"](customFields).call(customFields, _customType => {
1113
+ var _context11;
1114
+ return _customType.typeKey === customType.typeKey ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1115
+ fields: _mapInstanceProperty__default["default"](_context11 = _customType.fields).call(_context11, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1116
+ isChecked: e.target.checked
1117
+ }) : _field)
1118
+ }) : _customType;
1119
+ }));
1120
+ },
1121
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
1122
+ children: field.label
1123
+ })
1124
+ }, field.name))
1125
+ })]
1126
+ })]
1127
+ }, customType.typeKey);
1128
+ });
1129
+ };
935
1130
 
936
1131
  process.env.NODE_ENV !== "production" ? {
937
1132
  renderProperties: PropTypes__default["default"].func
@@ -960,6 +1155,14 @@ const ExportResourcesModalShape = PropTypes__default["default"].shape({
960
1155
  isRequired: PropTypes__default["default"].bool
961
1156
  }))
962
1157
  })).isRequired,
1158
+ customFields: PropTypes__default["default"].shape({
1159
+ typeKey: PropTypes__default["default"].string.isRequired,
1160
+ typeLabel: PropTypes__default["default"].string.isRequired,
1161
+ fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
1162
+ name: PropTypes__default["default"].string.isRequired,
1163
+ label: PropTypes__default["default"].string
1164
+ })).isRequired
1165
+ }),
963
1166
  exportType: PropTypes__default["default"].string,
964
1167
  renderProperties: PropTypes__default["default"].func
965
1168
  }).isRequired;
@@ -967,9 +1170,9 @@ const ExportResourcesModalShape = PropTypes__default["default"].shape({
967
1170
  function ownKeys$1(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
968
1171
  function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
969
1172
  const ExportResourcesProvider = props => {
1173
+ const initialValues = useInitialValues(props);
970
1174
  const _useStartExportOperat = useStartExportOperation(props),
971
1175
  startExportOperation = _useStartExportOperat.startExportOperation;
972
- const initialValues = useInitialValues(props);
973
1176
  const _React$useState = React__default["default"].useState(1),
974
1177
  _React$useState2 = _slicedToArray(_React$useState, 2),
975
1178
  currentStep = _React$useState2[0],
@@ -1027,8 +1230,9 @@ function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Objec
1027
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__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1028
1231
  const ExportResourcesModal = props => {
1029
1232
  const intl = reactIntl.useIntl();
1030
- const resourceTypePlural = resourceTypeToPlural({
1031
- resourceType: props.resourceType
1233
+ const resourceTypePlural = resourceTypeToDisplayName({
1234
+ resourceType: props.resourceType,
1235
+ isPlural: true
1032
1236
  });
1033
1237
  return jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1034
1238
  children: jsxRuntime.jsx(applicationComponents.InfoDialog, {
@@ -1048,7 +1252,8 @@ ExportResourcesModal.defaultProps = {
1048
1252
  isOpen: false,
1049
1253
  selectedResourceIds: [],
1050
1254
  exportType: EXPORT_TYPES.ALL,
1051
- outputFormat: OUTPUT_FORMATS.CSV
1255
+ outputFormat: OUTPUT_FORMATS.CSV,
1256
+ customFields: []
1052
1257
  };
1053
1258
 
1054
1259
  exports.EXPORTABLE_RESOURCES = EXPORTABLE_RESOURCES;