@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
|
@@ -7,14 +7,13 @@ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-st
|
|
|
7
7
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
8
8
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
9
9
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
|
-
import
|
|
11
|
-
import {
|
|
10
|
+
import { defineMessages, FormattedMessage, useIntl, IntlProvider } from 'react-intl';
|
|
11
|
+
import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
|
|
12
|
+
import { Text, TextInput, Link, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, SearchTextInput, Grid } from '@commercetools-frontend/ui-kit';
|
|
12
13
|
import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
|
|
13
14
|
import '@commercetools-uikit/design-system';
|
|
14
|
-
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
|
15
15
|
import _valuesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/values';
|
|
16
16
|
import { FormDialog } from '@commercetools-frontend/application-components';
|
|
17
|
-
import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
|
|
18
17
|
import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
|
|
19
18
|
import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
|
|
20
19
|
import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
|
|
@@ -22,28 +21,37 @@ import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits';
|
|
|
22
21
|
import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn';
|
|
23
22
|
import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
|
|
24
23
|
import _wrapNativeSuper from '@babel/runtime-corejs3/helpers/esm/wrapNativeSuper';
|
|
24
|
+
import React, { useContext, createContext, useState, useEffect } from 'react';
|
|
25
25
|
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
26
26
|
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
27
27
|
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
28
28
|
import moment from 'moment';
|
|
29
|
+
import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
|
|
29
30
|
import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
|
|
30
31
|
import omitEmpty from 'omit-empty-es';
|
|
31
32
|
import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
|
|
32
33
|
import _flatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat';
|
|
33
|
-
import _flatMapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat-map';
|
|
34
34
|
import _Set from '@babel/runtime-corejs3/core-js-stable/set';
|
|
35
35
|
import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort';
|
|
36
|
-
import
|
|
37
|
-
import
|
|
36
|
+
import '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
|
|
37
|
+
import _indexOfInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/index-of';
|
|
38
|
+
import { UnexpectedResourceTypeError, InvalidResponseError } from '@commercetools-local/shared';
|
|
38
39
|
import { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
|
|
39
40
|
import { useShowNotification } from '@commercetools-frontend/actions-global';
|
|
40
41
|
import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants';
|
|
42
|
+
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
41
43
|
import _styled from '@emotion/styled/base';
|
|
42
44
|
import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
|
|
43
|
-
import
|
|
45
|
+
import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
|
|
46
|
+
import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
|
|
47
|
+
import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
|
|
48
|
+
import throttle from 'lodash/throttle';
|
|
49
|
+
import { css } from '@emotion/react';
|
|
50
|
+
import get from 'lodash/get';
|
|
44
51
|
import PropTypes from 'prop-types';
|
|
45
|
-
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
46
52
|
import { useFormik } from 'formik';
|
|
53
|
+
import { reportErrorToSentry } from '@commercetools-frontend/sentry';
|
|
54
|
+
import { mapLocaleToIntlLocale } from '@commercetools-frontend/i18n';
|
|
47
55
|
|
|
48
56
|
function getBold(msg) {
|
|
49
57
|
return jsx(Text.Body, {
|
|
@@ -177,25 +185,35 @@ var messages = defineMessages({
|
|
|
177
185
|
description: 'Label for "Field definitions" link',
|
|
178
186
|
defaultMessage: 'Field definitions'
|
|
179
187
|
},
|
|
180
|
-
allGeneralFields: {
|
|
181
|
-
id: 'ExportResourcesModal.allGeneralFields',
|
|
182
|
-
description: 'Label for "All general fields" checkbox',
|
|
183
|
-
defaultMessage: 'All general fields'
|
|
184
|
-
},
|
|
185
|
-
allCustomFields: {
|
|
186
|
-
id: 'ExportResourcesModal.allCustomFields',
|
|
187
|
-
description: 'Label for "All custom fields" checkbox',
|
|
188
|
-
defaultMessage: 'All custom fields'
|
|
189
|
-
},
|
|
190
|
-
customTypeKeyAndTypeId: {
|
|
191
|
-
id: 'ExportResourcesModal.customTypeKeyAndTypeId',
|
|
192
|
-
description: 'Label for "Custom type key and typeId" checkbox',
|
|
193
|
-
defaultMessage: 'Custom type key and typeId'
|
|
194
|
-
},
|
|
195
188
|
unexpectedError: {
|
|
196
189
|
id: 'ExportResourcesModal.unexpectedError',
|
|
197
190
|
description: 'Generic notification message when starting export process fails',
|
|
198
191
|
defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
|
|
192
|
+
},
|
|
193
|
+
searchForFields: {
|
|
194
|
+
id: 'ExportResourcesModal.searchForFields',
|
|
195
|
+
description: 'Placeholder for "Search for fields" search input',
|
|
196
|
+
defaultMessage: 'Search for fields'
|
|
197
|
+
},
|
|
198
|
+
thereAreNoResults: {
|
|
199
|
+
id: 'ExportResourcesModal.thereAreNoResults',
|
|
200
|
+
description: 'No search results message',
|
|
201
|
+
defaultMessage: 'There are no results that match your search.'
|
|
202
|
+
},
|
|
203
|
+
suggestions: {
|
|
204
|
+
id: 'ExportResourcesModal.suggestions',
|
|
205
|
+
description: 'In Export fields selection - Suggestions message',
|
|
206
|
+
defaultMessage: 'Suggestions:'
|
|
207
|
+
},
|
|
208
|
+
checkTheSpelling: {
|
|
209
|
+
id: 'ExportResourcesModal.checkTheSpelling',
|
|
210
|
+
description: 'In Export fields selection - Check the spelling message',
|
|
211
|
+
defaultMessage: 'Check the spelling.'
|
|
212
|
+
},
|
|
213
|
+
searchByEnteringTheExactFieldName: {
|
|
214
|
+
id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
|
|
215
|
+
description: 'In Export fields selection - Search by entering the exact field name message',
|
|
216
|
+
defaultMessage: 'Try searching by entering the exact field name.'
|
|
199
217
|
}
|
|
200
218
|
});
|
|
201
219
|
|
|
@@ -256,11 +274,11 @@ const FIELD_DEFINITIONS_URLS = {
|
|
|
256
274
|
category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
|
|
257
275
|
};
|
|
258
276
|
|
|
259
|
-
function _createSuper$
|
|
260
|
-
function _isNativeReflectConstruct$
|
|
277
|
+
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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
278
|
+
function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
|
|
261
279
|
let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
|
|
262
280
|
_inherits(UnexpectedExportTypeError, _Error);
|
|
263
|
-
var _super = _createSuper$
|
|
281
|
+
var _super = _createSuper$2(UnexpectedExportTypeError);
|
|
264
282
|
function UnexpectedExportTypeError(exportType) {
|
|
265
283
|
var _this;
|
|
266
284
|
_classCallCheck(this, UnexpectedExportTypeError);
|
|
@@ -271,11 +289,11 @@ let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
|
|
|
271
289
|
return _createClass(UnexpectedExportTypeError);
|
|
272
290
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
273
291
|
|
|
274
|
-
function _createSuper$
|
|
275
|
-
function _isNativeReflectConstruct$
|
|
292
|
+
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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
293
|
+
function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
|
|
276
294
|
let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
|
|
277
295
|
_inherits(MissingExportResourceProviderError, _Error);
|
|
278
|
-
var _super = _createSuper$
|
|
296
|
+
var _super = _createSuper$1(MissingExportResourceProviderError);
|
|
279
297
|
function MissingExportResourceProviderError() {
|
|
280
298
|
var _this;
|
|
281
299
|
_classCallCheck(this, MissingExportResourceProviderError);
|
|
@@ -286,11 +304,11 @@ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
|
|
|
286
304
|
return _createClass(MissingExportResourceProviderError);
|
|
287
305
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
288
306
|
|
|
289
|
-
function _createSuper
|
|
290
|
-
function _isNativeReflectConstruct
|
|
307
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
308
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
|
|
291
309
|
let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
|
|
292
310
|
_inherits(UnexpectedExportOperationStateError, _Error);
|
|
293
|
-
var _super = _createSuper
|
|
311
|
+
var _super = _createSuper(UnexpectedExportOperationStateError);
|
|
294
312
|
function UnexpectedExportOperationStateError(state) {
|
|
295
313
|
var _this;
|
|
296
314
|
_classCallCheck(this, UnexpectedExportOperationStateError);
|
|
@@ -301,36 +319,6 @@ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
|
|
|
301
319
|
return _createClass(UnexpectedExportOperationStateError);
|
|
302
320
|
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
303
321
|
|
|
304
|
-
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(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
305
|
-
function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
|
|
306
|
-
let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
|
|
307
|
-
_inherits(UnexpectedResourceTypeError, _Error);
|
|
308
|
-
var _super = _createSuper$1(UnexpectedResourceTypeError);
|
|
309
|
-
function UnexpectedResourceTypeError(resourceType) {
|
|
310
|
-
var _this;
|
|
311
|
-
_classCallCheck(this, UnexpectedResourceTypeError);
|
|
312
|
-
_this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
|
|
313
|
-
_this.name = 'UnexpectedResourceTypeError';
|
|
314
|
-
return _this;
|
|
315
|
-
}
|
|
316
|
-
return _createClass(UnexpectedResourceTypeError);
|
|
317
|
-
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
318
|
-
|
|
319
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
320
|
-
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
|
|
321
|
-
let InvalidResponseError = /*#__PURE__*/function (_Error) {
|
|
322
|
-
_inherits(InvalidResponseError, _Error);
|
|
323
|
-
var _super = _createSuper(InvalidResponseError);
|
|
324
|
-
function InvalidResponseError(message) {
|
|
325
|
-
var _this;
|
|
326
|
-
_classCallCheck(this, InvalidResponseError);
|
|
327
|
-
_this = _super.call(this, message);
|
|
328
|
-
_this.name = 'InvalidResponseError';
|
|
329
|
-
return _this;
|
|
330
|
-
}
|
|
331
|
-
return _createClass(InvalidResponseError);
|
|
332
|
-
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
333
|
-
|
|
334
322
|
function useExportResourcesContext() {
|
|
335
323
|
const context = useContext(ExportResourcesContext);
|
|
336
324
|
if (!context) {
|
|
@@ -339,33 +327,44 @@ function useExportResourcesContext() {
|
|
|
339
327
|
return context;
|
|
340
328
|
}
|
|
341
329
|
|
|
330
|
+
function checkAtLeastOneFieldChecked$1(fields) {
|
|
331
|
+
return _someInstanceProperty(fields).call(fields, field => {
|
|
332
|
+
if (field.fields) {
|
|
333
|
+
return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
|
|
334
|
+
}
|
|
335
|
+
return field.isChecked;
|
|
336
|
+
});
|
|
337
|
+
}
|
|
342
338
|
function validate(_ref) {
|
|
343
339
|
let values = _valuesInstanceProperty(_ref),
|
|
344
340
|
step = _ref.step;
|
|
345
341
|
const fileName = values.fileName,
|
|
346
342
|
locales = values.locales,
|
|
347
|
-
|
|
348
|
-
customFields = values.customFields;
|
|
343
|
+
groups = values.groups;
|
|
349
344
|
const errors = {
|
|
350
345
|
fileName: {},
|
|
351
346
|
locales: {},
|
|
352
347
|
fields: {}
|
|
353
348
|
};
|
|
354
349
|
if (TextInput.isEmpty(fileName)) {
|
|
350
|
+
// @ts-ignore
|
|
355
351
|
errors.fileName.missing = true;
|
|
356
352
|
} else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
|
|
353
|
+
// @ts-ignore
|
|
357
354
|
errors.fileName.invalidInput = true;
|
|
358
355
|
}
|
|
359
356
|
if (locales.length < 1) {
|
|
357
|
+
// @ts-ignore
|
|
360
358
|
errors.locales.missing = true;
|
|
361
359
|
}
|
|
362
360
|
if (step === 2) {
|
|
363
|
-
const
|
|
364
|
-
const
|
|
365
|
-
|
|
366
|
-
return
|
|
367
|
-
}
|
|
368
|
-
if (
|
|
361
|
+
const allFields = _reduceInstanceProperty(groups).call(groups, (acc, group) => _concatInstanceProperty(acc).call(acc, group.fields), []);
|
|
362
|
+
const checkedFieldsCount = _filterInstanceProperty(allFields).call(allFields, field => {
|
|
363
|
+
if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
|
|
364
|
+
return !field.isRequired && !field.isReadOnly && field.isChecked;
|
|
365
|
+
}).length;
|
|
366
|
+
if (checkedFieldsCount < 1) {
|
|
367
|
+
// @ts-ignore
|
|
369
368
|
errors.fields.missing = true;
|
|
370
369
|
}
|
|
371
370
|
}
|
|
@@ -373,7 +372,7 @@ function validate(_ref) {
|
|
|
373
372
|
}
|
|
374
373
|
|
|
375
374
|
function ownKeys$5(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
376
|
-
function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var
|
|
375
|
+
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(_context5 = ownKeys$5(Object(t), !0)).call(_context5, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context6 = ownKeys$5(Object(t))).call(_context6, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
377
376
|
function resourceTypeToDisplayName(_ref) {
|
|
378
377
|
let resourceType = _ref.resourceType,
|
|
379
378
|
_ref$isUpperCase = _ref.isUpperCase,
|
|
@@ -426,17 +425,6 @@ function flattenNestedFields(fields) {
|
|
|
426
425
|
})) || [];
|
|
427
426
|
return _flatInstanceProperty(result).call(result);
|
|
428
427
|
}
|
|
429
|
-
function getSelectedGeneralFields(fields) {
|
|
430
|
-
return _filterInstanceProperty(fields).call(fields, field => field.isChecked);
|
|
431
|
-
}
|
|
432
|
-
function getSelectedCustomFields(customFields) {
|
|
433
|
-
return _mapInstanceProperty(customFields).call(customFields, customType => {
|
|
434
|
-
var _context4;
|
|
435
|
-
return _objectSpread$5(_objectSpread$5({}, customType), {}, {
|
|
436
|
-
fields: _filterInstanceProperty(_context4 = customType.fields).call(_context4, field => field.isChecked)
|
|
437
|
-
});
|
|
438
|
-
});
|
|
439
|
-
}
|
|
440
428
|
function checkRequiredFields(fields) {
|
|
441
429
|
return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
|
|
442
430
|
isChecked: true
|
|
@@ -450,45 +438,38 @@ function getExportLogsLink(projectKey, msg) {
|
|
|
450
438
|
}
|
|
451
439
|
function setInitialCheckedStateForCustomFields(customFields) {
|
|
452
440
|
return _mapInstanceProperty(customFields).call(customFields, customType => {
|
|
453
|
-
var
|
|
441
|
+
var _context4;
|
|
454
442
|
return _objectSpread$5(_objectSpread$5({}, customType), {}, {
|
|
455
|
-
fields: _mapInstanceProperty(
|
|
443
|
+
fields: _mapInstanceProperty(_context4 = customType.fields).call(_context4, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
|
|
456
444
|
isChecked: false
|
|
457
445
|
}))
|
|
458
446
|
});
|
|
459
447
|
});
|
|
460
448
|
}
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
const fields = _flatMapInstanceProperty(customFields).call(customFields, customType => {
|
|
466
|
-
var _context6;
|
|
467
|
-
return _flatMapInstanceProperty(_context6 = customType.fields).call(_context6, field => {
|
|
468
|
-
return getCustomFieldNameWithPrefix(field, customType.type.resourceTypeIds);
|
|
469
|
-
});
|
|
470
|
-
});
|
|
471
|
-
return [...new _Set(fields)];
|
|
472
|
-
}
|
|
473
|
-
function getCustomFieldNameWithPrefix(field, resourceTypeIds) {
|
|
474
|
-
const prefixes = _mapInstanceProperty(resourceTypeIds).call(resourceTypeIds, type => {
|
|
475
|
-
switch (type) {
|
|
476
|
-
case 'asset':
|
|
477
|
-
return 'assets.custom.fields.';
|
|
478
|
-
default:
|
|
479
|
-
return 'custom.fields.';
|
|
449
|
+
const extractFieldNamesAndAdditionalFieldExtensions = fields => {
|
|
450
|
+
const result = _reduceInstanceProperty(fields).call(fields, (acc, field) => {
|
|
451
|
+
if (field.additionalFieldExtensions) {
|
|
452
|
+
return [...acc, ...field.additionalFieldExtensions, field.name];
|
|
480
453
|
}
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
454
|
+
return [...acc, field.name];
|
|
455
|
+
}, []);
|
|
456
|
+
return [...new _Set(result)];
|
|
457
|
+
};
|
|
458
|
+
function sortFieldsByFieldOrder(_ref2) {
|
|
459
|
+
let fields = _ref2.fields,
|
|
460
|
+
fieldOrder = _ref2.fieldOrder;
|
|
461
|
+
if (isFilledArray(fieldOrder)) {
|
|
462
|
+
return _sortInstanceProperty(fields).call(fields, (a, b) => {
|
|
463
|
+
let orderA = _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a) !== -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a) : _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a.split('.')[0]);
|
|
464
|
+
let orderB = _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b) !== -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b) : _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b.split('.')[0]);
|
|
487
465
|
|
|
488
|
-
//
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
466
|
+
// If a field is not 'custom',then consider it as '*'
|
|
467
|
+
orderA = orderA === -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, '*') : orderA;
|
|
468
|
+
orderB = orderB === -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, '*') : orderB;
|
|
469
|
+
return orderA - orderB;
|
|
470
|
+
});
|
|
471
|
+
}
|
|
472
|
+
return fields;
|
|
492
473
|
}
|
|
493
474
|
|
|
494
475
|
// TODO: remove this function when filters are passed directly from parent views
|
|
@@ -501,43 +482,52 @@ function tmpBuildFilters(selectedResourceIds) {
|
|
|
501
482
|
return ["id in (".concat(formattedIds, ")")];
|
|
502
483
|
}
|
|
503
484
|
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
const
|
|
507
|
-
const
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
default: defaultFieldExtension,
|
|
528
|
-
category: categoryFieldExtension
|
|
485
|
+
function ownKeys$4(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
486
|
+
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(_context = ownKeys$4(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$4(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
487
|
+
const updateFieldGroupsWithIsCheckedValue = groups => {
|
|
488
|
+
const updateFields = (fields, parentChecked) => {
|
|
489
|
+
return _mapInstanceProperty(fields).call(fields, field => {
|
|
490
|
+
var _field$isRequired;
|
|
491
|
+
let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
|
|
492
|
+
if (field.fields) {
|
|
493
|
+
const updatedFields = updateFields(field.fields, isChecked);
|
|
494
|
+
isChecked = false;
|
|
495
|
+
field.fields = updatedFields;
|
|
496
|
+
}
|
|
497
|
+
return _objectSpread$4(_objectSpread$4({}, field), {}, {
|
|
498
|
+
isChecked
|
|
499
|
+
});
|
|
500
|
+
});
|
|
501
|
+
};
|
|
502
|
+
return _mapInstanceProperty(groups).call(groups, group => {
|
|
503
|
+
const updatedFields = updateFields(group.fields, false);
|
|
504
|
+
return _objectSpread$4(_objectSpread$4({}, group), {}, {
|
|
505
|
+
fields: updatedFields
|
|
506
|
+
});
|
|
507
|
+
});
|
|
529
508
|
};
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
509
|
+
const updateFieldGroupWithAdditionalFieldExtensions = groups => {
|
|
510
|
+
function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
|
|
511
|
+
return _mapInstanceProperty(fields).call(fields, field => {
|
|
512
|
+
const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
|
|
513
|
+
if (field.fields) {
|
|
514
|
+
field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
|
|
515
|
+
}
|
|
516
|
+
return _objectSpread$4(_objectSpread$4({}, field), {}, {
|
|
517
|
+
additionalFieldExtensions: updatedAdditionalFieldExtensions
|
|
518
|
+
});
|
|
519
|
+
});
|
|
520
|
+
}
|
|
521
|
+
return _mapInstanceProperty(groups).call(groups, group => {
|
|
522
|
+
return _objectSpread$4(_objectSpread$4({}, group), {}, {
|
|
523
|
+
fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
|
|
524
|
+
});
|
|
525
|
+
});
|
|
536
526
|
};
|
|
537
527
|
|
|
538
528
|
const _excluded = ["isSelectedByDefault"];
|
|
539
|
-
function ownKeys$
|
|
540
|
-
function _objectSpread$
|
|
529
|
+
function ownKeys$3(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
530
|
+
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(_context3 = ownKeys$3(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$3(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
541
531
|
const useInitialValues = props => {
|
|
542
532
|
var _context;
|
|
543
533
|
const todayFormatted = moment().format('DD-MM-YY_HH-mm');
|
|
@@ -548,10 +538,11 @@ const useInitialValues = props => {
|
|
|
548
538
|
const fields = _mapInstanceProperty(_context = flattenNestedFields(props.fields)).call(_context, _ref => {
|
|
549
539
|
let isSelectedByDefault = _ref.isSelectedByDefault,
|
|
550
540
|
field = _objectWithoutProperties(_ref, _excluded);
|
|
551
|
-
return _objectSpread$
|
|
541
|
+
return _objectSpread$3(_objectSpread$3({}, field), {}, {
|
|
552
542
|
isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
|
|
553
543
|
});
|
|
554
544
|
});
|
|
545
|
+
const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
|
|
555
546
|
return React.useMemo(() => {
|
|
556
547
|
var _context2;
|
|
557
548
|
return {
|
|
@@ -563,9 +554,10 @@ const useInitialValues = props => {
|
|
|
563
554
|
}), "_Export_")).call(_context2, todayFormatted),
|
|
564
555
|
locales: [locale],
|
|
565
556
|
fields: checkRequiredFields(fields),
|
|
566
|
-
customFields: setInitialCheckedStateForCustomFields(props.customFields)
|
|
557
|
+
customFields: setInitialCheckedStateForCustomFields(props.customFields),
|
|
558
|
+
groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
|
|
567
559
|
};
|
|
568
|
-
}, [props, locale, todayFormatted, fields]);
|
|
560
|
+
}, [props, locale, todayFormatted, fields, groups]);
|
|
569
561
|
};
|
|
570
562
|
|
|
571
563
|
async function createExportOperation(_ref) {
|
|
@@ -610,12 +602,29 @@ const useStartExportOperation = props => {
|
|
|
610
602
|
};
|
|
611
603
|
}),
|
|
612
604
|
projectKey = _useApplicationContex.projectKey;
|
|
605
|
+
const extractFieldsFromGroups = groups => {
|
|
606
|
+
let selectedGeneralFields = [];
|
|
607
|
+
const getSelectedFields = fields => {
|
|
608
|
+
return _filterInstanceProperty(fields).call(fields, field => {
|
|
609
|
+
var _field$isChecked;
|
|
610
|
+
if (field.fields) {
|
|
611
|
+
return getSelectedFields(field.fields);
|
|
612
|
+
}
|
|
613
|
+
if (field.isChecked) selectedGeneralFields.push(field);
|
|
614
|
+
return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
|
|
615
|
+
});
|
|
616
|
+
};
|
|
617
|
+
_forEachInstanceProperty(groups).call(groups, group => {
|
|
618
|
+
getSelectedFields(group.fields);
|
|
619
|
+
});
|
|
620
|
+
return sortFieldsByFieldOrder({
|
|
621
|
+
fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
|
|
622
|
+
fieldOrder: props.fieldOrder
|
|
623
|
+
});
|
|
624
|
+
};
|
|
613
625
|
const startExportOperation = async values => {
|
|
614
626
|
try {
|
|
615
|
-
const
|
|
616
|
-
const selectedCustomFields = getSelectedCustomFields(values.customFields);
|
|
617
|
-
const generalFields = extractGeneralFieldNames(selectedGeneralFields);
|
|
618
|
-
const customFields = sortCustomFields(extractCustomFieldNamesWithPrefix(selectedCustomFields));
|
|
627
|
+
const fields = extractFieldsFromGroups(values.groups);
|
|
619
628
|
const filters = tmpBuildFilters(props.selectedResourceIds);
|
|
620
629
|
const response = await createExportOperation({
|
|
621
630
|
projectKey,
|
|
@@ -623,10 +632,7 @@ const useStartExportOperation = props => {
|
|
|
623
632
|
fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
|
|
624
633
|
fileFormat: values.outputFormat,
|
|
625
634
|
locales: values.locales,
|
|
626
|
-
fields
|
|
627
|
-
resourceType: props.resourceType,
|
|
628
|
-
fields: [...generalFields, ...customFields]
|
|
629
|
-
}),
|
|
635
|
+
fields,
|
|
630
636
|
filters,
|
|
631
637
|
asyncDispatchFn: asyncDispatch
|
|
632
638
|
});
|
|
@@ -636,6 +642,7 @@ const useStartExportOperation = props => {
|
|
|
636
642
|
showNotification({
|
|
637
643
|
kind: 'info',
|
|
638
644
|
domain: DOMAINS.SIDE,
|
|
645
|
+
// @ts-ignore
|
|
639
646
|
text: intl.formatMessage(messages.exportOperationSuccessMessage, {
|
|
640
647
|
newline: getNewLine,
|
|
641
648
|
logsLink: msg => getExportLogsLink(projectKey, msg),
|
|
@@ -665,8 +672,8 @@ const useStartExportOperation = props => {
|
|
|
665
672
|
};
|
|
666
673
|
};
|
|
667
674
|
|
|
668
|
-
function ownKeys$
|
|
669
|
-
function _objectSpread$
|
|
675
|
+
function ownKeys$2(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
676
|
+
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(_context = ownKeys$2(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$2(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
670
677
|
function ExportTextMessage() {
|
|
671
678
|
const intl = useIntl();
|
|
672
679
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
@@ -694,7 +701,7 @@ function ExportTextMessage() {
|
|
|
694
701
|
}
|
|
695
702
|
return jsx(Text.Body, {
|
|
696
703
|
"data-testid": "export-description",
|
|
697
|
-
intlMessage: _objectSpread$
|
|
704
|
+
intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
|
|
698
705
|
values: {
|
|
699
706
|
count: intl.formatNumber(count),
|
|
700
707
|
resourceType: resourceTypePlural,
|
|
@@ -793,35 +800,203 @@ const ExportFileSettingsStep = () => {
|
|
|
793
800
|
});
|
|
794
801
|
};
|
|
795
802
|
|
|
796
|
-
function
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
803
|
+
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)."; }
|
|
804
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
805
|
+
name: "ti75j2",
|
|
806
|
+
styles: "margin:0"
|
|
800
807
|
} : {
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
}, ";" + (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"]} */"));
|
|
810
|
-
|
|
811
|
-
|
|
808
|
+
name: "ozey8m-NoSearchResults",
|
|
809
|
+
styles: "margin:0;label:NoSearchResults;",
|
|
810
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
|
|
811
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
812
|
+
};
|
|
813
|
+
const NoSearchResults = () => {
|
|
814
|
+
return jsxs(Card, {
|
|
815
|
+
insetScale: "xl",
|
|
816
|
+
children: [jsxs(Spacings.Stack, {
|
|
817
|
+
scale: "s",
|
|
818
|
+
children: [jsx(Text.Body, {
|
|
819
|
+
fontWeight: "medium",
|
|
820
|
+
intlMessage: messages.thereAreNoResults
|
|
821
|
+
}), jsx(Text.Body, {
|
|
822
|
+
intlMessage: messages.suggestions
|
|
823
|
+
})]
|
|
824
|
+
}), jsxs("ul", {
|
|
825
|
+
css: _ref,
|
|
826
|
+
children: [jsx("li", {
|
|
827
|
+
children: jsx(Text.Body, {
|
|
828
|
+
intlMessage: messages.checkTheSpelling
|
|
829
|
+
})
|
|
830
|
+
}), jsx("li", {
|
|
831
|
+
children: jsx(Text.Body, {
|
|
832
|
+
intlMessage: messages.searchByEnteringTheExactFieldName
|
|
833
|
+
})
|
|
834
|
+
})]
|
|
835
|
+
})]
|
|
836
|
+
});
|
|
837
|
+
};
|
|
838
|
+
|
|
839
|
+
function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
840
|
+
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(_context7 = ownKeys$1(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context8 = ownKeys$1(Object(t))).call(_context8, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
841
|
+
const StyledGroupCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
|
|
842
|
+
target: "e3xiyhb1"
|
|
843
|
+
} : {
|
|
844
|
+
target: "e3xiyhb1",
|
|
845
|
+
label: "StyledGroupCard"
|
|
846
|
+
})("border-right:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";background-color:", designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", 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"]} */"));
|
|
847
|
+
const StyledFieldsCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
|
|
848
|
+
target: "e3xiyhb0"
|
|
812
849
|
} : {
|
|
813
|
-
target: "
|
|
814
|
-
label: "
|
|
815
|
-
})("height:100%;border-left:0;border-top:", _ref3 => {
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
}, ";" + (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"]} */"));
|
|
850
|
+
target: "e3xiyhb0",
|
|
851
|
+
label: "StyledFieldsCard"
|
|
852
|
+
})("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", 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"]} */"));
|
|
853
|
+
const FieldSections = _ref => {
|
|
854
|
+
let fields = _ref.fields,
|
|
855
|
+
parentKeys = _ref.parentKeys,
|
|
856
|
+
formik = _ref.formik,
|
|
857
|
+
isAnySiblingChecked = _ref.isAnySiblingChecked;
|
|
858
|
+
return jsx(Spacings.Stack, {
|
|
859
|
+
scale: "s",
|
|
860
|
+
children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty(fields).call(fields, (field, index) => {
|
|
861
|
+
var _context, _field$fields3;
|
|
862
|
+
const isAtleastOneChildChecked = () => {
|
|
863
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
864
|
+
return fields === null || fields === void 0 ? void 0 : _someInstanceProperty(fields).call(fields, field => {
|
|
865
|
+
if (field.fields) {
|
|
866
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
867
|
+
}
|
|
868
|
+
return field.isChecked;
|
|
869
|
+
});
|
|
870
|
+
}
|
|
871
|
+
return checkAtLeastOneFieldChecked(field.fields);
|
|
872
|
+
};
|
|
873
|
+
const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
|
|
874
|
+
if (field.isHidden) return null;
|
|
875
|
+
return jsxs(React.Fragment, {
|
|
876
|
+
children: [jsxs(CheckboxInput, {
|
|
877
|
+
isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
|
|
878
|
+
isReadOnly: field.isReadOnly || field.isRequired,
|
|
879
|
+
onChange: e => {
|
|
880
|
+
var _context2, _field$fields2;
|
|
881
|
+
const path = _concatInstanceProperty(_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
|
|
882
|
+
// Update all child fields
|
|
883
|
+
const updateAllChildFieldsChecked = (path, checked) => {
|
|
884
|
+
const item = get(_valuesInstanceProperty(formik), path);
|
|
885
|
+
if (item && item.fields) {
|
|
886
|
+
var _context3;
|
|
887
|
+
_forEachInstanceProperty(_context3 = item.fields).call(_context3, (field, i) => {
|
|
888
|
+
var _context4, _field$fields;
|
|
889
|
+
const fieldPath = _concatInstanceProperty(_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
|
|
890
|
+
if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
|
|
891
|
+
formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
|
|
892
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
893
|
+
false);
|
|
894
|
+
}
|
|
895
|
+
updateAllChildFieldsChecked(fieldPath, checked);
|
|
896
|
+
});
|
|
897
|
+
}
|
|
898
|
+
};
|
|
899
|
+
if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
|
|
900
|
+
formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
|
|
901
|
+
// pass `false` to avoid revalidating the form with intermediate values
|
|
902
|
+
false);
|
|
903
|
+
}
|
|
904
|
+
updateAllChildFieldsChecked(path, e.target.checked);
|
|
905
|
+
},
|
|
906
|
+
children: [field.label, " ", field.isRequired && '*']
|
|
907
|
+
}), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxs(Spacings.Inline, {
|
|
908
|
+
scale: "l",
|
|
909
|
+
children: [jsx("div", {}), jsx(FieldSections, {
|
|
910
|
+
fields: field.fields,
|
|
911
|
+
formik: formik,
|
|
912
|
+
parentKeys: [...parentKeys, "fields[".concat(index, "]")],
|
|
913
|
+
isAnySiblingChecked: isAnySiblingChecked
|
|
914
|
+
})]
|
|
915
|
+
})]
|
|
916
|
+
}, _concatInstanceProperty(_context = "".concat(field.name, "-")).call(_context, index));
|
|
917
|
+
})
|
|
918
|
+
});
|
|
919
|
+
};
|
|
920
|
+
function checkAllFieldsSelected(fields) {
|
|
921
|
+
return _everyInstanceProperty(fields).call(fields, field => {
|
|
922
|
+
if (field.fields) {
|
|
923
|
+
return checkAllFieldsSelected(field.fields);
|
|
924
|
+
}
|
|
925
|
+
return field.isChecked || field.isRequired || field.isReadOnly;
|
|
926
|
+
});
|
|
927
|
+
}
|
|
928
|
+
function checkAtLeastOneFieldChecked(fields) {
|
|
929
|
+
return _someInstanceProperty(fields).call(fields, field => {
|
|
930
|
+
if (field.fields) {
|
|
931
|
+
return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
|
|
932
|
+
}
|
|
933
|
+
return field.isChecked;
|
|
934
|
+
});
|
|
935
|
+
}
|
|
936
|
+
const FieldGroupSection = _ref2 => {
|
|
937
|
+
let group = _ref2.group,
|
|
938
|
+
index = _ref2.index,
|
|
939
|
+
formik = _ref2.formik;
|
|
940
|
+
const allAllFieldsSelected = React.useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
|
|
941
|
+
const isAtleastOneFieldChecked = React.useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
|
|
942
|
+
const parentKey = "groups[".concat(index, "]");
|
|
943
|
+
const handleChangeAllFields = e => {
|
|
944
|
+
const item = get(_valuesInstanceProperty(formik), parentKey);
|
|
945
|
+
function updateAllFields(fields, checked) {
|
|
946
|
+
return _mapInstanceProperty(fields).call(fields, field => {
|
|
947
|
+
if (field.fields) {
|
|
948
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
949
|
+
fields: updateAllFields(field.fields, checked)
|
|
950
|
+
});
|
|
951
|
+
}
|
|
952
|
+
if (field.isReadOnly || field.isRequired) return field;
|
|
953
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
954
|
+
isChecked: checked
|
|
955
|
+
});
|
|
956
|
+
});
|
|
957
|
+
}
|
|
958
|
+
formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
|
|
959
|
+
fields: updateAllFields(item.fields, e.target.checked)
|
|
960
|
+
}));
|
|
961
|
+
};
|
|
962
|
+
if (group.isHidden) return null;
|
|
963
|
+
return jsxs(Fragment, {
|
|
964
|
+
children: [jsx(Grid.Item, {
|
|
965
|
+
children: jsx(StyledGroupCard, {
|
|
966
|
+
type: "flat",
|
|
967
|
+
insetScale: "l",
|
|
968
|
+
showTopBorder: true,
|
|
969
|
+
children: jsx(CheckboxInput, {
|
|
970
|
+
isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
|
|
971
|
+
isChecked: allAllFieldsSelected,
|
|
972
|
+
onChange: handleChangeAllFields,
|
|
973
|
+
children: group.groupLabel
|
|
974
|
+
})
|
|
975
|
+
})
|
|
976
|
+
}), jsx(Grid.Item, {
|
|
977
|
+
children: jsx(StyledFieldsCard, {
|
|
978
|
+
type: "flat",
|
|
979
|
+
insetScale: "l",
|
|
980
|
+
showTopBorder: true,
|
|
981
|
+
children: jsx(Spacings.Stack, {
|
|
982
|
+
scale: "s",
|
|
983
|
+
children: jsx(FieldSections, {
|
|
984
|
+
fields: group.fields,
|
|
985
|
+
formik: formik,
|
|
986
|
+
parentKeys: [parentKey],
|
|
987
|
+
isAnySiblingChecked: isAtleastOneFieldChecked
|
|
988
|
+
})
|
|
989
|
+
})
|
|
990
|
+
})
|
|
991
|
+
})]
|
|
992
|
+
});
|
|
993
|
+
};
|
|
822
994
|
const ExportFieldsSelectionStep = () => {
|
|
823
|
-
var _formik$values$custom;
|
|
824
995
|
const intl = useIntl();
|
|
996
|
+
const _React$useState = React.useState(''),
|
|
997
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
998
|
+
fieldSearchTerm = _React$useState2[0],
|
|
999
|
+
setFieldSearchTerm = _React$useState2[1];
|
|
825
1000
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
826
1001
|
formik = _useExportResourcesCo.formik,
|
|
827
1002
|
setCurrentStep = _useExportResourcesCo.setCurrentStep,
|
|
@@ -831,24 +1006,48 @@ const ExportFieldsSelectionStep = () => {
|
|
|
831
1006
|
resourceType: resourceType,
|
|
832
1007
|
isPlural: true
|
|
833
1008
|
});
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
}, [_valuesInstanceProperty(formik).
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
1009
|
+
React.useEffect(() => {
|
|
1010
|
+
formik.validateForm();
|
|
1011
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
1012
|
+
}, [_valuesInstanceProperty(formik).groups]);
|
|
1013
|
+
// adds `isHidden` property to each field based on search term
|
|
1014
|
+
const filteredGroups = React.useMemo(() => {
|
|
1015
|
+
var _fieldSearchTerm$trim, _context6;
|
|
1016
|
+
const updateFields = (fields, parentMatches) => {
|
|
1017
|
+
return _mapInstanceProperty(fields).call(fields, field => {
|
|
1018
|
+
var _context5;
|
|
1019
|
+
const matches = _includesInstanceProperty(_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
|
|
1020
|
+
let isHidden = !matches && !parentMatches;
|
|
1021
|
+
if (field.fields) {
|
|
1022
|
+
const updatedFields = updateFields(field.fields, matches);
|
|
1023
|
+
isHidden = isHidden && _everyInstanceProperty(updatedFields).call(updatedFields, f => f.isHidden);
|
|
1024
|
+
field = _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
1025
|
+
fields: updatedFields
|
|
1026
|
+
});
|
|
1027
|
+
}
|
|
1028
|
+
return _objectSpread$1(_objectSpread$1({}, field), {}, {
|
|
1029
|
+
isHidden
|
|
1030
|
+
});
|
|
1031
|
+
});
|
|
1032
|
+
};
|
|
1033
|
+
if (!(fieldSearchTerm !== null && fieldSearchTerm !== void 0 && (_fieldSearchTerm$trim = _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm)) !== null && _fieldSearchTerm$trim !== void 0 && _fieldSearchTerm$trim.length)) return _valuesInstanceProperty(formik).groups;
|
|
1034
|
+
return _mapInstanceProperty(_context6 = _valuesInstanceProperty(formik).groups).call(_context6, group => {
|
|
1035
|
+
const updatedFields = updateFields(group.fields, false);
|
|
1036
|
+
const isHidden = _everyInstanceProperty(updatedFields).call(updatedFields, field => field.isHidden);
|
|
1037
|
+
return _objectSpread$1(_objectSpread$1({}, group), {}, {
|
|
1038
|
+
fields: updatedFields,
|
|
1039
|
+
isHidden
|
|
1040
|
+
});
|
|
1041
|
+
});
|
|
1042
|
+
}, [_valuesInstanceProperty(formik).groups, fieldSearchTerm]);
|
|
1043
|
+
const onSearchChange = React.useCallback(event => {
|
|
1044
|
+
setFieldSearchTerm(event.target.value);
|
|
1045
|
+
}, [setFieldSearchTerm]);
|
|
1046
|
+
const hasResults = Boolean(_findInstanceProperty(filteredGroups).call(filteredGroups, group => !group.isHidden));
|
|
1047
|
+
const onSearchChangeThrottled = React.useMemo(() => throttle(onSearchChange, 300), [onSearchChange]);
|
|
1048
|
+
const onSearchReset = () => {
|
|
1049
|
+
setFieldSearchTerm('');
|
|
1050
|
+
};
|
|
852
1051
|
return jsx(FormDialog, {
|
|
853
1052
|
isOpen: true,
|
|
854
1053
|
title: intl.formatMessage(messages.modalTitle, {
|
|
@@ -875,145 +1074,30 @@ const ExportFieldsSelectionStep = () => {
|
|
|
875
1074
|
intlMessage: messages.fieldDefinitions,
|
|
876
1075
|
to: FIELD_DEFINITIONS_URLS[resourceType]
|
|
877
1076
|
})]
|
|
878
|
-
}),
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
children: jsx(StyledCardRight, {
|
|
899
|
-
isTopRow: true,
|
|
900
|
-
insetScale: "l",
|
|
901
|
-
children: jsx(Spacings.Stack, {
|
|
902
|
-
scale: "s",
|
|
903
|
-
children: jsx(GeneralFieldsSelection, {
|
|
904
|
-
fields: _valuesInstanceProperty(formik).fields,
|
|
905
|
-
setFieldValue: formik.setFieldValue
|
|
906
|
-
})
|
|
907
|
-
})
|
|
908
|
-
})
|
|
909
|
-
}), ((_formik$values$custom = _valuesInstanceProperty(formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxs(Fragment, {
|
|
910
|
-
children: [jsx(Grid.Item, {
|
|
911
|
-
children: jsx(StyledCardLeft, {
|
|
912
|
-
insetScale: "l",
|
|
913
|
-
children: jsx(CheckboxInput, {
|
|
914
|
-
isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
|
|
915
|
-
isChecked: areAllCustomFieldsChecked,
|
|
916
|
-
onChange: e => {
|
|
917
|
-
var _context5;
|
|
918
|
-
formik.setFieldValue('customFields', _mapInstanceProperty(_context5 = _valuesInstanceProperty(formik).customFields).call(_context5, customType => {
|
|
919
|
-
var _context6;
|
|
920
|
-
return _objectSpread$2(_objectSpread$2({}, customType), {}, {
|
|
921
|
-
fields: _mapInstanceProperty(_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
922
|
-
isChecked: e.target.checked
|
|
923
|
-
}))
|
|
924
|
-
});
|
|
925
|
-
}));
|
|
926
|
-
},
|
|
927
|
-
children: jsx(FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
|
|
928
|
-
})
|
|
929
|
-
})
|
|
930
|
-
}), jsx(Grid.Item, {
|
|
931
|
-
children: jsx(StyledCardRight, {
|
|
932
|
-
insetScale: "l",
|
|
933
|
-
children: jsxs(Spacings.Stack, {
|
|
934
|
-
scale: "s",
|
|
935
|
-
children: [jsxs(CheckboxInput, {
|
|
936
|
-
isReadOnly: true,
|
|
937
|
-
onChange: () => {},
|
|
938
|
-
isChecked: isAtLeastOneCustomFieldChecked,
|
|
939
|
-
children: [jsx(FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
|
|
940
|
-
}), jsx(CustomFieldsSelection, {
|
|
941
|
-
customFields: _valuesInstanceProperty(formik).customFields,
|
|
942
|
-
setFieldValue: formik.setFieldValue
|
|
943
|
-
})]
|
|
944
|
-
})
|
|
945
|
-
})
|
|
946
|
-
})]
|
|
947
|
-
})]
|
|
948
|
-
})]
|
|
1077
|
+
}), jsx(SearchTextInput, {
|
|
1078
|
+
placeholder: intl.formatMessage(messages.searchForFields),
|
|
1079
|
+
value: fieldSearchTerm,
|
|
1080
|
+
onChange: onSearchChangeThrottled,
|
|
1081
|
+
onReset: onSearchReset
|
|
1082
|
+
// TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
|
|
1083
|
+
,
|
|
1084
|
+
onSubmit: () => {}
|
|
1085
|
+
}), hasResults ? jsx(Card, {
|
|
1086
|
+
insetScale: "none",
|
|
1087
|
+
children: jsx(Grid, {
|
|
1088
|
+
gridAutoFlow: "row",
|
|
1089
|
+
gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
|
|
1090
|
+
children: _mapInstanceProperty(filteredGroups).call(filteredGroups, (group, index) => jsx(FieldGroupSection, {
|
|
1091
|
+
group: group,
|
|
1092
|
+
index: index,
|
|
1093
|
+
formik: formik
|
|
1094
|
+
}, group.groupLabel))
|
|
1095
|
+
})
|
|
1096
|
+
}) : jsx(NoSearchResults, {})]
|
|
949
1097
|
})
|
|
950
1098
|
})
|
|
951
1099
|
});
|
|
952
1100
|
};
|
|
953
|
-
const GeneralFieldsSelection = _ref5 => {
|
|
954
|
-
let fields = _ref5.fields,
|
|
955
|
-
setFieldValue = _ref5.setFieldValue;
|
|
956
|
-
return _mapInstanceProperty(fields).call(fields, field => jsxs(CheckboxInput, {
|
|
957
|
-
isChecked: field.isChecked,
|
|
958
|
-
isReadOnly: field.isRequired,
|
|
959
|
-
onChange: e => {
|
|
960
|
-
setFieldValue('fields', _mapInstanceProperty(fields).call(fields, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
961
|
-
isChecked: e.target.checked
|
|
962
|
-
}) : _field));
|
|
963
|
-
},
|
|
964
|
-
children: [field.label, " ", field.isRequired && '*']
|
|
965
|
-
}, field.name));
|
|
966
|
-
};
|
|
967
|
-
const CustomFieldsSelection = _ref6 => {
|
|
968
|
-
let customFields = _ref6.customFields,
|
|
969
|
-
setFieldValue = _ref6.setFieldValue;
|
|
970
|
-
return _mapInstanceProperty(customFields).call(customFields, customType => {
|
|
971
|
-
var _context7, _context8, _context10;
|
|
972
|
-
const areAllFieldsChecked = _everyInstanceProperty(_context7 = customType.fields).call(_context7, field => field.isChecked);
|
|
973
|
-
const isAtLeastOneFieldChecked = _someInstanceProperty(_context8 = customType.fields).call(_context8, field => field.isChecked);
|
|
974
|
-
return jsxs(Spacings.Stack, {
|
|
975
|
-
scale: "s",
|
|
976
|
-
children: [jsx(CheckboxInput, {
|
|
977
|
-
isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
|
|
978
|
-
isChecked: areAllFieldsChecked,
|
|
979
|
-
onChange: e => {
|
|
980
|
-
setFieldValue('customFields', _mapInstanceProperty(customFields).call(customFields, _customType => {
|
|
981
|
-
var _context9;
|
|
982
|
-
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
983
|
-
fields: _mapInstanceProperty(_context9 = _customType.fields).call(_context9, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
984
|
-
isChecked: e.target.checked
|
|
985
|
-
}))
|
|
986
|
-
}) : _customType;
|
|
987
|
-
}));
|
|
988
|
-
},
|
|
989
|
-
children: jsx(Text.Body, {
|
|
990
|
-
children: customType.type.label
|
|
991
|
-
})
|
|
992
|
-
}), jsxs(Spacings.Inline, {
|
|
993
|
-
scale: "l",
|
|
994
|
-
children: [jsx("div", {}), jsx(Spacings.Stack, {
|
|
995
|
-
scale: "s",
|
|
996
|
-
children: _mapInstanceProperty(_context10 = customType.fields).call(_context10, field => jsx(CheckboxInput, {
|
|
997
|
-
isChecked: field.isChecked,
|
|
998
|
-
onChange: e => {
|
|
999
|
-
setFieldValue('customFields', _mapInstanceProperty(customFields).call(customFields, _customType => {
|
|
1000
|
-
var _context11;
|
|
1001
|
-
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
1002
|
-
fields: _mapInstanceProperty(_context11 = _customType.fields).call(_context11, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
1003
|
-
isChecked: e.target.checked
|
|
1004
|
-
}) : _field)
|
|
1005
|
-
}) : _customType;
|
|
1006
|
-
}));
|
|
1007
|
-
},
|
|
1008
|
-
children: jsx(Text.Body, {
|
|
1009
|
-
children: field.label
|
|
1010
|
-
})
|
|
1011
|
-
}, field.name))
|
|
1012
|
-
})]
|
|
1013
|
-
})]
|
|
1014
|
-
}, customType.type.key);
|
|
1015
|
-
});
|
|
1016
|
-
};
|
|
1017
1101
|
|
|
1018
1102
|
process.env.NODE_ENV !== "production" ? {
|
|
1019
1103
|
renderProperties: PropTypes.func
|
|
@@ -1021,42 +1105,6 @@ process.env.NODE_ENV !== "production" ? {
|
|
|
1021
1105
|
|
|
1022
1106
|
const ExportResourcesContext = /*#__PURE__*/createContext();
|
|
1023
1107
|
|
|
1024
|
-
const ExportResourcesModalShape = PropTypes.shape({
|
|
1025
|
-
isOpen: PropTypes.bool,
|
|
1026
|
-
resourceType: PropTypes.string.isRequired,
|
|
1027
|
-
outputFormat: PropTypes.string,
|
|
1028
|
-
onClose: PropTypes.func,
|
|
1029
|
-
onExportSuccess: PropTypes.func,
|
|
1030
|
-
totalResourcesCount: PropTypes.number.isRequired,
|
|
1031
|
-
selectedResourceIds: PropTypes.array,
|
|
1032
|
-
// TODO: Circular reference
|
|
1033
|
-
fields: PropTypes.arrayOf(PropTypes.shape({
|
|
1034
|
-
name: PropTypes.string.isRequired,
|
|
1035
|
-
label: PropTypes.string,
|
|
1036
|
-
fields: PropTypes.arrayOf(PropTypes.shape({
|
|
1037
|
-
name: PropTypes.string.isRequired,
|
|
1038
|
-
label: PropTypes.string,
|
|
1039
|
-
isSelectedByDefault: PropTypes.bool,
|
|
1040
|
-
isRequired: PropTypes.bool
|
|
1041
|
-
}))
|
|
1042
|
-
})).isRequired,
|
|
1043
|
-
customFields: PropTypes.shape({
|
|
1044
|
-
type: PropTypes.shape({
|
|
1045
|
-
key: PropTypes.string.isRequired,
|
|
1046
|
-
label: PropTypes.string.isRequired,
|
|
1047
|
-
resourceTypeIds: PropTypes.arrayOf(PropTypes.string)
|
|
1048
|
-
}).isRequired,
|
|
1049
|
-
fields: PropTypes.arrayOf(PropTypes.shape({
|
|
1050
|
-
name: PropTypes.string.isRequired,
|
|
1051
|
-
label: PropTypes.string
|
|
1052
|
-
})).isRequired
|
|
1053
|
-
}),
|
|
1054
|
-
exportType: PropTypes.string,
|
|
1055
|
-
renderProperties: PropTypes.func
|
|
1056
|
-
}).isRequired;
|
|
1057
|
-
|
|
1058
|
-
function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1059
|
-
function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
1060
1108
|
const ExportResourcesProvider = props => {
|
|
1061
1109
|
const initialValues = useInitialValues(props);
|
|
1062
1110
|
const _useStartExportOperat = useStartExportOperation(props),
|
|
@@ -1097,10 +1145,6 @@ const ExportResourcesProvider = props => {
|
|
|
1097
1145
|
children: props.children
|
|
1098
1146
|
});
|
|
1099
1147
|
};
|
|
1100
|
-
ExportResourcesProvider.displayName = 'ExportResourcesProvider';
|
|
1101
|
-
ExportResourcesProvider.propTypes = process.env.NODE_ENV !== "production" ? _objectSpread$1(_objectSpread$1({}, ExportResourcesModalShape), {}, {
|
|
1102
|
-
children: PropTypes.node
|
|
1103
|
-
}) : {};
|
|
1104
1148
|
|
|
1105
1149
|
const CurrentStep = () => {
|
|
1106
1150
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
@@ -1112,22 +1156,101 @@ const CurrentStep = () => {
|
|
|
1112
1156
|
return steps[currentStep] || null;
|
|
1113
1157
|
};
|
|
1114
1158
|
|
|
1159
|
+
const loadMessages = locale => {
|
|
1160
|
+
const intlLocale = mapLocaleToIntlLocale(locale);
|
|
1161
|
+
switch (intlLocale) {
|
|
1162
|
+
case 'de':
|
|
1163
|
+
return import( /* webpackChunkName: "export-resources-modal-i18n-de" */'./de-cd6c45d3.esm.js');
|
|
1164
|
+
case 'es':
|
|
1165
|
+
return import( /* webpackChunkName: "export-resources-modal-i18n-es" */'./es-e544023d.esm.js');
|
|
1166
|
+
case 'fr-FR':
|
|
1167
|
+
return import( /* webpackChunkName: "export-resources-modal-i18n-fr-FR" */'./fr-FR-9d9081ee.esm.js');
|
|
1168
|
+
case 'zh-CN':
|
|
1169
|
+
return import( /* webpackChunkName: "export-resources-modal-i18n-zh-CN" */'./zh-CN-4780d88e.esm.js');
|
|
1170
|
+
case 'ja':
|
|
1171
|
+
return import( /* webpackChunkName: "export-resources-modal-i18n-ja" */'./ja-73c088a7.esm.js');
|
|
1172
|
+
case 'pt-BR':
|
|
1173
|
+
return import( /* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-b37d730b.esm.js');
|
|
1174
|
+
default:
|
|
1175
|
+
return import( /* webpackChunkName: "export-resources-modal-i18n-en" */'./en-3a9aa2d4.esm.js');
|
|
1176
|
+
}
|
|
1177
|
+
};
|
|
1178
|
+
|
|
1179
|
+
// eslint-disable-next-line import/prefer-default-export
|
|
1180
|
+
const loadI18n = async locale => {
|
|
1181
|
+
try {
|
|
1182
|
+
const messages = await loadMessages(locale);
|
|
1183
|
+
return messages.default || messages;
|
|
1184
|
+
} catch (error) {
|
|
1185
|
+
// eslint-disable-next-line no-console
|
|
1186
|
+
console.warn("Something went wrong while loading the export-resources-modal messages for ".concat(locale), error);
|
|
1187
|
+
reportErrorToSentry(new Error("Something went wrong while loading the export-resources-modal messages for ".concat(locale)), {
|
|
1188
|
+
extra: error
|
|
1189
|
+
});
|
|
1190
|
+
return {};
|
|
1191
|
+
}
|
|
1192
|
+
};
|
|
1193
|
+
|
|
1194
|
+
const useAsyncIntlMessages = (locale, loader) => {
|
|
1195
|
+
const _useState = useState({
|
|
1196
|
+
isLoading: true,
|
|
1197
|
+
messages: undefined,
|
|
1198
|
+
error: undefined
|
|
1199
|
+
}),
|
|
1200
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1201
|
+
state = _useState2[0],
|
|
1202
|
+
setState = _useState2[1];
|
|
1203
|
+
useEffect(() => {
|
|
1204
|
+
let _isUnmounting = false;
|
|
1205
|
+
async function load() {
|
|
1206
|
+
try {
|
|
1207
|
+
if (!_isUnmounting) {
|
|
1208
|
+
const messages = await loader(locale);
|
|
1209
|
+
setState({
|
|
1210
|
+
isLoading: false,
|
|
1211
|
+
messages
|
|
1212
|
+
});
|
|
1213
|
+
}
|
|
1214
|
+
} catch (error) {
|
|
1215
|
+
setState({
|
|
1216
|
+
isLoading: false,
|
|
1217
|
+
error
|
|
1218
|
+
});
|
|
1219
|
+
}
|
|
1220
|
+
}
|
|
1221
|
+
if (locale) load();
|
|
1222
|
+
return () => {
|
|
1223
|
+
_isUnmounting = true;
|
|
1224
|
+
};
|
|
1225
|
+
}, [locale, loader]);
|
|
1226
|
+
return state;
|
|
1227
|
+
};
|
|
1228
|
+
|
|
1115
1229
|
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
1116
1230
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
1117
1231
|
const ExportResourcesModal = props => {
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
1232
|
+
const _useApplicationContex = useApplicationContext(context => ({
|
|
1233
|
+
locale: context.user && context.user.locale
|
|
1234
|
+
})),
|
|
1235
|
+
locale = _useApplicationContex.locale;
|
|
1236
|
+
const messages = useAsyncIntlMessages('en', loadI18n);
|
|
1237
|
+
if (!props.isOpen || messages.isLoading) return null;
|
|
1238
|
+
return jsx(IntlProvider, {
|
|
1239
|
+
locale: locale,
|
|
1240
|
+
messages: messages.messages,
|
|
1241
|
+
children: jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
|
|
1242
|
+
children: jsx(CurrentStep, {})
|
|
1243
|
+
}))
|
|
1244
|
+
});
|
|
1122
1245
|
};
|
|
1123
1246
|
ExportResourcesModal.displayName = 'ExportResourcesModal';
|
|
1124
|
-
ExportResourcesModal.propTypes = process.env.NODE_ENV !== "production" ? ExportResourcesModalShape : {};
|
|
1125
1247
|
ExportResourcesModal.defaultProps = {
|
|
1126
1248
|
isOpen: false,
|
|
1127
1249
|
selectedResourceIds: [],
|
|
1128
1250
|
exportType: EXPORT_TYPES.ALL,
|
|
1129
1251
|
outputFormat: OUTPUT_FORMATS.CSV,
|
|
1130
|
-
customFields: []
|
|
1252
|
+
customFields: [],
|
|
1253
|
+
fieldGroups: []
|
|
1131
1254
|
};
|
|
1132
1255
|
|
|
1133
1256
|
export { EXPORTABLE_RESOURCES, EXPORT_TYPES, ExportResourcesModal as default };
|