@commercetools-frontend-extensions/export-resources-modal 3.2.1 → 3.4.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.
@@ -25,12 +25,16 @@ import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectW
25
25
  import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
26
26
  import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
27
27
  import _Object$assign from '@babel/runtime-corejs3/core-js-stable/object/assign';
28
- import { Link, TextInput, Text, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, PrimaryButton, Card, Grid, customProperties, SecondaryButton } from '@commercetools-frontend/ui-kit';
29
- import { jsx, jsxs } from '@emotion/react/jsx-runtime';
28
+ import _flatMapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat-map';
29
+ import _Set from '@babel/runtime-corejs3/core-js-stable/set';
30
+ import { Link, TextInput, Text, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, PrimaryButton, Card, designTokens, Grid, SecondaryButton } from '@commercetools-frontend/ui-kit';
31
+ import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
30
32
  import _valuesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/values';
33
+ import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
31
34
  import omitEmpty from 'omit-empty-es';
32
35
  import _findIndexInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find-index';
33
36
  import _spliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/splice';
37
+ import _startsWithInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
34
38
  import '@commercetools-uikit/design-system';
35
39
  import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
36
40
  import moment from 'moment';
@@ -74,7 +78,7 @@ const OUTPUT_FORMAT_OPTIONS = [{
74
78
  label: 'JSON'
75
79
  }];
76
80
 
77
- const COLUMN_DEFINITIONS_URLS = {
81
+ const FIELD_DEFINITIONS_URLS = {
78
82
  category: 'https://docs-proxy-sarm-product-import-csv.commercetools.vercel.app/merchant-center/import-categories#supported-headers-and-values'
79
83
  };
80
84
 
@@ -140,21 +144,28 @@ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
140
144
 
141
145
  const _excluded$1 = ["name"];
142
146
  function ownKeys$6(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; }
143
- 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(_context4 = ownKeys$6(Object(t), !0)).call(_context4, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context5 = ownKeys$6(Object(t))).call(_context5, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
144
- function resourceTypeToPlural(_ref) {
147
+ 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(_context7 = ownKeys$6(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context8 = ownKeys$6(Object(t))).call(_context8, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
148
+ function resourceTypeToDisplayName(_ref) {
145
149
  let resourceType = _ref.resourceType,
146
150
  _ref$isUpperCase = _ref.isUpperCase,
147
- isUpperCase = _ref$isUpperCase === void 0 ? false : _ref$isUpperCase;
151
+ isUpperCase = _ref$isUpperCase === void 0 ? false : _ref$isUpperCase,
152
+ _ref$isPlural = _ref.isPlural,
153
+ isPlural = _ref$isPlural === void 0 ? false : _ref$isPlural;
154
+ let displayName;
148
155
  switch (resourceType) {
149
156
  case EXPORTABLE_RESOURCES.CATEGORY:
150
- return isUpperCase ? 'Categories' : 'categories';
157
+ displayName = isPlural ? 'Categories' : 'Category';
158
+ break;
151
159
  case EXPORTABLE_RESOURCES.PRODUCT:
152
- return isUpperCase ? 'Products' : 'products';
160
+ displayName = isPlural ? 'Products' : 'Product';
161
+ break;
153
162
  case EXPORTABLE_RESOURCES.DISCOUNT_CODE:
154
- return isUpperCase ? 'Discount codes' : 'discount codes';
163
+ displayName = isPlural ? 'Discount codes' : 'Discount code';
164
+ break;
155
165
  default:
156
166
  throw UnexpectedResourceTypeError(resourceType);
157
167
  }
168
+ return isUpperCase ? displayName : displayName.toLowerCase();
158
169
  }
159
170
  function resourceTypeToOperationName(resourceType) {
160
171
  switch (resourceType) {
@@ -226,21 +237,51 @@ function unflattenNestedFields(flattenedFields) {
226
237
  });
227
238
  return reconstructed;
228
239
  }
229
- function getSelectedFields(fields) {
240
+ function getSelectedGeneralFields(fields) {
230
241
  return _filterInstanceProperty(fields).call(fields, field => field.isChecked);
231
242
  }
232
- function getFieldNames(fields) {
233
- return _mapInstanceProperty(fields).call(fields, field => field.name);
243
+ function getSelectedCustomFields(customFields) {
244
+ return _mapInstanceProperty(customFields).call(customFields, customType => {
245
+ var _context4;
246
+ return _objectSpread$6(_objectSpread$6({}, customType), {}, {
247
+ fields: _filterInstanceProperty(_context4 = customType.fields).call(_context4, field => field.isChecked)
248
+ });
249
+ });
250
+ }
251
+ function flattenCustomFields(customFields) {
252
+ return _flatMapInstanceProperty(customFields).call(customFields, customType => customType.fields);
234
253
  }
235
254
  function checkRequiredFields(fields) {
236
255
  return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$6(_objectSpread$6({}, field), {}, {
237
256
  isChecked: true
238
257
  }) : field);
239
258
  }
240
- const getExportLogsLink = (projectKey, msg) => jsx(Link, {
241
- to: "/".concat(projectKey, "/operations/export/logs"),
242
- children: msg
243
- });
259
+ function getExportLogsLink(projectKey, msg) {
260
+ return jsx(Link, {
261
+ to: "/".concat(projectKey, "/operations/export/logs"),
262
+ children: msg
263
+ });
264
+ }
265
+ function setInitialCheckedStateForCustomFields(customFields) {
266
+ return _mapInstanceProperty(customFields).call(customFields, customType => {
267
+ var _context5;
268
+ return _objectSpread$6(_objectSpread$6({}, customType), {}, {
269
+ fields: _mapInstanceProperty(_context5 = customType.fields).call(_context5, field => _objectSpread$6(_objectSpread$6({}, field), {}, {
270
+ isChecked: false
271
+ }))
272
+ });
273
+ });
274
+ }
275
+ function buildGeneralFieldColumns(generalFields) {
276
+ return _mapInstanceProperty(generalFields).call(generalFields, field => field.name);
277
+ }
278
+ function buildCustomFieldColumns(customFields) {
279
+ const columns = _flatMapInstanceProperty(customFields).call(customFields, customType => {
280
+ var _context6;
281
+ return _mapInstanceProperty(_context6 = customType.fields).call(_context6, field => "custom.fields.".concat(field.name));
282
+ });
283
+ return [...new _Set(columns)];
284
+ }
244
285
 
245
286
  /*
246
287
  * This function is responsible for constructing the GraphQL query based on the export settings
@@ -250,18 +291,28 @@ const getExportLogsLink = (projectKey, msg) => jsx(Link, {
250
291
  * - 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.
251
292
  * - The 'filtered' case is a placeholder for future development where a query will be constructed based on certain filtering criteria using the `where` parameter.
252
293
  */
253
- function buildGraphQuery(exportSettings) {
294
+ function buildGraphQLQuery(exportSettings) {
254
295
  var _context;
255
296
  const operation = resourceTypeToOperationName(exportSettings.resourceType);
297
+ const generalFields = buildGeneralFieldsForGraphQLQuery({
298
+ fields: exportSettings.fields,
299
+ locales: exportSettings.locales
300
+ });
301
+ const results = [...generalFields];
302
+ if (exportSettings.customFields && exportSettings.customFields.length > 0) {
303
+ const customFields = buildCustomFieldsForGraphQLQuery({
304
+ customFields: exportSettings.customFields
305
+ });
306
+ results.push({
307
+ custom: customFields
308
+ });
309
+ }
256
310
  switch (exportSettings.exportType) {
257
311
  case EXPORT_TYPES.ALL:
258
312
  return query({
259
313
  operation,
260
314
  fields: [{
261
- results: buildFields({
262
- fields: exportSettings.fields,
263
- locales: exportSettings.locales
264
- })
315
+ results
265
316
  }],
266
317
  variables: {}
267
318
  });
@@ -269,10 +320,7 @@ function buildGraphQuery(exportSettings) {
269
320
  return query({
270
321
  operation,
271
322
  fields: [{
272
- results: buildFields({
273
- fields: exportSettings.fields,
274
- locales: exportSettings.locales
275
- })
323
+ results
276
324
  }],
277
325
  variables: {
278
326
  where: "id in (".concat(_mapInstanceProperty(_context = exportSettings.selectedResourceIds).call(_context, id => "\"".concat(id, "\"")).join(', '), ")")
@@ -300,7 +348,7 @@ function buildGraphQuery(exportSettings) {
300
348
  * More details can be found in the related PR: https://github.com/commercetools/commercetools-exporter/pull/103
301
349
  */
302
350
 
303
- function buildFields(_ref) {
351
+ function buildGeneralFieldsForGraphQLQuery(_ref) {
304
352
  var _context2;
305
353
  let fields = _ref.fields,
306
354
  locales = _ref.locales;
@@ -312,7 +360,7 @@ function buildFields(_ref) {
312
360
  });else {
313
361
  if (isFilledArray(field.fields)) {
314
362
  return {
315
- [field.name]: buildFields({
363
+ [field.name]: buildGeneralFieldsForGraphQLQuery({
316
364
  fields: field.fields,
317
365
  locales
318
366
  })
@@ -322,31 +370,48 @@ function buildFields(_ref) {
322
370
  }
323
371
  })).call(_context2);
324
372
  }
373
+ function buildCustomFieldsForGraphQLQuery(_ref2) {
374
+ _ref2.customFields;
375
+ // const customFieldNames = customFields.map((customField) => customField.name)
376
+ return [{
377
+ type: ['key']
378
+ }, {
379
+ operation: 'customFieldsRaw',
380
+ fields: ['name', 'value'],
381
+ // TODO: Add custom fields filter to the variables when they are supported on the Export API side
382
+ variables: {
383
+ // includeNames: customFieldNames,
384
+ }
385
+ }];
386
+ }
325
387
 
326
388
  function validate(_ref) {
327
389
  let values = _valuesInstanceProperty(_ref),
328
390
  step = _ref.step;
391
+ const fileName = values.fileName,
392
+ locales = values.locales,
393
+ fields = values.fields,
394
+ customFields = values.customFields;
329
395
  const errors = {
330
396
  fileName: {},
331
397
  locales: {},
332
398
  fields: {}
333
399
  };
334
- // Always validate these fields (first and second steps)
335
- if (TextInput.isEmpty(values.fileName)) {
400
+ if (TextInput.isEmpty(fileName)) {
336
401
  errors.fileName.missing = true;
337
- } else if (!/^[a-zA-Z0-9-_.]+$/.test(values.fileName)) {
402
+ } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
338
403
  errors.fileName.invalidInput = true;
339
404
  }
340
- if (values.locales.length < 1) {
405
+ if (locales.length < 1) {
341
406
  errors.locales.missing = true;
342
407
  }
343
- //
344
-
345
- // Only validate these fields on the 2nd step
346
408
  if (step === 2) {
347
- var _context;
348
- const checkedFields = _filterInstanceProperty(_context = values.fields).call(_context, field => field.isChecked);
349
- if (checkedFields.length < 2) {
409
+ const checkedGeneralFieldsCount = _filterInstanceProperty(fields).call(fields, field => field.isChecked).length;
410
+ const checkedCustomFieldsCount = _reduceInstanceProperty(customFields).call(customFields, (count, customType) => {
411
+ var _context;
412
+ return count + _filterInstanceProperty(_context = customType.fields).call(_context, field => field.isChecked).length;
413
+ }, 0);
414
+ if (checkedGeneralFieldsCount + checkedCustomFieldsCount < 2) {
350
415
  errors.fields.missing = true;
351
416
  }
352
417
  }
@@ -359,6 +424,10 @@ const categoryColumnExtension = columns => {
359
424
  if (parentKeyIndex !== -1) {
360
425
  _spliceInstanceProperty(extendedColumns).call(extendedColumns, parentKeyIndex + 1, 0, 'parent.typeId');
361
426
  }
427
+ const firstCustomFieldIndex = _findIndexInstanceProperty(extendedColumns).call(extendedColumns, column => _startsWithInstanceProperty(column).call(column, 'custom.fields.'));
428
+ if (firstCustomFieldIndex !== -1) {
429
+ _spliceInstanceProperty(extendedColumns).call(extendedColumns, firstCustomFieldIndex, 0, 'custom.type.key', 'custom.type.typeId');
430
+ }
362
431
  return extendedColumns;
363
432
  };
364
433
  const defaultColumnExtension = columns => columns;
@@ -367,7 +436,9 @@ const columnExtensionByResourceType = {
367
436
  category: categoryColumnExtension
368
437
  };
369
438
 
370
- const extendColumns = (columns, resourceType) => {
439
+ const extendColumns = _ref => {
440
+ let resourceType = _ref.resourceType,
441
+ columns = _ref.columns;
371
442
  const extensionFunction = columnExtensionByResourceType[resourceType] || columnExtensionByResourceType.default;
372
443
  return extensionFunction(columns);
373
444
  };
@@ -423,11 +494,6 @@ var messages = defineMessages({
423
494
  description: 'resources are selected and will be exported',
424
495
  defaultMessage: '<b>{count}</b> {resourceType} are selected and will be exported.'
425
496
  },
426
- columnsMessage: {
427
- id: 'ExportResourcesModal.columnsMessage',
428
- description: 'Exported columns and attributes based on table settings',
429
- defaultMessage: 'Exported columns/attributes based on table settings: {columnsCount}'
430
- },
431
497
  exportBasedOnMyViewsMessage: {
432
498
  id: 'ExportResourcesModal.exportBasedOnMyViewsMessage',
433
499
  description: 'Select Export setttings based on my views',
@@ -473,9 +539,9 @@ var messages = defineMessages({
473
539
  description: 'Label for "My Views" Select Field',
474
540
  defaultMessage: 'My Views'
475
541
  },
476
- selectColumnsToExport: {
477
- id: 'ExportResourcesModal.selectColumnsToExport',
478
- defaultMessage: 'Select columns to export'
542
+ selectFieldsToExport: {
543
+ id: 'ExportResourcesModal.selectFieldsToExport',
544
+ defaultMessage: 'Select fields to export'
479
545
  },
480
546
  back: {
481
547
  id: 'ExportResourcesModal.back',
@@ -492,15 +558,25 @@ var messages = defineMessages({
492
558
  description: 'Label for "Continue" button',
493
559
  defaultMessage: 'Continue'
494
560
  },
495
- columnDefinitions: {
496
- id: 'ExportResourcesModal.columnDefinitions',
497
- description: 'Label for "Column Definitions" link',
498
- defaultMessage: 'Column definitions'
561
+ fieldDefinitions: {
562
+ id: 'ExportResourcesModal.fieldDefinitions',
563
+ description: 'Label for "Field definitions" link',
564
+ defaultMessage: 'Field definitions'
499
565
  },
500
566
  allGeneralFields: {
501
567
  id: 'ExportResourcesModal.allGeneralFields',
502
568
  description: 'Label for "All general fields" checkbox',
503
569
  defaultMessage: 'All general fields'
570
+ },
571
+ allCustomFields: {
572
+ id: 'ExportResourcesModal.allCustomFields',
573
+ description: 'Label for "All custom fields" checkbox',
574
+ defaultMessage: 'All custom fields'
575
+ },
576
+ customTypeKeyAndTypeId: {
577
+ id: 'ExportResourcesModal.customTypeKeyAndTypeId',
578
+ description: 'Label for "Custom type key and typeId" checkbox',
579
+ defaultMessage: 'Custom type key and typeId'
504
580
  }
505
581
  });
506
582
 
@@ -566,12 +642,14 @@ const useInitialValues = props => {
566
642
  var _context2;
567
643
  return {
568
644
  outputFormat: props.outputFormat,
569
- fileName: _concatInstanceProperty(_context2 = "".concat(resourceTypeToPlural({
645
+ fileName: _concatInstanceProperty(_context2 = "".concat(resourceTypeToDisplayName({
570
646
  resourceType: props.resourceType,
571
- isUpperCase: true
647
+ isUpperCase: true,
648
+ isPlural: true
572
649
  }), "_Export_")).call(_context2, todayFormatted),
573
650
  locales: [locale],
574
- fields: checkRequiredFields(fields)
651
+ fields: checkRequiredFields(fields),
652
+ customFields: setInitialCheckedStateForCustomFields(props.customFields)
575
653
  };
576
654
  }, [props, locale, todayFormatted, fields]);
577
655
  };
@@ -616,19 +694,27 @@ const useStartExportOperation = props => {
616
694
  }),
617
695
  projectKey = _useApplicationContex.projectKey;
618
696
  const startExportOperation = async values => {
619
- const graphQuery = buildGraphQuery({
620
- resourceType: props.resourceType,
621
- exportType: props.exportType,
622
- selectedResourceIds: props.selectedResourceIds,
623
- fields: unflattenNestedFields(getSelectedFields(values.fields)),
624
- locales: values.locales
625
- });
626
697
  try {
698
+ const selectedGeneralFields = getSelectedGeneralFields(values.fields);
699
+ const selectedCustomFields = getSelectedCustomFields(values.customFields);
700
+ const generalColumns = buildGeneralFieldColumns(selectedGeneralFields);
701
+ const customColumns = buildCustomFieldColumns(selectedCustomFields);
702
+ const graphQuery = buildGraphQLQuery({
703
+ resourceType: props.resourceType,
704
+ exportType: props.exportType,
705
+ selectedResourceIds: props.selectedResourceIds,
706
+ fields: unflattenNestedFields(selectedGeneralFields),
707
+ customFields: flattenCustomFields(selectedCustomFields),
708
+ locales: values.locales
709
+ });
627
710
  const response = await createExportOperation({
628
711
  fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
629
712
  fileFormat: values.outputFormat,
630
713
  locales: values.locales,
631
- columns: extendColumns(getFieldNames(getSelectedFields(values.fields)), props.resourceType),
714
+ columns: extendColumns({
715
+ resourceType: props.resourceType,
716
+ columns: [...generalColumns, ...customColumns]
717
+ }),
632
718
  projectKey,
633
719
  graphQuery,
634
720
  asyncDispatchFn: asyncDispatch
@@ -669,13 +755,15 @@ const useStartExportOperation = props => {
669
755
  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; }
670
756
  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; }
671
757
  function ExportTextMessage() {
758
+ const intl = useIntl();
672
759
  const _useExportResourcesCo = useExportResourcesContext(),
673
760
  resourceType = _useExportResourcesCo.resourceType,
674
761
  totalResourcesCount = _useExportResourcesCo.totalResourcesCount,
675
762
  selectedResourceIds = _useExportResourcesCo.selectedResourceIds,
676
763
  exportType = _useExportResourcesCo.exportType;
677
- const resourceTypePlural = resourceTypeToPlural({
678
- resourceType: resourceType
764
+ const resourceTypePlural = resourceTypeToDisplayName({
765
+ resourceType: resourceType,
766
+ isPlural: true
679
767
  });
680
768
  let message;
681
769
  let count;
@@ -695,7 +783,7 @@ function ExportTextMessage() {
695
783
  "data-testid": "export-description",
696
784
  intlMessage: _objectSpread$3(_objectSpread$3({}, message), {}, {
697
785
  values: {
698
- count: count,
786
+ count: intl.formatNumber(count),
699
787
  resourceType: resourceTypePlural,
700
788
  b: getBold
701
789
  }
@@ -780,7 +868,7 @@ const ExportFileSettingsStep = () => {
780
868
  };
781
869
 
782
870
  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; }
783
- 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(_context6 = ownKeys$2(Object(t), !0)).call(_context6, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context7 = ownKeys$2(Object(t))).call(_context7, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
871
+ 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; }
784
872
  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)."; }
785
873
  const StyledCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
786
874
  target: "e1ocu3bb2"
@@ -788,12 +876,12 @@ const StyledCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "producti
788
876
  target: "e1ocu3bb2",
789
877
  label: "StyledCard"
790
878
  })(process.env.NODE_ENV === "production" ? {
791
- name: "1jtoq3b",
792
- styles: "border-radius:4px 0px 0px 4px;&>div{height:490px;overflow-y:auto;}"
879
+ name: "yqmzw4",
880
+ styles: "&>div{height:490px;overflow-y:auto;}"
793
881
  } : {
794
- name: "1jtoq3b",
795
- styles: "border-radius:4px 0px 0px 4px;&>div{height:490px;overflow-y:auto;}",
796
- 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 */",
882
+ name: "yqmzw4",
883
+ styles: "&>div{height:490px;overflow-y:auto;}",
884
+ 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.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"]} */",
797
885
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
798
886
  });
799
887
  const StyledCardLeft = /*#__PURE__*/_styled(StyledCard, process.env.NODE_ENV === "production" ? {
@@ -801,38 +889,37 @@ const StyledCardLeft = /*#__PURE__*/_styled(StyledCard, process.env.NODE_ENV ===
801
889
  } : {
802
890
  target: "e1ocu3bb1",
803
891
  label: "StyledCardLeft"
804
- })(process.env.NODE_ENV === "production" ? {
805
- name: "65buvr",
806
- styles: "background-color:#f9f9fb"
807
- } : {
808
- name: "65buvr",
809
- styles: "background-color:#f9f9fb",
810
- 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 */",
811
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
812
- });
892
+ })("background-color:#f9f9fb;border-top:", _ref => {
893
+ let isTopRow = _ref.isTopRow;
894
+ return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
895
+ }, ";border-radius:", _ref2 => {
896
+ let isTopRow = _ref2.isTopRow;
897
+ return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
898
+ }, ";" + (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.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"]} */"));
813
899
  const StyledCardRight = /*#__PURE__*/_styled(StyledCard, process.env.NODE_ENV === "production" ? {
814
900
  target: "e1ocu3bb0"
815
901
  } : {
816
902
  target: "e1ocu3bb0",
817
903
  label: "StyledCardRight"
818
- })(process.env.NODE_ENV === "production" ? {
819
- name: "1oktwfs",
820
- styles: "border-radius:0px 4px 4px 0px;border-left:0"
821
- } : {
822
- name: "1oktwfs",
823
- styles: "border-radius:0px 4px 4px 0px;border-left:0",
824
- 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 */",
825
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
826
- });
904
+ })("border-left:0;border-top:", _ref3 => {
905
+ let isTopRow = _ref3.isTopRow;
906
+ return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
907
+ }, ";border-radius:", _ref4 => {
908
+ let isTopRow = _ref4.isTopRow;
909
+ return isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px';
910
+ }, ";" + (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.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"]} */"));
827
911
  const ExportFieldsSelectionStep = () => {
828
- var _context, _context2, _context4;
912
+ var _context, _context2, _context3, _formik$values$custom;
829
913
  const intl = useIntl();
830
914
  const _useExportResourcesCo = useExportResourcesContext(),
831
915
  formik = _useExportResourcesCo.formik,
832
916
  setCurrentStep = _useExportResourcesCo.setCurrentStep,
833
917
  resourceType = _useExportResourcesCo.resourceType;
834
- const areAllFieldsChecked = _everyInstanceProperty(_context = _valuesInstanceProperty(formik).fields).call(_context, field => field.isChecked);
835
- const isAtLeastOneFieldChecked = _someInstanceProperty(_context2 = _valuesInstanceProperty(formik).fields).call(_context2, field => field.isChecked);
918
+ const areAllGeneralFieldsChecked = _everyInstanceProperty(_context = _valuesInstanceProperty(formik).fields).call(_context, field => field.isChecked);
919
+ const isAtLeastOneGeneralFieldChecked = _someInstanceProperty(_context2 = _valuesInstanceProperty(formik).fields).call(_context2, field => field.isChecked);
920
+ const allCustomFields = _flatMapInstanceProperty(_context3 = _valuesInstanceProperty(formik).customFields).call(_context3, customType => customType.fields);
921
+ const areAllCustomFieldsChecked = _everyInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
922
+ const isAtLeastOneCustomFieldChecked = _someInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
836
923
  return jsxs(Spacings.Stack, {
837
924
  scale: "xl",
838
925
  children: [jsxs(Spacings.Stack, {
@@ -840,25 +927,26 @@ const ExportFieldsSelectionStep = () => {
840
927
  children: [jsxs(Spacings.Inline, {
841
928
  justifyContent: "space-between",
842
929
  children: [jsx(Text.Body, {
843
- intlMessage: messages.selectColumnsToExport
930
+ intlMessage: messages.selectFieldsToExport
844
931
  }), jsx(Link, {
845
932
  isExternal: true,
846
933
  tone: "secondary",
847
- intlMessage: messages.columnDefinitions,
848
- to: COLUMN_DEFINITIONS_URLS[resourceType]
934
+ intlMessage: messages.fieldDefinitions,
935
+ to: FIELD_DEFINITIONS_URLS[resourceType]
849
936
  })]
850
937
  }), jsxs(Grid, {
851
- gridAutoFlow: "column",
852
- gridTemplateColumns: "".concat(customProperties.constraint5, " auto"),
938
+ gridAutoFlow: "row",
939
+ gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
853
940
  children: [jsx(Grid.Item, {
854
941
  children: jsx(StyledCardLeft, {
942
+ isTopRow: true,
855
943
  insetScale: "l",
856
944
  children: jsx(CheckboxInput, {
857
- isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
858
- isChecked: areAllFieldsChecked,
945
+ isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
946
+ isChecked: areAllGeneralFieldsChecked,
859
947
  onChange: e => {
860
- var _context3;
861
- formik.setFieldValue('fields', _mapInstanceProperty(_context3 = _valuesInstanceProperty(formik).fields).call(_context3, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
948
+ var _context4;
949
+ formik.setFieldValue('fields', _mapInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
862
950
  isChecked: field.isRequired ? true : e.target.checked
863
951
  })));
864
952
  },
@@ -869,21 +957,58 @@ const ExportFieldsSelectionStep = () => {
869
957
  })
870
958
  }), jsx(Grid.Item, {
871
959
  children: jsx(StyledCardRight, {
960
+ isTopRow: true,
872
961
  insetScale: "l",
873
- children: _mapInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => jsx(CheckboxInput, {
874
- isReadOnly: field.isRequired,
875
- isChecked: field.isChecked,
876
- onChange: e => {
877
- var _context5;
878
- formik.setFieldValue('fields', _mapInstanceProperty(_context5 = _valuesInstanceProperty(formik).fields).call(_context5, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
879
- isChecked: e.target.checked
880
- }) : _field));
881
- },
882
- children: jsxs(Text.Body, {
883
- children: [field.label, " ", field.isRequired && '*']
962
+ children: jsx(Spacings.Stack, {
963
+ scale: "s",
964
+ children: jsx(GeneralFieldsSelection, {
965
+ fields: _valuesInstanceProperty(formik).fields,
966
+ setFieldValue: formik.setFieldValue
884
967
  })
885
- }, field.name))
968
+ })
886
969
  })
970
+ }), ((_formik$values$custom = _valuesInstanceProperty(formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxs(Fragment, {
971
+ children: [jsx(Grid.Item, {
972
+ children: jsx(StyledCardLeft, {
973
+ insetScale: "l",
974
+ children: jsx(CheckboxInput, {
975
+ isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
976
+ isChecked: areAllCustomFieldsChecked,
977
+ onChange: e => {
978
+ var _context5;
979
+ formik.setFieldValue('customFields', _mapInstanceProperty(_context5 = _valuesInstanceProperty(formik).customFields).call(_context5, customType => {
980
+ var _context6;
981
+ return _objectSpread$2(_objectSpread$2({}, customType), {}, {
982
+ fields: _mapInstanceProperty(_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
983
+ isChecked: e.target.checked
984
+ }))
985
+ });
986
+ }));
987
+ },
988
+ children: jsx(Text.Body, {
989
+ intlMessage: messages.allCustomFields
990
+ })
991
+ })
992
+ })
993
+ }), jsx(Grid.Item, {
994
+ children: jsx(StyledCardRight, {
995
+ insetScale: "l",
996
+ children: jsxs(Spacings.Stack, {
997
+ scale: "s",
998
+ children: [jsx(CheckboxInput, {
999
+ isReadOnly: true,
1000
+ onChange: () => {},
1001
+ isChecked: isAtLeastOneCustomFieldChecked,
1002
+ children: jsxs(Text.Body, {
1003
+ children: [intl.formatMessage(messages.customTypeKeyAndTypeId), " *"]
1004
+ })
1005
+ }), jsx(CustomFieldsSelection, {
1006
+ customFields: _valuesInstanceProperty(formik).customFields,
1007
+ setFieldValue: formik.setFieldValue
1008
+ })]
1009
+ })
1010
+ })
1011
+ })]
887
1012
  })]
888
1013
  })]
889
1014
  }), jsxs(Spacings.Inline, {
@@ -900,6 +1025,72 @@ const ExportFieldsSelectionStep = () => {
900
1025
  })]
901
1026
  });
902
1027
  };
1028
+ const GeneralFieldsSelection = _ref5 => {
1029
+ let fields = _ref5.fields,
1030
+ setFieldValue = _ref5.setFieldValue;
1031
+ return _mapInstanceProperty(fields).call(fields, field => jsx(CheckboxInput, {
1032
+ isChecked: field.isChecked,
1033
+ isReadOnly: field.isRequired,
1034
+ onChange: e => {
1035
+ setFieldValue('fields', _mapInstanceProperty(fields).call(fields, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1036
+ isChecked: e.target.checked
1037
+ }) : _field));
1038
+ },
1039
+ children: jsxs(Text.Body, {
1040
+ children: [field.label, " ", field.isRequired && '*']
1041
+ })
1042
+ }, field.name));
1043
+ };
1044
+ const CustomFieldsSelection = _ref6 => {
1045
+ let customFields = _ref6.customFields,
1046
+ setFieldValue = _ref6.setFieldValue;
1047
+ return _mapInstanceProperty(customFields).call(customFields, customType => {
1048
+ var _context7, _context8, _context10;
1049
+ const areAllFieldsChecked = _everyInstanceProperty(_context7 = customType.fields).call(_context7, field => field.isChecked);
1050
+ const isAtLeastOneFieldChecked = _someInstanceProperty(_context8 = customType.fields).call(_context8, field => field.isChecked);
1051
+ return jsxs(Spacings.Stack, {
1052
+ scale: "s",
1053
+ children: [jsx(CheckboxInput, {
1054
+ isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
1055
+ isChecked: areAllFieldsChecked,
1056
+ onChange: e => {
1057
+ setFieldValue('customFields', _mapInstanceProperty(customFields).call(customFields, _customType => {
1058
+ var _context9;
1059
+ return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1060
+ fields: _mapInstanceProperty(_context9 = _customType.fields).call(_context9, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1061
+ isChecked: e.target.checked
1062
+ }))
1063
+ }) : _customType;
1064
+ }));
1065
+ },
1066
+ children: jsx(Text.Body, {
1067
+ children: customType.type.label
1068
+ })
1069
+ }), jsxs(Spacings.Inline, {
1070
+ scale: "l",
1071
+ children: [jsx("div", {}), jsx(Spacings.Stack, {
1072
+ scale: "s",
1073
+ children: _mapInstanceProperty(_context10 = customType.fields).call(_context10, field => jsx(CheckboxInput, {
1074
+ isChecked: field.isChecked,
1075
+ onChange: e => {
1076
+ setFieldValue('customFields', _mapInstanceProperty(customFields).call(customFields, _customType => {
1077
+ var _context11;
1078
+ return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
1079
+ fields: _mapInstanceProperty(_context11 = _customType.fields).call(_context11, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
1080
+ isChecked: e.target.checked
1081
+ }) : _field)
1082
+ }) : _customType;
1083
+ }));
1084
+ },
1085
+ children: jsx(Text.Body, {
1086
+ children: field.label
1087
+ })
1088
+ }, field.name))
1089
+ })]
1090
+ })]
1091
+ }, customType.type.key);
1092
+ });
1093
+ };
903
1094
 
904
1095
  process.env.NODE_ENV !== "production" ? {
905
1096
  renderProperties: PropTypes.func
@@ -928,6 +1119,16 @@ const ExportResourcesModalShape = PropTypes.shape({
928
1119
  isRequired: PropTypes.bool
929
1120
  }))
930
1121
  })).isRequired,
1122
+ customFields: PropTypes.shape({
1123
+ type: PropTypes.shape({
1124
+ key: PropTypes.string.isRequired,
1125
+ label: PropTypes.string.isRequired
1126
+ }).isRequired,
1127
+ fields: PropTypes.arrayOf(PropTypes.shape({
1128
+ name: PropTypes.string.isRequired,
1129
+ label: PropTypes.string
1130
+ })).isRequired
1131
+ }),
931
1132
  exportType: PropTypes.string,
932
1133
  renderProperties: PropTypes.func
933
1134
  }).isRequired;
@@ -935,9 +1136,9 @@ const ExportResourcesModalShape = PropTypes.shape({
935
1136
  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; }
936
1137
  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; }
937
1138
  const ExportResourcesProvider = props => {
1139
+ const initialValues = useInitialValues(props);
938
1140
  const _useStartExportOperat = useStartExportOperation(props),
939
1141
  startExportOperation = _useStartExportOperat.startExportOperation;
940
- const initialValues = useInitialValues(props);
941
1142
  const _React$useState = React.useState(1),
942
1143
  _React$useState2 = _slicedToArray(_React$useState, 2),
943
1144
  currentStep = _React$useState2[0],
@@ -995,8 +1196,9 @@ function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymb
995
1196
  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; }
996
1197
  const ExportResourcesModal = props => {
997
1198
  const intl = useIntl();
998
- const resourceTypePlural = resourceTypeToPlural({
999
- resourceType: props.resourceType
1199
+ const resourceTypePlural = resourceTypeToDisplayName({
1200
+ resourceType: props.resourceType,
1201
+ isPlural: true
1000
1202
  });
1001
1203
  return jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1002
1204
  children: jsx(InfoDialog, {
@@ -1016,7 +1218,8 @@ ExportResourcesModal.defaultProps = {
1016
1218
  isOpen: false,
1017
1219
  selectedResourceIds: [],
1018
1220
  exportType: EXPORT_TYPES.ALL,
1019
- outputFormat: OUTPUT_FORMATS.CSV
1221
+ outputFormat: OUTPUT_FORMATS.CSV,
1222
+ customFields: []
1020
1223
  };
1021
1224
 
1022
1225
  export { EXPORTABLE_RESOURCES, EXPORT_TYPES, ExportResourcesModal as default };