@commercetools-frontend-extensions/export-resources-modal 3.6.0 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +166 -138
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.dev.js +517 -391
- package/dist/commercetools-frontend-extensions-export-resources-modal.cjs.prod.js +510 -387
- package/dist/commercetools-frontend-extensions-export-resources-modal.esm.js +508 -385
- 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/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 +31 -18
|
@@ -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,28 +25,37 @@ 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');
|
|
28
|
+
var React = require('react');
|
|
29
29
|
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
30
30
|
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
31
31
|
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
32
32
|
var moment = require('moment');
|
|
33
|
+
var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
|
|
33
34
|
var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
|
|
34
35
|
var omitEmpty = require('omit-empty-es');
|
|
35
36
|
var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
|
|
36
37
|
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
38
|
var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
|
|
39
39
|
var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
|
|
40
|
-
|
|
41
|
-
var
|
|
40
|
+
require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
|
|
41
|
+
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
42
|
+
var shared = require('@commercetools-local/shared');
|
|
42
43
|
var sdk = require('@commercetools-frontend/sdk');
|
|
43
44
|
var actionsGlobal = require('@commercetools-frontend/actions-global');
|
|
44
45
|
var constants = require('@commercetools-frontend/constants');
|
|
46
|
+
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
45
47
|
var _styled = require('@emotion/styled/base');
|
|
46
48
|
var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
|
|
47
|
-
var
|
|
49
|
+
var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
|
|
50
|
+
var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
|
|
51
|
+
var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
|
|
52
|
+
var throttle = require('lodash/throttle');
|
|
53
|
+
var react = require('@emotion/react');
|
|
54
|
+
var get = require('lodash/get');
|
|
48
55
|
var PropTypes = require('prop-types');
|
|
49
|
-
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
50
56
|
var formik = require('formik');
|
|
57
|
+
var sentry = require('@commercetools-frontend/sentry');
|
|
58
|
+
var i18n = require('@commercetools-frontend/i18n');
|
|
51
59
|
|
|
52
60
|
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
53
61
|
|
|
@@ -59,24 +67,27 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
|
|
|
59
67
|
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
60
68
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
61
69
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
62
|
-
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
63
70
|
var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
|
|
64
71
|
var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
|
|
72
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
65
73
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
66
74
|
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
67
75
|
var moment__default = /*#__PURE__*/_interopDefault(moment);
|
|
76
|
+
var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
|
|
68
77
|
var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
|
|
69
78
|
var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
|
|
70
79
|
var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
|
|
71
80
|
var _flatInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatInstanceProperty);
|
|
72
|
-
var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
|
|
73
81
|
var _Set__default = /*#__PURE__*/_interopDefault(_Set);
|
|
74
82
|
var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
|
|
75
|
-
var
|
|
76
|
-
var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
|
|
83
|
+
var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
|
|
77
84
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
78
85
|
var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
|
|
79
|
-
var
|
|
86
|
+
var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
|
|
87
|
+
var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
|
|
88
|
+
var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
|
|
89
|
+
var throttle__default = /*#__PURE__*/_interopDefault(throttle);
|
|
90
|
+
var get__default = /*#__PURE__*/_interopDefault(get);
|
|
80
91
|
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
81
92
|
|
|
82
93
|
function getBold(msg) {
|
|
@@ -211,25 +222,35 @@ var messages = reactIntl.defineMessages({
|
|
|
211
222
|
description: 'Label for "Field definitions" link',
|
|
212
223
|
defaultMessage: 'Field definitions'
|
|
213
224
|
},
|
|
214
|
-
allGeneralFields: {
|
|
215
|
-
id: 'ExportResourcesModal.allGeneralFields',
|
|
216
|
-
description: 'Label for "All general fields" checkbox',
|
|
217
|
-
defaultMessage: 'All general fields'
|
|
218
|
-
},
|
|
219
|
-
allCustomFields: {
|
|
220
|
-
id: 'ExportResourcesModal.allCustomFields',
|
|
221
|
-
description: 'Label for "All custom fields" checkbox',
|
|
222
|
-
defaultMessage: 'All custom fields'
|
|
223
|
-
},
|
|
224
|
-
customTypeKeyAndTypeId: {
|
|
225
|
-
id: 'ExportResourcesModal.customTypeKeyAndTypeId',
|
|
226
|
-
description: 'Label for "Custom type key and typeId" checkbox',
|
|
227
|
-
defaultMessage: 'Custom type key and typeId'
|
|
228
|
-
},
|
|
229
225
|
unexpectedError: {
|
|
230
226
|
id: 'ExportResourcesModal.unexpectedError',
|
|
231
227
|
description: 'Generic notification message when starting export process fails',
|
|
232
228
|
defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
|
|
229
|
+
},
|
|
230
|
+
searchForFields: {
|
|
231
|
+
id: 'ExportResourcesModal.searchForFields',
|
|
232
|
+
description: 'Placeholder for "Search for fields" search input',
|
|
233
|
+
defaultMessage: 'Search for fields'
|
|
234
|
+
},
|
|
235
|
+
thereAreNoResults: {
|
|
236
|
+
id: 'ExportResourcesModal.thereAreNoResults',
|
|
237
|
+
description: 'No search results message',
|
|
238
|
+
defaultMessage: 'There are no results that match your search.'
|
|
239
|
+
},
|
|
240
|
+
suggestions: {
|
|
241
|
+
id: 'ExportResourcesModal.suggestions',
|
|
242
|
+
description: 'In Export fields selection - Suggestions message',
|
|
243
|
+
defaultMessage: 'Suggestions:'
|
|
244
|
+
},
|
|
245
|
+
checkTheSpelling: {
|
|
246
|
+
id: 'ExportResourcesModal.checkTheSpelling',
|
|
247
|
+
description: 'In Export fields selection - Check the spelling message',
|
|
248
|
+
defaultMessage: 'Check the spelling.'
|
|
249
|
+
},
|
|
250
|
+
searchByEnteringTheExactFieldName: {
|
|
251
|
+
id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
|
|
252
|
+
description: 'In Export fields selection - Search by entering the exact field name message',
|
|
253
|
+
defaultMessage: 'Try searching by entering the exact field name.'
|
|
233
254
|
}
|
|
234
255
|
});
|
|
235
256
|
|
|
@@ -290,11 +311,11 @@ const FIELD_DEFINITIONS_URLS = {
|
|
|
290
311
|
category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
|
|
291
312
|
};
|
|
292
313
|
|
|
293
|
-
function _createSuper$
|
|
294
|
-
function _isNativeReflectConstruct$
|
|
314
|
+
function _createSuper$2(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$2(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
315
|
+
function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
|
|
295
316
|
let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
|
|
296
317
|
_inherits(UnexpectedExportTypeError, _Error);
|
|
297
|
-
var _super = _createSuper$
|
|
318
|
+
var _super = _createSuper$2(UnexpectedExportTypeError);
|
|
298
319
|
function UnexpectedExportTypeError(exportType) {
|
|
299
320
|
var _this;
|
|
300
321
|
_classCallCheck(this, UnexpectedExportTypeError);
|
|
@@ -305,11 +326,11 @@ let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
|
|
|
305
326
|
return _createClass(UnexpectedExportTypeError);
|
|
306
327
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
307
328
|
|
|
308
|
-
function _createSuper$
|
|
309
|
-
function _isNativeReflectConstruct$
|
|
329
|
+
function _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
330
|
+
function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
|
|
310
331
|
let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
|
|
311
332
|
_inherits(MissingExportResourceProviderError, _Error);
|
|
312
|
-
var _super = _createSuper$
|
|
333
|
+
var _super = _createSuper$1(MissingExportResourceProviderError);
|
|
313
334
|
function MissingExportResourceProviderError() {
|
|
314
335
|
var _this;
|
|
315
336
|
_classCallCheck(this, MissingExportResourceProviderError);
|
|
@@ -320,11 +341,11 @@ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
|
|
|
320
341
|
return _createClass(MissingExportResourceProviderError);
|
|
321
342
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
322
343
|
|
|
323
|
-
function _createSuper
|
|
324
|
-
function _isNativeReflectConstruct
|
|
344
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
345
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
|
|
325
346
|
let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
|
|
326
347
|
_inherits(UnexpectedExportOperationStateError, _Error);
|
|
327
|
-
var _super = _createSuper
|
|
348
|
+
var _super = _createSuper(UnexpectedExportOperationStateError);
|
|
328
349
|
function UnexpectedExportOperationStateError(state) {
|
|
329
350
|
var _this;
|
|
330
351
|
_classCallCheck(this, UnexpectedExportOperationStateError);
|
|
@@ -335,36 +356,6 @@ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
|
|
|
335
356
|
return _createClass(UnexpectedExportOperationStateError);
|
|
336
357
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
337
358
|
|
|
338
|
-
function _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
339
|
-
function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
|
|
340
|
-
let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
|
|
341
|
-
_inherits(UnexpectedResourceTypeError, _Error);
|
|
342
|
-
var _super = _createSuper$1(UnexpectedResourceTypeError);
|
|
343
|
-
function UnexpectedResourceTypeError(resourceType) {
|
|
344
|
-
var _this;
|
|
345
|
-
_classCallCheck(this, UnexpectedResourceTypeError);
|
|
346
|
-
_this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
|
|
347
|
-
_this.name = 'UnexpectedResourceTypeError';
|
|
348
|
-
return _this;
|
|
349
|
-
}
|
|
350
|
-
return _createClass(UnexpectedResourceTypeError);
|
|
351
|
-
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
352
|
-
|
|
353
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
354
|
-
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
|
|
355
|
-
let InvalidResponseError = /*#__PURE__*/function (_Error) {
|
|
356
|
-
_inherits(InvalidResponseError, _Error);
|
|
357
|
-
var _super = _createSuper(InvalidResponseError);
|
|
358
|
-
function InvalidResponseError(message) {
|
|
359
|
-
var _this;
|
|
360
|
-
_classCallCheck(this, InvalidResponseError);
|
|
361
|
-
_this = _super.call(this, message);
|
|
362
|
-
_this.name = 'InvalidResponseError';
|
|
363
|
-
return _this;
|
|
364
|
-
}
|
|
365
|
-
return _createClass(InvalidResponseError);
|
|
366
|
-
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
367
|
-
|
|
368
359
|
function useExportResourcesContext() {
|
|
369
360
|
const context = React.useContext(ExportResourcesContext);
|
|
370
361
|
if (!context) {
|
|
@@ -373,33 +364,44 @@ function useExportResourcesContext() {
|
|
|
373
364
|
return context;
|
|
374
365
|
}
|
|
375
366
|
|
|
367
|
+
function checkAtLeastOneFieldChecked$1(fields) {
|
|
368
|
+
return _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
369
|
+
if (field.fields) {
|
|
370
|
+
return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
|
|
371
|
+
}
|
|
372
|
+
return field.isChecked;
|
|
373
|
+
});
|
|
374
|
+
}
|
|
376
375
|
function validate(_ref) {
|
|
377
376
|
let values = _valuesInstanceProperty__default["default"](_ref),
|
|
378
377
|
step = _ref.step;
|
|
379
378
|
const fileName = values.fileName,
|
|
380
379
|
locales = values.locales,
|
|
381
|
-
|
|
382
|
-
customFields = values.customFields;
|
|
380
|
+
groups = values.groups;
|
|
383
381
|
const errors = {
|
|
384
382
|
fileName: {},
|
|
385
383
|
locales: {},
|
|
386
384
|
fields: {}
|
|
387
385
|
};
|
|
388
386
|
if (uiKit.TextInput.isEmpty(fileName)) {
|
|
387
|
+
// @ts-ignore
|
|
389
388
|
errors.fileName.missing = true;
|
|
390
389
|
} else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
|
|
390
|
+
// @ts-ignore
|
|
391
391
|
errors.fileName.invalidInput = true;
|
|
392
392
|
}
|
|
393
393
|
if (locales.length < 1) {
|
|
394
|
+
// @ts-ignore
|
|
394
395
|
errors.locales.missing = true;
|
|
395
396
|
}
|
|
396
397
|
if (step === 2) {
|
|
397
|
-
const
|
|
398
|
-
const
|
|
399
|
-
|
|
400
|
-
return
|
|
401
|
-
}
|
|
402
|
-
if (
|
|
398
|
+
const allFields = _reduceInstanceProperty__default["default"](groups).call(groups, (acc, group) => _concatInstanceProperty__default["default"](acc).call(acc, group.fields), []);
|
|
399
|
+
const checkedFieldsCount = _filterInstanceProperty__default["default"](allFields).call(allFields, field => {
|
|
400
|
+
if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
|
|
401
|
+
return !field.isRequired && !field.isReadOnly && field.isChecked;
|
|
402
|
+
}).length;
|
|
403
|
+
if (checkedFieldsCount < 1) {
|
|
404
|
+
// @ts-ignore
|
|
403
405
|
errors.fields.missing = true;
|
|
404
406
|
}
|
|
405
407
|
}
|
|
@@ -407,7 +409,7 @@ function validate(_ref) {
|
|
|
407
409
|
}
|
|
408
410
|
|
|
409
411
|
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; }
|
|
410
|
-
function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var
|
|
412
|
+
function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context5, _context6; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context5 = ownKeys$5(Object(t), !0)).call(_context5, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context6 = ownKeys$5(Object(t))).call(_context6, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
411
413
|
function resourceTypeToDisplayName(_ref) {
|
|
412
414
|
let resourceType = _ref.resourceType,
|
|
413
415
|
_ref$isUpperCase = _ref.isUpperCase,
|
|
@@ -426,7 +428,7 @@ function resourceTypeToDisplayName(_ref) {
|
|
|
426
428
|
displayName = isPlural ? 'Discount codes' : 'Discount code';
|
|
427
429
|
break;
|
|
428
430
|
default:
|
|
429
|
-
throw UnexpectedResourceTypeError(resourceType);
|
|
431
|
+
throw shared.UnexpectedResourceTypeError(resourceType);
|
|
430
432
|
}
|
|
431
433
|
return isUpperCase ? displayName : displayName.toLowerCase();
|
|
432
434
|
}
|
|
@@ -460,17 +462,6 @@ function flattenNestedFields(fields) {
|
|
|
460
462
|
})) || [];
|
|
461
463
|
return _flatInstanceProperty__default["default"](result).call(result);
|
|
462
464
|
}
|
|
463
|
-
function getSelectedGeneralFields(fields) {
|
|
464
|
-
return _filterInstanceProperty__default["default"](fields).call(fields, field => field.isChecked);
|
|
465
|
-
}
|
|
466
|
-
function getSelectedCustomFields(customFields) {
|
|
467
|
-
return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
468
|
-
var _context4;
|
|
469
|
-
return _objectSpread$5(_objectSpread$5({}, customType), {}, {
|
|
470
|
-
fields: _filterInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => field.isChecked)
|
|
471
|
-
});
|
|
472
|
-
});
|
|
473
|
-
}
|
|
474
465
|
function checkRequiredFields(fields) {
|
|
475
466
|
return _mapInstanceProperty__default["default"](fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
|
|
476
467
|
isChecked: true
|
|
@@ -484,45 +475,38 @@ function getExportLogsLink(projectKey, msg) {
|
|
|
484
475
|
}
|
|
485
476
|
function setInitialCheckedStateForCustomFields(customFields) {
|
|
486
477
|
return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
487
|
-
var
|
|
478
|
+
var _context4;
|
|
488
479
|
return _objectSpread$5(_objectSpread$5({}, customType), {}, {
|
|
489
|
-
fields: _mapInstanceProperty__default["default"](
|
|
480
|
+
fields: _mapInstanceProperty__default["default"](_context4 = customType.fields).call(_context4, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
|
|
490
481
|
isChecked: false
|
|
491
482
|
}))
|
|
492
483
|
});
|
|
493
484
|
});
|
|
494
485
|
}
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
const fields = _flatMapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
500
|
-
var _context6;
|
|
501
|
-
return _flatMapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => {
|
|
502
|
-
return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
|
|
503
|
-
});
|
|
504
|
-
});
|
|
505
|
-
return [...new _Set__default["default"](fields)];
|
|
506
|
-
}
|
|
507
|
-
function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
|
|
508
|
-
const prefixes = _mapInstanceProperty__default["default"](resourceTypeIds).call(resourceTypeIds, type => {
|
|
509
|
-
switch (type) {
|
|
510
|
-
case 'asset':
|
|
511
|
-
return 'assets.custom.fields.';
|
|
512
|
-
default:
|
|
513
|
-
return 'custom.fields.';
|
|
486
|
+
const extractFieldNamesAndAdditionalFieldExtensions = fields => {
|
|
487
|
+
const result = _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
|
|
488
|
+
if (field.additionalFieldExtensions) {
|
|
489
|
+
return [...acc, ...field.additionalFieldExtensions, field.name];
|
|
514
490
|
}
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
491
|
+
return [...acc, field.name];
|
|
492
|
+
}, []);
|
|
493
|
+
return [...new _Set__default["default"](result)];
|
|
494
|
+
};
|
|
495
|
+
function sortFieldsByFieldOrder(_ref2) {
|
|
496
|
+
let fields = _ref2.fields,
|
|
497
|
+
fieldOrder = _ref2.fieldOrder;
|
|
498
|
+
if (isFilledArray(fieldOrder)) {
|
|
499
|
+
return _sortInstanceProperty__default["default"](fields).call(fields, (a, b) => {
|
|
500
|
+
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]);
|
|
501
|
+
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]);
|
|
521
502
|
|
|
522
|
-
//
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
503
|
+
// If a field is not 'custom',then consider it as '*'
|
|
504
|
+
orderA = orderA === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderA;
|
|
505
|
+
orderB = orderB === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderB;
|
|
506
|
+
return orderA - orderB;
|
|
507
|
+
});
|
|
508
|
+
}
|
|
509
|
+
return fields;
|
|
526
510
|
}
|
|
527
511
|
|
|
528
512
|
// TODO: remove this function when filters are passed directly from parent views
|
|
@@ -535,43 +519,52 @@ function tmpBuildFilters(selectedResourceIds) {
|
|
|
535
519
|
return ["id in (".concat(formattedIds, ")")];
|
|
536
520
|
}
|
|
537
521
|
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
const
|
|
541
|
-
const
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
default: defaultFieldExtension,
|
|
562
|
-
category: categoryFieldExtension
|
|
522
|
+
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; }
|
|
523
|
+
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; }
|
|
524
|
+
const updateFieldGroupsWithIsCheckedValue = groups => {
|
|
525
|
+
const updateFields = (fields, parentChecked) => {
|
|
526
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
527
|
+
var _field$isRequired;
|
|
528
|
+
let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
|
|
529
|
+
if (field.fields) {
|
|
530
|
+
const updatedFields = updateFields(field.fields, isChecked);
|
|
531
|
+
isChecked = false;
|
|
532
|
+
field.fields = updatedFields;
|
|
533
|
+
}
|
|
534
|
+
return _objectSpread$4(_objectSpread$4({}, field), {}, {
|
|
535
|
+
isChecked
|
|
536
|
+
});
|
|
537
|
+
});
|
|
538
|
+
};
|
|
539
|
+
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
540
|
+
const updatedFields = updateFields(group.fields, false);
|
|
541
|
+
return _objectSpread$4(_objectSpread$4({}, group), {}, {
|
|
542
|
+
fields: updatedFields
|
|
543
|
+
});
|
|
544
|
+
});
|
|
563
545
|
};
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
546
|
+
const updateFieldGroupWithAdditionalFieldExtensions = groups => {
|
|
547
|
+
function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
|
|
548
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
549
|
+
const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
|
|
550
|
+
if (field.fields) {
|
|
551
|
+
field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
|
|
552
|
+
}
|
|
553
|
+
return _objectSpread$4(_objectSpread$4({}, field), {}, {
|
|
554
|
+
additionalFieldExtensions: updatedAdditionalFieldExtensions
|
|
555
|
+
});
|
|
556
|
+
});
|
|
557
|
+
}
|
|
558
|
+
return _mapInstanceProperty__default["default"](groups).call(groups, group => {
|
|
559
|
+
return _objectSpread$4(_objectSpread$4({}, group), {}, {
|
|
560
|
+
fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
|
|
561
|
+
});
|
|
562
|
+
});
|
|
570
563
|
};
|
|
571
564
|
|
|
572
565
|
const _excluded = ["isSelectedByDefault"];
|
|
573
|
-
function ownKeys$
|
|
574
|
-
function _objectSpread$
|
|
566
|
+
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; }
|
|
567
|
+
function _objectSpread$3(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$3(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$3(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
575
568
|
const useInitialValues = props => {
|
|
576
569
|
var _context;
|
|
577
570
|
const todayFormatted = moment__default["default"]().format('DD-MM-YY_HH-mm');
|
|
@@ -582,10 +575,11 @@ const useInitialValues = props => {
|
|
|
582
575
|
const fields = _mapInstanceProperty__default["default"](_context = flattenNestedFields(props.fields)).call(_context, _ref => {
|
|
583
576
|
let isSelectedByDefault = _ref.isSelectedByDefault,
|
|
584
577
|
field = _objectWithoutProperties(_ref, _excluded);
|
|
585
|
-
return _objectSpread$
|
|
578
|
+
return _objectSpread$3(_objectSpread$3({}, field), {}, {
|
|
586
579
|
isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
|
|
587
580
|
});
|
|
588
581
|
});
|
|
582
|
+
const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
|
|
589
583
|
return React__default["default"].useMemo(() => {
|
|
590
584
|
var _context2;
|
|
591
585
|
return {
|
|
@@ -597,9 +591,10 @@ const useInitialValues = props => {
|
|
|
597
591
|
}), "_Export_")).call(_context2, todayFormatted),
|
|
598
592
|
locales: [locale],
|
|
599
593
|
fields: checkRequiredFields(fields),
|
|
600
|
-
customFields: setInitialCheckedStateForCustomFields(props.customFields)
|
|
594
|
+
customFields: setInitialCheckedStateForCustomFields(props.customFields),
|
|
595
|
+
groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
|
|
601
596
|
};
|
|
602
|
-
}, [props, locale, todayFormatted, fields]);
|
|
597
|
+
}, [props, locale, todayFormatted, fields, groups]);
|
|
603
598
|
};
|
|
604
599
|
|
|
605
600
|
async function createExportOperation(_ref) {
|
|
@@ -628,7 +623,7 @@ async function createExportOperation(_ref) {
|
|
|
628
623
|
filters
|
|
629
624
|
}
|
|
630
625
|
}));
|
|
631
|
-
if (!response.state) throw new InvalidResponseError('Invalid response');
|
|
626
|
+
if (!response.state) throw new shared.InvalidResponseError('Invalid response');
|
|
632
627
|
return response;
|
|
633
628
|
}
|
|
634
629
|
|
|
@@ -644,12 +639,29 @@ const useStartExportOperation = props => {
|
|
|
644
639
|
};
|
|
645
640
|
}),
|
|
646
641
|
projectKey = _useApplicationContex.projectKey;
|
|
642
|
+
const extractFieldsFromGroups = groups => {
|
|
643
|
+
let selectedGeneralFields = [];
|
|
644
|
+
const getSelectedFields = fields => {
|
|
645
|
+
return _filterInstanceProperty__default["default"](fields).call(fields, field => {
|
|
646
|
+
var _field$isChecked;
|
|
647
|
+
if (field.fields) {
|
|
648
|
+
return getSelectedFields(field.fields);
|
|
649
|
+
}
|
|
650
|
+
if (field.isChecked) selectedGeneralFields.push(field);
|
|
651
|
+
return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
|
|
652
|
+
});
|
|
653
|
+
};
|
|
654
|
+
_forEachInstanceProperty__default["default"](groups).call(groups, group => {
|
|
655
|
+
getSelectedFields(group.fields);
|
|
656
|
+
});
|
|
657
|
+
return sortFieldsByFieldOrder({
|
|
658
|
+
fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
|
|
659
|
+
fieldOrder: props.fieldOrder
|
|
660
|
+
});
|
|
661
|
+
};
|
|
647
662
|
const startExportOperation = async values => {
|
|
648
663
|
try {
|
|
649
|
-
const
|
|
650
|
-
const selectedCustomFields = getSelectedCustomFields(values.customFields);
|
|
651
|
-
const generalFields = extractGeneralFieldNames(selectedGeneralFields);
|
|
652
|
-
const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
|
|
664
|
+
const fields = extractFieldsFromGroups(values.groups);
|
|
653
665
|
const filters = tmpBuildFilters(props.selectedResourceIds);
|
|
654
666
|
const response = await createExportOperation({
|
|
655
667
|
projectKey,
|
|
@@ -657,10 +669,7 @@ const useStartExportOperation = props => {
|
|
|
657
669
|
fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
|
|
658
670
|
fileFormat: values.outputFormat,
|
|
659
671
|
locales: values.locales,
|
|
660
|
-
fields
|
|
661
|
-
resourceType: props.resourceType,
|
|
662
|
-
fields: [...generalFields, ...customFields]
|
|
663
|
-
}),
|
|
672
|
+
fields,
|
|
664
673
|
filters,
|
|
665
674
|
asyncDispatchFn: asyncDispatch
|
|
666
675
|
});
|
|
@@ -670,6 +679,7 @@ const useStartExportOperation = props => {
|
|
|
670
679
|
showNotification({
|
|
671
680
|
kind: 'info',
|
|
672
681
|
domain: constants.DOMAINS.SIDE,
|
|
682
|
+
// @ts-ignore
|
|
673
683
|
text: intl.formatMessage(messages.exportOperationSuccessMessage, {
|
|
674
684
|
newline: getNewLine,
|
|
675
685
|
logsLink: msg => getExportLogsLink(projectKey, msg),
|
|
@@ -699,8 +709,8 @@ const useStartExportOperation = props => {
|
|
|
699
709
|
};
|
|
700
710
|
};
|
|
701
711
|
|
|
702
|
-
function ownKeys$
|
|
703
|
-
function _objectSpread$
|
|
712
|
+
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; }
|
|
713
|
+
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; }
|
|
704
714
|
function ExportTextMessage() {
|
|
705
715
|
const intl = reactIntl.useIntl();
|
|
706
716
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
@@ -728,7 +738,7 @@ function ExportTextMessage() {
|
|
|
728
738
|
}
|
|
729
739
|
return jsxRuntime.jsx(uiKit.Text.Body, {
|
|
730
740
|
"data-testid": "export-description",
|
|
731
|
-
intlMessage: _objectSpread$
|
|
741
|
+
intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
|
|
732
742
|
values: {
|
|
733
743
|
count: intl.formatNumber(count),
|
|
734
744
|
resourceType: resourceTypePlural,
|
|
@@ -827,35 +837,203 @@ const ExportFileSettingsStep = () => {
|
|
|
827
837
|
});
|
|
828
838
|
};
|
|
829
839
|
|
|
830
|
-
function
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
840
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
841
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
842
|
+
name: "ti75j2",
|
|
843
|
+
styles: "margin:0"
|
|
844
|
+
} : {
|
|
845
|
+
name: "ozey8m-NoSearchResults",
|
|
846
|
+
styles: "margin:0;label:NoSearchResults;",
|
|
847
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
|
|
848
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
849
|
+
};
|
|
850
|
+
const NoSearchResults = () => {
|
|
851
|
+
return jsxRuntime.jsxs(uiKit.Card, {
|
|
852
|
+
insetScale: "xl",
|
|
853
|
+
children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
|
|
854
|
+
scale: "s",
|
|
855
|
+
children: [jsxRuntime.jsx(uiKit.Text.Body, {
|
|
856
|
+
fontWeight: "medium",
|
|
857
|
+
intlMessage: messages.thereAreNoResults
|
|
858
|
+
}), jsxRuntime.jsx(uiKit.Text.Body, {
|
|
859
|
+
intlMessage: messages.suggestions
|
|
860
|
+
})]
|
|
861
|
+
}), jsxRuntime.jsxs("ul", {
|
|
862
|
+
css: _ref,
|
|
863
|
+
children: [jsxRuntime.jsx("li", {
|
|
864
|
+
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
865
|
+
intlMessage: messages.checkTheSpelling
|
|
866
|
+
})
|
|
867
|
+
}), jsxRuntime.jsx("li", {
|
|
868
|
+
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
869
|
+
intlMessage: messages.searchByEnteringTheExactFieldName
|
|
870
|
+
})
|
|
871
|
+
})]
|
|
872
|
+
})]
|
|
873
|
+
});
|
|
874
|
+
};
|
|
875
|
+
|
|
876
|
+
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; }
|
|
877
|
+
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; }
|
|
878
|
+
const StyledGroupCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
879
|
+
target: "e3xiyhb1"
|
|
834
880
|
} : {
|
|
835
|
-
target: "
|
|
836
|
-
label: "
|
|
837
|
-
})("height:100%;background-color:#f9f9fb;border-top:", _ref => {
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
}, ";border-radius:", _ref2 => {
|
|
841
|
-
let isTopRow = _ref2.isTopRow;
|
|
842
|
-
return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
|
|
843
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmBmC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, 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\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          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow 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 ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <FormattedMessage {...messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <FormattedMessage\n                          {...messages.customTypeKeyAndTypeId}\n                        />{' '}\n                        *\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
|
|
844
|
-
const StyledCardRight = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
845
|
-
target: "e1ocu3bb0"
|
|
881
|
+
target: "e3xiyhb1",
|
|
882
|
+
label: "StyledGroupCard"
|
|
883
|
+
})("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"]} */"));
|
|
884
|
+
const StyledFieldsCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
|
|
885
|
+
target: "e3xiyhb0"
|
|
846
886
|
} : {
|
|
847
|
-
target: "
|
|
848
|
-
label: "
|
|
849
|
-
})("height:100%;border-left:0;border-top:", _ref3 => {
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA2BoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, 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\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          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow 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 ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <FormattedMessage {...messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <FormattedMessage\n                          {...messages.customTypeKeyAndTypeId}\n                        />{' '}\n                        *\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
|
|
887
|
+
target: "e3xiyhb0",
|
|
888
|
+
label: "StyledFieldsCard"
|
|
889
|
+
})("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"]} */"));
|
|
890
|
+
const FieldSections = _ref => {
|
|
891
|
+
let fields = _ref.fields,
|
|
892
|
+
parentKeys = _ref.parentKeys,
|
|
893
|
+
formik = _ref.formik,
|
|
894
|
+
isAnySiblingChecked = _ref.isAnySiblingChecked;
|
|
895
|
+
return jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
896
|
+
scale: "s",
|
|
897
|
+
children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty__default["default"](fields).call(fields, (field, index) => {
|
|
898
|
+
var _context, _field$fields3;
|
|
899
|
+
const isAtleastOneChildChecked = () => {
|
|
900
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
901
|
+
return fields === null || fields === void 0 ? void 0 : _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
902
|
+
if (field.fields) {
|
|
903
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
904
|
+
}
|
|
905
|
+
return field.isChecked;
|
|
906
|
+
});
|
|
907
|
+
}
|
|
908
|
+
return checkAtLeastOneFieldChecked(field.fields);
|
|
909
|
+
};
|
|
910
|
+
const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
|
|
911
|
+
if (field.isHidden) return null;
|
|
912
|
+
return jsxRuntime.jsxs(React__default["default"].Fragment, {
|
|
913
|
+
children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
914
|
+
isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
|
|
915
|
+
isReadOnly: field.isReadOnly || field.isRequired,
|
|
916
|
+
onChange: e => {
|
|
917
|
+
var _context2, _field$fields2;
|
|
918
|
+
const path = _concatInstanceProperty__default["default"](_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
|
|
919
|
+
// Update all child fields
|
|
920
|
+
const updateAllChildFieldsChecked = (path, checked) => {
|
|
921
|
+
const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), path);
|
|
922
|
+
if (item && item.fields) {
|
|
923
|
+
var _context3;
|
|
924
|
+
_forEachInstanceProperty__default["default"](_context3 = item.fields).call(_context3, (field, i) => {
|
|
925
|
+
var _context4, _field$fields;
|
|
926
|
+
const fieldPath = _concatInstanceProperty__default["default"](_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
|
|
927
|
+
if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
|
|
928
|
+
formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
|
|
929
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
930
|
+
false);
|
|
931
|
+
}
|
|
932
|
+
updateAllChildFieldsChecked(fieldPath, checked);
|
|
933
|
+
});
|
|
934
|
+
}
|
|
935
|
+
};
|
|
936
|
+
if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
|
|
937
|
+
formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
|
|
938
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
939
|
+
false);
|
|
940
|
+
}
|
|
941
|
+
updateAllChildFieldsChecked(path, e.target.checked);
|
|
942
|
+
},
|
|
943
|
+
children: [field.label, " ", field.isRequired && '*']
|
|
944
|
+
}), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxRuntime.jsxs(uiKit.Spacings.Inline, {
|
|
945
|
+
scale: "l",
|
|
946
|
+
children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(FieldSections, {
|
|
947
|
+
fields: field.fields,
|
|
948
|
+
formik: formik,
|
|
949
|
+
parentKeys: [...parentKeys, "fields[".concat(index, "]")],
|
|
950
|
+
isAnySiblingChecked: isAnySiblingChecked
|
|
951
|
+
})]
|
|
952
|
+
})]
|
|
953
|
+
}, _concatInstanceProperty__default["default"](_context = "".concat(field.name, "-")).call(_context, index));
|
|
954
|
+
})
|
|
955
|
+
});
|
|
956
|
+
};
|
|
957
|
+
function checkAllFieldsSelected(fields) {
|
|
958
|
+
return _everyInstanceProperty__default["default"](fields).call(fields, field => {
|
|
959
|
+
if (field.fields) {
|
|
960
|
+
return checkAllFieldsSelected(field.fields);
|
|
961
|
+
}
|
|
962
|
+
return field.isChecked || field.isRequired || field.isReadOnly;
|
|
963
|
+
});
|
|
964
|
+
}
|
|
965
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
966
|
+
return _someInstanceProperty__default["default"](fields).call(fields, field => {
|
|
967
|
+
if (field.fields) {
|
|
968
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
969
|
+
}
|
|
970
|
+
return field.isChecked;
|
|
971
|
+
});
|
|
972
|
+
}
|
|
973
|
+
const FieldGroupSection = _ref2 => {
|
|
974
|
+
let group = _ref2.group,
|
|
975
|
+
index = _ref2.index,
|
|
976
|
+
formik = _ref2.formik;
|
|
977
|
+
const allAllFieldsSelected = React__default["default"].useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
|
|
978
|
+
const isAtleastOneFieldChecked = React__default["default"].useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
|
|
979
|
+
const parentKey = "groups[".concat(index, "]");
|
|
980
|
+
const handleChangeAllFields = e => {
|
|
981
|
+
const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), parentKey);
|
|
982
|
+
function updateAllFields(fields, checked) {
|
|
983
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
984
|
+
if (field.fields) {
|
|
985
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
986
|
+
fields: updateAllFields(field.fields, checked)
|
|
987
|
+
});
|
|
988
|
+
}
|
|
989
|
+
if (field.isReadOnly || field.isRequired) return field;
|
|
990
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
991
|
+
isChecked: checked
|
|
992
|
+
});
|
|
993
|
+
});
|
|
994
|
+
}
|
|
995
|
+
formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
|
|
996
|
+
fields: updateAllFields(item.fields, e.target.checked)
|
|
997
|
+
}));
|
|
998
|
+
};
|
|
999
|
+
if (group.isHidden) return null;
|
|
1000
|
+
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
1001
|
+
children: [jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1002
|
+
children: jsxRuntime.jsx(StyledGroupCard, {
|
|
1003
|
+
type: "flat",
|
|
1004
|
+
insetScale: "l",
|
|
1005
|
+
showTopBorder: true,
|
|
1006
|
+
children: jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1007
|
+
isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
|
|
1008
|
+
isChecked: allAllFieldsSelected,
|
|
1009
|
+
onChange: handleChangeAllFields,
|
|
1010
|
+
children: group.groupLabel
|
|
1011
|
+
})
|
|
1012
|
+
})
|
|
1013
|
+
}), jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
1014
|
+
children: jsxRuntime.jsx(StyledFieldsCard, {
|
|
1015
|
+
type: "flat",
|
|
1016
|
+
insetScale: "l",
|
|
1017
|
+
showTopBorder: true,
|
|
1018
|
+
children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
1019
|
+
scale: "s",
|
|
1020
|
+
children: jsxRuntime.jsx(FieldSections, {
|
|
1021
|
+
fields: group.fields,
|
|
1022
|
+
formik: formik,
|
|
1023
|
+
parentKeys: [parentKey],
|
|
1024
|
+
isAnySiblingChecked: isAtleastOneFieldChecked
|
|
1025
|
+
})
|
|
1026
|
+
})
|
|
1027
|
+
})
|
|
1028
|
+
})]
|
|
1029
|
+
});
|
|
1030
|
+
};
|
|
856
1031
|
const ExportFieldsSelectionStep = () => {
|
|
857
|
-
var _formik$values$custom;
|
|
858
1032
|
const intl = reactIntl.useIntl();
|
|
1033
|
+
const _React$useState = React__default["default"].useState(''),
|
|
1034
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
1035
|
+
fieldSearchTerm = _React$useState2[0],
|
|
1036
|
+
setFieldSearchTerm = _React$useState2[1];
|
|
859
1037
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
860
1038
|
formik = _useExportResourcesCo.formik,
|
|
861
1039
|
setCurrentStep = _useExportResourcesCo.setCurrentStep,
|
|
@@ -865,24 +1043,48 @@ const ExportFieldsSelectionStep = () => {
|
|
|
865
1043
|
resourceType: resourceType,
|
|
866
1044
|
isPlural: true
|
|
867
1045
|
});
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
}, [_valuesInstanceProperty__default["default"](formik).
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
1046
|
+
React__default["default"].useEffect(() => {
|
|
1047
|
+
formik.validateForm();
|
|
1048
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
1049
|
+
}, [_valuesInstanceProperty__default["default"](formik).groups]);
|
|
1050
|
+
// adds `isHidden` property to each field based on search term
|
|
1051
|
+
const filteredGroups = React__default["default"].useMemo(() => {
|
|
1052
|
+
var _fieldSearchTerm$trim, _context6;
|
|
1053
|
+
const updateFields = (fields, parentMatches) => {
|
|
1054
|
+
return _mapInstanceProperty__default["default"](fields).call(fields, field => {
|
|
1055
|
+
var _context5;
|
|
1056
|
+
const matches = _includesInstanceProperty__default["default"](_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
|
|
1057
|
+
let isHidden = !matches && !parentMatches;
|
|
1058
|
+
if (field.fields) {
|
|
1059
|
+
const updatedFields = updateFields(field.fields, matches);
|
|
1060
|
+
isHidden = isHidden && _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, f => f.isHidden);
|
|
1061
|
+
field = _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
1062
|
+
fields: updatedFields
|
|
1063
|
+
});
|
|
1064
|
+
}
|
|
1065
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
1066
|
+
isHidden
|
|
1067
|
+
});
|
|
1068
|
+
});
|
|
1069
|
+
};
|
|
1070
|
+
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;
|
|
1071
|
+
return _mapInstanceProperty__default["default"](_context6 = _valuesInstanceProperty__default["default"](formik).groups).call(_context6, group => {
|
|
1072
|
+
const updatedFields = updateFields(group.fields, false);
|
|
1073
|
+
const isHidden = _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, field => field.isHidden);
|
|
1074
|
+
return _objectSpread$1(_objectSpread$1({}, group), {}, {
|
|
1075
|
+
fields: updatedFields,
|
|
1076
|
+
isHidden
|
|
1077
|
+
});
|
|
1078
|
+
});
|
|
1079
|
+
}, [_valuesInstanceProperty__default["default"](formik).groups, fieldSearchTerm]);
|
|
1080
|
+
const onSearchChange = React__default["default"].useCallback(event => {
|
|
1081
|
+
setFieldSearchTerm(event.target.value);
|
|
1082
|
+
}, [setFieldSearchTerm]);
|
|
1083
|
+
const hasResults = Boolean(_findInstanceProperty__default["default"](filteredGroups).call(filteredGroups, group => !group.isHidden));
|
|
1084
|
+
const onSearchChangeThrottled = React__default["default"].useMemo(() => throttle__default["default"](onSearchChange, 300), [onSearchChange]);
|
|
1085
|
+
const onSearchReset = () => {
|
|
1086
|
+
setFieldSearchTerm('');
|
|
1087
|
+
};
|
|
886
1088
|
return jsxRuntime.jsx(applicationComponents.FormDialog, {
|
|
887
1089
|
isOpen: true,
|
|
888
1090
|
title: intl.formatMessage(messages.modalTitle, {
|
|
@@ -909,145 +1111,30 @@ const ExportFieldsSelectionStep = () => {
|
|
|
909
1111
|
intlMessage: messages.fieldDefinitions,
|
|
910
1112
|
to: FIELD_DEFINITIONS_URLS[resourceType]
|
|
911
1113
|
})]
|
|
912
|
-
}), jsxRuntime.
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
children: jsxRuntime.jsx(StyledCardRight, {
|
|
933
|
-
isTopRow: true,
|
|
934
|
-
insetScale: "l",
|
|
935
|
-
children: jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
936
|
-
scale: "s",
|
|
937
|
-
children: jsxRuntime.jsx(GeneralFieldsSelection, {
|
|
938
|
-
fields: _valuesInstanceProperty__default["default"](formik).fields,
|
|
939
|
-
setFieldValue: formik.setFieldValue
|
|
940
|
-
})
|
|
941
|
-
})
|
|
942
|
-
})
|
|
943
|
-
}), ((_formik$values$custom = _valuesInstanceProperty__default["default"](formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
944
|
-
children: [jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
945
|
-
children: jsxRuntime.jsx(StyledCardLeft, {
|
|
946
|
-
insetScale: "l",
|
|
947
|
-
children: jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
948
|
-
isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
|
|
949
|
-
isChecked: areAllCustomFieldsChecked,
|
|
950
|
-
onChange: e => {
|
|
951
|
-
var _context5;
|
|
952
|
-
formik.setFieldValue('customFields', _mapInstanceProperty__default["default"](_context5 = _valuesInstanceProperty__default["default"](formik).customFields).call(_context5, customType => {
|
|
953
|
-
var _context6;
|
|
954
|
-
return _objectSpread$2(_objectSpread$2({}, customType), {}, {
|
|
955
|
-
fields: _mapInstanceProperty__default["default"](_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
956
|
-
isChecked: e.target.checked
|
|
957
|
-
}))
|
|
958
|
-
});
|
|
959
|
-
}));
|
|
960
|
-
},
|
|
961
|
-
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
|
|
962
|
-
})
|
|
963
|
-
})
|
|
964
|
-
}), jsxRuntime.jsx(uiKit.Grid.Item, {
|
|
965
|
-
children: jsxRuntime.jsx(StyledCardRight, {
|
|
966
|
-
insetScale: "l",
|
|
967
|
-
children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
|
|
968
|
-
scale: "s",
|
|
969
|
-
children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
970
|
-
isReadOnly: true,
|
|
971
|
-
onChange: () => {},
|
|
972
|
-
isChecked: isAtLeastOneCustomFieldChecked,
|
|
973
|
-
children: [jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
|
|
974
|
-
}), jsxRuntime.jsx(CustomFieldsSelection, {
|
|
975
|
-
customFields: _valuesInstanceProperty__default["default"](formik).customFields,
|
|
976
|
-
setFieldValue: formik.setFieldValue
|
|
977
|
-
})]
|
|
978
|
-
})
|
|
979
|
-
})
|
|
980
|
-
})]
|
|
981
|
-
})]
|
|
982
|
-
})]
|
|
1114
|
+
}), jsxRuntime.jsx(uiKit.SearchTextInput, {
|
|
1115
|
+
placeholder: intl.formatMessage(messages.searchForFields),
|
|
1116
|
+
value: fieldSearchTerm,
|
|
1117
|
+
onChange: onSearchChangeThrottled,
|
|
1118
|
+
onReset: onSearchReset
|
|
1119
|
+
// TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
|
|
1120
|
+
,
|
|
1121
|
+
onSubmit: () => {}
|
|
1122
|
+
}), hasResults ? jsxRuntime.jsx(uiKit.Card, {
|
|
1123
|
+
insetScale: "none",
|
|
1124
|
+
children: jsxRuntime.jsx(uiKit.Grid, {
|
|
1125
|
+
gridAutoFlow: "row",
|
|
1126
|
+
gridTemplateColumns: "".concat(uiKit.designTokens.constraint5, " auto"),
|
|
1127
|
+
children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) => jsxRuntime.jsx(FieldGroupSection, {
|
|
1128
|
+
group: group,
|
|
1129
|
+
index: index,
|
|
1130
|
+
formik: formik
|
|
1131
|
+
}, group.groupLabel))
|
|
1132
|
+
})
|
|
1133
|
+
}) : jsxRuntime.jsx(NoSearchResults, {})]
|
|
983
1134
|
})
|
|
984
1135
|
})
|
|
985
1136
|
});
|
|
986
1137
|
};
|
|
987
|
-
const GeneralFieldsSelection = _ref5 => {
|
|
988
|
-
let fields = _ref5.fields,
|
|
989
|
-
setFieldValue = _ref5.setFieldValue;
|
|
990
|
-
return _mapInstanceProperty__default["default"](fields).call(fields, field => jsxRuntime.jsxs(uiKit.CheckboxInput, {
|
|
991
|
-
isChecked: field.isChecked,
|
|
992
|
-
isReadOnly: field.isRequired,
|
|
993
|
-
onChange: e => {
|
|
994
|
-
setFieldValue('fields', _mapInstanceProperty__default["default"](fields).call(fields, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
995
|
-
isChecked: e.target.checked
|
|
996
|
-
}) : _field));
|
|
997
|
-
},
|
|
998
|
-
children: [field.label, " ", field.isRequired && '*']
|
|
999
|
-
}, field.name));
|
|
1000
|
-
};
|
|
1001
|
-
const CustomFieldsSelection = _ref6 => {
|
|
1002
|
-
let customFields = _ref6.customFields,
|
|
1003
|
-
setFieldValue = _ref6.setFieldValue;
|
|
1004
|
-
return _mapInstanceProperty__default["default"](customFields).call(customFields, customType => {
|
|
1005
|
-
var _context7, _context8, _context10;
|
|
1006
|
-
const areAllFieldsChecked = _everyInstanceProperty__default["default"](_context7 = customType.fields).call(_context7, field => field.isChecked);
|
|
1007
|
-
const isAtLeastOneFieldChecked = _someInstanceProperty__default["default"](_context8 = customType.fields).call(_context8, field => field.isChecked);
|
|
1008
|
-
return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
|
|
1009
|
-
scale: "s",
|
|
1010
|
-
children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1011
|
-
isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
|
|
1012
|
-
isChecked: areAllFieldsChecked,
|
|
1013
|
-
onChange: e => {
|
|
1014
|
-
setFieldValue('customFields', _mapInstanceProperty__default["default"](customFields).call(customFields, _customType => {
|
|
1015
|
-
var _context9;
|
|
1016
|
-
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
1017
|
-
fields: _mapInstanceProperty__default["default"](_context9 = _customType.fields).call(_context9, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
1018
|
-
isChecked: e.target.checked
|
|
1019
|
-
}))
|
|
1020
|
-
}) : _customType;
|
|
1021
|
-
}));
|
|
1022
|
-
},
|
|
1023
|
-
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
1024
|
-
children: customType.type.label
|
|
1025
|
-
})
|
|
1026
|
-
}), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
|
|
1027
|
-
scale: "l",
|
|
1028
|
-
children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(uiKit.Spacings.Stack, {
|
|
1029
|
-
scale: "s",
|
|
1030
|
-
children: _mapInstanceProperty__default["default"](_context10 = customType.fields).call(_context10, field => jsxRuntime.jsx(uiKit.CheckboxInput, {
|
|
1031
|
-
isChecked: field.isChecked,
|
|
1032
|
-
onChange: e => {
|
|
1033
|
-
setFieldValue('customFields', _mapInstanceProperty__default["default"](customFields).call(customFields, _customType => {
|
|
1034
|
-
var _context11;
|
|
1035
|
-
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
1036
|
-
fields: _mapInstanceProperty__default["default"](_context11 = _customType.fields).call(_context11, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
1037
|
-
isChecked: e.target.checked
|
|
1038
|
-
}) : _field)
|
|
1039
|
-
}) : _customType;
|
|
1040
|
-
}));
|
|
1041
|
-
},
|
|
1042
|
-
children: jsxRuntime.jsx(uiKit.Text.Body, {
|
|
1043
|
-
children: field.label
|
|
1044
|
-
})
|
|
1045
|
-
}, field.name))
|
|
1046
|
-
})]
|
|
1047
|
-
})]
|
|
1048
|
-
}, customType.type.key);
|
|
1049
|
-
});
|
|
1050
|
-
};
|
|
1051
1138
|
|
|
1052
1139
|
process.env.NODE_ENV !== "production" ? {
|
|
1053
1140
|
renderProperties: PropTypes__default["default"].func
|
|
@@ -1055,42 +1142,6 @@ process.env.NODE_ENV !== "production" ? {
|
|
|
1055
1142
|
|
|
1056
1143
|
const ExportResourcesContext = /*#__PURE__*/React.createContext();
|
|
1057
1144
|
|
|
1058
|
-
const ExportResourcesModalShape = PropTypes__default["default"].shape({
|
|
1059
|
-
isOpen: PropTypes__default["default"].bool,
|
|
1060
|
-
resourceType: PropTypes__default["default"].string.isRequired,
|
|
1061
|
-
outputFormat: PropTypes__default["default"].string,
|
|
1062
|
-
onClose: PropTypes__default["default"].func,
|
|
1063
|
-
onExportSuccess: PropTypes__default["default"].func,
|
|
1064
|
-
totalResourcesCount: PropTypes__default["default"].number.isRequired,
|
|
1065
|
-
selectedResourceIds: PropTypes__default["default"].array,
|
|
1066
|
-
// TODO: Circular reference
|
|
1067
|
-
fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1068
|
-
name: PropTypes__default["default"].string.isRequired,
|
|
1069
|
-
label: PropTypes__default["default"].string,
|
|
1070
|
-
fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1071
|
-
name: PropTypes__default["default"].string.isRequired,
|
|
1072
|
-
label: PropTypes__default["default"].string,
|
|
1073
|
-
isSelectedByDefault: PropTypes__default["default"].bool,
|
|
1074
|
-
isRequired: PropTypes__default["default"].bool
|
|
1075
|
-
}))
|
|
1076
|
-
})).isRequired,
|
|
1077
|
-
customFields: PropTypes__default["default"].shape({
|
|
1078
|
-
type: PropTypes__default["default"].shape({
|
|
1079
|
-
key: PropTypes__default["default"].string.isRequired,
|
|
1080
|
-
label: PropTypes__default["default"].string.isRequired,
|
|
1081
|
-
resourceTypeIds: PropTypes__default["default"].arrayOf(PropTypes__default["default"].string)
|
|
1082
|
-
}).isRequired,
|
|
1083
|
-
fields: PropTypes__default["default"].arrayOf(PropTypes__default["default"].shape({
|
|
1084
|
-
name: PropTypes__default["default"].string.isRequired,
|
|
1085
|
-
label: PropTypes__default["default"].string
|
|
1086
|
-
})).isRequired
|
|
1087
|
-
}),
|
|
1088
|
-
exportType: PropTypes__default["default"].string,
|
|
1089
|
-
renderProperties: PropTypes__default["default"].func
|
|
1090
|
-
}).isRequired;
|
|
1091
|
-
|
|
1092
|
-
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; }
|
|
1093
|
-
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; }
|
|
1094
1145
|
const ExportResourcesProvider = props => {
|
|
1095
1146
|
const initialValues = useInitialValues(props);
|
|
1096
1147
|
const _useStartExportOperat = useStartExportOperation(props),
|
|
@@ -1131,10 +1182,6 @@ const ExportResourcesProvider = props => {
|
|
|
1131
1182
|
children: props.children
|
|
1132
1183
|
});
|
|
1133
1184
|
};
|
|
1134
|
-
ExportResourcesProvider.displayName = 'ExportResourcesProvider';
|
|
1135
|
-
ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
|
|
1136
|
-
children: PropTypes__default["default"].node
|
|
1137
|
-
}) : {};
|
|
1138
1185
|
|
|
1139
1186
|
const CurrentStep = () => {
|
|
1140
1187
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
@@ -1146,22 +1193,101 @@ const CurrentStep = () => {
|
|
|
1146
1193
|
return steps[currentStep] || null;
|
|
1147
1194
|
};
|
|
1148
1195
|
|
|
1196
|
+
const loadMessages = locale => {
|
|
1197
|
+
const intlLocale = i18n.mapLocaleToIntlLocale(locale);
|
|
1198
|
+
switch (intlLocale) {
|
|
1199
|
+
case 'de':
|
|
1200
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-de" */'./de-a34c5dd4.cjs.dev.js'); });
|
|
1201
|
+
case 'es':
|
|
1202
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-es" */'./es-8b3ecab1.cjs.dev.js'); });
|
|
1203
|
+
case 'fr-FR':
|
|
1204
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-fr-FR" */'./fr-FR-e7126fcc.cjs.dev.js'); });
|
|
1205
|
+
case 'zh-CN':
|
|
1206
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-zh-CN" */'./zh-CN-d4bc6d26.cjs.dev.js'); });
|
|
1207
|
+
case 'ja':
|
|
1208
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-ja" */'./ja-9bd5f452.cjs.dev.js'); });
|
|
1209
|
+
case 'pt-BR':
|
|
1210
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-ea6b3251.cjs.dev.js'); });
|
|
1211
|
+
default:
|
|
1212
|
+
return Promise.resolve().then(function () { return require( /* webpackChunkName: "export-resources-modal-i18n-en" */'./en-6b3694f6.cjs.dev.js'); });
|
|
1213
|
+
}
|
|
1214
|
+
};
|
|
1215
|
+
|
|
1216
|
+
// eslint-disable-next-line import/prefer-default-export
|
|
1217
|
+
const loadI18n = async locale => {
|
|
1218
|
+
try {
|
|
1219
|
+
const messages = await loadMessages(locale);
|
|
1220
|
+
return messages.default || messages;
|
|
1221
|
+
} catch (error) {
|
|
1222
|
+
// eslint-disable-next-line no-console
|
|
1223
|
+
console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
|
|
1224
|
+
sentry.reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
|
|
1225
|
+
extra: error
|
|
1226
|
+
});
|
|
1227
|
+
return {};
|
|
1228
|
+
}
|
|
1229
|
+
};
|
|
1230
|
+
|
|
1231
|
+
const useAsyncIntlMessages = (locale, loader) => {
|
|
1232
|
+
const _useState = React.useState({
|
|
1233
|
+
isLoading: true,
|
|
1234
|
+
messages: undefined,
|
|
1235
|
+
error: undefined
|
|
1236
|
+
}),
|
|
1237
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1238
|
+
state = _useState2[0],
|
|
1239
|
+
setState = _useState2[1];
|
|
1240
|
+
React.useEffect(() => {
|
|
1241
|
+
let _isUnmounting = false;
|
|
1242
|
+
async function load() {
|
|
1243
|
+
try {
|
|
1244
|
+
if (!_isUnmounting) {
|
|
1245
|
+
const messages = await loader(locale);
|
|
1246
|
+
setState({
|
|
1247
|
+
isLoading: false,
|
|
1248
|
+
messages
|
|
1249
|
+
});
|
|
1250
|
+
}
|
|
1251
|
+
} catch (error) {
|
|
1252
|
+
setState({
|
|
1253
|
+
isLoading: false,
|
|
1254
|
+
error
|
|
1255
|
+
});
|
|
1256
|
+
}
|
|
1257
|
+
}
|
|
1258
|
+
if (locale) load();
|
|
1259
|
+
return () => {
|
|
1260
|
+
_isUnmounting = true;
|
|
1261
|
+
};
|
|
1262
|
+
}, [locale, loader]);
|
|
1263
|
+
return state;
|
|
1264
|
+
};
|
|
1265
|
+
|
|
1149
1266
|
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; }
|
|
1150
1267
|
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; }
|
|
1151
1268
|
const ExportResourcesModal = props => {
|
|
1152
|
-
|
|
1153
|
-
|
|
1154
|
-
|
|
1155
|
-
|
|
1269
|
+
const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
|
|
1270
|
+
locale: context.user && context.user.locale
|
|
1271
|
+
})),
|
|
1272
|
+
locale = _useApplicationContex.locale;
|
|
1273
|
+
const messages = useAsyncIntlMessages('en', loadI18n);
|
|
1274
|
+
if (!props.isOpen || messages.isLoading) return null;
|
|
1275
|
+
return jsxRuntime.jsx(reactIntl.IntlProvider, {
|
|
1276
|
+
locale: locale,
|
|
1277
|
+
messages: messages.messages,
|
|
1278
|
+
children: jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
|
|
1279
|
+
children: jsxRuntime.jsx(CurrentStep, {})
|
|
1280
|
+
}))
|
|
1281
|
+
});
|
|
1156
1282
|
};
|
|
1157
1283
|
ExportResourcesModal.displayName = 'ExportResourcesModal';
|
|
1158
|
-
ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
|
|
1159
1284
|
ExportResourcesModal.defaultProps = {
|
|
1160
1285
|
isOpen: false,
|
|
1161
1286
|
selectedResourceIds: [],
|
|
1162
1287
|
exportType: EXPORT_TYPES.ALL,
|
|
1163
1288
|
outputFormat: OUTPUT_FORMATS.CSV,
|
|
1164
|
-
customFields: []
|
|
1289
|
+
customFields: [],
|
|
1290
|
+
fieldGroups: []
|
|
1165
1291
|
};
|
|
1166
1292
|
|
|
1167
1293
|
exports.EXPORTABLE_RESOURCES = EXPORTABLE_RESOURCES;
|