@commercetools-frontend-extensions/export-resources-modal 0.0.0-canary-20250311100750 → 0.0.0-canary-20250314145250

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