@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.
- package/README.md +96 -22
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.dev.js +321 -114
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.prod.js +318 -101
- package/dist/commercetools-frontend-extensions-export-resources-modal.esm.js +319 -116
- package/package.json +14 -14
|
@@ -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
|
|
29
|
-
import
|
|
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
|
|
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
|
|
144
|
-
function
|
|
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
|
-
|
|
157
|
+
displayName = isPlural ? 'Categories' : 'Category';
|
|
158
|
+
break;
|
|
151
159
|
case EXPORTABLE_RESOURCES.PRODUCT:
|
|
152
|
-
|
|
160
|
+
displayName = isPlural ? 'Products' : 'Product';
|
|
161
|
+
break;
|
|
153
162
|
case EXPORTABLE_RESOURCES.DISCOUNT_CODE:
|
|
154
|
-
|
|
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
|
|
240
|
+
function getSelectedGeneralFields(fields) {
|
|
230
241
|
return _filterInstanceProperty(fields).call(fields, field => field.isChecked);
|
|
231
242
|
}
|
|
232
|
-
function
|
|
233
|
-
return _mapInstanceProperty(
|
|
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
|
-
|
|
241
|
-
|
|
242
|
-
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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]:
|
|
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
|
-
|
|
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(
|
|
402
|
+
} else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
|
|
338
403
|
errors.fileName.invalidInput = true;
|
|
339
404
|
}
|
|
340
|
-
if (
|
|
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
|
-
|
|
348
|
-
const
|
|
349
|
-
|
|
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 =
|
|
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
|
-
|
|
477
|
-
id: 'ExportResourcesModal.
|
|
478
|
-
defaultMessage: 'Select
|
|
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
|
-
|
|
496
|
-
id: 'ExportResourcesModal.
|
|
497
|
-
description: 'Label for "
|
|
498
|
-
defaultMessage: '
|
|
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(
|
|
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(
|
|
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 =
|
|
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
|
|
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: "
|
|
792
|
-
styles: "
|
|
879
|
+
name: "yqmzw4",
|
|
880
|
+
styles: "&>div{height:490px;overflow-y:auto;}"
|
|
793
881
|
} : {
|
|
794
|
-
name: "
|
|
795
|
-
styles: "
|
|
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
|
-
})(
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
} : {
|
|
808
|
-
|
|
809
|
-
|
|
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
|
-
})(
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
} : {
|
|
822
|
-
|
|
823
|
-
|
|
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,
|
|
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
|
|
835
|
-
const
|
|
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.
|
|
930
|
+
intlMessage: messages.selectFieldsToExport
|
|
844
931
|
}), jsx(Link, {
|
|
845
932
|
isExternal: true,
|
|
846
933
|
tone: "secondary",
|
|
847
|
-
intlMessage: messages.
|
|
848
|
-
to:
|
|
934
|
+
intlMessage: messages.fieldDefinitions,
|
|
935
|
+
to: FIELD_DEFINITIONS_URLS[resourceType]
|
|
849
936
|
})]
|
|
850
937
|
}), jsxs(Grid, {
|
|
851
|
-
gridAutoFlow: "
|
|
852
|
-
gridTemplateColumns: "".concat(
|
|
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: !
|
|
858
|
-
isChecked:
|
|
945
|
+
isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
|
|
946
|
+
isChecked: areAllGeneralFieldsChecked,
|
|
859
947
|
onChange: e => {
|
|
860
|
-
var
|
|
861
|
-
formik.setFieldValue('fields', _mapInstanceProperty(
|
|
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:
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
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
|
-
}
|
|
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 =
|
|
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 };
|