@commercetools-frontend-extensions/export-resources-modal 3.4.1 → 3.4.3-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -8,12 +8,13 @@ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/obje
8
8
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
10
  import React, { useContext, createContext } from 'react';
11
+ import { Text, Link, TextInput, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, Grid } from '@commercetools-frontend/ui-kit';
12
+ import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
13
+ import '@commercetools-uikit/design-system';
11
14
  import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
12
- import { InfoDialog } from '@commercetools-frontend/application-components';
13
- import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
14
- import _flatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat';
15
- import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
16
- import { query } from 'gql-query-builder';
15
+ import _valuesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/values';
16
+ import { FormDialog } from '@commercetools-frontend/application-components';
17
+ import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
17
18
  import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
18
19
  import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
19
20
  import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
@@ -22,22 +23,21 @@ import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possi
22
23
  import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
23
24
  import _wrapNativeSuper from '@babel/runtime-corejs3/helpers/esm/wrapNativeSuper';
24
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 _flatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat';
30
+ import { query } from 'gql-query-builder';
25
31
  import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
26
32
  import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
27
33
  import _Object$assign from '@babel/runtime-corejs3/core-js-stable/object/assign';
28
34
  import _flatMapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat-map';
29
35
  import _Set from '@babel/runtime-corejs3/core-js-stable/set';
30
- import { Link, TextInput, Text, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, PrimaryButton, Card, designTokens, Grid, SecondaryButton } from '@commercetools-frontend/ui-kit';
31
- import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
32
- import _valuesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/values';
33
36
  import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
34
37
  import omitEmpty from 'omit-empty-es';
35
38
  import _findIndexInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find-index';
36
39
  import _spliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/splice';
37
40
  import _startsWithInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
38
- import '@commercetools-uikit/design-system';
39
- import { useApplicationContext } from '@commercetools-frontend/application-shell-connectors';
40
- import moment from 'moment';
41
41
  import { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
42
42
  import { useShowNotification, showApiErrorNotification } from '@commercetools-frontend/actions-global';
43
43
  import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants';
@@ -48,6 +48,178 @@ import PropTypes from 'prop-types';
48
48
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
49
49
  import { useFormik } from 'formik';
50
50
 
51
+ function getBold(msg) {
52
+ return jsx(Text.Body, {
53
+ as: "span",
54
+ isBold: true,
55
+ children: msg
56
+ });
57
+ }
58
+
59
+ function getNewLine() {
60
+ return jsx("br", {});
61
+ }
62
+
63
+ var messages = defineMessages({
64
+ modalTitle: {
65
+ id: 'ExportResourcesModal.modalTitle',
66
+ description: 'Label for the modal title',
67
+ defaultMessage: 'Export {resourceType}'
68
+ },
69
+ outputFormat: {
70
+ id: 'ExportResourcesModal.outputFormat',
71
+ description: 'File format like (csv, xls, ...etc)',
72
+ defaultMessage: 'File format'
73
+ },
74
+ fileName: {
75
+ id: 'ExportResourcesModal.fileName',
76
+ description: 'exported file name',
77
+ defaultMessage: 'File name'
78
+ },
79
+ locale: {
80
+ id: 'ExportResourcesModal.locale',
81
+ description: 'Locale',
82
+ defaultMessage: 'Locale'
83
+ },
84
+ exportSelection: {
85
+ id: 'ExportResourcesModal.exportSelection',
86
+ description: 'Export selection',
87
+ defaultMessage: 'Export selection'
88
+ },
89
+ exportAllResources: {
90
+ id: 'ExportResourcesModal.exportAllResources',
91
+ description: 'Export All selection',
92
+ defaultMessage: 'Export all {resourceType} ({count})'
93
+ },
94
+ exportOnlySelectedResources: {
95
+ id: 'ExportResourcesModal.exportOnlySelectedResources',
96
+ description: 'Export only selected resources',
97
+ defaultMessage: 'Export selected {resourceType} ({count})'
98
+ },
99
+ exportAllMessage: {
100
+ id: 'ExportResourcesModal.exportAllMessage',
101
+ description: 'All resources will be exported',
102
+ defaultMessage: 'All <b>{count}</b> {resourceType} will be exported.'
103
+ },
104
+ exportMatchingMessage: {
105
+ id: 'ExportResourcesModal.exportMatchingMessage',
106
+ description: 'resources will be exported',
107
+ defaultMessage: '<b>{count}</b> {resourceType} will be exported.'
108
+ },
109
+ exportSelectedMessage: {
110
+ id: 'ExportResourcesModal.exportSelectedMessage',
111
+ description: 'resources are selected and will be exported',
112
+ defaultMessage: '<b>{count}</b> {resourceType} are selected and will be exported.'
113
+ },
114
+ exportBasedOnMyViewsMessage: {
115
+ id: 'ExportResourcesModal.exportBasedOnMyViewsMessage',
116
+ description: 'Select Export setttings based on my views',
117
+ defaultMessage: 'Select export settings based on:'
118
+ },
119
+ propertiesPanelLabel: {
120
+ id: 'ExportResourcesModal.propertiesPanelLabel',
121
+ description: 'properties panel label',
122
+ defaultMessage: 'Properties'
123
+ },
124
+ exportOperationSuccessMessage: {
125
+ id: 'ExportResourcesModal.exportOperationSuccessMessage',
126
+ description: 'Success message',
127
+ defaultMessage: '<b>Your export has started.</b> <newline></newline><logsLink>Go to Export logs</logsLink> to view the progress and download the file.'
128
+ },
129
+ nothingApplied: {
130
+ id: 'ExportResourcesModal.nothingApplied',
131
+ description: 'Shown when there is no filter applied',
132
+ defaultMessage: 'nothing applied'
133
+ },
134
+ selectAllLocales: {
135
+ id: 'ExportResourcesModal.selectAllLocales',
136
+ description: 'label for "Select all locales" checkbox',
137
+ defaultMessage: 'Select all locales'
138
+ },
139
+ missingFileNameError: {
140
+ id: 'ExportResourcesModal.missingFileNameError',
141
+ description: 'Error when file name field is missing',
142
+ defaultMessage: 'Please enter a file name'
143
+ },
144
+ invalidFileNameError: {
145
+ id: 'ExportResourcesModal.invalidFileNameError',
146
+ description: 'Error when file name field is not valid',
147
+ defaultMessage: 'File name may only contain alphanumeric characters, hyphens and underscores'
148
+ },
149
+ missingLocaleError: {
150
+ id: 'ExportResourcesModal.missingLocaleError',
151
+ description: 'Error when no locale is selected',
152
+ defaultMessage: 'Please select at least one locale'
153
+ },
154
+ myViews: {
155
+ id: 'ExportResourcesModal.myViews',
156
+ description: 'Label for "My Views" Select Field',
157
+ defaultMessage: 'My Views'
158
+ },
159
+ selectFieldsToExport: {
160
+ id: 'ExportResourcesModal.selectFieldsToExport',
161
+ defaultMessage: 'Select fields to export'
162
+ },
163
+ back: {
164
+ id: 'ExportResourcesModal.back',
165
+ description: 'Label for "Back" button',
166
+ defaultMessage: 'Back'
167
+ },
168
+ startExport: {
169
+ id: 'ExportResourcesModal.startExport',
170
+ description: 'Label for "Start export" button',
171
+ defaultMessage: 'Start export'
172
+ },
173
+ continue: {
174
+ id: 'ExportResourcesModal.continue',
175
+ description: 'Label for "Continue" button',
176
+ defaultMessage: 'Continue'
177
+ },
178
+ fieldDefinitions: {
179
+ id: 'ExportResourcesModal.fieldDefinitions',
180
+ description: 'Label for "Field definitions" link',
181
+ defaultMessage: 'Field definitions'
182
+ },
183
+ allGeneralFields: {
184
+ id: 'ExportResourcesModal.allGeneralFields',
185
+ description: 'Label for "All general fields" checkbox',
186
+ defaultMessage: 'All general fields'
187
+ },
188
+ allCustomFields: {
189
+ id: 'ExportResourcesModal.allCustomFields',
190
+ description: 'Label for "All custom fields" checkbox',
191
+ defaultMessage: 'All custom fields'
192
+ },
193
+ customTypeKeyAndTypeId: {
194
+ id: 'ExportResourcesModal.customTypeKeyAndTypeId',
195
+ description: 'Label for "Custom type key and typeId" checkbox',
196
+ defaultMessage: 'Custom type key and typeId'
197
+ }
198
+ });
199
+
200
+ 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; }
201
+ 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; }
202
+ function renderFileNameError(key) {
203
+ switch (key) {
204
+ case 'missing':
205
+ return jsx(FormattedMessage, _objectSpread$6({}, messages.missingFileNameError));
206
+ case 'invalidInput':
207
+ return jsx(FormattedMessage, _objectSpread$6({}, messages.invalidFileNameError));
208
+ default:
209
+ return null;
210
+ }
211
+ }
212
+ function renderLocaleError(key) {
213
+ switch (key) {
214
+ case 'missing':
215
+ return jsx(FormattedMessage, _objectSpread$6({}, messages.missingLocaleError));
216
+ default:
217
+ return null;
218
+ }
219
+ }
220
+
221
+ const Z_INDEX_DROPDOWN = 30000;
222
+
51
223
  const EXPORT_OPERATION_STATES = {
52
224
  PROCESSING: 'processing',
53
225
  COMPLETED: 'completed',
@@ -79,7 +251,7 @@ const OUTPUT_FORMAT_OPTIONS = [{
79
251
  }];
80
252
 
81
253
  const FIELD_DEFINITIONS_URLS = {
82
- category: 'https://docs-proxy-sarm-product-import-csv.commercetools.vercel.app/merchant-center/import-categories#supported-headers-and-values'
254
+ category: 'https://docs.commercetools.com/merchant-center/import-categories#supported-headers-and-values'
83
255
  };
84
256
 
85
257
  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); }; }
@@ -142,9 +314,17 @@ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
142
314
  return _createClass(UnexpectedResourceTypeError);
143
315
  }( /*#__PURE__*/_wrapNativeSuper(Error));
144
316
 
317
+ function useExportResourcesContext() {
318
+ const context = useContext(ExportResourcesContext);
319
+ if (!context) {
320
+ throw new MissingExportResourceProviderError();
321
+ }
322
+ return context;
323
+ }
324
+
145
325
  const _excluded$1 = ["name"];
146
- function ownKeys$6(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
147
- function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var _context7, _context8; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context7 = ownKeys$6(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context8 = ownKeys$6(Object(t))).call(_context8, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
326
+ 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; }
327
+ function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context7, _context8; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context7 = ownKeys$5(Object(t), !0)).call(_context7, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context8 = ownKeys$5(Object(t))).call(_context8, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
148
328
  function resourceTypeToDisplayName(_ref) {
149
329
  let resourceType = _ref.resourceType,
150
330
  _ref$isUpperCase = _ref.isUpperCase,
@@ -203,7 +383,7 @@ function flattenNestedFields(fields) {
203
383
  var _context2;
204
384
  return _mapInstanceProperty(_context2 = flattenNestedFields(field.fields)).call(_context2, nestedField => {
205
385
  var _context3;
206
- return _objectSpread$6(_objectSpread$6({}, nestedField), {}, {
386
+ return _objectSpread$5(_objectSpread$5({}, nestedField), {}, {
207
387
  name: _concatInstanceProperty(_context3 = "".concat(field.name, ".")).call(_context3, nestedField.name)
208
388
  });
209
389
  });
@@ -243,7 +423,7 @@ function getSelectedGeneralFields(fields) {
243
423
  function getSelectedCustomFields(customFields) {
244
424
  return _mapInstanceProperty(customFields).call(customFields, customType => {
245
425
  var _context4;
246
- return _objectSpread$6(_objectSpread$6({}, customType), {}, {
426
+ return _objectSpread$5(_objectSpread$5({}, customType), {}, {
247
427
  fields: _filterInstanceProperty(_context4 = customType.fields).call(_context4, field => field.isChecked)
248
428
  });
249
429
  });
@@ -252,7 +432,7 @@ function flattenCustomFields(customFields) {
252
432
  return _flatMapInstanceProperty(customFields).call(customFields, customType => customType.fields);
253
433
  }
254
434
  function checkRequiredFields(fields) {
255
- return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$6(_objectSpread$6({}, field), {}, {
435
+ return _mapInstanceProperty(fields).call(fields, field => field.isRequired ? _objectSpread$5(_objectSpread$5({}, field), {}, {
256
436
  isChecked: true
257
437
  }) : field);
258
438
  }
@@ -265,8 +445,8 @@ function getExportLogsLink(projectKey, msg) {
265
445
  function setInitialCheckedStateForCustomFields(customFields) {
266
446
  return _mapInstanceProperty(customFields).call(customFields, customType => {
267
447
  var _context5;
268
- return _objectSpread$6(_objectSpread$6({}, customType), {}, {
269
- fields: _mapInstanceProperty(_context5 = customType.fields).call(_context5, field => _objectSpread$6(_objectSpread$6({}, field), {}, {
448
+ return _objectSpread$5(_objectSpread$5({}, customType), {}, {
449
+ fields: _mapInstanceProperty(_context5 = customType.fields).call(_context5, field => _objectSpread$5(_objectSpread$5({}, field), {}, {
270
450
  isChecked: false
271
451
  }))
272
452
  });
@@ -443,184 +623,6 @@ const extendColumns = _ref => {
443
623
  return extensionFunction(columns);
444
624
  };
445
625
 
446
- var messages = defineMessages({
447
- modalTitle: {
448
- id: 'ExportResourcesModal.modalTitle',
449
- description: 'Label for the modal title',
450
- defaultMessage: 'Export {resourceType}'
451
- },
452
- outputFormat: {
453
- id: 'ExportResourcesModal.outputFormat',
454
- description: 'File format like (csv, xls, ...etc)',
455
- defaultMessage: 'File format'
456
- },
457
- fileName: {
458
- id: 'ExportResourcesModal.fileName',
459
- description: 'exported file name',
460
- defaultMessage: 'File name'
461
- },
462
- locale: {
463
- id: 'ExportResourcesModal.locale',
464
- description: 'Locale',
465
- defaultMessage: 'Locale'
466
- },
467
- exportSelection: {
468
- id: 'ExportResourcesModal.exportSelection',
469
- description: 'Export selection',
470
- defaultMessage: 'Export selection'
471
- },
472
- exportAllResources: {
473
- id: 'ExportResourcesModal.exportAllResources',
474
- description: 'Export All selection',
475
- defaultMessage: 'Export all {resourceType} ({count})'
476
- },
477
- exportOnlySelectedResources: {
478
- id: 'ExportResourcesModal.exportOnlySelectedResources',
479
- description: 'Export only selected resources',
480
- defaultMessage: 'Export selected {resourceType} ({count})'
481
- },
482
- exportAllMessage: {
483
- id: 'ExportResourcesModal.exportAllMessage',
484
- description: 'All resources will be exported',
485
- defaultMessage: 'All <b>{count}</b> {resourceType} will be exported.'
486
- },
487
- exportMatchingMessage: {
488
- id: 'ExportResourcesModal.exportMatchingMessage',
489
- description: 'resources will be exported',
490
- defaultMessage: '<b>{count}</b> {resourceType} will be exported.'
491
- },
492
- exportSelectedMessage: {
493
- id: 'ExportResourcesModal.exportSelectedMessage',
494
- description: 'resources are selected and will be exported',
495
- defaultMessage: '<b>{count}</b> {resourceType} are selected and will be exported.'
496
- },
497
- exportBasedOnMyViewsMessage: {
498
- id: 'ExportResourcesModal.exportBasedOnMyViewsMessage',
499
- description: 'Select Export setttings based on my views',
500
- defaultMessage: 'Select export settings based on:'
501
- },
502
- propertiesPanelLabel: {
503
- id: 'ExportResourcesModal.propertiesPanelLabel',
504
- description: 'properties panel label',
505
- defaultMessage: 'Properties'
506
- },
507
- exportOperationSuccessMessage: {
508
- id: 'ExportResourcesModal.exportOperationSuccessMessage',
509
- description: 'Success message',
510
- defaultMessage: '<b>Your export has started.</b> <newline></newline><logsLink>Go to Export logs</logsLink> to view the progress and download the file.'
511
- },
512
- nothingApplied: {
513
- id: 'ExportResourcesModal.nothingApplied',
514
- description: 'Shown when there is no filter applied',
515
- defaultMessage: 'nothing applied'
516
- },
517
- selectAllLocales: {
518
- id: 'ExportResourcesModal.selectAllLocales',
519
- description: 'label for "Select all locales" checkbox',
520
- defaultMessage: 'Select all locales'
521
- },
522
- missingFileNameError: {
523
- id: 'ExportResourcesModal.missingFileNameError',
524
- description: 'Error when file name field is missing',
525
- defaultMessage: 'Please enter a file name'
526
- },
527
- invalidFileNameError: {
528
- id: 'ExportResourcesModal.invalidFileNameError',
529
- description: 'Error when file name field is not valid',
530
- defaultMessage: 'File name may only contain alphanumeric characters, hyphens and underscores'
531
- },
532
- missingLocaleError: {
533
- id: 'ExportResourcesModal.missingLocaleError',
534
- description: 'Error when no locale is selected',
535
- defaultMessage: 'Please select at least one locale'
536
- },
537
- myViews: {
538
- id: 'ExportResourcesModal.myViews',
539
- description: 'Label for "My Views" Select Field',
540
- defaultMessage: 'My Views'
541
- },
542
- selectFieldsToExport: {
543
- id: 'ExportResourcesModal.selectFieldsToExport',
544
- defaultMessage: 'Select fields to export'
545
- },
546
- back: {
547
- id: 'ExportResourcesModal.back',
548
- description: 'Label for "Back" button',
549
- defaultMessage: 'Back'
550
- },
551
- startExport: {
552
- id: 'ExportResourcesModal.startExport',
553
- description: 'Label for "Start export" button',
554
- defaultMessage: 'Start export'
555
- },
556
- continue: {
557
- id: 'ExportResourcesModal.continue',
558
- description: 'Label for "Continue" button',
559
- defaultMessage: 'Continue'
560
- },
561
- fieldDefinitions: {
562
- id: 'ExportResourcesModal.fieldDefinitions',
563
- description: 'Label for "Field definitions" link',
564
- defaultMessage: 'Field definitions'
565
- },
566
- allGeneralFields: {
567
- id: 'ExportResourcesModal.allGeneralFields',
568
- description: 'Label for "All general fields" checkbox',
569
- defaultMessage: 'All general fields'
570
- },
571
- allCustomFields: {
572
- id: 'ExportResourcesModal.allCustomFields',
573
- description: 'Label for "All custom fields" checkbox',
574
- defaultMessage: 'All custom fields'
575
- },
576
- customTypeKeyAndTypeId: {
577
- id: 'ExportResourcesModal.customTypeKeyAndTypeId',
578
- description: 'Label for "Custom type key and typeId" checkbox',
579
- defaultMessage: 'Custom type key and typeId'
580
- }
581
- });
582
-
583
- function getBold(msg) {
584
- return jsx(Text.Body, {
585
- as: "span",
586
- isBold: true,
587
- children: msg
588
- });
589
- }
590
-
591
- function getNewLine() {
592
- return jsx("br", {});
593
- }
594
-
595
- 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; }
596
- function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$5(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$5(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
597
- function renderFileNameError(key) {
598
- switch (key) {
599
- case 'missing':
600
- return jsx(FormattedMessage, _objectSpread$5({}, messages.missingFileNameError));
601
- case 'invalidInput':
602
- return jsx(FormattedMessage, _objectSpread$5({}, messages.invalidFileNameError));
603
- default:
604
- return null;
605
- }
606
- }
607
- function renderLocaleError(key) {
608
- switch (key) {
609
- case 'missing':
610
- return jsx(FormattedMessage, _objectSpread$5({}, messages.missingLocaleError));
611
- default:
612
- return null;
613
- }
614
- }
615
-
616
- function useExportResourcesContext() {
617
- const context = useContext(ExportResourcesContext);
618
- if (!context) {
619
- throw new MissingExportResourceProviderError();
620
- }
621
- return context;
622
- }
623
-
624
626
  const _excluded = ["isSelectedByDefault"];
625
627
  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; }
626
628
  function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context3 = ownKeys$4(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$4(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
@@ -794,7 +796,13 @@ function ExportTextMessage() {
794
796
  const ExportFileSettingsStep = () => {
795
797
  const intl = useIntl();
796
798
  const _useExportResourcesCo = useExportResourcesContext(),
797
- formik = _useExportResourcesCo.formik;
799
+ formik = _useExportResourcesCo.formik,
800
+ resourceType = _useExportResourcesCo.resourceType,
801
+ onClose = _useExportResourcesCo.onClose;
802
+ const resourceTypePlural = resourceTypeToDisplayName({
803
+ resourceType: resourceType,
804
+ isPlural: true
805
+ });
798
806
  const _useApplicationContex = useApplicationContext(applicationContext => {
799
807
  var _applicationContext$p;
800
808
  return {
@@ -805,224 +813,235 @@ const ExportFileSettingsStep = () => {
805
813
  locales = _useApplicationContex.locales,
806
814
  locale = _useApplicationContex.locale;
807
815
  const areAllLocalesChecked = _valuesInstanceProperty(formik).locales.length === locales.length;
808
- return jsxs(Spacings.Stack, {
809
- scale: "xxxl",
810
- children: [jsxs(Spacings.Stack, {
811
- scale: "l",
812
- children: [jsxs(Spacings.Inline, {
813
- alignItems: "center",
814
- children: [jsx(ExportIcon, {
815
- size: "medium",
816
- color: "neutral60"
817
- }), jsx(ExportTextMessage, {})]
818
- }), jsxs(Spacings.Stack, {
819
- scale: "m",
820
- children: [jsx(SelectField, {
821
- name: "outputFormat",
822
- onChange: formik.handleChange,
823
- onBlur: formik.handleBlur,
824
- value: _valuesInstanceProperty(formik).outputFormat,
825
- title: intl.formatMessage(messages.outputFormat),
826
- options: OUTPUT_FORMAT_OPTIONS
827
- }), jsx(TextField, {
828
- name: "fileName",
829
- onChange: formik.handleChange,
830
- onBlur: formik.handleBlur,
831
- value: _valuesInstanceProperty(formik).fileName,
832
- title: intl.formatMessage(messages.fileName),
833
- touched: formik.touched.fileName,
834
- errors: formik.errors.fileName,
835
- renderError: renderFileNameError
816
+ return jsx(FormDialog, {
817
+ isOpen: true,
818
+ title: intl.formatMessage(messages.modalTitle, {
819
+ resourceType: resourceTypePlural
820
+ }),
821
+ labelPrimary: intl.formatMessage(messages.continue),
822
+ onPrimaryButtonClick: formik.submitForm,
823
+ isPrimaryButtonDisabled: !formik.isValid,
824
+ onClose: onClose,
825
+ size: 16,
826
+ children: jsxs(Spacings.Stack, {
827
+ scale: "xxxl",
828
+ children: [jsxs(Spacings.Stack, {
829
+ scale: "l",
830
+ children: [jsxs(Spacings.Inline, {
831
+ alignItems: "center",
832
+ children: [jsx(ExportIcon, {
833
+ size: "medium",
834
+ color: "neutral60"
835
+ }), jsx(ExportTextMessage, {})]
836
836
  }), jsxs(Spacings.Stack, {
837
- scale: "xs",
837
+ scale: "m",
838
838
  children: [jsx(SelectField, {
839
- id: "locales",
840
- name: "locales",
841
- value: _valuesInstanceProperty(formik).locales,
842
- title: intl.formatMessage(messages.locale),
843
- options: mapLocalesToOptions(locales),
844
- isMulti: true,
839
+ name: "outputFormat",
845
840
  onChange: formik.handleChange,
846
841
  onBlur: formik.handleBlur,
847
- touched: formik.touched.locales,
848
- errors: formik.errors.locales,
849
- renderError: renderLocaleError
850
- }), jsx(CheckboxInput, {
851
- isChecked: areAllLocalesChecked,
852
- onChange: e => {
853
- if (e.target.checked) formik.setFieldValue('locales', locales);else formik.setFieldValue('locales', [locale]);
854
- },
855
- children: intl.formatMessage(messages.selectAllLocales)
842
+ value: _valuesInstanceProperty(formik).outputFormat,
843
+ title: intl.formatMessage(messages.outputFormat),
844
+ options: OUTPUT_FORMAT_OPTIONS
845
+ }), jsx(TextField, {
846
+ name: "fileName",
847
+ onChange: formik.handleChange,
848
+ onBlur: formik.handleBlur,
849
+ value: _valuesInstanceProperty(formik).fileName,
850
+ title: intl.formatMessage(messages.fileName),
851
+ touched: formik.touched.fileName,
852
+ errors: formik.errors.fileName,
853
+ renderError: renderFileNameError
854
+ }), jsxs(Spacings.Stack, {
855
+ scale: "xs",
856
+ children: [jsx(SelectField, {
857
+ id: "locales",
858
+ name: "locales",
859
+ value: _valuesInstanceProperty(formik).locales,
860
+ title: intl.formatMessage(messages.locale),
861
+ options: mapLocalesToOptions(locales),
862
+ isMulti: true,
863
+ onChange: formik.handleChange,
864
+ onBlur: formik.handleBlur,
865
+ touched: formik.touched.locales,
866
+ errors: formik.errors.locales,
867
+ renderError: renderLocaleError,
868
+ menuPortalTarget: document.body,
869
+ menuPortalZIndex: Z_INDEX_DROPDOWN
870
+ }), jsx(CheckboxInput, {
871
+ isChecked: areAllLocalesChecked,
872
+ onChange: e => {
873
+ if (e.target.checked) formik.setFieldValue('locales', locales);else formik.setFieldValue('locales', [locale]);
874
+ },
875
+ children: intl.formatMessage(messages.selectAllLocales)
876
+ })]
856
877
  })]
857
878
  })]
858
- })]
859
- }), jsx(Spacings.Inline, {
860
- justifyContent: "flex-end",
861
- children: jsx(PrimaryButton, {
862
- label: intl.formatMessage(messages.continue),
863
- onClick: formik.submitForm,
864
- isDisabled: !formik.isValid
865
- })
866
- })]
879
+ }), jsx("div", {})]
880
+ })
867
881
  });
868
882
  };
869
883
 
870
884
  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; }
871
885
  function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context12, _context13; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context12 = ownKeys$2(Object(t), !0)).call(_context12, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context13 = ownKeys$2(Object(t))).call(_context13, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
872
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
873
- const StyledCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
874
- target: "e1ocu3bb2"
875
- } : {
876
- target: "e1ocu3bb2",
877
- label: "StyledCard"
878
- })(process.env.NODE_ENV === "production" ? {
879
- name: "yqmzw4",
880
- styles: "&>div{height:490px;overflow-y:auto;}"
881
- } : {
882
- name: "yqmzw4",
883
- styles: "&>div{height:490px;overflow-y:auto;}",
884
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmB+B","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCard = styled(Card)`\n  & > div {\n    height: 490px;\n    overflow-y: auto;\n  }\n`\nconst StyledCardLeft = styled(StyledCard)`\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\n\nconst StyledCardRight = styled(StyledCard)`\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType } = useExportResourcesContext()\n  const areAllGeneralFieldsChecked = formik.values.fields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneGeneralFieldChecked = formik.values.fields.some(\n    (field) => field.isChecked\n  )\n  const allCustomFields = formik.values.customFields.flatMap(\n    (customType) => customType.fields\n  )\n  const areAllCustomFieldsChecked = allCustomFields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneCustomFieldChecked = allCustomFields.some(\n    (field) => field.isChecked\n  )\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Spacings.Inline justifyContent=\"space-between\">\n          <Text.Body intlMessage={messages.selectFieldsToExport} />\n          <Link\n            isExternal\n            tone=\"secondary\"\n            intlMessage={messages.fieldDefinitions}\n            to={FIELD_DEFINITIONS_URLS[resourceType]}\n          />\n        </Spacings.Inline>\n        <Grid\n          gridAutoFlow=\"row\"\n          gridTemplateColumns={`${designTokens.constraint5} auto`}\n        >\n          <Grid.Item>\n            <StyledCardLeft isTopRow insetScale=\"l\">\n              <CheckboxInput\n                isIndeterminate={\n                  !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked\n                }\n                isChecked={areAllGeneralFieldsChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'fields',\n                    formik.values.fields.map((field) => ({\n                      ...field,\n                      isChecked: field.isRequired ? true : e.target.checked,\n                    }))\n                  )\n                }}\n              >\n                <Text.Body intlMessage={messages.allGeneralFields} />\n              </CheckboxInput>\n            </StyledCardLeft>\n          </Grid.Item>\n          <Grid.Item>\n            <StyledCardRight isTopRow insetScale=\"l\">\n              <Spacings.Stack scale=\"s\">\n                <GeneralFieldsSelection\n                  fields={formik.values.fields}\n                  setFieldValue={formik.setFieldValue}\n                />\n              </Spacings.Stack>\n            </StyledCardRight>\n          </Grid.Item>\n          {formik.values.customFields?.length > 0 && (\n            <>\n              <Grid.Item>\n                <StyledCardLeft insetScale=\"l\">\n                  <CheckboxInput\n                    isIndeterminate={\n                      !areAllCustomFieldsChecked &&\n                      isAtLeastOneCustomFieldChecked\n                    }\n                    isChecked={areAllCustomFieldsChecked}\n                    onChange={(e) => {\n                      formik.setFieldValue(\n                        'customFields',\n                        formik.values.customFields.map((customType) => ({\n                          ...customType,\n                          fields: customType.fields.map((field) => ({\n                            ...field,\n                            isChecked: e.target.checked,\n                          })),\n                        }))\n                      )\n                    }}\n                  >\n                    <Text.Body intlMessage={messages.allCustomFields} />\n                  </CheckboxInput>\n                </StyledCardLeft>\n              </Grid.Item>\n              <Grid.Item>\n                <StyledCardRight insetScale=\"l\">\n                  <Spacings.Stack scale=\"s\">\n                    <CheckboxInput\n                      isReadOnly\n                      onChange={() => {}}\n                      isChecked={isAtLeastOneCustomFieldChecked}\n                    >\n                      <Text.Body>\n                        {intl.formatMessage(messages.customTypeKeyAndTypeId)} *\n                      </Text.Body>\n                    </CheckboxInput>\n                    <CustomFieldsSelection\n                      customFields={formik.values.customFields}\n                      setFieldValue={formik.setFieldValue}\n                    />\n                  </Spacings.Stack>\n                </StyledCardRight>\n              </Grid.Item>\n            </>\n          )}\n        </Grid>\n      </Spacings.Stack>\n      <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n        <SecondaryButton\n          label={intl.formatMessage(messages.back)}\n          onClick={() => setCurrentStep(1)}\n        />\n        <PrimaryButton\n          label={intl.formatMessage(messages.startExport)}\n          onClick={formik.submitForm}\n          isDisabled={!formik.isValid}\n        />\n      </Spacings.Inline>\n    </Spacings.Stack>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */",
885
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
886
- });
887
- const StyledCardLeft = /*#__PURE__*/_styled(StyledCard, process.env.NODE_ENV === "production" ? {
886
+ const StyledCardLeft = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
888
887
  target: "e1ocu3bb1"
889
888
  } : {
890
889
  target: "e1ocu3bb1",
891
890
  label: "StyledCardLeft"
892
- })("background-color:#f9f9fb;border-top:", _ref => {
891
+ })("height:100%;background-color:#f9f9fb;border-top:", _ref => {
893
892
  let isTopRow = _ref.isTopRow;
894
893
  return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
895
894
  }, ";border-radius:", _ref2 => {
896
895
  let isTopRow = _ref2.isTopRow;
897
896
  return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
898
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAyByC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCard = styled(Card)`\n  & > div {\n    height: 490px;\n    overflow-y: auto;\n  }\n`\nconst StyledCardLeft = styled(StyledCard)`\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\n\nconst StyledCardRight = styled(StyledCard)`\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType } = useExportResourcesContext()\n  const areAllGeneralFieldsChecked = formik.values.fields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneGeneralFieldChecked = formik.values.fields.some(\n    (field) => field.isChecked\n  )\n  const allCustomFields = formik.values.customFields.flatMap(\n    (customType) => customType.fields\n  )\n  const areAllCustomFieldsChecked = allCustomFields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneCustomFieldChecked = allCustomFields.some(\n    (field) => field.isChecked\n  )\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Spacings.Inline justifyContent=\"space-between\">\n          <Text.Body intlMessage={messages.selectFieldsToExport} />\n          <Link\n            isExternal\n            tone=\"secondary\"\n            intlMessage={messages.fieldDefinitions}\n            to={FIELD_DEFINITIONS_URLS[resourceType]}\n          />\n        </Spacings.Inline>\n        <Grid\n          gridAutoFlow=\"row\"\n          gridTemplateColumns={`${designTokens.constraint5} auto`}\n        >\n          <Grid.Item>\n            <StyledCardLeft isTopRow insetScale=\"l\">\n              <CheckboxInput\n                isIndeterminate={\n                  !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked\n                }\n                isChecked={areAllGeneralFieldsChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'fields',\n                    formik.values.fields.map((field) => ({\n                      ...field,\n                      isChecked: field.isRequired ? true : e.target.checked,\n                    }))\n                  )\n                }}\n              >\n                <Text.Body intlMessage={messages.allGeneralFields} />\n              </CheckboxInput>\n            </StyledCardLeft>\n          </Grid.Item>\n          <Grid.Item>\n            <StyledCardRight isTopRow insetScale=\"l\">\n              <Spacings.Stack scale=\"s\">\n                <GeneralFieldsSelection\n                  fields={formik.values.fields}\n                  setFieldValue={formik.setFieldValue}\n                />\n              </Spacings.Stack>\n            </StyledCardRight>\n          </Grid.Item>\n          {formik.values.customFields?.length > 0 && (\n            <>\n              <Grid.Item>\n                <StyledCardLeft insetScale=\"l\">\n                  <CheckboxInput\n                    isIndeterminate={\n                      !areAllCustomFieldsChecked &&\n                      isAtLeastOneCustomFieldChecked\n                    }\n                    isChecked={areAllCustomFieldsChecked}\n                    onChange={(e) => {\n                      formik.setFieldValue(\n                        'customFields',\n                        formik.values.customFields.map((customType) => ({\n                          ...customType,\n                          fields: customType.fields.map((field) => ({\n                            ...field,\n                            isChecked: e.target.checked,\n                          })),\n                        }))\n                      )\n                    }}\n                  >\n                    <Text.Body intlMessage={messages.allCustomFields} />\n                  </CheckboxInput>\n                </StyledCardLeft>\n              </Grid.Item>\n              <Grid.Item>\n                <StyledCardRight insetScale=\"l\">\n                  <Spacings.Stack scale=\"s\">\n                    <CheckboxInput\n                      isReadOnly\n                      onChange={() => {}}\n                      isChecked={isAtLeastOneCustomFieldChecked}\n                    >\n                      <Text.Body>\n                        {intl.formatMessage(messages.customTypeKeyAndTypeId)} *\n                      </Text.Body>\n                    </CheckboxInput>\n                    <CustomFieldsSelection\n                      customFields={formik.values.customFields}\n                      setFieldValue={formik.setFieldValue}\n                    />\n                  </Spacings.Stack>\n                </StyledCardRight>\n              </Grid.Item>\n            </>\n          )}\n        </Grid>\n      </Spacings.Stack>\n      <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n        <SecondaryButton\n          label={intl.formatMessage(messages.back)}\n          onClick={() => setCurrentStep(1)}\n        />\n        <PrimaryButton\n          label={intl.formatMessage(messages.startExport)}\n          onClick={formik.submitForm}\n          isDisabled={!formik.isValid}\n        />\n      </Spacings.Inline>\n    </Spacings.Stack>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
899
- const StyledCardRight = /*#__PURE__*/_styled(StyledCard, process.env.NODE_ENV === "production" ? {
897
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmBmC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow insetScale=\"l\">\n                <CheckboxInput\n                  isIndeterminate={\n                    !areAllGeneralFieldsChecked &&\n                    isAtLeastOneGeneralFieldChecked\n                  }\n                  isChecked={areAllGeneralFieldsChecked}\n                  onChange={(e) => {\n                    formik.setFieldValue(\n                      'fields',\n                      formik.values.fields.map((field) => ({\n                        ...field,\n                        isChecked: field.isRequired ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <Text.Body intlMessage={messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <Text.Body intlMessage={messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <Text.Body>\n                          {intl.formatMessage(messages.customTypeKeyAndTypeId)}{' '}\n                          *\n                        </Text.Body>\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
898
+ const StyledCardRight = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
900
899
  target: "e1ocu3bb0"
901
900
  } : {
902
901
  target: "e1ocu3bb0",
903
902
  label: "StyledCardRight"
904
- })("border-left:0;border-top:", _ref3 => {
903
+ })("height:100%;border-left:0;border-top:", _ref3 => {
905
904
  let isTopRow = _ref3.isTopRow;
906
905
  return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
907
906
  }, ";border-radius:", _ref4 => {
908
907
  let isTopRow = _ref4.isTopRow;
909
908
  return isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px';
910
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAiC0C","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCard = styled(Card)`\n  & > div {\n    height: 490px;\n    overflow-y: auto;\n  }\n`\nconst StyledCardLeft = styled(StyledCard)`\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\n\nconst StyledCardRight = styled(StyledCard)`\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType } = useExportResourcesContext()\n  const areAllGeneralFieldsChecked = formik.values.fields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneGeneralFieldChecked = formik.values.fields.some(\n    (field) => field.isChecked\n  )\n  const allCustomFields = formik.values.customFields.flatMap(\n    (customType) => customType.fields\n  )\n  const areAllCustomFieldsChecked = allCustomFields.every(\n    (field) => field.isChecked\n  )\n  const isAtLeastOneCustomFieldChecked = allCustomFields.some(\n    (field) => field.isChecked\n  )\n\n  return (\n    <Spacings.Stack scale=\"xl\">\n      <Spacings.Stack scale=\"m\">\n        <Spacings.Inline justifyContent=\"space-between\">\n          <Text.Body intlMessage={messages.selectFieldsToExport} />\n          <Link\n            isExternal\n            tone=\"secondary\"\n            intlMessage={messages.fieldDefinitions}\n            to={FIELD_DEFINITIONS_URLS[resourceType]}\n          />\n        </Spacings.Inline>\n        <Grid\n          gridAutoFlow=\"row\"\n          gridTemplateColumns={`${designTokens.constraint5} auto`}\n        >\n          <Grid.Item>\n            <StyledCardLeft isTopRow insetScale=\"l\">\n              <CheckboxInput\n                isIndeterminate={\n                  !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked\n                }\n                isChecked={areAllGeneralFieldsChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'fields',\n                    formik.values.fields.map((field) => ({\n                      ...field,\n                      isChecked: field.isRequired ? true : e.target.checked,\n                    }))\n                  )\n                }}\n              >\n                <Text.Body intlMessage={messages.allGeneralFields} />\n              </CheckboxInput>\n            </StyledCardLeft>\n          </Grid.Item>\n          <Grid.Item>\n            <StyledCardRight isTopRow insetScale=\"l\">\n              <Spacings.Stack scale=\"s\">\n                <GeneralFieldsSelection\n                  fields={formik.values.fields}\n                  setFieldValue={formik.setFieldValue}\n                />\n              </Spacings.Stack>\n            </StyledCardRight>\n          </Grid.Item>\n          {formik.values.customFields?.length > 0 && (\n            <>\n              <Grid.Item>\n                <StyledCardLeft insetScale=\"l\">\n                  <CheckboxInput\n                    isIndeterminate={\n                      !areAllCustomFieldsChecked &&\n                      isAtLeastOneCustomFieldChecked\n                    }\n                    isChecked={areAllCustomFieldsChecked}\n                    onChange={(e) => {\n                      formik.setFieldValue(\n                        'customFields',\n                        formik.values.customFields.map((customType) => ({\n                          ...customType,\n                          fields: customType.fields.map((field) => ({\n                            ...field,\n                            isChecked: e.target.checked,\n                          })),\n                        }))\n                      )\n                    }}\n                  >\n                    <Text.Body intlMessage={messages.allCustomFields} />\n                  </CheckboxInput>\n                </StyledCardLeft>\n              </Grid.Item>\n              <Grid.Item>\n                <StyledCardRight insetScale=\"l\">\n                  <Spacings.Stack scale=\"s\">\n                    <CheckboxInput\n                      isReadOnly\n                      onChange={() => {}}\n                      isChecked={isAtLeastOneCustomFieldChecked}\n                    >\n                      <Text.Body>\n                        {intl.formatMessage(messages.customTypeKeyAndTypeId)} *\n                      </Text.Body>\n                    </CheckboxInput>\n                    <CustomFieldsSelection\n                      customFields={formik.values.customFields}\n                      setFieldValue={formik.setFieldValue}\n                    />\n                  </Spacings.Stack>\n                </StyledCardRight>\n              </Grid.Item>\n            </>\n          )}\n        </Grid>\n      </Spacings.Stack>\n      <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n        <SecondaryButton\n          label={intl.formatMessage(messages.back)}\n          onClick={() => setCurrentStep(1)}\n        />\n        <PrimaryButton\n          label={intl.formatMessage(messages.startExport)}\n          onClick={formik.submitForm}\n          isDisabled={!formik.isValid}\n        />\n      </Spacings.Inline>\n    </Spacings.Stack>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
909
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA2BoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow insetScale=\"l\">\n                <CheckboxInput\n                  isIndeterminate={\n                    !areAllGeneralFieldsChecked &&\n                    isAtLeastOneGeneralFieldChecked\n                  }\n                  isChecked={areAllGeneralFieldsChecked}\n                  onChange={(e) => {\n                    formik.setFieldValue(\n                      'fields',\n                      formik.values.fields.map((field) => ({\n                        ...field,\n                        isChecked: field.isRequired ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <Text.Body intlMessage={messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <Text.Body intlMessage={messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <Text.Body>\n                          {intl.formatMessage(messages.customTypeKeyAndTypeId)}{' '}\n                          *\n                        </Text.Body>\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      <Text.Body>\n        {field.label} {field.isRequired && '*'}\n      </Text.Body>\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
911
910
  const ExportFieldsSelectionStep = () => {
912
- var _context, _context2, _context3, _formik$values$custom;
911
+ var _formik$values$custom;
913
912
  const intl = useIntl();
914
913
  const _useExportResourcesCo = useExportResourcesContext(),
915
914
  formik = _useExportResourcesCo.formik,
916
915
  setCurrentStep = _useExportResourcesCo.setCurrentStep,
917
- resourceType = _useExportResourcesCo.resourceType;
918
- const areAllGeneralFieldsChecked = _everyInstanceProperty(_context = _valuesInstanceProperty(formik).fields).call(_context, field => field.isChecked);
919
- const isAtLeastOneGeneralFieldChecked = _someInstanceProperty(_context2 = _valuesInstanceProperty(formik).fields).call(_context2, field => field.isChecked);
920
- const allCustomFields = _flatMapInstanceProperty(_context3 = _valuesInstanceProperty(formik).customFields).call(_context3, customType => customType.fields);
921
- const areAllCustomFieldsChecked = _everyInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
922
- const isAtLeastOneCustomFieldChecked = _someInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
923
- return jsxs(Spacings.Stack, {
924
- scale: "xl",
925
- children: [jsxs(Spacings.Stack, {
926
- scale: "m",
927
- children: [jsxs(Spacings.Inline, {
928
- justifyContent: "space-between",
929
- children: [jsx(Text.Body, {
930
- intlMessage: messages.selectFieldsToExport
931
- }), jsx(Link, {
932
- isExternal: true,
933
- tone: "secondary",
934
- intlMessage: messages.fieldDefinitions,
935
- to: FIELD_DEFINITIONS_URLS[resourceType]
936
- })]
937
- }), jsxs(Grid, {
938
- gridAutoFlow: "row",
939
- gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
940
- children: [jsx(Grid.Item, {
941
- children: jsx(StyledCardLeft, {
942
- isTopRow: true,
943
- insetScale: "l",
944
- children: jsx(CheckboxInput, {
945
- isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
946
- isChecked: areAllGeneralFieldsChecked,
947
- onChange: e => {
948
- var _context4;
949
- formik.setFieldValue('fields', _mapInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
950
- isChecked: field.isRequired ? true : e.target.checked
951
- })));
952
- },
953
- children: jsx(Text.Body, {
954
- intlMessage: messages.allGeneralFields
955
- })
956
- })
957
- })
958
- }), jsx(Grid.Item, {
959
- children: jsx(StyledCardRight, {
960
- isTopRow: true,
961
- insetScale: "l",
962
- children: jsx(Spacings.Stack, {
963
- scale: "s",
964
- children: jsx(GeneralFieldsSelection, {
965
- fields: _valuesInstanceProperty(formik).fields,
966
- setFieldValue: formik.setFieldValue
967
- })
968
- })
969
- })
970
- }), ((_formik$values$custom = _valuesInstanceProperty(formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxs(Fragment, {
916
+ resourceType = _useExportResourcesCo.resourceType,
917
+ onClose = _useExportResourcesCo.onClose;
918
+ const resourceTypePlural = resourceTypeToDisplayName({
919
+ resourceType: resourceType,
920
+ isPlural: true
921
+ });
922
+ const areAllGeneralFieldsChecked = React.useMemo(() => {
923
+ var _context;
924
+ return _everyInstanceProperty(_context = _valuesInstanceProperty(formik).fields).call(_context, field => field.isChecked);
925
+ }, [_valuesInstanceProperty(formik).fields]);
926
+ const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {
927
+ var _context2;
928
+ return _someInstanceProperty(_context2 = _valuesInstanceProperty(formik).fields).call(_context2, field => field.isChecked);
929
+ }, [_valuesInstanceProperty(formik).fields]);
930
+ const allCustomFields = React.useMemo(() => {
931
+ var _context3;
932
+ return _flatMapInstanceProperty(_context3 = _valuesInstanceProperty(formik).customFields).call(_context3, customType => customType.fields);
933
+ }, [_valuesInstanceProperty(formik).customFields]);
934
+ const areAllCustomFieldsChecked = React.useMemo(() => {
935
+ return _everyInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
936
+ }, [allCustomFields]);
937
+ const isAtLeastOneCustomFieldChecked = React.useMemo(() => {
938
+ return _someInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
939
+ }, [allCustomFields]);
940
+ return jsx(FormDialog, {
941
+ isOpen: true,
942
+ title: intl.formatMessage(messages.modalTitle, {
943
+ resourceType: resourceTypePlural
944
+ }),
945
+ labelPrimary: intl.formatMessage(messages.startExport),
946
+ onPrimaryButtonClick: formik.submitForm,
947
+ isPrimaryButtonDisabled: !formik.isValid,
948
+ labelSecondary: intl.formatMessage(messages.back),
949
+ onSecondaryButtonClick: () => setCurrentStep(1),
950
+ onClose: onClose,
951
+ size: 16,
952
+ children: jsx(Spacings.Stack, {
953
+ scale: "xl",
954
+ children: jsxs(Spacings.Stack, {
955
+ scale: "m",
956
+ children: [jsxs(Spacings.Inline, {
957
+ justifyContent: "space-between",
958
+ children: [jsx(Text.Body, {
959
+ intlMessage: messages.selectFieldsToExport
960
+ }), jsx(Link, {
961
+ isExternal: true,
962
+ tone: "secondary",
963
+ intlMessage: messages.fieldDefinitions,
964
+ to: FIELD_DEFINITIONS_URLS[resourceType]
965
+ })]
966
+ }), jsxs(Grid, {
967
+ gridAutoFlow: "row",
968
+ gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
971
969
  children: [jsx(Grid.Item, {
972
970
  children: jsx(StyledCardLeft, {
971
+ isTopRow: true,
973
972
  insetScale: "l",
974
973
  children: jsx(CheckboxInput, {
975
- isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
976
- isChecked: areAllCustomFieldsChecked,
974
+ isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
975
+ isChecked: areAllGeneralFieldsChecked,
977
976
  onChange: e => {
978
- var _context5;
979
- formik.setFieldValue('customFields', _mapInstanceProperty(_context5 = _valuesInstanceProperty(formik).customFields).call(_context5, customType => {
980
- var _context6;
981
- return _objectSpread$2(_objectSpread$2({}, customType), {}, {
982
- fields: _mapInstanceProperty(_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
983
- isChecked: e.target.checked
984
- }))
985
- });
986
- }));
977
+ var _context4;
978
+ formik.setFieldValue('fields', _mapInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
979
+ isChecked: field.isRequired ? true : e.target.checked
980
+ })));
987
981
  },
988
982
  children: jsx(Text.Body, {
989
- intlMessage: messages.allCustomFields
983
+ intlMessage: messages.allGeneralFields
990
984
  })
991
985
  })
992
986
  })
993
987
  }), jsx(Grid.Item, {
994
988
  children: jsx(StyledCardRight, {
989
+ isTopRow: true,
995
990
  insetScale: "l",
996
- children: jsxs(Spacings.Stack, {
991
+ children: jsx(Spacings.Stack, {
997
992
  scale: "s",
998
- children: [jsx(CheckboxInput, {
999
- isReadOnly: true,
1000
- onChange: () => {},
1001
- isChecked: isAtLeastOneCustomFieldChecked,
1002
- children: jsxs(Text.Body, {
1003
- children: [intl.formatMessage(messages.customTypeKeyAndTypeId), " *"]
1004
- })
1005
- }), jsx(CustomFieldsSelection, {
1006
- customFields: _valuesInstanceProperty(formik).customFields,
993
+ children: jsx(GeneralFieldsSelection, {
994
+ fields: _valuesInstanceProperty(formik).fields,
1007
995
  setFieldValue: formik.setFieldValue
1008
- })]
996
+ })
1009
997
  })
1010
998
  })
999
+ }), ((_formik$values$custom = _valuesInstanceProperty(formik).customFields) === null || _formik$values$custom === void 0 ? void 0 : _formik$values$custom.length) > 0 && jsxs(Fragment, {
1000
+ children: [jsx(Grid.Item, {
1001
+ children: jsx(StyledCardLeft, {
1002
+ insetScale: "l",
1003
+ children: jsx(CheckboxInput, {
1004
+ isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
1005
+ isChecked: areAllCustomFieldsChecked,
1006
+ onChange: e => {
1007
+ var _context5;
1008
+ formik.setFieldValue('customFields', _mapInstanceProperty(_context5 = _valuesInstanceProperty(formik).customFields).call(_context5, customType => {
1009
+ var _context6;
1010
+ return _objectSpread$2(_objectSpread$2({}, customType), {}, {
1011
+ fields: _mapInstanceProperty(_context6 = customType.fields).call(_context6, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
1012
+ isChecked: e.target.checked
1013
+ }))
1014
+ });
1015
+ }));
1016
+ },
1017
+ children: jsx(Text.Body, {
1018
+ intlMessage: messages.allCustomFields
1019
+ })
1020
+ })
1021
+ })
1022
+ }), jsx(Grid.Item, {
1023
+ children: jsx(StyledCardRight, {
1024
+ insetScale: "l",
1025
+ children: jsxs(Spacings.Stack, {
1026
+ scale: "s",
1027
+ children: [jsx(CheckboxInput, {
1028
+ isReadOnly: true,
1029
+ onChange: () => {},
1030
+ isChecked: isAtLeastOneCustomFieldChecked,
1031
+ children: jsxs(Text.Body, {
1032
+ children: [intl.formatMessage(messages.customTypeKeyAndTypeId), ' ', "*"]
1033
+ })
1034
+ }), jsx(CustomFieldsSelection, {
1035
+ customFields: _valuesInstanceProperty(formik).customFields,
1036
+ setFieldValue: formik.setFieldValue
1037
+ })]
1038
+ })
1039
+ })
1040
+ })]
1011
1041
  })]
1012
1042
  })]
1013
- })]
1014
- }), jsxs(Spacings.Inline, {
1015
- scale: "m",
1016
- justifyContent: "flex-end",
1017
- children: [jsx(SecondaryButton, {
1018
- label: intl.formatMessage(messages.back),
1019
- onClick: () => setCurrentStep(1)
1020
- }), jsx(PrimaryButton, {
1021
- label: intl.formatMessage(messages.startExport),
1022
- onClick: formik.submitForm,
1023
- isDisabled: !formik.isValid
1024
- })]
1025
- })]
1043
+ })
1044
+ })
1026
1045
  });
1027
1046
  };
1028
1047
  const GeneralFieldsSelection = _ref5 => {
@@ -1161,17 +1180,12 @@ const ExportResourcesProvider = props => {
1161
1180
  React.useEffect(() => {
1162
1181
  formik.validateForm();
1163
1182
  }, [currentStep]);
1164
- React.useEffect(() => {
1165
- if (props.isOpen) {
1166
- formik.resetForm();
1167
- setCurrentStep(1);
1168
- }
1169
- }, [props.isOpen]);
1170
1183
  return jsx(ExportResourcesContext.Provider, {
1171
1184
  value: {
1185
+ formik,
1172
1186
  currentStep,
1173
1187
  setCurrentStep,
1174
- formik,
1188
+ onClose: props.onClose,
1175
1189
  resourceType: props.resourceType,
1176
1190
  exportType: props.exportType,
1177
1191
  totalResourcesCount: props.totalResourcesCount,
@@ -1198,21 +1212,9 @@ const CurrentStep = () => {
1198
1212
  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; }
1199
1213
  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; }
1200
1214
  const ExportResourcesModal = props => {
1201
- const intl = useIntl();
1202
- const resourceTypePlural = resourceTypeToDisplayName({
1203
- resourceType: props.resourceType,
1204
- isPlural: true
1205
- });
1215
+ if (!props.isOpen) return null;
1206
1216
  return jsx(ExportResourcesProvider, _objectSpread(_objectSpread({}, props), {}, {
1207
- children: jsx(InfoDialog, {
1208
- isOpen: props.isOpen,
1209
- title: intl.formatMessage(messages.modalTitle, {
1210
- resourceType: resourceTypePlural
1211
- }),
1212
- onClose: props.onClose,
1213
- size: 16,
1214
- children: jsx(CurrentStep, {})
1215
- })
1217
+ children: jsx(CurrentStep, {})
1216
1218
  }));
1217
1219
  };
1218
1220
  ExportResourcesModal.displayName = 'ExportResourcesModal';