@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
|
|
13
|
-
import
|
|
14
|
-
import
|
|
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
|
|
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$
|
|
147
|
-
function _objectSpread$
|
|
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$
|
|
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$
|
|
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$
|
|
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$
|
|
269
|
-
fields: _mapInstanceProperty(_context5 = customType.fields).call(_context5, field => _objectSpread$
|
|
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
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
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: "
|
|
837
|
+
scale: "m",
|
|
838
838
|
children: [jsx(SelectField, {
|
|
839
|
-
|
|
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
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
}), jsx(
|
|
851
|
-
|
|
852
|
-
onChange:
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
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
|
-
})
|
|
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
|
-
|
|
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(
|
|
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
|
|
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
|
-
|
|
919
|
-
const
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
children: jsx(
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
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: !
|
|
976
|
-
isChecked:
|
|
974
|
+
isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
|
|
975
|
+
isChecked: areAllGeneralFieldsChecked,
|
|
977
976
|
onChange: e => {
|
|
978
|
-
var
|
|
979
|
-
formik.setFieldValue('
|
|
980
|
-
|
|
981
|
-
|
|
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.
|
|
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:
|
|
991
|
+
children: jsx(Spacings.Stack, {
|
|
997
992
|
scale: "s",
|
|
998
|
-
children:
|
|
999
|
-
|
|
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
|
-
})
|
|
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
|
-
|
|
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
|
-
|
|
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(
|
|
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';
|