35 lines
973 B
TypeScript
35 lines
973 B
TypeScript
import React from 'react';
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
|
|
import { Modal } from 'soapbox/components/ui';
|
|
|
|
const messages = defineMessages({
|
|
error: { id: 'bundle_modal_error.message', defaultMessage: 'Something went wrong while loading this modal.' },
|
|
retry: { id: 'bundle_modal_error.retry', defaultMessage: 'Try again' },
|
|
close: { id: 'bundle_modal_error.close', defaultMessage: 'Close' },
|
|
});
|
|
|
|
interface IBundleModalError {
|
|
onRetry: () => void,
|
|
onClose: () => void,
|
|
}
|
|
|
|
const BundleModalError: React.FC<IBundleModalError> = ({ onRetry, onClose }) => {
|
|
const intl = useIntl();
|
|
|
|
const handleRetry = () => {
|
|
onRetry();
|
|
};
|
|
|
|
return (
|
|
<Modal
|
|
title={intl.formatMessage(messages.error)}
|
|
confirmationAction={onClose}
|
|
confirmationText={intl.formatMessage(messages.close)}
|
|
secondaryAction={handleRetry}
|
|
secondaryText={intl.formatMessage(messages.retry)}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export default BundleModalError;
|