@commercetools-frontend-extensions/delete-resources-modal 1.5.0 → 1.6.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.
@@ -438,6 +438,11 @@ var messages$4 = reactIntl.defineMessages({
438
438
  description: 'Generic notification message when file upload fails',
439
439
  defaultMessage: 'An unexpected error occurred during the file upload. Please try again, or contact support if this error occurs again.'
440
440
  },
441
+ uploadIsTakingTooLong: {
442
+ id: 'operations.import.resource.upload.uploadIsTakingTooLong',
443
+ description: 'Notification message when file upload is taking longer than expected',
444
+ defaultMessage: 'Upload timed out. Please reduce your file size or split the data into smaller files and try again.'
445
+ },
441
446
  missingRequiredField: {
442
447
  id: 'DeleteResourcesModal.missingRequiredField',
443
448
  description: 'Error message displayed when a required field is missing',
@@ -546,6 +551,19 @@ const useUpload = () => {
546
551
  } else if (error.errorData?.invalid > 0) {
547
552
  actions.setUploadFileResponse(error.errorData);
548
553
  actions.setCurrentStep('upload-error');
554
+ } else if (error.statusCode === 408) {
555
+ actions.cancelImport();
556
+ showNotification({
557
+ kind: 'error',
558
+ domain: constants.DOMAINS.PAGE,
559
+ text: intl.formatMessage(messages$4.uploadIsTakingTooLong)
560
+ });
561
+ sentry.reportErrorToSentry(new Error('Upload File Error: The upload request timed out (408 Request Timeout)'), {
562
+ extra: {
563
+ error,
564
+ fileSizeInBytes: state.droppedFile?.size
565
+ }
566
+ });
549
567
  } else {
550
568
  actions.cancelImport();
551
569
  showNotification({
@@ -582,6 +600,7 @@ const useUpload = () => {
582
600
  settings: {
583
601
  format: 'CSV'
584
602
  },
603
+ operationType: 'delete',
585
604
  abortSignal: abortController.signal,
586
605
  onSuccess: result => {
587
606
  actions.setValidationProgress({
@@ -1180,7 +1199,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
1180
1199
  styles: "width:360px"
1181
1200
  } : {
1182
1201
  name: "g36yzl-ImportRunningTextNotification",
1183
- styles: "width:360px;label:ImportRunningTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAoCY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          action: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1202
+ styles: "width:360px;label:ImportRunningTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAoCY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          operationType: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1184
1203
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1185
1204
  };
1186
1205
  const ImportRunningTextNotification = props => jsxRuntime.jsx("div", {
@@ -1200,7 +1219,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
1200
1219
  styles: "width:360px"
1201
1220
  } : {
1202
1221
  name: "mjwslu-ImportPreparingTextNotification",
1203
- styles: "width:360px;label:ImportPreparingTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAuDY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          action: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1222
+ styles: "width:360px;label:ImportPreparingTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAuDY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          operationType: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1204
1223
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1205
1224
  };
1206
1225
  const ImportPreparingTextNotification = props => jsxRuntime.jsx("div", {
@@ -1249,7 +1268,7 @@ const DeleteResourcesConfirmationModal = () => {
1249
1268
  importContainerKey: state.containerKey,
1250
1269
  jobId: state.jobId,
1251
1270
  resourceType,
1252
- action: 'delete'
1271
+ operationType: 'delete'
1253
1272
  });
1254
1273
  } else {
1255
1274
  await operations.processUploadedFile({
@@ -438,6 +438,11 @@ var messages$4 = reactIntl.defineMessages({
438
438
  description: 'Generic notification message when file upload fails',
439
439
  defaultMessage: 'An unexpected error occurred during the file upload. Please try again, or contact support if this error occurs again.'
440
440
  },
441
+ uploadIsTakingTooLong: {
442
+ id: 'operations.import.resource.upload.uploadIsTakingTooLong',
443
+ description: 'Notification message when file upload is taking longer than expected',
444
+ defaultMessage: 'Upload timed out. Please reduce your file size or split the data into smaller files and try again.'
445
+ },
441
446
  missingRequiredField: {
442
447
  id: 'DeleteResourcesModal.missingRequiredField',
443
448
  description: 'Error message displayed when a required field is missing',
@@ -546,6 +551,19 @@ const useUpload = () => {
546
551
  } else if (error.errorData?.invalid > 0) {
547
552
  actions.setUploadFileResponse(error.errorData);
548
553
  actions.setCurrentStep('upload-error');
554
+ } else if (error.statusCode === 408) {
555
+ actions.cancelImport();
556
+ showNotification({
557
+ kind: 'error',
558
+ domain: constants.DOMAINS.PAGE,
559
+ text: intl.formatMessage(messages$4.uploadIsTakingTooLong)
560
+ });
561
+ sentry.reportErrorToSentry(new Error('Upload File Error: The upload request timed out (408 Request Timeout)'), {
562
+ extra: {
563
+ error,
564
+ fileSizeInBytes: state.droppedFile?.size
565
+ }
566
+ });
549
567
  } else {
550
568
  actions.cancelImport();
551
569
  showNotification({
@@ -582,6 +600,7 @@ const useUpload = () => {
582
600
  settings: {
583
601
  format: 'CSV'
584
602
  },
603
+ operationType: 'delete',
585
604
  abortSignal: abortController.signal,
586
605
  onSuccess: result => {
587
606
  actions.setValidationProgress({
@@ -1240,7 +1259,7 @@ const DeleteResourcesConfirmationModal = () => {
1240
1259
  importContainerKey: state.containerKey,
1241
1260
  jobId: state.jobId,
1242
1261
  resourceType,
1243
- action: 'delete'
1262
+ operationType: 'delete'
1244
1263
  });
1245
1264
  } else {
1246
1265
  await operations.processUploadedFile({
@@ -420,6 +420,11 @@ var messages$4 = defineMessages({
420
420
  description: 'Generic notification message when file upload fails',
421
421
  defaultMessage: 'An unexpected error occurred during the file upload. Please try again, or contact support if this error occurs again.'
422
422
  },
423
+ uploadIsTakingTooLong: {
424
+ id: 'operations.import.resource.upload.uploadIsTakingTooLong',
425
+ description: 'Notification message when file upload is taking longer than expected',
426
+ defaultMessage: 'Upload timed out. Please reduce your file size or split the data into smaller files and try again.'
427
+ },
423
428
  missingRequiredField: {
424
429
  id: 'DeleteResourcesModal.missingRequiredField',
425
430
  description: 'Error message displayed when a required field is missing',
@@ -528,6 +533,19 @@ const useUpload = () => {
528
533
  } else if (error.errorData?.invalid > 0) {
529
534
  actions.setUploadFileResponse(error.errorData);
530
535
  actions.setCurrentStep('upload-error');
536
+ } else if (error.statusCode === 408) {
537
+ actions.cancelImport();
538
+ showNotification({
539
+ kind: 'error',
540
+ domain: DOMAINS.PAGE,
541
+ text: intl.formatMessage(messages$4.uploadIsTakingTooLong)
542
+ });
543
+ reportErrorToSentry(new Error('Upload File Error: The upload request timed out (408 Request Timeout)'), {
544
+ extra: {
545
+ error,
546
+ fileSizeInBytes: state.droppedFile?.size
547
+ }
548
+ });
531
549
  } else {
532
550
  actions.cancelImport();
533
551
  showNotification({
@@ -564,6 +582,7 @@ const useUpload = () => {
564
582
  settings: {
565
583
  format: 'CSV'
566
584
  },
585
+ operationType: 'delete',
567
586
  abortSignal: abortController.signal,
568
587
  onSuccess: result => {
569
588
  actions.setValidationProgress({
@@ -1162,7 +1181,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
1162
1181
  styles: "width:360px"
1163
1182
  } : {
1164
1183
  name: "g36yzl-ImportRunningTextNotification",
1165
- styles: "width:360px;label:ImportRunningTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAoCY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          action: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1184
+ styles: "width:360px;label:ImportRunningTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAoCY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          operationType: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1166
1185
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1167
1186
  };
1168
1187
  const ImportRunningTextNotification = props => jsx("div", {
@@ -1182,7 +1201,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
1182
1201
  styles: "width:360px"
1183
1202
  } : {
1184
1203
  name: "mjwslu-ImportPreparingTextNotification",
1185
- styles: "width:360px;label:ImportPreparingTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAuDY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          action: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1204
+ styles: "width:360px;label:ImportPreparingTextNotification;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["delete-resources-confirmation-modal.tsx"],"names":[],"mappings":"AAuDY","file":"delete-resources-confirmation-modal.tsx","sourcesContent":["import { useIntl } from 'react-intl'\nimport { useShowNotification } from '@commercetools-frontend/actions-global'\nimport { InfoDialog } from '@commercetools-frontend/application-components'\nimport { useApplicationContext } from '@commercetools-frontend/application-shell-connectors'\nimport { DOMAINS } from '@commercetools-frontend/constants'\nimport { Masking as FullStoryMasking } from '@commercetools-frontend/fullstory'\nimport {\n  Link,\n  PrimaryButton,\n  SecondaryButton,\n  Spacings,\n  Text,\n  WarningIcon,\n} from '@commercetools-frontend/ui-kit'\nimport {\n  processUploadedFile,\n  processFileImportJob,\n} from '@commercetools-frontend-extensions/operations'\nimport { css } from '@emotion/react'\nimport messages from './messages'\nimport {\n  resourceTypeToMessage,\n  resourceTypeToPluralMessage,\n} from '../../@helpers'\nimport { useDeleteResourcesContext } from '../../@hooks'\nimport sharedMessages from '../../messages'\n\nconst getNewLine = () => <br key=\"break\" />\nconst getImportLogsLink = (msg, projectKey) => (\n  <Link to={`/${projectKey}/operations/import/logs`} key=\"link\">\n    {msg}\n  </Link>\n)\n\nconst ImportRunningTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.importStarted,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nconst ImportPreparingTextNotification = (props: { projectKey: string }) => (\n  <div\n    css={css`\n      width: 360px;\n    `}\n  >\n    <Text.Body\n      intlMessage={{\n        ...messages.preparingImport,\n        values: {\n          newline: getNewLine,\n          logsLink: (msg) => getImportLogsLink(msg, props.projectKey),\n          b: getBold,\n        },\n      }}\n    />\n  </div>\n)\n\nexport const DeleteResourcesConfirmationModal = () => {\n  const intl = useIntl()\n  const { resourceType, state, onClose } = useDeleteResourcesContext()\n  const { projectKey, projectName } = useApplicationContext((context) => ({\n    projectKey: context.project?.key,\n    projectName: context.project?.name,\n  }))\n\n  const showNotification = useShowNotification()\n\n  const onStartImport = async () => {\n    try {\n      const canConfirm =\n        projectKey && state.containerKey && state.droppedFile?.name\n      if (!canConfirm) return\n      onClose()\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportPreparingTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n\n      if (state.jobId) {\n        await processFileImportJob({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          jobId: state.jobId,\n          resourceType,\n          operationType: 'delete',\n        })\n      } else {\n        await processUploadedFile({\n          projectKey,\n          importContainerKey: state.containerKey!,\n          resourceType,\n          action: 'delete',\n        })\n      }\n      showNotification(\n        {\n          kind: 'info',\n          domain: DOMAINS.SIDE,\n          // @ts-ignore\n          text: <ImportRunningTextNotification projectKey={projectKey} />,\n        },\n        {\n          dismissAfter: 5000,\n        }\n      )\n    } catch (error) {\n      onClose({ shouldDeleteImportContainer: true })\n      showNotification({\n        kind: 'error',\n        domain: DOMAINS.PAGE,\n        text: String(error),\n      })\n    }\n  }\n\n  return (\n    <InfoDialog\n      title={intl.formatMessage(sharedMessages.deleteModalTitle)}\n      isOpen\n      onClose={() => onClose({ shouldDeleteImportContainer: true })}\n      size={16}\n    >\n      <FullStoryMasking.Unmask>\n        <Spacings.Stack scale=\"xl\">\n          <Spacings.Stack scale=\"m\">\n            <div>\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationText,\n                  values: {\n                    projectName: projectName,\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                    resourceType: intl.formatMessage(\n                      resourceTypeToMessage(resourceType)\n                    ),\n                    count: intl.formatNumber(\n                      state.uploadFileResponse?.rowsCount ?? 0\n                    ),\n                    b: getBold,\n                  },\n                }}\n              />\n              <Text.Body\n                intlMessage={{\n                  ...messages.confirmationQuestion,\n                  values: {\n                    resourceTypePlural: intl.formatMessage(\n                      resourceTypeToPluralMessage(resourceType)\n                    ),\n                  },\n                }}\n              />\n            </div>\n            <Spacings.Inline scale=\"s\" alignItems=\"center\">\n              <WarningIcon size=\"40\" color=\"warning\" />\n              <Text.Body intlMessage={messages.cannotBeUndoneNote} />\n            </Spacings.Inline>\n          </Spacings.Stack>\n          <Spacings.Inline scale=\"m\" justifyContent=\"flex-end\">\n            <SecondaryButton\n              data-test-id=\"confirmation-dialog-cancel\"\n              label={intl.formatMessage(sharedMessages.cancel)}\n              onClick={() => onClose({ shouldDeleteImportContainer: true })}\n            />\n            <PrimaryButton\n              tone=\"critical\"\n              data-test-id=\"confirmation-dialog-confirm\"\n              label={intl.formatMessage(sharedMessages.startBulkDelete)}\n              onClick={onStartImport}\n            />\n          </Spacings.Inline>\n        </Spacings.Stack>\n      </FullStoryMasking.Unmask>\n    </InfoDialog>\n  )\n}\n\nfunction getBold(msg) {\n  return (\n    <Text.Body as=\"span\" isBold key={crypto.randomUUID()}>\n      {msg}\n    </Text.Body>\n  )\n}\n"]} */",
1186
1205
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
1187
1206
  };
1188
1207
  const ImportPreparingTextNotification = props => jsx("div", {
@@ -1231,7 +1250,7 @@ const DeleteResourcesConfirmationModal = () => {
1231
1250
  importContainerKey: state.containerKey,
1232
1251
  jobId: state.jobId,
1233
1252
  resourceType,
1234
- action: 'delete'
1253
+ operationType: 'delete'
1235
1254
  });
1236
1255
  } else {
1237
1256
  await processUploadedFile({
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-frontend-extensions/delete-resources-modal",
3
3
  "description": "Shared import modal for deleting resources",
4
- "version": "1.5.0",
4
+ "version": "1.6.0",
5
5
  "license": "BSD-3-Clause",
6
6
  "publishConfig": {
7
7
  "access": "public"
@@ -31,7 +31,7 @@
31
31
  "pluralize": "8.0.0",
32
32
  "prop-types": "15.8.1",
33
33
  "ramda": "^0.32.0",
34
- "@commercetools-frontend-extensions/operations": "3.3.0"
34
+ "@commercetools-frontend-extensions/operations": "3.4.0"
35
35
  },
36
36
  "devDependencies": {
37
37
  "@commercetools-frontend/actions-global": "25.1.0",