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