@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.
- package/README.md +87 -22
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.dev.js +319 -114
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.prod.js +316 -101
- package/dist/commercetools-frontend-extensions-export-resources-modal.esm.js +317 -116
- package/package.json +14 -14
|
@@ -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
|
|
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
|
|
176
|
-
function
|
|
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
|
-
|
|
193
|
+
displayName = isPlural ? 'Categories' : 'Category';
|
|
194
|
+
break;
|
|
183
195
|
case EXPORTABLE_RESOURCES.PRODUCT:
|
|
184
|
-
|
|
196
|
+
displayName = isPlural ? 'Products' : 'Product';
|
|
197
|
+
break;
|
|
185
198
|
case EXPORTABLE_RESOURCES.DISCOUNT_CODE:
|
|
186
|
-
|
|
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
|
|
276
|
+
function getSelectedGeneralFields(fields) {
|
|
262
277
|
return _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked);
|
|
263
278
|
}
|
|
264
|
-
function
|
|
265
|
-
return _mapInstanceProperty__default["default"](
|
|
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
|
-
|
|
273
|
-
|
|
274
|
-
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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]:
|
|
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
|
-
|
|
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(
|
|
438
|
+
} else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
|
|
370
439
|
errors.fileName.invalidInput = true;
|
|
371
440
|
}
|
|
372
|
-
if (
|
|
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
|
-
|
|
380
|
-
const
|
|
381
|
-
|
|
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 =
|
|
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
|
-
|
|
509
|
-
id: 'ExportResourcesModal.
|
|
510
|
-
defaultMessage: 'Select
|
|
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
|
-
|
|
528
|
-
id: 'ExportResourcesModal.
|
|
529
|
-
description: 'Label for "
|
|
530
|
-
defaultMessage: '
|
|
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(
|
|
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(
|
|
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 =
|
|
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
|
|
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: "
|
|
824
|
-
styles: "
|
|
915
|
+
name: "yqmzw4",
|
|
916
|
+
styles: "&>div{height:490px;overflow-y:auto;}"
|
|
825
917
|
} : {
|
|
826
|
-
name: "
|
|
827
|
-
styles: "
|
|
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
|
-
})(
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
} : {
|
|
840
|
-
|
|
841
|
-
|
|
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
|
-
})(
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
} : {
|
|
854
|
-
|
|
855
|
-
|
|
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,
|
|
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
|
|
867
|
-
const
|
|
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.
|
|
966
|
+
intlMessage: messages.selectFieldsToExport
|
|
876
967
|
}), jsxRuntime.jsx(uiKit.Link, {
|
|
877
968
|
isExternal: true,
|
|
878
969
|
tone: "secondary",
|
|
879
|
-
intlMessage: messages.
|
|
880
|
-
to:
|
|
970
|
+
intlMessage: messages.fieldDefinitions,
|
|
971
|
+
to: FIELD_DEFINITIONS_URLS[resourceType]
|
|
881
972
|
})]
|
|
882
973
|
}), jsxRuntime.jsxs(uiKit.Grid, {
|
|
883
|
-
gridAutoFlow: "
|
|
884
|
-
gridTemplateColumns: "".concat(uiKit.
|
|
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: !
|
|
890
|
-
isChecked:
|
|
981
|
+
isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
|
|
982
|
+
isChecked: areAllGeneralFieldsChecked,
|
|
891
983
|
onChange: e => {
|
|
892
|
-
var
|
|
893
|
-
formik.setFieldValue('fields', _mapInstanceProperty__default["default"](
|
|
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:
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
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
|
-
}
|
|
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 =
|
|
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;
|