@commercetools-frontend-extensions/unpublish-products-modal 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/LICENSE +29 -0
  2. package/README.md +72 -0
  3. package/dist/active-drag-drop-area-c4d16e89.cjs.prod.js +54 -0
  4. package/dist/active-drag-drop-area-cec2c6b5.esm.js +52 -0
  5. package/dist/active-drag-drop-area-f09afa25.cjs.dev.js +54 -0
  6. package/dist/commercetools-frontend-extensions-unpublish-products-modal.cjs.d.ts +3 -0
  7. package/dist/commercetools-frontend-extensions-unpublish-products-modal.cjs.dev.js +52 -0
  8. package/dist/commercetools-frontend-extensions-unpublish-products-modal.cjs.js +7 -0
  9. package/dist/commercetools-frontend-extensions-unpublish-products-modal.cjs.prod.js +52 -0
  10. package/dist/commercetools-frontend-extensions-unpublish-products-modal.esm.js +44 -0
  11. package/dist/de-a34c5dd4.cjs.dev.js +6 -0
  12. package/dist/de-cd6c45d3.esm.js +4 -0
  13. package/dist/de-d954fe3d.cjs.prod.js +6 -0
  14. package/dist/declarations/src/@types/file-upload.d.ts +42 -0
  15. package/dist/declarations/src/@types/import-container.d.ts +11 -0
  16. package/dist/declarations/src/@types/index.d.ts +3 -0
  17. package/dist/declarations/src/@types/unpublish-products-modal-props.d.ts +4 -0
  18. package/dist/declarations/src/index.d.ts +2 -0
  19. package/dist/declarations/src/unpublish-products-modal.d.ts +6 -0
  20. package/dist/en-3a9aa2d4.esm.js +4 -0
  21. package/dist/en-6b3694f6.cjs.dev.js +6 -0
  22. package/dist/en-c7757448.cjs.prod.js +6 -0
  23. package/dist/enabled-drop-area-0fcec033.cjs.dev.js +115 -0
  24. package/dist/enabled-drop-area-82ec844a.esm.js +102 -0
  25. package/dist/enabled-drop-area-9e04a444.cjs.prod.js +115 -0
  26. package/dist/es-042343bd.cjs.prod.js +6 -0
  27. package/dist/es-8b3ecab1.cjs.dev.js +6 -0
  28. package/dist/es-e544023d.esm.js +4 -0
  29. package/dist/file-dropped-area-411688d1.cjs.prod.js +74 -0
  30. package/dist/file-dropped-area-7cd5f0cb.cjs.dev.js +74 -0
  31. package/dist/file-dropped-area-e301d075.esm.js +72 -0
  32. package/dist/fr-FR-9d9081ee.esm.js +4 -0
  33. package/dist/fr-FR-e7126fcc.cjs.dev.js +6 -0
  34. package/dist/fr-FR-fce1ca96.cjs.prod.js +6 -0
  35. package/dist/index-601d8304.cjs.prod.js +1533 -0
  36. package/dist/index-73a8bbcd.cjs.dev.js +1547 -0
  37. package/dist/index-95840e98.esm.js +1517 -0
  38. package/dist/ja-37632763.cjs.prod.js +6 -0
  39. package/dist/ja-73c088a7.esm.js +4 -0
  40. package/dist/ja-9bd5f452.cjs.dev.js +6 -0
  41. package/dist/pt-BR-b37d730b.esm.js +4 -0
  42. package/dist/pt-BR-ea6b3251.cjs.dev.js +6 -0
  43. package/dist/pt-BR-ec2a1a11.cjs.prod.js +6 -0
  44. package/dist/zh-CN-4780d88e.esm.js +4 -0
  45. package/dist/zh-CN-52baa549.cjs.prod.js +6 -0
  46. package/dist/zh-CN-d4bc6d26.cjs.dev.js +6 -0
  47. package/package.json +92 -0
@@ -0,0 +1,1517 @@
1
+ import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
2
+ import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
3
+ import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
4
+ import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
5
+ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
6
+ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
7
+ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
8
+ import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
9
+ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
+ import { defineMessages, useIntl, FormattedMessage, IntlProvider } from 'react-intl';
11
+ import { useApplicationContext, oidcStorage } from '@commercetools-frontend/application-shell-connectors';
12
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
13
+ import React, { lazy, useContext, useState, useEffect } from 'react';
14
+ import { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
15
+ import _JSON$stringify from '@babel/runtime-corejs3/core-js-stable/json/stringify';
16
+ import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants';
17
+ import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
18
+ import _Promise from '@babel/runtime-corejs3/core-js-stable/promise';
19
+ import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
20
+ import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
21
+ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
22
+ import Papa from 'papaparse';
23
+ import { jsx, jsxs } from '@emotion/react/jsx-runtime';
24
+ import { FormDialog, InfoDialog, ConfirmationDialog } from '@commercetools-frontend/application-components';
25
+ import { Masking } from '@commercetools-frontend/fullstory';
26
+ import { customProperties, Constraints, Text, Link, Spacings, SecondaryButton, ProgressBar, usePaginationState, PageNavigator, Stamp, PrimaryButton, ImportIcon, Card, CloseBoldIcon } from '@commercetools-frontend/ui-kit';
27
+ import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
28
+ import { useDropzone } from 'react-dropzone';
29
+ import { useShowNotification } from '@commercetools-frontend/actions-global';
30
+ import _styled from '@emotion/styled/base';
31
+ import { css } from '@emotion/react';
32
+ import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
33
+ import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
34
+ import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
35
+ import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn';
36
+ import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
37
+ import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits';
38
+ import _wrapNativeSuper from '@babel/runtime-corejs3/helpers/esm/wrapNativeSuper';
39
+ import { reportErrorToSentry } from '@commercetools-frontend/sentry';
40
+ import { createHttpClientOptions, buildApiUrl } from '@commercetools-frontend/application-shell';
41
+ import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice';
42
+ import DataTable from '@commercetools-uikit/data-table';
43
+ import { parseChunkImport, mapLocaleToIntlLocale } from '@commercetools-frontend/i18n';
44
+
45
+ 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; }
46
+ 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; }
47
+ function reducer(state, action) {
48
+ if (action.type === 'setCurrentStep') return _objectSpread$a(_objectSpread$a({}, state), {}, {
49
+ currentStep: action.currentStep,
50
+ progress: 0
51
+ });
52
+ if (action.type === 'setContainerKey') return _objectSpread$a(_objectSpread$a({}, state), {}, {
53
+ containerKey: action.containerKey
54
+ });
55
+ if (action.type === 'cancelImport') return _objectSpread$a(_objectSpread$a({}, state), {}, {
56
+ currentStep: 'upload',
57
+ containerKey: undefined,
58
+ droppedFile: undefined,
59
+ dropAreaState: 'ready-for-drop',
60
+ progress: 0
61
+ });
62
+ if (action.type === 'uploadNewFile') return _objectSpread$a(_objectSpread$a({}, state), {}, {
63
+ currentStep: 'upload',
64
+ containerKey: undefined,
65
+ droppedFile: undefined,
66
+ dropAreaState: 'ready-for-drop',
67
+ progress: 0
68
+ });
69
+ if (action.type === 'setDroppedFile') {
70
+ return _objectSpread$a(_objectSpread$a({}, state), {}, {
71
+ droppedFile: action.droppedFile
72
+ });
73
+ }
74
+ if (action.type === 'setAbortController') {
75
+ return _objectSpread$a(_objectSpread$a({}, state), {}, {
76
+ abortController: action.abortController
77
+ });
78
+ }
79
+ if (action.type === 'setProgress') {
80
+ return _objectSpread$a(_objectSpread$a({}, state), {}, {
81
+ progress: action.progress
82
+ });
83
+ }
84
+ if (action.type === 'setUploadFileResponse') {
85
+ return _objectSpread$a(_objectSpread$a({}, state), {}, {
86
+ uploadFileResponse: action.uploadFileResponse
87
+ });
88
+ }
89
+ if (action.type === 'setFileUploadErrors') {
90
+ return _objectSpread$a(_objectSpread$a({}, state), {}, {
91
+ fileUploadErrors: action.fileUploadErrors
92
+ });
93
+ }
94
+ throw new Error(getUnknownActionError(action));
95
+ }
96
+ function getUnknownActionError(actionType) {
97
+ return `Unkown type: ${actionType}`;
98
+ }
99
+ const initialState = {
100
+ currentStep: 'upload',
101
+ abortController: new AbortController(),
102
+ dropAreaState: 'ready-for-drop',
103
+ containerKey: undefined,
104
+ progress: 0,
105
+ uploadFileResponse: undefined,
106
+ fileUploadErrors: []
107
+ };
108
+ const initialActions = {
109
+ setCurrentStep(_currentStep) {
110
+ /**/
111
+ },
112
+ cancelImport() {
113
+ /**/
114
+ },
115
+ uploadNewFile() {
116
+ /**/
117
+ },
118
+ setDroppedFile(_nextDroppedFile) {
119
+ /**/
120
+ },
121
+ setUploadFileResponse(_uploadFileResponse) {
122
+ /**/
123
+ },
124
+ setFileUploadErrors(_fileUploadErrors) {
125
+ /**/
126
+ },
127
+ setContainerKey(_containerKey) {
128
+ /**/
129
+ },
130
+ setAbortController(_abortController) {
131
+ /**/
132
+ },
133
+ setProgress(_progress) {
134
+ /**/
135
+ }
136
+ };
137
+
138
+ function getCreateImportContainerURL(projectKey) {
139
+ return `/${projectKey}/import-containers`;
140
+ }
141
+ function getDeleteImportContainerURL(projectKey, containerKey) {
142
+ return `/${projectKey}/import-containers/${containerKey}`;
143
+ }
144
+ function getFileUploadURL(projectKey, containerKey) {
145
+ return `/${projectKey}/products/import-containers/${containerKey}/file-upload`;
146
+ }
147
+ function getProccessFileURL(projectKey, containerKey) {
148
+ return `/${projectKey}/products/import-containers/${containerKey}/process-file`;
149
+ }
150
+
151
+ function createImportContainerForFileUpload(importContainerDraft, projectKey, asyncDispatch) {
152
+ return asyncDispatch(actions.post({
153
+ mcApiProxyTarget: MC_API_PROXY_TARGETS.IMPORT,
154
+ uri: getCreateImportContainerURL(projectKey),
155
+ headers: {
156
+ accept: 'application/json',
157
+ 'Content-Type': 'application/json'
158
+ },
159
+ payload: _JSON$stringify(importContainerDraft)
160
+ }));
161
+ }
162
+ function deleteImportContainer(projectKey, containerKey, asyncDispatch) {
163
+ return asyncDispatch(actions.del({
164
+ mcApiProxyTarget: MC_API_PROXY_TARGETS.IMPORT,
165
+ uri: getDeleteImportContainerURL(projectKey, containerKey),
166
+ headers: {
167
+ accept: 'application/json'
168
+ }
169
+ }));
170
+ }
171
+
172
+ function convertFileSizeToKB(sizeInBytes) {
173
+ return sizeInBytes / 1000;
174
+ }
175
+ function hasOwnProperty(obj, prop) {
176
+ return typeof obj === 'object' && obj !== null && obj.hasOwnProperty(prop);
177
+ }
178
+ function hasRequiredFields(maybeValidObject, requiredFields) {
179
+ return typeof maybeValidObject === 'object' && maybeValidObject !== null && _everyInstanceProperty(requiredFields).call(requiredFields, property => hasOwnProperty(maybeValidObject, property));
180
+ }
181
+ function isAbortError(error) {
182
+ return error instanceof DOMException && error.name === 'AbortError';
183
+ }
184
+
185
+ const encodeFileNameWithTimestampToContainerKey = fileName => {
186
+ return btoa(_JSON$stringify({
187
+ timestamp: new Date().getTime(),
188
+ fileName
189
+ })).replace(/=+$/g, '');
190
+ };
191
+
192
+ 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; }
193
+ 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; }
194
+ /**
195
+ * Returns the number of rows in a CSV file excluding the header
196
+ * @param file The CSV file to process.
197
+ * @returns A promise that resolves to the number of rows
198
+ */
199
+ const getRowCount = file => {
200
+ return new _Promise(resolve => {
201
+ let lineCount = 0;
202
+ Papa.parse(file, {
203
+ step: _ref => {
204
+ let data = _ref.data;
205
+ // empty lines at the end of the file should not be counted
206
+ if (_Array$isArray(data) && _findInstanceProperty(data).call(data, Boolean)) lineCount++;
207
+ },
208
+ complete: () => {
209
+ // Subtract 1 for the header row
210
+ // We use Math.max to make sure the count is not less than 0, this is needed for empty files
211
+ resolve(Math.max(0, lineCount - 1));
212
+ }
213
+ });
214
+ });
215
+ };
216
+
217
+ /**
218
+ * Checks if the CSV file only contains a single column named 'key'
219
+ * @param file The CSV file to process
220
+ * @returns A promise that resolves to true if the file contains only one column named 'key', otherwise false
221
+ */
222
+ const hasSingleKeyColumn = file => {
223
+ return new _Promise(resolve => {
224
+ Papa.parse(file, {
225
+ header: true,
226
+ // Only parse the first row (header)
227
+ preview: 1,
228
+ complete: results => {
229
+ const fields = results?.meta?.fields;
230
+ resolve(fields.length === 1 && fields[0] === 'key');
231
+ }
232
+ });
233
+ });
234
+ };
235
+ const toBytes = megabytes => megabytes * 1024 * 1024;
236
+ const mapFileUploadErrorsToUploadFileErrorRows = uploadFileErrors => {
237
+ let idCounter = 1;
238
+ return _mapInstanceProperty(uploadFileErrors).call(uploadFileErrors, uploadFileError => _objectSpread$9(_objectSpread$9({}, uploadFileError), {}, {
239
+ id: String(idCounter++)
240
+ }));
241
+ };
242
+
243
+ async function processUploadedFile(_ref) {
244
+ let projectKey = _ref.projectKey,
245
+ containerKey = _ref.containerKey,
246
+ asyncDispatch = _ref.asyncDispatch;
247
+ const uri = getProccessFileURL(projectKey, containerKey);
248
+ const response = await asyncDispatch(actions.post({
249
+ mcApiProxyTarget: MC_API_PROXY_TARGETS.IMPORT,
250
+ uri: uri,
251
+ headers: {
252
+ accept: 'application/json',
253
+ 'Content-Type': 'application/json'
254
+ },
255
+ payload: {}
256
+ }));
257
+ assertProcessFileResponse(response);
258
+ return response;
259
+ }
260
+ function assertProcessFileResponse(maybeProcessFileResponse) {
261
+ const requiredFields = ['message'];
262
+ if (hasRequiredFields(maybeProcessFileResponse, requiredFields)) return;
263
+ throw new Error('Invalid response');
264
+ }
265
+
266
+ const UnpublishProductsContext = /*#__PURE__*/React.createContext({
267
+ state: initialState,
268
+ actions: initialActions,
269
+ onClose: () => {}
270
+ });
271
+ const UnpublishProductsProvider = props => {
272
+ const _useApplicationContex = useApplicationContext(context => ({
273
+ projectKey: context.project?.key
274
+ })),
275
+ projectKey = _useApplicationContex.projectKey;
276
+ const asyncDispatch = useAsyncDispatch();
277
+ const _React$useReducer = React.useReducer(reducer, initialState),
278
+ _React$useReducer2 = _slicedToArray(_React$useReducer, 2),
279
+ state = _React$useReducer2[0],
280
+ dispatch = _React$useReducer2[1];
281
+ const setCurrentStep = currentStep => dispatch({
282
+ type: 'setCurrentStep',
283
+ currentStep
284
+ });
285
+ const setContainerKey = containerKey => dispatch({
286
+ type: 'setContainerKey',
287
+ containerKey
288
+ });
289
+ const cancelImport = () => dispatch({
290
+ type: 'cancelImport'
291
+ });
292
+ const uploadNewFile = () => dispatch({
293
+ type: 'uploadNewFile'
294
+ });
295
+ const setDroppedFile = droppedFile => dispatch({
296
+ type: 'setDroppedFile',
297
+ droppedFile: droppedFile
298
+ });
299
+ const setFileUploadErrors = fileUploadErrors => {
300
+ dispatch({
301
+ type: 'setFileUploadErrors',
302
+ fileUploadErrors
303
+ });
304
+ };
305
+ const setAbortController = abortController => dispatch({
306
+ type: 'setAbortController',
307
+ abortController: abortController
308
+ });
309
+ const setProgress = progress => dispatch({
310
+ type: 'setProgress',
311
+ progress
312
+ });
313
+ const setUploadFileResponse = uploadFileResponse => {
314
+ dispatch({
315
+ type: 'setUploadFileResponse',
316
+ uploadFileResponse
317
+ });
318
+ };
319
+ const handleClose = function () {
320
+ let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
321
+ if (state.abortController) state.abortController.abort();
322
+ if (typeof props.onClose === 'function') props.onClose();
323
+ // Removes the associated import container when the import is closed
324
+ if (options.shouldDeleteImportContainer && projectKey && state.containerKey) deleteImportContainer(projectKey, state.containerKey, asyncDispatch);
325
+ };
326
+ return jsx(UnpublishProductsContext.Provider, {
327
+ value: {
328
+ state,
329
+ onClose: handleClose,
330
+ actions: {
331
+ setCurrentStep,
332
+ cancelImport,
333
+ uploadNewFile,
334
+ setDroppedFile,
335
+ setUploadFileResponse,
336
+ setFileUploadErrors,
337
+ setContainerKey,
338
+ setAbortController,
339
+ setProgress
340
+ }
341
+ },
342
+ children: props.children
343
+ });
344
+ };
345
+
346
+ const getBorderColor = state => {
347
+ const borderColors = {
348
+ default: '#909dbc',
349
+ error: '#e60050',
350
+ active: customProperties.colorPrimary
351
+ };
352
+ return borderColors[state] || borderColors.default;
353
+ };
354
+ const getDashedBorder = function () {
355
+ let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default';
356
+ const color = getBorderColor(state);
357
+ const svgContent = `
358
+ <svg width="100%" height="100%" xmlns="http://www.w3.org/2000/svg">
359
+ <rect width="100%" height="100%" fill="none" stroke="${color}" stroke-width="2px" stroke-dasharray="6,6" stroke-dashoffset="0" stroke-linecap="square"/>
360
+ </svg>
361
+ `;
362
+ return `data:image/svg+xml,${encodeURIComponent(svgContent)}`;
363
+ };
364
+ const base = /*#__PURE__*/css("border-radius:", customProperties.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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QmdCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcblxudHlwZSBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnIHwgJ2Vycm9yJyB8ICdhY3RpdmUnXG5cbmNvbnN0IGdldEJvcmRlckNvbG9yID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlKSA9PiB7XG4gIGNvbnN0IGJvcmRlckNvbG9ycyA9IHtcbiAgICBkZWZhdWx0OiAnIzkwOWRiYycsXG4gICAgZXJyb3I6ICcjZTYwMDUwJyxcbiAgICBhY3RpdmU6IGN1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5LFxuICB9XG5cbiAgcmV0dXJuIGJvcmRlckNvbG9yc1tzdGF0ZV0gfHwgYm9yZGVyQ29sb3JzLmRlZmF1bHRcbn1cblxuY29uc3QgZ2V0RGFzaGVkQm9yZGVyID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnKSA9PiB7XG4gIGNvbnN0IGNvbG9yID0gZ2V0Qm9yZGVyQ29sb3Ioc3RhdGUpXG4gIGNvbnN0IHN2Z0NvbnRlbnQgPSBgXG4gICAgPHN2ZyB3aWR0aD1cIjEwMCVcIiBoZWlnaHQ9XCIxMDAlXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgICAgPHJlY3Qgd2lkdGg9XCIxMDAlXCIgaGVpZ2h0PVwiMTAwJVwiIGZpbGw9XCJub25lXCIgc3Ryb2tlPVwiJHtjb2xvcn1cIiBzdHJva2Utd2lkdGg9XCIycHhcIiBzdHJva2UtZGFzaGFycmF5PVwiNiw2XCIgc3Ryb2tlLWRhc2hvZmZzZXQ9XCIwXCIgc3Ryb2tlLWxpbmVjYXA9XCJzcXVhcmVcIi8+XG4gICAgPC9zdmc+XG4gIGBcbiAgcmV0dXJuIGBkYXRhOmltYWdlL3N2Zyt4bWwsJHtlbmNvZGVVUklDb21wb25lbnQoc3ZnQ29udGVudCl9YFxufVxuXG5jb25zdCBiYXNlID0gY3NzYFxuICBib3JkZXItcmFkaXVzOiAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzNn07XG4gIG1pbi1oZWlnaHQ6IDEzNnB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcbmNvbnN0IHJlYWR5Rm9yRHJvcCA9IGNzc2BcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKFxcXCIke2dldERhc2hlZEJvcmRlcigpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JTdXJmYWNlfTtcbmBcbmNvbnN0IGFjdGl2ZURyYWcgPSBjc3NgXG4gIGJhY2tncm91bmQtaW1hZ2U6IHVybChcXFwiJHtnZXREYXNoZWRCb3JkZXIoJ2FjdGl2ZScpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5OTV9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcbmNvbnN0IGZpbGVEcm9wcGVkID0gY3NzYFxuICBiYWNrZ3JvdW5kLWltYWdlOiB1cmwoXFxcIiR7Z2V0RGFzaGVkQm9yZGVyKCl9XFxcIik7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y3VzdG9tUHJvcGVydGllcy5jb2xvclN1cmZhY2V9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHtcbiAgYmFzZSxcbiAgcmVhZHlGb3JEcm9wLFxuICBmaWxlRHJvcHBlZCxcbiAgYWN0aXZlRHJhZyxcbn1cbiJdfQ== */");
365
+ const readyForDrop = /*#__PURE__*/css("background-image:url(\"", getDashedBorder(), "\");background-color:", customProperties.colorSurface, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:readyForDrop;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ3dCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcblxudHlwZSBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnIHwgJ2Vycm9yJyB8ICdhY3RpdmUnXG5cbmNvbnN0IGdldEJvcmRlckNvbG9yID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlKSA9PiB7XG4gIGNvbnN0IGJvcmRlckNvbG9ycyA9IHtcbiAgICBkZWZhdWx0OiAnIzkwOWRiYycsXG4gICAgZXJyb3I6ICcjZTYwMDUwJyxcbiAgICBhY3RpdmU6IGN1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5LFxuICB9XG5cbiAgcmV0dXJuIGJvcmRlckNvbG9yc1tzdGF0ZV0gfHwgYm9yZGVyQ29sb3JzLmRlZmF1bHRcbn1cblxuY29uc3QgZ2V0RGFzaGVkQm9yZGVyID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnKSA9PiB7XG4gIGNvbnN0IGNvbG9yID0gZ2V0Qm9yZGVyQ29sb3Ioc3RhdGUpXG4gIGNvbnN0IHN2Z0NvbnRlbnQgPSBgXG4gICAgPHN2ZyB3aWR0aD1cIjEwMCVcIiBoZWlnaHQ9XCIxMDAlXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgICAgPHJlY3Qgd2lkdGg9XCIxMDAlXCIgaGVpZ2h0PVwiMTAwJVwiIGZpbGw9XCJub25lXCIgc3Ryb2tlPVwiJHtjb2xvcn1cIiBzdHJva2Utd2lkdGg9XCIycHhcIiBzdHJva2UtZGFzaGFycmF5PVwiNiw2XCIgc3Ryb2tlLWRhc2hvZmZzZXQ9XCIwXCIgc3Ryb2tlLWxpbmVjYXA9XCJzcXVhcmVcIi8+XG4gICAgPC9zdmc+XG4gIGBcbiAgcmV0dXJuIGBkYXRhOmltYWdlL3N2Zyt4bWwsJHtlbmNvZGVVUklDb21wb25lbnQoc3ZnQ29udGVudCl9YFxufVxuXG5jb25zdCBiYXNlID0gY3NzYFxuICBib3JkZXItcmFkaXVzOiAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzNn07XG4gIG1pbi1oZWlnaHQ6IDEzNnB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcbmNvbnN0IHJlYWR5Rm9yRHJvcCA9IGNzc2BcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKFxcXCIke2dldERhc2hlZEJvcmRlcigpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JTdXJmYWNlfTtcbmBcbmNvbnN0IGFjdGl2ZURyYWcgPSBjc3NgXG4gIGJhY2tncm91bmQtaW1hZ2U6IHVybChcXFwiJHtnZXREYXNoZWRCb3JkZXIoJ2FjdGl2ZScpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5OTV9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcbmNvbnN0IGZpbGVEcm9wcGVkID0gY3NzYFxuICBiYWNrZ3JvdW5kLWltYWdlOiB1cmwoXFxcIiR7Z2V0RGFzaGVkQm9yZGVyKCl9XFxcIik7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y3VzdG9tUHJvcGVydGllcy5jb2xvclN1cmZhY2V9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHtcbiAgYmFzZSxcbiAgcmVhZHlGb3JEcm9wLFxuICBmaWxlRHJvcHBlZCxcbiAgYWN0aXZlRHJhZyxcbn1cbiJdfQ== */");
366
+ const activeDrag = /*#__PURE__*/css("background-image:url(\"", getDashedBorder('active'), "\");background-color:", customProperties.colorPrimary95, ";padding:", customProperties.spacing50, " 100px;" + (process.env.NODE_ENV === "production" ? "" : ";label:activeDrag;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ3NCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcblxudHlwZSBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnIHwgJ2Vycm9yJyB8ICdhY3RpdmUnXG5cbmNvbnN0IGdldEJvcmRlckNvbG9yID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlKSA9PiB7XG4gIGNvbnN0IGJvcmRlckNvbG9ycyA9IHtcbiAgICBkZWZhdWx0OiAnIzkwOWRiYycsXG4gICAgZXJyb3I6ICcjZTYwMDUwJyxcbiAgICBhY3RpdmU6IGN1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5LFxuICB9XG5cbiAgcmV0dXJuIGJvcmRlckNvbG9yc1tzdGF0ZV0gfHwgYm9yZGVyQ29sb3JzLmRlZmF1bHRcbn1cblxuY29uc3QgZ2V0RGFzaGVkQm9yZGVyID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnKSA9PiB7XG4gIGNvbnN0IGNvbG9yID0gZ2V0Qm9yZGVyQ29sb3Ioc3RhdGUpXG4gIGNvbnN0IHN2Z0NvbnRlbnQgPSBgXG4gICAgPHN2ZyB3aWR0aD1cIjEwMCVcIiBoZWlnaHQ9XCIxMDAlXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgICAgPHJlY3Qgd2lkdGg9XCIxMDAlXCIgaGVpZ2h0PVwiMTAwJVwiIGZpbGw9XCJub25lXCIgc3Ryb2tlPVwiJHtjb2xvcn1cIiBzdHJva2Utd2lkdGg9XCIycHhcIiBzdHJva2UtZGFzaGFycmF5PVwiNiw2XCIgc3Ryb2tlLWRhc2hvZmZzZXQ9XCIwXCIgc3Ryb2tlLWxpbmVjYXA9XCJzcXVhcmVcIi8+XG4gICAgPC9zdmc+XG4gIGBcbiAgcmV0dXJuIGBkYXRhOmltYWdlL3N2Zyt4bWwsJHtlbmNvZGVVUklDb21wb25lbnQoc3ZnQ29udGVudCl9YFxufVxuXG5jb25zdCBiYXNlID0gY3NzYFxuICBib3JkZXItcmFkaXVzOiAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzNn07XG4gIG1pbi1oZWlnaHQ6IDEzNnB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcbmNvbnN0IHJlYWR5Rm9yRHJvcCA9IGNzc2BcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKFxcXCIke2dldERhc2hlZEJvcmRlcigpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JTdXJmYWNlfTtcbmBcbmNvbnN0IGFjdGl2ZURyYWcgPSBjc3NgXG4gIGJhY2tncm91bmQtaW1hZ2U6IHVybChcXFwiJHtnZXREYXNoZWRCb3JkZXIoJ2FjdGl2ZScpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5OTV9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcbmNvbnN0IGZpbGVEcm9wcGVkID0gY3NzYFxuICBiYWNrZ3JvdW5kLWltYWdlOiB1cmwoXFxcIiR7Z2V0RGFzaGVkQm9yZGVyKCl9XFxcIik7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y3VzdG9tUHJvcGVydGllcy5jb2xvclN1cmZhY2V9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHtcbiAgYmFzZSxcbiAgcmVhZHlGb3JEcm9wLFxuICBmaWxlRHJvcHBlZCxcbiAgYWN0aXZlRHJhZyxcbn1cbiJdfQ== */");
367
+ const fileDropped = /*#__PURE__*/css("background-image:url(\"", getDashedBorder(), "\");background-color:", customProperties.colorSurface, ";padding:", customProperties.spacing50, " 100px;" + (process.env.NODE_ENV === "production" ? "" : ";label:fileDropped;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5Q3VCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGN1c3RvbVByb3BlcnRpZXMgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcblxudHlwZSBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnIHwgJ2Vycm9yJyB8ICdhY3RpdmUnXG5cbmNvbnN0IGdldEJvcmRlckNvbG9yID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlKSA9PiB7XG4gIGNvbnN0IGJvcmRlckNvbG9ycyA9IHtcbiAgICBkZWZhdWx0OiAnIzkwOWRiYycsXG4gICAgZXJyb3I6ICcjZTYwMDUwJyxcbiAgICBhY3RpdmU6IGN1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5LFxuICB9XG5cbiAgcmV0dXJuIGJvcmRlckNvbG9yc1tzdGF0ZV0gfHwgYm9yZGVyQ29sb3JzLmRlZmF1bHRcbn1cblxuY29uc3QgZ2V0RGFzaGVkQm9yZGVyID0gKHN0YXRlOiBEcm9wQXJlYVN0YXRlID0gJ2RlZmF1bHQnKSA9PiB7XG4gIGNvbnN0IGNvbG9yID0gZ2V0Qm9yZGVyQ29sb3Ioc3RhdGUpXG4gIGNvbnN0IHN2Z0NvbnRlbnQgPSBgXG4gICAgPHN2ZyB3aWR0aD1cIjEwMCVcIiBoZWlnaHQ9XCIxMDAlXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgICAgPHJlY3Qgd2lkdGg9XCIxMDAlXCIgaGVpZ2h0PVwiMTAwJVwiIGZpbGw9XCJub25lXCIgc3Ryb2tlPVwiJHtjb2xvcn1cIiBzdHJva2Utd2lkdGg9XCIycHhcIiBzdHJva2UtZGFzaGFycmF5PVwiNiw2XCIgc3Ryb2tlLWRhc2hvZmZzZXQ9XCIwXCIgc3Ryb2tlLWxpbmVjYXA9XCJzcXVhcmVcIi8+XG4gICAgPC9zdmc+XG4gIGBcbiAgcmV0dXJuIGBkYXRhOmltYWdlL3N2Zyt4bWwsJHtlbmNvZGVVUklDb21wb25lbnQoc3ZnQ29udGVudCl9YFxufVxuXG5jb25zdCBiYXNlID0gY3NzYFxuICBib3JkZXItcmFkaXVzOiAke2N1c3RvbVByb3BlcnRpZXMuYm9yZGVyUmFkaXVzNn07XG4gIG1pbi1oZWlnaHQ6IDEzNnB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcbmNvbnN0IHJlYWR5Rm9yRHJvcCA9IGNzc2BcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKFxcXCIke2dldERhc2hlZEJvcmRlcigpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JTdXJmYWNlfTtcbmBcbmNvbnN0IGFjdGl2ZURyYWcgPSBjc3NgXG4gIGJhY2tncm91bmQtaW1hZ2U6IHVybChcXFwiJHtnZXREYXNoZWRCb3JkZXIoJ2FjdGl2ZScpfVxcXCIpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2N1c3RvbVByb3BlcnRpZXMuY29sb3JQcmltYXJ5OTV9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcbmNvbnN0IGZpbGVEcm9wcGVkID0gY3NzYFxuICBiYWNrZ3JvdW5kLWltYWdlOiB1cmwoXFxcIiR7Z2V0RGFzaGVkQm9yZGVyKCl9XFxcIik7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y3VzdG9tUHJvcGVydGllcy5jb2xvclN1cmZhY2V9O1xuICBwYWRkaW5nOiAke2N1c3RvbVByb3BlcnRpZXMuc3BhY2luZzUwfSAxMDBweDtcbmBcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHtcbiAgYmFzZSxcbiAgcmVhZHlGb3JEcm9wLFxuICBmaWxlRHJvcHBlZCxcbiAgYWN0aXZlRHJhZyxcbn1cbiJdfQ== */");
368
+ const styles = {
369
+ base,
370
+ readyForDrop,
371
+ fileDropped,
372
+ activeDrag
373
+ };
374
+
375
+ const DropWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
376
+ target: "e19vac9v0"
377
+ } : {
378
+ target: "e19vac9v0",
379
+ label: "DropWrapper"
380
+ })(styles.base, " ", props => {
381
+ if (props.dropAreaState === 'ready-for-drop') {
382
+ return styles.readyForDrop;
383
+ }
384
+ if (props.dropAreaState === 'active-drag') {
385
+ return styles.activeDrag;
386
+ }
387
+ if (props.dropAreaState === 'file-dropped') {
388
+ return styles.fileDropped;
389
+ }
390
+ return getDefaultDropWrapperStyles(props.dropAreaState);
391
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyb3AtYXJlYS13cmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTdUQiLCJmaWxlIjoiZHJvcC1hcmVhLXdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHlwZSBEcm9wem9uZVJvb3RQcm9wcyB9IGZyb20gJ3JlYWN0LWRyb3B6b25lJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHN0eWxlcyB9IGZyb20gJy4vc3R5bGVzJ1xuaW1wb3J0IHsgdHlwZSBEcm9wQXJlYVN0YXRlIH0gZnJvbSAnLi4vLi4vLi4vQHR5cGVzJ1xuXG5pbnRlcmZhY2UgRHJvcFdyYXBwZXJQcm9wcyBleHRlbmRzIERyb3B6b25lUm9vdFByb3BzIHtcbiAgZHJvcEFyZWFTdGF0ZTogRHJvcEFyZWFTdGF0ZVxufVxuZXhwb3J0IGNvbnN0IERyb3BXcmFwcGVyID0gc3R5bGVkLmRpdjxEcm9wV3JhcHBlclByb3BzPmBcbiAgJHtzdHlsZXMuYmFzZX1cbiAgJHsocHJvcHMpID0+IHtcbiAgICBpZiAocHJvcHMuZHJvcEFyZWFTdGF0ZSA9PT0gJ3JlYWR5LWZvci1kcm9wJykge1xuICAgICAgcmV0dXJuIHN0eWxlcy5yZWFkeUZvckRyb3BcbiAgICB9XG4gICAgaWYgKHByb3BzLmRyb3BBcmVhU3RhdGUgPT09ICdhY3RpdmUtZHJhZycpIHtcbiAgICAgIHJldHVybiBzdHlsZXMuYWN0aXZlRHJhZ1xuICAgIH1cbiAgICBpZiAocHJvcHMuZHJvcEFyZWFTdGF0ZSA9PT0gJ2ZpbGUtZHJvcHBlZCcpIHtcbiAgICAgIHJldHVybiBzdHlsZXMuZmlsZURyb3BwZWRcbiAgICB9XG4gICAgcmV0dXJuIGdldERlZmF1bHREcm9wV3JhcHBlclN0eWxlcyhwcm9wcy5kcm9wQXJlYVN0YXRlKVxuICB9fVxuYFxuZnVuY3Rpb24gZ2V0RGVmYXVsdERyb3BXcmFwcGVyU3R5bGVzKF9kcm9wQXJlYVN0YXRlOiBuZXZlcikge1xuICByZXR1cm4gY3NzYGBcbn1cbiJdfQ== */"));
392
+ function getDefaultDropWrapperStyles(_dropAreaState) {
393
+ return /*#__PURE__*/css(process.env.NODE_ENV === "production" ? "" : ";label:getDefaultDropWrapperStyles;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRyb3AtYXJlYS13cmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoiZHJvcC1hcmVhLXdyYXBwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHlwZSBEcm9wem9uZVJvb3RQcm9wcyB9IGZyb20gJ3JlYWN0LWRyb3B6b25lJ1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IHN0eWxlcyB9IGZyb20gJy4vc3R5bGVzJ1xuaW1wb3J0IHsgdHlwZSBEcm9wQXJlYVN0YXRlIH0gZnJvbSAnLi4vLi4vLi4vQHR5cGVzJ1xuXG5pbnRlcmZhY2UgRHJvcFdyYXBwZXJQcm9wcyBleHRlbmRzIERyb3B6b25lUm9vdFByb3BzIHtcbiAgZHJvcEFyZWFTdGF0ZTogRHJvcEFyZWFTdGF0ZVxufVxuZXhwb3J0IGNvbnN0IERyb3BXcmFwcGVyID0gc3R5bGVkLmRpdjxEcm9wV3JhcHBlclByb3BzPmBcbiAgJHtzdHlsZXMuYmFzZX1cbiAgJHsocHJvcHMpID0+IHtcbiAgICBpZiAocHJvcHMuZHJvcEFyZWFTdGF0ZSA9PT0gJ3JlYWR5LWZvci1kcm9wJykge1xuICAgICAgcmV0dXJuIHN0eWxlcy5yZWFkeUZvckRyb3BcbiAgICB9XG4gICAgaWYgKHByb3BzLmRyb3BBcmVhU3RhdGUgPT09ICdhY3RpdmUtZHJhZycpIHtcbiAgICAgIHJldHVybiBzdHlsZXMuYWN0aXZlRHJhZ1xuICAgIH1cbiAgICBpZiAocHJvcHMuZHJvcEFyZWFTdGF0ZSA9PT0gJ2ZpbGUtZHJvcHBlZCcpIHtcbiAgICAgIHJldHVybiBzdHlsZXMuZmlsZURyb3BwZWRcbiAgICB9XG4gICAgcmV0dXJuIGdldERlZmF1bHREcm9wV3JhcHBlclN0eWxlcyhwcm9wcy5kcm9wQXJlYVN0YXRlKVxuICB9fVxuYFxuZnVuY3Rpb24gZ2V0RGVmYXVsdERyb3BXcmFwcGVyU3R5bGVzKF9kcm9wQXJlYVN0YXRlOiBuZXZlcikge1xuICByZXR1cm4gY3NzYGBcbn1cbiJdfQ== */");
394
+ }
395
+
396
+ var ActiveDragDropArea = /*#__PURE__*/lazy(() => import('./active-drag-drop-area-cec2c6b5.esm.js' /* webpackChunkName: "active-drag-drop-area" */));
397
+
398
+ var EnabledDropArea = /*#__PURE__*/lazy(() => import('./enabled-drop-area-82ec844a.esm.js' /* webpackChunkName: "enabled-drop-area" */));
399
+
400
+ var FileDropped = /*#__PURE__*/lazy(() => import('./file-dropped-area-e301d075.esm.js' /* webpackChunkName: "filed-dropped-area" */));
401
+
402
+ function getDropArea(_ref) {
403
+ let dropAreaState = _ref.dropAreaState,
404
+ isFileDropped = _ref.isFileDropped;
405
+ if (dropAreaState === 'ready-for-drop') {
406
+ return jsx(EnabledDropArea, {});
407
+ }
408
+ if (dropAreaState === 'file-dropped') {
409
+ return jsx(FileDropped, {});
410
+ }
411
+ if (dropAreaState === 'active-drag') {
412
+ return jsx(ActiveDragDropArea, {
413
+ isFileDropped: isFileDropped
414
+ });
415
+ }
416
+ return fallbackDropArea();
417
+ }
418
+ function fallbackDropArea(_invalidDropAreaState) {
419
+ return jsx(FileDropped, {});
420
+ }
421
+ function getDropAreaState(flags) {
422
+ if (flags.isDragActive) {
423
+ return 'active-drag';
424
+ }
425
+ if (flags.isReady) {
426
+ return 'file-dropped';
427
+ }
428
+ return 'ready-for-drop';
429
+ }
430
+
431
+ var messages$4 = defineMessages({
432
+ dragAndDropCSV: {
433
+ id: 'UnpublishProductsModal.dragAndDropCSV',
434
+ description: 'The message telling the user to drag and drop CSV file in the file drop area',
435
+ defaultMessage: 'Drag and drop CSV'
436
+ },
437
+ or: {
438
+ id: 'UnpublishProductsModal.or',
439
+ description: 'The word "or" in the drag and drop message',
440
+ defaultMessage: 'or'
441
+ },
442
+ browseButton: {
443
+ id: 'UnpublishProductsModal.browseFile',
444
+ defaultMessage: 'Browse file'
445
+ },
446
+ uploadAndPreview: {
447
+ id: 'UnpublishProductsModal.uploadAndPreview',
448
+ description: 'Label for the button that uploads the file and shows the preview',
449
+ defaultMessage: 'Upload and preview'
450
+ },
451
+ chooseFile: {
452
+ id: 'UnpublishProductsModal.chooseFile',
453
+ description: 'Label for a button on the file upload page, shown on ready to upload state',
454
+ defaultMessage: 'Choose file'
455
+ },
456
+ fileUploadFailed: {
457
+ id: 'UnpublishProductsModal.fileUploadFailed',
458
+ description: 'A title on the file upload page, shown on file upload error state',
459
+ defaultMessage: 'File upload failed'
460
+ },
461
+ fileFormatNotSupported: {
462
+ id: 'UnpublishProductsModal.fileFormatNotSupported',
463
+ description: 'Error message displayed when a user drags and drops a non-CSV file',
464
+ defaultMessage: 'Invalid file format: The file is not in CSV format and cannot be processed.'
465
+ },
466
+ tooManyFilesError: {
467
+ id: 'UnpublishProductsModal.tooManyFilesError',
468
+ description: 'Error message displayed when a user drags and drops multiple files at once',
469
+ defaultMessage: 'Multiple files detected: You can only drag and drop one file at a time.'
470
+ },
471
+ genericError: {
472
+ id: 'UnpublishProductsModal.genericError',
473
+ description: 'Default error message for unexpected file upload issues (for unhandled cases)',
474
+ defaultMessage: 'Error occurred: Please try uploading the file again or contact our support team for assistance.'
475
+ },
476
+ dataType: {
477
+ id: 'UnpublishProductsModal.dataType',
478
+ description: 'Label for the data type selection dropdown',
479
+ defaultMessage: 'Data type'
480
+ },
481
+ instructions: {
482
+ id: 'UnpublishProductsModal.instructions',
483
+ description: 'Label for the instructions section',
484
+ defaultMessage: 'Instructions'
485
+ }
486
+ });
487
+
488
+ 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)); }
489
+ function _isNativeReflectConstruct$1() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct$1 = function () { return !!t; })(); }
490
+ let HttpError = /*#__PURE__*/function (_Error) {
491
+ function HttpError(statusCode, statusText, errorData) {
492
+ var _this;
493
+ _classCallCheck(this, HttpError);
494
+ _this = _callSuper$1(this, HttpError, [`HTTP Error! Status code: ${statusCode}, message: "${statusText ? statusText : ''}"`]);
495
+ _this.statusCode = void 0;
496
+ _this.errorData = void 0;
497
+ _this.name = 'HttpError';
498
+ _this.statusCode = statusCode;
499
+ _this.errorData = errorData;
500
+ return _this;
501
+ }
502
+ _inherits(HttpError, _Error);
503
+ return _createClass(HttpError);
504
+ }(/*#__PURE__*/_wrapNativeSuper(Error));
505
+
506
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? _Reflect$construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
507
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
508
+ let MissingUnpublishProductsProviderError = /*#__PURE__*/function (_Error) {
509
+ function MissingUnpublishProductsProviderError() {
510
+ var _this;
511
+ _classCallCheck(this, MissingUnpublishProductsProviderError);
512
+ _this = _callSuper(this, MissingUnpublishProductsProviderError, ['useUnpublishProductsProviderError must be used within MissingUnpublishProductsProviderError']);
513
+ _this.name = 'MissingUnpublishProductsProviderError';
514
+ return _this;
515
+ }
516
+ _inherits(MissingUnpublishProductsProviderError, _Error);
517
+ return _createClass(MissingUnpublishProductsProviderError);
518
+ }(/*#__PURE__*/_wrapNativeSuper(Error));
519
+
520
+ const useUnpublishProductsContext = () => {
521
+ const context = useContext(UnpublishProductsContext);
522
+ if (!context) {
523
+ throw new MissingUnpublishProductsProviderError();
524
+ }
525
+ return context;
526
+ };
527
+
528
+ var messages$3 = defineMessages({
529
+ fileSizeExceededTitle: {
530
+ id: 'UnpublishProductsModal.sizeExceededTitle',
531
+ defaultMessage: 'File size exceeded'
532
+ },
533
+ fileSizeExceededDescription: {
534
+ id: 'UnpublishProductsModal.sizeExceededDescription',
535
+ description: 'Error description when the file size exceeds the allowable limit',
536
+ defaultMessage: 'The file exceeds the maximum allowed size of {fileSizeLimit} MB'
537
+ },
538
+ rowLimitExceededTitle: {
539
+ id: 'UnpublishProductsModal.rowLimitExceededTitle',
540
+ defaultMessage: 'Row limit exceeded'
541
+ },
542
+ rowLimitExceededDescription: {
543
+ id: 'UnpublishProductsModal.rowLimitExceededDescription',
544
+ description: 'Error description when the file contains more rows than the allowable maximum',
545
+ defaultMessage: 'The file contains more than the allowable maximum of {rowLimit} rows'
546
+ },
547
+ dropAreaNotEnoughRowsTitle: {
548
+ id: 'UnpublishProductsModal.dropAreaNotEnoughRowsTitle',
549
+ description: 'Error title shown when the uploaded CSV file does not contain a header and at least one row of data',
550
+ defaultMessage: 'Invalid CSV file'
551
+ },
552
+ dropAreaNotEnoughRowsDescription: {
553
+ id: 'UnpublishProductsModal.dropAreaNotEnoughRowsDescription',
554
+ description: 'Error description shown when the uploaded CSV file does not contain a header and at least one row of data',
555
+ defaultMessage: 'Make sure the file contains a header and at least one row of data'
556
+ },
557
+ unexpectedError: {
558
+ id: 'UnpublishProductsModal.unexpectedError',
559
+ description: 'Generic notification message when file upload fails',
560
+ defaultMessage: 'An unexpected error occurred during the file upload. Please try again, or contact support if this error occurs again.'
561
+ },
562
+ missingRequiredField: {
563
+ id: 'UnpublishProductsModal.missingRequiredField',
564
+ description: 'Error message displayed when a required field is missing',
565
+ defaultMessage: 'Missing required field'
566
+ },
567
+ missingKeyError: {
568
+ id: 'UnpublishProductsModal.missingKeyError',
569
+ description: 'Error message displayed when the uploaded file is missing the key field',
570
+ defaultMessage: "The 'key' field is missing or incomplete in some rows. Please ensure every row has a 'key' value."
571
+ },
572
+ csvFormatErrorTitle: {
573
+ id: 'UnpublishProductsModal.csvFormatErrorTitle',
574
+ description: 'Error title shown when the uploaded CSV file is not formatted correctly',
575
+ defaultMessage: 'Invalid CSV file'
576
+ },
577
+ csvFormatErrorDescription: {
578
+ id: 'FileUpload.csvFormatErrorDescription',
579
+ description: 'Error message displayed when the CSV file is not formatted correctly',
580
+ defaultMessage: "Your CSV file is not formatted correctly. Make sure the file contains only one column named 'key', which includes the product keys"
581
+ }
582
+ });
583
+
584
+ const IMPORT_TAG_KEYS = {
585
+ source: 'source'
586
+ };
587
+ const IMPORT_TAG_VALUES = {
588
+ fileUpload: 'file-upload'
589
+ };
590
+ const TAG_KEY_SOURCE_FILE_UPLOAD = `${IMPORT_TAG_KEYS.source}:${IMPORT_TAG_VALUES.fileUpload}`;
591
+ const FILE_SIZE_LIMIT_MB = 35;
592
+ const ROW_COUNT_LIMIT = 80_000;
593
+
594
+ // TODO: replace with actual links
595
+ const DOCUMENTATION_LINK = '';
596
+
597
+ // TODO: replace with actual links
598
+ const TEMPLATE_DOWNLOAD_LINK = '';
599
+
600
+ 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; }
601
+ function _objectSpread$8(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context2 = ownKeys$8(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context3 = ownKeys$8(Object(t))).call(_context3, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
602
+ const addProxyPrefixToUrl = (uri, proxy) => {
603
+ return proxy ? `/proxy/${proxy}${uri}` : uri;
604
+ };
605
+ const fetchUsingXhr = _ref2 => {
606
+ let url = _ref2.url,
607
+ payload = _ref2.payload,
608
+ config = _ref2.config,
609
+ onProgress = _ref2.onProgress,
610
+ onSuccess = _ref2.onSuccess,
611
+ onError = _ref2.onError;
612
+ const options = createHttpClientOptions({
613
+ headers: _objectSpread$8({
614
+ 'Content-Type': 'application/json'
615
+ }, config?.headers)
616
+ });
617
+ const xhr = new XMLHttpRequest();
618
+ xhr.open(config?.method, buildApiUrl(addProxyPrefixToUrl(url, config?.proxy)), true);
619
+ // Include cookies in the request
620
+ xhr.withCredentials = true;
621
+ if (options.headers) {
622
+ var _context;
623
+ _forEachInstanceProperty(_context = _Object$keys(options.headers)).call(_context, key => {
624
+ xhr.setRequestHeader(key, options.headers[key]);
625
+ });
626
+ }
627
+ xhr.upload.onprogress = function (event) {
628
+ if (event.lengthComputable) {
629
+ const percentComplete = event.loaded / event.total * 100;
630
+ onProgress(percentComplete);
631
+ }
632
+ };
633
+ xhr.onload = function () {
634
+ const data = JSON.parse(xhr.responseText);
635
+ // Code copied from `executeHttpClientRequest` to replicate the same behavior
636
+ const refreshedSessionToken = xhr.getResponseHeader('x-refreshed-session-token');
637
+ if (refreshedSessionToken) {
638
+ oidcStorage.setActiveSession(refreshedSessionToken);
639
+ }
640
+ if (xhr.status >= 200 && xhr.status < 300) {
641
+ onSuccess(data);
642
+ } else {
643
+ onError(new HttpError(xhr.status, xhr.statusText, data));
644
+ }
645
+ };
646
+ xhr.onerror = function () {
647
+ const errorData = JSON.parse(xhr.responseText);
648
+ onError(new HttpError(xhr.status, xhr.statusText, errorData));
649
+ };
650
+ xhr.onabort = function () {
651
+ onError(new DOMException('Aborted', 'AbortError'));
652
+ };
653
+ xhr.send(payload);
654
+ return xhr;
655
+ };
656
+
657
+ function uploadFileForImport(_ref) {
658
+ let projectKey = _ref.projectKey,
659
+ containerKey = _ref.containerKey,
660
+ file = _ref.file,
661
+ abortSignal = _ref.abortSignal,
662
+ onSuccess = _ref.onSuccess,
663
+ onProgress = _ref.onProgress,
664
+ onError = _ref.onError;
665
+ const uri = getFileUploadURL(projectKey, containerKey);
666
+ const formData = new FormData();
667
+ formData.append('file', file, file.name);
668
+ return fetchUsingXhr({
669
+ url: uri,
670
+ payload: formData,
671
+ config: {
672
+ abortSignal,
673
+ proxy: MC_API_PROXY_TARGETS.IMPORT,
674
+ method: 'POST',
675
+ headers: {
676
+ 'Content-Type': null
677
+ }
678
+ },
679
+ onProgress,
680
+ onSuccess,
681
+ onError
682
+ });
683
+ }
684
+
685
+ const useUpload = () => {
686
+ const intl = useIntl();
687
+ const projectKey = useApplicationContext(context => context.project?.key);
688
+ const _useUnpublishProducts = useUnpublishProductsContext(),
689
+ state = _useUnpublishProducts.state,
690
+ actions = _useUnpublishProducts.actions;
691
+ const asyncDispatch = useAsyncDispatch();
692
+ const showNotification = useShowNotification();
693
+ React.useEffect(() => {
694
+ return () => {
695
+ if (state.abortController) state.abortController.abort();
696
+ };
697
+ }, [state.abortController]);
698
+ const isFileValid = async file => {
699
+ const errors = [];
700
+ const rowCount = await getRowCount(file);
701
+ if (rowCount < 1) errors.push({
702
+ title: intl.formatMessage(messages$3.dropAreaNotEnoughRowsTitle),
703
+ description: intl.formatMessage(messages$3.dropAreaNotEnoughRowsDescription)
704
+ });
705
+ if (file.size > toBytes(FILE_SIZE_LIMIT_MB)) errors.push({
706
+ title: intl.formatMessage(messages$3.fileSizeExceededTitle),
707
+ description: intl.formatMessage(messages$3.fileSizeExceededDescription, {
708
+ fileSizeLimit: intl.formatNumber(FILE_SIZE_LIMIT_MB)
709
+ })
710
+ });
711
+ if (!(await hasSingleKeyColumn(file))) {
712
+ errors.push({
713
+ title: intl.formatMessage(messages$3.csvFormatErrorTitle),
714
+ description: intl.formatMessage(messages$3.csvFormatErrorDescription)
715
+ });
716
+ }
717
+ if (rowCount > ROW_COUNT_LIMIT) errors.push({
718
+ title: intl.formatMessage(messages$3.rowLimitExceededTitle),
719
+ description: intl.formatMessage(messages$3.rowLimitExceededDescription, {
720
+ rowLimit: intl.formatNumber(ROW_COUNT_LIMIT)
721
+ })
722
+ });
723
+ if (errors.length > 0) {
724
+ actions.setFileUploadErrors(errors);
725
+ actions.setCurrentStep('upload-error');
726
+ return false;
727
+ }
728
+ return true;
729
+ };
730
+ const handleUploadError = error => {
731
+ if (isAbortError(error)) {
732
+ actions.cancelImport();
733
+ return;
734
+ }
735
+ if (error instanceof HttpError) {
736
+ if (error.errorData?.code === 'MISSING_KEY_ERROR') {
737
+ actions.setFileUploadErrors([{
738
+ title: intl.formatMessage(messages$3.missingRequiredField),
739
+ description: intl.formatMessage(messages$3.missingKeyError)
740
+ }]);
741
+ actions.setCurrentStep('upload-error');
742
+ } else {
743
+ actions.cancelImport();
744
+ showNotification({
745
+ kind: 'error',
746
+ domain: DOMAINS.PAGE,
747
+ text: intl.formatMessage(messages$3.unexpectedError)
748
+ });
749
+ }
750
+ } else {
751
+ actions.cancelImport();
752
+ showNotification({
753
+ kind: 'error',
754
+ domain: DOMAINS.PAGE,
755
+ text: String(error)
756
+ });
757
+ reportErrorToSentry(new Error('Upload File Error: An unexpected issue occurred while uploading the file'), {
758
+ extra: {
759
+ error,
760
+ projectKey,
761
+ containerKey: state.containerKey,
762
+ fileSizeInBytes: state.droppedFile?.size
763
+ }
764
+ });
765
+ }
766
+ };
767
+ const handleUploadAndValidation = async () => {
768
+ if (!projectKey || !state.droppedFile) return;
769
+ const canUpload = await isFileValid(state.droppedFile);
770
+ if (!canUpload) return;
771
+ actions.setCurrentStep('uploading');
772
+ const containerKey = encodeFileNameWithTimestampToContainerKey(state.droppedFile.name);
773
+ actions.setContainerKey(containerKey);
774
+ try {
775
+ await createImportContainerForFileUpload({
776
+ key: containerKey,
777
+ tags: [TAG_KEY_SOURCE_FILE_UPLOAD],
778
+ resourceType: 'product',
779
+ settings: {
780
+ resourceType: 'product-draft',
781
+ format: 'CSV',
782
+ options: {
783
+ unpublishAllChanges: true
784
+ }
785
+ }
786
+ }, projectKey, asyncDispatch);
787
+ const newAbortController = uploadFileForImport({
788
+ projectKey,
789
+ containerKey,
790
+ file: state.droppedFile,
791
+ onSuccess: fileUploadResponse => {
792
+ actions.setUploadFileResponse(fileUploadResponse);
793
+ actions.setCurrentStep('upload-preview');
794
+ },
795
+ onProgress: progress => {
796
+ actions.setProgress(progress);
797
+ },
798
+ onError: error => {
799
+ deleteImportContainer(projectKey, containerKey, asyncDispatch);
800
+ handleUploadError(error);
801
+ }
802
+ });
803
+ actions.setAbortController(newAbortController);
804
+ } catch (error) {
805
+ deleteImportContainer(projectKey, containerKey, asyncDispatch);
806
+ handleUploadError(error);
807
+ }
808
+ };
809
+ return {
810
+ handleUploadAndValidation
811
+ };
812
+ };
813
+
814
+ 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; }
815
+ function _objectSpread$7(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context3 = ownKeys$7(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$7(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
816
+ const FileDropArea = () => {
817
+ const intl = useIntl();
818
+ const _useUnpublishProducts = useUnpublishProductsContext(),
819
+ state = _useUnpublishProducts.state,
820
+ actions = _useUnpublishProducts.actions;
821
+ const showNotification = useShowNotification();
822
+ const onDrop = React.useCallback(_ref => {
823
+ let _ref2 = _slicedToArray(_ref, 1),
824
+ file = _ref2[0];
825
+ if (!file) return;
826
+ actions.setDroppedFile(file);
827
+ }, [actions]);
828
+ const _useDropzone = useDropzone({
829
+ onDrop,
830
+ multiple: false,
831
+ accept: {
832
+ 'text/csv': ['.csv']
833
+ },
834
+ onDropRejected: _ref3 => {
835
+ var _context, _context2;
836
+ let _ref4 = _slicedToArray(_ref3, 1),
837
+ rejectedFile = _ref4[0];
838
+ if (_someInstanceProperty(_context = rejectedFile.errors).call(_context, error => error.code === 'too-many-files')) {
839
+ showNotification({
840
+ kind: 'error',
841
+ domain: DOMAINS.PAGE,
842
+ text: intl.formatMessage(messages$4.tooManyFilesError)
843
+ });
844
+ return;
845
+ }
846
+ if (_someInstanceProperty(_context2 = rejectedFile.errors).call(_context2, error => error.code === 'file-invalid-type')) {
847
+ showNotification({
848
+ kind: 'error',
849
+ domain: DOMAINS.PAGE,
850
+ text: intl.formatMessage(messages$4.fileFormatNotSupported)
851
+ });
852
+ } else {
853
+ showNotification({
854
+ kind: 'error',
855
+ domain: DOMAINS.PAGE,
856
+ text: intl.formatMessage(messages$4.genericError)
857
+ });
858
+ }
859
+ }
860
+ }),
861
+ getRootProps = _useDropzone.getRootProps,
862
+ getInputProps = _useDropzone.getInputProps,
863
+ isDragActive = _useDropzone.isDragActive;
864
+ const dropAreaState = React.useMemo(() => getDropAreaState({
865
+ isReady: Boolean(state.droppedFile),
866
+ isDragActive
867
+ }), [state.droppedFile, isDragActive]);
868
+ const dropArea = getDropArea({
869
+ dropAreaState,
870
+ isFileDropped: Boolean(state.droppedFile)
871
+ });
872
+ return jsxs(DropWrapper, _objectSpread$7(_objectSpread$7({
873
+ role: "presentation"
874
+ }, getRootProps()), {}, {
875
+ dropAreaState: dropAreaState,
876
+ children: [jsx("input", _objectSpread$7({
877
+ "data-testid": "file-input"
878
+ }, getInputProps())), jsx(Constraints.Horizontal, {
879
+ children: dropArea
880
+ })]
881
+ }));
882
+ };
883
+
884
+ var sharedMessages = defineMessages({
885
+ unpublishModalTitle: {
886
+ id: 'UnpublishProductsModal.unpublishModalTitle',
887
+ description: 'The title of the modal',
888
+ defaultMessage: 'Bulk unpublish via CSV'
889
+ },
890
+ startBulkUnpublish: {
891
+ id: 'UnpublishProductsModal.startBulkUnpublish',
892
+ description: 'Start bulk unpublish button',
893
+ defaultMessage: 'Start bulk unpublish'
894
+ },
895
+ cancel: {
896
+ id: 'UnpublishProductsModal.cancel',
897
+ description: 'The label for the cancel button',
898
+ defaultMessage: 'Cancel'
899
+ }
900
+ });
901
+
902
+ var messages$2 = defineMessages({
903
+ fileUploadInstructions: {
904
+ id: 'UnpublishProductsModal.fileUploadInstructions',
905
+ description: 'Instructions for uploading a CSV file with product keys to unpublish',
906
+ defaultMessage: "The CSV file must contain the product keys to be unpublished under the header 'key'. Maximum file size is {maxFileSize} MB with a limit of {maxRowCount} rows. Download <csvTemplateLink>the CSV template</csvTemplateLink> or refer to <documentationLink>the documentation</documentationLink>."
907
+ }
908
+ });
909
+
910
+ 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; }
911
+ 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; }
912
+ const Instructions = () => {
913
+ const intl = useIntl();
914
+ return jsx(Text.Body, {
915
+ intlMessage: _objectSpread$6(_objectSpread$6({}, messages$2.fileUploadInstructions), {}, {
916
+ values: {
917
+ maxFileSize: intl.formatNumber(FILE_SIZE_LIMIT_MB),
918
+ maxRowCount: intl.formatNumber(ROW_COUNT_LIMIT),
919
+ csvTemplateLink: msg => jsx(Link, {
920
+ tone: "secondary",
921
+ isExternal: true,
922
+ to: TEMPLATE_DOWNLOAD_LINK,
923
+ children: msg
924
+ }),
925
+ documentationLink: msg => jsx(Link, {
926
+ tone: "secondary",
927
+ isExternal: true,
928
+ to: DOCUMENTATION_LINK,
929
+ children: msg
930
+ })
931
+ }
932
+ })
933
+ });
934
+ };
935
+
936
+ const Upload = () => {
937
+ const _useUnpublishProducts = useUnpublishProductsContext(),
938
+ state = _useUnpublishProducts.state,
939
+ onClose = _useUnpublishProducts.onClose;
940
+ const intl = useIntl();
941
+ const _useUpload = useUpload(),
942
+ handleUploadAndValidation = _useUpload.handleUploadAndValidation;
943
+ return jsx(FormDialog, {
944
+ size: 16,
945
+ isOpen: true,
946
+ title: intl.formatMessage(sharedMessages.unpublishModalTitle),
947
+ labelPrimary: intl.formatMessage(messages$4.uploadAndPreview),
948
+ onPrimaryButtonClick: handleUploadAndValidation,
949
+ isPrimaryButtonDisabled: !Boolean(state.droppedFile),
950
+ onSecondaryButtonClick: () => onClose({
951
+ shouldDeleteImportContainer: true
952
+ }),
953
+ onClose: () => onClose({
954
+ shouldDeleteImportContainer: true
955
+ }),
956
+ children: jsx(Masking.Unmask, {
957
+ children: jsxs(Spacings.Stack, {
958
+ scale: "m",
959
+ children: [jsx(Instructions, {}), jsx(FileDropArea, {})]
960
+ })
961
+ })
962
+ });
963
+ };
964
+
965
+ 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; }
966
+ function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$5(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$5(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
967
+ var FileIcon = function FileIcon(props) {
968
+ return jsxs("svg", _objectSpread$5(_objectSpread$5({}, props), {}, {
969
+ children: [jsx("mask", {
970
+ id: "a",
971
+ style: {
972
+ maskType: "alpha"
973
+ },
974
+ maskUnits: "userSpaceOnUse",
975
+ x: "0",
976
+ y: "0",
977
+ width: "32",
978
+ height: "32",
979
+ children: jsx("path", {
980
+ fill: "#D9D9D9",
981
+ d: "M0 0h32v32H0z"
982
+ })
983
+ }), jsx("g", {
984
+ mask: "url(#a)",
985
+ children: jsx("path", {
986
+ d: "M14.667 25.333h2.666v-5.566l2.134 2.133 1.866-1.9L16 14.667 10.667 20l1.9 1.867 2.1-2.1v5.566Zm-6.667 4a2.568 2.568 0 0 1-1.883-.783 2.568 2.568 0 0 1-.784-1.883V5.333c0-.733.261-1.36.784-1.883A2.568 2.568 0 0 1 8 2.667h10.667l8 8v16c0 .733-.261 1.36-.784 1.883a2.568 2.568 0 0 1-1.883.783H8ZM17.333 12H24l-6.667-6.667V12Z",
987
+ fill: "#B1ACFF"
988
+ })
989
+ })]
990
+ }));
991
+ };
992
+ FileIcon.defaultProps = {
993
+ width: "32",
994
+ height: "32",
995
+ fill: "none",
996
+ xmlns: "http://www.w3.org/2000/svg"
997
+ };
998
+ const Uploading = () => {
999
+ const intl = useIntl();
1000
+ const _useUnpublishProducts = useUnpublishProductsContext(),
1001
+ state = _useUnpublishProducts.state,
1002
+ actions = _useUnpublishProducts.actions,
1003
+ onClose = _useUnpublishProducts.onClose;
1004
+ if (state.droppedFile?.name) return jsx(InfoDialog, {
1005
+ size: 16,
1006
+ isOpen: true,
1007
+ title: intl.formatMessage(sharedMessages.unpublishModalTitle),
1008
+ onClose: () => onClose({
1009
+ shouldDeleteImportContainer: true
1010
+ }),
1011
+ children: jsxs(Spacings.Stack, {
1012
+ scale: "m",
1013
+ children: [jsxs(Spacings.Inline, {
1014
+ alignItems: "center",
1015
+ justifyContent: "space-between",
1016
+ children: [jsxs(Spacings.Inline, {
1017
+ alignItems: "center",
1018
+ children: [jsx(FileIcon, {}), jsx(Spacings.Inline, {
1019
+ children: jsx(Constraints.Horizontal, {
1020
+ max: 10,
1021
+ children: jsx(Text.Body, {
1022
+ truncate: true,
1023
+ fontWeight: "bold",
1024
+ children: state.droppedFile.name
1025
+ })
1026
+ })
1027
+ }), jsxs(Text.Body, {
1028
+ tone: "secondary",
1029
+ children: ["(", intl.formatNumber(convertFileSizeToKB(state.droppedFile.size)), ' ', "KB)"]
1030
+ })]
1031
+ }), jsx(SecondaryButton, {
1032
+ tone: "secondary",
1033
+ size: "medium",
1034
+ label: intl.formatMessage(sharedMessages.cancel),
1035
+ onClick: () => {
1036
+ actions.setCurrentStep('upload');
1037
+ state.abortController.abort();
1038
+ }
1039
+ })]
1040
+ }), jsx(ProgressBar, {
1041
+ barWidth: "scale",
1042
+ height: "10",
1043
+ progress: state.progress
1044
+ }), jsx("div", {})]
1045
+ })
1046
+ });
1047
+ return null;
1048
+ };
1049
+
1050
+ var messages$1 = defineMessages({
1051
+ uploadNewFile: {
1052
+ id: 'UnpublishProductsModal.uploadNewFile',
1053
+ defaultMessage: 'Upload new file'
1054
+ },
1055
+ uploadErrorDescription: {
1056
+ id: 'UnpublishProductsModal.uploadError',
1057
+ description: 'Title when errors detected while uploading file',
1058
+ defaultMessage: 'There {errorsCount, plural, one {is <b>1</b> error} other {are <b>{errorsCount}</b> errors}} detected while uploading the file "{fileName}".'
1059
+ },
1060
+ errorType: {
1061
+ id: 'UnpublishProductsModal.errorType',
1062
+ description: 'Error type" column',
1063
+ defaultMessage: 'Error type'
1064
+ },
1065
+ details: {
1066
+ id: 'UnpublishProductsModal.details',
1067
+ description: '"Details" column',
1068
+ defaultMessage: 'Details'
1069
+ }
1070
+ });
1071
+
1072
+ 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; }
1073
+ function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context2 = ownKeys$4(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context3 = ownKeys$4(Object(t))).call(_context3, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1074
+ const getColumns = () => [{
1075
+ key: 'errorType',
1076
+ label: jsx(FormattedMessage, _objectSpread$4({}, messages$1.errorType)),
1077
+ width: 'max-content'
1078
+ }, {
1079
+ key: 'details',
1080
+ label: jsx(FormattedMessage, _objectSpread$4({}, messages$1.details))
1081
+ }];
1082
+ const UploadErrorTable = props => {
1083
+ var _context;
1084
+ const pagination = usePaginationState({
1085
+ perPage: 10
1086
+ });
1087
+ const startIndex = (pagination.page.value - 1) * pagination.perPage.value;
1088
+ const endIndex = startIndex + pagination.perPage.value;
1089
+ const currentPageRows = _sliceInstanceProperty(_context = props.rows).call(_context, startIndex, endIndex);
1090
+ const shouldShowPagination = props.rows.length > pagination.perPage.value;
1091
+ return jsxs(Spacings.Stack, {
1092
+ scale: "l",
1093
+ children: [jsx(DataTable, {
1094
+ verticalCellAlignment: "center",
1095
+ isCondensed: true,
1096
+ rows: currentPageRows,
1097
+ columns: getColumns(),
1098
+ itemRenderer: itemRenderer
1099
+ }), shouldShowPagination && jsx(PageNavigator, {
1100
+ onPageChange: pagination.page.onChange,
1101
+ page: pagination.page.value,
1102
+ totalPages: Math.ceil(props.rows.length / pagination.perPage.value)
1103
+ })]
1104
+ });
1105
+ };
1106
+ function itemRenderer(item, column) {
1107
+ switch (column.key) {
1108
+ case 'errorType':
1109
+ return jsx(Stamp, {
1110
+ isCondensed: true,
1111
+ label: item.title,
1112
+ tone: "critical"
1113
+ });
1114
+ case 'details':
1115
+ return jsx(Text.Body, {
1116
+ children: item.description
1117
+ });
1118
+ default:
1119
+ return null;
1120
+ }
1121
+ }
1122
+
1123
+ 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; }
1124
+ function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$3(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$3(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1125
+ const UploadErrorsModal = () => {
1126
+ const intl = useIntl();
1127
+ const _useUnpublishProducts = useUnpublishProductsContext(),
1128
+ state = _useUnpublishProducts.state,
1129
+ actions = _useUnpublishProducts.actions,
1130
+ onClose = _useUnpublishProducts.onClose;
1131
+ const errorsCount = state.fileUploadErrors.length;
1132
+ return jsx(InfoDialog, {
1133
+ size: 16,
1134
+ isOpen: true,
1135
+ title: intl.formatMessage(sharedMessages.unpublishModalTitle),
1136
+ onClose: () => onClose(),
1137
+ children: jsx(Masking.Unmask, {
1138
+ children: jsxs(Spacings.Stack, {
1139
+ scale: "l",
1140
+ children: [jsx(Masking.Mask, {
1141
+ children: jsx(Text.Body, {
1142
+ intlMessage: _objectSpread$3(_objectSpread$3({}, messages$1.uploadErrorDescription), {}, {
1143
+ values: {
1144
+ fileName: state.droppedFile?.name,
1145
+ errorsCount: intl.formatNumber(errorsCount),
1146
+ b: getBold$2
1147
+ }
1148
+ })
1149
+ })
1150
+ }), jsx(UploadErrorTable, {
1151
+ rows: mapFileUploadErrorsToUploadFileErrorRows(state.fileUploadErrors)
1152
+ }), jsxs(Spacings.Inline, {
1153
+ scale: "m",
1154
+ justifyContent: "flex-end",
1155
+ children: [jsx(SecondaryButton, {
1156
+ label: intl.formatMessage(sharedMessages.cancel),
1157
+ onClick: () => onClose()
1158
+ }), jsx(PrimaryButton, {
1159
+ iconLeft: jsx(ImportIcon, {}),
1160
+ label: intl.formatMessage(messages$1.uploadNewFile),
1161
+ onClick: () => actions.uploadNewFile()
1162
+ })]
1163
+ })]
1164
+ })
1165
+ })
1166
+ });
1167
+ };
1168
+ function getBold$2(msg) {
1169
+ return jsx(Text.Body, {
1170
+ as: "span",
1171
+ isBold: true,
1172
+ children: msg
1173
+ });
1174
+ }
1175
+
1176
+ var messages = defineMessages({
1177
+ continue: {
1178
+ id: 'UnpublishProductsModal.continue',
1179
+ description: 'Continue button',
1180
+ defaultMessage: 'Continue'
1181
+ },
1182
+ heresAPreview: {
1183
+ id: 'UnpublishProductsModal.heresAPreview',
1184
+ description: 'Here is a preview',
1185
+ defaultMessage: "Here's a preview:"
1186
+ },
1187
+ productsToBeUnpublished: {
1188
+ id: 'UnpublishProductsModal.productsToBeUnpublished',
1189
+ description: 'Products to be unpublished',
1190
+ defaultMessage: '{count, plural, one {<b>{count}</b> product to be unpublished} other {<b>{count}</b> products to be unpublished}}'
1191
+ },
1192
+ confirmationQuestion: {
1193
+ id: 'UnpublishProductsModal.confirmationQuestion',
1194
+ description: 'Confirmation question',
1195
+ defaultMessage: 'Are you sure you want to unpublish the products? '
1196
+ },
1197
+ confirmationText: {
1198
+ id: 'UnpublishProductsModal.confirmationText',
1199
+ description: 'Confirmation text',
1200
+ defaultMessage: '{count, plural, one {You are about to unpublish <b>{count}</b> product in the project: <b>{projectName}</b>.} other {You are about to unpublish <b>{count}</b> products in the project: <b>{projectName}</b>.}}'
1201
+ },
1202
+ importStarted: {
1203
+ id: 'UnpublishProductsModal.importStarted',
1204
+ description: 'Import started',
1205
+ defaultMessage: '<b>Your import for bulk unpublish has started.</b><newline></newline>Go to <logsLink>Import logs</logsLink> to view the progress.'
1206
+ },
1207
+ preparingImport: {
1208
+ id: 'UnpublishProductsModal.preparingImport',
1209
+ description: 'Preparing import',
1210
+ defaultMessage: '<b>Prepare bulk unpublish.</b><newline></newline>Once preparation is complete, you can track the progress <logsLink>in the Import logs</logsLink>. The data will be unpublished after the import is finalized.'
1211
+ }
1212
+ });
1213
+
1214
+ 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; }
1215
+ 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; }
1216
+ 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)."; }
1217
+ const getNewLine = () => jsx("br", {});
1218
+ const getImportLogsLink = (msg, projectKey) => jsx(Link, {
1219
+ to: `/${projectKey}/operations/import/logs`,
1220
+ children: msg
1221
+ });
1222
+ var _ref2 = process.env.NODE_ENV === "production" ? {
1223
+ name: "1vs9i7r",
1224
+ styles: "width:360px"
1225
+ } : {
1226
+ name: "g36yzl-ImportRunningTextNotification",
1227
+ styles: "width:360px;label:ImportRunningTextNotification;",
1228
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVucHVibGlzaC1wcm9kdWN0cy1jb25maXJtYXRpb24tbW9kYWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCWSIsImZpbGUiOiJ1bnB1Ymxpc2gtcHJvZHVjdHMtY29uZmlybWF0aW9uLW1vZGFsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJ1xuaW1wb3J0IHsgdXNlU2hvd05vdGlmaWNhdGlvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FjdGlvbnMtZ2xvYmFsJ1xuaW1wb3J0IHsgQ29uZmlybWF0aW9uRGlhbG9nIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cydcbmltcG9ydCB7IHVzZUFwcGxpY2F0aW9uQ29udGV4dCB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLXNoZWxsLWNvbm5lY3RvcnMnXG5pbXBvcnQgeyBET01BSU5TIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvY29uc3RhbnRzJ1xuaW1wb3J0IHsgTWFza2luZyBhcyBGdWxsU3RvcnlNYXNraW5nIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvZnVsbHN0b3J5J1xuaW1wb3J0IHsgdXNlQXN5bmNEaXNwYXRjaCB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3NkaydcbmltcG9ydCB7IExpbmssIFNwYWNpbmdzLCBUZXh0IH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcydcbmltcG9ydCB7IHByb2Nlc3NVcGxvYWRlZEZpbGUgfSBmcm9tICcuLi8uLi9AYXBpJ1xuaW1wb3J0IHsgdXNlVW5wdWJsaXNoUHJvZHVjdHNDb250ZXh0IH0gZnJvbSAnLi4vLi4vQGhvb2tzJ1xuaW1wb3J0IHNoYXJlZE1lc3NhZ2VzIGZyb20gJy4uLy4uL21lc3NhZ2VzJ1xuXG5jb25zdCBnZXROZXdMaW5lID0gKCkgPT4gPGJyIC8+XG5jb25zdCBnZXRJbXBvcnRMb2dzTGluayA9IChtc2c6IHN0cmluZywgcHJvamVjdEtleT86IHN0cmluZykgPT4gKFxuICA8TGluayB0bz17YC8ke3Byb2plY3RLZXl9L29wZXJhdGlvbnMvaW1wb3J0L2xvZ3NgfT57bXNnfTwvTGluaz5cbilcblxuY29uc3QgSW1wb3J0UnVubmluZ1RleHROb3RpZmljYXRpb24gPSAocHJvcHM6IHsgcHJvamVjdEtleTogc3RyaW5nIH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17Y3NzYFxuICAgICAgd2lkdGg6IDM2MHB4O1xuICAgIGB9XG4gID5cbiAgICA8VGV4dC5Cb2R5XG4gICAgICBpbnRsTWVzc2FnZT17e1xuICAgICAgICAuLi5tZXNzYWdlcy5pbXBvcnRTdGFydGVkLFxuICAgICAgICB2YWx1ZXM6IHtcbiAgICAgICAgICBuZXdsaW5lOiBnZXROZXdMaW5lLFxuICAgICAgICAgIGxvZ3NMaW5rOiAobXNnOiBzdHJpbmcpID0+IGdldEltcG9ydExvZ3NMaW5rKG1zZywgcHJvcHMucHJvamVjdEtleSksXG4gICAgICAgICAgYjogZ2V0Qm9sZCxcbiAgICAgICAgfSxcbiAgICAgIH19XG4gICAgLz5cbiAgPC9kaXY+XG4pXG5cbmNvbnN0IEltcG9ydFByZXBhcmluZ1RleHROb3RpZmljYXRpb24gPSAocHJvcHM6IHsgcHJvamVjdEtleTogc3RyaW5nIH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17Y3NzYFxuICAgICAgd2lkdGg6IDM2MHB4O1xuICAgIGB9XG4gID5cbiAgICA8VGV4dC5Cb2R5XG4gICAgICBpbnRsTWVzc2FnZT17e1xuICAgICAgICAuLi5tZXNzYWdlcy5wcmVwYXJpbmdJbXBvcnQsXG4gICAgICAgIHZhbHVlczoge1xuICAgICAgICAgIG5ld2xpbmU6IGdldE5ld0xpbmUsXG4gICAgICAgICAgbG9nc0xpbms6IChtc2c6IHN0cmluZykgPT4gZ2V0SW1wb3J0TG9nc0xpbmsobXNnLCBwcm9wcy5wcm9qZWN0S2V5KSxcbiAgICAgICAgICBiOiBnZXRCb2xkLFxuICAgICAgICB9LFxuICAgICAgfX1cbiAgICAvPlxuICA8L2Rpdj5cbilcblxuZXhwb3J0IGNvbnN0IFVucHVibGlzaFByb2R1Y3RzQ29uZmlybWF0aW9uTW9kYWwgPSAoKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKClcbiAgY29uc3QgeyBzdGF0ZSwgb25DbG9zZSB9ID0gdXNlVW5wdWJsaXNoUHJvZHVjdHNDb250ZXh0KClcbiAgY29uc3QgeyBwcm9qZWN0S2V5LCBwcm9qZWN0TmFtZSB9ID0gdXNlQXBwbGljYXRpb25Db250ZXh0KChjb250ZXh0KSA9PiAoe1xuICAgIHByb2plY3RLZXk6IGNvbnRleHQucHJvamVjdD8ua2V5LFxuICAgIHByb2plY3ROYW1lOiBjb250ZXh0LnByb2plY3Q/Lm5hbWUsXG4gIH0pKVxuXG4gIGNvbnN0IGFzeW5jRGlzcGF0Y2ggPSB1c2VBc3luY0Rpc3BhdGNoKClcblxuICBjb25zdCBzaG93Tm90aWZpY2F0aW9uID0gdXNlU2hvd05vdGlmaWNhdGlvbigpXG5cbiAgcmV0dXJuIChcbiAgICA8Q29uZmlybWF0aW9uRGlhbG9nXG4gICAgICB0aXRsZT17aW50bC5mb3JtYXRNZXNzYWdlKHNoYXJlZE1lc3NhZ2VzLnVucHVibGlzaE1vZGFsVGl0bGUpfVxuICAgICAgbGFiZWxQcmltYXJ5PXtpbnRsLmZvcm1hdE1lc3NhZ2Uoc2hhcmVkTWVzc2FnZXMuc3RhcnRCdWxrVW5wdWJsaXNoKX1cbiAgICAgIGlzT3Blbj17dHJ1ZX1cbiAgICAgIG9uQ2xvc2U9eygpID0+IG9uQ2xvc2UoeyBzaG91bGREZWxldGVJbXBvcnRDb250YWluZXI6IHRydWUgfSl9XG4gICAgICBvbkNhbmNlbD17KCkgPT4gb25DbG9zZSh7IHNob3VsZERlbGV0ZUltcG9ydENvbnRhaW5lcjogdHJ1ZSB9KX1cbiAgICAgIGRhdGFBdHRyaWJ1dGVzUHJpbWFyeUJ1dHRvbj17e1xuICAgICAgICAnZGF0YS10ZXN0LWlkJzogJ2NvbmZpcm1hdGlvbi1kaWFsb2ctY29uZmlybScsXG4gICAgICB9fVxuICAgICAgZGF0YUF0dHJpYnV0ZXNTZWNvbmRhcnlCdXR0b249e3tcbiAgICAgICAgJ2RhdGEtdGVzdC1pZCc6ICdjb25maXJtYXRpb24tZGlhbG9nLWNhbmNlbCcsXG4gICAgICB9fVxuICAgICAgb25Db25maXJtPXthc3luYyAoKSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgY2FuQ29uZmlybSA9XG4gICAgICAgICAgICBwcm9qZWN0S2V5ICYmIHN0YXRlLmNvbnRhaW5lcktleSAmJiBzdGF0ZS5kcm9wcGVkRmlsZT8ubmFtZVxuICAgICAgICAgIGlmICghY2FuQ29uZmlybSkgcmV0dXJuXG4gICAgICAgICAgb25DbG9zZSgpXG4gICAgICAgICAgc2hvd05vdGlmaWNhdGlvbihcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAga2luZDogJ2luZm8nLFxuICAgICAgICAgICAgICBkb21haW46IERPTUFJTlMuU0lERSxcbiAgICAgICAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICAgICAgICB0ZXh0OiA8SW1wb3J0UHJlcGFyaW5nVGV4dE5vdGlmaWNhdGlvbiBwcm9qZWN0S2V5PXtwcm9qZWN0S2V5fSAvPixcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGRpc21pc3NBZnRlcjogNTAwMCxcbiAgICAgICAgICAgIH1cbiAgICAgICAgICApXG4gICAgICAgICAgYXdhaXQgcHJvY2Vzc1VwbG9hZGVkRmlsZSh7XG4gICAgICAgICAgICBwcm9qZWN0S2V5LFxuICAgICAgICAgICAgY29udGFpbmVyS2V5OiBzdGF0ZS5jb250YWluZXJLZXkhLFxuICAgICAgICAgICAgYXN5bmNEaXNwYXRjaCxcbiAgICAgICAgICB9KVxuICAgICAgICAgIHNob3dOb3RpZmljYXRpb24oXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGtpbmQ6ICdpbmZvJyxcbiAgICAgICAgICAgICAgZG9tYWluOiBET01BSU5TLlNJREUsXG4gICAgICAgICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgICAgICAgdGV4dDogPEltcG9ydFJ1bm5pbmdUZXh0Tm90aWZpY2F0aW9uIHByb2plY3RLZXk9e3Byb2plY3RLZXl9IC8+LFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgZGlzbWlzc0FmdGVyOiA1MDAwLFxuICAgICAgICAgICAgfVxuICAgICAgICAgIClcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBvbkNsb3NlKHsgc2hvdWxkRGVsZXRlSW1wb3J0Q29udGFpbmVyOiB0cnVlIH0pXG4gICAgICAgICAgc2hvd05vdGlmaWNhdGlvbih7XG4gICAgICAgICAgICBraW5kOiAnZXJyb3InLFxuICAgICAgICAgICAgZG9tYWluOiBET01BSU5TLlBBR0UsXG4gICAgICAgICAgICB0ZXh0OiBTdHJpbmcoZXJyb3IpLFxuICAgICAgICAgIH0pXG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgICBzaXplPXsxNn1cbiAgICA+XG4gICAgICA8RnVsbFN0b3J5TWFza2luZy5Vbm1hc2s+XG4gICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgICAgaW50bE1lc3NhZ2U9e3tcbiAgICAgICAgICAgICAgLi4ubWVzc2FnZXMuY29uZmlybWF0aW9uVGV4dCxcbiAgICAgICAgICAgICAgdmFsdWVzOiB7XG4gICAgICAgICAgICAgICAgcHJvamVjdE5hbWU6IHByb2plY3ROYW1lLFxuICAgICAgICAgICAgICAgIC8vIFRPRE86IFJlcGxhY2Ugd2l0aCBhY3R1YWwgY291bnRcbiAgICAgICAgICAgICAgICBjb3VudDogaW50bC5mb3JtYXROdW1iZXIoc3RhdGUudXBsb2FkRmlsZVJlc3BvbnNlPy5yb3dzQ291bnQpLFxuICAgICAgICAgICAgICAgIGI6IGdldEJvbGQsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9fVxuICAgICAgICAgIC8+XG4gICAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuY29uZmlybWF0aW9uUXVlc3Rpb259IC8+XG4gICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICA8L0Z1bGxTdG9yeU1hc2tpbmcuVW5tYXNrPlxuICAgIDwvQ29uZmlybWF0aW9uRGlhbG9nPlxuICApXG59XG5cbmZ1bmN0aW9uIGdldEJvbGQobXNnOiBzdHJpbmcpIHtcbiAgcmV0dXJuIChcbiAgICA8VGV4dC5Cb2R5IGFzPVwic3BhblwiIGlzQm9sZD5cbiAgICAgIHttc2d9XG4gICAgPC9UZXh0LkJvZHk+XG4gIClcbn1cbiJdfQ== */",
1229
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1230
+ };
1231
+ const ImportRunningTextNotification = props => jsx("div", {
1232
+ css: _ref2,
1233
+ children: jsx(Text.Body, {
1234
+ intlMessage: _objectSpread$2(_objectSpread$2({}, messages.importStarted), {}, {
1235
+ values: {
1236
+ newline: getNewLine,
1237
+ logsLink: msg => getImportLogsLink(msg, props.projectKey),
1238
+ b: getBold$1
1239
+ }
1240
+ })
1241
+ })
1242
+ });
1243
+ var _ref = process.env.NODE_ENV === "production" ? {
1244
+ name: "1vs9i7r",
1245
+ styles: "width:360px"
1246
+ } : {
1247
+ name: "mjwslu-ImportPreparingTextNotification",
1248
+ styles: "width:360px;label:ImportPreparingTextNotification;",
1249
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVucHVibGlzaC1wcm9kdWN0cy1jb25maXJtYXRpb24tbW9kYWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdDWSIsImZpbGUiOiJ1bnB1Ymxpc2gtcHJvZHVjdHMtY29uZmlybWF0aW9uLW1vZGFsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJ1xuaW1wb3J0IHsgdXNlU2hvd05vdGlmaWNhdGlvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FjdGlvbnMtZ2xvYmFsJ1xuaW1wb3J0IHsgQ29uZmlybWF0aW9uRGlhbG9nIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvYXBwbGljYXRpb24tY29tcG9uZW50cydcbmltcG9ydCB7IHVzZUFwcGxpY2F0aW9uQ29udGV4dCB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLXNoZWxsLWNvbm5lY3RvcnMnXG5pbXBvcnQgeyBET01BSU5TIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvY29uc3RhbnRzJ1xuaW1wb3J0IHsgTWFza2luZyBhcyBGdWxsU3RvcnlNYXNraW5nIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvZnVsbHN0b3J5J1xuaW1wb3J0IHsgdXNlQXN5bmNEaXNwYXRjaCB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL3NkaydcbmltcG9ydCB7IExpbmssIFNwYWNpbmdzLCBUZXh0IH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtZnJvbnRlbmQvdWkta2l0J1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgbWVzc2FnZXMgZnJvbSAnLi9tZXNzYWdlcydcbmltcG9ydCB7IHByb2Nlc3NVcGxvYWRlZEZpbGUgfSBmcm9tICcuLi8uLi9AYXBpJ1xuaW1wb3J0IHsgdXNlVW5wdWJsaXNoUHJvZHVjdHNDb250ZXh0IH0gZnJvbSAnLi4vLi4vQGhvb2tzJ1xuaW1wb3J0IHNoYXJlZE1lc3NhZ2VzIGZyb20gJy4uLy4uL21lc3NhZ2VzJ1xuXG5jb25zdCBnZXROZXdMaW5lID0gKCkgPT4gPGJyIC8+XG5jb25zdCBnZXRJbXBvcnRMb2dzTGluayA9IChtc2c6IHN0cmluZywgcHJvamVjdEtleT86IHN0cmluZykgPT4gKFxuICA8TGluayB0bz17YC8ke3Byb2plY3RLZXl9L29wZXJhdGlvbnMvaW1wb3J0L2xvZ3NgfT57bXNnfTwvTGluaz5cbilcblxuY29uc3QgSW1wb3J0UnVubmluZ1RleHROb3RpZmljYXRpb24gPSAocHJvcHM6IHsgcHJvamVjdEtleTogc3RyaW5nIH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17Y3NzYFxuICAgICAgd2lkdGg6IDM2MHB4O1xuICAgIGB9XG4gID5cbiAgICA8VGV4dC5Cb2R5XG4gICAgICBpbnRsTWVzc2FnZT17e1xuICAgICAgICAuLi5tZXNzYWdlcy5pbXBvcnRTdGFydGVkLFxuICAgICAgICB2YWx1ZXM6IHtcbiAgICAgICAgICBuZXdsaW5lOiBnZXROZXdMaW5lLFxuICAgICAgICAgIGxvZ3NMaW5rOiAobXNnOiBzdHJpbmcpID0+IGdldEltcG9ydExvZ3NMaW5rKG1zZywgcHJvcHMucHJvamVjdEtleSksXG4gICAgICAgICAgYjogZ2V0Qm9sZCxcbiAgICAgICAgfSxcbiAgICAgIH19XG4gICAgLz5cbiAgPC9kaXY+XG4pXG5cbmNvbnN0IEltcG9ydFByZXBhcmluZ1RleHROb3RpZmljYXRpb24gPSAocHJvcHM6IHsgcHJvamVjdEtleTogc3RyaW5nIH0pID0+IChcbiAgPGRpdlxuICAgIGNzcz17Y3NzYFxuICAgICAgd2lkdGg6IDM2MHB4O1xuICAgIGB9XG4gID5cbiAgICA8VGV4dC5Cb2R5XG4gICAgICBpbnRsTWVzc2FnZT17e1xuICAgICAgICAuLi5tZXNzYWdlcy5wcmVwYXJpbmdJbXBvcnQsXG4gICAgICAgIHZhbHVlczoge1xuICAgICAgICAgIG5ld2xpbmU6IGdldE5ld0xpbmUsXG4gICAgICAgICAgbG9nc0xpbms6IChtc2c6IHN0cmluZykgPT4gZ2V0SW1wb3J0TG9nc0xpbmsobXNnLCBwcm9wcy5wcm9qZWN0S2V5KSxcbiAgICAgICAgICBiOiBnZXRCb2xkLFxuICAgICAgICB9LFxuICAgICAgfX1cbiAgICAvPlxuICA8L2Rpdj5cbilcblxuZXhwb3J0IGNvbnN0IFVucHVibGlzaFByb2R1Y3RzQ29uZmlybWF0aW9uTW9kYWwgPSAoKSA9PiB7XG4gIGNvbnN0IGludGwgPSB1c2VJbnRsKClcbiAgY29uc3QgeyBzdGF0ZSwgb25DbG9zZSB9ID0gdXNlVW5wdWJsaXNoUHJvZHVjdHNDb250ZXh0KClcbiAgY29uc3QgeyBwcm9qZWN0S2V5LCBwcm9qZWN0TmFtZSB9ID0gdXNlQXBwbGljYXRpb25Db250ZXh0KChjb250ZXh0KSA9PiAoe1xuICAgIHByb2plY3RLZXk6IGNvbnRleHQucHJvamVjdD8ua2V5LFxuICAgIHByb2plY3ROYW1lOiBjb250ZXh0LnByb2plY3Q/Lm5hbWUsXG4gIH0pKVxuXG4gIGNvbnN0IGFzeW5jRGlzcGF0Y2ggPSB1c2VBc3luY0Rpc3BhdGNoKClcblxuICBjb25zdCBzaG93Tm90aWZpY2F0aW9uID0gdXNlU2hvd05vdGlmaWNhdGlvbigpXG5cbiAgcmV0dXJuIChcbiAgICA8Q29uZmlybWF0aW9uRGlhbG9nXG4gICAgICB0aXRsZT17aW50bC5mb3JtYXRNZXNzYWdlKHNoYXJlZE1lc3NhZ2VzLnVucHVibGlzaE1vZGFsVGl0bGUpfVxuICAgICAgbGFiZWxQcmltYXJ5PXtpbnRsLmZvcm1hdE1lc3NhZ2Uoc2hhcmVkTWVzc2FnZXMuc3RhcnRCdWxrVW5wdWJsaXNoKX1cbiAgICAgIGlzT3Blbj17dHJ1ZX1cbiAgICAgIG9uQ2xvc2U9eygpID0+IG9uQ2xvc2UoeyBzaG91bGREZWxldGVJbXBvcnRDb250YWluZXI6IHRydWUgfSl9XG4gICAgICBvbkNhbmNlbD17KCkgPT4gb25DbG9zZSh7IHNob3VsZERlbGV0ZUltcG9ydENvbnRhaW5lcjogdHJ1ZSB9KX1cbiAgICAgIGRhdGFBdHRyaWJ1dGVzUHJpbWFyeUJ1dHRvbj17e1xuICAgICAgICAnZGF0YS10ZXN0LWlkJzogJ2NvbmZpcm1hdGlvbi1kaWFsb2ctY29uZmlybScsXG4gICAgICB9fVxuICAgICAgZGF0YUF0dHJpYnV0ZXNTZWNvbmRhcnlCdXR0b249e3tcbiAgICAgICAgJ2RhdGEtdGVzdC1pZCc6ICdjb25maXJtYXRpb24tZGlhbG9nLWNhbmNlbCcsXG4gICAgICB9fVxuICAgICAgb25Db25maXJtPXthc3luYyAoKSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgY2FuQ29uZmlybSA9XG4gICAgICAgICAgICBwcm9qZWN0S2V5ICYmIHN0YXRlLmNvbnRhaW5lcktleSAmJiBzdGF0ZS5kcm9wcGVkRmlsZT8ubmFtZVxuICAgICAgICAgIGlmICghY2FuQ29uZmlybSkgcmV0dXJuXG4gICAgICAgICAgb25DbG9zZSgpXG4gICAgICAgICAgc2hvd05vdGlmaWNhdGlvbihcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAga2luZDogJ2luZm8nLFxuICAgICAgICAgICAgICBkb21haW46IERPTUFJTlMuU0lERSxcbiAgICAgICAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICAgICAgICB0ZXh0OiA8SW1wb3J0UHJlcGFyaW5nVGV4dE5vdGlmaWNhdGlvbiBwcm9qZWN0S2V5PXtwcm9qZWN0S2V5fSAvPixcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGRpc21pc3NBZnRlcjogNTAwMCxcbiAgICAgICAgICAgIH1cbiAgICAgICAgICApXG4gICAgICAgICAgYXdhaXQgcHJvY2Vzc1VwbG9hZGVkRmlsZSh7XG4gICAgICAgICAgICBwcm9qZWN0S2V5LFxuICAgICAgICAgICAgY29udGFpbmVyS2V5OiBzdGF0ZS5jb250YWluZXJLZXkhLFxuICAgICAgICAgICAgYXN5bmNEaXNwYXRjaCxcbiAgICAgICAgICB9KVxuICAgICAgICAgIHNob3dOb3RpZmljYXRpb24oXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGtpbmQ6ICdpbmZvJyxcbiAgICAgICAgICAgICAgZG9tYWluOiBET01BSU5TLlNJREUsXG4gICAgICAgICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgICAgICAgdGV4dDogPEltcG9ydFJ1bm5pbmdUZXh0Tm90aWZpY2F0aW9uIHByb2plY3RLZXk9e3Byb2plY3RLZXl9IC8+LFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgZGlzbWlzc0FmdGVyOiA1MDAwLFxuICAgICAgICAgICAgfVxuICAgICAgICAgIClcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBvbkNsb3NlKHsgc2hvdWxkRGVsZXRlSW1wb3J0Q29udGFpbmVyOiB0cnVlIH0pXG4gICAgICAgICAgc2hvd05vdGlmaWNhdGlvbih7XG4gICAgICAgICAgICBraW5kOiAnZXJyb3InLFxuICAgICAgICAgICAgZG9tYWluOiBET01BSU5TLlBBR0UsXG4gICAgICAgICAgICB0ZXh0OiBTdHJpbmcoZXJyb3IpLFxuICAgICAgICAgIH0pXG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgICBzaXplPXsxNn1cbiAgICA+XG4gICAgICA8RnVsbFN0b3J5TWFza2luZy5Vbm1hc2s+XG4gICAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInhsXCI+XG4gICAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgICAgaW50bE1lc3NhZ2U9e3tcbiAgICAgICAgICAgICAgLi4ubWVzc2FnZXMuY29uZmlybWF0aW9uVGV4dCxcbiAgICAgICAgICAgICAgdmFsdWVzOiB7XG4gICAgICAgICAgICAgICAgcHJvamVjdE5hbWU6IHByb2plY3ROYW1lLFxuICAgICAgICAgICAgICAgIC8vIFRPRE86IFJlcGxhY2Ugd2l0aCBhY3R1YWwgY291bnRcbiAgICAgICAgICAgICAgICBjb3VudDogaW50bC5mb3JtYXROdW1iZXIoc3RhdGUudXBsb2FkRmlsZVJlc3BvbnNlPy5yb3dzQ291bnQpLFxuICAgICAgICAgICAgICAgIGI6IGdldEJvbGQsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9fVxuICAgICAgICAgIC8+XG4gICAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuY29uZmlybWF0aW9uUXVlc3Rpb259IC8+XG4gICAgICAgIDwvU3BhY2luZ3MuU3RhY2s+XG4gICAgICA8L0Z1bGxTdG9yeU1hc2tpbmcuVW5tYXNrPlxuICAgIDwvQ29uZmlybWF0aW9uRGlhbG9nPlxuICApXG59XG5cbmZ1bmN0aW9uIGdldEJvbGQobXNnOiBzdHJpbmcpIHtcbiAgcmV0dXJuIChcbiAgICA8VGV4dC5Cb2R5IGFzPVwic3BhblwiIGlzQm9sZD5cbiAgICAgIHttc2d9XG4gICAgPC9UZXh0LkJvZHk+XG4gIClcbn1cbiJdfQ== */",
1250
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1251
+ };
1252
+ const ImportPreparingTextNotification = props => jsx("div", {
1253
+ css: _ref,
1254
+ children: jsx(Text.Body, {
1255
+ intlMessage: _objectSpread$2(_objectSpread$2({}, messages.preparingImport), {}, {
1256
+ values: {
1257
+ newline: getNewLine,
1258
+ logsLink: msg => getImportLogsLink(msg, props.projectKey),
1259
+ b: getBold$1
1260
+ }
1261
+ })
1262
+ })
1263
+ });
1264
+ const UnpublishProductsConfirmationModal = () => {
1265
+ const intl = useIntl();
1266
+ const _useUnpublishProducts = useUnpublishProductsContext(),
1267
+ state = _useUnpublishProducts.state,
1268
+ onClose = _useUnpublishProducts.onClose;
1269
+ const _useApplicationContex = useApplicationContext(context => ({
1270
+ projectKey: context.project?.key,
1271
+ projectName: context.project?.name
1272
+ })),
1273
+ projectKey = _useApplicationContex.projectKey,
1274
+ projectName = _useApplicationContex.projectName;
1275
+ const asyncDispatch = useAsyncDispatch();
1276
+ const showNotification = useShowNotification();
1277
+ return jsx(ConfirmationDialog, {
1278
+ title: intl.formatMessage(sharedMessages.unpublishModalTitle),
1279
+ labelPrimary: intl.formatMessage(sharedMessages.startBulkUnpublish),
1280
+ isOpen: true,
1281
+ onClose: () => onClose({
1282
+ shouldDeleteImportContainer: true
1283
+ }),
1284
+ onCancel: () => onClose({
1285
+ shouldDeleteImportContainer: true
1286
+ }),
1287
+ dataAttributesPrimaryButton: {
1288
+ 'data-test-id': 'confirmation-dialog-confirm'
1289
+ },
1290
+ dataAttributesSecondaryButton: {
1291
+ 'data-test-id': 'confirmation-dialog-cancel'
1292
+ },
1293
+ onConfirm: async () => {
1294
+ try {
1295
+ const canConfirm = projectKey && state.containerKey && state.droppedFile?.name;
1296
+ if (!canConfirm) return;
1297
+ onClose();
1298
+ showNotification({
1299
+ kind: 'info',
1300
+ domain: DOMAINS.SIDE,
1301
+ // @ts-ignore
1302
+ text: jsx(ImportPreparingTextNotification, {
1303
+ projectKey: projectKey
1304
+ })
1305
+ }, {
1306
+ dismissAfter: 5000
1307
+ });
1308
+ await processUploadedFile({
1309
+ projectKey,
1310
+ containerKey: state.containerKey,
1311
+ asyncDispatch
1312
+ });
1313
+ showNotification({
1314
+ kind: 'info',
1315
+ domain: DOMAINS.SIDE,
1316
+ // @ts-ignore
1317
+ text: jsx(ImportRunningTextNotification, {
1318
+ projectKey: projectKey
1319
+ })
1320
+ }, {
1321
+ dismissAfter: 5000
1322
+ });
1323
+ } catch (error) {
1324
+ onClose({
1325
+ shouldDeleteImportContainer: true
1326
+ });
1327
+ showNotification({
1328
+ kind: 'error',
1329
+ domain: DOMAINS.PAGE,
1330
+ text: String(error)
1331
+ });
1332
+ }
1333
+ },
1334
+ size: 16,
1335
+ children: jsx(Masking.Unmask, {
1336
+ children: jsxs(Spacings.Stack, {
1337
+ scale: "xl",
1338
+ children: [jsx(Text.Body, {
1339
+ intlMessage: _objectSpread$2(_objectSpread$2({}, messages.confirmationText), {}, {
1340
+ values: {
1341
+ projectName: projectName,
1342
+ // TODO: Replace with actual count
1343
+ count: intl.formatNumber(state.uploadFileResponse?.rowsCount),
1344
+ b: getBold$1
1345
+ }
1346
+ })
1347
+ }), jsx(Text.Body, {
1348
+ intlMessage: messages.confirmationQuestion
1349
+ })]
1350
+ })
1351
+ })
1352
+ });
1353
+ };
1354
+ function getBold$1(msg) {
1355
+ return jsx(Text.Body, {
1356
+ as: "span",
1357
+ isBold: true,
1358
+ children: msg
1359
+ });
1360
+ }
1361
+
1362
+ 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; }
1363
+ 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; }
1364
+ function UploadPreviewModal() {
1365
+ const _useUnpublishProducts = useUnpublishProductsContext(),
1366
+ state = _useUnpublishProducts.state,
1367
+ onClose = _useUnpublishProducts.onClose,
1368
+ actions = _useUnpublishProducts.actions;
1369
+ const intl = useIntl();
1370
+ return jsx(FormDialog, {
1371
+ size: 16,
1372
+ isOpen: true,
1373
+ title: intl.formatMessage(sharedMessages.unpublishModalTitle),
1374
+ labelPrimary: intl.formatMessage(messages.continue),
1375
+ onSecondaryButtonClick: () => onClose({
1376
+ shouldDeleteImportContainer: true
1377
+ }),
1378
+ onPrimaryButtonClick: () => {
1379
+ actions.setCurrentStep('unpublish-confirmation');
1380
+ },
1381
+ onClose: () => onClose({
1382
+ shouldDeleteImportContainer: true
1383
+ }),
1384
+ children: jsxs(Spacings.Stack, {
1385
+ scale: "m",
1386
+ children: [jsx(Text.Body, {
1387
+ intlMessage: messages.heresAPreview
1388
+ }), jsx(Card, {
1389
+ insetScale: "xl",
1390
+ children: jsxs(Spacings.Inline, {
1391
+ scale: "m",
1392
+ alignItems: "center",
1393
+ children: [jsx(CloseBoldIcon, {
1394
+ size: "40",
1395
+ color: "neutral60"
1396
+ }), jsx(Text.Body, {
1397
+ intlMessage: _objectSpread$1(_objectSpread$1({}, messages.productsToBeUnpublished), {}, {
1398
+ values: {
1399
+ count: intl.formatNumber(state.uploadFileResponse?.rowsCount),
1400
+ b: getBold
1401
+ }
1402
+ })
1403
+ })]
1404
+ })
1405
+ })]
1406
+ })
1407
+ });
1408
+ }
1409
+ function getBold(msg) {
1410
+ return jsx(Text.Body, {
1411
+ as: "span",
1412
+ isBold: true,
1413
+ children: msg
1414
+ });
1415
+ }
1416
+
1417
+ const steps = {
1418
+ upload: jsx(Upload, {}),
1419
+ uploading: jsx(Uploading, {}),
1420
+ 'upload-preview': jsx(UploadPreviewModal, {}),
1421
+ 'upload-error': jsx(UploadErrorsModal, {}),
1422
+ 'unpublish-confirmation': jsx(UnpublishProductsConfirmationModal, {})
1423
+ };
1424
+ const CurrentStep = () => {
1425
+ const _useUnpublishProducts = useUnpublishProductsContext(),
1426
+ state = _useUnpublishProducts.state;
1427
+ return steps[state.currentStep] || null;
1428
+ };
1429
+
1430
+ const getChunkImport = locale => {
1431
+ const intlLocale = mapLocaleToIntlLocale(locale);
1432
+ switch (intlLocale) {
1433
+ case 'de':
1434
+ return import(/* webpackChunkName: "unpublish-products-modal-i18n-de" */'./de-cd6c45d3.esm.js');
1435
+ case 'es':
1436
+ return import(/* webpackChunkName: "unpublish-products-modal-i18n-es" */'./es-e544023d.esm.js');
1437
+ case 'fr-FR':
1438
+ return import(/* webpackChunkName: "unpublish-products-modal-i18n-fr-FR" */'./fr-FR-9d9081ee.esm.js');
1439
+ case 'zh-CN':
1440
+ return import(/* webpackChunkName: "unpublish-products-modal-i18n-zh-CN" */'./zh-CN-4780d88e.esm.js');
1441
+ case 'ja':
1442
+ return import(/* webpackChunkName: "unpublish-products-modal-i18n-ja" */'./ja-73c088a7.esm.js');
1443
+ case 'pt-BR':
1444
+ return import(/* webpackChunkName: "change-history-i18n-pt-BR" */'./pt-BR-b37d730b.esm.js');
1445
+ default:
1446
+ return import(/* webpackChunkName: "unpublish-products-modal-i18n-en" */'./en-3a9aa2d4.esm.js');
1447
+ }
1448
+ };
1449
+ const loadMessages = async locale => {
1450
+ try {
1451
+ const chunkImport = await getChunkImport(locale);
1452
+ return parseChunkImport(chunkImport);
1453
+ } catch (error) {
1454
+ // eslint-disable-next-line no-console
1455
+ console.warn(`Something went wrong while loading the unpublish-products-modal messages for ${locale}`, error);
1456
+ reportErrorToSentry(new Error(`Something went wrong while loading the unpublish-products-modal messages for ${locale}`), {
1457
+ extra: error
1458
+ });
1459
+ return {};
1460
+ }
1461
+ };
1462
+
1463
+ const useAsyncIntlMessages = (locale, loader) => {
1464
+ const _useState = useState({
1465
+ isLoading: true,
1466
+ messages: undefined,
1467
+ error: undefined
1468
+ }),
1469
+ _useState2 = _slicedToArray(_useState, 2),
1470
+ state = _useState2[0],
1471
+ setState = _useState2[1];
1472
+ useEffect(() => {
1473
+ let _isUnmounting = false;
1474
+ async function load() {
1475
+ try {
1476
+ if (!_isUnmounting) {
1477
+ const messages = await loader(locale);
1478
+ setState({
1479
+ isLoading: false,
1480
+ messages
1481
+ });
1482
+ }
1483
+ } catch (error) {
1484
+ setState({
1485
+ isLoading: false,
1486
+ error
1487
+ });
1488
+ }
1489
+ }
1490
+ if (locale) load();
1491
+ return () => {
1492
+ _isUnmounting = true;
1493
+ };
1494
+ }, [locale, loader]);
1495
+ return state;
1496
+ };
1497
+
1498
+ 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; }
1499
+ 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; }
1500
+ const UnpublishProductsModal = props => {
1501
+ const _useApplicationContex = useApplicationContext(context => ({
1502
+ locale: context.user && context.user.locale
1503
+ })),
1504
+ locale = _useApplicationContex.locale;
1505
+ const messages = useAsyncIntlMessages(locale, loadMessages);
1506
+ if (!props.isOpen || messages.isLoading) return null;
1507
+ return jsx(IntlProvider, {
1508
+ locale: locale,
1509
+ messages: messages.messages,
1510
+ children: jsx(UnpublishProductsProvider, _objectSpread(_objectSpread({}, props), {}, {
1511
+ children: jsx(CurrentStep, {})
1512
+ }))
1513
+ });
1514
+ };
1515
+ UnpublishProductsModal.displayName = 'UnpublishProductsModal';
1516
+
1517
+ export { EnabledDropArea as E, FileDropped as F, UnpublishProductsModal as U, messages$4 as m, useUnpublishProductsContext as u };