@commercetools-frontend-extensions/export-resources-modal 3.7.0 → 4.0.1
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 +166 -138
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.d.ts +3 -0
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.dev.js +417 -412
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.prod.js +410 -402
- package/dist/commercetools-frontend-extensions-export-resources-modal.esm.js +410 -405
- package/dist/de-a34c5dd4.cjs.dev.js +6 -0
- package/dist/de-cd6c45d3.esm.js +4 -0
- package/dist/de-d954fe3d.cjs.prod.js +6 -0
- package/dist/declarations/src/@constants/delimiters.d.ts +4 -0
- package/dist/declarations/src/@constants/export-operation-states.d.ts +5 -0
- package/dist/declarations/src/@constants/export-types.d.ts +5 -0
- package/dist/declarations/src/@constants/exportable-resources.d.ts +5 -0
- package/dist/declarations/src/@constants/index.d.ts +7 -0
- package/dist/declarations/src/@constants/misc.d.ts +1 -0
- package/dist/declarations/src/@constants/output-formats.d.ts +8 -0
- package/dist/declarations/src/@constants/urls.d.ts +3 -0
- package/dist/declarations/src/@types/export-resources-modal-shape.d.ts +27 -0
- package/dist/declarations/src/@types/formik.d.ts +11 -0
- package/dist/declarations/src/@types/index.d.ts +2 -0
- package/dist/declarations/src/export-resources-modal.d.ts +13 -0
- package/dist/declarations/src/index.d.ts +3 -0
- package/dist/en-3a9aa2d4.esm.js +4 -0
- package/dist/en-6b3694f6.cjs.dev.js +6 -0
- package/dist/en-c7757448.cjs.prod.js +6 -0
- package/dist/es-042343bd.cjs.prod.js +6 -0
- package/dist/es-8b3ecab1.cjs.dev.js +6 -0
- package/dist/es-e544023d.esm.js +4 -0
- package/dist/fr-FR-9d9081ee.esm.js +4 -0
- package/dist/fr-FR-e7126fcc.cjs.dev.js +6 -0
- package/dist/fr-FR-fce1ca96.cjs.prod.js +6 -0
- package/dist/ja-37632763.cjs.prod.js +6 -0
- package/dist/ja-73c088a7.esm.js +4 -0
- package/dist/ja-9bd5f452.cjs.dev.js +6 -0
- package/dist/pt-BR-b37d730b.esm.js +4 -0
- package/dist/pt-BR-ea6b3251.cjs.dev.js +6 -0
- package/dist/pt-BR-ec2a1a11.cjs.prod.js +6 -0
- package/dist/zh-CN-4780d88e.esm.js +4 -0
- package/dist/zh-CN-52baa549.cjs.prod.js +6 -0
- package/dist/zh-CN-d4bc6d26.cjs.dev.js +6 -0
- package/package.json +30 -19
|
@@ -11,14 +11,13 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
|
|
|
11
11
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
12
12
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
13
13
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
-
var
|
|
14
|
+
var reactIntl = require('react-intl');
|
|
15
|
+
var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
|
|
15
16
|
var uiKit = require('@commercetools-frontend/ui-kit');
|
|
16
17
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
17
18
|
require('@commercetools-uikit/design-system');
|
|
18
|
-
var reactIntl = require('react-intl');
|
|
19
19
|
var _valuesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/values');
|
|
20
20
|
var applicationComponents = require('@commercetools-frontend/application-components');
|
|
21
|
-
var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
|
|
22
21
|
var _Reflect$construct = require('@babel/runtime-corejs3/core-js-stable/reflect/construct');
|
|
23
22
|
var _createClass = require('@babel/runtime-corejs3/helpers/createClass');
|
|
24
23
|
var _classCallCheck = require('@babel/runtime-corejs3/helpers/classCallCheck');
|
|
@@ -26,31 +25,33 @@ var _inherits = require('@babel/runtime-corejs3/helpers/inherits');
|
|
|
26
25
|
var _possibleConstructorReturn = require('@babel/runtime-corejs3/helpers/possibleConstructorReturn');
|
|
27
26
|
var _getPrototypeOf = require('@babel/runtime-corejs3/helpers/getPrototypeOf');
|
|
28
27
|
var _wrapNativeSuper = require('@babel/runtime-corejs3/helpers/wrapNativeSuper');
|
|
29
|
-
var
|
|
30
|
-
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
28
|
+
var React = require('react');
|
|
31
29
|
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
32
30
|
var moment = require('moment');
|
|
31
|
+
var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
|
|
33
32
|
var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
34
33
|
var omitEmpty = require('omit-empty-es');
|
|
34
|
+
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
35
35
|
var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
|
|
36
|
-
var _flatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat');
|
|
37
|
-
var _flatMapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat-map');
|
|
38
36
|
var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
|
|
39
37
|
var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
|
|
40
|
-
var
|
|
41
|
-
var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
|
|
38
|
+
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
42
39
|
var sdk = require('@commercetools-frontend/sdk');
|
|
43
40
|
var actionsGlobal = require('@commercetools-frontend/actions-global');
|
|
44
41
|
var constants = require('@commercetools-frontend/constants');
|
|
45
42
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
46
43
|
var _styled = require('@emotion/styled/base');
|
|
47
44
|
var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
|
|
48
|
-
var
|
|
45
|
+
var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
|
|
49
46
|
var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
|
|
47
|
+
var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
50
48
|
var throttle = require('lodash/throttle');
|
|
51
49
|
var react = require('@emotion/react');
|
|
50
|
+
var get = require('lodash/get');
|
|
52
51
|
var PropTypes = require('prop-types');
|
|
53
52
|
var formik = require('formik');
|
|
53
|
+
var sentry = require('@commercetools-frontend/sentry');
|
|
54
|
+
var i18n = require('@commercetools-frontend/i18n');
|
|
54
55
|
|
|
55
56
|
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
56
57
|
|
|
@@ -62,26 +63,26 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
|
|
|
62
63
|
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
63
64
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
64
65
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
65
|
-
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
66
66
|
var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
|
|
67
67
|
var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
|
|
68
|
-
var
|
|
68
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
69
69
|
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
70
70
|
var moment__default = /*#__PURE__*/_interopDefault(moment);
|
|
71
|
+
var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
|
|
71
72
|
var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
|
|
72
73
|
var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
|
|
74
|
+
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
73
75
|
var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
|
|
74
|
-
var _flatInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatInstanceProperty);
|
|
75
|
-
var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
|
|
76
76
|
var _Set__default = /*#__PURE__*/_interopDefault(_Set);
|
|
77
77
|
var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
|
|
78
|
-
var
|
|
79
|
-
var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
|
|
78
|
+
var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
|
|
80
79
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
81
80
|
var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
|
|
82
|
-
var
|
|
81
|
+
var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
|
|
83
82
|
var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
|
|
83
|
+
var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
|
|
84
84
|
var throttle__default = /*#__PURE__*/_interopDefault(throttle);
|
|
85
|
+
var get__default = /*#__PURE__*/_interopDefault(get);
|
|
85
86
|
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
86
87
|
|
|
87
88
|
function getBold(msg) {
|
|
@@ -216,21 +217,6 @@ var messages = reactIntl.defineMessages({
|
|
|
216
217
|
description: 'Label for "Field definitions" link',
|
|
217
218
|
defaultMessage: 'Field definitions'
|
|
218
219
|
},
|
|
219
|
-
allGeneralFields: {
|
|
220
|
-
id: 'ExportResourcesModal.allGeneralFields',
|
|
221
|
-
description: 'Label for "All general fields" checkbox',
|
|
222
|
-
defaultMessage: 'All general fields'
|
|
223
|
-
},
|
|
224
|
-
allCustomFields: {
|
|
225
|
-
id: 'ExportResourcesModal.allCustomFields',
|
|
226
|
-
description: 'Label for "All custom fields" checkbox',
|
|
227
|
-
defaultMessage: 'All custom fields'
|
|
228
|
-
},
|
|
229
|
-
customTypeKeyAndTypeId: {
|
|
230
|
-
id: 'ExportResourcesModal.customTypeKeyAndTypeId',
|
|
231
|
-
description: 'Label for "Custom type key and typeId" checkbox',
|
|
232
|
-
defaultMessage: 'Custom type key and typeId'
|
|
233
|
-
},
|
|
234
220
|
unexpectedError: {
|
|
235
221
|
id: 'ExportResourcesModal.unexpectedError',
|
|
236
222
|
description: 'Generic notification message when starting export process fails',
|
|
@@ -263,14 +249,14 @@ var messages = reactIntl.defineMessages({
|
|
|
263
249
|
}
|
|
264
250
|
});
|
|
265
251
|
|
|
266
|
-
function ownKeys$
|
|
267
|
-
function _objectSpread$
|
|
252
|
+
function ownKeys$4(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; }
|
|
253
|
+
function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$4(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$4(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
268
254
|
function renderFileNameError(key) {
|
|
269
255
|
switch (key) {
|
|
270
256
|
case 'missing':
|
|
271
|
-
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$
|
|
257
|
+
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$4({}, messages.missingFileNameError));
|
|
272
258
|
case 'invalidInput':
|
|
273
|
-
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$
|
|
259
|
+
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$4({}, messages.invalidFileNameError));
|
|
274
260
|
default:
|
|
275
261
|
return null;
|
|
276
262
|
}
|
|
@@ -278,7 +264,7 @@ function renderFileNameError(key) {
|
|
|
278
264
|
function renderLocaleError(key) {
|
|
279
265
|
switch (key) {
|
|
280
266
|
case 'missing':
|
|
281
|
-
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$
|
|
267
|
+
return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$4({}, messages.missingLocaleError));
|
|
282
268
|
default:
|
|
283
269
|
return null;
|
|
284
270
|
}
|
|
@@ -373,7 +359,7 @@ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
|
|
|
373
359
|
function UnexpectedResourceTypeError(resourceType) {
|
|
374
360
|
var _this;
|
|
375
361
|
_classCallCheck(this, UnexpectedResourceTypeError);
|
|
376
|
-
_this = _super.call(this, "Unexpected resource type
|
|
362
|
+
_this = _super.call(this, "Unexpected resource type \"".concat(resourceType, "\""));
|
|
377
363
|
_this.name = 'UnexpectedResourceTypeError';
|
|
378
364
|
return _this;
|
|
379
365
|
}
|
|
@@ -403,41 +389,50 @@ function useExportResourcesContext() {
|
|
|
403
389
|
return context;
|
|
404
390
|
}
|
|
405
391
|
|
|
392
|
+
function checkAtLeastOneFieldChecked$1(fields) {
|
|
393
|
+
return _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
394
|
+
if (field.fields) {
|
|
395
|
+
return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
|
|
396
|
+
}
|
|
397
|
+
return field.isChecked;
|
|
398
|
+
});
|
|
399
|
+
}
|
|
406
400
|
function validate(_ref) {
|
|
407
401
|
let values = _valuesInstanceProperty__default["default"](_ref),
|
|
408
402
|
step = _ref.step;
|
|
409
403
|
const fileName = values.fileName,
|
|
410
404
|
locales = values.locales,
|
|
411
|
-
|
|
412
|
-
customFields = values.customFields;
|
|
405
|
+
groups = values.groups;
|
|
413
406
|
const errors = {
|
|
414
407
|
fileName: {},
|
|
415
408
|
locales: {},
|
|
416
409
|
fields: {}
|
|
417
410
|
};
|
|
418
411
|
if (uiKit.TextInput.isEmpty(fileName)) {
|
|
412
|
+
// @ts-ignore
|
|
419
413
|
errors.fileName.missing = true;
|
|
420
414
|
} else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
|
|
415
|
+
// @ts-ignore
|
|
421
416
|
errors.fileName.invalidInput = true;
|
|
422
417
|
}
|
|
423
418
|
if (locales.length < 1) {
|
|
419
|
+
// @ts-ignore
|
|
424
420
|
errors.locales.missing = true;
|
|
425
421
|
}
|
|
426
422
|
if (step === 2) {
|
|
427
|
-
const
|
|
428
|
-
const
|
|
429
|
-
|
|
430
|
-
return
|
|
431
|
-
}
|
|
432
|
-
if (
|
|
423
|
+
const allFields = _reduceInstanceProperty__default["default"](groups).call(groups, (acc, group) => _concatInstanceProperty__default["default"](acc).call(acc, group.fields), []);
|
|
424
|
+
const checkedFieldsCount = _filterInstanceProperty__default["default"](allFields).call(allFields, field => {
|
|
425
|
+
if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
|
|
426
|
+
return !field.isRequired && !field.isReadOnly && field.isChecked;
|
|
427
|
+
}).length;
|
|
428
|
+
if (checkedFieldsCount < 1) {
|
|
429
|
+
// @ts-ignore
|
|
433
430
|
errors.fields.missing = true;
|
|
434
431
|
}
|
|
435
432
|
}
|
|
436
433
|
return omitEmpty__default["default"](errors);
|
|
437
434
|
}
|
|
438
435
|
|
|
439
|
-
function ownKeys$5(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; }
|
|
440
|
-
function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context8, _context9; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context8 = ownKeys$5(Object(t), !0)).call(_context8, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context9 = ownKeys$5(Object(t))).call(_context9, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
441
436
|
function resourceTypeToDisplayName(_ref) {
|
|
442
437
|
let resourceType = _ref.resourceType,
|
|
443
438
|
_ref$isUpperCase = _ref.isUpperCase,
|
|
@@ -456,7 +451,7 @@ function resourceTypeToDisplayName(_ref) {
|
|
|
456
451
|
displayName = isPlural ? 'Discount codes' : 'Discount code';
|
|
457
452
|
break;
|
|
458
453
|
default:
|
|
459
|
-
throw UnexpectedResourceTypeError(resourceType);
|
|
454
|
+
throw new UnexpectedResourceTypeError(resourceType);
|
|
460
455
|
}
|
|
461
456
|
return isUpperCase ? displayName : displayName.toLowerCase();
|
|
462
457
|
}
|
|
@@ -475,84 +470,36 @@ function appendCsvOrJsonExtensionIfAbsent(fileName, fileFormat) {
|
|
|
475
470
|
if (!extensionRegex.test(fileName)) return _concatInstanceProperty__default["default"](_context = "".concat(fileName, ".")).call(_context, fileFormat);
|
|
476
471
|
return fileName;
|
|
477
472
|
}
|
|
478
|
-
function flattenNestedFields(fields) {
|
|
479
|
-
const result = (fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
480
|
-
if (isFilledArray(field.fields)) {
|
|
481
|
-
var _context2;
|
|
482
|
-
return _mapInstanceProperty__default["default"](_context2 = flattenNestedFields(field.fields)).call(_context2, nestedField => {
|
|
483
|
-
var _context3;
|
|
484
|
-
return _objectSpread$5(_objectSpread$5({}, nestedField), {}, {
|
|
485
|
-
name: _concatInstanceProperty__default["default"](_context3 = "".concat(field.name, ".")).call(_context3, nestedField.name)
|
|
486
|
-
});
|
|
487
|
-
});
|
|
488
|
-
}
|
|
489
|
-
return field;
|
|
490
|
-
})) || [];
|
|
491
|
-
return _flatInstanceProperty__default["default"](result).call(result);
|
|
492
|
-
}
|
|
493
|
-
function getSelectedGeneralFields(fields) {
|
|
494
|
-
return _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked);
|
|
495
|
-
}
|
|
496
|
-
function getSelectedCustomFields(customFields) {
|
|
497
|
-
return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
498
|
-
var _context4;
|
|
499
|
-
return _objectSpread$5(_objectSpread$5({}, customType), {}, {
|
|
500
|
-
fields: _filterInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => field.isChecked)
|
|
501
|
-
});
|
|
502
|
-
});
|
|
503
|
-
}
|
|
504
|
-
function checkRequiredFields(fields) {
|
|
505
|
-
return _mapInstanceProperty__default["default"](fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
|
|
506
|
-
isChecked: true
|
|
507
|
-
}) : field);
|
|
508
|
-
}
|
|
509
473
|
function getExportLogsLink(projectKey, msg) {
|
|
510
474
|
return jsxRuntime.jsx(uiKit.Link, {
|
|
511
475
|
to: "/".concat(projectKey, "/operations/export/logs"),
|
|
512
476
|
children: msg
|
|
513
477
|
});
|
|
514
478
|
}
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
fields: _mapInstanceProperty__default["default"](_context5 = customType.fields).call(_context5, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
|
|
520
|
-
isChecked: false
|
|
521
|
-
}))
|
|
522
|
-
});
|
|
523
|
-
});
|
|
524
|
-
}
|
|
525
|
-
function extractGeneralFieldNames(generalFields) {
|
|
526
|
-
return _mapInstanceProperty__default["default"](generalFields).call(generalFields, field => field.name);
|
|
527
|
-
}
|
|
528
|
-
function extractCustomFieldNamesWithPrefix(customFields) {
|
|
529
|
-
const fields = _flatMapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
530
|
-
var _context6;
|
|
531
|
-
return _flatMapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => {
|
|
532
|
-
return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
|
|
533
|
-
});
|
|
534
|
-
});
|
|
535
|
-
return [...new _Set__default["default"](fields)];
|
|
536
|
-
}
|
|
537
|
-
function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
|
|
538
|
-
const prefixes = _mapInstanceProperty__default["default"](resourceTypeIds).call(resourceTypeIds, type => {
|
|
539
|
-
switch (type) {
|
|
540
|
-
case 'asset':
|
|
541
|
-
return 'assets.custom.fields.';
|
|
542
|
-
default:
|
|
543
|
-
return 'custom.fields.';
|
|
479
|
+
const extractFieldNamesAndAdditionalFieldExtensions = fields => {
|
|
480
|
+
const result = _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
|
|
481
|
+
if (field.additionalFieldExtensions) {
|
|
482
|
+
return [...acc, ...field.additionalFieldExtensions, field.name];
|
|
544
483
|
}
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
484
|
+
return [...acc, field.name];
|
|
485
|
+
}, []);
|
|
486
|
+
return [...new _Set__default["default"](result)];
|
|
487
|
+
};
|
|
488
|
+
function sortFieldsByFieldOrder(_ref2) {
|
|
489
|
+
let fields = _ref2.fields,
|
|
490
|
+
fieldOrder = _ref2.fieldOrder;
|
|
491
|
+
if (isFilledArray(fieldOrder)) {
|
|
492
|
+
return _sortInstanceProperty__default["default"](fields).call(fields, (a, b) => {
|
|
493
|
+
let orderA = _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, a) !== -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, a) : _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, a.split('.')[0]);
|
|
494
|
+
let orderB = _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, b) !== -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, b) : _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, b.split('.')[0]);
|
|
551
495
|
|
|
552
|
-
//
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
496
|
+
// If a field is not 'custom',then consider it as '*'
|
|
497
|
+
orderA = orderA === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderA;
|
|
498
|
+
orderB = orderB === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderB;
|
|
499
|
+
return orderA - orderB;
|
|
500
|
+
});
|
|
501
|
+
}
|
|
502
|
+
return fields;
|
|
556
503
|
}
|
|
557
504
|
|
|
558
505
|
// TODO: remove this function when filters are passed directly from parent views
|
|
@@ -565,71 +512,69 @@ function tmpBuildFilters(selectedResourceIds) {
|
|
|
565
512
|
return ["id in (".concat(formattedIds, ")")];
|
|
566
513
|
}
|
|
567
514
|
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
const
|
|
571
|
-
const
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
default: defaultFieldExtension,
|
|
592
|
-
category: categoryFieldExtension
|
|
515
|
+
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; }
|
|
516
|
+
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; }
|
|
517
|
+
const updateFieldGroupsWithIsCheckedValue = groups => {
|
|
518
|
+
const updateFields = (fields, parentChecked) => {
|
|
519
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
520
|
+
var _field$isRequired;
|
|
521
|
+
let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
|
|
522
|
+
if (field.fields) {
|
|
523
|
+
const updatedFields = updateFields(field.fields, isChecked);
|
|
524
|
+
isChecked = false;
|
|
525
|
+
field.fields = updatedFields;
|
|
526
|
+
}
|
|
527
|
+
return _objectSpread$3(_objectSpread$3({}, field), {}, {
|
|
528
|
+
isChecked
|
|
529
|
+
});
|
|
530
|
+
});
|
|
531
|
+
};
|
|
532
|
+
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
533
|
+
const updatedFields = updateFields(group.fields, false);
|
|
534
|
+
return _objectSpread$3(_objectSpread$3({}, group), {}, {
|
|
535
|
+
fields: updatedFields
|
|
536
|
+
});
|
|
537
|
+
});
|
|
593
538
|
};
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
539
|
+
const updateFieldGroupWithAdditionalFieldExtensions = groups => {
|
|
540
|
+
function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
|
|
541
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
542
|
+
const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
|
|
543
|
+
if (field.fields) {
|
|
544
|
+
field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
|
|
545
|
+
}
|
|
546
|
+
return _objectSpread$3(_objectSpread$3({}, field), {}, {
|
|
547
|
+
additionalFieldExtensions: updatedAdditionalFieldExtensions
|
|
548
|
+
});
|
|
549
|
+
});
|
|
550
|
+
}
|
|
551
|
+
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
552
|
+
return _objectSpread$3(_objectSpread$3({}, group), {}, {
|
|
553
|
+
fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
|
|
554
|
+
});
|
|
555
|
+
});
|
|
600
556
|
};
|
|
601
557
|
|
|
602
|
-
const _excluded = ["isSelectedByDefault"];
|
|
603
|
-
function ownKeys$4(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; }
|
|
604
|
-
function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys$4(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys$4(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
605
558
|
const useInitialValues = props => {
|
|
606
|
-
var _context;
|
|
607
559
|
const todayFormatted = moment__default["default"]().format('DD-MM-YY_HH-mm');
|
|
608
560
|
const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
|
|
609
561
|
locale: applicationContext.dataLocale
|
|
610
562
|
})),
|
|
611
563
|
locale = _useApplicationContex.locale;
|
|
612
|
-
const
|
|
613
|
-
let isSelectedByDefault = _ref.isSelectedByDefault,
|
|
614
|
-
field = _objectWithoutProperties(_ref, _excluded);
|
|
615
|
-
return _objectSpread$4(_objectSpread$4({}, field), {}, {
|
|
616
|
-
isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
|
|
617
|
-
});
|
|
618
|
-
});
|
|
564
|
+
const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
|
|
619
565
|
return React__default["default"].useMemo(() => {
|
|
620
|
-
var
|
|
566
|
+
var _context;
|
|
621
567
|
return {
|
|
622
568
|
outputFormat: props.outputFormat,
|
|
623
|
-
fileName: _concatInstanceProperty__default["default"](
|
|
569
|
+
fileName: _concatInstanceProperty__default["default"](_context = "".concat(resourceTypeToDisplayName({
|
|
624
570
|
resourceType: props.resourceType,
|
|
625
571
|
isUpperCase: true,
|
|
626
572
|
isPlural: true
|
|
627
|
-
}), "_Export_")).call(
|
|
573
|
+
}), "_Export_")).call(_context, todayFormatted),
|
|
628
574
|
locales: [locale],
|
|
629
|
-
|
|
630
|
-
customFields: setInitialCheckedStateForCustomFields(props.customFields)
|
|
575
|
+
groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
|
|
631
576
|
};
|
|
632
|
-
}, [props, locale, todayFormatted,
|
|
577
|
+
}, [props, locale, todayFormatted, groups]);
|
|
633
578
|
};
|
|
634
579
|
|
|
635
580
|
async function createExportOperation(_ref) {
|
|
@@ -644,6 +589,7 @@ async function createExportOperation(_ref) {
|
|
|
644
589
|
const uri = "/proxy/export/".concat(projectKey, "/export-operations");
|
|
645
590
|
const response = await asyncDispatchFn(sdk.actions.post({
|
|
646
591
|
// FIXME: EXPORT is undefined
|
|
592
|
+
// @ts-ignore
|
|
647
593
|
mcApiProxyTarget: constants.MC_API_PROXY_TARGETS.EXPORT,
|
|
648
594
|
uri: uri,
|
|
649
595
|
headers: {
|
|
@@ -674,12 +620,29 @@ const useStartExportOperation = props => {
|
|
|
674
620
|
};
|
|
675
621
|
}),
|
|
676
622
|
projectKey = _useApplicationContex.projectKey;
|
|
623
|
+
const extractFieldsFromGroups = groups => {
|
|
624
|
+
let selectedGeneralFields = [];
|
|
625
|
+
const getSelectedFields = fields => {
|
|
626
|
+
return _filterInstanceProperty__default["default"](fields).call(fields, field => {
|
|
627
|
+
var _field$isChecked;
|
|
628
|
+
if (field.fields) {
|
|
629
|
+
return getSelectedFields(field.fields);
|
|
630
|
+
}
|
|
631
|
+
if (field.isChecked) selectedGeneralFields.push(field);
|
|
632
|
+
return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
|
|
633
|
+
});
|
|
634
|
+
};
|
|
635
|
+
_forEachInstanceProperty__default["default"](groups).call(groups, group => {
|
|
636
|
+
getSelectedFields(group.fields);
|
|
637
|
+
});
|
|
638
|
+
return sortFieldsByFieldOrder({
|
|
639
|
+
fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
|
|
640
|
+
fieldOrder: props.fieldOrder
|
|
641
|
+
});
|
|
642
|
+
};
|
|
677
643
|
const startExportOperation = async values => {
|
|
678
644
|
try {
|
|
679
|
-
const
|
|
680
|
-
const selectedCustomFields = getSelectedCustomFields(values.customFields);
|
|
681
|
-
const generalFields = extractGeneralFieldNames(selectedGeneralFields);
|
|
682
|
-
const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
|
|
645
|
+
const fields = extractFieldsFromGroups(values.groups);
|
|
683
646
|
const filters = tmpBuildFilters(props.selectedResourceIds);
|
|
684
647
|
const response = await createExportOperation({
|
|
685
648
|
projectKey,
|
|
@@ -687,10 +650,7 @@ const useStartExportOperation = props => {
|
|
|
687
650
|
fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
|
|
688
651
|
fileFormat: values.outputFormat,
|
|
689
652
|
locales: values.locales,
|
|
690
|
-
fields
|
|
691
|
-
resourceType: props.resourceType,
|
|
692
|
-
fields: [...generalFields, ...customFields]
|
|
693
|
-
}),
|
|
653
|
+
fields,
|
|
694
654
|
filters,
|
|
695
655
|
asyncDispatchFn: asyncDispatch
|
|
696
656
|
});
|
|
@@ -700,6 +660,7 @@ const useStartExportOperation = props => {
|
|
|
700
660
|
showNotification({
|
|
701
661
|
kind: 'info',
|
|
702
662
|
domain: constants.DOMAINS.SIDE,
|
|
663
|
+
// @ts-ignore
|
|
703
664
|
text: intl.formatMessage(messages.exportOperationSuccessMessage, {
|
|
704
665
|
newline: getNewLine,
|
|
705
666
|
logsLink: msg => getExportLogsLink(projectKey, msg),
|
|
@@ -729,8 +690,8 @@ const useStartExportOperation = props => {
|
|
|
729
690
|
};
|
|
730
691
|
};
|
|
731
692
|
|
|
732
|
-
function ownKeys$
|
|
733
|
-
function _objectSpread$
|
|
693
|
+
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; }
|
|
694
|
+
function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$2(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$2(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
734
695
|
function ExportTextMessage() {
|
|
735
696
|
const intl = reactIntl.useIntl();
|
|
736
697
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
@@ -758,7 +719,7 @@ function ExportTextMessage() {
|
|
|
758
719
|
}
|
|
759
720
|
return jsxRuntime.jsx(uiKit.Text.Body, {
|
|
760
721
|
"data-testid": "export-description",
|
|
761
|
-
intlMessage: _objectSpread$
|
|
722
|
+
intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
|
|
762
723
|
values: {
|
|
763
724
|
count: intl.formatNumber(count),
|
|
764
725
|
resourceType: resourceTypePlural,
|
|
@@ -893,20 +854,161 @@ const NoSearchResults = () => {
|
|
|
893
854
|
});
|
|
894
855
|
};
|
|
895
856
|
|
|
896
|
-
function ownKeys$
|
|
897
|
-
function _objectSpread$
|
|
857
|
+
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; }
|
|
858
|
+
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context7, _context8; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context7 = ownKeys$1(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$1(Object(t))).call(_context8, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
898
859
|
const StyledGroupCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
899
|
-
target: "
|
|
860
|
+
target: "e3xiyhb1"
|
|
900
861
|
} : {
|
|
901
|
-
target: "
|
|
862
|
+
target: "e3xiyhb1",
|
|
902
863
|
label: "StyledGroupCard"
|
|
903
|
-
})("border-right:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";background-color:", uiKit.designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledGroupCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA8BO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\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            formik.setFieldValue(\n              'customFields',\n              formik.values.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                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.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"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAsBoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\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            formik.setFieldValue(\n              'customFields',\n              formik.values.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                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.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"]} */"));
|
|
864
|
+
})("border-right:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";background-color:", uiKit.designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledGroupCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AAgCO","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </Card>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AAwBiE","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </Card>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"));
|
|
904
865
|
const StyledFieldsCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
905
|
-
target: "
|
|
866
|
+
target: "e3xiyhb0"
|
|
906
867
|
} : {
|
|
907
|
-
target: "
|
|
868
|
+
target: "e3xiyhb0",
|
|
908
869
|
label: "StyledFieldsCard"
|
|
909
|
-
})("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledFieldsCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAuCO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\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            formik.setFieldValue(\n              'customFields',\n              formik.values.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                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.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"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmCqC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\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            formik.setFieldValue(\n              'customFields',\n              formik.values.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                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.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"]} */"));
|
|
870
|
+
})("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledFieldsCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AA0CO","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </Card>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.tsx"],"names":[],"mappings":"AAsCkE","file":"export-fields-selection-step.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport get from 'lodash/get'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\nimport { FieldGroup, FormikField } from '@types'\n\nconst StyledGroupCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nconst StyledFieldsCard = styled(Card)<{ showTopBorder?: boolean }>`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\ninterface FilteredField extends FormikField {\n  isHidden?: boolean\n}\ninterface FilteredGroups extends FieldGroup {\n  isHidden?: boolean\n  fields: FilteredField[]\n}\n\ntype FieldSectionsProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: any\n  isAnySiblingChecked: boolean\n}\n\nconst FieldSections = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n}: FieldSectionsProps) => {\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const isAtleastOneChildChecked = () => {\n          function checkAtLeastOneFieldChecked(fields): boolean {\n            return fields?.some((field) => {\n              if (field.fields) {\n                return (\n                  field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n                )\n              }\n              return field.isChecked\n            })\n          }\n\n          return checkAtLeastOneFieldChecked(field.fields)\n        }\n        const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked()\n        if (field.isHidden) return null\n        return (\n          <React.Fragment key={`${field.name}-${index}`}>\n            <CheckboxInput\n              isChecked={\n                field.isReadOnly\n                  ? isAnySiblingChecked\n                  : isAnyOfTheChildFieldsChecked || field.isChecked\n              }\n              isReadOnly={field.isReadOnly || field.isRequired}\n              onChange={(e) => {\n                const path = `${parentKeys.join('.')}.fields[${index}]`\n                // Update all child fields\n                const updateAllChildFieldsChecked = (\n                  path: string,\n                  checked: boolean\n                ) => {\n                  const item = get(formik.values, path)\n                  if (item && item.fields) {\n                    item.fields.forEach((field, i) => {\n                      const fieldPath = `${path}.fields[${i}]`\n                      if (!field.fields?.length) {\n                        formik.setFieldValue(\n                          `${fieldPath}.isChecked`,\n                          checked,\n                          // pass `false` to avoid revalidating the form with intermediate values\n                          false\n                        )\n                      }\n                      updateAllChildFieldsChecked(fieldPath, checked)\n                    })\n                  }\n                }\n                if (!field.fields?.length) {\n                  formik.setFieldValue(\n                    `${path}.isChecked`,\n                    e.target.checked,\n                    // pass `false` to avoid revalidating the form with intermediate values\n                    false\n                  )\n                }\n                updateAllChildFieldsChecked(path, e.target.checked)\n              }}\n            >\n              {field.label} {field.isRequired && '*'}\n            </CheckboxInput>\n            {field.fields && field.fields?.length > 0 && (\n              <Spacings.Inline scale=\"l\">\n                <div />\n                <FieldSections\n                  fields={field.fields}\n                  formik={formik}\n                  parentKeys={[...parentKeys, `fields[${index}]`]}\n                  isAnySiblingChecked={isAnySiblingChecked}\n                />\n              </Spacings.Inline>\n            )}\n          </React.Fragment>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n\ntype FieldGroupSectionProps = {\n  index: number\n  group: FilteredGroups\n  formik: any\n}\n\nfunction checkAllFieldsSelected(fields): boolean {\n  return fields.every((field) => {\n    if (field.fields) {\n      return checkAllFieldsSelected(field.fields)\n    }\n    return field.isChecked || field.isRequired || field.isReadOnly\n  })\n}\n\nfunction checkAtLeastOneFieldChecked(fields): boolean {\n  return fields.some((field) => {\n    if (field.fields) {\n      return field.isChecked || checkAtLeastOneFieldChecked(field.fields)\n    }\n    return field.isChecked\n  })\n}\n\nconst FieldGroupSection = ({\n  group,\n  index,\n  formik,\n}: FieldGroupSectionProps) => {\n  const allAllFieldsSelected = React.useMemo(\n    () => checkAllFieldsSelected(group.fields),\n    [group.fields]\n  )\n\n  const isAtleastOneFieldChecked = React.useMemo(\n    () => checkAtLeastOneFieldChecked(group.fields),\n    [group.fields]\n  )\n\n  const parentKey = `groups[${index}]`\n\n  const handleChangeAllFields = (e) => {\n    const item = get(formik.values, parentKey)\n    function updateAllFields(fields, checked) {\n      return fields.map((field) => {\n        if (field.fields) {\n          return {\n            ...field,\n            fields: updateAllFields(field.fields, checked),\n          }\n        }\n        if (field.isReadOnly || field.isRequired) return field\n        return {\n          ...field,\n          isChecked: checked,\n        }\n      })\n    }\n\n    formik.setFieldValue(parentKey, {\n      ...item,\n      fields: updateAllFields(item.fields, e.target.checked),\n    })\n  }\n\n  if (group.isHidden) return null\n  return (\n    <>\n      <Grid.Item>\n        <StyledGroupCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <CheckboxInput\n            isIndeterminate={!allAllFieldsSelected && isAtleastOneFieldChecked}\n            isChecked={allAllFieldsSelected}\n            onChange={handleChangeAllFields}\n          >\n            {group.groupLabel}\n          </CheckboxInput>\n        </StyledGroupCard>\n      </Grid.Item>\n      <Grid.Item>\n        <StyledFieldsCard type=\"flat\" insetScale=\"l\" showTopBorder={true}>\n          <Spacings.Stack scale=\"s\">\n            <FieldSections\n              fields={group.fields}\n              formik={formik}\n              parentKeys={[parentKey]}\n              isAnySiblingChecked={isAtleastOneFieldChecked}\n            />\n          </Spacings.Stack>\n        </StyledFieldsCard>\n      </Grid.Item>\n    </>\n  )\n}\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n\n  React.useEffect(() => {\n    formik.validateForm()\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [formik.values.groups])\n  // adds `isHidden` property to each field based on search term\n  const filteredGroups = React.useMemo(() => {\n    const updateFields = (fields, parentMatches: boolean) => {\n      return fields.map((field) => {\n        const matches = field.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.toLowerCase())\n        let isHidden = !matches && !parentMatches\n        if (field.fields) {\n          const updatedFields = updateFields(field.fields, matches)\n          isHidden = isHidden && updatedFields.every((f) => f.isHidden)\n          field = {\n            ...field,\n            fields: updatedFields,\n          }\n        }\n        return { ...field, isHidden }\n      })\n    }\n    if (!fieldSearchTerm?.trim()?.length) return formik.values.groups\n\n    return formik.values.groups.map((group) => {\n      const updatedFields = updateFields(group.fields, false)\n      const isHidden = updatedFields.every((field) => field.isHidden)\n      return { ...group, fields: updatedFields, isHidden }\n    })\n  }, [formik.values.groups, fieldSearchTerm])\n\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n\n  const hasResults = Boolean(filteredGroups.find((group) => !group.isHidden))\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n            // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n            onSubmit={() => {}}\n          />\n          {hasResults ? (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGroups.map((group, index) => (\n                  <FieldGroupSection\n                    key={group.groupLabel}\n                    group={group}\n                    index={index}\n                    formik={formik}\n                  />\n                ))}\n              </Grid>\n            </Card>\n          ) : (\n            <NoSearchResults />\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n"]} */"));
|
|
871
|
+
const FieldSections = _ref => {
|
|
872
|
+
let fields = _ref.fields,
|
|
873
|
+
parentKeys = _ref.parentKeys,
|
|
874
|
+
formik = _ref.formik,
|
|
875
|
+
isAnySiblingChecked = _ref.isAnySiblingChecked;
|
|
876
|
+
return jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
877
|
+
scale: "s",
|
|
878
|
+
children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, (field, index) => {
|
|
879
|
+
var _context, _field$fields3;
|
|
880
|
+
const isAtleastOneChildChecked = () => {
|
|
881
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
882
|
+
return fields === null || fields === void 0 ? void 0 : _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
883
|
+
if (field.fields) {
|
|
884
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
885
|
+
}
|
|
886
|
+
return field.isChecked;
|
|
887
|
+
});
|
|
888
|
+
}
|
|
889
|
+
return checkAtLeastOneFieldChecked(field.fields);
|
|
890
|
+
};
|
|
891
|
+
const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
|
|
892
|
+
if (field.isHidden) return null;
|
|
893
|
+
return jsxRuntime.jsxs(React__default["default"].Fragment, {
|
|
894
|
+
children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
895
|
+
isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
|
|
896
|
+
isReadOnly: field.isReadOnly || field.isRequired,
|
|
897
|
+
onChange: e => {
|
|
898
|
+
var _context2, _field$fields2;
|
|
899
|
+
const path = _concatInstanceProperty__default["default"](_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
|
|
900
|
+
// Update all child fields
|
|
901
|
+
const updateAllChildFieldsChecked = (path, checked) => {
|
|
902
|
+
const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), path);
|
|
903
|
+
if (item && item.fields) {
|
|
904
|
+
var _context3;
|
|
905
|
+
_forEachInstanceProperty__default["default"](_context3 = item.fields).call(_context3, (field, i) => {
|
|
906
|
+
var _context4, _field$fields;
|
|
907
|
+
const fieldPath = _concatInstanceProperty__default["default"](_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
|
|
908
|
+
if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
|
|
909
|
+
formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
|
|
910
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
911
|
+
false);
|
|
912
|
+
}
|
|
913
|
+
updateAllChildFieldsChecked(fieldPath, checked);
|
|
914
|
+
});
|
|
915
|
+
}
|
|
916
|
+
};
|
|
917
|
+
if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
|
|
918
|
+
formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
|
|
919
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
920
|
+
false);
|
|
921
|
+
}
|
|
922
|
+
updateAllChildFieldsChecked(path, e.target.checked);
|
|
923
|
+
},
|
|
924
|
+
children: [field.label, " ", field.isRequired && '*']
|
|
925
|
+
}), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxRuntime.jsxs(uiKit.Spacings.Inline, {
|
|
926
|
+
scale: "l",
|
|
927
|
+
children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(FieldSections, {
|
|
928
|
+
fields: field.fields,
|
|
929
|
+
formik: formik,
|
|
930
|
+
parentKeys: [...parentKeys, "fields[".concat(index, "]")],
|
|
931
|
+
isAnySiblingChecked: isAnySiblingChecked
|
|
932
|
+
})]
|
|
933
|
+
})]
|
|
934
|
+
}, _concatInstanceProperty__default["default"](_context = "".concat(field.name, "-")).call(_context, index));
|
|
935
|
+
})
|
|
936
|
+
});
|
|
937
|
+
};
|
|
938
|
+
function checkAllFieldsSelected(fields) {
|
|
939
|
+
return _everyInstanceProperty__default["default"](fields).call(fields, field => {
|
|
940
|
+
if (field.fields) {
|
|
941
|
+
return checkAllFieldsSelected(field.fields);
|
|
942
|
+
}
|
|
943
|
+
return field.isChecked || field.isRequired || field.isReadOnly;
|
|
944
|
+
});
|
|
945
|
+
}
|
|
946
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
947
|
+
return _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
948
|
+
if (field.fields) {
|
|
949
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
950
|
+
}
|
|
951
|
+
return field.isChecked;
|
|
952
|
+
});
|
|
953
|
+
}
|
|
954
|
+
const FieldGroupSection = _ref2 => {
|
|
955
|
+
let group = _ref2.group,
|
|
956
|
+
index = _ref2.index,
|
|
957
|
+
formik = _ref2.formik;
|
|
958
|
+
const allAllFieldsSelected = React__default["default"].useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
|
|
959
|
+
const isAtleastOneFieldChecked = React__default["default"].useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
|
|
960
|
+
const parentKey = "groups[".concat(index, "]");
|
|
961
|
+
const handleChangeAllFields = e => {
|
|
962
|
+
const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), parentKey);
|
|
963
|
+
function updateAllFields(fields, checked) {
|
|
964
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
965
|
+
if (field.fields) {
|
|
966
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
967
|
+
fields: updateAllFields(field.fields, checked)
|
|
968
|
+
});
|
|
969
|
+
}
|
|
970
|
+
if (field.isReadOnly || field.isRequired) return field;
|
|
971
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
972
|
+
isChecked: checked
|
|
973
|
+
});
|
|
974
|
+
});
|
|
975
|
+
}
|
|
976
|
+
formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
|
|
977
|
+
fields: updateAllFields(item.fields, e.target.checked)
|
|
978
|
+
}));
|
|
979
|
+
};
|
|
980
|
+
if (group.isHidden) return null;
|
|
981
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
982
|
+
children: [jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
983
|
+
children: jsxRuntime.jsx(StyledGroupCard, {
|
|
984
|
+
type: "flat",
|
|
985
|
+
insetScale: "l",
|
|
986
|
+
showTopBorder: true,
|
|
987
|
+
children: jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
988
|
+
isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
|
|
989
|
+
isChecked: allAllFieldsSelected,
|
|
990
|
+
onChange: handleChangeAllFields,
|
|
991
|
+
children: group.groupLabel
|
|
992
|
+
})
|
|
993
|
+
})
|
|
994
|
+
}), jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
995
|
+
children: jsxRuntime.jsx(StyledFieldsCard, {
|
|
996
|
+
type: "flat",
|
|
997
|
+
insetScale: "l",
|
|
998
|
+
showTopBorder: true,
|
|
999
|
+
children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
1000
|
+
scale: "s",
|
|
1001
|
+
children: jsxRuntime.jsx(FieldSections, {
|
|
1002
|
+
fields: group.fields,
|
|
1003
|
+
formik: formik,
|
|
1004
|
+
parentKeys: [parentKey],
|
|
1005
|
+
isAnySiblingChecked: isAtleastOneFieldChecked
|
|
1006
|
+
})
|
|
1007
|
+
})
|
|
1008
|
+
})
|
|
1009
|
+
})]
|
|
1010
|
+
});
|
|
1011
|
+
};
|
|
910
1012
|
const ExportFieldsSelectionStep = () => {
|
|
911
1013
|
const intl = reactIntl.useIntl();
|
|
912
1014
|
const _React$useState = React__default["default"].useState(''),
|
|
@@ -922,47 +1024,44 @@ const ExportFieldsSelectionStep = () => {
|
|
|
922
1024
|
resourceType: resourceType,
|
|
923
1025
|
isPlural: true
|
|
924
1026
|
});
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
}, [_valuesInstanceProperty__default["default"](formik).
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
return _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
|
|
948
|
-
});
|
|
949
|
-
}, [_valuesInstanceProperty__default["default"](formik).fields, fieldSearchTerm]);
|
|
950
|
-
const filteredCustomFields = React__default["default"].useMemo(() => {
|
|
951
|
-
var _context6, _context7;
|
|
952
|
-
return _filterInstanceProperty__default["default"](_context6 = _mapInstanceProperty__default["default"](_context7 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context7, customType => {
|
|
953
|
-
var _context8, _context9;
|
|
954
|
-
return _objectSpread$2(_objectSpread$2({}, customType), {}, {
|
|
955
|
-
fields: _includesInstanceProperty__default["default"](_context8 = customType.type.label.toLowerCase()).call(_context8, _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm).toLowerCase()) ? customType.fields : _filterInstanceProperty__default["default"](_context9 = customType.fields).call(_context9, field => {
|
|
956
|
-
var _context10;
|
|
957
|
-
return _includesInstanceProperty__default["default"](_context10 = field.label.toLowerCase()).call(_context10, _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
|
|
958
|
-
})
|
|
1027
|
+
React__default["default"].useEffect(() => {
|
|
1028
|
+
formik.validateForm();
|
|
1029
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
1030
|
+
}, [_valuesInstanceProperty__default["default"](formik).groups]);
|
|
1031
|
+
// adds `isHidden` property to each field based on search term
|
|
1032
|
+
const filteredGroups = React__default["default"].useMemo(() => {
|
|
1033
|
+
var _fieldSearchTerm$trim, _context6;
|
|
1034
|
+
const updateFields = (fields, parentMatches) => {
|
|
1035
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1036
|
+
var _context5;
|
|
1037
|
+
const matches = _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
|
|
1038
|
+
let isHidden = !matches && !parentMatches;
|
|
1039
|
+
if (field.fields) {
|
|
1040
|
+
const updatedFields = updateFields(field.fields, matches);
|
|
1041
|
+
isHidden = isHidden && _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, f => f.isHidden);
|
|
1042
|
+
field = _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
1043
|
+
fields: updatedFields
|
|
1044
|
+
});
|
|
1045
|
+
}
|
|
1046
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
1047
|
+
isHidden
|
|
1048
|
+
});
|
|
959
1049
|
});
|
|
960
|
-
}
|
|
961
|
-
|
|
1050
|
+
};
|
|
1051
|
+
if (!(fieldSearchTerm !== null && fieldSearchTerm !== void 0 && (_fieldSearchTerm$trim = _trimInstanceProperty__default["default"](fieldSearchTerm).call(fieldSearchTerm)) !== null && _fieldSearchTerm$trim !== void 0 && _fieldSearchTerm$trim.length)) return _valuesInstanceProperty__default["default"](formik).groups;
|
|
1052
|
+
return _mapInstanceProperty__default["default"](_context6 = _valuesInstanceProperty__default["default"](formik).groups).call(_context6, group => {
|
|
1053
|
+
const updatedFields = updateFields(group.fields, false);
|
|
1054
|
+
const isHidden = _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, field => field.isHidden);
|
|
1055
|
+
return _objectSpread$1(_objectSpread$1({}, group), {}, {
|
|
1056
|
+
fields: updatedFields,
|
|
1057
|
+
isHidden
|
|
1058
|
+
});
|
|
1059
|
+
});
|
|
1060
|
+
}, [_valuesInstanceProperty__default["default"](formik).groups, fieldSearchTerm]);
|
|
962
1061
|
const onSearchChange = React__default["default"].useCallback(event => {
|
|
963
1062
|
setFieldSearchTerm(event.target.value);
|
|
964
1063
|
}, [setFieldSearchTerm]);
|
|
965
|
-
const hasResults =
|
|
1064
|
+
const hasResults = Boolean(_findInstanceProperty__default["default"](filteredGroups).call(filteredGroups, group => !group.isHidden));
|
|
966
1065
|
const onSearchChangeThrottled = React__default["default"].useMemo(() => throttle__default["default"](onSearchChange, 300), [onSearchChange]);
|
|
967
1066
|
const onSearchReset = () => {
|
|
968
1067
|
setFieldSearchTerm('');
|
|
@@ -998,157 +1097,25 @@ const ExportFieldsSelectionStep = () => {
|
|
|
998
1097
|
value: fieldSearchTerm,
|
|
999
1098
|
onChange: onSearchChangeThrottled,
|
|
1000
1099
|
onReset: onSearchReset
|
|
1001
|
-
|
|
1100
|
+
// TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
|
|
1101
|
+
,
|
|
1102
|
+
onSubmit: () => {}
|
|
1103
|
+
}), hasResults ? jsxRuntime.jsx(uiKit.Card, {
|
|
1002
1104
|
insetScale: "none",
|
|
1003
|
-
children: jsxRuntime.
|
|
1105
|
+
children: jsxRuntime.jsx(uiKit.Grid, {
|
|
1004
1106
|
gridAutoFlow: "row",
|
|
1005
1107
|
gridTemplateColumns: "".concat(uiKit.designTokens.constraint5, " auto"),
|
|
1006
|
-
children: [
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
children: jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1012
|
-
isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
|
|
1013
|
-
isChecked: areAllGeneralFieldsChecked,
|
|
1014
|
-
onChange: e => {
|
|
1015
|
-
var _context11;
|
|
1016
|
-
formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context11 = _valuesInstanceProperty__default["default"](formik).fields).call(_context11, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
1017
|
-
isChecked: field.isRequired ? true : e.target.checked
|
|
1018
|
-
})));
|
|
1019
|
-
},
|
|
1020
|
-
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allGeneralFields))
|
|
1021
|
-
})
|
|
1022
|
-
})
|
|
1023
|
-
}), jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1024
|
-
children: jsxRuntime.jsx(StyledFieldsCard, {
|
|
1025
|
-
type: "flat",
|
|
1026
|
-
insetScale: "l",
|
|
1027
|
-
children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
1028
|
-
scale: "s",
|
|
1029
|
-
children: jsxRuntime.jsx(GeneralFieldsSelection, {
|
|
1030
|
-
fields: filteredGeneralFields,
|
|
1031
|
-
formik: formik
|
|
1032
|
-
})
|
|
1033
|
-
})
|
|
1034
|
-
})
|
|
1035
|
-
})]
|
|
1036
|
-
}), filteredCustomFields.length > 0 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
1037
|
-
children: [jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1038
|
-
children: jsxRuntime.jsx(StyledGroupCard, {
|
|
1039
|
-
type: "flat",
|
|
1040
|
-
insetScale: "l",
|
|
1041
|
-
showTopBorder: filteredGeneralFields.length > 0,
|
|
1042
|
-
children: jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1043
|
-
isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
|
|
1044
|
-
isChecked: areAllCustomFieldsChecked,
|
|
1045
|
-
onChange: e => {
|
|
1046
|
-
var _context12;
|
|
1047
|
-
formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context12 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context12, customType => {
|
|
1048
|
-
var _context13;
|
|
1049
|
-
return _objectSpread$2(_objectSpread$2({}, customType), {}, {
|
|
1050
|
-
fields: _mapInstanceProperty__default["default"](_context13 = customType.fields).call(_context13, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
1051
|
-
isChecked: e.target.checked
|
|
1052
|
-
}))
|
|
1053
|
-
});
|
|
1054
|
-
}));
|
|
1055
|
-
},
|
|
1056
|
-
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
|
|
1057
|
-
})
|
|
1058
|
-
})
|
|
1059
|
-
}), jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1060
|
-
children: jsxRuntime.jsx(StyledFieldsCard, {
|
|
1061
|
-
type: "flat",
|
|
1062
|
-
insetScale: "l",
|
|
1063
|
-
showTopBorder: filteredGeneralFields.length > 0,
|
|
1064
|
-
children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
|
|
1065
|
-
scale: "s",
|
|
1066
|
-
children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
1067
|
-
isReadOnly: true,
|
|
1068
|
-
onChange: () => {},
|
|
1069
|
-
isChecked: isAtLeastOneCustomFieldChecked,
|
|
1070
|
-
children: [jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
|
|
1071
|
-
}), jsxRuntime.jsx(CustomFieldsSelection, {
|
|
1072
|
-
customFields: filteredCustomFields,
|
|
1073
|
-
formik: formik
|
|
1074
|
-
})]
|
|
1075
|
-
})
|
|
1076
|
-
})
|
|
1077
|
-
})]
|
|
1078
|
-
})]
|
|
1108
|
+
children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) => jsxRuntime.jsx(FieldGroupSection, {
|
|
1109
|
+
group: group,
|
|
1110
|
+
index: index,
|
|
1111
|
+
formik: formik
|
|
1112
|
+
}, group.groupLabel))
|
|
1079
1113
|
})
|
|
1080
|
-
})]
|
|
1114
|
+
}) : jsxRuntime.jsx(NoSearchResults, {})]
|
|
1081
1115
|
})
|
|
1082
1116
|
})
|
|
1083
1117
|
});
|
|
1084
1118
|
};
|
|
1085
|
-
const GeneralFieldsSelection = _ref => {
|
|
1086
|
-
let fields = _ref.fields,
|
|
1087
|
-
formik = _ref.formik;
|
|
1088
|
-
return _mapInstanceProperty__default["default"](fields).call(fields, field => jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
1089
|
-
isChecked: field.isChecked,
|
|
1090
|
-
isReadOnly: field.isRequired,
|
|
1091
|
-
onChange: e => {
|
|
1092
|
-
var _context14;
|
|
1093
|
-
formik.setFieldValue('fields', _mapInstanceProperty__default["default"](_context14 = _valuesInstanceProperty__default["default"](formik).fields).call(_context14, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
1094
|
-
isChecked: e.target.checked
|
|
1095
|
-
}) : _field));
|
|
1096
|
-
},
|
|
1097
|
-
children: [field.label, " ", field.isRequired && '*']
|
|
1098
|
-
}, field.name));
|
|
1099
|
-
};
|
|
1100
|
-
const CustomFieldsSelection = _ref2 => {
|
|
1101
|
-
let customFields = _ref2.customFields,
|
|
1102
|
-
formik = _ref2.formik;
|
|
1103
|
-
return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
1104
|
-
var _context15, _context16, _context19;
|
|
1105
|
-
const areAllFieldsChecked = _everyInstanceProperty__default["default"](_context15 = customType.fields).call(_context15, field => field.isChecked);
|
|
1106
|
-
const isAtLeastOneFieldChecked = _someInstanceProperty__default["default"](_context16 = customType.fields).call(_context16, field => field.isChecked);
|
|
1107
|
-
return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
|
|
1108
|
-
scale: "s",
|
|
1109
|
-
children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1110
|
-
isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
|
|
1111
|
-
isChecked: areAllFieldsChecked,
|
|
1112
|
-
onChange: e => {
|
|
1113
|
-
var _context17;
|
|
1114
|
-
formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context17 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context17, _customType => {
|
|
1115
|
-
var _context18;
|
|
1116
|
-
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
1117
|
-
fields: _mapInstanceProperty__default["default"](_context18 = _customType.fields).call(_context18, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
1118
|
-
isChecked: e.target.checked
|
|
1119
|
-
}))
|
|
1120
|
-
}) : _customType;
|
|
1121
|
-
}));
|
|
1122
|
-
},
|
|
1123
|
-
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
1124
|
-
children: customType.type.label
|
|
1125
|
-
})
|
|
1126
|
-
}), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
|
|
1127
|
-
scale: "l",
|
|
1128
|
-
children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
1129
|
-
scale: "s",
|
|
1130
|
-
children: _mapInstanceProperty__default["default"](_context19 = customType.fields).call(_context19, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1131
|
-
isChecked: field.isChecked,
|
|
1132
|
-
onChange: e => {
|
|
1133
|
-
var _context20;
|
|
1134
|
-
formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context20 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context20, _customType => {
|
|
1135
|
-
var _context21;
|
|
1136
|
-
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
1137
|
-
fields: _mapInstanceProperty__default["default"](_context21 = _customType.fields).call(_context21, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
1138
|
-
isChecked: e.target.checked
|
|
1139
|
-
}) : _field)
|
|
1140
|
-
}) : _customType;
|
|
1141
|
-
}));
|
|
1142
|
-
},
|
|
1143
|
-
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
1144
|
-
children: field.label
|
|
1145
|
-
})
|
|
1146
|
-
}, field.name))
|
|
1147
|
-
})]
|
|
1148
|
-
})]
|
|
1149
|
-
}, customType.type.key);
|
|
1150
|
-
});
|
|
1151
|
-
};
|
|
1152
1119
|
|
|
1153
1120
|
process.env.NODE_ENV !== "production" ? {
|
|
1154
1121
|
renderProperties: PropTypes__default["default"].func
|
|
@@ -1156,42 +1123,6 @@ process.env.NODE_ENV !== "production" ? {
|
|
|
1156
1123
|
|
|
1157
1124
|
const ExportResourcesContext = /*#__PURE__*/React.createContext();
|
|
1158
1125
|
|
|
1159
|
-
const ExportResourcesModalShape = PropTypes__default["default"].shape({
|
|
1160
|
-
isOpen: PropTypes__default["default"].bool,
|
|
1161
|
-
resourceType: PropTypes__default["default"].string.isRequired,
|
|
1162
|
-
outputFormat: PropTypes__default["default"].string,
|
|
1163
|
-
onClose: PropTypes__default["default"].func,
|
|
1164
|
-
onExportSuccess: PropTypes__default["default"].func,
|
|
1165
|
-
totalResourcesCount: PropTypes__default["default"].number.isRequired,
|
|
1166
|
-
selectedResourceIds: PropTypes__default["default"].array,
|
|
1167
|
-
// TODO: Circular reference
|
|
1168
|
-
fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1169
|
-
name: PropTypes__default["default"].string.isRequired,
|
|
1170
|
-
label: PropTypes__default["default"].string,
|
|
1171
|
-
fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1172
|
-
name: PropTypes__default["default"].string.isRequired,
|
|
1173
|
-
label: PropTypes__default["default"].string,
|
|
1174
|
-
isSelectedByDefault: PropTypes__default["default"].bool,
|
|
1175
|
-
isRequired: PropTypes__default["default"].bool
|
|
1176
|
-
}))
|
|
1177
|
-
})).isRequired,
|
|
1178
|
-
customFields: PropTypes__default["default"].shape({
|
|
1179
|
-
type: PropTypes__default["default"].shape({
|
|
1180
|
-
key: PropTypes__default["default"].string.isRequired,
|
|
1181
|
-
label: PropTypes__default["default"].string.isRequired,
|
|
1182
|
-
resourceTypeIds: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string)
|
|
1183
|
-
}).isRequired,
|
|
1184
|
-
fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1185
|
-
name: PropTypes__default["default"].string.isRequired,
|
|
1186
|
-
label: PropTypes__default["default"].string
|
|
1187
|
-
})).isRequired
|
|
1188
|
-
}),
|
|
1189
|
-
exportType: PropTypes__default["default"].string,
|
|
1190
|
-
renderProperties: PropTypes__default["default"].func
|
|
1191
|
-
}).isRequired;
|
|
1192
|
-
|
|
1193
|
-
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; }
|
|
1194
|
-
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; }
|
|
1195
1126
|
const ExportResourcesProvider = props => {
|
|
1196
1127
|
const initialValues = useInitialValues(props);
|
|
1197
1128
|
const _useStartExportOperat = useStartExportOperation(props),
|
|
@@ -1232,10 +1163,6 @@ const ExportResourcesProvider = props => {
|
|
|
1232
1163
|
children: props.children
|
|
1233
1164
|
});
|
|
1234
1165
|
};
|
|
1235
|
-
ExportResourcesProvider.displayName = 'ExportResourcesProvider';
|
|
1236
|
-
ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
|
|
1237
|
-
children: PropTypes__default["default"].node
|
|
1238
|
-
}) : {};
|
|
1239
1166
|
|
|
1240
1167
|
const CurrentStep = () => {
|
|
1241
1168
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
@@ -1247,22 +1174,100 @@ const CurrentStep = () => {
|
|
|
1247
1174
|
return steps[currentStep] || null;
|
|
1248
1175
|
};
|
|
1249
1176
|
|
|
1177
|
+
const loadMessages = locale => {
|
|
1178
|
+
const intlLocale = i18n.mapLocaleToIntlLocale(locale);
|
|
1179
|
+
switch (intlLocale) {
|
|
1180
|
+
case 'de':
|
|
1181
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-de" */'./de-a34c5dd4.cjs.dev.js'); });
|
|
1182
|
+
case 'es':
|
|
1183
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-es" */'./es-8b3ecab1.cjs.dev.js'); });
|
|
1184
|
+
case 'fr-FR':
|
|
1185
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-fr-FR" */'./fr-FR-e7126fcc.cjs.dev.js'); });
|
|
1186
|
+
case 'zh-CN':
|
|
1187
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-zh-CN" */'./zh-CN-d4bc6d26.cjs.dev.js'); });
|
|
1188
|
+
case 'ja':
|
|
1189
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-ja" */'./ja-9bd5f452.cjs.dev.js'); });
|
|
1190
|
+
case 'pt-BR':
|
|
1191
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-ea6b3251.cjs.dev.js'); });
|
|
1192
|
+
default:
|
|
1193
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-en" */'./en-6b3694f6.cjs.dev.js'); });
|
|
1194
|
+
}
|
|
1195
|
+
};
|
|
1196
|
+
|
|
1197
|
+
// eslint-disable-next-line import/prefer-default-export
|
|
1198
|
+
const loadI18n = async locale => {
|
|
1199
|
+
try {
|
|
1200
|
+
const messages = await loadMessages(locale);
|
|
1201
|
+
return messages.default || messages;
|
|
1202
|
+
} catch (error) {
|
|
1203
|
+
// eslint-disable-next-line no-console
|
|
1204
|
+
console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
|
|
1205
|
+
sentry.reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
|
|
1206
|
+
extra: error
|
|
1207
|
+
});
|
|
1208
|
+
return {};
|
|
1209
|
+
}
|
|
1210
|
+
};
|
|
1211
|
+
|
|
1212
|
+
const useAsyncIntlMessages = (locale, loader) => {
|
|
1213
|
+
const _useState = React.useState({
|
|
1214
|
+
isLoading: true,
|
|
1215
|
+
messages: undefined,
|
|
1216
|
+
error: undefined
|
|
1217
|
+
}),
|
|
1218
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1219
|
+
state = _useState2[0],
|
|
1220
|
+
setState = _useState2[1];
|
|
1221
|
+
React.useEffect(() => {
|
|
1222
|
+
let _isUnmounting = false;
|
|
1223
|
+
async function load() {
|
|
1224
|
+
try {
|
|
1225
|
+
if (!_isUnmounting) {
|
|
1226
|
+
const messages = await loader(locale);
|
|
1227
|
+
setState({
|
|
1228
|
+
isLoading: false,
|
|
1229
|
+
messages
|
|
1230
|
+
});
|
|
1231
|
+
}
|
|
1232
|
+
} catch (error) {
|
|
1233
|
+
setState({
|
|
1234
|
+
isLoading: false,
|
|
1235
|
+
error
|
|
1236
|
+
});
|
|
1237
|
+
}
|
|
1238
|
+
}
|
|
1239
|
+
if (locale) load();
|
|
1240
|
+
return () => {
|
|
1241
|
+
_isUnmounting = true;
|
|
1242
|
+
};
|
|
1243
|
+
}, [locale, loader]);
|
|
1244
|
+
return state;
|
|
1245
|
+
};
|
|
1246
|
+
|
|
1250
1247
|
function ownKeys(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; }
|
|
1251
1248
|
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; }
|
|
1252
1249
|
const ExportResourcesModal = props => {
|
|
1253
|
-
|
|
1254
|
-
|
|
1255
|
-
|
|
1256
|
-
|
|
1250
|
+
const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
|
|
1251
|
+
locale: context.user && context.user.locale
|
|
1252
|
+
})),
|
|
1253
|
+
locale = _useApplicationContex.locale;
|
|
1254
|
+
const messages = useAsyncIntlMessages('en', loadI18n);
|
|
1255
|
+
if (!props.isOpen || messages.isLoading) return null;
|
|
1256
|
+
return jsxRuntime.jsx(reactIntl.IntlProvider, {
|
|
1257
|
+
locale: locale,
|
|
1258
|
+
messages: messages.messages,
|
|
1259
|
+
children: jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
|
|
1260
|
+
children: jsxRuntime.jsx(CurrentStep, {})
|
|
1261
|
+
}))
|
|
1262
|
+
});
|
|
1257
1263
|
};
|
|
1258
1264
|
ExportResourcesModal.displayName = 'ExportResourcesModal';
|
|
1259
|
-
ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
|
|
1260
1265
|
ExportResourcesModal.defaultProps = {
|
|
1261
1266
|
isOpen: false,
|
|
1262
1267
|
selectedResourceIds: [],
|
|
1263
1268
|
exportType: EXPORT_TYPES.ALL,
|
|
1264
1269
|
outputFormat: OUTPUT_FORMATS.CSV,
|
|
1265
|
-
|
|
1270
|
+
fieldGroups: []
|
|
1266
1271
|
};
|
|
1267
1272
|
|
|
1268
1273
|
exports.EXPORTABLE_RESOURCES = EXPORTABLE_RESOURCES;
|