@commercetools-frontend-extensions/export-resources-modal 0.0.0-canary-20240507102123

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.
@@ -0,0 +1,1219 @@
1
+ import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
2
+ import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
3
+ import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
4
+ import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
5
+ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
6
+ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
7
+ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
8
+ import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
+ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
+ import { Text, TextInput, Link, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, SearchTextInput, Grid } from '@commercetools-frontend/ui-kit';
11
+ import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
12
+ import '@commercetools-uikit/design-system';
13
+ import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
14
+ import _valuesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/values';
15
+ import { FormDialog } from '@commercetools-frontend/application-components';
16
+ import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
17
+ import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
18
+ import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
19
+ import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
20
+ import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits';
21
+ import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn';
22
+ import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
23
+ import _wrapNativeSuper from '@babel/runtime-corejs3/helpers/esm/wrapNativeSuper';
24
+ import React, { useContext, createContext } from 'react';
25
+ import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
26
+ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
27
+ import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
28
+ import moment from 'moment';
29
+ import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
30
+ import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
31
+ import omitEmpty from 'omit-empty-es';
32
+ import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
33
+ import _flatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat';
34
+ import _Set from '@babel/runtime-corejs3/core-js-stable/set';
35
+ import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort';
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 { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
39
+ import { useShowNotification } from '@commercetools-frontend/actions-global';
40
+ import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants';
41
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
42
+ import _styled from '@emotion/styled/base';
43
+ import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
44
+ import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
45
+ import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
46
+ import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
47
+ import throttle from 'lodash/throttle';
48
+ import { css } from '@emotion/react';
49
+ import get from 'lodash/get';
50
+ import PropTypes from 'prop-types';
51
+ import { useFormik } from 'formik';
52
+
53
+ function getBold(msg) {
54
+ return jsx(Text.Body, {
55
+ as: "span",
56
+ isBold: true,
57
+ children: msg
58
+ });
59
+ }
60
+
61
+ function getNewLine() {
62
+ return jsx("br", {});
63
+ }
64
+
65
+ var messages = defineMessages({
66
+ modalTitle: {
67
+ id: 'ExportResourcesModal.modalTitle',
68
+ description: 'Label for the modal title',
69
+ defaultMessage: 'Export {resourceType}'
70
+ },
71
+ outputFormat: {
72
+ id: 'ExportResourcesModal.outputFormat',
73
+ description: 'File format like (csv, xls, ...etc)',
74
+ defaultMessage: 'File format'
75
+ },
76
+ fileName: {
77
+ id: 'ExportResourcesModal.fileName',
78
+ description: 'exported file name',
79
+ defaultMessage: 'File name'
80
+ },
81
+ locale: {
82
+ id: 'ExportResourcesModal.locale',
83
+ description: 'Locale',
84
+ defaultMessage: 'Locale'
85
+ },
86
+ exportSelection: {
87
+ id: 'ExportResourcesModal.exportSelection',
88
+ description: 'Export selection',
89
+ defaultMessage: 'Export selection'
90
+ },
91
+ exportAllResources: {
92
+ id: 'ExportResourcesModal.exportAllResources',
93
+ description: 'Export All selection',
94
+ defaultMessage: 'Export all {resourceType} ({count})'
95
+ },
96
+ exportOnlySelectedResources: {
97
+ id: 'ExportResourcesModal.exportOnlySelectedResources',
98
+ description: 'Export only selected resources',
99
+ defaultMessage: 'Export selected {resourceType} ({count})'
100
+ },
101
+ exportAllMessage: {
102
+ id: 'ExportResourcesModal.exportAllMessage',
103
+ description: 'All resources will be exported',
104
+ defaultMessage: 'All <b>{count}</b> {resourceType} will be exported.'
105
+ },
106
+ exportMatchingMessage: {
107
+ id: 'ExportResourcesModal.exportMatchingMessage',
108
+ description: 'resources will be exported',
109
+ defaultMessage: '<b>{count}</b> {resourceType} will be exported.'
110
+ },
111
+ exportSelectedMessage: {
112
+ id: 'ExportResourcesModal.exportSelectedMessage',
113
+ description: 'resources are selected and will be exported',
114
+ defaultMessage: '<b>{count}</b> {resourceType} are selected and will be exported.'
115
+ },
116
+ exportBasedOnMyViewsMessage: {
117
+ id: 'ExportResourcesModal.exportBasedOnMyViewsMessage',
118
+ description: 'Select Export setttings based on my views',
119
+ defaultMessage: 'Select export settings based on:'
120
+ },
121
+ propertiesPanelLabel: {
122
+ id: 'ExportResourcesModal.propertiesPanelLabel',
123
+ description: 'properties panel label',
124
+ defaultMessage: 'Properties'
125
+ },
126
+ exportOperationSuccessMessage: {
127
+ id: 'ExportResourcesModal.exportOperationSuccessMessage',
128
+ description: 'Success message',
129
+ defaultMessage: '<b>Your export has started.</b> <newline></newline><logsLink>Go to Export logs</logsLink> to view the progress and download the file.'
130
+ },
131
+ nothingApplied: {
132
+ id: 'ExportResourcesModal.nothingApplied',
133
+ description: 'Shown when there is no filter applied',
134
+ defaultMessage: 'nothing applied'
135
+ },
136
+ selectAllLocales: {
137
+ id: 'ExportResourcesModal.selectAllLocales',
138
+ description: 'label for "Select all locales" checkbox',
139
+ defaultMessage: 'Select all locales'
140
+ },
141
+ missingFileNameError: {
142
+ id: 'ExportResourcesModal.missingFileNameError',
143
+ description: 'Error when file name field is missing',
144
+ defaultMessage: 'Please enter a file name'
145
+ },
146
+ invalidFileNameError: {
147
+ id: 'ExportResourcesModal.invalidFileNameError',
148
+ description: 'Error when file name field is not valid',
149
+ defaultMessage: 'File name may only contain alphanumeric characters, hyphens and underscores'
150
+ },
151
+ missingLocaleError: {
152
+ id: 'ExportResourcesModal.missingLocaleError',
153
+ description: 'Error when no locale is selected',
154
+ defaultMessage: 'Please select at least one locale'
155
+ },
156
+ myViews: {
157
+ id: 'ExportResourcesModal.myViews',
158
+ description: 'Label for "My Views" Select Field',
159
+ defaultMessage: 'My Views'
160
+ },
161
+ selectFieldsToExport: {
162
+ id: 'ExportResourcesModal.selectFieldsToExport',
163
+ defaultMessage: 'Select fields to export'
164
+ },
165
+ back: {
166
+ id: 'ExportResourcesModal.back',
167
+ description: 'Label for "Back" button',
168
+ defaultMessage: 'Back'
169
+ },
170
+ startExport: {
171
+ id: 'ExportResourcesModal.startExport',
172
+ description: 'Label for "Start export" button',
173
+ defaultMessage: 'Start export'
174
+ },
175
+ continue: {
176
+ id: 'ExportResourcesModal.continue',
177
+ description: 'Label for "Continue" button',
178
+ defaultMessage: 'Continue'
179
+ },
180
+ fieldDefinitions: {
181
+ id: 'ExportResourcesModal.fieldDefinitions',
182
+ description: 'Label for "Field definitions" link',
183
+ defaultMessage: 'Field definitions'
184
+ },
185
+ allGeneralFields: {
186
+ id: 'ExportResourcesModal.allGeneralFields',
187
+ description: 'Label for "All general fields" checkbox',
188
+ defaultMessage: 'All general fields'
189
+ },
190
+ allCustomFields: {
191
+ id: 'ExportResourcesModal.allCustomFields',
192
+ description: 'Label for "All custom fields" checkbox',
193
+ defaultMessage: 'All custom fields'
194
+ },
195
+ customTypeKeyAndTypeId: {
196
+ id: 'ExportResourcesModal.customTypeKeyAndTypeId',
197
+ description: 'Label for "Custom type key and typeId" checkbox',
198
+ defaultMessage: 'Custom type key and typeId'
199
+ },
200
+ unexpectedError: {
201
+ id: 'ExportResourcesModal.unexpectedError',
202
+ description: 'Generic notification message when starting export process fails',
203
+ defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
204
+ },
205
+ searchForFields: {
206
+ id: 'ExportResourcesModal.searchForFields',
207
+ description: 'Placeholder for "Search for fields" search input',
208
+ defaultMessage: 'Search for fields'
209
+ },
210
+ thereAreNoResults: {
211
+ id: 'ExportResourcesModal.thereAreNoResults',
212
+ description: 'No search results message',
213
+ defaultMessage: 'There are no results that match your search.'
214
+ },
215
+ suggestions: {
216
+ id: 'ExportResourcesModal.suggestions',
217
+ description: 'In Export fields selection - Suggestions message',
218
+ defaultMessage: 'Suggestions:'
219
+ },
220
+ checkTheSpelling: {
221
+ id: 'ExportResourcesModal.checkTheSpelling',
222
+ description: 'In Export fields selection - Check the spelling message',
223
+ defaultMessage: 'Check the spelling.'
224
+ },
225
+ searchByEnteringTheExactFieldName: {
226
+ id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
227
+ description: 'In Export fields selection - Search by entering the exact field name message',
228
+ defaultMessage: 'Try searching by entering the exact field name.'
229
+ }
230
+ });
231
+
232
+ function ownKeys$6(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
233
+ function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$6(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$6(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
234
+ function renderFileNameError(key) {
235
+ switch (key) {
236
+ case 'missing':
237
+ return jsx(FormattedMessage, _objectSpread$6({}, messages.missingFileNameError));
238
+ case 'invalidInput':
239
+ return jsx(FormattedMessage, _objectSpread$6({}, messages.invalidFileNameError));
240
+ default:
241
+ return null;
242
+ }
243
+ }
244
+ function renderLocaleError(key) {
245
+ switch (key) {
246
+ case 'missing':
247
+ return jsx(FormattedMessage, _objectSpread$6({}, messages.missingLocaleError));
248
+ default:
249
+ return null;
250
+ }
251
+ }
252
+
253
+ const Z_INDEX_DROPDOWN = 30000;
254
+
255
+ const EXPORT_OPERATION_STATES = {
256
+ PROCESSING: 'processing',
257
+ COMPLETED: 'completed',
258
+ FAILED: 'failed'
259
+ };
260
+
261
+ const EXPORT_TYPES = {
262
+ ALL: 'all',
263
+ FILTERED: 'filtered',
264
+ SELECTED: 'selected'
265
+ };
266
+
267
+ const EXPORTABLE_RESOURCES = {
268
+ CATEGORY: 'category',
269
+ PRODUCT: 'product',
270
+ DISCOUNT_CODE: 'discountCode'
271
+ };
272
+
273
+ const OUTPUT_FORMATS = {
274
+ JSON: 'json',
275
+ CSV: 'csv'
276
+ };
277
+ const OUTPUT_FORMAT_OPTIONS = [{
278
+ value: OUTPUT_FORMATS.CSV,
279
+ label: 'CSV'
280
+ }, {
281
+ value: OUTPUT_FORMATS.JSON,
282
+ label: 'JSON'
283
+ }];
284
+
285
+ const FIELD_DEFINITIONS_URLS = {
286
+ category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
287
+ };
288
+
289
+ function _createSuper$4(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$4(); 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); }; }
290
+ function _isNativeReflectConstruct$4() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$4 = function () { return !!t; })(); }
291
+ let UnexpectedExportTypeError = /*#__PURE__*/function (_Error) {
292
+ _inherits(UnexpectedExportTypeError, _Error);
293
+ var _super = _createSuper$4(UnexpectedExportTypeError);
294
+ function UnexpectedExportTypeError(exportType) {
295
+ var _this;
296
+ _classCallCheck(this, UnexpectedExportTypeError);
297
+ _this = _super.call(this, "Unexpected export type: ".concat(exportType));
298
+ _this.name = 'UnexpectedExportTypeError';
299
+ return _this;
300
+ }
301
+ return _createClass(UnexpectedExportTypeError);
302
+ }( /*#__PURE__*/_wrapNativeSuper(Error));
303
+
304
+ function _createSuper$3(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$3(); 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$3() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$3 = function () { return !!t; })(); }
306
+ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
307
+ _inherits(MissingExportResourceProviderError, _Error);
308
+ var _super = _createSuper$3(MissingExportResourceProviderError);
309
+ function MissingExportResourceProviderError() {
310
+ var _this;
311
+ _classCallCheck(this, MissingExportResourceProviderError);
312
+ _this = _super.call(this, 'useExportResourcesContext must be used within ExportResourcesProvider');
313
+ _this.name = 'MissingExportResourceProviderError';
314
+ return _this;
315
+ }
316
+ return _createClass(MissingExportResourceProviderError);
317
+ }( /*#__PURE__*/_wrapNativeSuper(Error));
318
+
319
+ 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); }; }
320
+ function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
321
+ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
322
+ _inherits(UnexpectedExportOperationStateError, _Error);
323
+ var _super = _createSuper$2(UnexpectedExportOperationStateError);
324
+ function UnexpectedExportOperationStateError(state) {
325
+ var _this;
326
+ _classCallCheck(this, UnexpectedExportOperationStateError);
327
+ _this = _super.call(this, "Unexpected export operation state \"".concat(state, "\""));
328
+ _this.name = 'UnexpectedExportOperationStateError';
329
+ return _this;
330
+ }
331
+ return _createClass(UnexpectedExportOperationStateError);
332
+ }( /*#__PURE__*/_wrapNativeSuper(Error));
333
+
334
+ 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); }; }
335
+ function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
336
+ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
337
+ _inherits(UnexpectedResourceTypeError, _Error);
338
+ var _super = _createSuper$1(UnexpectedResourceTypeError);
339
+ function UnexpectedResourceTypeError(resourceType) {
340
+ var _this;
341
+ _classCallCheck(this, UnexpectedResourceTypeError);
342
+ _this = _super.call(this, "Unexpected resource type: ".concat(resourceType));
343
+ _this.name = 'UnexpectedResourceTypeError';
344
+ return _this;
345
+ }
346
+ return _createClass(UnexpectedResourceTypeError);
347
+ }( /*#__PURE__*/_wrapNativeSuper(Error));
348
+
349
+ 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); }; }
350
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
351
+ let InvalidResponseError = /*#__PURE__*/function (_Error) {
352
+ _inherits(InvalidResponseError, _Error);
353
+ var _super = _createSuper(InvalidResponseError);
354
+ function InvalidResponseError(message) {
355
+ var _this;
356
+ _classCallCheck(this, InvalidResponseError);
357
+ _this = _super.call(this, message);
358
+ _this.name = 'InvalidResponseError';
359
+ return _this;
360
+ }
361
+ return _createClass(InvalidResponseError);
362
+ }( /*#__PURE__*/_wrapNativeSuper(Error));
363
+
364
+ function useExportResourcesContext() {
365
+ const context = useContext(ExportResourcesContext);
366
+ if (!context) {
367
+ throw new MissingExportResourceProviderError();
368
+ }
369
+ return context;
370
+ }
371
+
372
+ function checkAtLeastOneFieldChecked$1(fields) {
373
+ return _someInstanceProperty(fields).call(fields, field => {
374
+ if (field.fields) {
375
+ return field.isChecked || checkAtLeastOneFieldChecked$1(field.fields);
376
+ }
377
+ return field.isChecked;
378
+ });
379
+ }
380
+ function validate(_ref) {
381
+ let values = _valuesInstanceProperty(_ref),
382
+ step = _ref.step;
383
+ const fileName = values.fileName,
384
+ locales = values.locales,
385
+ groups = values.groups;
386
+ const errors = {
387
+ fileName: {},
388
+ locales: {},
389
+ fields: {}
390
+ };
391
+ if (TextInput.isEmpty(fileName)) {
392
+ // @ts-ignore
393
+ errors.fileName.missing = true;
394
+ } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
395
+ // @ts-ignore
396
+ errors.fileName.invalidInput = true;
397
+ }
398
+ if (locales.length < 1) {
399
+ // @ts-ignore
400
+ errors.locales.missing = true;
401
+ }
402
+ if (step === 2) {
403
+ const allFields = _reduceInstanceProperty(groups).call(groups, (acc, group) => _concatInstanceProperty(acc).call(acc, group.fields), []);
404
+ const checkedFieldsCount = _filterInstanceProperty(allFields).call(allFields, field => {
405
+ if (field.fields) return checkAtLeastOneFieldChecked$1(field.fields);
406
+ return !field.isRequired && !field.isReadOnly && field.isChecked;
407
+ }).length;
408
+ if (checkedFieldsCount < 1) {
409
+ // @ts-ignore
410
+ errors.fields.missing = true;
411
+ }
412
+ }
413
+ return omitEmpty(errors);
414
+ }
415
+
416
+ 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; }
417
+ 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; }
418
+ function resourceTypeToDisplayName(_ref) {
419
+ let resourceType = _ref.resourceType,
420
+ _ref$isUpperCase = _ref.isUpperCase,
421
+ isUpperCase = _ref$isUpperCase === void 0 ? false : _ref$isUpperCase,
422
+ _ref$isPlural = _ref.isPlural,
423
+ isPlural = _ref$isPlural === void 0 ? false : _ref$isPlural;
424
+ let displayName;
425
+ switch (resourceType) {
426
+ case EXPORTABLE_RESOURCES.CATEGORY:
427
+ displayName = isPlural ? 'Categories' : 'Category';
428
+ break;
429
+ case EXPORTABLE_RESOURCES.PRODUCT:
430
+ displayName = isPlural ? 'Products' : 'Product';
431
+ break;
432
+ case EXPORTABLE_RESOURCES.DISCOUNT_CODE:
433
+ displayName = isPlural ? 'Discount codes' : 'Discount code';
434
+ break;
435
+ default:
436
+ throw UnexpectedResourceTypeError(resourceType);
437
+ }
438
+ return isUpperCase ? displayName : displayName.toLowerCase();
439
+ }
440
+ function mapLocalesToOptions(locales) {
441
+ return _mapInstanceProperty(locales).call(locales, locale => ({
442
+ value: locale,
443
+ label: locale
444
+ }));
445
+ }
446
+ function isFilledArray(maybeArray) {
447
+ return _Array$isArray(maybeArray) && maybeArray.length;
448
+ }
449
+ function appendCsvOrJsonExtensionIfAbsent(fileName, fileFormat) {
450
+ var _context;
451
+ const extensionRegex = /\.(csv|json)$/i;
452
+ if (!extensionRegex.test(fileName)) return _concatInstanceProperty(_context = "".concat(fileName, ".")).call(_context, fileFormat);
453
+ return fileName;
454
+ }
455
+ function flattenNestedFields(fields) {
456
+ const result = (fields === null || fields === void 0 ? void 0 : _mapInstanceProperty(fields).call(fields, field => {
457
+ if (isFilledArray(field.fields)) {
458
+ var _context2;
459
+ return _mapInstanceProperty(_context2 = flattenNestedFields(field.fields)).call(_context2, nestedField => {
460
+ var _context3;
461
+ return _objectSpread$5(_objectSpread$5({}, nestedField), {}, {
462
+ name: _concatInstanceProperty(_context3 = "".concat(field.name, ".")).call(_context3, nestedField.name)
463
+ });
464
+ });
465
+ }
466
+ return field;
467
+ })) || [];
468
+ return _flatInstanceProperty(result).call(result);
469
+ }
470
+ function checkRequiredFields(fields) {
471
+ return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
472
+ isChecked: true
473
+ }) : field);
474
+ }
475
+ function getExportLogsLink(projectKey, msg) {
476
+ return jsx(Link, {
477
+ to: "/".concat(projectKey, "/operations/export/logs"),
478
+ children: msg
479
+ });
480
+ }
481
+ function setInitialCheckedStateForCustomFields(customFields) {
482
+ return _mapInstanceProperty(customFields).call(customFields, customType => {
483
+ var _context4;
484
+ return _objectSpread$5(_objectSpread$5({}, customType), {}, {
485
+ fields: _mapInstanceProperty(_context4 = customType.fields).call(_context4, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
486
+ isChecked: false
487
+ }))
488
+ });
489
+ });
490
+ }
491
+ const extractFieldNamesAndAdditionalFieldExtensions = fields => {
492
+ const result = _reduceInstanceProperty(fields).call(fields, (acc, field) => {
493
+ if (field.additionalFieldExtensions) {
494
+ return [...acc, ...field.additionalFieldExtensions, field.name];
495
+ }
496
+ return [...acc, field.name];
497
+ }, []);
498
+ return [...new _Set(result)];
499
+ };
500
+ function sortFieldsByFieldOrder(_ref2) {
501
+ let fields = _ref2.fields,
502
+ fieldOrder = _ref2.fieldOrder;
503
+ if (isFilledArray(fieldOrder)) {
504
+ return _sortInstanceProperty(fields).call(fields, (a, b) => {
505
+ let orderA = _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a) !== -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a) : _indexOfInstanceProperty(fieldOrder).call(fieldOrder, a.split('.')[0]);
506
+ let orderB = _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b) !== -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b) : _indexOfInstanceProperty(fieldOrder).call(fieldOrder, b.split('.')[0]);
507
+
508
+ // If a field is not 'custom',then consider it as '*'
509
+ orderA = orderA === -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, '*') : orderA;
510
+ orderB = orderB === -1 ? _indexOfInstanceProperty(fieldOrder).call(fieldOrder, '*') : orderB;
511
+ return orderA - orderB;
512
+ });
513
+ }
514
+ return fields;
515
+ }
516
+
517
+ // TODO: remove this function when filters are passed directly from parent views
518
+ // This function is temporary and will be removed in the future
519
+ // Later, filters will be passed directly from parent views (category, product...) instead of being built within the Export resources modal
520
+ // The `selectedResourceIds` prop will also be removed
521
+ function tmpBuildFilters(selectedResourceIds) {
522
+ if (!selectedResourceIds || (selectedResourceIds === null || selectedResourceIds === void 0 ? void 0 : selectedResourceIds.length) === 0) return undefined;
523
+ const formattedIds = _mapInstanceProperty(selectedResourceIds).call(selectedResourceIds, id => "\"".concat(id, "\"")).join(', ');
524
+ return ["id in (".concat(formattedIds, ")")];
525
+ }
526
+
527
+ 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; }
528
+ 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; }
529
+ const updateFieldGroupsWithIsCheckedValue = groups => {
530
+ const updateFields = (fields, parentChecked) => {
531
+ return _mapInstanceProperty(fields).call(fields, field => {
532
+ var _field$isRequired;
533
+ let isChecked = ((_field$isRequired = field.isRequired) !== null && _field$isRequired !== void 0 ? _field$isRequired : !field.isReadOnly && field.isSelectedByDefault) || parentChecked;
534
+ if (field.fields) {
535
+ const updatedFields = updateFields(field.fields, isChecked);
536
+ isChecked = false;
537
+ field.fields = updatedFields;
538
+ }
539
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
540
+ isChecked
541
+ });
542
+ });
543
+ };
544
+ return _mapInstanceProperty(groups).call(groups, group => {
545
+ const updatedFields = updateFields(group.fields, false);
546
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
547
+ fields: updatedFields
548
+ });
549
+ });
550
+ };
551
+ const updateFieldGroupWithAdditionalFieldExtensions = groups => {
552
+ function updateAdditionalFieldExtensions(fields, additionalFieldExtensions) {
553
+ return _mapInstanceProperty(fields).call(fields, field => {
554
+ const updatedAdditionalFieldExtensions = [...additionalFieldExtensions, ...(field.additionalFieldExtensions || [])];
555
+ if (field.fields) {
556
+ field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
557
+ }
558
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
559
+ additionalFieldExtensions: updatedAdditionalFieldExtensions
560
+ });
561
+ });
562
+ }
563
+ return _mapInstanceProperty(groups).call(groups, group => {
564
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
565
+ fields: updateAdditionalFieldExtensions(group.fields, group.additionalFieldExtensions || [])
566
+ });
567
+ });
568
+ };
569
+
570
+ const _excluded = ["isSelectedByDefault"];
571
+ 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; }
572
+ 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; }
573
+ const useInitialValues = props => {
574
+ var _context;
575
+ const todayFormatted = moment().format('DD-MM-YY_HH-mm');
576
+ const _useApplicationContex = useApplicationContext(applicationContext => ({
577
+ locale: applicationContext.dataLocale
578
+ })),
579
+ locale = _useApplicationContex.locale;
580
+ const fields = _mapInstanceProperty(_context = flattenNestedFields(props.fields)).call(_context, _ref => {
581
+ let isSelectedByDefault = _ref.isSelectedByDefault,
582
+ field = _objectWithoutProperties(_ref, _excluded);
583
+ return _objectSpread$3(_objectSpread$3({}, field), {}, {
584
+ isChecked: isSelectedByDefault !== null && isSelectedByDefault !== void 0 ? isSelectedByDefault : true
585
+ });
586
+ });
587
+ const groups = updateFieldGroupsWithIsCheckedValue(props.fieldGroups);
588
+ return React.useMemo(() => {
589
+ var _context2;
590
+ return {
591
+ outputFormat: props.outputFormat,
592
+ fileName: _concatInstanceProperty(_context2 = "".concat(resourceTypeToDisplayName({
593
+ resourceType: props.resourceType,
594
+ isUpperCase: true,
595
+ isPlural: true
596
+ }), "_Export_")).call(_context2, todayFormatted),
597
+ locales: [locale],
598
+ fields: checkRequiredFields(fields),
599
+ customFields: setInitialCheckedStateForCustomFields(props.customFields),
600
+ groups: updateFieldGroupWithAdditionalFieldExtensions(groups)
601
+ };
602
+ }, [props, locale, todayFormatted, fields, groups]);
603
+ };
604
+
605
+ async function createExportOperation(_ref) {
606
+ let projectKey = _ref.projectKey,
607
+ resourceType = _ref.resourceType,
608
+ fileName = _ref.fileName,
609
+ fileFormat = _ref.fileFormat,
610
+ fields = _ref.fields,
611
+ locales = _ref.locales,
612
+ filters = _ref.filters,
613
+ asyncDispatchFn = _ref.asyncDispatchFn;
614
+ const uri = "/proxy/export/".concat(projectKey, "/export-operations");
615
+ const response = await asyncDispatchFn(actions.post({
616
+ // FIXME: EXPORT is undefined
617
+ mcApiProxyTarget: MC_API_PROXY_TARGETS.EXPORT,
618
+ uri: uri,
619
+ headers: {
620
+ accept: 'application/json'
621
+ },
622
+ payload: {
623
+ resourceType,
624
+ fileName,
625
+ fileFormat,
626
+ fields,
627
+ locales,
628
+ filters
629
+ }
630
+ }));
631
+ if (!response.state) throw new InvalidResponseError('Invalid response');
632
+ return response;
633
+ }
634
+
635
+ const useStartExportOperation = props => {
636
+ const intl = useIntl();
637
+ const asyncDispatch = useAsyncDispatch();
638
+ const showNotification = useShowNotification();
639
+ const _useApplicationContex = useApplicationContext(applicationContext => {
640
+ var _applicationContext$p;
641
+ return {
642
+ locale: applicationContext.dataLocale,
643
+ projectKey: (_applicationContext$p = applicationContext.project) === null || _applicationContext$p === void 0 ? void 0 : _applicationContext$p.key
644
+ };
645
+ }),
646
+ projectKey = _useApplicationContex.projectKey;
647
+ const extractFieldsFromGroups = groups => {
648
+ let selectedGeneralFields = [];
649
+ const getSelectedFields = fields => {
650
+ return _filterInstanceProperty(fields).call(fields, field => {
651
+ var _field$isChecked;
652
+ if (field.fields) {
653
+ return getSelectedFields(field.fields);
654
+ }
655
+ if (field.isChecked) selectedGeneralFields.push(field);
656
+ return (_field$isChecked = field.isChecked) !== null && _field$isChecked !== void 0 ? _field$isChecked : false;
657
+ });
658
+ };
659
+ _forEachInstanceProperty(groups).call(groups, group => {
660
+ getSelectedFields(group.fields);
661
+ });
662
+ return sortFieldsByFieldOrder({
663
+ fields: extractFieldNamesAndAdditionalFieldExtensions(selectedGeneralFields),
664
+ fieldOrder: props.fieldOrder
665
+ });
666
+ };
667
+ const startExportOperation = async values => {
668
+ try {
669
+ const fields = extractFieldsFromGroups(values.groups);
670
+ const filters = tmpBuildFilters(props.selectedResourceIds);
671
+ const response = await createExportOperation({
672
+ projectKey,
673
+ resourceType: props.resourceType,
674
+ fileName: appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
675
+ fileFormat: values.outputFormat,
676
+ locales: values.locales,
677
+ fields,
678
+ filters,
679
+ asyncDispatchFn: asyncDispatch
680
+ });
681
+ switch (response.state) {
682
+ case EXPORT_OPERATION_STATES.PROCESSING:
683
+ case EXPORT_OPERATION_STATES.COMPLETED:
684
+ showNotification({
685
+ kind: 'info',
686
+ domain: DOMAINS.SIDE,
687
+ // @ts-ignore
688
+ text: intl.formatMessage(messages.exportOperationSuccessMessage, {
689
+ newline: getNewLine,
690
+ logsLink: msg => getExportLogsLink(projectKey, msg),
691
+ b: getBold
692
+ })
693
+ }, {
694
+ dismissAfter: 5000
695
+ });
696
+ if (typeof props.onExportSuccess === 'function') props.onExportSuccess();
697
+ break;
698
+ default:
699
+ throw new UnexpectedExportOperationStateError(response.state);
700
+ }
701
+ } catch (error) {
702
+ // TODO: custom error messages for each error type
703
+ showNotification({
704
+ text: intl.formatMessage(messages.unexpectedError),
705
+ kind: 'error',
706
+ domain: DOMAINS.PAGE
707
+ });
708
+ } finally {
709
+ if (typeof props.onClose === 'function') props.onClose();
710
+ }
711
+ };
712
+ return {
713
+ startExportOperation
714
+ };
715
+ };
716
+
717
+ 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; }
718
+ 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; }
719
+ function ExportTextMessage() {
720
+ const intl = useIntl();
721
+ const _useExportResourcesCo = useExportResourcesContext(),
722
+ resourceType = _useExportResourcesCo.resourceType,
723
+ totalResourcesCount = _useExportResourcesCo.totalResourcesCount,
724
+ selectedResourceIds = _useExportResourcesCo.selectedResourceIds,
725
+ exportType = _useExportResourcesCo.exportType;
726
+ const resourceTypePlural = resourceTypeToDisplayName({
727
+ resourceType: resourceType,
728
+ isPlural: true
729
+ });
730
+ let message;
731
+ let count;
732
+ switch (exportType) {
733
+ case EXPORT_TYPES.ALL:
734
+ message = messages.exportAllMessage;
735
+ count = totalResourcesCount;
736
+ break;
737
+ case EXPORT_TYPES.SELECTED:
738
+ message = messages.exportSelectedMessage;
739
+ count = selectedResourceIds.length;
740
+ break;
741
+ default:
742
+ throw new UnexpectedExportTypeError(exportType);
743
+ }
744
+ return jsx(Text.Body, {
745
+ "data-testid": "export-description",
746
+ intlMessage: _objectSpread$2(_objectSpread$2({}, message), {}, {
747
+ values: {
748
+ count: intl.formatNumber(count),
749
+ resourceType: resourceTypePlural,
750
+ b: getBold
751
+ }
752
+ })
753
+ });
754
+ }
755
+
756
+ const ExportFileSettingsStep = () => {
757
+ const intl = useIntl();
758
+ const _useExportResourcesCo = useExportResourcesContext(),
759
+ formik = _useExportResourcesCo.formik,
760
+ resourceType = _useExportResourcesCo.resourceType,
761
+ onClose = _useExportResourcesCo.onClose;
762
+ const resourceTypePlural = resourceTypeToDisplayName({
763
+ resourceType: resourceType,
764
+ isPlural: true
765
+ });
766
+ const _useApplicationContex = useApplicationContext(applicationContext => {
767
+ var _applicationContext$p;
768
+ return {
769
+ locale: applicationContext.dataLocale,
770
+ locales: ((_applicationContext$p = applicationContext.project) === null || _applicationContext$p === void 0 ? void 0 : _applicationContext$p.languages) || []
771
+ };
772
+ }),
773
+ locales = _useApplicationContex.locales,
774
+ locale = _useApplicationContex.locale;
775
+ const areAllLocalesChecked = _valuesInstanceProperty(formik).locales.length === locales.length;
776
+ return jsx(FormDialog, {
777
+ isOpen: true,
778
+ title: intl.formatMessage(messages.modalTitle, {
779
+ resourceType: resourceTypePlural
780
+ }),
781
+ labelPrimary: intl.formatMessage(messages.continue),
782
+ onPrimaryButtonClick: formik.submitForm,
783
+ isPrimaryButtonDisabled: !formik.isValid,
784
+ onSecondaryButtonClick: onClose,
785
+ onClose: onClose,
786
+ size: 16,
787
+ children: jsxs(Spacings.Stack, {
788
+ scale: "xxxl",
789
+ children: [jsxs(Spacings.Stack, {
790
+ scale: "l",
791
+ children: [jsxs(Spacings.Inline, {
792
+ alignItems: "center",
793
+ children: [jsx(ExportIcon, {
794
+ size: "medium",
795
+ color: "neutral60"
796
+ }), jsx(ExportTextMessage, {})]
797
+ }), jsxs(Spacings.Stack, {
798
+ scale: "m",
799
+ children: [jsx(SelectField, {
800
+ name: "outputFormat",
801
+ onChange: formik.handleChange,
802
+ onBlur: formik.handleBlur,
803
+ value: _valuesInstanceProperty(formik).outputFormat,
804
+ title: intl.formatMessage(messages.outputFormat),
805
+ options: OUTPUT_FORMAT_OPTIONS
806
+ }), jsx(TextField, {
807
+ name: "fileName",
808
+ onChange: formik.handleChange,
809
+ onBlur: formik.handleBlur,
810
+ value: _valuesInstanceProperty(formik).fileName,
811
+ title: intl.formatMessage(messages.fileName),
812
+ touched: formik.touched.fileName,
813
+ errors: formik.errors.fileName,
814
+ renderError: renderFileNameError
815
+ }), jsxs(Spacings.Stack, {
816
+ scale: "xs",
817
+ children: [jsx(SelectField, {
818
+ id: "locales",
819
+ name: "locales",
820
+ value: _valuesInstanceProperty(formik).locales,
821
+ title: intl.formatMessage(messages.locale),
822
+ options: mapLocalesToOptions(locales),
823
+ isMulti: true,
824
+ onChange: formik.handleChange,
825
+ onBlur: formik.handleBlur,
826
+ touched: formik.touched.locales,
827
+ errors: formik.errors.locales,
828
+ renderError: renderLocaleError,
829
+ menuPortalTarget: document.body,
830
+ menuPortalZIndex: Z_INDEX_DROPDOWN
831
+ }), jsx(CheckboxInput, {
832
+ isChecked: areAllLocalesChecked,
833
+ onChange: e => {
834
+ if (e.target.checked) formik.setFieldValue('locales', locales);else formik.setFieldValue('locales', [locale]);
835
+ },
836
+ children: intl.formatMessage(messages.selectAllLocales)
837
+ })]
838
+ })]
839
+ })]
840
+ }), jsx("div", {})]
841
+ })
842
+ });
843
+ };
844
+
845
+ 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)."; }
846
+ var _ref = process.env.NODE_ENV === "production" ? {
847
+ name: "ti75j2",
848
+ styles: "margin:0"
849
+ } : {
850
+ name: "ozey8m-NoSearchResults",
851
+ styles: "margin:0;label:NoSearchResults;",
852
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
853
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
854
+ };
855
+ const NoSearchResults = () => {
856
+ return jsxs(Card, {
857
+ insetScale: "xl",
858
+ children: [jsxs(Spacings.Stack, {
859
+ scale: "s",
860
+ children: [jsx(Text.Body, {
861
+ fontWeight: "medium",
862
+ intlMessage: messages.thereAreNoResults
863
+ }), jsx(Text.Body, {
864
+ intlMessage: messages.suggestions
865
+ })]
866
+ }), jsxs("ul", {
867
+ css: _ref,
868
+ children: [jsx("li", {
869
+ children: jsx(Text.Body, {
870
+ intlMessage: messages.checkTheSpelling
871
+ })
872
+ }), jsx("li", {
873
+ children: jsx(Text.Body, {
874
+ intlMessage: messages.searchByEnteringTheExactFieldName
875
+ })
876
+ })]
877
+ })]
878
+ });
879
+ };
880
+
881
+ 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; }
882
+ 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; }
883
+ const StyledGroupCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
884
+ target: "e3xiyhb1"
885
+ } : {
886
+ target: "e3xiyhb1",
887
+ label: "StyledGroupCard"
888
+ })("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"]} */"));
889
+ const StyledFieldsCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
890
+ target: "e3xiyhb0"
891
+ } : {
892
+ target: "e3xiyhb0",
893
+ label: "StyledFieldsCard"
894
+ })("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"]} */"));
895
+ const FieldSections = _ref => {
896
+ let fields = _ref.fields,
897
+ parentKeys = _ref.parentKeys,
898
+ formik = _ref.formik,
899
+ isAnySiblingChecked = _ref.isAnySiblingChecked;
900
+ return jsx(Spacings.Stack, {
901
+ scale: "s",
902
+ children: fields === null || fields === void 0 ? void 0 : _mapInstanceProperty(fields).call(fields, (field, index) => {
903
+ var _context, _field$fields3;
904
+ const isAtleastOneChildChecked = () => {
905
+ function checkAtLeastOneFieldChecked(fields) {
906
+ return fields === null || fields === void 0 ? void 0 : _someInstanceProperty(fields).call(fields, field => {
907
+ if (field.fields) {
908
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
909
+ }
910
+ return field.isChecked;
911
+ });
912
+ }
913
+ return checkAtLeastOneFieldChecked(field.fields);
914
+ };
915
+ const isAnyOfTheChildFieldsChecked = isAtleastOneChildChecked();
916
+ if (field.isHidden) return null;
917
+ return jsxs(React.Fragment, {
918
+ children: [jsxs(CheckboxInput, {
919
+ isChecked: field.isReadOnly ? isAnySiblingChecked : isAnyOfTheChildFieldsChecked || field.isChecked,
920
+ isReadOnly: field.isReadOnly || field.isRequired,
921
+ onChange: e => {
922
+ var _context2, _field$fields2;
923
+ const path = _concatInstanceProperty(_context2 = "".concat(parentKeys.join('.'), ".fields[")).call(_context2, index, "]");
924
+ // Update all child fields
925
+ const updateAllChildFieldsChecked = (path, checked) => {
926
+ const item = get(_valuesInstanceProperty(formik), path);
927
+ if (item && item.fields) {
928
+ var _context3;
929
+ _forEachInstanceProperty(_context3 = item.fields).call(_context3, (field, i) => {
930
+ var _context4, _field$fields;
931
+ const fieldPath = _concatInstanceProperty(_context4 = "".concat(path, ".fields[")).call(_context4, i, "]");
932
+ if (!((_field$fields = field.fields) !== null && _field$fields !== void 0 && _field$fields.length)) {
933
+ formik.setFieldValue("".concat(fieldPath, ".isChecked"), checked,
934
+ // pass `false` to avoid revalidating the form with intermediate values
935
+ false);
936
+ }
937
+ updateAllChildFieldsChecked(fieldPath, checked);
938
+ });
939
+ }
940
+ };
941
+ if (!((_field$fields2 = field.fields) !== null && _field$fields2 !== void 0 && _field$fields2.length)) {
942
+ formik.setFieldValue("".concat(path, ".isChecked"), e.target.checked,
943
+ // pass `false` to avoid revalidating the form with intermediate values
944
+ false);
945
+ }
946
+ updateAllChildFieldsChecked(path, e.target.checked);
947
+ },
948
+ children: [field.label, " ", field.isRequired && '*']
949
+ }), field.fields && ((_field$fields3 = field.fields) === null || _field$fields3 === void 0 ? void 0 : _field$fields3.length) > 0 && jsxs(Spacings.Inline, {
950
+ scale: "l",
951
+ children: [jsx("div", {}), jsx(FieldSections, {
952
+ fields: field.fields,
953
+ formik: formik,
954
+ parentKeys: [...parentKeys, "fields[".concat(index, "]")],
955
+ isAnySiblingChecked: isAnySiblingChecked
956
+ })]
957
+ })]
958
+ }, _concatInstanceProperty(_context = "".concat(field.name, "-")).call(_context, index));
959
+ })
960
+ });
961
+ };
962
+ function checkAllFieldsSelected(fields) {
963
+ return _everyInstanceProperty(fields).call(fields, field => {
964
+ if (field.fields) {
965
+ return checkAllFieldsSelected(field.fields);
966
+ }
967
+ return field.isChecked || field.isRequired || field.isReadOnly;
968
+ });
969
+ }
970
+ function checkAtLeastOneFieldChecked(fields) {
971
+ return _someInstanceProperty(fields).call(fields, field => {
972
+ if (field.fields) {
973
+ return field.isChecked || checkAtLeastOneFieldChecked(field.fields);
974
+ }
975
+ return field.isChecked;
976
+ });
977
+ }
978
+ const FieldGroupSection = _ref2 => {
979
+ let group = _ref2.group,
980
+ index = _ref2.index,
981
+ formik = _ref2.formik;
982
+ const allAllFieldsSelected = React.useMemo(() => checkAllFieldsSelected(group.fields), [group.fields]);
983
+ const isAtleastOneFieldChecked = React.useMemo(() => checkAtLeastOneFieldChecked(group.fields), [group.fields]);
984
+ const parentKey = "groups[".concat(index, "]");
985
+ const handleChangeAllFields = e => {
986
+ const item = get(_valuesInstanceProperty(formik), parentKey);
987
+ function updateAllFields(fields, checked) {
988
+ return _mapInstanceProperty(fields).call(fields, field => {
989
+ if (field.fields) {
990
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
991
+ fields: updateAllFields(field.fields, checked)
992
+ });
993
+ }
994
+ if (field.isReadOnly || field.isRequired) return field;
995
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
996
+ isChecked: checked
997
+ });
998
+ });
999
+ }
1000
+ formik.setFieldValue(parentKey, _objectSpread$1(_objectSpread$1({}, item), {}, {
1001
+ fields: updateAllFields(item.fields, e.target.checked)
1002
+ }));
1003
+ };
1004
+ if (group.isHidden) return null;
1005
+ return jsxs(Fragment, {
1006
+ children: [jsx(Grid.Item, {
1007
+ children: jsx(StyledGroupCard, {
1008
+ type: "flat",
1009
+ insetScale: "l",
1010
+ showTopBorder: true,
1011
+ children: jsx(CheckboxInput, {
1012
+ isIndeterminate: !allAllFieldsSelected && isAtleastOneFieldChecked,
1013
+ isChecked: allAllFieldsSelected,
1014
+ onChange: handleChangeAllFields,
1015
+ children: group.groupLabel
1016
+ })
1017
+ })
1018
+ }), jsx(Grid.Item, {
1019
+ children: jsx(StyledFieldsCard, {
1020
+ type: "flat",
1021
+ insetScale: "l",
1022
+ showTopBorder: true,
1023
+ children: jsx(Spacings.Stack, {
1024
+ scale: "s",
1025
+ children: jsx(FieldSections, {
1026
+ fields: group.fields,
1027
+ formik: formik,
1028
+ parentKeys: [parentKey],
1029
+ isAnySiblingChecked: isAtleastOneFieldChecked
1030
+ })
1031
+ })
1032
+ })
1033
+ })]
1034
+ });
1035
+ };
1036
+ const ExportFieldsSelectionStep = () => {
1037
+ const intl = useIntl();
1038
+ const _React$useState = React.useState(''),
1039
+ _React$useState2 = _slicedToArray(_React$useState, 2),
1040
+ fieldSearchTerm = _React$useState2[0],
1041
+ setFieldSearchTerm = _React$useState2[1];
1042
+ const _useExportResourcesCo = useExportResourcesContext(),
1043
+ formik = _useExportResourcesCo.formik,
1044
+ setCurrentStep = _useExportResourcesCo.setCurrentStep,
1045
+ resourceType = _useExportResourcesCo.resourceType,
1046
+ onClose = _useExportResourcesCo.onClose;
1047
+ const resourceTypePlural = resourceTypeToDisplayName({
1048
+ resourceType: resourceType,
1049
+ isPlural: true
1050
+ });
1051
+ React.useEffect(() => {
1052
+ formik.validateForm();
1053
+ // eslint-disable-next-line react-hooks/exhaustive-deps
1054
+ }, [_valuesInstanceProperty(formik).groups]);
1055
+ // adds `isHidden` property to each field based on search term
1056
+ const filteredGroups = React.useMemo(() => {
1057
+ var _fieldSearchTerm$trim, _context6;
1058
+ const updateFields = (fields, parentMatches) => {
1059
+ return _mapInstanceProperty(fields).call(fields, field => {
1060
+ var _context5;
1061
+ const matches = _includesInstanceProperty(_context5 = field.label.toLowerCase()).call(_context5, fieldSearchTerm.toLowerCase());
1062
+ let isHidden = !matches && !parentMatches;
1063
+ if (field.fields) {
1064
+ const updatedFields = updateFields(field.fields, matches);
1065
+ isHidden = isHidden && _everyInstanceProperty(updatedFields).call(updatedFields, f => f.isHidden);
1066
+ field = _objectSpread$1(_objectSpread$1({}, field), {}, {
1067
+ fields: updatedFields
1068
+ });
1069
+ }
1070
+ return _objectSpread$1(_objectSpread$1({}, field), {}, {
1071
+ isHidden
1072
+ });
1073
+ });
1074
+ };
1075
+ if (!(fieldSearchTerm !== null && fieldSearchTerm !== void 0 && (_fieldSearchTerm$trim = _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm)) !== null && _fieldSearchTerm$trim !== void 0 && _fieldSearchTerm$trim.length)) return _valuesInstanceProperty(formik).groups;
1076
+ return _mapInstanceProperty(_context6 = _valuesInstanceProperty(formik).groups).call(_context6, group => {
1077
+ const updatedFields = updateFields(group.fields, false);
1078
+ const isHidden = _everyInstanceProperty(updatedFields).call(updatedFields, field => field.isHidden);
1079
+ return _objectSpread$1(_objectSpread$1({}, group), {}, {
1080
+ fields: updatedFields,
1081
+ isHidden
1082
+ });
1083
+ });
1084
+ }, [_valuesInstanceProperty(formik).groups, fieldSearchTerm]);
1085
+ const onSearchChange = React.useCallback(event => {
1086
+ setFieldSearchTerm(event.target.value);
1087
+ }, [setFieldSearchTerm]);
1088
+ const hasResults = Boolean(_findInstanceProperty(filteredGroups).call(filteredGroups, group => !group.isHidden));
1089
+ const onSearchChangeThrottled = React.useMemo(() => throttle(onSearchChange, 300), [onSearchChange]);
1090
+ const onSearchReset = () => {
1091
+ setFieldSearchTerm('');
1092
+ };
1093
+ return jsx(FormDialog, {
1094
+ isOpen: true,
1095
+ title: intl.formatMessage(messages.modalTitle, {
1096
+ resourceType: resourceTypePlural
1097
+ }),
1098
+ labelPrimary: intl.formatMessage(messages.startExport),
1099
+ onPrimaryButtonClick: formik.submitForm,
1100
+ isPrimaryButtonDisabled: !formik.isValid,
1101
+ labelSecondary: intl.formatMessage(messages.back),
1102
+ onSecondaryButtonClick: () => setCurrentStep(1),
1103
+ onClose: onClose,
1104
+ size: 16,
1105
+ children: jsx(Spacings.Stack, {
1106
+ scale: "xl",
1107
+ children: jsxs(Spacings.Stack, {
1108
+ scale: "m",
1109
+ children: [jsxs(Spacings.Inline, {
1110
+ justifyContent: "space-between",
1111
+ children: [jsx(Text.Body, {
1112
+ intlMessage: messages.selectFieldsToExport
1113
+ }), jsx(Link, {
1114
+ isExternal: true,
1115
+ tone: "secondary",
1116
+ intlMessage: messages.fieldDefinitions,
1117
+ to: FIELD_DEFINITIONS_URLS[resourceType]
1118
+ })]
1119
+ }), jsx(SearchTextInput, {
1120
+ placeholder: intl.formatMessage(messages.searchForFields),
1121
+ value: fieldSearchTerm,
1122
+ onChange: onSearchChangeThrottled,
1123
+ onReset: onSearchReset
1124
+ // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
1125
+ ,
1126
+ onSubmit: () => {}
1127
+ }), hasResults ? jsx(Card, {
1128
+ insetScale: "none",
1129
+ children: jsx(Grid, {
1130
+ gridAutoFlow: "row",
1131
+ gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
1132
+ children: _mapInstanceProperty(filteredGroups).call(filteredGroups, (group, index) => jsx(FieldGroupSection, {
1133
+ group: group,
1134
+ index: index,
1135
+ formik: formik
1136
+ }, group.groupLabel))
1137
+ })
1138
+ }) : jsx(NoSearchResults, {})]
1139
+ })
1140
+ })
1141
+ });
1142
+ };
1143
+
1144
+ process.env.NODE_ENV !== "production" ? {
1145
+ renderProperties: PropTypes.func
1146
+ } : {};
1147
+
1148
+ const ExportResourcesContext = /*#__PURE__*/createContext();
1149
+
1150
+ const ExportResourcesProvider = props => {
1151
+ const initialValues = useInitialValues(props);
1152
+ const _useStartExportOperat = useStartExportOperation(props),
1153
+ startExportOperation = _useStartExportOperat.startExportOperation;
1154
+ const _React$useState = React.useState(1),
1155
+ _React$useState2 = _slicedToArray(_React$useState, 2),
1156
+ currentStep = _React$useState2[0],
1157
+ setCurrentStep = _React$useState2[1];
1158
+ const onSubmit = async values => {
1159
+ if (currentStep === 1) {
1160
+ setCurrentStep(2);
1161
+ } else {
1162
+ startExportOperation(values);
1163
+ }
1164
+ };
1165
+ const formik = useFormik({
1166
+ initialValues,
1167
+ validate: values => validate({
1168
+ values,
1169
+ step: currentStep
1170
+ }),
1171
+ onSubmit
1172
+ });
1173
+ React.useEffect(() => {
1174
+ formik.validateForm();
1175
+ }, [currentStep]);
1176
+ return jsx(ExportResourcesContext.Provider, {
1177
+ value: {
1178
+ formik,
1179
+ currentStep,
1180
+ setCurrentStep,
1181
+ onClose: props.onClose,
1182
+ resourceType: props.resourceType,
1183
+ exportType: props.exportType,
1184
+ totalResourcesCount: props.totalResourcesCount,
1185
+ selectedResourceIds: props.selectedResourceIds
1186
+ },
1187
+ children: props.children
1188
+ });
1189
+ };
1190
+
1191
+ const CurrentStep = () => {
1192
+ const _useExportResourcesCo = useExportResourcesContext(),
1193
+ currentStep = _useExportResourcesCo.currentStep;
1194
+ const steps = {
1195
+ 1: jsx(ExportFileSettingsStep, {}),
1196
+ 2: jsx(ExportFieldsSelectionStep, {})
1197
+ };
1198
+ return steps[currentStep] || null;
1199
+ };
1200
+
1201
+ 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; }
1202
+ 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; }
1203
+ const ExportResourcesModal = props => {
1204
+ if (!props.isOpen) return null;
1205
+ return jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1206
+ children: jsx(CurrentStep, {})
1207
+ }));
1208
+ };
1209
+ ExportResourcesModal.displayName = 'ExportResourcesModal';
1210
+ ExportResourcesModal.defaultProps = {
1211
+ isOpen: false,
1212
+ selectedResourceIds: [],
1213
+ exportType: EXPORT_TYPES.ALL,
1214
+ outputFormat: OUTPUT_FORMATS.CSV,
1215
+ customFields: [],
1216
+ fieldGroups: []
1217
+ };
1218
+
1219
+ export { EXPORTABLE_RESOURCES, EXPORT_TYPES, ExportResourcesModal as default };