@commercetools-frontend-extensions/export-resources-modal 0.0.0-canary-20250923074036 → 0.0.0-canary-20251204134053

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.
@@ -2,74 +2,3609 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var dist_commercetoolsFrontendExtensionsExportResourcesModal = require('./index-9307c4c9.cjs.dev.js');
6
- require('react');
7
- require('@commercetools-frontend/ui-kit');
8
- require('@emotion/react/jsx-runtime');
9
- require('@babel/runtime-corejs3/core-js-stable/object/keys');
10
- require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
11
- require('@babel/runtime-corejs3/core-js-stable/instance/filter');
12
- require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
13
- require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
14
- require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
15
- require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
16
- require('@babel/runtime-corejs3/core-js-stable/object/define-property');
17
- require('@babel/runtime-corejs3/helpers/defineProperty');
18
- require('react-intl');
19
- require('@babel/runtime-corejs3/core-js-stable/instance/values');
20
- require('@commercetools-frontend/application-components');
21
- require('@commercetools-frontend/fullstory');
22
- require('@babel/runtime-corejs3/core-js-stable/instance/map');
23
- require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
24
- require('@babel/runtime-corejs3/core-js-stable/instance/concat');
25
- require('omit-empty-es');
26
- require('@babel/runtime-corejs3/core-js-stable/instance/some');
27
- require('@babel/runtime-corejs3/core-js-stable/instance/find');
28
- require('@babel/runtime-corejs3/core-js-stable/instance/every');
29
- require('@babel/runtime-corejs3/core-js-stable/array/is-array');
30
- require('@babel/runtime-corejs3/core-js-stable/set');
31
- require('@babel/runtime-corejs3/core-js-stable/instance/sort');
32
- require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
33
- require('@babel/runtime-corejs3/core-js-stable/instance/trim');
34
- require('@babel/runtime-corejs3/core-js-stable/instance/bind');
35
- require('@babel/runtime-corejs3/core-js-stable/reflect/construct');
36
- require('@babel/runtime-corejs3/helpers/createClass');
37
- require('@babel/runtime-corejs3/helpers/classCallCheck');
38
- require('@babel/runtime-corejs3/helpers/possibleConstructorReturn');
39
- require('@babel/runtime-corejs3/helpers/getPrototypeOf');
40
- require('@babel/runtime-corejs3/helpers/inherits');
41
- require('@babel/runtime-corejs3/helpers/wrapNativeSuper');
42
- require('@babel/runtime-corejs3/core-js-stable/promise');
43
- require('@babel/runtime-corejs3/core-js-stable/instance/slice');
44
- require('@babel/runtime-corejs3/core-js-stable/instance/includes');
45
- require('@babel/runtime-corejs3/core-js-stable/object/values');
46
- require('@commercetools-frontend/application-shell-connectors');
47
- require('@babel/runtime-corejs3/helpers/slicedToArray');
48
- require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
49
- require('formik');
50
- require('@commercetools-uikit/icons');
51
- require('react-dropzone');
52
- require('@babel/runtime-corejs3/core-js-stable/json/stringify');
53
- require('@commercetools-frontend/actions-global');
54
- require('@commercetools-frontend/constants');
55
- require('@commercetools-frontend/sdk');
56
- require('@babel/runtime-corejs3/core-js-stable/object/entries');
57
- require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
58
- require('@babel/runtime-corejs3/core-js-stable/instance/ends-with');
59
- require('@commercetools-frontend/l10n');
60
- require('lodash/sortBy');
61
- require('@emotion/styled/base');
62
- require('lodash/debounce');
63
- require('@emotion/react');
64
- require('lodash/get');
65
- require('@commercetools-frontend/i18n');
66
- require('@commercetools-frontend/sentry');
67
-
68
-
69
-
70
- exports.EXPORTABLE_RESOURCES = dist_commercetoolsFrontendExtensionsExportResourcesModal.EXPORTABLE_RESOURCES;
71
- exports.EXPORT_TYPES = dist_commercetoolsFrontendExtensionsExportResourcesModal.EXPORT_TYPES;
72
- exports.LocaleOption = dist_commercetoolsFrontendExtensionsExportResourcesModal.LocaleOption;
73
- exports.Step = dist_commercetoolsFrontendExtensionsExportResourcesModal.Step;
74
- exports["default"] = dist_commercetoolsFrontendExtensionsExportResourcesModal.ExportResourcesModal;
75
- exports.useConvertFieldDefinitionsForExport = dist_commercetoolsFrontendExtensionsExportResourcesModal.useConvertFieldDefinitionsForExport;
5
+ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
6
+ var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
7
+ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
8
+ var _Object$entries = require('@babel/runtime-corejs3/core-js-stable/object/entries');
9
+ var _startsWithInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
10
+ var _endsWithInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/ends-with');
11
+ var _JSON$stringify = require('@babel/runtime-corejs3/core-js-stable/json/stringify');
12
+ var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
13
+ var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
14
+ var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
15
+ var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
16
+ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
17
+ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
18
+ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
19
+ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
20
+ var reactIntl = require('react-intl');
21
+ var applicationShellConnectors = require('@commercetools-frontend/application-shell-connectors');
22
+ var uiKit = require('@commercetools-frontend/ui-kit');
23
+ var jsxRuntime = require('@emotion/react/jsx-runtime');
24
+ var _valuesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/values');
25
+ var applicationComponents = require('@commercetools-frontend/application-components');
26
+ var fullstory = require('@commercetools-frontend/fullstory');
27
+ var operations = require('@commercetools-frontend-extensions/operations');
28
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
29
+ var React = require('react');
30
+ var _Reflect$construct = require('@babel/runtime-corejs3/core-js-stable/reflect/construct');
31
+ var _createClass = require('@babel/runtime-corejs3/helpers/createClass');
32
+ var _classCallCheck = require('@babel/runtime-corejs3/helpers/classCallCheck');
33
+ var _possibleConstructorReturn = require('@babel/runtime-corejs3/helpers/possibleConstructorReturn');
34
+ var _getPrototypeOf = require('@babel/runtime-corejs3/helpers/getPrototypeOf');
35
+ var _inherits = require('@babel/runtime-corejs3/helpers/inherits');
36
+ var _wrapNativeSuper = require('@babel/runtime-corejs3/helpers/wrapNativeSuper');
37
+ var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
38
+ var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
39
+ var omitEmpty = require('omit-empty-es');
40
+ var _someInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/some');
41
+ var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
42
+ var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
43
+ var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
44
+ var _Set = require('@babel/runtime-corejs3/core-js-stable/set');
45
+ var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
46
+ var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
47
+ var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
48
+ var _bindInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/bind');
49
+ var _Promise = require('@babel/runtime-corejs3/core-js-stable/promise');
50
+ var _sliceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/slice');
51
+ var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
52
+ var _Object$values = require('@babel/runtime-corejs3/core-js-stable/object/values');
53
+ var actionsGlobal = require('@commercetools-frontend/actions-global');
54
+ var constants = require('@commercetools-frontend/constants');
55
+ var sdk = require('@commercetools-frontend/sdk');
56
+ var l10n = require('@commercetools-frontend/l10n');
57
+ var sortBy = require('lodash/sortBy');
58
+ var _styled = require('@emotion/styled/base');
59
+ var debounce = require('lodash/debounce');
60
+ var formik = require('formik');
61
+ var icons = require('@commercetools-uikit/icons');
62
+ var react = require('@emotion/react');
63
+ var get = require('lodash/get');
64
+ var i18n = require('@commercetools-frontend/i18n');
65
+ var sentry = require('@commercetools-frontend/sentry');
66
+
67
+ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
68
+
69
+ var _Object$entries__default = /*#__PURE__*/_interopDefault(_Object$entries);
70
+ var _startsWithInstanceProperty__default = /*#__PURE__*/_interopDefault(_startsWithInstanceProperty);
71
+ var _endsWithInstanceProperty__default = /*#__PURE__*/_interopDefault(_endsWithInstanceProperty);
72
+ var _JSON$stringify__default = /*#__PURE__*/_interopDefault(_JSON$stringify);
73
+ var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
74
+ var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
75
+ var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
76
+ var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
77
+ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
78
+ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
79
+ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
80
+ var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
81
+ var _valuesInstanceProperty__default = /*#__PURE__*/_interopDefault(_valuesInstanceProperty);
82
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
83
+ var React__default = /*#__PURE__*/_interopDefault(React);
84
+ var _Reflect$construct__default = /*#__PURE__*/_interopDefault(_Reflect$construct);
85
+ var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
86
+ var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
87
+ var omitEmpty__default = /*#__PURE__*/_interopDefault(omitEmpty);
88
+ var _someInstanceProperty__default = /*#__PURE__*/_interopDefault(_someInstanceProperty);
89
+ var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
90
+ var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
91
+ var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
92
+ var _Set__default = /*#__PURE__*/_interopDefault(_Set);
93
+ var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
94
+ var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
95
+ var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
96
+ var _bindInstanceProperty__default = /*#__PURE__*/_interopDefault(_bindInstanceProperty);
97
+ var _Promise__default = /*#__PURE__*/_interopDefault(_Promise);
98
+ var _sliceInstanceProperty__default = /*#__PURE__*/_interopDefault(_sliceInstanceProperty);
99
+ var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
100
+ var _Object$values__default = /*#__PURE__*/_interopDefault(_Object$values);
101
+ var sortBy__default = /*#__PURE__*/_interopDefault(sortBy);
102
+ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
103
+ var debounce__default = /*#__PURE__*/_interopDefault(debounce);
104
+ var get__default = /*#__PURE__*/_interopDefault(get);
105
+
106
+ function getBold(chunks) {
107
+ return jsxRuntime.jsx(uiKit.Text.Body, {
108
+ as: "span",
109
+ fontWeight: "bold",
110
+ children: chunks
111
+ }, crypto.randomUUID());
112
+ }
113
+ function getSmallBold(chunks) {
114
+ return jsxRuntime.jsx(uiKit.Text.Detail, {
115
+ as: "span",
116
+ fontWeight: "bold",
117
+ children: chunks
118
+ }, crypto.randomUUID());
119
+ }
120
+
121
+ function getNewLine() {
122
+ return jsxRuntime.jsx("br", {}, crypto.randomUUID());
123
+ }
124
+
125
+ var messages = reactIntl.defineMessages({
126
+ 'modalTitle.category': {
127
+ id: 'ExportResourcesModal.modalTitle.category',
128
+ description: 'Label for the categories modal title',
129
+ defaultMessage: 'Export categories'
130
+ },
131
+ 'modalTitle.product': {
132
+ id: 'ExportResourcesModal.modalTitle.product',
133
+ description: 'Label for the products modal title',
134
+ defaultMessage: 'Export products'
135
+ },
136
+ 'modalTitle.inventory-entry': {
137
+ id: 'ExportResourcesModal.modalTitle.inventoryEntry',
138
+ description: 'Label for the inventories modal title',
139
+ defaultMessage: 'Export inventories'
140
+ },
141
+ 'modalTitle.discount-code': {
142
+ id: 'ExportResourcesModal.modalTitle.discountCode',
143
+ description: 'Label for the discount codes modal title',
144
+ defaultMessage: 'Export discount codes'
145
+ },
146
+ 'modalTitle.customer': {
147
+ id: 'ExportResourcesModal.modalTitle.customer',
148
+ description: 'Label for the customers modal title',
149
+ defaultMessage: 'Export customers'
150
+ },
151
+ 'modalTitle.order': {
152
+ id: 'ExportResourcesModal.modalTitle.order',
153
+ description: 'Label for the orders modal title',
154
+ defaultMessage: 'Export orders'
155
+ },
156
+ 'modalTitle.product-type': {
157
+ id: 'ExportResourcesModal.modalTitle.productType',
158
+ description: 'Label for the product types modal title',
159
+ defaultMessage: 'Export product types'
160
+ },
161
+ 'modalTitle.business-unit': {
162
+ id: 'ExportResourcesModal.modalTitle.businessUnit',
163
+ description: 'Label for the business units modal title',
164
+ defaultMessage: 'Export business units'
165
+ },
166
+ outputFormat: {
167
+ id: 'ExportResourcesModal.outputFormat',
168
+ description: 'File format like (csv, xls, ...etc)',
169
+ defaultMessage: 'File format'
170
+ },
171
+ fileName: {
172
+ id: 'ExportResourcesModal.fileName',
173
+ description: 'exported file name',
174
+ defaultMessage: 'File name'
175
+ },
176
+ locales: {
177
+ id: 'ExportResourcesModal.locales',
178
+ description: 'Locales',
179
+ defaultMessage: 'Locales'
180
+ },
181
+ exportBasedOnMyViewsMessage: {
182
+ id: 'ExportResourcesModal.exportBasedOnMyViewsMessage',
183
+ description: 'Select Export setttings based on my views',
184
+ defaultMessage: 'Select export settings based on:'
185
+ },
186
+ propertiesPanelLabel: {
187
+ id: 'ExportResourcesModal.propertiesPanelLabel',
188
+ description: 'properties panel label',
189
+ defaultMessage: 'Properties'
190
+ },
191
+ exportOperationSuccessMessage: {
192
+ id: 'ExportResourcesModal.exportOperationSuccessMessage',
193
+ description: 'Success message',
194
+ defaultMessage: '<b>Your export has started.</b> <newline></newline><logsLink>Go to Export logs</logsLink> to view the progress and download the file.'
195
+ },
196
+ nothingApplied: {
197
+ id: 'ExportResourcesModal.nothingApplied',
198
+ description: 'Shown when there is no filter applied',
199
+ defaultMessage: 'nothing applied'
200
+ },
201
+ includeAllLocales: {
202
+ id: 'ExportResourcesModal.includeAllLocales',
203
+ description: 'label for "Include all locales" checkbox',
204
+ defaultMessage: 'Include all locales'
205
+ },
206
+ includeAllLocalesRadioOption: {
207
+ id: 'ExportResourcesModal.includeAllLocalesRadioOption',
208
+ description: 'label for "all" option in locales radio options',
209
+ defaultMessage: 'all'
210
+ },
211
+ onlyLocalesFoundInCsvFileTooltip: {
212
+ id: 'ExportResourcesModal.onlyLocalesFoundInCsvFileTooltip',
213
+ description: 'Tooltip for "only locales found in the CSV file" option',
214
+ defaultMessage: 'Upload a file first to be able to select this option'
215
+ },
216
+ includeOnlySelectedLocalesRadioOption: {
217
+ id: 'ExportResourcesModal.includeOnlySelectedLocalesRadioOption',
218
+ description: 'label for "only selected" option in locales radio options',
219
+ defaultMessage: 'only selected'
220
+ },
221
+ onlyLocalesFoundInCsvFile: {
222
+ id: 'ExportResourcesModal.onlyLocalesFoundInCsvFile',
223
+ description: 'label for "only locales found in the CSV file" option in locales radio options',
224
+ defaultMessage: 'only locales found in the CSV file'
225
+ },
226
+ missingFileNameError: {
227
+ id: 'ExportResourcesModal.missingFileNameError',
228
+ description: 'Error when file name field is missing',
229
+ defaultMessage: 'Please enter a file name'
230
+ },
231
+ invalidFileNameError: {
232
+ id: 'ExportResourcesModal.invalidFileNameError',
233
+ description: 'Error when file name field is not valid',
234
+ defaultMessage: 'File name may only contain alphanumeric characters, hyphens and underscores'
235
+ },
236
+ missingLocaleError: {
237
+ id: 'ExportResourcesModal.missingLocaleError',
238
+ description: 'Error when no locale is selected',
239
+ defaultMessage: 'Please select at least one locale'
240
+ },
241
+ myViews: {
242
+ id: 'ExportResourcesModal.myViews',
243
+ description: 'Label for "My Views" Select Field',
244
+ defaultMessage: 'My Views'
245
+ },
246
+ selectFieldsToExport: {
247
+ id: 'ExportResourcesModal.selectFieldsToExport',
248
+ defaultMessage: 'Select fields to export'
249
+ },
250
+ back: {
251
+ id: 'ExportResourcesModal.back',
252
+ description: 'Label for "Back" button',
253
+ defaultMessage: 'Back'
254
+ },
255
+ startExport: {
256
+ id: 'ExportResourcesModal.startExport',
257
+ description: 'Label for "Start export" button',
258
+ defaultMessage: 'Start export'
259
+ },
260
+ fieldDefinitions: {
261
+ id: 'ExportResourcesModal.fieldDefinitions',
262
+ description: 'Label for "Field definitions" link',
263
+ defaultMessage: 'Field definitions'
264
+ },
265
+ unexpectedError: {
266
+ id: 'ExportResourcesModal.unexpectedError',
267
+ description: 'Generic notification message when starting export process fails',
268
+ defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
269
+ },
270
+ searchForFields: {
271
+ id: 'ExportResourcesModal.searchForFields',
272
+ description: 'Placeholder for "Search for fields" search input',
273
+ defaultMessage: 'Search for fields'
274
+ },
275
+ thereAreNoResults: {
276
+ id: 'ExportResourcesModal.thereAreNoResults',
277
+ description: 'No search results message',
278
+ defaultMessage: 'There are no results that match your search.'
279
+ },
280
+ suggestions: {
281
+ id: 'ExportResourcesModal.suggestions',
282
+ description: 'In Export fields selection - Suggestions message',
283
+ defaultMessage: 'Suggestions:'
284
+ },
285
+ checkTheSpelling: {
286
+ id: 'ExportResourcesModal.checkTheSpelling',
287
+ description: 'In Export fields selection - Check the spelling message',
288
+ defaultMessage: 'Check the spelling.'
289
+ },
290
+ searchByEnteringTheExactFieldName: {
291
+ id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
292
+ description: 'In Export fields selection - Search by entering the exact field name message',
293
+ defaultMessage: 'Try searching by entering the exact field name.'
294
+ },
295
+ scope: {
296
+ id: 'ExportResourcesModal.scope',
297
+ description: 'Label for "Scope:"',
298
+ defaultMessage: 'Scope:'
299
+ },
300
+ exportScopeAllCategories: {
301
+ id: 'ExportResourcesModal.exportScopeAllCategories',
302
+ description: 'Label for Export All categories',
303
+ defaultMessage: 'Export all: {total, plural, one {# category} other {# categories}}'
304
+ },
305
+ exportScopeSelectedCategories: {
306
+ id: 'ExportResourcesModal.exportScopeSelectedCategories',
307
+ description: 'Label for Export Selected categories',
308
+ defaultMessage: 'Export selected: {total, plural, one {# category} other {# categories}}'
309
+ },
310
+ exportScopeFilteredCategories: {
311
+ id: 'ExportResourcesModal.exportScopeFilteredCategories',
312
+ description: 'Label for Export Filtered categories',
313
+ defaultMessage: 'Export filtered: {total, plural, one {# category} other {# categories}}'
314
+ },
315
+ exportScopeAllProducts: {
316
+ id: 'ExportResourcesModal.exportScopeAllProducts',
317
+ description: 'Label for Export All products',
318
+ defaultMessage: 'Export all: {total, plural, one {# product} other {# products}}'
319
+ },
320
+ exportScopeSelectedProducts: {
321
+ id: 'ExportResourcesModal.exportScopeSelectedProducts',
322
+ description: 'Label for Export Selected products',
323
+ defaultMessage: 'Export selected: {total, plural, one {# product} other {# products}}'
324
+ },
325
+ exportScopeFilteredProducts: {
326
+ id: 'ExportResourcesModal.exportScopeFilteredProducts',
327
+ description: 'Label for Export Filtered products',
328
+ defaultMessage: 'Export filtered: {total, plural, one {# product} other {# products}}'
329
+ },
330
+ exportScopeAllProductTypes: {
331
+ id: 'ExportResourcesModal.exportScopeAllProductTypes',
332
+ description: 'Label for Export All product types',
333
+ defaultMessage: 'Export all: {total, plural, one {# product type} other {# product types}}'
334
+ },
335
+ exportScopeSelectedProductTypes: {
336
+ id: 'ExportResourcesModal.exportScopeSelectedProductTypes',
337
+ description: 'Label for Export Selected product types',
338
+ defaultMessage: 'Export selected: {total, plural, one {# product type} other {# product types}}'
339
+ },
340
+ exportScopeFilteredProductTypes: {
341
+ id: 'ExportResourcesModal.exportScopeFilteredProductTypes',
342
+ description: 'Label for Export Filtered product types',
343
+ defaultMessage: 'Export filtered: {total, plural, one {# product type} other {# product types}}'
344
+ },
345
+ exportInventoriesForAllProducts: {
346
+ id: 'ExportResourcesModal.exportInventoriesForAllProducts',
347
+ description: 'Label for Export All inventories',
348
+ defaultMessage: 'Export inventories for all {total, plural, one {# product} other {# products}}'
349
+ },
350
+ exportInventoriesForSelectedProducts: {
351
+ id: 'ExportResourcesModal.exportInventoriesForSelectedProducts',
352
+ description: 'Label for Export Selected inventories',
353
+ defaultMessage: 'Export inventories for the {total, plural, one {# selected product} other {# selected products}}'
354
+ },
355
+ exportInventoriesForFilteredProducts: {
356
+ id: 'ExportResourcesModal.exportInventoriesForFilteredProducts',
357
+ description: 'Label for Export Filtered inventories',
358
+ defaultMessage: 'Export inventories for the {total, plural, one {# filtered product} other {# filtered products}}'
359
+ },
360
+ exportScopeAllDiscountCodes: {
361
+ id: 'ExportResourcesModal.exportScopeAllDiscountCodes',
362
+ description: 'Label for Export All discount codes',
363
+ defaultMessage: 'Export all: {total, plural, one {# discount code} other {# discount codes}}'
364
+ },
365
+ exportScopeSelectedDiscountCodes: {
366
+ id: 'ExportResourcesModal.exportScopeSelectedDiscountCodes',
367
+ description: 'Label for Export Selected discount codes',
368
+ defaultMessage: 'Export selected: {total, plural, one {# discount code} other {# discount codes}}'
369
+ },
370
+ exportScopeFilteredDiscountCodes: {
371
+ id: 'ExportResourcesModal.exportScopeFilteredDiscountCodes',
372
+ description: 'Label for Export Filtered discount codes',
373
+ defaultMessage: 'Export filtered: {total, plural, one {# discount code} other {# discount codes}}'
374
+ },
375
+ exportScopeAllBusinessUnits: {
376
+ id: 'ExportResourcesModal.exportScopeAllBusinessUnits',
377
+ description: 'Label for Export All business units',
378
+ defaultMessage: 'Export all: {total, plural, one {# business unit} other {# business units}}'
379
+ },
380
+ exportScopeSelectedBusinessUnits: {
381
+ id: 'ExportResourcesModal.exportScopeSelectedBusinessUnits',
382
+ description: 'Label for Export Selected business units',
383
+ defaultMessage: 'Export selected: {total, plural, one {# business unit} other {# business units}}'
384
+ },
385
+ exportScopeFilteredBusinessUnits: {
386
+ id: 'ExportResourcesModal.exportScopeFilteredBusinessUnits',
387
+ description: 'Label for Export Filtered business units',
388
+ defaultMessage: 'Export filtered: {total, plural, one {# business unit} other {# business units}}'
389
+ },
390
+ exportScopeAllOrders: {
391
+ id: 'ExportResourcesModal.exportScopeAllOrders',
392
+ description: 'Label for Export All orders',
393
+ defaultMessage: 'Export all: {total, plural, one {# order} other {# orders}}'
394
+ },
395
+ exportScopeSelectedOrders: {
396
+ id: 'ExportResourcesModal.exportScopeSelectedOrders',
397
+ description: 'Label for Export Selected orders',
398
+ defaultMessage: 'Export selected: {total, plural, one {# order} other {# orders}}'
399
+ },
400
+ exportScopeFilteredOrders: {
401
+ id: 'ExportResourcesModal.exportScopeFilteredOrders',
402
+ description: 'Label for Export Filtered orders',
403
+ defaultMessage: 'Export filtered: {total, plural, one {# order} other {# orders}}'
404
+ },
405
+ exportScopeAllCustomers: {
406
+ id: 'ExportResourcesModal.exportScopeAllCustomers',
407
+ description: 'Label for Export All customers',
408
+ defaultMessage: 'Export all: {total, plural, one {# customer} other {# customers}}'
409
+ },
410
+ exportScopeSelectedCustomers: {
411
+ id: 'ExportResourcesModal.exportScopeSelectedCustomers',
412
+ description: 'Label for Export Selected customers',
413
+ defaultMessage: 'Export selected: {total, plural, one {# customer} other {# customers}}'
414
+ },
415
+ exportScopeFilteredCustomers: {
416
+ id: 'ExportResourcesModal.exportScopeFilteredCustomers',
417
+ description: 'Label for Export Filtered customers',
418
+ defaultMessage: 'Export filtered: {total, plural, one {# customer} other {# customers}}'
419
+ },
420
+ exportScopeSelectedWithoutCount: {
421
+ id: 'ExportResourcesModal.exportScopeSelectedWithoutCount',
422
+ description: 'Label for Export Selected without count',
423
+ defaultMessage: 'Export selected'
424
+ },
425
+ exportScopeFilteredWithoutCount: {
426
+ id: 'ExportResourcesModal.exportScopeFilteredWithoutCount',
427
+ description: 'Label for Export Filtered without count',
428
+ defaultMessage: 'Export filtered'
429
+ },
430
+ exportAllWithoutCount: {
431
+ id: 'ExportResourcesModal.exportAllWithoutCount',
432
+ description: 'Label for Export All without count',
433
+ defaultMessage: 'Export all'
434
+ },
435
+ saveAs: {
436
+ id: 'ExportResourcesModal.saveAs',
437
+ description: 'Label for "Save as:"',
438
+ defaultMessage: 'Save as:'
439
+ },
440
+ selected: {
441
+ id: 'ExportResourcesModal.selected',
442
+ description: 'Label for total Selected',
443
+ defaultMessage: '{total} selected'
444
+ },
445
+ fillRows: {
446
+ id: 'ExportResourcesModal.fillRows',
447
+ description: 'A checkbox label for filling rows with complete data',
448
+ defaultMessage: 'Fill all rows with complete data'
449
+ },
450
+ moreInformation: {
451
+ id: 'ExportResourcesModal.moreInformation',
452
+ description: 'A label for more information',
453
+ defaultMessage: 'For more information, refer to the {documentationLink}'
454
+ },
455
+ documentation: {
456
+ id: 'ExportResourcesModal.documentation',
457
+ description: 'A label for Documentation link',
458
+ defaultMessage: 'Documentation'
459
+ },
460
+ loadMoreFields: {
461
+ id: 'ExportResourcesModal.loadMoreFields',
462
+ description: 'Load more fields message',
463
+ defaultMessage: 'Load more fields by using the search functionality or specify the full list of fields with a CSV file'
464
+ },
465
+ itemCount: {
466
+ id: 'ExportResourcesModal.itemCount',
467
+ description: 'Label for item count',
468
+ defaultMessage: '{count, plural, one {# item} other {# items}}'
469
+ },
470
+ exportPreview: {
471
+ id: 'ExportResourcesModal.exportPreview',
472
+ description: 'Label for export preview step',
473
+ defaultMessage: 'Export preview'
474
+ },
475
+ selectDifferentFields: {
476
+ id: 'ExportResourcesModal.selectDifferentFields',
477
+ description: 'Label for "Select different fields" button',
478
+ defaultMessage: 'Select different fields'
479
+ },
480
+ fieldsToBeExportedInLanguages: {
481
+ id: 'ExportResourcesModal.fieldsToBeExportedInLanguages',
482
+ description: 'Label for fields to be exported in languages',
483
+ defaultMessage: '{fieldCount, plural, one {<b>1</b> field to be exported in {languageCount, plural, one {<b>1</b> language} other {<b>{languageCount}</b> languages}}} other {<b>{fieldCount}</b> fields to be exported in {languageCount, plural, one {<b>1</b> language} other {<b>{languageCount}</b> languages}}}}:'
484
+ },
485
+ fieldsToBeExported: {
486
+ id: 'ExportResourcesModal.fieldsToBeExported',
487
+ description: 'Label for fields to be exported',
488
+ defaultMessage: '{fieldCount, plural, one {<b>1</b> field to be exported} other {<b>{fieldCount}</b> fields to be exported}}:'
489
+ },
490
+ confirmSelection: {
491
+ id: 'ExportResourcesModal.confirmSelection',
492
+ description: 'Label for "Confirm selection" button',
493
+ defaultMessage: 'Confirm selection'
494
+ },
495
+ exportProcessMayTakeAWhile: {
496
+ id: 'ExportResourcesModal.exportProcessMayTakeAWhile',
497
+ description: 'The export process may take a while',
498
+ defaultMessage: 'The export process may take a while. To view the progress and download the file after starting the export, go to <exportLogsLink>Export logs</exportLogsLink> area, located in the <operationsIcon></operationsIcon> Operations menu.'
499
+ },
500
+ showAll: {
501
+ id: 'ExportResourcesModal.showAll',
502
+ description: 'Label for "Show all" button',
503
+ defaultMessage: 'Show all'
504
+ },
505
+ showLess: {
506
+ id: 'ExportResourcesModal.showLess',
507
+ description: 'Label for "Show less" button',
508
+ defaultMessage: 'Show less'
509
+ },
510
+ selectFieldsFromLimitedList: {
511
+ id: 'ExportResourcesModal.selectFieldsFromLimitedList',
512
+ description: 'Label for "Select fields from a limited list" button',
513
+ defaultMessage: 'Select fields from a limited list'
514
+ },
515
+ selectFieldsFromImportedCSV: {
516
+ id: 'ExportResourcesModal.selectFieldsFromImportedCSV',
517
+ description: 'Label for "Select fields from an imported CSV" button',
518
+ defaultMessage: 'Select fields from an imported CSV'
519
+ },
520
+ defineFieldsToIncludeInExport: {
521
+ id: 'ExportResourcesModal.defineFieldsToIncludeInExport',
522
+ description: 'A message to define the fields to include in export',
523
+ defaultMessage: 'Define the fields to include in your export with a CSV file below. The file must contain column headers in the predefined format shown in <templateLink>our template</templateLink>. A previously exported CSV can be used as well.'
524
+ },
525
+ chooseFile: {
526
+ id: 'ExportResourcesModal.chooseFile',
527
+ description: 'Label for "Choose file" button',
528
+ defaultMessage: 'Choose file'
529
+ },
530
+ or: {
531
+ id: 'ExportResourcesModal.or',
532
+ description: 'Label for "or" text',
533
+ defaultMessage: 'or'
534
+ },
535
+ dragAndDropCSV: {
536
+ id: 'ExportResourcesModal.dragAndDropCSV',
537
+ description: 'Label for "Drag and drop CSV" text',
538
+ defaultMessage: 'Drag and drop CSV'
539
+ },
540
+ browseFile: {
541
+ id: 'ExportResourcesModal.browseFile',
542
+ description: 'Label for "Browse file" button',
543
+ defaultMessage: 'browse file'
544
+ },
545
+ stepCount: {
546
+ id: 'ExportResourcesModal.stepCount',
547
+ description: 'Step count',
548
+ defaultMessage: 'Step {currentStep}/{totalSteps}'
549
+ },
550
+ stepNumber: {
551
+ id: 'ExportResourcesModal.stepNumber',
552
+ description: 'Step number',
553
+ defaultMessage: 'Step {stepNumber}'
554
+ },
555
+ selectContentToExport: {
556
+ id: 'ExportResourcesModal.selectContentToExport',
557
+ description: 'Label for "Select content to export" button',
558
+ defaultMessage: 'Select content to export'
559
+ },
560
+ errorType: {
561
+ id: 'ExportResourcesModal.errorType',
562
+ description: 'Label for error type column',
563
+ defaultMessage: 'Error type'
564
+ },
565
+ details: {
566
+ id: 'ExportResourcesModal.details',
567
+ description: 'Label for details column',
568
+ defaultMessage: 'Details'
569
+ },
570
+ backToSelection: {
571
+ id: 'ExportResourcesModal.backToSelection',
572
+ description: 'Label for "Back to selection" button',
573
+ defaultMessage: 'Back to selection'
574
+ },
575
+ uploadDifferentCSV: {
576
+ id: 'ExportResourcesModal.uploadDifferentCSV',
577
+ description: 'Label for "Upload a different CSV file" button',
578
+ defaultMessage: 'Upload a different CSV file'
579
+ },
580
+ csvUploadFailed: {
581
+ id: 'ExportResourcesModal.csvUploadFailed',
582
+ description: 'CSV upload failed title',
583
+ defaultMessage: 'CSV upload failed'
584
+ },
585
+ backToPreviousStep: {
586
+ id: 'ExportResourcesModal.backToPreviousStep',
587
+ description: 'Label for "Back to previous step" button',
588
+ defaultMessage: 'Back to previous step'
589
+ },
590
+ notSupportedField: {
591
+ id: 'ExportResourcesModal.notSupportedField',
592
+ description: 'Not supported field error',
593
+ defaultMessage: 'Not supported field'
594
+ },
595
+ duplicateField: {
596
+ id: 'ExportResourcesModal.duplicateField',
597
+ description: 'Duplicate field error',
598
+ defaultMessage: 'Duplicate field'
599
+ },
600
+ localizedFieldWithoutLocale: {
601
+ id: 'ExportResourcesModal.localizedFieldWithoutLocale',
602
+ description: 'Localized field without locale error',
603
+ defaultMessage: 'Localized field without locale'
604
+ },
605
+ attributeDefinitionNotFound: {
606
+ id: 'ExportResourcesModal.attributeDefinitionNotFound',
607
+ description: 'Attribute definition not found error',
608
+ defaultMessage: 'Attribute definition not found'
609
+ },
610
+ fieldDefinitionNotFound: {
611
+ id: 'ExportResourcesModal.fieldDefinitionNotFound',
612
+ description: 'Field definition not found error',
613
+ defaultMessage: 'Field definition not found'
614
+ },
615
+ incompleteField: {
616
+ id: 'ExportResourcesModal.incompleteField',
617
+ description: 'Incomplete field error',
618
+ defaultMessage: 'Incomplete field'
619
+ },
620
+ attributeLevelMismatch: {
621
+ id: 'ExportResourcesModal.attributeLevelMismatch',
622
+ description: 'Attribute level mismatch error',
623
+ defaultMessage: 'Attribute level mismatch'
624
+ },
625
+ notSupportedFieldsTitle: {
626
+ id: 'ExportResourcesModal.notSupportedFieldsTitle',
627
+ description: 'Title for not supported fields error',
628
+ defaultMessage: 'The following fields are not supported for the resource type:'
629
+ },
630
+ localizedFieldWithoutLocaleTitle: {
631
+ id: 'ExportResourcesModal.localizedFieldWithoutLocaleTitle',
632
+ description: 'Title for localized fields without locale error',
633
+ defaultMessage: 'The following localised fields do not specify any locale suffix. Pick a different option in the Locales field or upload a different CSV file:'
634
+ },
635
+ incompleteFieldTitle: {
636
+ id: 'ExportResourcesModal.incompleteFieldTitle',
637
+ description: 'Title for incomplete fields error',
638
+ defaultMessage: 'The following fields are missing a subfield:'
639
+ },
640
+ duplicateFieldTitle: {
641
+ id: 'ExportResourcesModal.duplicateFieldTitle',
642
+ description: 'Title for duplicate fields error',
643
+ defaultMessage: 'The following fields are duplicated. Each field must appear once:'
644
+ },
645
+ attributeDefinitionNotFoundTitle: {
646
+ id: 'ExportResourcesModal.attributeDefinitionNotFoundTitle',
647
+ description: 'Title for attribute definitions not found error',
648
+ defaultMessage: 'The following attribute(s) cannot be found in this project:'
649
+ },
650
+ fieldDefinitionNotFoundTitle: {
651
+ id: 'ExportResourcesModal.fieldDefinitionNotFoundTitle',
652
+ description: 'Title for field definitions not found error',
653
+ defaultMessage: 'The following custom field(s) cannot be found in this project:'
654
+ },
655
+ attributeLevelMismatchProductLevelTitle: {
656
+ id: 'ExportResourcesModal.attributeLevelMismatchProductLevelTitle',
657
+ description: 'Title for attribute level mismatch error when attribute needs to be at Product level',
658
+ defaultMessage: "Attribute needs to be defined at the Product level. Change the mapping by using this format <b>productAttributes.'{'nameOfAttribute'}'</b>."
659
+ },
660
+ attributeLevelMismatchVariantLevelTitle: {
661
+ id: 'ExportResourcesModal.attributeLevelMismatchVariantLevelTitle',
662
+ description: 'Title for attribute level mismatch error when attribute needs to be at Variant level',
663
+ defaultMessage: "Attribute needs to be defined at the Variant level. Change the mapping by using this format <b>attributes.'{'nameOfAttribute'}'</b>."
664
+ },
665
+ unknownError: {
666
+ id: 'ExportResourcesModal.unknownError',
667
+ description: 'Unknown error',
668
+ defaultMessage: 'An unknown error occurred'
669
+ },
670
+ uploadErrorsDetected: {
671
+ id: 'ExportResourcesModal.uploadErrorsDetected',
672
+ description: 'Message shown when errors are detected during file upload',
673
+ defaultMessage: 'There are <b>{total}</b> errors detected while uploading the file <b>{fileName}</b>. Use <templateLink>our template</templateLink> to review the right formatting and supported values, try exporting using our field selection first or visit <documentationLink>our documentation</documentationLink> for further information.'
674
+ },
675
+ queryPredicate: {
676
+ id: 'ExportResourcesModal.queryPredicate',
677
+ description: 'Label for query predicate option',
678
+ defaultMessage: 'Query predicate'
679
+ },
680
+ invalidQueryPredicate: {
681
+ id: 'ExportResourcesModal.invalidQueryPredicate',
682
+ description: 'Error when query predicate field is not valid',
683
+ defaultMessage: 'There is an error with the query predicate. Make sure the syntax is correct.'
684
+ },
685
+ missingQueryPredicateError: {
686
+ id: 'ExportResourcesModal.missingQueryPredicateError',
687
+ description: 'Error when query predicate field is missing',
688
+ defaultMessage: 'Please enter a query predicate'
689
+ },
690
+ noResourcesToExportForQueryPredicate: {
691
+ id: 'ExportResourcesModal.noResourcesToExportForQueryPredicate',
692
+ description: 'Error message when there are no resources to export for given query predicate',
693
+ defaultMessage: 'No resources match your query predicate. Please check your query predicate and try again.'
694
+ },
695
+ separators: {
696
+ id: 'ExportResourcesModal.separators',
697
+ description: 'Label for separators',
698
+ defaultMessage: 'Separators'
699
+ },
700
+ separatorsDescription: {
701
+ id: 'ExportResourcesModal.separatorsDescription',
702
+ description: 'Description for column separators',
703
+ defaultMessage: 'Configure how columns are separated in the exported file'
704
+ },
705
+ columns: {
706
+ id: 'ExportResourcesModal.columns',
707
+ description: 'Label for column separator select',
708
+ defaultMessage: 'Columns'
709
+ },
710
+ decimals: {
711
+ id: 'ExportResourcesModal.decimals',
712
+ description: 'Label for decimal separator select',
713
+ defaultMessage: 'Decimals'
714
+ },
715
+ columnSeparatorComma: {
716
+ id: 'ExportResourcesModal.columnSeparatorComma',
717
+ description: 'Label for comma column separator option',
718
+ defaultMessage: 'comma (,)'
719
+ },
720
+ columnSeparatorSemicolon: {
721
+ id: 'ExportResourcesModal.columnSeparatorSemicolon',
722
+ description: 'Label for semicolon column separator option',
723
+ defaultMessage: 'semicolon (;)'
724
+ },
725
+ decimalSeparatorPoint: {
726
+ id: 'ExportResourcesModal.decimalSeparatorPoint',
727
+ description: 'Label for point decimal separator option',
728
+ defaultMessage: 'point (.)'
729
+ },
730
+ decimalSeparatorComma: {
731
+ id: 'ExportResourcesModal.decimalSeparatorComma',
732
+ description: 'Label for comma decimal separator option',
733
+ defaultMessage: 'comma (,)'
734
+ },
735
+ columnSeparatorTab: {
736
+ id: 'ExportResourcesModal.columnSeparatorTab',
737
+ description: 'Label for tab column separator option',
738
+ defaultMessage: 'tab (\\t)'
739
+ },
740
+ columnSeparatorPipe: {
741
+ id: 'ExportResourcesModal.columnSeparatorPipe',
742
+ description: 'Label for pipe column separator option',
743
+ defaultMessage: 'pipe (|)'
744
+ },
745
+ csvSettings: {
746
+ id: 'ExportResourcesModal.csvSettings',
747
+ description: 'Label for CSV settings section',
748
+ defaultMessage: 'CSV settings:'
749
+ },
750
+ excelOptimized: {
751
+ id: 'ExportResourcesModal.excelOptimized',
752
+ description: 'Label for Excel-optimized CSV export checkbox',
753
+ defaultMessage: 'CSV file optimized for Excel'
754
+ },
755
+ excelOptimizedDescription: {
756
+ id: 'ExportResourcesModal.excelOptimizedDescription',
757
+ description: 'Description for Excel-optimized CSV export checkbox',
758
+ defaultMessage: 'Checking this option will prevent Excel from interpreting the data of the file.'
759
+ },
760
+ readMoreOnDocumentation: {
761
+ id: 'ExportResourcesModal.readMoreOnDocumentation',
762
+ description: 'Read more on documentation',
763
+ defaultMessage: 'Read more on the {documentationLink}'
764
+ }
765
+ });
766
+
767
+ function ownKeys$g(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; }
768
+ function _objectSpread$g(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$g(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$g(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
769
+ function renderFileNameError(key) {
770
+ switch (key) {
771
+ case 'missing':
772
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$g({}, messages.missingFileNameError));
773
+ case 'invalidInput':
774
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$g({}, messages.invalidFileNameError));
775
+ default:
776
+ return null;
777
+ }
778
+ }
779
+ function renderLocaleError(key) {
780
+ switch (key) {
781
+ case 'missing':
782
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$g({}, messages.missingLocaleError));
783
+ default:
784
+ return null;
785
+ }
786
+ }
787
+ const renderQueryPredicateError = key => {
788
+ switch (key) {
789
+ case 'missing':
790
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$g({}, messages.missingQueryPredicateError));
791
+ case 'invalidInput':
792
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$g({}, messages.invalidQueryPredicate));
793
+ case 'noResourcesToExportForQueryPredicate':
794
+ return jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$g({}, messages.noResourcesToExportForQueryPredicate));
795
+ default:
796
+ return null;
797
+ }
798
+ };
799
+
800
+ const Z_INDEX_DROPDOWN = 30000;
801
+ const OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION = 'OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION';
802
+ const OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP = 'OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP';
803
+ const TOTAL_STEPS = 3;
804
+
805
+ const COLUMN_DELIMITER_OPTIONS = [{
806
+ label: messages.columnSeparatorComma,
807
+ value: operations.DELIMITERS.COMMA
808
+ }, {
809
+ label: messages.columnSeparatorSemicolon,
810
+ value: operations.DELIMITERS.SEMICOLON
811
+ }, {
812
+ label: messages.columnSeparatorTab,
813
+ value: operations.DELIMITERS.TAB
814
+ }, {
815
+ label: messages.columnSeparatorPipe,
816
+ value: operations.DELIMITERS.PIPE
817
+ }];
818
+ const DECIMAL_DELIMITER_OPTIONS = [{
819
+ label: messages.decimalSeparatorPoint,
820
+ value: operations.DELIMITERS.POINT
821
+ }, {
822
+ label: messages.decimalSeparatorComma,
823
+ value: operations.DELIMITERS.COMMA
824
+ }];
825
+
826
+ const EXPORT_OPERATION_STATES = {
827
+ PROCESSING: 'processing',
828
+ COMPLETED: 'completed',
829
+ FAILED: 'failed',
830
+ QUEUED: 'queued'
831
+ };
832
+
833
+ const EXPORT_TYPES = {
834
+ ALL: 'all',
835
+ FILTERED: 'filtered',
836
+ SELECTED: 'selected',
837
+ QUERY_PREDICATE: 'query-predicate'
838
+ };
839
+
840
+ const EXPORTABLE_RESOURCES = {
841
+ CATEGORY: 'category',
842
+ PRODUCT: 'product',
843
+ PRODUCT_TYPE: 'product-type',
844
+ DISCOUNT_CODE: 'discount-code',
845
+ INVENTORY_ENTRY: 'inventory-entry',
846
+ ORDER: 'order',
847
+ CUSTOMER: 'customer',
848
+ BUSINESS_UNIT: 'business-unit'
849
+ };
850
+
851
+ const OUTPUT_FORMATS = {
852
+ JSON: 'json',
853
+ CSV: 'csv'
854
+ };
855
+ const OUTPUT_FORMAT_OPTIONS = [{
856
+ value: OUTPUT_FORMATS.CSV,
857
+ label: 'CSV'
858
+ }, {
859
+ value: OUTPUT_FORMATS.JSON,
860
+ label: 'JSON'
861
+ }];
862
+
863
+ const EXPORT_DATA_DOCUMENTATION_LINK = 'https://docs.commercetools.com/merchant-center/export-data';
864
+ const CSV_TEMPLATES_LINK = 'https://docs.commercetools.com/merchant-center/import-data#download-a-template';
865
+ const CSV_STRUCTURE_DOCUMENTATION_LINK = 'https://docs.commercetools.com/merchant-center/export-data#structure-of-exported-csv-files';
866
+ const EXPORT_EXCEL_DOCUMENTATION_LINK = 'https://docs.commercetools.com/merchant-center/export-data#optimize-csv-file-for-microsoft-excel';
867
+
868
+ const resourceTypeMessages = {
869
+ [EXPORTABLE_RESOURCES.CATEGORY]: {
870
+ exportScopeAll: messages.exportScopeAllCategories,
871
+ exportScopeSelected: messages.exportScopeSelectedCategories,
872
+ exportScopeFiltered: messages.exportScopeFilteredCategories
873
+ },
874
+ [EXPORTABLE_RESOURCES.PRODUCT]: {
875
+ exportScopeAll: messages.exportScopeAllProducts,
876
+ exportScopeSelected: messages.exportScopeSelectedProducts,
877
+ exportScopeFiltered: messages.exportScopeFilteredProducts
878
+ },
879
+ [EXPORTABLE_RESOURCES.PRODUCT_TYPE]: {
880
+ exportScopeAll: messages.exportScopeAllProductTypes,
881
+ exportScopeSelected: messages.exportScopeSelectedProductTypes,
882
+ exportScopeFiltered: messages.exportScopeFilteredProductTypes
883
+ },
884
+ [EXPORTABLE_RESOURCES.INVENTORY_ENTRY]: {
885
+ exportScopeAll: messages.exportInventoriesForAllProducts,
886
+ exportScopeSelected: messages.exportInventoriesForSelectedProducts,
887
+ exportScopeFiltered: messages.exportInventoriesForFilteredProducts
888
+ },
889
+ [EXPORTABLE_RESOURCES.DISCOUNT_CODE]: {
890
+ exportScopeAll: messages.exportAllWithoutCount,
891
+ exportScopeSelected: messages.exportScopeSelectedWithoutCount,
892
+ exportScopeFiltered: messages.exportScopeFilteredWithoutCount
893
+ },
894
+ [EXPORTABLE_RESOURCES.ORDER]: {
895
+ exportScopeAll: messages.exportScopeAllOrders,
896
+ exportScopeSelected: messages.exportScopeSelectedOrders,
897
+ exportScopeFiltered: messages.exportScopeFilteredOrders
898
+ },
899
+ [EXPORTABLE_RESOURCES.CUSTOMER]: {
900
+ exportScopeAll: messages.exportScopeAllCustomers,
901
+ exportScopeSelected: messages.exportScopeSelectedCustomers,
902
+ exportScopeFiltered: messages.exportScopeFilteredCustomers
903
+ },
904
+ [EXPORTABLE_RESOURCES.BUSINESS_UNIT]: {
905
+ exportScopeAll: messages.exportScopeAllBusinessUnits,
906
+ exportScopeSelected: messages.exportScopeSelectedBusinessUnits,
907
+ exportScopeFiltered: messages.exportScopeFilteredBusinessUnits
908
+ }
909
+ };
910
+
911
+ const FIELD_SELECTION_MODES = {
912
+ SELECTED_FIELDS: 'selected-fields',
913
+ IMPORTED_CSV_TEMPLATE: 'imported-csv-template'
914
+ };
915
+
916
+ function ownKeys$f(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; }
917
+ function _objectSpread$f(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$f(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$f(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
918
+ const DEFAULT_SHORT_LIVED_FLAGS = {};
919
+ const DEFAULT_LONG_LIVED_FLAGS = {};
920
+ _objectSpread$f(_objectSpread$f({}, DEFAULT_SHORT_LIVED_FLAGS), DEFAULT_LONG_LIVED_FLAGS);
921
+
922
+ function _callSuper$3(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct$3() ? _Reflect$construct__default["default"](o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
923
+ function _isNativeReflectConstruct$3() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$3 = function () { return !!t; })(); }
924
+ let MissingExportResourceProviderError = /*#__PURE__*/function (_Error) {
925
+ function MissingExportResourceProviderError() {
926
+ var _this;
927
+ _classCallCheck(this, MissingExportResourceProviderError);
928
+ _this = _callSuper$3(this, MissingExportResourceProviderError, ['useExportResourcesModalContext must be used within ExportResourcesProvider']);
929
+ _this.name = 'MissingExportResourceProviderError';
930
+ return _this;
931
+ }
932
+ _inherits(MissingExportResourceProviderError, _Error);
933
+ return _createClass(MissingExportResourceProviderError);
934
+ }(/*#__PURE__*/_wrapNativeSuper(Error));
935
+
936
+ function _callSuper$2(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct$2() ? _Reflect$construct__default["default"](o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
937
+ function _isNativeReflectConstruct$2() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$2 = function () { return !!t; })(); }
938
+ let UnexpectedExportOperationStateError = /*#__PURE__*/function (_Error) {
939
+ function UnexpectedExportOperationStateError(state) {
940
+ var _this;
941
+ _classCallCheck(this, UnexpectedExportOperationStateError);
942
+ _this = _callSuper$2(this, UnexpectedExportOperationStateError, [`Unexpected export operation state "${state}"`]);
943
+ _this.name = 'UnexpectedExportOperationStateError';
944
+ return _this;
945
+ }
946
+ _inherits(UnexpectedExportOperationStateError, _Error);
947
+ return _createClass(UnexpectedExportOperationStateError);
948
+ }(/*#__PURE__*/_wrapNativeSuper(Error));
949
+
950
+ function _callSuper$1(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct$1() ? _Reflect$construct__default["default"](o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
951
+ function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
952
+ let UnexpectedResourceTypeError = /*#__PURE__*/function (_Error) {
953
+ function UnexpectedResourceTypeError(resourceType) {
954
+ var _this;
955
+ _classCallCheck(this, UnexpectedResourceTypeError);
956
+ _this = _callSuper$1(this, UnexpectedResourceTypeError, [`Unexpected resource type "${resourceType}"`]);
957
+ _this.name = 'UnexpectedResourceTypeError';
958
+ return _this;
959
+ }
960
+ _inherits(UnexpectedResourceTypeError, _Error);
961
+ return _createClass(UnexpectedResourceTypeError);
962
+ }(/*#__PURE__*/_wrapNativeSuper(Error));
963
+
964
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? _Reflect$construct__default["default"](o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
965
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
966
+ let InvalidResponseError = /*#__PURE__*/function (_Error) {
967
+ function InvalidResponseError() {
968
+ var _this;
969
+ let message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'Invalid API response';
970
+ _classCallCheck(this, InvalidResponseError);
971
+ _this = _callSuper(this, InvalidResponseError, [message]);
972
+ _this.name = 'InvalidResponseError';
973
+ return _this;
974
+ }
975
+ _inherits(InvalidResponseError, _Error);
976
+ return _createClass(InvalidResponseError);
977
+ }(/*#__PURE__*/_wrapNativeSuper(Error));
978
+
979
+ function useExportResourcesModalContext() {
980
+ const context = React.useContext(ExportResourcesContext);
981
+ if (!context) {
982
+ throw new MissingExportResourceProviderError();
983
+ }
984
+ return context;
985
+ }
986
+
987
+ function ownKeys$e(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; }
988
+ function _objectSpread$e(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$e(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$e(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
989
+ const defaultOptions = {
990
+ storageType: 'local',
991
+ segregateByUser: true
992
+ };
993
+ const safeParse = value => {
994
+ if (value === null) return value;
995
+ try {
996
+ return JSON.parse(value);
997
+ } catch {
998
+ return value;
999
+ }
1000
+ };
1001
+ const serialize = value => _JSON$stringify__default["default"](value);
1002
+ const getStorage = storageType => storageType === 'session' ? sessionStorage : localStorage;
1003
+ const isNil = value => typeof value === 'undefined' || value === null;
1004
+ const useStorage = (storageKey, initialStorageValue, options) => {
1005
+ var _context;
1006
+ const mergedOptions = _objectSpread$e(_objectSpread$e({}, defaultOptions), options);
1007
+ const userId = applicationShellConnectors.useApplicationContext(context => context.user?.id);
1008
+ const scopedStorageKey = _filterInstanceProperty__default["default"](_context = [mergedOptions.segregateByUser && userId, storageKey]).call(_context, Boolean).join('/');
1009
+ const readFromStorage = React.useCallback(() => {
1010
+ const rawStorageValue = getStorage(mergedOptions.storageType).getItem(scopedStorageKey);
1011
+
1012
+ /**
1013
+ * NOTE:
1014
+ * We prior wrote `undefined` or `null` to storage which when written
1015
+ * to storage via `setItem` results in `"undefined"` or `"null"`
1016
+ * being written polluting the storage.
1017
+ */
1018
+ if (rawStorageValue === 'undefined' || rawStorageValue === 'null') {
1019
+ getStorage(mergedOptions.storageType).removeItem(scopedStorageKey);
1020
+ return null;
1021
+ }
1022
+ const parsedStorageValue = safeParse(rawStorageValue);
1023
+ return parsedStorageValue;
1024
+ }, [mergedOptions.storageType, scopedStorageKey]);
1025
+ const initializeStorageValue = () => {
1026
+ // default the storage value to the initial provided value when provided
1027
+ return readFromStorage() ?? initialStorageValue ?? null;
1028
+ };
1029
+ const _useState = React.useState(initializeStorageValue),
1030
+ _useState2 = _slicedToArray(_useState, 2),
1031
+ actualStorageValue = _useState2[0],
1032
+ setActualStorageValue = _useState2[1];
1033
+ const writeToStorage = React.useCallback(nextStorageValue => {
1034
+ getStorage(mergedOptions.storageType).setItem(scopedStorageKey, serialize(nextStorageValue));
1035
+ setActualStorageValue(nextStorageValue);
1036
+ }, [scopedStorageKey, mergedOptions.storageType]);
1037
+
1038
+ // set the initial storage value in the storage. The reason why this is not
1039
+ // done in initializeStorageValue is the state initializer function should
1040
+ // be pure.
1041
+ // https://beta.reactjs.org/apis/react/useState#my-initializer-or-updater-function-runs-twice
1042
+ React.useEffect(() => {
1043
+ if (isNil(readFromStorage()) && !isNil(initialStorageValue)) {
1044
+ writeToStorage(initialStorageValue);
1045
+ }
1046
+ }, [actualStorageValue, initialStorageValue, readFromStorage, writeToStorage]);
1047
+ return [actualStorageValue, writeToStorage, readFromStorage];
1048
+ };
1049
+
1050
+ function resourceTypeToFileName(resourceType, locale) {
1051
+ var _context;
1052
+ const date = new Date();
1053
+ const dateFormatter = new Intl.DateTimeFormat(locale, {
1054
+ year: '2-digit',
1055
+ month: '2-digit',
1056
+ day: '2-digit',
1057
+ hour: '2-digit',
1058
+ minute: '2-digit',
1059
+ hour12: false
1060
+ });
1061
+ const parts = dateFormatter.formatToParts(date);
1062
+ const dateParts = _reduceInstanceProperty__default["default"](parts).call(parts, (acc, part) => {
1063
+ if (part.type !== 'literal') {
1064
+ acc[part.type] = part.value;
1065
+ }
1066
+ return acc;
1067
+ }, {});
1068
+ const orderedDateParts = _mapInstanceProperty__default["default"](_context = _filterInstanceProperty__default["default"](parts).call(parts, part => part.type === 'day' || part.type === 'month' || part.type === 'year')).call(_context, part => dateParts[part.type]).join('-');
1069
+ const formattedDate = `${orderedDateParts}_${dateParts.hour}-${dateParts.minute}`;
1070
+ const resourceTypeMap = {
1071
+ [EXPORTABLE_RESOURCES.CATEGORY]: 'Categories',
1072
+ [EXPORTABLE_RESOURCES.PRODUCT]: 'Products',
1073
+ [EXPORTABLE_RESOURCES.PRODUCT_TYPE]: 'Product_Types',
1074
+ [EXPORTABLE_RESOURCES.DISCOUNT_CODE]: 'Discount_Codes',
1075
+ [EXPORTABLE_RESOURCES.INVENTORY_ENTRY]: 'Inventories',
1076
+ [EXPORTABLE_RESOURCES.CUSTOMER]: 'Customers',
1077
+ [EXPORTABLE_RESOURCES.ORDER]: 'Orders',
1078
+ [EXPORTABLE_RESOURCES.BUSINESS_UNIT]: 'Business_Units'
1079
+ };
1080
+ const displayName = resourceTypeMap[resourceType];
1081
+ if (!displayName) {
1082
+ throw new UnexpectedResourceTypeError(resourceType);
1083
+ }
1084
+ return `${displayName}_Export_${formattedDate}`;
1085
+ }
1086
+ function mapLocalesToOptions(locales) {
1087
+ return _mapInstanceProperty__default["default"](locales).call(locales, locale => ({
1088
+ value: locale,
1089
+ label: locale
1090
+ }));
1091
+ }
1092
+ function isFilledArray(maybeArray) {
1093
+ return _Array$isArray__default["default"](maybeArray) && maybeArray.length > 0;
1094
+ }
1095
+ const extractFieldNamesAndAdditionalFieldExtensions = fields => {
1096
+ const result = _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
1097
+ if (field.extendedFieldNames) {
1098
+ return [...acc, field.name, ...field.extendedFieldNames];
1099
+ }
1100
+ return [...acc, field.name];
1101
+ }, []);
1102
+ return [...new _Set__default["default"](result)];
1103
+ };
1104
+ function sortFieldsByFieldOrder(_ref) {
1105
+ let fieldNames = _ref.fieldNames,
1106
+ fieldOrder = _ref.fieldOrder;
1107
+ if (isFilledArray(fieldOrder)) {
1108
+ return _sortInstanceProperty__default["default"](fieldNames).call(fieldNames, (a, b) => {
1109
+ 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]);
1110
+ 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]);
1111
+
1112
+ // If a field is not 'custom',then consider it as '*'
1113
+ orderA = orderA === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderA;
1114
+ orderB = orderB === -1 ? _indexOfInstanceProperty__default["default"](fieldOrder).call(fieldOrder, '*') : orderB;
1115
+ return orderA - orderB;
1116
+ });
1117
+ }
1118
+ return fieldNames;
1119
+ }
1120
+ function buildSelectedExportFilters(selectedResourceIds) {
1121
+ if (!selectedResourceIds || selectedResourceIds?.length === 0) return undefined;
1122
+ const formattedIds = _mapInstanceProperty__default["default"](selectedResourceIds).call(selectedResourceIds, id => `"${id}"`).join(', ');
1123
+ return `id in (${formattedIds})`;
1124
+ }
1125
+ function isQueryFilter(filters) {
1126
+ if (!filters) return false;
1127
+ return 'query' in filters;
1128
+ }
1129
+ function isSearchFilter(filters) {
1130
+ if (!filters) return false;
1131
+ return 'filters' in filters || 'fullText' in filters;
1132
+ }
1133
+ function isPredicateFilter(filters) {
1134
+ if (!filters) return false;
1135
+ return 'where' in filters;
1136
+ }
1137
+ function validateFilters(filtersObject) {
1138
+ if (filtersObject.where && filtersObject.filters) {
1139
+ return false;
1140
+ }
1141
+ return Boolean(isQueryFilter(filtersObject.filters) || isSearchFilter(filtersObject.filters) || isPredicateFilter(filtersObject));
1142
+ }
1143
+ function areFiltersApplied(filtersObject) {
1144
+ var _context2;
1145
+ if (!filtersObject) {
1146
+ return false;
1147
+ }
1148
+ if (filtersObject.where && _trimInstanceProperty__default["default"](_context2 = filtersObject.where).call(_context2) !== '') {
1149
+ return true;
1150
+ }
1151
+ if (isQueryFilter(filtersObject.filters)) {
1152
+ return Boolean(filtersObject.filters.query);
1153
+ }
1154
+ if (isSearchFilter(filtersObject.filters)) {
1155
+ var _context3, _context4;
1156
+ const _filters = filtersObject.filters;
1157
+ return Boolean(_filters.filters?.length || ((_context3 = _filters.fullText?.text) == null ? void 0 : _bindInstanceProperty__default["default"](_context4 = Function.call).call(_context4, _trimInstanceProperty__default["default"](_context3), _context3))?.());
1158
+ }
1159
+ return false;
1160
+ }
1161
+ function getInitialExportType(args) {
1162
+ if (args.selectedResourceIds?.length) {
1163
+ return EXPORT_TYPES.SELECTED;
1164
+ }
1165
+ if (args.filters?.total && areFiltersApplied(args.filters)) {
1166
+ return EXPORT_TYPES.FILTERED;
1167
+ }
1168
+ return EXPORT_TYPES.ALL;
1169
+ }
1170
+ function removeEmptyGroups(groups) {
1171
+ return _filterInstanceProperty__default["default"](groups).call(groups, group => group.fields && group.fields.length > 0);
1172
+ }
1173
+
1174
+ const isAnyFieldChecked = fields => {
1175
+ return _someInstanceProperty__default["default"](fields).call(fields, field => field.isChecked || field.fields && isAnyFieldChecked(field.fields));
1176
+ };
1177
+ const hasDependentFields = field => {
1178
+ var _context;
1179
+ return Boolean(field?.dependentGroupNames && field.dependentGroupNames.length > 0 || field?.dependentFieldNames && field.dependentFieldNames.length > 0 || field?.fields && _someInstanceProperty__default["default"](_context = field.fields).call(_context, nestedField => hasDependentFields(nestedField)));
1180
+ };
1181
+ const isFieldOrNestedFieldChecked = (field, fieldName) => {
1182
+ if (field.name === fieldName && field.isChecked) {
1183
+ return true;
1184
+ }
1185
+ if (field.fields) {
1186
+ var _context2;
1187
+ return _someInstanceProperty__default["default"](_context2 = field.fields).call(_context2, nestedField => {
1188
+ return nestedField.isChecked || isFieldOrNestedFieldChecked(nestedField, fieldName);
1189
+ });
1190
+ }
1191
+ return false;
1192
+ };
1193
+ const getIndependentFields = group => {
1194
+ const independentFields = [];
1195
+ const findIndependentFields = fields => {
1196
+ _forEachInstanceProperty__default["default"](fields).call(fields, field => {
1197
+ if (!field.dependentGroupNames?.length && !field.dependentFieldNames?.length) {
1198
+ independentFields.push(field);
1199
+ }
1200
+ if (field.fields) {
1201
+ findIndependentFields(field.fields);
1202
+ }
1203
+ });
1204
+ };
1205
+ findIndependentFields(group.fields);
1206
+ return independentFields;
1207
+ };
1208
+ const checkDependentFields = (independentFields, dependentFieldNames) => {
1209
+ return _someInstanceProperty__default["default"](dependentFieldNames).call(dependentFieldNames, fieldName => _someInstanceProperty__default["default"](independentFields).call(independentFields, field => {
1210
+ if (field.name === fieldName) {
1211
+ if (field.fields) {
1212
+ var _context3;
1213
+ return _someInstanceProperty__default["default"](_context3 = field.fields).call(_context3, nestedField => isFieldOrNestedFieldChecked(nestedField, fieldName));
1214
+ }
1215
+ if (isFieldOrNestedFieldChecked(field, fieldName)) {
1216
+ return true;
1217
+ }
1218
+ }
1219
+ return false;
1220
+ }));
1221
+ };
1222
+
1223
+ /**
1224
+ * Checks if any dependent fields are checked within the field groups
1225
+ *
1226
+ * This function iterates over the provided dependent group names and checks if any fields within those groups
1227
+ * are checked. It considers both independent fields and their nested fields within
1228
+ * the specified dependent field names
1229
+ *
1230
+ * @param groups - The array of field groups
1231
+ * @param dependentGroupNames - The names of the groups to check for dependencies
1232
+ * @param dependentFieldNames - The names of the fields to check within the groups
1233
+ * @returns True if any dependent fields are checked otherwise false
1234
+ */
1235
+ const isAnyDependentChecked = function (groups) {
1236
+ let dependentGroupNames = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
1237
+ let dependentFieldNames = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
1238
+ return _someInstanceProperty__default["default"](dependentGroupNames).call(dependentGroupNames, groupName => {
1239
+ const group = _findInstanceProperty__default["default"](groups).call(groups, g => g.groupName === groupName);
1240
+ if (group) {
1241
+ const independentFields = getIndependentFields(group);
1242
+ const isADependentFieldChecked = isAnyFieldChecked(independentFields);
1243
+ const isFieldDependentChecked = checkDependentFields(independentFields, dependentFieldNames);
1244
+ if (dependentFieldNames.length > 0) {
1245
+ return isADependentFieldChecked && isFieldDependentChecked;
1246
+ }
1247
+ return isADependentFieldChecked || isFieldDependentChecked;
1248
+ }
1249
+ return false;
1250
+ });
1251
+ };
1252
+ const areAllFieldsChecked = fields => {
1253
+ return _everyInstanceProperty__default["default"](fields).call(fields, field => field.fields ? areAllFieldsChecked(field.fields) : field.isChecked || field.isRequired || hasDependentFields(field));
1254
+ };
1255
+ const getGroupSelectedFieldCount = group => {
1256
+ const countSelectedFields = fields => {
1257
+ return _reduceInstanceProperty__default["default"](fields).call(fields, (total, field) => {
1258
+ if (field.fields) {
1259
+ return total + countSelectedFields(field.fields);
1260
+ }
1261
+ return total + (field.isChecked ? 1 : 0);
1262
+ }, 0);
1263
+ };
1264
+ return countSelectedFields(group.fields);
1265
+ };
1266
+ const getAllSelectedFieldCount = groups => {
1267
+ return _reduceInstanceProperty__default["default"](groups).call(groups, (total, group) => total + getGroupSelectedFieldCount(group), 0);
1268
+ };
1269
+ const getGroupsWithSelectedFields = groups => {
1270
+ return _filterInstanceProperty__default["default"](groups).call(groups, group => getGroupSelectedFieldCount(group) > 0);
1271
+ };
1272
+ const getSelectedFieldLabels = group => {
1273
+ const selectedLabels = [];
1274
+ const findSelectedFieldLabels = fields => {
1275
+ _forEachInstanceProperty__default["default"](fields).call(fields, field => {
1276
+ if (field.isChecked && !field.fields) {
1277
+ selectedLabels.push(field.label);
1278
+ }
1279
+ if (field.fields) {
1280
+ findSelectedFieldLabels(field.fields);
1281
+ }
1282
+ });
1283
+ };
1284
+ findSelectedFieldLabels(group.fields);
1285
+ return selectedLabels;
1286
+ };
1287
+ const extractFieldNamesFromGroups = (groups, fieldOrder) => {
1288
+ let checkedFields = [];
1289
+ const getCheckedFields = fields => {
1290
+ return _filterInstanceProperty__default["default"](fields).call(fields, field => {
1291
+ if (field.fields) {
1292
+ return getCheckedFields(field.fields);
1293
+ }
1294
+ if (field.isChecked) checkedFields.push(field);
1295
+ return field.isChecked ?? false;
1296
+ });
1297
+ };
1298
+ _forEachInstanceProperty__default["default"](groups).call(groups, group => {
1299
+ getCheckedFields(group.fields);
1300
+ });
1301
+ return sortFieldsByFieldOrder({
1302
+ fieldNames: extractFieldNamesAndAdditionalFieldExtensions(checkedFields),
1303
+ fieldOrder
1304
+ });
1305
+ };
1306
+
1307
+ let Step = /*#__PURE__*/function (Step) {
1308
+ Step["FileSettings"] = "file-settings";
1309
+ Step["FieldsSelection"] = "fields-selection";
1310
+ Step["ConfirmExport"] = "confirm-export";
1311
+ Step["ValidationErrors"] = "validation-errors";
1312
+ return Step;
1313
+ }({});
1314
+
1315
+ let LocaleOption = /*#__PURE__*/function (LocaleOption) {
1316
+ LocaleOption["Selected"] = "selected";
1317
+ LocaleOption["All"] = "all";
1318
+ LocaleOption["OnlyLocalesFoundInCsvFile"] = "onlyLocalesFoundInCsvFile";
1319
+ return LocaleOption;
1320
+ }({});
1321
+
1322
+ function validate(_ref) {
1323
+ let values = _valuesInstanceProperty__default["default"](_ref),
1324
+ step = _ref.step,
1325
+ fieldSelectionMode = _ref.fieldSelectionMode,
1326
+ importedHeaders = _ref.importedHeaders,
1327
+ exportType = _ref.exportType;
1328
+ const fileName = values.fileName,
1329
+ queryPredicate = values.queryPredicate,
1330
+ locales = values.locales,
1331
+ groups = values.groups;
1332
+ const errors = {
1333
+ fileName: {},
1334
+ locales: {},
1335
+ fields: {},
1336
+ importedCsvTemplateFile: {},
1337
+ queryPredicate: {}
1338
+ };
1339
+ if (uiKit.TextInput.isEmpty(fileName)) {
1340
+ errors.fileName.missing = true;
1341
+ } else if (!/^[a-zA-Z0-9-_.]+$/.test(fileName)) {
1342
+ errors.fileName.invalidInput = true;
1343
+ }
1344
+ if (exportType === 'query-predicate' && uiKit.TextInput.isEmpty(queryPredicate)) {
1345
+ errors.queryPredicate.missing = true;
1346
+ }
1347
+ if (step === Step.FieldsSelection) {
1348
+ if (fieldSelectionMode === 'selected-fields') {
1349
+ const allFields = _reduceInstanceProperty__default["default"](groups).call(groups, (acc, group) => _concatInstanceProperty__default["default"](acc).call(acc, group.fields), []);
1350
+ const checkedFieldsCount = _filterInstanceProperty__default["default"](allFields).call(allFields, field => {
1351
+ if (field.fields) return isAnyFieldChecked(field.fields);
1352
+ return field.isChecked;
1353
+ }).length;
1354
+ if (checkedFieldsCount < 1) {
1355
+ errors.fields.missing = true;
1356
+ }
1357
+ }
1358
+ if (fieldSelectionMode === 'imported-csv-template') {
1359
+ if (!values.importedCsvTemplateFile || importedHeaders.length === 0) {
1360
+ errors.importedCsvTemplateFile = {
1361
+ missing: true
1362
+ };
1363
+ }
1364
+ }
1365
+ if (locales.length < 1) {
1366
+ errors.locales.missing = true;
1367
+ }
1368
+ }
1369
+ return omitEmpty__default["default"](errors);
1370
+ }
1371
+ function isFieldNameValid(header) {
1372
+ const processedHeader = header.replace(/\.\*\./g, '.');
1373
+ return /^[a-zA-Z0-9._-]+$/.test(processedHeader);
1374
+ }
1375
+
1376
+ function ownKeys$d(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; }
1377
+ function _objectSpread$d(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$d(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$d(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1378
+ const updateFieldGroupsWithIsCheckedValue = (groups, cachedSelectedGroups) => {
1379
+ const updateFields = (fields, isParentChecked, parentFieldPath) => {
1380
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
1381
+ let isChecked = false;
1382
+ if (field.isRequired) {
1383
+ isChecked = true;
1384
+ } else {
1385
+ if (cachedSelectedGroups[`${parentFieldPath}.${field.name}`] !== undefined) {
1386
+ isChecked = cachedSelectedGroups[`${parentFieldPath}.${field.name}`];
1387
+ } else if (!hasDependentFields(field) && field.isSelectedByDefault) {
1388
+ isChecked = true;
1389
+ } else if (isParentChecked) {
1390
+ isChecked = true;
1391
+ }
1392
+ }
1393
+ let updatedFields = field.fields;
1394
+ if (field.fields) {
1395
+ updatedFields = updateFields(field.fields, isChecked, `${parentFieldPath}.${field.name}`);
1396
+ isChecked = false;
1397
+ }
1398
+ return _objectSpread$d(_objectSpread$d({}, field), {}, {
1399
+ isChecked,
1400
+ fields: updatedFields
1401
+ });
1402
+ });
1403
+ };
1404
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
1405
+ const updatedFields = updateFields(group.fields, false, group.groupName);
1406
+ return _objectSpread$d(_objectSpread$d({}, group), {}, {
1407
+ fields: updatedFields
1408
+ });
1409
+ });
1410
+ };
1411
+ const updateFieldGroupWithAdditionalFieldExtensions = groups => {
1412
+ function updateAdditionalFieldExtensions(fields, extendedFieldNames) {
1413
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
1414
+ const updatedAdditionalFieldExtensions = [...extendedFieldNames, ...(field.extendedFieldNames || [])];
1415
+ if (field.fields) {
1416
+ field.fields = updateAdditionalFieldExtensions(field.fields, updatedAdditionalFieldExtensions);
1417
+ }
1418
+ return _objectSpread$d(_objectSpread$d({}, field), {}, {
1419
+ extendedFieldNames: updatedAdditionalFieldExtensions
1420
+ });
1421
+ });
1422
+ }
1423
+ function combineDependentGroupNames(fields) {
1424
+ return _reduceInstanceProperty__default["default"](fields).call(fields, (acc, field) => {
1425
+ if (field.dependentGroupNames) {
1426
+ acc = [...acc, ...field.dependentGroupNames];
1427
+ }
1428
+ if (field.fields) {
1429
+ acc = [...acc, ...combineDependentGroupNames(field.fields)];
1430
+ }
1431
+ return acc;
1432
+ }, []);
1433
+ }
1434
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
1435
+ return _objectSpread$d(_objectSpread$d({}, group), {}, {
1436
+ dependentGroupNames: combineDependentGroupNames(group.fields),
1437
+ fields: updateAdditionalFieldExtensions(group.fields, [])
1438
+ });
1439
+ });
1440
+ };
1441
+ const getIsExpanded = (field, groupName, cachedExpandedGroups) => {
1442
+ if (!field.isExpandable) {
1443
+ return false;
1444
+ }
1445
+ if (field.fields && field.maxVisibleChildren && field.fields.length > field.maxVisibleChildren) {
1446
+ return false;
1447
+ }
1448
+ const cacheKey = `${groupName}.${field.name}`;
1449
+ return cachedExpandedGroups[cacheKey] ?? field.isExpanded ?? false;
1450
+ };
1451
+ const updateFieldGroupsWithIsExpandedValue = (groups, cachedExpandedGroups) => {
1452
+ function updateFields(fields, groupName) {
1453
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
1454
+ let isExpanded = null;
1455
+ if (field.isExpandable) {
1456
+ isExpanded = getIsExpanded(field, groupName, cachedExpandedGroups);
1457
+ }
1458
+ if (field.fields) {
1459
+ field.fields = updateFields(field.fields, groupName);
1460
+ }
1461
+ if (isExpanded !== null) {
1462
+ return _objectSpread$d(_objectSpread$d({}, field), {}, {
1463
+ isExpanded
1464
+ });
1465
+ }
1466
+ return field;
1467
+ });
1468
+ }
1469
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
1470
+ const updatedFields = updateFields(group.fields, group.groupName);
1471
+ return _objectSpread$d(_objectSpread$d({}, group), {}, {
1472
+ isExpanded: cachedExpandedGroups[group.groupName] ?? group.isExpanded ?? false,
1473
+ fields: updatedFields
1474
+ });
1475
+ });
1476
+ };
1477
+ const updateFieldDependenciesStatus = formik => {
1478
+ var _context;
1479
+ const updateFields = (fields, path) => {
1480
+ _forEachInstanceProperty__default["default"](fields).call(fields, (field, index) => {
1481
+ const currentPath = `${path}.fields[${index}]`;
1482
+ if (hasDependentFields(field)) {
1483
+ formik.setFieldValue(`${currentPath}.isChecked`, isAnyDependentChecked(_valuesInstanceProperty__default["default"](formik).groups, field.dependentGroupNames, field.dependentFieldNames), false);
1484
+ }
1485
+ if (field.fields) {
1486
+ updateFields(field.fields, currentPath);
1487
+ }
1488
+ });
1489
+ };
1490
+ _forEachInstanceProperty__default["default"](_context = _valuesInstanceProperty__default["default"](formik).groups).call(_context, (group, index) => {
1491
+ updateFields(group.fields, `groups[${index}]`);
1492
+ });
1493
+ };
1494
+
1495
+ const EXCLUDED_COLUMNS = ['data-object'];
1496
+ const CHUNK_SIZE = 10 * 1024;
1497
+ const DELIMITERS = [',', ';', '\t', ' ', '|'];
1498
+ const getCsvHeaders = file => {
1499
+ return new _Promise__default["default"](resolve => {
1500
+ const reader = new FileReader();
1501
+ let headers = [];
1502
+ let offset = 0;
1503
+ let entireFile = '';
1504
+ const readChunk = () => {
1505
+ const blobSlice = _sliceInstanceProperty__default["default"](file).call(file, offset, offset + CHUNK_SIZE);
1506
+ reader.readAsText(blobSlice);
1507
+ offset += CHUNK_SIZE;
1508
+ };
1509
+ reader.onload = e => {
1510
+ try {
1511
+ var _context, _context2;
1512
+ const text = e.target?.result;
1513
+ entireFile += text;
1514
+ const firstLineEnd = _indexOfInstanceProperty__default["default"](entireFile).call(entireFile, '\n');
1515
+ if (firstLineEnd === -1 && offset < file.size) {
1516
+ readChunk();
1517
+ return;
1518
+ }
1519
+ const headerLine = entireFile.substring(0, firstLineEnd === -1 ? entireFile.length : firstLineEnd);
1520
+ const delimiter = _reduceInstanceProperty__default["default"](DELIMITERS).call(DELIMITERS, (a, b) => headerLine.split(a).length > headerLine.split(b).length ? a : b);
1521
+ headers = _filterInstanceProperty__default["default"](_context = _mapInstanceProperty__default["default"](_context2 = headerLine.split(delimiter)).call(_context2, header => _trimInstanceProperty__default["default"](header).call(header))).call(_context, header => header !== '' && !_includesInstanceProperty__default["default"](EXCLUDED_COLUMNS).call(EXCLUDED_COLUMNS, header));
1522
+ resolve(headers);
1523
+ } catch (error) {
1524
+ resolve([]);
1525
+ }
1526
+ };
1527
+ reader.onerror = () => {
1528
+ resolve([]);
1529
+ };
1530
+ readChunk();
1531
+ });
1532
+ };
1533
+
1534
+ function ownKeys$c(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; }
1535
+ function _objectSpread$c(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$c(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$c(Object(t))).call(_context6, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1536
+ function groupFieldValidationErrors(errors, intl) {
1537
+ var _context2, _context4;
1538
+ const errorsByCode = _reduceInstanceProperty__default["default"](errors).call(errors, (groups, error) => {
1539
+ var _context;
1540
+ const groupKey = error.code === 'AttributeLevelMismatch' && error.actualLevel ? `${error.code}-${error.actualLevel}` : error.code;
1541
+ const group = groups[groupKey] || {
1542
+ code: error.code,
1543
+ originalErrors: [],
1544
+ fieldNames: []
1545
+ };
1546
+ if (error.field && !_includesInstanceProperty__default["default"](_context = group.fieldNames).call(_context, error.field)) {
1547
+ group.fieldNames.push(error.field);
1548
+ }
1549
+ group.originalErrors.push(error);
1550
+ groups[groupKey] = group;
1551
+ return groups;
1552
+ }, {});
1553
+ _forEachInstanceProperty__default["default"](_context2 = _Object$values__default["default"](errorsByCode)).call(_context2, group => {
1554
+ var _context3;
1555
+ _sortInstanceProperty__default["default"](_context3 = group.fieldNames).call(_context3);
1556
+ });
1557
+ return _mapInstanceProperty__default["default"](_context4 = _Object$values__default["default"](errorsByCode)).call(_context4, group => {
1558
+ let messageTitle;
1559
+ switch (group.code) {
1560
+ case 'NotSupportedField':
1561
+ messageTitle = intl.formatMessage(messages.notSupportedFieldsTitle);
1562
+ break;
1563
+ case 'LocalizedFieldWithoutLocale':
1564
+ messageTitle = intl.formatMessage(messages.localizedFieldWithoutLocaleTitle);
1565
+ break;
1566
+ case 'IncompleteField':
1567
+ messageTitle = intl.formatMessage(messages.incompleteFieldTitle);
1568
+ break;
1569
+ case 'DuplicateFields':
1570
+ messageTitle = intl.formatMessage(messages.duplicateFieldTitle);
1571
+ break;
1572
+ case 'AttributeDefinitionNotFound':
1573
+ messageTitle = intl.formatMessage(messages.attributeDefinitionNotFoundTitle);
1574
+ break;
1575
+ case 'FieldDefinitionNotFound':
1576
+ messageTitle = intl.formatMessage(messages.fieldDefinitionNotFoundTitle);
1577
+ break;
1578
+ case 'AttributeLevelMismatch':
1579
+ {
1580
+ const referenceError = group.originalErrors[0];
1581
+ if (referenceError?.actualLevel === 'Product') {
1582
+ messageTitle = intl.formatMessage(messages.attributeLevelMismatchProductLevelTitle, {
1583
+ b: getSmallBold
1584
+ });
1585
+ } else if (referenceError?.actualLevel === 'Variant') {
1586
+ messageTitle = intl.formatMessage(messages.attributeLevelMismatchVariantLevelTitle, {
1587
+ b: getSmallBold
1588
+ });
1589
+ } else {
1590
+ messageTitle = referenceError?.message || intl.formatMessage(messages.unknownError);
1591
+ }
1592
+ break;
1593
+ }
1594
+ default:
1595
+ messageTitle = group.originalErrors[0]?.message || intl.formatMessage(messages.unknownError);
1596
+ }
1597
+ return _objectSpread$c(_objectSpread$c({}, group), {}, {
1598
+ messageTitle
1599
+ });
1600
+ });
1601
+ }
1602
+
1603
+ function isExportApiSuccessResponse(response) {
1604
+ return 'id' in response && 'state' in response && 'resourceType' in response && 'resourceCount' in response;
1605
+ }
1606
+ function isExportApiErrorResponse(error) {
1607
+ return Boolean(error && typeof error === 'object' && 'body' in error && error.body && typeof error.body === 'object' && ('validationErrors' in error.body || 'errors' in error.body) && 'message' in error.body && 'statusCode' in error.body && 'error' in error.body);
1608
+ }
1609
+
1610
+ const useInitialValues = props => {
1611
+ var _context;
1612
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
1613
+ locale: applicationContext.dataLocale,
1614
+ userLocale: applicationContext.user?.locale
1615
+ })),
1616
+ locale = _useApplicationContex.locale,
1617
+ userLocale = _useApplicationContex.userLocale;
1618
+ const _useApplicationContex2 = applicationShellConnectors.useApplicationContext(context => ({
1619
+ projectKey: context.project?.key
1620
+ })),
1621
+ projectKey = _useApplicationContex2.projectKey;
1622
+ const _useStorage = useStorage(`${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`, {}),
1623
+ _useStorage2 = _slicedToArray(_useStorage, 1),
1624
+ cachedSelectedGroups = _useStorage2[0];
1625
+ const _useStorage3 = useStorage(`${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP}`, {
1626
+ [props.resourceType]: _reduceInstanceProperty__default["default"](_context = props.fieldGroups).call(_context, (acc, group) => {
1627
+ acc[group.groupName] = group.isExpanded;
1628
+ return acc;
1629
+ }, {})
1630
+ }),
1631
+ _useStorage4 = _slicedToArray(_useStorage3, 1),
1632
+ cachedExpandedGroups = _useStorage4[0];
1633
+ return React__default["default"].useMemo(() => {
1634
+ let groups = removeEmptyGroups(props.fieldGroups);
1635
+ groups = updateFieldGroupsWithIsCheckedValue(groups, cachedSelectedGroups?.[props.resourceType] || {});
1636
+ groups = updateFieldGroupsWithIsExpandedValue(groups, cachedExpandedGroups?.[props.resourceType] || {});
1637
+ return {
1638
+ fileName: `${resourceTypeToFileName(props.resourceType, userLocale)}`,
1639
+ locales: [locale],
1640
+ groups: updateFieldGroupWithAdditionalFieldExtensions(groups),
1641
+ queryPredicate: '',
1642
+ fillRows: false,
1643
+ excelCompatible: false,
1644
+ outputFormat: props.outputFormat,
1645
+ columnSeparator: operations.DELIMITERS.COMMA,
1646
+ decimalSeparator: operations.DELIMITERS.POINT,
1647
+ importedCsvTemplateFile: null
1648
+ };
1649
+ }, [props.fieldGroups, props.resourceType, props.outputFormat, cachedSelectedGroups, cachedExpandedGroups, locale, userLocale]);
1650
+ };
1651
+
1652
+ const _excluded$3 = ["projectKey"];
1653
+ function ownKeys$b(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; }
1654
+ function _objectSpread$b(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$b(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$b(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1655
+ async function makeExportRequest(params, asyncDispatchFn) {
1656
+ const projectKey = params.projectKey,
1657
+ requestData = _objectWithoutProperties(params, _excluded$3);
1658
+ const uri = `/${projectKey}/export-operations`;
1659
+ const requestAction = sdk.actions.post({
1660
+ mcApiProxyTarget: constants.MC_API_PROXY_TARGETS.EXPORT,
1661
+ uri,
1662
+ headers: {
1663
+ accept: 'application/json'
1664
+ },
1665
+ payload: requestData
1666
+ });
1667
+ const response = await asyncDispatchFn(requestAction);
1668
+ if (!response || typeof response !== 'object') {
1669
+ throw new InvalidResponseError();
1670
+ }
1671
+ if (!('state' in response)) {
1672
+ throw new InvalidResponseError('Response missing state field');
1673
+ }
1674
+ return response;
1675
+ }
1676
+ function createExportOperation(params, asyncDispatchFn) {
1677
+ return makeExportRequest(params, asyncDispatchFn);
1678
+ }
1679
+ function validateExportOperation(params, asyncDispatchFn) {
1680
+ return makeExportRequest(_objectSpread$b(_objectSpread$b({}, params), {}, {
1681
+ dryRun: true
1682
+ }), asyncDispatchFn);
1683
+ }
1684
+
1685
+ const useStartExportOperation = props => {
1686
+ const intl = reactIntl.useIntl();
1687
+ const asyncDispatch = sdk.useAsyncDispatch();
1688
+ const showNotification = actionsGlobal.useShowNotification();
1689
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
1690
+ locale: applicationContext.dataLocale,
1691
+ projectKey: applicationContext.project?.key
1692
+ })),
1693
+ projectKey = _useApplicationContex.projectKey;
1694
+ const startExportOperation = async (values, exportType, fieldSelectionMode, localeOption, importedHeaders) => {
1695
+ try {
1696
+ if (!projectKey) throw new Error('Project key is missing');
1697
+ let fields = [];
1698
+ if (fieldSelectionMode === 'imported-csv-template' && values.importedCsvTemplateFile) {
1699
+ fields = importedHeaders;
1700
+ } else {
1701
+ fields = extractFieldNamesFromGroups(values.groups, props.fieldOrder);
1702
+ }
1703
+ let where = undefined;
1704
+ let filters = undefined;
1705
+ if (exportType === EXPORT_TYPES.SELECTED && props.selectedResourceIds?.length) {
1706
+ where = buildSelectedExportFilters(props.selectedResourceIds);
1707
+ } else if (exportType === EXPORT_TYPES.FILTERED && props.filters) {
1708
+ where = props.filters.where;
1709
+ if (isQueryFilter(props.filters.filters)) {
1710
+ filters = props.filters.filters;
1711
+ } else if (isSearchFilter(props.filters.filters)) {
1712
+ filters = props.filters.filters;
1713
+ }
1714
+ } else if (exportType === EXPORT_TYPES.QUERY_PREDICATE) {
1715
+ var _context;
1716
+ where = _trimInstanceProperty__default["default"](_context = values.queryPredicate).call(_context);
1717
+ }
1718
+ let locales = undefined;
1719
+ if (localeOption !== 'onlyLocalesFoundInCsvFile') {
1720
+ locales = values.locales;
1721
+ }
1722
+ const isCsv = values.outputFormat === 'csv';
1723
+ const response = await createExportOperation({
1724
+ projectKey,
1725
+ resourceType: props.resourceType,
1726
+ fileName: operations.appendCsvOrJsonExtensionIfAbsent(values.fileName, values.outputFormat),
1727
+ fileFormat: values.outputFormat,
1728
+ locales,
1729
+ fillRows: isCsv && values.fillRows,
1730
+ excelCompatible: isCsv && values.excelCompatible,
1731
+ separator: isCsv ? {
1732
+ columns: values.columnSeparator,
1733
+ decimal: values.decimalSeparator
1734
+ } : undefined,
1735
+ fields,
1736
+ where,
1737
+ filters
1738
+ }, asyncDispatch);
1739
+ if (isExportApiSuccessResponse(response)) {
1740
+ switch (response.state) {
1741
+ case EXPORT_OPERATION_STATES.QUEUED:
1742
+ case EXPORT_OPERATION_STATES.PROCESSING:
1743
+ case EXPORT_OPERATION_STATES.COMPLETED:
1744
+ showNotification({
1745
+ kind: 'info',
1746
+ domain: constants.DOMAINS.SIDE,
1747
+ // @ts-ignore
1748
+ text: intl.formatMessage(messages.exportOperationSuccessMessage, {
1749
+ newline: getNewLine,
1750
+ logsLink: msg => jsxRuntime.jsx(ExportLogsLink, {
1751
+ projectKey: projectKey
1752
+ // @ts-ignore the `msg` parameter type is not compatible with the `string` type
1753
+ ,
1754
+ msg: msg
1755
+ }, "export-logs-link"),
1756
+ b: getBold
1757
+ })
1758
+ }, {
1759
+ dismissAfter: 5000
1760
+ });
1761
+ if (typeof props.onExportSuccess === 'function') props.onExportSuccess();
1762
+ break;
1763
+ default:
1764
+ throw new UnexpectedExportOperationStateError(response.state);
1765
+ }
1766
+ } else {
1767
+ throw new Error(response.message || 'Unknown error occurred during export operation');
1768
+ }
1769
+ } catch (error) {
1770
+ showNotification({
1771
+ text: intl.formatMessage(messages.unexpectedError),
1772
+ kind: 'error',
1773
+ domain: constants.DOMAINS.PAGE
1774
+ });
1775
+ } finally {
1776
+ if (typeof props.onClose === 'function') props.onClose();
1777
+ }
1778
+ };
1779
+ return {
1780
+ startExportOperation
1781
+ };
1782
+ };
1783
+
1784
+ const _excluded$2 = ["fields"];
1785
+ function ownKeys$a(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; }
1786
+ function _objectSpread$a(e) { for (var r = 1; r < arguments.length; r++) { var _context6, _context7; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context6 = ownKeys$a(Object(t), !0)).call(_context6, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context7 = ownKeys$a(Object(t))).call(_context7, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1787
+ const getFieldFullName = _ref => {
1788
+ var _context;
1789
+ let fieldPrefix = _ref.fieldPrefix,
1790
+ fieldName = _ref.fieldName;
1791
+ return _filterInstanceProperty__default["default"](_context = [fieldPrefix, fieldName]).call(_context, Boolean).join('.');
1792
+ };
1793
+ const localizeTypeDefinitionLabels = function () {
1794
+ let fieldDefinitions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
1795
+ return _mapInstanceProperty__default["default"](fieldDefinitions).call(fieldDefinitions, _ref2 => {
1796
+ var _context2, _context3;
1797
+ let fields = _ref2.fields,
1798
+ fieldsType = _objectWithoutProperties(_ref2, _excluded$2);
1799
+ const isFieldTypeLabelLocalized = _Array$isArray__default["default"](fieldsType.label);
1800
+ return {
1801
+ name: fieldsType.name,
1802
+ label: isFieldTypeLabelLocalized ? l10n.applyTransformedLocalizedFields(fieldsType, [{
1803
+ from: 'label',
1804
+ to: 'label'
1805
+ }]).label : fieldsType.label,
1806
+ fields: ((_context2 = fields) == null ? void 0 : _bindInstanceProperty__default["default"](_context3 = Function.call).call(_context3, _mapInstanceProperty__default["default"](_context2), _context2))?.(field => {
1807
+ const isFieldLabelLocalized = _Array$isArray__default["default"](field.label);
1808
+ if (!isFieldLabelLocalized) {
1809
+ return field;
1810
+ }
1811
+ return _objectSpread$a({}, l10n.applyTransformedLocalizedFields(field, [{
1812
+ from: 'label',
1813
+ to: 'label'
1814
+ }]));
1815
+ }) || []
1816
+ };
1817
+ });
1818
+ };
1819
+ const useConvertFieldDefinitionsForExport = () => {
1820
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
1821
+ language: applicationContext.dataLocale,
1822
+ languages: applicationContext.project?.languages
1823
+ })),
1824
+ language = _useApplicationContex.language,
1825
+ languages = _useApplicationContex.languages;
1826
+ const sortByField = (fields, fieldName) => {
1827
+ if (!fields) return [];
1828
+ if (fieldName) {
1829
+ return sortBy__default["default"](fields, field => {
1830
+ return field[fieldName]?.toLowerCase();
1831
+ });
1832
+ }
1833
+ return fields;
1834
+ };
1835
+ const convertFieldDefinitionsForExport = _ref3 => {
1836
+ let fieldDefinitions = _ref3.fieldDefinitions,
1837
+ fieldPrefix = _ref3.fieldPrefix,
1838
+ _ref3$expandAll = _ref3.expandAll,
1839
+ expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll,
1840
+ sortField = _ref3.sortField;
1841
+ if (!fieldDefinitions) return [];
1842
+ const localizedTypeDefinitions = localizeTypeDefinitionLabels(fieldDefinitions);
1843
+ const results = _mapInstanceProperty__default["default"](localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => {
1844
+ var _context4, _context5;
1845
+ const isTypeLabelLocalized = typeof transformedType.label !== 'string';
1846
+ return {
1847
+ isExpandable: true,
1848
+ isExpanded: expandAll,
1849
+ name: transformedType.name,
1850
+ label: isTypeLabelLocalized ? l10n.formatLocalizedString({
1851
+ label: transformedType.label
1852
+ }, {
1853
+ key: 'label',
1854
+ locale: language,
1855
+ fallbackOrder: languages,
1856
+ fallback: transformedType.name
1857
+ }) : transformedType.label,
1858
+ fields: sortByField(((_context4 = transformedType.fields) == null ? void 0 : _bindInstanceProperty__default["default"](_context5 = Function.call).call(_context5, _mapInstanceProperty__default["default"](_context4), _context4))?.(fieldDefinition => {
1859
+ const isFieldLabelLocalized = typeof fieldDefinition.label !== 'string';
1860
+ return {
1861
+ name: getFieldFullName({
1862
+ fieldPrefix: fieldPrefix,
1863
+ fieldName: fieldDefinition.name
1864
+ }),
1865
+ label: isFieldLabelLocalized ? l10n.formatLocalizedString({
1866
+ label: fieldDefinition.label
1867
+ }, {
1868
+ key: 'label',
1869
+ locale: language,
1870
+ fallbackOrder: languages,
1871
+ fallback: fieldDefinition.name
1872
+ }) : fieldDefinition.label,
1873
+ extendedFieldNames: fieldDefinition.extendedFieldNames
1874
+ };
1875
+ }), sortField)
1876
+ };
1877
+ });
1878
+ return sortByField(results, sortField);
1879
+ };
1880
+ return {
1881
+ convertFieldDefinitionsForExport
1882
+ };
1883
+ };
1884
+
1885
+ const useValidateExportOperation = () => {
1886
+ const intl = reactIntl.useIntl();
1887
+ const asyncDispatch = sdk.useAsyncDispatch();
1888
+ const showNotification = actionsGlobal.useShowNotification();
1889
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
1890
+ projectKey: context.project?.key
1891
+ })),
1892
+ projectKey = _useApplicationContex.projectKey;
1893
+ const validateExport = async params => {
1894
+ try {
1895
+ var _context, _context2, _context3;
1896
+ if (!projectKey) return;
1897
+ const invalidFields = _filterInstanceProperty__default["default"](_context = params.fields).call(_context, field => !isFieldNameValid(field));
1898
+ if (invalidFields.length > 0) {
1899
+ return {
1900
+ success: false,
1901
+ validationErrors: _mapInstanceProperty__default["default"](invalidFields).call(invalidFields, field => ({
1902
+ code: 'NotSupportedField',
1903
+ field: field
1904
+ }))
1905
+ };
1906
+ }
1907
+ const response = await validateExportOperation({
1908
+ projectKey,
1909
+ resourceType: params.resourceType,
1910
+ fileName: params.fileName,
1911
+ fileFormat: params.outputFormat,
1912
+ fields: params.fields,
1913
+ locales: params.locales,
1914
+ where: ((_context2 = params.queryPredicate) == null ? void 0 : _bindInstanceProperty__default["default"](_context3 = Function.call).call(_context3, _trimInstanceProperty__default["default"](_context2), _context2))?.() || undefined
1915
+ }, asyncDispatch);
1916
+ if (isExportApiSuccessResponse(response) && response.resourceCount === 0) {
1917
+ return {
1918
+ success: false,
1919
+ noResourcesToExportForQueryPredicate: true
1920
+ };
1921
+ }
1922
+ return {
1923
+ success: true
1924
+ };
1925
+ } catch (error) {
1926
+ if (isExportApiErrorResponse(error)) {
1927
+ if (error.body.errors?.length) {
1928
+ var _context4;
1929
+ const whereError = _findInstanceProperty__default["default"](_context4 = error.body.errors).call(_context4, error => {
1930
+ var _context5;
1931
+ return error.message && _includesInstanceProperty__default["default"](_context5 = error.message).call(_context5, 'Malformed parameter: where');
1932
+ });
1933
+ if (whereError) {
1934
+ return {
1935
+ success: false,
1936
+ invalidQueryPredicate: true
1937
+ };
1938
+ }
1939
+ }
1940
+ if (error.body.validationErrors?.length) {
1941
+ return {
1942
+ success: false,
1943
+ validationErrors: error.body.validationErrors
1944
+ };
1945
+ }
1946
+ }
1947
+ showNotification({
1948
+ text: intl.formatMessage(messages.unexpectedError),
1949
+ kind: 'error',
1950
+ domain: constants.DOMAINS.PAGE
1951
+ });
1952
+ return {
1953
+ success: false,
1954
+ validationErrors: []
1955
+ };
1956
+ }
1957
+ };
1958
+ return {
1959
+ validateExport
1960
+ };
1961
+ };
1962
+
1963
+ function ownKeys$9(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; }
1964
+ function _objectSpread$9(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$9(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$9(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
1965
+ const ExportPreferenceSection = () => {
1966
+ const intl = reactIntl.useIntl();
1967
+ const _useExportResourcesMo = useExportResourcesModalContext(),
1968
+ formik = _useExportResourcesMo.formik;
1969
+ const columnSeparatorOptions = _mapInstanceProperty__default["default"](COLUMN_DELIMITER_OPTIONS).call(COLUMN_DELIMITER_OPTIONS, option => _objectSpread$9(_objectSpread$9({}, option), {}, {
1970
+ label: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$9({}, option.label))
1971
+ }));
1972
+ const decimalSeparatorOptions = _mapInstanceProperty__default["default"](DECIMAL_DELIMITER_OPTIONS).call(DECIMAL_DELIMITER_OPTIONS, option => _objectSpread$9(_objectSpread$9({}, option), {}, {
1973
+ label: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$9({}, option.label))
1974
+ }));
1975
+ return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1976
+ scale: "l",
1977
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
1978
+ scale: "s",
1979
+ children: [jsxRuntime.jsxs("div", {
1980
+ children: [jsxRuntime.jsx(uiKit.Text.Body, {
1981
+ intlMessage: messages.separators
1982
+ }), jsxRuntime.jsx(uiKit.Text.Caption, {
1983
+ intlMessage: messages.separatorsDescription
1984
+ })]
1985
+ }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
1986
+ scale: "s",
1987
+ children: [jsxRuntime.jsx(uiKit.SelectField, {
1988
+ title: intl.formatMessage(messages.columns),
1989
+ isSearchable: false,
1990
+ options: columnSeparatorOptions,
1991
+ value: _valuesInstanceProperty__default["default"](formik).columnSeparator,
1992
+ onChange: e => {
1993
+ formik.setFieldValue('columnSeparator', e.target.value);
1994
+ },
1995
+ menuPortalTarget: document.body,
1996
+ menuPortalZIndex: Z_INDEX_DROPDOWN
1997
+ }), jsxRuntime.jsx(uiKit.SelectField, {
1998
+ title: intl.formatMessage(messages.decimals),
1999
+ isSearchable: false,
2000
+ options: decimalSeparatorOptions,
2001
+ value: _valuesInstanceProperty__default["default"](formik).decimalSeparator,
2002
+ onChange: e => {
2003
+ formik.setFieldValue('decimalSeparator', e.target.value);
2004
+ },
2005
+ menuPortalTarget: document.body,
2006
+ menuPortalZIndex: Z_INDEX_DROPDOWN
2007
+ })]
2008
+ })]
2009
+ }), jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2010
+ scale: "m",
2011
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2012
+ scale: "m",
2013
+ children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
2014
+ isChecked: _valuesInstanceProperty__default["default"](formik).excelCompatible,
2015
+ onChange: e => {
2016
+ formik.setFieldValue('excelCompatible', e.target.checked);
2017
+ },
2018
+ children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$9({}, messages.excelOptimized))
2019
+ }), _valuesInstanceProperty__default["default"](formik).excelCompatible && jsxRuntime.jsx(uiKit.ContentNotification, {
2020
+ type: "info",
2021
+ children: jsxRuntime.jsx(uiKit.Spacings.Inset, {
2022
+ scale: "xs",
2023
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2024
+ children: [jsxRuntime.jsx("div", {
2025
+ children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$9({}, messages.excelOptimizedDescription))
2026
+ }), jsxRuntime.jsx("div", {
2027
+ children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$9(_objectSpread$9({}, messages.readMoreOnDocumentation), {}, {
2028
+ values: {
2029
+ documentationLink: jsxRuntime.jsx(uiKit.Link, {
2030
+ intlMessage: messages.documentation,
2031
+ isExternal: true,
2032
+ to: EXPORT_EXCEL_DOCUMENTATION_LINK
2033
+ }, "documentation-link")
2034
+ }
2035
+ }))
2036
+ })]
2037
+ })
2038
+ })
2039
+ })]
2040
+ }), jsxRuntime.jsxs("div", {
2041
+ children: [jsxRuntime.jsx(uiKit.CheckboxInput, {
2042
+ isChecked: _valuesInstanceProperty__default["default"](formik).fillRows,
2043
+ onChange: e => {
2044
+ formik.setFieldValue('fillRows', e.target.checked);
2045
+ },
2046
+ children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$9({}, messages.fillRows))
2047
+ }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
2048
+ scale: "xl",
2049
+ children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(uiKit.Text.Caption, {
2050
+ intlMessage: _objectSpread$9(_objectSpread$9({}, messages.moreInformation), {}, {
2051
+ values: {
2052
+ documentationLink: jsxRuntime.jsx(uiKit.Link, {
2053
+ intlMessage: messages.documentation,
2054
+ isExternal: true,
2055
+ to: CSV_STRUCTURE_DOCUMENTATION_LINK
2056
+ }, "documentation-link")
2057
+ }
2058
+ })
2059
+ })]
2060
+ })]
2061
+ })]
2062
+ })]
2063
+ });
2064
+ };
2065
+
2066
+ function ownKeys$8(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; }
2067
+ function _objectSpread$8(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$8(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$8(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
2068
+ function ExportScopeSection() {
2069
+ const _useExportResourcesMo = useExportResourcesModalContext(),
2070
+ formik = _useExportResourcesMo.formik,
2071
+ exportType = _useExportResourcesMo.exportType,
2072
+ totalResourcesCount = _useExportResourcesMo.totalResourcesCount,
2073
+ filters = _useExportResourcesMo.filters,
2074
+ hasFilters = _useExportResourcesMo.hasFilters,
2075
+ selectedResourceIds = _useExportResourcesMo.selectedResourceIds,
2076
+ setExportType = _useExportResourcesMo.setExportType,
2077
+ resourceType = _useExportResourcesMo.resourceType,
2078
+ hideExportSelectedResourcesOption = _useExportResourcesMo.hideExportSelectedResourcesOption,
2079
+ showQueryPredicateOption = _useExportResourcesMo.showQueryPredicateOption;
2080
+ const shouldShowQueryPredicateField = exportType === EXPORT_TYPES.QUERY_PREDICATE;
2081
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
2082
+ children: [jsxRuntime.jsxs(uiKit.RadioInput.Group, {
2083
+ value: exportType,
2084
+ onChange: e => {
2085
+ setExportType(e.target.value);
2086
+ },
2087
+ direction: "stack",
2088
+ directionProps: {
2089
+ scale: 's'
2090
+ },
2091
+ children: [jsxRuntime.jsx(uiKit.RadioInput.Option, {
2092
+ value: EXPORT_TYPES.ALL,
2093
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2094
+ intlMessage: _objectSpread$8(_objectSpread$8({}, resourceTypeMessages[resourceType].exportScopeAll), {}, {
2095
+ values: {
2096
+ total: totalResourcesCount
2097
+ }
2098
+ })
2099
+ })
2100
+ }), filters && jsxRuntime.jsx(uiKit.RadioInput.Option, {
2101
+ value: EXPORT_TYPES.FILTERED,
2102
+ isDisabled: !filters.total || !hasFilters,
2103
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2104
+ tone: !filters.total || !hasFilters ? 'tertiary' : undefined,
2105
+ intlMessage: filters.total ? _objectSpread$8(_objectSpread$8({}, resourceTypeMessages[resourceType].exportScopeFiltered), {}, {
2106
+ values: {
2107
+ total: filters.total
2108
+ }
2109
+ }) : messages.exportScopeFilteredWithoutCount
2110
+ })
2111
+ }), !hideExportSelectedResourcesOption && jsxRuntime.jsx(uiKit.RadioInput.Option, {
2112
+ value: EXPORT_TYPES.SELECTED,
2113
+ isDisabled: !selectedResourceIds?.length,
2114
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2115
+ tone: !selectedResourceIds?.length ? 'tertiary' : undefined,
2116
+ intlMessage: selectedResourceIds?.length ? _objectSpread$8(_objectSpread$8({}, resourceTypeMessages[resourceType].exportScopeSelected), {}, {
2117
+ values: {
2118
+ total: selectedResourceIds.length
2119
+ }
2120
+ }) : messages.exportScopeSelectedWithoutCount
2121
+ })
2122
+ }), showQueryPredicateOption && jsxRuntime.jsx(uiKit.RadioInput.Option, {
2123
+ value: EXPORT_TYPES.QUERY_PREDICATE,
2124
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2125
+ intlMessage: messages.queryPredicate
2126
+ })
2127
+ })]
2128
+ }), shouldShowQueryPredicateField && jsxRuntime.jsx(uiKit.TextField, {
2129
+ name: "queryPredicate",
2130
+ "data-testid": "query-predicate-field",
2131
+ title: "",
2132
+ onChange: formik.handleChange,
2133
+ onBlur: formik.handleBlur,
2134
+ value: _valuesInstanceProperty__default["default"](formik).queryPredicate,
2135
+ touched: formik.touched.queryPredicate,
2136
+ errors: operations.mapFormikErrors(formik.errors.queryPredicate),
2137
+ renderError: renderQueryPredicateError
2138
+ })]
2139
+ });
2140
+ }
2141
+
2142
+ const ExportFileSettingsStep = () => {
2143
+ const intl = reactIntl.useIntl();
2144
+ const _useExportResourcesMo = useExportResourcesModalContext(),
2145
+ formik = _useExportResourcesMo.formik,
2146
+ resourceType = _useExportResourcesMo.resourceType,
2147
+ setFieldSelectionMode = _useExportResourcesMo.setFieldSelectionMode,
2148
+ setLocaleOption = _useExportResourcesMo.setLocaleOption,
2149
+ onClose = _useExportResourcesMo.onClose;
2150
+ const handleOutputFormatChange = event => {
2151
+ formik.handleChange(event);
2152
+ if (event.target.value === OUTPUT_FORMATS.JSON) {
2153
+ setFieldSelectionMode(FIELD_SELECTION_MODES.SELECTED_FIELDS);
2154
+ setLocaleOption(LocaleOption.Selected);
2155
+ }
2156
+ };
2157
+ const shouldShowPreferences = _valuesInstanceProperty__default["default"](formik).outputFormat === 'csv';
2158
+ return jsxRuntime.jsx(applicationComponents.FormDialog, {
2159
+ isOpen: true,
2160
+ title: `${intl.formatMessage(messages.stepCount, {
2161
+ currentStep: 1,
2162
+ totalSteps: TOTAL_STEPS
2163
+ })}: ${intl.formatMessage(messages[`modalTitle.${resourceType}`])}`,
2164
+ labelPrimary: `${intl.formatMessage(messages.stepNumber, {
2165
+ stepNumber: 2
2166
+ })}: ${intl.formatMessage(messages.selectContentToExport)}`,
2167
+ iconLeftPrimaryButton: jsxRuntime.jsx(uiKit.AngleRightIcon, {}),
2168
+ onPrimaryButtonClick: formik.submitForm,
2169
+ isPrimaryButtonDisabled: !formik.isValid,
2170
+ onSecondaryButtonClick: onClose,
2171
+ onClose: onClose,
2172
+ size: 16,
2173
+ children: jsxRuntime.jsx(fullstory.Masking.Unmask, {
2174
+ children: jsxRuntime.jsxs(uiKit.Grid, {
2175
+ gridRowGap: uiKit.designTokens.spacingXl,
2176
+ gridTemplateColumns: `calc(${uiKit.designTokens.constraint3} + ${uiKit.designTokens.spacingL}) auto`,
2177
+ children: [jsxRuntime.jsx(uiKit.Grid.Item, {
2178
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2179
+ intlMessage: messages.scope
2180
+ })
2181
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
2182
+ children: jsxRuntime.jsx(ExportScopeSection, {})
2183
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
2184
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2185
+ intlMessage: messages.saveAs
2186
+ })
2187
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
2188
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2189
+ scale: "m",
2190
+ children: [jsxRuntime.jsx(fullstory.Masking.Mask, {
2191
+ children: jsxRuntime.jsx(uiKit.TextField, {
2192
+ name: "fileName",
2193
+ onChange: formik.handleChange,
2194
+ onBlur: formik.handleBlur,
2195
+ value: _valuesInstanceProperty__default["default"](formik).fileName,
2196
+ title: intl.formatMessage(messages.fileName),
2197
+ touched: formik.touched.fileName,
2198
+ errors: operations.mapFormikErrors(formik.errors.fileName),
2199
+ renderError: renderFileNameError
2200
+ })
2201
+ }), jsxRuntime.jsx(uiKit.SelectField, {
2202
+ name: "outputFormat",
2203
+ onChange: handleOutputFormatChange,
2204
+ onBlur: formik.handleBlur,
2205
+ value: _valuesInstanceProperty__default["default"](formik).outputFormat,
2206
+ title: intl.formatMessage(messages.outputFormat),
2207
+ options: OUTPUT_FORMAT_OPTIONS,
2208
+ menuPortalTarget: document.body,
2209
+ menuPortalZIndex: Z_INDEX_DROPDOWN
2210
+ })]
2211
+ })
2212
+ }), shouldShowPreferences && jsxRuntime.jsxs(jsxRuntime.Fragment, {
2213
+ children: [jsxRuntime.jsx(uiKit.Grid.Item, {
2214
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2215
+ intlMessage: messages.csvSettings
2216
+ })
2217
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
2218
+ children: jsxRuntime.jsx(ExportPreferenceSection, {})
2219
+ })]
2220
+ })]
2221
+ })
2222
+ })
2223
+ });
2224
+ };
2225
+
2226
+ const ExportLocaleSelectField = () => {
2227
+ const intl = reactIntl.useIntl();
2228
+ const _useExportResourcesMo = useExportResourcesModalContext(),
2229
+ formik = _useExportResourcesMo.formik,
2230
+ fieldSelectionMode = _useExportResourcesMo.fieldSelectionMode,
2231
+ localeOption = _useExportResourcesMo.localeOption,
2232
+ setLocaleOption = _useExportResourcesMo.setLocaleOption;
2233
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
2234
+ locale: applicationContext.dataLocale,
2235
+ locales: applicationContext.project?.languages || []
2236
+ })),
2237
+ locales = _useApplicationContex.locales,
2238
+ locale = _useApplicationContex.locale;
2239
+ const isOnlyLocalesFoundInCsvFileOptionDisabled = React__default["default"].useMemo(() => {
2240
+ return fieldSelectionMode !== 'imported-csv-template' || !_valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile;
2241
+ }, [fieldSelectionMode, _valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile]);
2242
+ const isLocalesSelectFieldDisabled = React__default["default"].useMemo(() => {
2243
+ return localeOption === LocaleOption.OnlyLocalesFoundInCsvFile;
2244
+ }, [localeOption]);
2245
+ const isCSVOutputFormat = _valuesInstanceProperty__default["default"](formik).outputFormat === OUTPUT_FORMATS.CSV;
2246
+ const localeChangeHandler = React__default["default"].useCallback(e => {
2247
+ const nextValue = e.target.value;
2248
+ if (nextValue === LocaleOption.All) formik.setFieldValue('locales', locales);else if (nextValue === LocaleOption.Selected) formik.setFieldValue('locales', [locale]);
2249
+ setLocaleOption(nextValue);
2250
+ }, [setLocaleOption, locales, locale, formik]);
2251
+ return jsxRuntime.jsxs(uiKit.Spacings.Inline, {
2252
+ scale: "xs",
2253
+ children: [jsxRuntime.jsx(uiKit.FieldLabel, {
2254
+ horizontalConstraint: 3,
2255
+ hasRequiredIndicator: true,
2256
+ title: intl.formatMessage(messages.locales),
2257
+ htmlFor: "locales-select-field"
2258
+ }), jsxRuntime.jsx(uiKit.Constraints.Horizontal, {
2259
+ max: "scale",
2260
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2261
+ scale: "xs",
2262
+ children: [jsxRuntime.jsxs(uiKit.RadioInput.Group, {
2263
+ onChange: localeChangeHandler,
2264
+ name: "locale-option",
2265
+ value: localeOption,
2266
+ direction: "inline",
2267
+ children: [jsxRuntime.jsx(uiKit.RadioInput.Option, {
2268
+ value: LocaleOption.Selected,
2269
+ children: intl.formatMessage(messages.includeOnlySelectedLocalesRadioOption)
2270
+ }), jsxRuntime.jsx(uiKit.RadioInput.Option, {
2271
+ "data-testid": "include-all-locales-toggle-input",
2272
+ value: LocaleOption.All,
2273
+ children: intl.formatMessage(messages.includeAllLocalesRadioOption)
2274
+ }), isCSVOutputFormat && jsxRuntime.jsx(uiKit.RadioInput.Option, {
2275
+ "data-testid": "only-locales-found-in-the-csv-file",
2276
+ value: LocaleOption.OnlyLocalesFoundInCsvFile,
2277
+ isDisabled: isOnlyLocalesFoundInCsvFileOptionDisabled,
2278
+ children: jsxRuntime.jsxs(uiKit.Spacings.Inline, {
2279
+ scale: "s",
2280
+ alignItems: "center",
2281
+ children: [jsxRuntime.jsx("div", {
2282
+ children: intl.formatMessage(messages.onlyLocalesFoundInCsvFile)
2283
+ }), jsxRuntime.jsx(uiKit.Tooltip, {
2284
+ title: intl.formatMessage(messages.onlyLocalesFoundInCsvFileTooltip),
2285
+ children: jsxRuntime.jsx(uiKit.SupportIcon, {
2286
+ color: "primary",
2287
+ size: "20"
2288
+ })
2289
+ })]
2290
+ })
2291
+ })]
2292
+ }), jsxRuntime.jsx(uiKit.SelectField, {
2293
+ id: "locales-select-field",
2294
+ name: "locales",
2295
+ "data-testid": "locales-select-field",
2296
+ isDisabled: isLocalesSelectFieldDisabled,
2297
+ title: "",
2298
+ value: _valuesInstanceProperty__default["default"](formik).locales,
2299
+ options: mapLocalesToOptions(locales),
2300
+ isMulti: true,
2301
+ onChange: formik.handleChange,
2302
+ onBlur: formik.handleBlur,
2303
+ touched: formik.touched.locales,
2304
+ errors: operations.mapFormikErrors(formik.errors.locales),
2305
+ renderError: renderLocaleError,
2306
+ menuPortalTarget: document.body,
2307
+ menuPortalZIndex: Z_INDEX_DROPDOWN,
2308
+ horizontalConstraint: 16,
2309
+ isClearable: false
2310
+ })]
2311
+ })
2312
+ })]
2313
+ });
2314
+ };
2315
+
2316
+ function ownKeys$7(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; }
2317
+ function _objectSpread$7(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$7(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$7(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
2318
+ const ImportedCsvTemplateFieldsForm = () => {
2319
+ return jsxRuntime.jsx(uiKit.Spacings.Stack, {
2320
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2321
+ scale: "m",
2322
+ children: [jsxRuntime.jsx(uiKit.Spacings.Stack, {
2323
+ scale: "xs",
2324
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2325
+ intlMessage: _objectSpread$7(_objectSpread$7({}, messages.defineFieldsToIncludeInExport), {}, {
2326
+ values: {
2327
+ templateLink: msg => jsxRuntime.jsx(uiKit.Link, {
2328
+ tone: "secondary",
2329
+ to: CSV_TEMPLATES_LINK,
2330
+ isExternal: true,
2331
+ children: msg
2332
+ }, "link")
2333
+ }
2334
+ })
2335
+ })
2336
+ }), jsxRuntime.jsx(FileDropArea, {})]
2337
+ })
2338
+ });
2339
+ };
2340
+
2341
+ 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; }
2342
+ 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; }
2343
+ const exportFieldSelectionContextDefaultValues = {
2344
+ updateExpandedGroups: (_name, _value) => {}
2345
+ };
2346
+ const ExportFieldSelectionContext = /*#__PURE__*/React.createContext(exportFieldSelectionContextDefaultValues);
2347
+ const ExportFieldSelectionProvider = _ref => {
2348
+ let resourceType = _ref.resourceType,
2349
+ children = _ref.children;
2350
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
2351
+ projectKey: context.project?.key
2352
+ })),
2353
+ projectKey = _useApplicationContex.projectKey;
2354
+ const _useStorage = useStorage(`${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_EXPANDED_GROUP}`, {}),
2355
+ _useStorage2 = _slicedToArray(_useStorage, 2),
2356
+ cachedExpandedGroups = _useStorage2[0],
2357
+ setCachedExpandedGroups = _useStorage2[1];
2358
+ const updateExpandedGroups = React.useCallback((name, value) => {
2359
+ setCachedExpandedGroups({
2360
+ [resourceType]: _objectSpread$6(_objectSpread$6({}, cachedExpandedGroups?.[resourceType] || {}), {}, {
2361
+ [name]: value
2362
+ })
2363
+ });
2364
+ }, [cachedExpandedGroups, resourceType, setCachedExpandedGroups]);
2365
+ return jsxRuntime.jsx(ExportFieldSelectionContext.Provider, {
2366
+ value: {
2367
+ updateExpandedGroups
2368
+ },
2369
+ children: children
2370
+ });
2371
+ };
2372
+ const useExportFieldSelectionContext = () => {
2373
+ return React.useContext(ExportFieldSelectionContext);
2374
+ };
2375
+
2376
+ const FieldsCountStamp = _ref => {
2377
+ let count = _ref.count;
2378
+ const _useIntl = reactIntl.useIntl(),
2379
+ formatMessage = _useIntl.formatMessage;
2380
+ return jsxRuntime.jsx(uiKit.Stamp, {
2381
+ tone: "information",
2382
+ isCondensed: true,
2383
+ label: formatMessage(messages.itemCount, {
2384
+ count
2385
+ })
2386
+ });
2387
+ };
2388
+
2389
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { 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)."; }
2390
+ const FieldWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
2391
+ target: "e1judmlm0"
2392
+ } : {
2393
+ target: "e1judmlm0",
2394
+ label: "FieldWrapper"
2395
+ })(process.env.NODE_ENV === "production" ? {
2396
+ name: "9iujih",
2397
+ styles: "position:relative;display:flex;align-items:center"
2398
+ } : {
2399
+ name: "9iujih",
2400
+ styles: "position:relative;display:flex;align-items:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAsB+B","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { FormikProps } from 'formik'\nimport get from 'lodash/get'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport { StyledExpandableContent } from './field-group-section'\nimport { FieldsCountStamp } from './fields-count-stamp'\nimport type { FormField, FormValues } from '../../@types'\nimport { areAllFieldsChecked, isAnyFieldChecked } from '../../@utils'\nimport messages from '../../messages'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n  display: flex;\n  align-items: center;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => React.ReactElement\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FormField[]\n  parentKeys: string[]\n  formik: FormikProps<FormValues>\n  isAnySiblingChecked: boolean\n  isSearchActive?: boolean\n  groupName: string\n  maxVisibleChildren?: number\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isSearchActive,\n  groupName,\n  maxVisibleChildren,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n\n  const visibleFields =\n    isSearchActive || !maxVisibleChildren\n      ? fields\n      : fields?.slice(0, maxVisibleChildren)\n\n  const hasMoreFields =\n    maxVisibleChildren &&\n    !isSearchActive &&\n    fields &&\n    fields.length > maxVisibleChildren\n\n  const visibleIndex = (field: FormField) =>\n    fields?.filter((f) => !f.isHidden).indexOf(field) || -1\n\n  const shouldDisplayField = (field: FormField) => {\n    if (field.isHidden) return false\n    if (!maxVisibleChildren) return true\n    return maxVisibleChildren && visibleIndex(field) < maxVisibleChildren\n  }\n\n  const shouldDisplayChildrenCount = (field: FormField) => {\n    return Boolean(field.maxVisibleChildren)\n  }\n\n  return (\n    <Spacings.Stack scale=\"s\">\n      {visibleFields?.map((field, index) => {\n        const isChildrenCountDisplayed = shouldDisplayChildrenCount(field)\n        const hasDependents = Boolean(\n          field.dependentGroupNames?.length || field.dependentFieldNames?.length\n        )\n        const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(\n          field.fields || []\n        )\n        const allFieldsChecked = areAllFieldsChecked(field.fields || [])\n        const getIsChecked = () => {\n          const isParent = Boolean(field.fields && field.fields?.length > 0)\n\n          if (isParent) return areAllFieldsChecked(field.fields!)\n\n          return field.isChecked\n        }\n        if (!shouldDisplayField(field)) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isSearchActive}\n            field={field}\n            key={`${field.name}.${isSearchActive}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isSearchActive) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allFieldsChecked &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={getIsChecked()}\n                      isReadOnly={hasDependents || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        const checked = e.target.checked\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path) as FormField\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 || field.isRequired,\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                            checked || field.isRequired,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, checked)\n                      }}\n                    >\n                      {field.label}\n                      {(hasDependents || field.isRequired) && ' *'}\n                    </CheckboxInput>\n                    {isChildrenCountDisplayed &&\n                      field.fields &&\n                      field.fields.length > 0 && (\n                        <div\n                          style={{\n                            flex: '0 0 auto',\n                          }}\n                        >\n                          <FieldsCountStamp count={field.fields.length} />\n                        </div>\n                      )}\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    {isOpen && (\n                      <Spacings.Inline scale=\"xl\">\n                        <div />\n                        <FieldSection\n                          fields={field.fields}\n                          maxVisibleChildren={field.maxVisibleChildren}\n                          formik={formik}\n                          parentKeys={[...parentKeys, `fields[${index}]`]}\n                          isAnySiblingChecked={isAnySiblingChecked}\n                          isSearchActive={isSearchActive}\n                          groupName={groupName}\n                        />\n                      </Spacings.Inline>\n                    )}\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n      {hasMoreFields && (\n        <div\n          css={css`\n            padding-left: ${designTokens.spacingXs};\n          `}\n        >\n          <Text.Detail tone=\"tertiary\" intlMessage={messages.loadMoreFields} />\n        </div>\n      )}\n    </Spacings.Stack>\n  )\n}\n"]} */",
2401
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
2402
+ });
2403
+ const CollapsibleFieldWrapper = _ref => {
2404
+ let isForceExpanded = _ref.isForceExpanded,
2405
+ field = _ref.field,
2406
+ children = _ref.children;
2407
+ if (field.isExpandable) return jsxRuntime.jsx(uiKit.CollapsibleMotion, {
2408
+ isDefaultClosed: isForceExpanded ? false : !field.isExpanded,
2409
+ children: _ref2 => {
2410
+ let isOpen = _ref2.isOpen,
2411
+ toggle = _ref2.toggle,
2412
+ registerContentNode = _ref2.registerContentNode;
2413
+ return children({
2414
+ isOpen,
2415
+ toggle,
2416
+ registerContentNode
2417
+ });
2418
+ }
2419
+ }, `${isForceExpanded}`);
2420
+ return children({
2421
+ isOpen: true,
2422
+ toggle: () => {},
2423
+ registerContentNode: () => {}
2424
+ });
2425
+ };
2426
+ const FieldSection = _ref3 => {
2427
+ var _context, _context2, _context7, _context8;
2428
+ let fields = _ref3.fields,
2429
+ parentKeys = _ref3.parentKeys,
2430
+ formik = _ref3.formik,
2431
+ isAnySiblingChecked = _ref3.isAnySiblingChecked,
2432
+ isSearchActive = _ref3.isSearchActive,
2433
+ groupName = _ref3.groupName,
2434
+ maxVisibleChildren = _ref3.maxVisibleChildren;
2435
+ const _useExportFieldSelect = useExportFieldSelectionContext(),
2436
+ updateExpandedGroups = _useExportFieldSelect.updateExpandedGroups;
2437
+ const visibleFields = isSearchActive || !maxVisibleChildren ? fields : ((_context = fields) == null ? void 0 : _bindInstanceProperty__default["default"](_context2 = Function.call).call(_context2, _sliceInstanceProperty__default["default"](_context), _context))?.(0, maxVisibleChildren);
2438
+ const hasMoreFields = maxVisibleChildren && !isSearchActive && fields && fields.length > maxVisibleChildren;
2439
+ const visibleIndex = field => {
2440
+ var _context3, _context4, _context5, _context6;
2441
+ return ((_context3 = ((_context4 = fields) == null ? void 0 : _bindInstanceProperty__default["default"](_context5 = Function.call).call(_context5, _filterInstanceProperty__default["default"](_context4), _context4))?.(f => !f.isHidden)) == null ? void 0 : _bindInstanceProperty__default["default"](_context6 = Function.call).call(_context6, _indexOfInstanceProperty__default["default"](_context3), _context3))?.(field) || -1;
2442
+ };
2443
+ const shouldDisplayField = field => {
2444
+ if (field.isHidden) return false;
2445
+ if (!maxVisibleChildren) return true;
2446
+ return maxVisibleChildren && visibleIndex(field) < maxVisibleChildren;
2447
+ };
2448
+ const shouldDisplayChildrenCount = field => {
2449
+ return Boolean(field.maxVisibleChildren);
2450
+ };
2451
+ return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2452
+ scale: "s",
2453
+ children: [((_context7 = visibleFields) == null ? void 0 : _bindInstanceProperty__default["default"](_context8 = Function.call).call(_context8, _mapInstanceProperty__default["default"](_context7), _context7))?.((field, index) => {
2454
+ const isChildrenCountDisplayed = shouldDisplayChildrenCount(field);
2455
+ const hasDependents = Boolean(field.dependentGroupNames?.length || field.dependentFieldNames?.length);
2456
+ const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(field.fields || []);
2457
+ const allFieldsChecked = areAllFieldsChecked(field.fields || []);
2458
+ const getIsChecked = () => {
2459
+ const isParent = Boolean(field.fields && field.fields?.length > 0);
2460
+ if (isParent) return areAllFieldsChecked(field.fields);
2461
+ return field.isChecked;
2462
+ };
2463
+ if (!shouldDisplayField(field)) return null;
2464
+ return jsxRuntime.jsx(CollapsibleFieldWrapper, {
2465
+ isForceExpanded: isSearchActive,
2466
+ field: field,
2467
+ children: _ref4 => {
2468
+ let isOpen = _ref4.isOpen,
2469
+ toggle = _ref4.toggle,
2470
+ registerContentNode = _ref4.registerContentNode;
2471
+ return jsxRuntime.jsxs(React.Fragment, {
2472
+ children: [jsxRuntime.jsxs(FieldWrapper, {
2473
+ children: [field.isExpandable && jsxRuntime.jsx(uiKit.IconButton, {
2474
+ size: "20",
2475
+ style: {
2476
+ position: 'absolute',
2477
+ left: `calc(-1 * ${uiKit.designTokens.spacingXl})`
2478
+ },
2479
+ onClick: () => {
2480
+ if (!isSearchActive) {
2481
+ updateExpandedGroups(`${groupName}.${field.name}`, !isOpen);
2482
+ }
2483
+ toggle();
2484
+ },
2485
+ icon: isOpen ? jsxRuntime.jsx(uiKit.AngleDownIcon, {}) : jsxRuntime.jsx(uiKit.AngleRightIcon, {}),
2486
+ label: ""
2487
+ }), jsxRuntime.jsxs(uiKit.Spacings.Inline, {
2488
+ scale: "s",
2489
+ alignItems: "center",
2490
+ children: [jsxRuntime.jsxs(uiKit.CheckboxInput, {
2491
+ isIndeterminate: field.isExpandable && !allFieldsChecked && isAnyOfTheChildFieldsChecked,
2492
+ isChecked: getIsChecked(),
2493
+ isReadOnly: hasDependents || field.isRequired,
2494
+ onChange: e => {
2495
+ const path = `${parentKeys.join('.')}.fields[${index}]`;
2496
+ const checked = e.target.checked;
2497
+ // Update all child fields
2498
+ const updateAllChildFieldsChecked = (path, checked) => {
2499
+ const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), path);
2500
+ if (item && item.fields) {
2501
+ var _context9;
2502
+ _forEachInstanceProperty__default["default"](_context9 = item.fields).call(_context9, (field, i) => {
2503
+ const fieldPath = `${path}.fields[${i}]`;
2504
+ if (!field.fields?.length) {
2505
+ formik.setFieldValue(`${fieldPath}.isChecked`, checked || field.isRequired,
2506
+ // pass `false` to avoid revalidating the form with intermediate values
2507
+ false);
2508
+ }
2509
+ updateAllChildFieldsChecked(fieldPath, checked);
2510
+ });
2511
+ }
2512
+ };
2513
+ if (!field.fields?.length) {
2514
+ formik.setFieldValue(`${path}.isChecked`, checked || field.isRequired,
2515
+ // pass `false` to avoid revalidating the form with intermediate values
2516
+ false);
2517
+ }
2518
+ updateAllChildFieldsChecked(path, checked);
2519
+ },
2520
+ children: [field.label, (hasDependents || field.isRequired) && ' *']
2521
+ }), isChildrenCountDisplayed && field.fields && field.fields.length > 0 && jsxRuntime.jsx("div", {
2522
+ style: {
2523
+ flex: '0 0 auto'
2524
+ },
2525
+ children: jsxRuntime.jsx(FieldsCountStamp, {
2526
+ count: field.fields.length
2527
+ })
2528
+ })]
2529
+ })]
2530
+ }), field.fields && field.fields.length > 0 && jsxRuntime.jsx(StyledExpandableContent, {
2531
+ ref: registerContentNode,
2532
+ isOpen: isOpen,
2533
+ children: isOpen && jsxRuntime.jsxs(uiKit.Spacings.Inline, {
2534
+ scale: "xl",
2535
+ children: [jsxRuntime.jsx("div", {}), jsxRuntime.jsx(FieldSection, {
2536
+ fields: field.fields,
2537
+ maxVisibleChildren: field.maxVisibleChildren,
2538
+ formik: formik,
2539
+ parentKeys: [...parentKeys, `fields[${index}]`],
2540
+ isAnySiblingChecked: isAnySiblingChecked,
2541
+ isSearchActive: isSearchActive,
2542
+ groupName: groupName
2543
+ })]
2544
+ })
2545
+ })]
2546
+ }, `${field.name}-${index}`);
2547
+ }
2548
+ }, `${field.name}.${isSearchActive}`);
2549
+ }), hasMoreFields && jsxRuntime.jsx("div", {
2550
+ css: /*#__PURE__*/react.css("padding-left:", uiKit.designTokens.spacingXs, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:FieldSection;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAqPkB","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { FormikProps } from 'formik'\nimport get from 'lodash/get'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport { StyledExpandableContent } from './field-group-section'\nimport { FieldsCountStamp } from './fields-count-stamp'\nimport type { FormField, FormValues } from '../../@types'\nimport { areAllFieldsChecked, isAnyFieldChecked } from '../../@utils'\nimport messages from '../../messages'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n  display: flex;\n  align-items: center;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => React.ReactElement\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FormField[]\n  parentKeys: string[]\n  formik: FormikProps<FormValues>\n  isAnySiblingChecked: boolean\n  isSearchActive?: boolean\n  groupName: string\n  maxVisibleChildren?: number\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isSearchActive,\n  groupName,\n  maxVisibleChildren,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n\n  const visibleFields =\n    isSearchActive || !maxVisibleChildren\n      ? fields\n      : fields?.slice(0, maxVisibleChildren)\n\n  const hasMoreFields =\n    maxVisibleChildren &&\n    !isSearchActive &&\n    fields &&\n    fields.length > maxVisibleChildren\n\n  const visibleIndex = (field: FormField) =>\n    fields?.filter((f) => !f.isHidden).indexOf(field) || -1\n\n  const shouldDisplayField = (field: FormField) => {\n    if (field.isHidden) return false\n    if (!maxVisibleChildren) return true\n    return maxVisibleChildren && visibleIndex(field) < maxVisibleChildren\n  }\n\n  const shouldDisplayChildrenCount = (field: FormField) => {\n    return Boolean(field.maxVisibleChildren)\n  }\n\n  return (\n    <Spacings.Stack scale=\"s\">\n      {visibleFields?.map((field, index) => {\n        const isChildrenCountDisplayed = shouldDisplayChildrenCount(field)\n        const hasDependents = Boolean(\n          field.dependentGroupNames?.length || field.dependentFieldNames?.length\n        )\n        const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(\n          field.fields || []\n        )\n        const allFieldsChecked = areAllFieldsChecked(field.fields || [])\n        const getIsChecked = () => {\n          const isParent = Boolean(field.fields && field.fields?.length > 0)\n\n          if (isParent) return areAllFieldsChecked(field.fields!)\n\n          return field.isChecked\n        }\n        if (!shouldDisplayField(field)) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isSearchActive}\n            field={field}\n            key={`${field.name}.${isSearchActive}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isSearchActive) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allFieldsChecked &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={getIsChecked()}\n                      isReadOnly={hasDependents || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        const checked = e.target.checked\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path) as FormField\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 || field.isRequired,\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                            checked || field.isRequired,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, checked)\n                      }}\n                    >\n                      {field.label}\n                      {(hasDependents || field.isRequired) && ' *'}\n                    </CheckboxInput>\n                    {isChildrenCountDisplayed &&\n                      field.fields &&\n                      field.fields.length > 0 && (\n                        <div\n                          style={{\n                            flex: '0 0 auto',\n                          }}\n                        >\n                          <FieldsCountStamp count={field.fields.length} />\n                        </div>\n                      )}\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    {isOpen && (\n                      <Spacings.Inline scale=\"xl\">\n                        <div />\n                        <FieldSection\n                          fields={field.fields}\n                          maxVisibleChildren={field.maxVisibleChildren}\n                          formik={formik}\n                          parentKeys={[...parentKeys, `fields[${index}]`]}\n                          isAnySiblingChecked={isAnySiblingChecked}\n                          isSearchActive={isSearchActive}\n                          groupName={groupName}\n                        />\n                      </Spacings.Inline>\n                    )}\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n      {hasMoreFields && (\n        <div\n          css={css`\n            padding-left: ${designTokens.spacingXs};\n          `}\n        >\n          <Text.Detail tone=\"tertiary\" intlMessage={messages.loadMoreFields} />\n        </div>\n      )}\n    </Spacings.Stack>\n  )\n}\n"]} */"),
2551
+ children: jsxRuntime.jsx(uiKit.Text.Detail, {
2552
+ tone: "tertiary",
2553
+ intlMessage: messages.loadMoreFields
2554
+ })
2555
+ })]
2556
+ });
2557
+ };
2558
+
2559
+ const SelectedGroupFieldsCountStamp = _ref => {
2560
+ let group = _ref.group;
2561
+ const _useIntl = reactIntl.useIntl(),
2562
+ formatMessage = _useIntl.formatMessage;
2563
+ return jsxRuntime.jsx(uiKit.Card, {
2564
+ type: "flat",
2565
+ insetScale: "m",
2566
+ children: jsxRuntime.jsx(uiKit.Spacings.Inline, {
2567
+ justifyContent: "flex-end",
2568
+ children: jsxRuntime.jsx(uiKit.Stamp, {
2569
+ tone: "secondary",
2570
+ isCondensed: true,
2571
+ label: formatMessage(messages.selected, {
2572
+ total: getGroupSelectedFieldCount(group)
2573
+ })
2574
+ })
2575
+ })
2576
+ });
2577
+ };
2578
+
2579
+ 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; }
2580
+ function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$5(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$5(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
2581
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { 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)."; }
2582
+ const StyledGroupCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
2583
+ target: "e1igkh7t2"
2584
+ } : {
2585
+ target: "e1igkh7t2",
2586
+ label: "StyledGroupCard"
2587
+ })("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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCTyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIEFuZ2xlRG93bkljb24sXG4gIEFuZ2xlUmlnaHRJY29uLFxuICBDYXJkLFxuICBDaGVja2JveElucHV0LFxuICBDb2xsYXBzaWJsZU1vdGlvbixcbiAgR3JpZCxcbiAgSWNvbkJ1dHRvbixcbiAgU3BhY2luZ3MsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRm9ybWlrUHJvcHMgfSBmcm9tICdmb3JtaWsnXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQgeyBTZWxlY3RlZEdyb3VwRmllbGRzQ291bnRTdGFtcCB9IGZyb20gJy4vc2VsZWN0ZWQtZ3JvdXAtZmllbGRzLWNvdW50LXN0YW1wJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCwgRm9ybUdyb3VwLCBGb3JtVmFsdWVzIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgYXJlQWxsRmllbGRzQ2hlY2tlZCwgaXNBbnlGaWVsZENoZWNrZWQgfSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRm9ybUdyb3VwXG4gIGZvcm1pazogRm9ybWlrUHJvcHM8Rm9ybVZhbHVlcz5cbiAgaXNTZWFyY2hBY3RpdmU/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc1NlYXJjaEFjdGl2ZSxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsRmllbGRzQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gYXJlQWxsRmllbGRzQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCBpc0FueUZpZWxkSW5Hcm91cENoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGlzQW55RmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzOiBGaWVsZFtdLCBjaGVja2VkOiBib29sZWFuKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNTZWFyY2hBY3RpdmUgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAgLy8gUmVzZXQgY29sbGFwc2Ugc3RhdGUgd2hlbiBzZWFyY2ggaW5wdXQgYmVjb21lcyBhY3RpdmUvaW5hY3RpdmVcbiAgICAgIGtleT17YCR7aXNTZWFyY2hBY3RpdmV9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzU2VhcmNoQWN0aXZlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgdXBkYXRlRXhwYW5kZWRHcm91cHMoZ3JvdXAuZ3JvdXBOYW1lLCAhaXNPcGVuKVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHRvZ2dsZSgpXG4gICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgaWNvbj17aXNPcGVuID8gPEFuZ2xlRG93bkljb24gLz4gOiA8QW5nbGVSaWdodEljb24gLz59XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIlwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAgaXNJbmRldGVybWluYXRlPXtcbiAgICAgICAgICAgICAgICAgICAgIWFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ9e2FsbEZpZWxkc0NoZWNrZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtpc09wZW4gJiYgKFxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBbnlGaWVsZEluR3JvdXBDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzU2VhcmNoQWN0aXZlPXtpc1NlYXJjaEFjdGl2ZX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8U2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgZ3JvdXA9e2dyb3VwfSAvPn1cbiAgICAgICAgICAgIDwvPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICA8Lz5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKVxufVxuIl19 */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCaUUiLCJmaWxlIjoiZmllbGQtZ3JvdXAtc2VjdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEZvcm1pa1Byb3BzIH0gZnJvbSAnZm9ybWlrJ1xuaW1wb3J0IGdldCBmcm9tICdsb2Rhc2gvZ2V0J1xuaW1wb3J0IHsgdXNlRXhwb3J0RmllbGRTZWxlY3Rpb25Db250ZXh0IH0gZnJvbSAnLi9leHBvcnQtZmllbGQtc2VsZWN0aW9uLXByb3ZpZGVyJ1xuaW1wb3J0IHsgRmllbGRTZWN0aW9uIH0gZnJvbSAnLi9maWVsZC1zZWN0aW9uJ1xuaW1wb3J0IHsgU2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgfSBmcm9tICcuL3NlbGVjdGVkLWdyb3VwLWZpZWxkcy1jb3VudC1zdGFtcCdcbmltcG9ydCB0eXBlIHsgRmllbGQsIEZvcm1Hcm91cCwgRm9ybVZhbHVlcyB9IGZyb20gJy4uLy4uL0B0eXBlcydcbmltcG9ydCB7IGFyZUFsbEZpZWxkc0NoZWNrZWQsIGlzQW55RmllbGRDaGVja2VkIH0gZnJvbSAnLi4vLi4vQHV0aWxzJ1xuXG5jb25zdCBTdHlsZWRHcm91cENhcmQgPSBzdHlsZWQoQ2FyZCk8eyBzaG93VG9wQm9yZGVyPzogYm9vbGVhbiB9PmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcbmNvbnN0IFN0eWxlZEZpZWxkc0NhcmQgPSBzdHlsZWQoQ2FyZCk8eyBzaG93VG9wQm9yZGVyPzogYm9vbGVhbiB9PmBcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFeHBhbmRhYmxlQ29udGVudCA9IHN0eWxlZC5kaXY8e1xuICBpc09wZW4/OiBib29sZWFuXG4gIHNob3dUb3BCb3JkZXI/OiBib29sZWFuXG59PmBcbiAgJHsocHJvcHMpID0+XG4gICAgIXByb3BzLmlzT3BlbiAmJlxuICAgIGNzc2BcbiAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBoZWlnaHQ6IDA7XG4gICAgICBtYXJnaW4tdG9wOiAwICFpbXBvcnRhbnQ7XG4gICAgYH1cbiAgJHsocHJvcHMpID0+XG4gICAgIXByb3BzLmlzT3BlbiAmJlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG50eXBlIEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMgPSB7XG4gIGluZGV4OiBudW1iZXJcbiAgZ3JvdXA6IEZvcm1Hcm91cFxuICBmb3JtaWs6IEZvcm1pa1Byb3BzPEZvcm1WYWx1ZXM+XG4gIGlzU2VhcmNoQWN0aXZlPzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgRmllbGRHcm91cFNlY3Rpb24gPSAoe1xuICBncm91cCxcbiAgaW5kZXgsXG4gIGZvcm1payxcbiAgaXNTZWFyY2hBY3RpdmUsXG59OiBGaWVsZEdyb3VwU2VjdGlvblByb3BzKSA9PiB7XG4gIGNvbnN0IGFsbEZpZWxkc0NoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGFyZUFsbEZpZWxkc0NoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBpc0FueUZpZWxkQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCB7IHVwZGF0ZUV4cGFuZGVkR3JvdXBzIH0gPSB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQoKVxuXG4gIGNvbnN0IHBhcmVudEtleSA9IGBncm91cHNbJHtpbmRleH1dYFxuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZUFsbEZpZWxkcyA9IChlKSA9PiB7XG4gICAgY29uc3QgaXRlbSA9IGdldChmb3JtaWsudmFsdWVzLCBwYXJlbnRLZXkpXG4gICAgZnVuY3Rpb24gdXBkYXRlQWxsRmllbGRzKGZpZWxkczogRmllbGRbXSwgY2hlY2tlZDogYm9vbGVhbikge1xuICAgICAgcmV0dXJuIGZpZWxkcy5tYXAoKGZpZWxkKSA9PiB7XG4gICAgICAgIGlmIChmaWVsZC5maWVsZHMpIHtcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgLi4uZmllbGQsXG4gICAgICAgICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhmaWVsZC5maWVsZHMsIGNoZWNrZWQpLFxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoZmllbGQuaXNSZXF1aXJlZCkgcmV0dXJuIGZpZWxkXG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgLi4uZmllbGQsXG4gICAgICAgICAgaXNDaGVja2VkOiBjaGVja2VkLFxuICAgICAgICB9XG4gICAgICB9KVxuICAgIH1cblxuICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKHBhcmVudEtleSwge1xuICAgICAgLi4uaXRlbSxcbiAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGl0ZW0uZmllbGRzLCBlLnRhcmdldC5jaGVja2VkKSxcbiAgICB9KVxuICB9XG5cbiAgaWYgKGdyb3VwLmlzSGlkZGVuKSByZXR1cm4gbnVsbFxuXG4gIHJldHVybiAoXG4gICAgPENvbGxhcHNpYmxlTW90aW9uXG4gICAgICBpc0RlZmF1bHRDbG9zZWQ9e2lzU2VhcmNoQWN0aXZlID8gZmFsc2UgOiAhZ3JvdXAuaXNFeHBhbmRlZH1cbiAgICAgIC8vIFJlc2V0IGNvbGxhcHNlIHN0YXRlIHdoZW4gc2VhcmNoIGlucHV0IGJlY29tZXMgYWN0aXZlL2luYWN0aXZlXG4gICAgICBrZXk9e2Ake2lzU2VhcmNoQWN0aXZlfWB9XG4gICAgPlxuICAgICAgeyh7IGlzT3BlbiwgdG9nZ2xlLCByZWdpc3RlckNvbnRlbnROb2RlIH0pID0+IChcbiAgICAgICAgPD5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPFN0eWxlZEdyb3VwQ2FyZFxuICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwic1wiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblxuICAgICAgICAgICAgICAgICAgc2l6ZT1cIjIwXCJcbiAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCFpc1NlYXJjaEFjdGl2ZSkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxGaWVsZHNDaGVja2VkICYmIGlzQW55RmllbGRJbkdyb3VwQ2hlY2tlZFxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxGaWVsZHNDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZUFsbEZpZWxkc31cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7Z3JvdXAuZ3JvdXBMYWJlbH1cbiAgICAgICAgICAgICAgICA8L0NoZWNrYm94SW5wdXQ+XG4gICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICAgICAgPC9TdHlsZWRHcm91cENhcmQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgICAgPEdyaWQuSXRlbT5cbiAgICAgICAgICAgIDw+XG4gICAgICAgICAgICAgIDxTdHlsZWRFeHBhbmRhYmxlQ29udGVudFxuICAgICAgICAgICAgICAgIHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX1cbiAgICAgICAgICAgICAgICBpc09wZW49e2lzT3Blbn1cbiAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICA8U3R5bGVkRmllbGRzQ2FyZFxuICAgICAgICAgICAgICAgICAgdHlwZT1cImZsYXRcIlxuICAgICAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17dHJ1ZX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7aXNPcGVuICYmIChcbiAgICAgICAgICAgICAgICAgICAgPEZpZWxkU2VjdGlvblxuICAgICAgICAgICAgICAgICAgICAgIGZpZWxkcz17Z3JvdXAuZmllbGRzfVxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1paz17Zm9ybWlrfVxuICAgICAgICAgICAgICAgICAgICAgIHBhcmVudEtleXM9e1twYXJlbnRLZXldfVxuICAgICAgICAgICAgICAgICAgICAgIGlzQW55U2libGluZ0NoZWNrZWQ9e2lzQW55RmllbGRJbkdyb3VwQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICAgICAgICBncm91cE5hbWU9e2dyb3VwLmdyb3VwTmFtZX1cbiAgICAgICAgICAgICAgICAgICAgICBpc1NlYXJjaEFjdGl2ZT17aXNTZWFyY2hBY3RpdmV9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDwvU3R5bGVkRmllbGRzQ2FyZD5cbiAgICAgICAgICAgICAgPC9TdHlsZWRFeHBhbmRhYmxlQ29udGVudD5cbiAgICAgICAgICAgICAgeyFpc09wZW4gJiYgPFNlbGVjdGVkR3JvdXBGaWVsZHNDb3VudFN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */"));
2588
+ const StyledFieldsCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
2589
+ target: "e1igkh7t1"
2590
+ } : {
2591
+ target: "e1igkh7t1",
2592
+ label: "StyledFieldsCard"
2593
+ })("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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9DTyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIEFuZ2xlRG93bkljb24sXG4gIEFuZ2xlUmlnaHRJY29uLFxuICBDYXJkLFxuICBDaGVja2JveElucHV0LFxuICBDb2xsYXBzaWJsZU1vdGlvbixcbiAgR3JpZCxcbiAgSWNvbkJ1dHRvbixcbiAgU3BhY2luZ3MsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRm9ybWlrUHJvcHMgfSBmcm9tICdmb3JtaWsnXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQgeyBTZWxlY3RlZEdyb3VwRmllbGRzQ291bnRTdGFtcCB9IGZyb20gJy4vc2VsZWN0ZWQtZ3JvdXAtZmllbGRzLWNvdW50LXN0YW1wJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCwgRm9ybUdyb3VwLCBGb3JtVmFsdWVzIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgYXJlQWxsRmllbGRzQ2hlY2tlZCwgaXNBbnlGaWVsZENoZWNrZWQgfSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRm9ybUdyb3VwXG4gIGZvcm1pazogRm9ybWlrUHJvcHM8Rm9ybVZhbHVlcz5cbiAgaXNTZWFyY2hBY3RpdmU/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc1NlYXJjaEFjdGl2ZSxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsRmllbGRzQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gYXJlQWxsRmllbGRzQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCBpc0FueUZpZWxkSW5Hcm91cENoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGlzQW55RmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzOiBGaWVsZFtdLCBjaGVja2VkOiBib29sZWFuKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNTZWFyY2hBY3RpdmUgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAgLy8gUmVzZXQgY29sbGFwc2Ugc3RhdGUgd2hlbiBzZWFyY2ggaW5wdXQgYmVjb21lcyBhY3RpdmUvaW5hY3RpdmVcbiAgICAgIGtleT17YCR7aXNTZWFyY2hBY3RpdmV9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzU2VhcmNoQWN0aXZlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgdXBkYXRlRXhwYW5kZWRHcm91cHMoZ3JvdXAuZ3JvdXBOYW1lLCAhaXNPcGVuKVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHRvZ2dsZSgpXG4gICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgaWNvbj17aXNPcGVuID8gPEFuZ2xlRG93bkljb24gLz4gOiA8QW5nbGVSaWdodEljb24gLz59XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIlwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAgaXNJbmRldGVybWluYXRlPXtcbiAgICAgICAgICAgICAgICAgICAgIWFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ9e2FsbEZpZWxkc0NoZWNrZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtpc09wZW4gJiYgKFxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBbnlGaWVsZEluR3JvdXBDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzU2VhcmNoQWN0aXZlPXtpc1NlYXJjaEFjdGl2ZX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8U2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgZ3JvdXA9e2dyb3VwfSAvPn1cbiAgICAgICAgICAgIDwvPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICA8Lz5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKVxufVxuIl19 */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdDa0UiLCJmaWxlIjoiZmllbGQtZ3JvdXAtc2VjdGlvbi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQge1xuICBBbmdsZURvd25JY29uLFxuICBBbmdsZVJpZ2h0SWNvbixcbiAgQ2FyZCxcbiAgQ2hlY2tib3hJbnB1dCxcbiAgQ29sbGFwc2libGVNb3Rpb24sXG4gIEdyaWQsXG4gIEljb25CdXR0b24sXG4gIFNwYWNpbmdzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEZvcm1pa1Byb3BzIH0gZnJvbSAnZm9ybWlrJ1xuaW1wb3J0IGdldCBmcm9tICdsb2Rhc2gvZ2V0J1xuaW1wb3J0IHsgdXNlRXhwb3J0RmllbGRTZWxlY3Rpb25Db250ZXh0IH0gZnJvbSAnLi9leHBvcnQtZmllbGQtc2VsZWN0aW9uLXByb3ZpZGVyJ1xuaW1wb3J0IHsgRmllbGRTZWN0aW9uIH0gZnJvbSAnLi9maWVsZC1zZWN0aW9uJ1xuaW1wb3J0IHsgU2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgfSBmcm9tICcuL3NlbGVjdGVkLWdyb3VwLWZpZWxkcy1jb3VudC1zdGFtcCdcbmltcG9ydCB0eXBlIHsgRmllbGQsIEZvcm1Hcm91cCwgRm9ybVZhbHVlcyB9IGZyb20gJy4uLy4uL0B0eXBlcydcbmltcG9ydCB7IGFyZUFsbEZpZWxkc0NoZWNrZWQsIGlzQW55RmllbGRDaGVja2VkIH0gZnJvbSAnLi4vLi4vQHV0aWxzJ1xuXG5jb25zdCBTdHlsZWRHcm91cENhcmQgPSBzdHlsZWQoQ2FyZCk8eyBzaG93VG9wQm9yZGVyPzogYm9vbGVhbiB9PmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcbmNvbnN0IFN0eWxlZEZpZWxkc0NhcmQgPSBzdHlsZWQoQ2FyZCk8eyBzaG93VG9wQm9yZGVyPzogYm9vbGVhbiB9PmBcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgJHsocHJvcHMpID0+XG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbmV4cG9ydCBjb25zdCBTdHlsZWRFeHBhbmRhYmxlQ29udGVudCA9IHN0eWxlZC5kaXY8e1xuICBpc09wZW4/OiBib29sZWFuXG4gIHNob3dUb3BCb3JkZXI/OiBib29sZWFuXG59PmBcbiAgJHsocHJvcHMpID0+XG4gICAgIXByb3BzLmlzT3BlbiAmJlxuICAgIGNzc2BcbiAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBoZWlnaHQ6IDA7XG4gICAgICBtYXJnaW4tdG9wOiAwICFpbXBvcnRhbnQ7XG4gICAgYH1cbiAgJHsocHJvcHMpID0+XG4gICAgIXByb3BzLmlzT3BlbiAmJlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuXG50eXBlIEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMgPSB7XG4gIGluZGV4OiBudW1iZXJcbiAgZ3JvdXA6IEZvcm1Hcm91cFxuICBmb3JtaWs6IEZvcm1pa1Byb3BzPEZvcm1WYWx1ZXM+XG4gIGlzU2VhcmNoQWN0aXZlPzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgRmllbGRHcm91cFNlY3Rpb24gPSAoe1xuICBncm91cCxcbiAgaW5kZXgsXG4gIGZvcm1payxcbiAgaXNTZWFyY2hBY3RpdmUsXG59OiBGaWVsZEdyb3VwU2VjdGlvblByb3BzKSA9PiB7XG4gIGNvbnN0IGFsbEZpZWxkc0NoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGFyZUFsbEZpZWxkc0NoZWNrZWQoZ3JvdXAuZmllbGRzKSxcbiAgICBbZ3JvdXAuZmllbGRzXVxuICApXG5cbiAgY29uc3QgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkID0gdXNlTWVtbyhcbiAgICAoKSA9PiBpc0FueUZpZWxkQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCB7IHVwZGF0ZUV4cGFuZGVkR3JvdXBzIH0gPSB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQoKVxuXG4gIGNvbnN0IHBhcmVudEtleSA9IGBncm91cHNbJHtpbmRleH1dYFxuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZUFsbEZpZWxkcyA9IChlKSA9PiB7XG4gICAgY29uc3QgaXRlbSA9IGdldChmb3JtaWsudmFsdWVzLCBwYXJlbnRLZXkpXG4gICAgZnVuY3Rpb24gdXBkYXRlQWxsRmllbGRzKGZpZWxkczogRmllbGRbXSwgY2hlY2tlZDogYm9vbGVhbikge1xuICAgICAgcmV0dXJuIGZpZWxkcy5tYXAoKGZpZWxkKSA9PiB7XG4gICAgICAgIGlmIChmaWVsZC5maWVsZHMpIHtcbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgLi4uZmllbGQsXG4gICAgICAgICAgICBmaWVsZHM6IHVwZGF0ZUFsbEZpZWxkcyhmaWVsZC5maWVsZHMsIGNoZWNrZWQpLFxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoZmllbGQuaXNSZXF1aXJlZCkgcmV0dXJuIGZpZWxkXG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgLi4uZmllbGQsXG4gICAgICAgICAgaXNDaGVja2VkOiBjaGVja2VkLFxuICAgICAgICB9XG4gICAgICB9KVxuICAgIH1cblxuICAgIGZvcm1pay5zZXRGaWVsZFZhbHVlKHBhcmVudEtleSwge1xuICAgICAgLi4uaXRlbSxcbiAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGl0ZW0uZmllbGRzLCBlLnRhcmdldC5jaGVja2VkKSxcbiAgICB9KVxuICB9XG5cbiAgaWYgKGdyb3VwLmlzSGlkZGVuKSByZXR1cm4gbnVsbFxuXG4gIHJldHVybiAoXG4gICAgPENvbGxhcHNpYmxlTW90aW9uXG4gICAgICBpc0RlZmF1bHRDbG9zZWQ9e2lzU2VhcmNoQWN0aXZlID8gZmFsc2UgOiAhZ3JvdXAuaXNFeHBhbmRlZH1cbiAgICAgIC8vIFJlc2V0IGNvbGxhcHNlIHN0YXRlIHdoZW4gc2VhcmNoIGlucHV0IGJlY29tZXMgYWN0aXZlL2luYWN0aXZlXG4gICAgICBrZXk9e2Ake2lzU2VhcmNoQWN0aXZlfWB9XG4gICAgPlxuICAgICAgeyh7IGlzT3BlbiwgdG9nZ2xlLCByZWdpc3RlckNvbnRlbnROb2RlIH0pID0+IChcbiAgICAgICAgPD5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPFN0eWxlZEdyb3VwQ2FyZFxuICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgIGluc2V0U2NhbGU9XCJtXCJcbiAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17aW5kZXggPiAwfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwic1wiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgICAgICA8SWNvbkJ1dHRvblxuICAgICAgICAgICAgICAgICAgc2l6ZT1cIjIwXCJcbiAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCFpc1NlYXJjaEFjdGl2ZSkge1xuICAgICAgICAgICAgICAgICAgICAgIHVwZGF0ZUV4cGFuZGVkR3JvdXBzKGdyb3VwLmdyb3VwTmFtZSwgIWlzT3BlbilcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKVxuICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgIGljb249e2lzT3BlbiA/IDxBbmdsZURvd25JY29uIC8+IDogPEFuZ2xlUmlnaHRJY29uIC8+fVxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJcIlxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94SW5wdXRcbiAgICAgICAgICAgICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17XG4gICAgICAgICAgICAgICAgICAgICFhbGxGaWVsZHNDaGVja2VkICYmIGlzQW55RmllbGRJbkdyb3VwQ2hlY2tlZFxuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgaXNDaGVja2VkPXthbGxGaWVsZHNDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZUFsbEZpZWxkc31cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7Z3JvdXAuZ3JvdXBMYWJlbH1cbiAgICAgICAgICAgICAgICA8L0NoZWNrYm94SW5wdXQ+XG4gICAgICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICAgICAgPC9TdHlsZWRHcm91cENhcmQ+XG4gICAgICAgICAgPC9HcmlkLkl0ZW0+XG4gICAgICAgICAgPEdyaWQuSXRlbT5cbiAgICAgICAgICAgIDw+XG4gICAgICAgICAgICAgIDxTdHlsZWRFeHBhbmRhYmxlQ29udGVudFxuICAgICAgICAgICAgICAgIHJlZj17cmVnaXN0ZXJDb250ZW50Tm9kZX1cbiAgICAgICAgICAgICAgICBpc09wZW49e2lzT3Blbn1cbiAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICA8U3R5bGVkRmllbGRzQ2FyZFxuICAgICAgICAgICAgICAgICAgdHlwZT1cImZsYXRcIlxuICAgICAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICAgICAgc2hvd1RvcEJvcmRlcj17dHJ1ZX1cbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICB7aXNPcGVuICYmIChcbiAgICAgICAgICAgICAgICAgICAgPEZpZWxkU2VjdGlvblxuICAgICAgICAgICAgICAgICAgICAgIGZpZWxkcz17Z3JvdXAuZmllbGRzfVxuICAgICAgICAgICAgICAgICAgICAgIGZvcm1paz17Zm9ybWlrfVxuICAgICAgICAgICAgICAgICAgICAgIHBhcmVudEtleXM9e1twYXJlbnRLZXldfVxuICAgICAgICAgICAgICAgICAgICAgIGlzQW55U2libGluZ0NoZWNrZWQ9e2lzQW55RmllbGRJbkdyb3VwQ2hlY2tlZH1cbiAgICAgICAgICAgICAgICAgICAgICBncm91cE5hbWU9e2dyb3VwLmdyb3VwTmFtZX1cbiAgICAgICAgICAgICAgICAgICAgICBpc1NlYXJjaEFjdGl2ZT17aXNTZWFyY2hBY3RpdmV9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgIDwvU3R5bGVkRmllbGRzQ2FyZD5cbiAgICAgICAgICAgICAgPC9TdHlsZWRFeHBhbmRhYmxlQ29udGVudD5cbiAgICAgICAgICAgICAgeyFpc09wZW4gJiYgPFNlbGVjdGVkR3JvdXBGaWVsZHNDb3VudFN0YW1wIGdyb3VwPXtncm91cH0gLz59XG4gICAgICAgICAgICA8Lz5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgPC8+XG4gICAgICApfVxuICAgIDwvQ29sbGFwc2libGVNb3Rpb24+XG4gIClcbn1cbiJdfQ== */"));
2594
+ var _ref$1 = process.env.NODE_ENV === "production" ? {
2595
+ name: "2ce4ng",
2596
+ styles: "overflow:hidden;height:0;margin-top:0!important"
2597
+ } : {
2598
+ name: "14qt8ie-StyledExpandableContent",
2599
+ styles: "overflow:hidden;height:0;margin-top:0!important;label:StyledExpandableContent;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdETyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIEFuZ2xlRG93bkljb24sXG4gIEFuZ2xlUmlnaHRJY29uLFxuICBDYXJkLFxuICBDaGVja2JveElucHV0LFxuICBDb2xsYXBzaWJsZU1vdGlvbixcbiAgR3JpZCxcbiAgSWNvbkJ1dHRvbixcbiAgU3BhY2luZ3MsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRm9ybWlrUHJvcHMgfSBmcm9tICdmb3JtaWsnXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQgeyBTZWxlY3RlZEdyb3VwRmllbGRzQ291bnRTdGFtcCB9IGZyb20gJy4vc2VsZWN0ZWQtZ3JvdXAtZmllbGRzLWNvdW50LXN0YW1wJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCwgRm9ybUdyb3VwLCBGb3JtVmFsdWVzIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgYXJlQWxsRmllbGRzQ2hlY2tlZCwgaXNBbnlGaWVsZENoZWNrZWQgfSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRm9ybUdyb3VwXG4gIGZvcm1pazogRm9ybWlrUHJvcHM8Rm9ybVZhbHVlcz5cbiAgaXNTZWFyY2hBY3RpdmU/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc1NlYXJjaEFjdGl2ZSxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsRmllbGRzQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gYXJlQWxsRmllbGRzQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCBpc0FueUZpZWxkSW5Hcm91cENoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGlzQW55RmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzOiBGaWVsZFtdLCBjaGVja2VkOiBib29sZWFuKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNTZWFyY2hBY3RpdmUgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAgLy8gUmVzZXQgY29sbGFwc2Ugc3RhdGUgd2hlbiBzZWFyY2ggaW5wdXQgYmVjb21lcyBhY3RpdmUvaW5hY3RpdmVcbiAgICAgIGtleT17YCR7aXNTZWFyY2hBY3RpdmV9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzU2VhcmNoQWN0aXZlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgdXBkYXRlRXhwYW5kZWRHcm91cHMoZ3JvdXAuZ3JvdXBOYW1lLCAhaXNPcGVuKVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHRvZ2dsZSgpXG4gICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgaWNvbj17aXNPcGVuID8gPEFuZ2xlRG93bkljb24gLz4gOiA8QW5nbGVSaWdodEljb24gLz59XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIlwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAgaXNJbmRldGVybWluYXRlPXtcbiAgICAgICAgICAgICAgICAgICAgIWFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ9e2FsbEZpZWxkc0NoZWNrZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtpc09wZW4gJiYgKFxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBbnlGaWVsZEluR3JvdXBDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzU2VhcmNoQWN0aXZlPXtpc1NlYXJjaEFjdGl2ZX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8U2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgZ3JvdXA9e2dyb3VwfSAvPn1cbiAgICAgICAgICAgIDwvPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICA8Lz5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKVxufVxuIl19 */",
2600
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
2601
+ };
2602
+ const StyledExpandableContent = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
2603
+ target: "e1igkh7t0"
2604
+ } : {
2605
+ target: "e1igkh7t0",
2606
+ label: "StyledExpandableContent"
2607
+ })(props => !props.isOpen && _ref$1, " ", props => !props.isOpen && props.showTopBorder && /*#__PURE__*/react.css("border-top:", uiKit.designTokens.borderWidth1, " solid ", uiKit.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledExpandableContent;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdETyIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIEFuZ2xlRG93bkljb24sXG4gIEFuZ2xlUmlnaHRJY29uLFxuICBDYXJkLFxuICBDaGVja2JveElucHV0LFxuICBDb2xsYXBzaWJsZU1vdGlvbixcbiAgR3JpZCxcbiAgSWNvbkJ1dHRvbixcbiAgU3BhY2luZ3MsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRm9ybWlrUHJvcHMgfSBmcm9tICdmb3JtaWsnXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQgeyBTZWxlY3RlZEdyb3VwRmllbGRzQ291bnRTdGFtcCB9IGZyb20gJy4vc2VsZWN0ZWQtZ3JvdXAtZmllbGRzLWNvdW50LXN0YW1wJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCwgRm9ybUdyb3VwLCBGb3JtVmFsdWVzIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgYXJlQWxsRmllbGRzQ2hlY2tlZCwgaXNBbnlGaWVsZENoZWNrZWQgfSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRm9ybUdyb3VwXG4gIGZvcm1pazogRm9ybWlrUHJvcHM8Rm9ybVZhbHVlcz5cbiAgaXNTZWFyY2hBY3RpdmU/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc1NlYXJjaEFjdGl2ZSxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsRmllbGRzQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gYXJlQWxsRmllbGRzQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCBpc0FueUZpZWxkSW5Hcm91cENoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGlzQW55RmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzOiBGaWVsZFtdLCBjaGVja2VkOiBib29sZWFuKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNTZWFyY2hBY3RpdmUgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAgLy8gUmVzZXQgY29sbGFwc2Ugc3RhdGUgd2hlbiBzZWFyY2ggaW5wdXQgYmVjb21lcyBhY3RpdmUvaW5hY3RpdmVcbiAgICAgIGtleT17YCR7aXNTZWFyY2hBY3RpdmV9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzU2VhcmNoQWN0aXZlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgdXBkYXRlRXhwYW5kZWRHcm91cHMoZ3JvdXAuZ3JvdXBOYW1lLCAhaXNPcGVuKVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHRvZ2dsZSgpXG4gICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgaWNvbj17aXNPcGVuID8gPEFuZ2xlRG93bkljb24gLz4gOiA8QW5nbGVSaWdodEljb24gLz59XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIlwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAgaXNJbmRldGVybWluYXRlPXtcbiAgICAgICAgICAgICAgICAgICAgIWFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ9e2FsbEZpZWxkc0NoZWNrZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtpc09wZW4gJiYgKFxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBbnlGaWVsZEluR3JvdXBDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzU2VhcmNoQWN0aXZlPXtpc1NlYXJjaEFjdGl2ZX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8U2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgZ3JvdXA9e2dyb3VwfSAvPn1cbiAgICAgICAgICAgIDwvPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICA8Lz5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKVxufVxuIl19 */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpZWxkLWdyb3VwLXNlY3Rpb24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZDRSIsImZpbGUiOiJmaWVsZC1ncm91cC1zZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIEFuZ2xlRG93bkljb24sXG4gIEFuZ2xlUmlnaHRJY29uLFxuICBDYXJkLFxuICBDaGVja2JveElucHV0LFxuICBDb2xsYXBzaWJsZU1vdGlvbixcbiAgR3JpZCxcbiAgSWNvbkJ1dHRvbixcbiAgU3BhY2luZ3MsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgRm9ybWlrUHJvcHMgfSBmcm9tICdmb3JtaWsnXG5pbXBvcnQgZ2V0IGZyb20gJ2xvZGFzaC9nZXQnXG5pbXBvcnQgeyB1c2VFeHBvcnRGaWVsZFNlbGVjdGlvbkNvbnRleHQgfSBmcm9tICcuL2V4cG9ydC1maWVsZC1zZWxlY3Rpb24tcHJvdmlkZXInXG5pbXBvcnQgeyBGaWVsZFNlY3Rpb24gfSBmcm9tICcuL2ZpZWxkLXNlY3Rpb24nXG5pbXBvcnQgeyBTZWxlY3RlZEdyb3VwRmllbGRzQ291bnRTdGFtcCB9IGZyb20gJy4vc2VsZWN0ZWQtZ3JvdXAtZmllbGRzLWNvdW50LXN0YW1wJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCwgRm9ybUdyb3VwLCBGb3JtVmFsdWVzIH0gZnJvbSAnLi4vLi4vQHR5cGVzJ1xuaW1wb3J0IHsgYXJlQWxsRmllbGRzQ2hlY2tlZCwgaXNBbnlGaWVsZENoZWNrZWQgfSBmcm9tICcuLi8uLi9AdXRpbHMnXG5cbmNvbnN0IFN0eWxlZEdyb3VwQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGJvcmRlci1yYWRpdXM6IDA7XG4gICR7KHByb3BzKSA9PlxuICAgIHByb3BzLnNob3dUb3BCb3JkZXIgJiZcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgICBgfVxuYFxuY29uc3QgU3R5bGVkRmllbGRzQ2FyZCA9IHN0eWxlZChDYXJkKTx7IHNob3dUb3BCb3JkZXI/OiBib29sZWFuIH0+YFxuICBib3JkZXItcmFkaXVzOiAwO1xuICAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5zaG93VG9wQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcDogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSBzb2xpZFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEV4cGFuZGFibGVDb250ZW50ID0gc3R5bGVkLmRpdjx7XG4gIGlzT3Blbj86IGJvb2xlYW5cbiAgc2hvd1RvcEJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgY3NzYFxuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGhlaWdodDogMDtcbiAgICAgIG1hcmdpbi10b3A6IDAgIWltcG9ydGFudDtcbiAgICBgfVxuICAkeyhwcm9wcykgPT5cbiAgICAhcHJvcHMuaXNPcGVuICYmXG4gICAgcHJvcHMuc2hvd1RvcEJvcmRlciAmJlxuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3A6ICR7ZGVzaWduVG9rZW5zLmJvcmRlcldpZHRoMX0gc29saWRcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICAgIGB9XG5gXG5cbnR5cGUgRmllbGRHcm91cFNlY3Rpb25Qcm9wcyA9IHtcbiAgaW5kZXg6IG51bWJlclxuICBncm91cDogRm9ybUdyb3VwXG4gIGZvcm1pazogRm9ybWlrUHJvcHM8Rm9ybVZhbHVlcz5cbiAgaXNTZWFyY2hBY3RpdmU/OiBib29sZWFuXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEdyb3VwU2VjdGlvbiA9ICh7XG4gIGdyb3VwLFxuICBpbmRleCxcbiAgZm9ybWlrLFxuICBpc1NlYXJjaEFjdGl2ZSxcbn06IEZpZWxkR3JvdXBTZWN0aW9uUHJvcHMpID0+IHtcbiAgY29uc3QgYWxsRmllbGRzQ2hlY2tlZCA9IHVzZU1lbW8oXG4gICAgKCkgPT4gYXJlQWxsRmllbGRzQ2hlY2tlZChncm91cC5maWVsZHMpLFxuICAgIFtncm91cC5maWVsZHNdXG4gIClcblxuICBjb25zdCBpc0FueUZpZWxkSW5Hcm91cENoZWNrZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IGlzQW55RmllbGRDaGVja2VkKGdyb3VwLmZpZWxkcyksXG4gICAgW2dyb3VwLmZpZWxkc11cbiAgKVxuXG4gIGNvbnN0IHsgdXBkYXRlRXhwYW5kZWRHcm91cHMgfSA9IHVzZUV4cG9ydEZpZWxkU2VsZWN0aW9uQ29udGV4dCgpXG5cbiAgY29uc3QgcGFyZW50S2V5ID0gYGdyb3Vwc1ske2luZGV4fV1gXG5cbiAgY29uc3QgaGFuZGxlQ2hhbmdlQWxsRmllbGRzID0gKGUpID0+IHtcbiAgICBjb25zdCBpdGVtID0gZ2V0KGZvcm1pay52YWx1ZXMsIHBhcmVudEtleSlcbiAgICBmdW5jdGlvbiB1cGRhdGVBbGxGaWVsZHMoZmllbGRzOiBGaWVsZFtdLCBjaGVja2VkOiBib29sZWFuKSB7XG4gICAgICByZXR1cm4gZmllbGRzLm1hcCgoZmllbGQpID0+IHtcbiAgICAgICAgaWYgKGZpZWxkLmZpZWxkcykge1xuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICAgIGZpZWxkczogdXBkYXRlQWxsRmllbGRzKGZpZWxkLmZpZWxkcywgY2hlY2tlZCksXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGlmIChmaWVsZC5pc1JlcXVpcmVkKSByZXR1cm4gZmllbGRcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgICBpc0NoZWNrZWQ6IGNoZWNrZWQsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuXG4gICAgZm9ybWlrLnNldEZpZWxkVmFsdWUocGFyZW50S2V5LCB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgZmllbGRzOiB1cGRhdGVBbGxGaWVsZHMoaXRlbS5maWVsZHMsIGUudGFyZ2V0LmNoZWNrZWQpLFxuICAgIH0pXG4gIH1cblxuICBpZiAoZ3JvdXAuaXNIaWRkZW4pIHJldHVybiBudWxsXG5cbiAgcmV0dXJuIChcbiAgICA8Q29sbGFwc2libGVNb3Rpb25cbiAgICAgIGlzRGVmYXVsdENsb3NlZD17aXNTZWFyY2hBY3RpdmUgPyBmYWxzZSA6ICFncm91cC5pc0V4cGFuZGVkfVxuICAgICAgLy8gUmVzZXQgY29sbGFwc2Ugc3RhdGUgd2hlbiBzZWFyY2ggaW5wdXQgYmVjb21lcyBhY3RpdmUvaW5hY3RpdmVcbiAgICAgIGtleT17YCR7aXNTZWFyY2hBY3RpdmV9YH1cbiAgICA+XG4gICAgICB7KHsgaXNPcGVuLCB0b2dnbGUsIHJlZ2lzdGVyQ29udGVudE5vZGUgfSkgPT4gKFxuICAgICAgICA8PlxuICAgICAgICAgIDxHcmlkLkl0ZW0+XG4gICAgICAgICAgICA8U3R5bGVkR3JvdXBDYXJkXG4gICAgICAgICAgICAgIHR5cGU9XCJmbGF0XCJcbiAgICAgICAgICAgICAgaW5zZXRTY2FsZT1cIm1cIlxuICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXtpbmRleCA+IDB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJzXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICAgIDxJY29uQnV0dG9uXG4gICAgICAgICAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIWlzU2VhcmNoQWN0aXZlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgdXBkYXRlRXhwYW5kZWRHcm91cHMoZ3JvdXAuZ3JvdXBOYW1lLCAhaXNPcGVuKVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHRvZ2dsZSgpXG4gICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgaWNvbj17aXNPcGVuID8gPEFuZ2xlRG93bkljb24gLz4gOiA8QW5nbGVSaWdodEljb24gLz59XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIlwiXG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICA8Q2hlY2tib3hJbnB1dFxuICAgICAgICAgICAgICAgICAgaXNJbmRldGVybWluYXRlPXtcbiAgICAgICAgICAgICAgICAgICAgIWFsbEZpZWxkc0NoZWNrZWQgJiYgaXNBbnlGaWVsZEluR3JvdXBDaGVja2VkXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICBpc0NoZWNrZWQ9e2FsbEZpZWxkc0NoZWNrZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlQWxsRmllbGRzfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtncm91cC5ncm91cExhYmVsfVxuICAgICAgICAgICAgICAgIDwvQ2hlY2tib3hJbnB1dD5cbiAgICAgICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgICAgICA8L1N0eWxlZEdyb3VwQ2FyZD5cbiAgICAgICAgICA8L0dyaWQuSXRlbT5cbiAgICAgICAgICA8R3JpZC5JdGVtPlxuICAgICAgICAgICAgPD5cbiAgICAgICAgICAgICAgPFN0eWxlZEV4cGFuZGFibGVDb250ZW50XG4gICAgICAgICAgICAgICAgcmVmPXtyZWdpc3RlckNvbnRlbnROb2RlfVxuICAgICAgICAgICAgICAgIGlzT3Blbj17aXNPcGVufVxuICAgICAgICAgICAgICAgIHNob3dUb3BCb3JkZXI9e2luZGV4ID4gMH1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxTdHlsZWRGaWVsZHNDYXJkXG4gICAgICAgICAgICAgICAgICB0eXBlPVwiZmxhdFwiXG4gICAgICAgICAgICAgICAgICBpbnNldFNjYWxlPVwibVwiXG4gICAgICAgICAgICAgICAgICBzaG93VG9wQm9yZGVyPXt0cnVlfVxuICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgIHtpc09wZW4gJiYgKFxuICAgICAgICAgICAgICAgICAgICA8RmllbGRTZWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgZmllbGRzPXtncm91cC5maWVsZHN9XG4gICAgICAgICAgICAgICAgICAgICAgZm9ybWlrPXtmb3JtaWt9XG4gICAgICAgICAgICAgICAgICAgICAgcGFyZW50S2V5cz17W3BhcmVudEtleV19XG4gICAgICAgICAgICAgICAgICAgICAgaXNBbnlTaWJsaW5nQ2hlY2tlZD17aXNBbnlGaWVsZEluR3JvdXBDaGVja2VkfVxuICAgICAgICAgICAgICAgICAgICAgIGdyb3VwTmFtZT17Z3JvdXAuZ3JvdXBOYW1lfVxuICAgICAgICAgICAgICAgICAgICAgIGlzU2VhcmNoQWN0aXZlPXtpc1NlYXJjaEFjdGl2ZX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgICAgPC9TdHlsZWRGaWVsZHNDYXJkPlxuICAgICAgICAgICAgICA8L1N0eWxlZEV4cGFuZGFibGVDb250ZW50PlxuICAgICAgICAgICAgICB7IWlzT3BlbiAmJiA8U2VsZWN0ZWRHcm91cEZpZWxkc0NvdW50U3RhbXAgZ3JvdXA9e2dyb3VwfSAvPn1cbiAgICAgICAgICAgIDwvPlxuICAgICAgICAgIDwvR3JpZC5JdGVtPlxuICAgICAgICA8Lz5cbiAgICAgICl9XG4gICAgPC9Db2xsYXBzaWJsZU1vdGlvbj5cbiAgKVxufVxuIl19 */"));
2608
+ const FieldGroupSection = _ref2 => {
2609
+ let group = _ref2.group,
2610
+ index = _ref2.index,
2611
+ formik = _ref2.formik,
2612
+ isSearchActive = _ref2.isSearchActive;
2613
+ const allFieldsChecked = React.useMemo(() => areAllFieldsChecked(group.fields), [group.fields]);
2614
+ const isAnyFieldInGroupChecked = React.useMemo(() => isAnyFieldChecked(group.fields), [group.fields]);
2615
+ const _useExportFieldSelect = useExportFieldSelectionContext(),
2616
+ updateExpandedGroups = _useExportFieldSelect.updateExpandedGroups;
2617
+ const parentKey = `groups[${index}]`;
2618
+ const handleChangeAllFields = e => {
2619
+ const item = get__default["default"](_valuesInstanceProperty__default["default"](formik), parentKey);
2620
+ function updateAllFields(fields, checked) {
2621
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
2622
+ if (field.fields) {
2623
+ return _objectSpread$5(_objectSpread$5({}, field), {}, {
2624
+ fields: updateAllFields(field.fields, checked)
2625
+ });
2626
+ }
2627
+ if (field.isRequired) return field;
2628
+ return _objectSpread$5(_objectSpread$5({}, field), {}, {
2629
+ isChecked: checked
2630
+ });
2631
+ });
2632
+ }
2633
+ formik.setFieldValue(parentKey, _objectSpread$5(_objectSpread$5({}, item), {}, {
2634
+ fields: updateAllFields(item.fields, e.target.checked)
2635
+ }));
2636
+ };
2637
+ if (group.isHidden) return null;
2638
+ return jsxRuntime.jsx(uiKit.CollapsibleMotion, {
2639
+ isDefaultClosed: isSearchActive ? false : !group.isExpanded
2640
+ // Reset collapse state when search input becomes active/inactive
2641
+ ,
2642
+ children: _ref3 => {
2643
+ let isOpen = _ref3.isOpen,
2644
+ toggle = _ref3.toggle,
2645
+ registerContentNode = _ref3.registerContentNode;
2646
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
2647
+ children: [jsxRuntime.jsx(uiKit.Grid.Item, {
2648
+ children: jsxRuntime.jsx(StyledGroupCard, {
2649
+ type: "flat",
2650
+ insetScale: "m",
2651
+ showTopBorder: index > 0,
2652
+ children: jsxRuntime.jsxs(uiKit.Spacings.Inline, {
2653
+ scale: "s",
2654
+ alignItems: "center",
2655
+ children: [jsxRuntime.jsx(uiKit.IconButton, {
2656
+ size: "20",
2657
+ onClick: () => {
2658
+ if (!isSearchActive) {
2659
+ updateExpandedGroups(group.groupName, !isOpen);
2660
+ }
2661
+ toggle();
2662
+ },
2663
+ icon: isOpen ? jsxRuntime.jsx(uiKit.AngleDownIcon, {}) : jsxRuntime.jsx(uiKit.AngleRightIcon, {}),
2664
+ label: ""
2665
+ }), jsxRuntime.jsx(uiKit.CheckboxInput, {
2666
+ isIndeterminate: !allFieldsChecked && isAnyFieldInGroupChecked,
2667
+ isChecked: allFieldsChecked,
2668
+ onChange: handleChangeAllFields,
2669
+ children: group.groupLabel
2670
+ })]
2671
+ })
2672
+ })
2673
+ }), jsxRuntime.jsx(uiKit.Grid.Item, {
2674
+ children: jsxRuntime.jsxs(jsxRuntime.Fragment, {
2675
+ children: [jsxRuntime.jsx(StyledExpandableContent, {
2676
+ ref: registerContentNode,
2677
+ isOpen: isOpen,
2678
+ showTopBorder: index > 0,
2679
+ children: jsxRuntime.jsx(StyledFieldsCard, {
2680
+ type: "flat",
2681
+ insetScale: "m",
2682
+ showTopBorder: true,
2683
+ children: isOpen && jsxRuntime.jsx(FieldSection, {
2684
+ fields: group.fields,
2685
+ formik: formik,
2686
+ parentKeys: [parentKey],
2687
+ isAnySiblingChecked: isAnyFieldInGroupChecked,
2688
+ groupName: group.groupName,
2689
+ isSearchActive: isSearchActive
2690
+ })
2691
+ })
2692
+ }), !isOpen && jsxRuntime.jsx(SelectedGroupFieldsCountStamp, {
2693
+ group: group
2694
+ })]
2695
+ })
2696
+ })]
2697
+ });
2698
+ }
2699
+ }, `${isSearchActive}`);
2700
+ };
2701
+
2702
+ 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)."; }
2703
+ var _ref = process.env.NODE_ENV === "production" ? {
2704
+ name: "ti75j2",
2705
+ styles: "margin:0"
2706
+ } : {
2707
+ name: "ozey8m-NoSearchResults",
2708
+ styles: "margin:0;label:NoSearchResults;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
2709
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
2710
+ };
2711
+ const NoSearchResults = () => {
2712
+ return jsxRuntime.jsxs(uiKit.Card, {
2713
+ insetScale: "xl",
2714
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2715
+ scale: "s",
2716
+ children: [jsxRuntime.jsx(uiKit.Text.Body, {
2717
+ fontWeight: "medium",
2718
+ intlMessage: messages.thereAreNoResults
2719
+ }), jsxRuntime.jsx(uiKit.Text.Body, {
2720
+ intlMessage: messages.suggestions
2721
+ })]
2722
+ }), jsxRuntime.jsxs("ul", {
2723
+ css: _ref,
2724
+ children: [jsxRuntime.jsx("li", {
2725
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2726
+ intlMessage: messages.checkTheSpelling
2727
+ })
2728
+ }), jsxRuntime.jsx("li", {
2729
+ children: jsxRuntime.jsx(uiKit.Text.Body, {
2730
+ intlMessage: messages.searchByEnteringTheExactFieldName
2731
+ })
2732
+ })]
2733
+ })]
2734
+ });
2735
+ };
2736
+
2737
+ 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; }
2738
+ function _objectSpread$4(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$4(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$4(Object(t))).call(_context8, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
2739
+ const totalSpacing = 56 +
2740
+ // MC header
2741
+ 32 * 2 + (
2742
+ // outer modal spacing
2743
+ 32 + 40) +
2744
+ // footer (dialog buttons + margin)
2745
+ 40 +
2746
+ // search input
2747
+ 24 +
2748
+ // search input padding
2749
+ 24 +
2750
+ // modal header
2751
+ 16 +
2752
+ // modal header margin
2753
+ 8 + (
2754
+ // spacing between search input and grid card
2755
+ 16 * 2 + 8 * 2) +
2756
+ // modal paddings
2757
+ 26 +
2758
+ // "Select fields from a limited list" radio button height
2759
+ 26 +
2760
+ // "Select fields from an imported CSV template" radio button height
2761
+ 48 +
2762
+ // Inset paddings (top + bottom)
2763
+ 1 +
2764
+ // 1st Divider height
2765
+ 1 +
2766
+ // 2nd Divider height
2767
+ 8 + 8 +
2768
+ // Divider margins
2769
+ 86 +
2770
+ // locale selector
2771
+ 32 +
2772
+ // locales selector margin
2773
+ 4; // borders
2774
+
2775
+ const MIN_SEARCH_LENGTH = 3;
2776
+ const StyledGridCard = /*#__PURE__*/_styled__default["default"](uiKit.Card, process.env.NODE_ENV === "production" ? {
2777
+ target: "e1odwg620"
2778
+ } : {
2779
+ target: "e1odwg620",
2780
+ label: "StyledGridCard"
2781
+ })("max-height:calc(100vh - ", totalSpacing, "px);overflow:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selected-fields-form.tsx"],"names":[],"mappings":"AA4CmC","file":"selected-fields-form.tsx","sourcesContent":["import React from 'react'\nimport { useIntl } from 'react-intl'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport {\n  Card,\n  Grid,\n  Spacings,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport styled from '@emotion/styled'\nimport debounce from 'lodash/debounce'\nimport ExportFieldSelectionProvider from './export-field-selection-provider'\nimport { FieldGroupSection } from './field-group-section'\nimport { OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION } from '../../@constants'\nimport { useExportResourcesModalContext, useStorage } from '../../@hooks'\nimport { type FormField, type FormGroup } from '../../@types'\nimport { updateFieldDependenciesStatus } from '../../@utils'\nimport messages from '../../messages'\nimport { NoSearchResults } from '../no-search-results'\n\nconst totalSpacing =\n  56 + // MC header\n  32 * 2 + // outer modal spacing\n  (32 + 40) + // footer (dialog buttons + margin)\n  40 + // search input\n  24 + // search input padding\n  24 + // modal header\n  16 + // modal header margin\n  8 + // spacing between search input and grid card\n  (16 * 2 + 8 * 2) + // modal paddings\n  26 + // \"Select fields from a limited list\" radio button height\n  26 + // \"Select fields from an imported CSV template\" radio button height\n  48 + // Inset paddings (top + bottom)\n  1 + // 1st Divider height\n  1 + // 2nd Divider height\n  8 +\n  8 + // Divider margins\n  86 + // locale selector\n  32 + // locales selector margin\n  4 // borders\n\nconst MIN_SEARCH_LENGTH = 3\n\nconst StyledGridCard = styled(Card)`\n  max-height: calc(100vh - ${totalSpacing}px);\n  overflow: auto;\n`\n\nexport const SelectedFieldsForm = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { projectKey } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n  }))\n  const [_, setCachedSelectedGroups] = useStorage(\n    `${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`,\n    {}\n  )\n  const { formik, resourceType } = useExportResourcesModalContext()\n\n  const isSearchActive = fieldSearchTerm?.trim()?.length >= MIN_SEARCH_LENGTH\n\n  React.useEffect(() => {\n    updateFieldDependenciesStatus(formik)\n    const checkedFields = {}\n    function getCheckedFields(field: FormField, groupName: string) {\n      const fieldName = field.name ? `${groupName}.${field.name}` : groupName\n      if (field.fields) {\n        return field.fields.forEach((f) => getCheckedFields(f, fieldName))\n      }\n\n      checkedFields[fieldName] = field.isChecked\n    }\n    formik.values.groups.forEach((group: FormGroup) => {\n      group.fields.forEach((field: FormField) => {\n        getCheckedFields(field, group.groupName)\n      })\n    })\n\n    setCachedSelectedGroups({\n      [resourceType]: checkedFields,\n    })\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<FormGroup[]>(() => {\n    const updateFields = (\n      fields: FormField[],\n      parentMatches: boolean\n    ): FormField[] => {\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\n    if (!isSearchActive) return formik.values.groups\n\n    const updateGroups = (groups: FormGroup[]): FormGroup[] => {\n      return groups.map((group) => {\n        const updatedFields = updateFields(group.fields, false)\n        const isHidden = updatedFields.every((field) => field.isHidden)\n        return {\n          ...group,\n          fields: updatedFields,\n          isHidden,\n        }\n      })\n    }\n    return updateGroups(formik.values.groups)\n  }, [formik.values.groups, fieldSearchTerm, isSearchActive])\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 onSearchChangeDebounced = React.useMemo(\n    () => debounce(onSearchChange, 500),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <ExportFieldSelectionProvider resourceType={resourceType}>\n      <Spacings.Stack scale=\"s\">\n        <SearchTextInput\n          placeholder={intl.formatMessage(messages.searchForFields)}\n          value={fieldSearchTerm}\n          onChange={onSearchChangeDebounced}\n          onReset={onSearchReset}\n          // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory\n          onSubmit={() => {}}\n          id=\"export-fields-search\"\n        />\n        {hasResults ? (\n          <StyledGridCard insetScale=\"none\">\n            <Grid\n              gridAutoFlow=\"row\"\n              gridTemplateColumns={`calc(${designTokens.spacingL} + ${designTokens.constraint5} + ${designTokens.spacingL}) auto`}\n            >\n              {filteredGroups.map((group, index) => (\n                <FieldGroupSection\n                  key={group.groupName}\n                  group={group}\n                  index={index}\n                  formik={formik}\n                  isSearchActive={isSearchActive}\n                />\n              ))}\n            </Grid>\n          </StyledGridCard>\n        ) : (\n          <NoSearchResults />\n        )}\n      </Spacings.Stack>\n    </ExportFieldSelectionProvider>\n  )\n}\n"]} */"));
2782
+ const SelectedFieldsForm = () => {
2783
+ var _context, _context2;
2784
+ const intl = reactIntl.useIntl();
2785
+ const _React$useState = React__default["default"].useState(''),
2786
+ _React$useState2 = _slicedToArray(_React$useState, 2),
2787
+ fieldSearchTerm = _React$useState2[0],
2788
+ setFieldSearchTerm = _React$useState2[1];
2789
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
2790
+ projectKey: context.project?.key
2791
+ })),
2792
+ projectKey = _useApplicationContex.projectKey;
2793
+ const _useStorage = useStorage(`${projectKey}/${OPERATIONS_EXPORT_RESOURCES_MODAL_SELECTION}`, {}),
2794
+ _useStorage2 = _slicedToArray(_useStorage, 2);
2795
+ _useStorage2[0];
2796
+ const setCachedSelectedGroups = _useStorage2[1];
2797
+ const _useExportResourcesMo = useExportResourcesModalContext(),
2798
+ formik = _useExportResourcesMo.formik,
2799
+ resourceType = _useExportResourcesMo.resourceType;
2800
+ const isSearchActive = ((_context = fieldSearchTerm) == null ? void 0 : _bindInstanceProperty__default["default"](_context2 = Function.call).call(_context2, _trimInstanceProperty__default["default"](_context), _context))?.()?.length >= MIN_SEARCH_LENGTH;
2801
+ React__default["default"].useEffect(() => {
2802
+ var _context4;
2803
+ updateFieldDependenciesStatus(formik);
2804
+ const checkedFields = {};
2805
+ function getCheckedFields(field, groupName) {
2806
+ const fieldName = field.name ? `${groupName}.${field.name}` : groupName;
2807
+ if (field.fields) {
2808
+ var _context3;
2809
+ return _forEachInstanceProperty__default["default"](_context3 = field.fields).call(_context3, f => getCheckedFields(f, fieldName));
2810
+ }
2811
+ checkedFields[fieldName] = field.isChecked;
2812
+ }
2813
+ _forEachInstanceProperty__default["default"](_context4 = _valuesInstanceProperty__default["default"](formik).groups).call(_context4, group => {
2814
+ var _context5;
2815
+ _forEachInstanceProperty__default["default"](_context5 = group.fields).call(_context5, field => {
2816
+ getCheckedFields(field, group.groupName);
2817
+ });
2818
+ });
2819
+ setCachedSelectedGroups({
2820
+ [resourceType]: checkedFields
2821
+ });
2822
+ // eslint-disable-next-line react-hooks/exhaustive-deps
2823
+ }, [_valuesInstanceProperty__default["default"](formik).groups]);
2824
+ // adds `isHidden` property to each field based on search term
2825
+ const filteredGroups = React__default["default"].useMemo(() => {
2826
+ const updateFields = (fields, parentMatches) => {
2827
+ return _mapInstanceProperty__default["default"](fields).call(fields, field => {
2828
+ var _context6;
2829
+ const matches = _includesInstanceProperty__default["default"](_context6 = field.label.toLowerCase()).call(_context6, fieldSearchTerm.toLowerCase());
2830
+ let isHidden = !matches && !parentMatches;
2831
+ if (field.fields) {
2832
+ const updatedFields = updateFields(field.fields, matches);
2833
+ isHidden = isHidden && _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, f => f.isHidden);
2834
+ field = _objectSpread$4(_objectSpread$4({}, field), {}, {
2835
+ fields: updatedFields
2836
+ });
2837
+ }
2838
+ return _objectSpread$4(_objectSpread$4({}, field), {}, {
2839
+ isHidden
2840
+ });
2841
+ });
2842
+ };
2843
+ if (!isSearchActive) return _valuesInstanceProperty__default["default"](formik).groups;
2844
+ const updateGroups = groups => {
2845
+ return _mapInstanceProperty__default["default"](groups).call(groups, group => {
2846
+ const updatedFields = updateFields(group.fields, false);
2847
+ const isHidden = _everyInstanceProperty__default["default"](updatedFields).call(updatedFields, field => field.isHidden);
2848
+ return _objectSpread$4(_objectSpread$4({}, group), {}, {
2849
+ fields: updatedFields,
2850
+ isHidden
2851
+ });
2852
+ });
2853
+ };
2854
+ return updateGroups(_valuesInstanceProperty__default["default"](formik).groups);
2855
+ }, [_valuesInstanceProperty__default["default"](formik).groups, fieldSearchTerm, isSearchActive]);
2856
+ const onSearchChange = React__default["default"].useCallback(event => {
2857
+ setFieldSearchTerm(event.target.value);
2858
+ }, [setFieldSearchTerm]);
2859
+ const hasResults = Boolean(_findInstanceProperty__default["default"](filteredGroups).call(filteredGroups, group => !group.isHidden));
2860
+ const onSearchChangeDebounced = React__default["default"].useMemo(() => debounce__default["default"](onSearchChange, 500), [onSearchChange]);
2861
+ const onSearchReset = () => {
2862
+ setFieldSearchTerm('');
2863
+ };
2864
+ return jsxRuntime.jsx(ExportFieldSelectionProvider, {
2865
+ resourceType: resourceType,
2866
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2867
+ scale: "s",
2868
+ children: [jsxRuntime.jsx(uiKit.SearchTextInput, {
2869
+ placeholder: intl.formatMessage(messages.searchForFields),
2870
+ value: fieldSearchTerm,
2871
+ onChange: onSearchChangeDebounced,
2872
+ onReset: onSearchReset
2873
+ // TODO: `SearchTextInput` props to be improved. The `onSubmit` callback shouldn't be mandatory
2874
+ ,
2875
+ onSubmit: () => {},
2876
+ id: "export-fields-search"
2877
+ }), hasResults ? jsxRuntime.jsx(StyledGridCard, {
2878
+ insetScale: "none",
2879
+ children: jsxRuntime.jsx(uiKit.Grid, {
2880
+ gridAutoFlow: "row",
2881
+ gridTemplateColumns: `calc(${uiKit.designTokens.spacingL} + ${uiKit.designTokens.constraint5} + ${uiKit.designTokens.spacingL}) auto`,
2882
+ children: _mapInstanceProperty__default["default"](filteredGroups).call(filteredGroups, (group, index) => jsxRuntime.jsx(FieldGroupSection, {
2883
+ group: group,
2884
+ index: index,
2885
+ formik: formik,
2886
+ isSearchActive: isSearchActive
2887
+ }, group.groupName))
2888
+ })
2889
+ }) : jsxRuntime.jsx(NoSearchResults, {})]
2890
+ })
2891
+ });
2892
+ };
2893
+
2894
+ const Divider = /*#__PURE__*/_styled__default["default"]("hr", process.env.NODE_ENV === "production" ? {
2895
+ target: "e1flfma0"
2896
+ } : {
2897
+ target: "e1flfma0",
2898
+ label: "Divider"
2899
+ })("display:block;height:1px;border:0;border-top:1px solid ", uiKit.designTokens.colorNeutral90, ";margin:0;padding:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRpdmlkZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdnQyIsImZpbGUiOiJkaXZpZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3VpLWtpdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5leHBvcnQgY29uc3QgRGl2aWRlciA9IHN0eWxlZC5ocmBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMXB4O1xuICBib3JkZXI6IDA7XG4gIGJvcmRlci10b3A6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbmBcbiJdfQ== */"));
2900
+
2901
+ const ExportFieldsSelectionStep = () => {
2902
+ const intl = reactIntl.useIntl();
2903
+ const _useExportResourcesMo = useExportResourcesModalContext(),
2904
+ formik = _useExportResourcesMo.formik,
2905
+ setCurrentStep = _useExportResourcesMo.setCurrentStep,
2906
+ onClose = _useExportResourcesMo.onClose,
2907
+ resourceType = _useExportResourcesMo.resourceType,
2908
+ fieldSelectionMode = _useExportResourcesMo.fieldSelectionMode,
2909
+ setFieldSelectionMode = _useExportResourcesMo.setFieldSelectionMode,
2910
+ setLocaleOption = _useExportResourcesMo.setLocaleOption;
2911
+ const shouldDisableImportedCsvTemplateOption = _valuesInstanceProperty__default["default"](formik).outputFormat === OUTPUT_FORMATS.JSON;
2912
+ const isUsingImportedCsvTemplate = fieldSelectionMode === 'imported-csv-template';
2913
+ const handleFieldSelectionModeChange = event => {
2914
+ const newFieldSelectionMode = event.target.value;
2915
+ setFieldSelectionMode(newFieldSelectionMode);
2916
+ if (newFieldSelectionMode !== 'imported-csv-template') {
2917
+ setLocaleOption(LocaleOption.Selected);
2918
+ }
2919
+ };
2920
+ return jsxRuntime.jsx(applicationComponents.FormDialog, {
2921
+ isOpen: true,
2922
+ title: `${intl.formatMessage(messages.stepCount, {
2923
+ currentStep: 2,
2924
+ totalSteps: TOTAL_STEPS
2925
+ })}: ${intl.formatMessage(messages.selectFieldsToExport)}`,
2926
+ labelPrimary: `${intl.formatMessage(messages.stepNumber, {
2927
+ stepNumber: 3
2928
+ })}: ${intl.formatMessage(messages.confirmSelection)}`,
2929
+ iconLeftPrimaryButton: jsxRuntime.jsx(uiKit.AngleRightIcon, {}),
2930
+ onPrimaryButtonClick: formik.submitForm,
2931
+ isPrimaryButtonDisabled: !formik.isValid,
2932
+ labelSecondary: intl.formatMessage(messages.back),
2933
+ onSecondaryButtonClick: () => setCurrentStep(Step.FileSettings),
2934
+ onClose: onClose,
2935
+ size: 16,
2936
+ dataAttributesPrimaryButton: {
2937
+ 'data-tracking-target': `${resourceType}_export-start_export_button`
2938
+ },
2939
+ children: jsxRuntime.jsx(fullstory.Masking.Unmask, {
2940
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2941
+ scale: "xl",
2942
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2943
+ scale: isUsingImportedCsvTemplate ? 'l' : 'xs',
2944
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2945
+ children: [jsxRuntime.jsx(uiKit.RadioInput.Option, {
2946
+ value: FIELD_SELECTION_MODES.SELECTED_FIELDS,
2947
+ isChecked: fieldSelectionMode === FIELD_SELECTION_MODES.SELECTED_FIELDS,
2948
+ onChange: handleFieldSelectionModeChange,
2949
+ children: intl.formatMessage(messages.selectFieldsFromLimitedList)
2950
+ }), jsxRuntime.jsx(Divider, {}), fieldSelectionMode === FIELD_SELECTION_MODES.SELECTED_FIELDS && jsxRuntime.jsx(uiKit.Spacings.Inset, {
2951
+ scale: "l",
2952
+ children: jsxRuntime.jsx(SelectedFieldsForm, {})
2953
+ })]
2954
+ }), jsxRuntime.jsxs(uiKit.Spacings.Stack, {
2955
+ children: [jsxRuntime.jsx(uiKit.RadioInput.Option, {
2956
+ isDisabled: shouldDisableImportedCsvTemplateOption,
2957
+ value: FIELD_SELECTION_MODES.IMPORTED_CSV_TEMPLATE,
2958
+ isChecked: fieldSelectionMode === FIELD_SELECTION_MODES.IMPORTED_CSV_TEMPLATE,
2959
+ onChange: handleFieldSelectionModeChange,
2960
+ children: intl.formatMessage(messages.selectFieldsFromImportedCSV)
2961
+ }), jsxRuntime.jsx(Divider, {}), fieldSelectionMode === FIELD_SELECTION_MODES.IMPORTED_CSV_TEMPLATE && jsxRuntime.jsx(uiKit.Spacings.Inset, {
2962
+ scale: "l",
2963
+ children: jsxRuntime.jsx(ImportedCsvTemplateFieldsForm, {})
2964
+ })]
2965
+ })]
2966
+ }), jsxRuntime.jsx(ExportLocaleSelectField, {})]
2967
+ })
2968
+ })
2969
+ });
2970
+ };
2971
+
2972
+ const ExportResourcesContext = /*#__PURE__*/React.createContext();
2973
+
2974
+ const _excluded$1 = ["children"];
2975
+ const ExportResourcesProvider = _ref => {
2976
+ let children = _ref.children,
2977
+ props = _objectWithoutProperties(_ref, _excluded$1);
2978
+ const initialValues = useInitialValues(props);
2979
+ const _React$useState = React__default["default"].useState(Step.FileSettings),
2980
+ _React$useState2 = _slicedToArray(_React$useState, 2),
2981
+ currentStep = _React$useState2[0],
2982
+ setCurrentStep = _React$useState2[1];
2983
+ const _React$useState3 = React__default["default"].useState(() => getInitialExportType({
2984
+ selectedResourceIds: props.selectedResourceIds,
2985
+ filters: props.filters
2986
+ })),
2987
+ _React$useState4 = _slicedToArray(_React$useState3, 2),
2988
+ exportType = _React$useState4[0],
2989
+ setExportType = _React$useState4[1];
2990
+ const _React$useState5 = React__default["default"].useState(LocaleOption.Selected),
2991
+ _React$useState6 = _slicedToArray(_React$useState5, 2),
2992
+ localeOption = _React$useState6[0],
2993
+ setLocaleOption = _React$useState6[1];
2994
+ const _React$useState7 = React__default["default"].useState('selected-fields'),
2995
+ _React$useState8 = _slicedToArray(_React$useState7, 2),
2996
+ fieldSelectionMode = _React$useState8[0],
2997
+ setFieldSelectionMode = _React$useState8[1];
2998
+ const _React$useState9 = React__default["default"].useState([]),
2999
+ _React$useState0 = _slicedToArray(_React$useState9, 2),
3000
+ importedHeaders = _React$useState0[0],
3001
+ setImportedHeaders = _React$useState0[1];
3002
+ const _React$useState1 = React__default["default"].useState([]),
3003
+ _React$useState10 = _slicedToArray(_React$useState1, 2),
3004
+ validationErrors = _React$useState10[0],
3005
+ setValidationErrors = _React$useState10[1];
3006
+ const _useStartExportOperat = useStartExportOperation(props),
3007
+ startExportOperation = _useStartExportOperat.startExportOperation;
3008
+ const _useValidateExportOpe = useValidateExportOperation(),
3009
+ validateExport = _useValidateExportOpe.validateExport;
3010
+ const formik$1 = formik.useFormik({
3011
+ initialValues,
3012
+ validate: values => validate({
3013
+ values,
3014
+ step: currentStep,
3015
+ fieldSelectionMode,
3016
+ importedHeaders,
3017
+ exportType
3018
+ }),
3019
+ onSubmit: async values => {
3020
+ if (currentStep === Step.FileSettings) {
3021
+ if (exportType === EXPORT_TYPES.QUERY_PREDICATE) {
3022
+ const validationResult = await validateExport({
3023
+ fileName: values.fileName,
3024
+ outputFormat: values.outputFormat,
3025
+ resourceType: props.resourceType,
3026
+ fields: extractFieldNamesFromGroups(values.groups, props.fieldOrder),
3027
+ locales: values.locales,
3028
+ queryPredicate: values.queryPredicate
3029
+ });
3030
+ if (validationResult?.invalidQueryPredicate) {
3031
+ formik$1.setFieldError('queryPredicate', 'invalidInput');
3032
+ return;
3033
+ }
3034
+ if (validationResult?.noResourcesToExportForQueryPredicate) {
3035
+ formik$1.setFieldError('queryPredicate', 'noResourcesToExportForQueryPredicate');
3036
+ return;
3037
+ }
3038
+ }
3039
+ setCurrentStep(Step.FieldsSelection);
3040
+ } else if (currentStep === Step.FieldsSelection) {
3041
+ if (fieldSelectionMode !== 'imported-csv-template') {
3042
+ setCurrentStep(Step.ConfirmExport);
3043
+ return;
3044
+ }
3045
+ const isUsingImportedCsvLocales = localeOption === 'onlyLocalesFoundInCsvFile';
3046
+ const validationResult = await validateExport({
3047
+ fileName: values.fileName,
3048
+ outputFormat: values.outputFormat,
3049
+ resourceType: props.resourceType,
3050
+ fields: importedHeaders,
3051
+ locales: isUsingImportedCsvLocales ? undefined : values.locales,
3052
+ queryPredicate: values.queryPredicate
3053
+ });
3054
+ if (validationResult?.success) {
3055
+ setCurrentStep(Step.ConfirmExport);
3056
+ } else {
3057
+ setValidationErrors(validationResult?.validationErrors);
3058
+ setCurrentStep(Step.ValidationErrors);
3059
+ }
3060
+ } else {
3061
+ startExportOperation(values, exportType, fieldSelectionMode, localeOption, importedHeaders);
3062
+ }
3063
+ }
3064
+ });
3065
+ React__default["default"].useEffect(() => {
3066
+ formik$1.validateForm();
3067
+ }, [currentStep, fieldSelectionMode, importedHeaders, exportType]);
3068
+ return jsxRuntime.jsx(ExportResourcesContext.Provider, {
3069
+ value: {
3070
+ formik: formik$1,
3071
+ currentStep,
3072
+ setCurrentStep,
3073
+ onClose: props.onClose,
3074
+ resourceType: props.resourceType,
3075
+ exportType: exportType,
3076
+ totalResourcesCount: props.totalResourcesCount,
3077
+ selectedResourceIds: props.selectedResourceIds,
3078
+ hideExportSelectedResourcesOption: props.hideExportSelectedResourcesOption,
3079
+ showQueryPredicateOption: props.showQueryPredicateOption,
3080
+ filters: props.filters,
3081
+ hasFilters: areFiltersApplied(props.filters),
3082
+ setExportType,
3083
+ fieldSelectionMode,
3084
+ setFieldSelectionMode,
3085
+ localeOption,
3086
+ setLocaleOption,
3087
+ importedHeaders,
3088
+ setImportedHeaders,
3089
+ validationErrors
3090
+ },
3091
+ children: children
3092
+ });
3093
+ };
3094
+
3095
+ const ExportLogsLink = props => {
3096
+ return jsxRuntime.jsx(uiKit.Link, {
3097
+ to: `/${props.projectKey}/operations/export/logs`,
3098
+ tone: props.tone,
3099
+ children: props.msg
3100
+ }, "link");
3101
+ };
3102
+
3103
+ const DEFAULT_MAX_VISIBLE_FIELDS = 10;
3104
+ const FieldsPreview = _ref => {
3105
+ let previewGroupLabel = _ref.previewGroupLabel,
3106
+ fields = _ref.fields;
3107
+ const intl = reactIntl.useIntl();
3108
+ const _React$useState = React__default["default"].useState(false),
3109
+ _React$useState2 = _slicedToArray(_React$useState, 2),
3110
+ isExpanded = _React$useState2[0],
3111
+ setIsExpanded = _React$useState2[1];
3112
+ const hasMoreFields = fields.length > DEFAULT_MAX_VISIBLE_FIELDS;
3113
+ const visibleFields = isExpanded ? fields : _sliceInstanceProperty__default["default"](fields).call(fields, 0, DEFAULT_MAX_VISIBLE_FIELDS);
3114
+ return jsxRuntime.jsx(uiKit.Spacings.Stack, {
3115
+ children: jsxRuntime.jsxs(uiKit.TagList, {
3116
+ children: [previewGroupLabel && jsxRuntime.jsxs(uiKit.Text.Detail, {
3117
+ as: "span",
3118
+ fontWeight: "bold",
3119
+ children: [previewGroupLabel, ":"]
3120
+ }), _mapInstanceProperty__default["default"](visibleFields).call(visibleFields, (field, index) => jsxRuntime.jsx(uiKit.Stamp, {
3121
+ isCondensed: true,
3122
+ tone: "secondary",
3123
+ label: field
3124
+ }, index)), hasMoreFields && jsxRuntime.jsx(uiKit.FlatButton, {
3125
+ onClick: () => setIsExpanded(!isExpanded),
3126
+ icon: isExpanded ? jsxRuntime.jsx(uiKit.AngleUpIcon, {
3127
+ size: "small"
3128
+ }) : jsxRuntime.jsx(uiKit.AngleDownIcon, {
3129
+ size: "small"
3130
+ }),
3131
+ label: intl.formatMessage(isExpanded ? messages.showLess : messages.showAll)
3132
+ })]
3133
+ })
3134
+ });
3135
+ };
3136
+
3137
+ 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; }
3138
+ function _objectSpread$3(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$3(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$3(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
3139
+ const ExportConfirmationStep = () => {
3140
+ const intl = reactIntl.useIntl();
3141
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(applicationContext => ({
3142
+ projectKey: applicationContext.project?.key
3143
+ })),
3144
+ projectKey = _useApplicationContex.projectKey;
3145
+ const _useExportResourcesMo = useExportResourcesModalContext(),
3146
+ formik = _useExportResourcesMo.formik,
3147
+ fieldSelectionMode = _useExportResourcesMo.fieldSelectionMode,
3148
+ importedHeaders = _useExportResourcesMo.importedHeaders,
3149
+ localeOption = _useExportResourcesMo.localeOption,
3150
+ setCurrentStep = _useExportResourcesMo.setCurrentStep,
3151
+ onClose = _useExportResourcesMo.onClose;
3152
+ const groupsWithSelectedFields = getGroupsWithSelectedFields(_valuesInstanceProperty__default["default"](formik).groups);
3153
+ const isUsingImportedCsvTemplate = fieldSelectionMode === 'imported-csv-template';
3154
+ const isUsingImportedCsvLocales = localeOption === 'onlyLocalesFoundInCsvFile';
3155
+ const allSelectedFieldCount = isUsingImportedCsvTemplate ? importedHeaders.length : getAllSelectedFieldCount(_valuesInstanceProperty__default["default"](formik).groups);
3156
+ const returnToFieldsSelection = () => setCurrentStep(Step.FieldsSelection);
3157
+ return jsxRuntime.jsx(applicationComponents.FormDialog, {
3158
+ isOpen: true,
3159
+ title: `${intl.formatMessage(messages.stepCount, {
3160
+ currentStep: 3,
3161
+ totalSteps: TOTAL_STEPS
3162
+ })}: ${intl.formatMessage(messages.exportPreview)}`,
3163
+ labelPrimary: intl.formatMessage(messages.startExport),
3164
+ onPrimaryButtonClick: formik.submitForm,
3165
+ labelSecondary: intl.formatMessage(messages.selectDifferentFields),
3166
+ onSecondaryButtonClick: returnToFieldsSelection,
3167
+ onClose: onClose,
3168
+ size: 16,
3169
+ children: jsxRuntime.jsx(fullstory.Masking.Unmask, {
3170
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
3171
+ scale: "m",
3172
+ children: [jsxRuntime.jsx(uiKit.Card, {
3173
+ insetScale: "l",
3174
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
3175
+ children: [jsxRuntime.jsxs(uiKit.Spacings.Inline, {
3176
+ alignItems: "center",
3177
+ children: [jsxRuntime.jsx(uiKit.CheckBoldIcon, {
3178
+ size: "40",
3179
+ color: "success"
3180
+ }), isUsingImportedCsvLocales ? jsxRuntime.jsx(uiKit.Text.Body, {
3181
+ intlMessage: _objectSpread$3(_objectSpread$3({}, messages.fieldsToBeExported), {}, {
3182
+ values: {
3183
+ fieldCount: allSelectedFieldCount,
3184
+ b: msg => jsxRuntime.jsx("b", {
3185
+ children: msg
3186
+ }, crypto.randomUUID())
3187
+ }
3188
+ })
3189
+ }) : jsxRuntime.jsx(uiKit.Text.Body, {
3190
+ intlMessage: _objectSpread$3(_objectSpread$3({}, messages.fieldsToBeExportedInLanguages), {}, {
3191
+ values: {
3192
+ fieldCount: allSelectedFieldCount,
3193
+ languageCount: _valuesInstanceProperty__default["default"](formik).locales.length,
3194
+ b: msg => jsxRuntime.jsx("b", {
3195
+ children: msg
3196
+ }, crypto.randomUUID())
3197
+ }
3198
+ })
3199
+ })]
3200
+ }), isUsingImportedCsvTemplate ? jsxRuntime.jsx(FieldsPreview, {
3201
+ fields: importedHeaders
3202
+ }) : _mapInstanceProperty__default["default"](groupsWithSelectedFields).call(groupsWithSelectedFields, group => {
3203
+ const selectedFields = getSelectedFieldLabels(group);
3204
+ return jsxRuntime.jsx(FieldsPreview, {
3205
+ previewGroupLabel: group.previewGroupLabel,
3206
+ fields: selectedFields
3207
+ }, group.groupName);
3208
+ })]
3209
+ })
3210
+ }), jsxRuntime.jsx(uiKit.Text.Body, {
3211
+ intlMessage: _objectSpread$3(_objectSpread$3({}, messages.exportProcessMayTakeAWhile), {}, {
3212
+ values: {
3213
+ exportLogsLink: msg => jsxRuntime.jsx(ExportLogsLink, {
3214
+ projectKey: projectKey,
3215
+ tone: "secondary"
3216
+ // @ts-ignore the `msg` parameter type is not compatible with the `string` type
3217
+ ,
3218
+ msg: msg
3219
+ }, "export-logs-link"),
3220
+ operationsIcon: () => jsxRuntime.jsx(icons.OperationsIcon, {
3221
+ size: "40"
3222
+ }, "operations-icon")
3223
+ }
3224
+ })
3225
+ })]
3226
+ })
3227
+ })
3228
+ });
3229
+ };
3230
+
3231
+ 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; }
3232
+ function _objectSpread$2(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$2(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$2(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
3233
+ const getColumns = () => [{
3234
+ key: 'errorType',
3235
+ label: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.errorType)),
3236
+ width: 'max-content'
3237
+ }, {
3238
+ key: 'details',
3239
+ label: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$2({}, messages.details))
3240
+ }];
3241
+ const ErrorTable = props => {
3242
+ var _context;
3243
+ const intl = reactIntl.useIntl();
3244
+ const rows = _mapInstanceProperty__default["default"](_context = props.errors).call(_context, row => {
3245
+ const id = row.code === 'AttributeLevelMismatch' && row.originalErrors[0]?.actualLevel ? `${row.code}-${row.originalErrors[0].actualLevel}` : row.code;
3246
+ return _objectSpread$2(_objectSpread$2({}, row), {}, {
3247
+ id
3248
+ });
3249
+ });
3250
+ return jsxRuntime.jsx(uiKit.Spacings.Stack, {
3251
+ scale: "l",
3252
+ children: jsxRuntime.jsx(uiKit.DataTable, {
3253
+ verticalCellAlignment: "center",
3254
+ isCondensed: true,
3255
+ rows: rows,
3256
+ columns: getColumns(),
3257
+ itemRenderer: (item, column) => itemRenderer(item, column, intl)
3258
+ })
3259
+ });
3260
+ };
3261
+ function itemRenderer(item, column, intl) {
3262
+ var _context2;
3263
+ switch (column.key) {
3264
+ case 'errorType':
3265
+ return jsxRuntime.jsx(uiKit.Stamp, {
3266
+ isCondensed: true,
3267
+ label: getErrorTypeLabel(item.code, intl),
3268
+ tone: "critical"
3269
+ });
3270
+ case 'details':
3271
+ return jsxRuntime.jsxs(uiKit.Spacings.Stack, {
3272
+ scale: "xs",
3273
+ children: [jsxRuntime.jsx(uiKit.Text.Detail, {
3274
+ children: item.messageTitle
3275
+ }), jsxRuntime.jsx("ul", {
3276
+ style: {
3277
+ margin: 0,
3278
+ paddingLeft: uiKit.designTokens.spacingL
3279
+ },
3280
+ children: _mapInstanceProperty__default["default"](_context2 = item.fieldNames).call(_context2, (field, index) => jsxRuntime.jsx("li", {
3281
+ children: jsxRuntime.jsx(uiKit.Text.Detail, {
3282
+ children: field
3283
+ })
3284
+ }, index))
3285
+ })]
3286
+ });
3287
+ default:
3288
+ // eslint-disable-next-line no-console
3289
+ console.warn('Unknown column key', column.key);
3290
+ return null;
3291
+ }
3292
+ }
3293
+ function getErrorTypeLabel(errorCode, intl) {
3294
+ switch (errorCode) {
3295
+ case 'NotSupportedField':
3296
+ return intl.formatMessage(messages.notSupportedField);
3297
+ case 'DuplicateFields':
3298
+ return intl.formatMessage(messages.duplicateField);
3299
+ case 'LocalizedFieldWithoutLocale':
3300
+ return intl.formatMessage(messages.localizedFieldWithoutLocale);
3301
+ case 'AttributeDefinitionNotFound':
3302
+ return intl.formatMessage(messages.attributeDefinitionNotFound);
3303
+ case 'FieldDefinitionNotFound':
3304
+ return intl.formatMessage(messages.fieldDefinitionNotFound);
3305
+ case 'IncompleteField':
3306
+ return intl.formatMessage(messages.incompleteField);
3307
+ case 'AttributeLevelMismatch':
3308
+ return intl.formatMessage(messages.attributeLevelMismatch);
3309
+ default:
3310
+ return errorCode;
3311
+ }
3312
+ }
3313
+
3314
+ 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; }
3315
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(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$1(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
3316
+ const ExportValidationErrorsStep = () => {
3317
+ const intl = reactIntl.useIntl();
3318
+ const _useExportResourcesMo = useExportResourcesModalContext(),
3319
+ formik = _useExportResourcesMo.formik,
3320
+ setCurrentStep = _useExportResourcesMo.setCurrentStep,
3321
+ onClose = _useExportResourcesMo.onClose,
3322
+ validationErrors = _useExportResourcesMo.validationErrors,
3323
+ setImportedHeaders = _useExportResourcesMo.setImportedHeaders;
3324
+ const groupedErrors = groupFieldValidationErrors(validationErrors, intl);
3325
+ const returnToFieldsSelection = () => setCurrentStep(Step.FieldsSelection);
3326
+ const uploadDifferentCSV = () => {
3327
+ formik.setFieldValue('importedCsvTemplateFile', undefined);
3328
+ setImportedHeaders([]);
3329
+ setCurrentStep(Step.FieldsSelection);
3330
+ };
3331
+ return jsxRuntime.jsx(applicationComponents.FormDialog, {
3332
+ isOpen: true,
3333
+ "aria-label": intl.formatMessage(messages.csvUploadFailed),
3334
+ title: jsxRuntime.jsxs(uiKit.Spacings.Inline, {
3335
+ alignItems: "center",
3336
+ children: [jsxRuntime.jsx(icons.WarningIcon, {
3337
+ size: "20",
3338
+ color: "warning"
3339
+ }), jsxRuntime.jsx(uiKit.Text.Headline, {
3340
+ tone: "inherit",
3341
+ as: "h3",
3342
+ children: intl.formatMessage(messages.csvUploadFailed)
3343
+ })]
3344
+ }),
3345
+ labelPrimary: intl.formatMessage(messages.uploadDifferentCSV),
3346
+ iconLeftPrimaryButton: jsxRuntime.jsx(icons.ImportIcon, {}),
3347
+ onPrimaryButtonClick: uploadDifferentCSV,
3348
+ labelSecondary: intl.formatMessage(messages.backToPreviousStep),
3349
+ onSecondaryButtonClick: returnToFieldsSelection,
3350
+ onClose: onClose,
3351
+ size: 16,
3352
+ children: jsxRuntime.jsx(fullstory.Masking.Unmask, {
3353
+ children: jsxRuntime.jsxs(uiKit.Spacings.Stack, {
3354
+ scale: "m",
3355
+ children: [jsxRuntime.jsx(uiKit.Text.Body, {
3356
+ intlMessage: _objectSpread$1(_objectSpread$1({}, messages.uploadErrorsDetected), {}, {
3357
+ values: {
3358
+ total: intl.formatNumber(validationErrors.length),
3359
+ fileName: _valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile?.name,
3360
+ b: msg => jsxRuntime.jsx("b", {
3361
+ children: msg
3362
+ }, crypto.randomUUID()),
3363
+ templateLink: msg => jsxRuntime.jsx(uiKit.Link, {
3364
+ tone: "secondary",
3365
+ to: CSV_TEMPLATES_LINK,
3366
+ isExternal: true,
3367
+ children: msg
3368
+ }, "template-link"),
3369
+ documentationLink: msg => jsxRuntime.jsx(uiKit.Link, {
3370
+ tone: "secondary",
3371
+ to: EXPORT_DATA_DOCUMENTATION_LINK,
3372
+ isExternal: true,
3373
+ children: msg
3374
+ }, "documentation-link")
3375
+ }
3376
+ })
3377
+ }), jsxRuntime.jsx(ErrorTable, {
3378
+ errors: groupedErrors
3379
+ })]
3380
+ })
3381
+ })
3382
+ });
3383
+ };
3384
+
3385
+ const CurrentStep = () => {
3386
+ const _useExportResourcesMo = useExportResourcesModalContext(),
3387
+ currentStep = _useExportResourcesMo.currentStep;
3388
+ const steps = {
3389
+ [Step.FileSettings]: jsxRuntime.jsx(ExportFileSettingsStep, {}),
3390
+ [Step.FieldsSelection]: jsxRuntime.jsx(ExportFieldsSelectionStep, {}),
3391
+ [Step.ConfirmExport]: jsxRuntime.jsx(ExportConfirmationStep, {}),
3392
+ [Step.ValidationErrors]: jsxRuntime.jsx(ExportValidationErrorsStep, {})
3393
+ };
3394
+ return steps[currentStep] || null;
3395
+ };
3396
+
3397
+ function getDropArea(_ref) {
3398
+ let dropAreaState = _ref.dropAreaState,
3399
+ isFileDropped = _ref.isFileDropped,
3400
+ fileName = _ref.fileName,
3401
+ messages = _ref.messages;
3402
+ if (dropAreaState === 'file-dropped') {
3403
+ return jsxRuntime.jsx(operations.FileDroppedArea, {
3404
+ fileName: fileName,
3405
+ chooseFileLabel: messages.chooseFile
3406
+ });
3407
+ }
3408
+ if (dropAreaState === 'ready-for-drop') {
3409
+ return jsxRuntime.jsx(operations.EnabledDropArea, {
3410
+ dragAndDropText: messages.dragAndDropCSV,
3411
+ orText: messages.or,
3412
+ browseFileText: messages.browseFile
3413
+ });
3414
+ }
3415
+ if (dropAreaState === 'active-drag') {
3416
+ return jsxRuntime.jsx(operations.ActiveDragDropArea, {
3417
+ isFileDropped: isFileDropped,
3418
+ fileName: fileName,
3419
+ chooseFileLabel: messages.chooseFile,
3420
+ dragAndDropText: messages.dragAndDropCSV,
3421
+ orText: messages.or,
3422
+ browseFileText: messages.browseFile
3423
+ });
3424
+ }
3425
+ return fallbackDropArea(dropAreaState, messages);
3426
+ }
3427
+ function fallbackDropArea(_dropAreaState, messages) {
3428
+ return jsxRuntime.jsx(operations.EnabledDropArea, {
3429
+ dragAndDropText: messages.dragAndDropCSV,
3430
+ orText: messages.or,
3431
+ browseFileText: messages.browseFile
3432
+ });
3433
+ }
3434
+ function getDropAreaState(flags) {
3435
+ if (flags.isDragActive) {
3436
+ return 'active-drag';
3437
+ }
3438
+ if (flags.isReady) {
3439
+ return 'file-dropped';
3440
+ }
3441
+ return 'ready-for-drop';
3442
+ }
3443
+
3444
+ const FileDropArea = () => {
3445
+ const intl = reactIntl.useIntl();
3446
+ const _useExportResourcesMo = useExportResourcesModalContext(),
3447
+ formik = _useExportResourcesMo.formik,
3448
+ setImportedHeaders = _useExportResourcesMo.setImportedHeaders;
3449
+ const onDrop = React__default["default"].useCallback(async _ref => {
3450
+ let _ref2 = _slicedToArray(_ref, 1),
3451
+ file = _ref2[0];
3452
+ if (!file) return;
3453
+ formik.setFieldValue('importedCsvTemplateFile', file);
3454
+ const csvHeaders = await getCsvHeaders(file);
3455
+ setImportedHeaders(csvHeaders);
3456
+ }, [formik, setImportedHeaders]);
3457
+ const getState = React__default["default"].useCallback(isDragActive => getDropAreaState({
3458
+ isReady: Boolean(_valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile),
3459
+ isDragActive
3460
+ }), [_valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile]);
3461
+ return jsxRuntime.jsx(operations.FileDropArea, {
3462
+ onDrop: onDrop,
3463
+ accept: {
3464
+ 'text/csv': ['.csv']
3465
+ },
3466
+ getDropAreaState: getState,
3467
+ children: dropAreaState => getDropArea({
3468
+ dropAreaState,
3469
+ isFileDropped: Boolean(_valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile),
3470
+ fileName: _valuesInstanceProperty__default["default"](formik).importedCsvTemplateFile?.name,
3471
+ messages: {
3472
+ chooseFile: intl.formatMessage(messages.chooseFile),
3473
+ dragAndDropCSV: intl.formatMessage(messages.dragAndDropCSV),
3474
+ or: intl.formatMessage(messages.or),
3475
+ browseFile: intl.formatMessage(messages.browseFile)
3476
+ }
3477
+ })
3478
+ });
3479
+ };
3480
+
3481
+ const getChunkImport = locale => {
3482
+ const intlLocale = i18n.mapLocaleToIntlLocale(locale);
3483
+ switch (intlLocale) {
3484
+ case 'de':
3485
+ return Promise.resolve().then(function () { return require('./de-a435ef4d.cjs.dev.js'); });
3486
+ case 'es':
3487
+ return Promise.resolve().then(function () { return require('./es-1b83dac0.cjs.dev.js'); });
3488
+ case 'fr-FR':
3489
+ return Promise.resolve().then(function () { return require('./fr-FR-f0b84a66.cjs.dev.js'); });
3490
+ case 'ja':
3491
+ return Promise.resolve().then(function () { return require('./ja-9bd5f452.cjs.dev.js'); });
3492
+ case 'pt-BR':
3493
+ return Promise.resolve().then(function () { return require('./pt-BR-c6bf925c.cjs.dev.js'); });
3494
+ default:
3495
+ return Promise.resolve().then(function () { return require('./en-0aab5dde.cjs.dev.js'); });
3496
+ }
3497
+ };
3498
+ const loadMessages = async locale => {
3499
+ try {
3500
+ const chunkImport = await getChunkImport(locale);
3501
+ return i18n.parseChunkImport(chunkImport);
3502
+ } catch (error) {
3503
+ // eslint-disable-next-line no-console
3504
+ console.warn(`Something went wrong while loading the export-resources-modal messages for ${locale}`, error);
3505
+ sentry.reportErrorToSentry(new Error(`Something went wrong while loading the export-resources-modal messages for ${locale}`), {
3506
+ extra: error
3507
+ });
3508
+ return {};
3509
+ }
3510
+ };
3511
+
3512
+ const useAsyncIntlMessages = (locale, loader) => {
3513
+ const _useState = React.useState({
3514
+ isLoading: true,
3515
+ messages: undefined,
3516
+ error: undefined
3517
+ }),
3518
+ _useState2 = _slicedToArray(_useState, 2),
3519
+ state = _useState2[0],
3520
+ setState = _useState2[1];
3521
+ React.useEffect(() => {
3522
+ let _isUnmounting = false;
3523
+ async function load() {
3524
+ try {
3525
+ if (!_isUnmounting) {
3526
+ const messages = await loader(locale);
3527
+ setState({
3528
+ isLoading: false,
3529
+ messages
3530
+ });
3531
+ }
3532
+ } catch (error) {
3533
+ setState({
3534
+ isLoading: false,
3535
+ error
3536
+ });
3537
+ }
3538
+ }
3539
+ if (locale) load();
3540
+ return () => {
3541
+ _isUnmounting = true;
3542
+ };
3543
+ }, [locale, loader]);
3544
+ return state;
3545
+ };
3546
+
3547
+ const _excluded = ["isOpen", "selectedResourceIds", "outputFormat", "fieldGroups", "fieldOrder"];
3548
+ 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; }
3549
+ 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; }
3550
+ function invalidateLaunchDarklyCachedFeatureFlag(flagName) {
3551
+ for (let _ref of _Object$entries__default["default"](localStorage)) {
3552
+ var _ref2 = _slicedToArray(_ref, 1);
3553
+ let key = _ref2[0];
3554
+ // This is the pattern that the LaunchDarkly adapter uses to store the flags
3555
+ if (_startsWithInstanceProperty__default["default"](key).call(key, '@flopflip/launchdarkly-adapter/') && _endsWithInstanceProperty__default["default"](key).call(key, '/flags')) {
3556
+ try {
3557
+ const flags = JSON.parse(localStorage.getItem(key) || '{}');
3558
+ if (flags[flagName] !== undefined) {
3559
+ delete flags[flagName];
3560
+ localStorage.setItem(key, _JSON$stringify__default["default"](flags));
3561
+ }
3562
+ } catch (error) {}
3563
+ }
3564
+ }
3565
+ }
3566
+ invalidateLaunchDarklyCachedFeatureFlag('enableOperationsExport');
3567
+ const ExportResourcesModal = _ref3 => {
3568
+ let _ref3$isOpen = _ref3.isOpen,
3569
+ isOpen = _ref3$isOpen === void 0 ? false : _ref3$isOpen,
3570
+ _ref3$selectedResourc = _ref3.selectedResourceIds,
3571
+ selectedResourceIds = _ref3$selectedResourc === void 0 ? [] : _ref3$selectedResourc,
3572
+ _ref3$outputFormat = _ref3.outputFormat,
3573
+ outputFormat = _ref3$outputFormat === void 0 ? OUTPUT_FORMATS.CSV : _ref3$outputFormat,
3574
+ _ref3$fieldGroups = _ref3.fieldGroups,
3575
+ fieldGroups = _ref3$fieldGroups === void 0 ? [] : _ref3$fieldGroups,
3576
+ _ref3$fieldOrder = _ref3.fieldOrder,
3577
+ fieldOrder = _ref3$fieldOrder === void 0 ? [] : _ref3$fieldOrder,
3578
+ props = _objectWithoutProperties(_ref3, _excluded);
3579
+ const _useApplicationContex = applicationShellConnectors.useApplicationContext(context => ({
3580
+ locale: context.user && context.user.locale
3581
+ })),
3582
+ locale = _useApplicationContex.locale;
3583
+ const messages = useAsyncIntlMessages(locale, loadMessages);
3584
+ if (!isOpen || messages.isLoading) return null;
3585
+ if (props.filters && !validateFilters(props.filters)) {
3586
+ console.error('Invalid filters prop:', props.filters, 'Filters must contain one of these values: `filters` or `where`');
3587
+ return null;
3588
+ }
3589
+ return jsxRuntime.jsx(reactIntl.IntlProvider, {
3590
+ locale: locale,
3591
+ messages: messages.messages,
3592
+ children: jsxRuntime.jsx(ExportResourcesProvider, _objectSpread(_objectSpread({
3593
+ fieldGroups: fieldGroups,
3594
+ fieldOrder: fieldOrder,
3595
+ isOpen: isOpen,
3596
+ outputFormat: outputFormat,
3597
+ selectedResourceIds: selectedResourceIds
3598
+ }, props), {}, {
3599
+ children: jsxRuntime.jsx(CurrentStep, {})
3600
+ }))
3601
+ });
3602
+ };
3603
+ ExportResourcesModal.displayName = 'ExportResourcesModal';
3604
+
3605
+ exports.EXPORTABLE_RESOURCES = EXPORTABLE_RESOURCES;
3606
+ exports.EXPORT_TYPES = EXPORT_TYPES;
3607
+ exports.LocaleOption = LocaleOption;
3608
+ exports.Step = Step;
3609
+ exports["default"] = ExportResourcesModal;
3610
+ exports.useConvertFieldDefinitionsForExport = useConvertFieldDefinitionsForExport;