sonarr-repo-only/frontend/src/Settings/PendingChangesModal.js

71 lines
1.8 KiB
JavaScript
Raw Normal View History

2018-01-13 02:01:27 +00:00
import PropTypes from 'prop-types';
import React, { useEffect } from 'react';
import keyboardShortcuts from 'Components/keyboardShortcuts';
2018-01-13 02:01:27 +00:00
import Button from 'Components/Link/Button';
import Modal from 'Components/Modal/Modal';
import ModalBody from 'Components/Modal/ModalBody';
2022-05-20 04:15:43 +00:00
import ModalContent from 'Components/Modal/ModalContent';
2018-01-13 02:01:27 +00:00
import ModalFooter from 'Components/Modal/ModalFooter';
2022-05-20 04:15:43 +00:00
import ModalHeader from 'Components/Modal/ModalHeader';
import { kinds } from 'Helpers/Props';
2018-01-13 02:01:27 +00:00
function PendingChangesModal(props) {
const {
isOpen,
onConfirm,
onCancel,
bindShortcut
2018-01-13 02:01:27 +00:00
} = props;
useEffect(() => {
bindShortcut('enter', onConfirm);
2022-11-04 21:16:11 +00:00
}, [bindShortcut, onConfirm]);
2018-01-13 02:01:27 +00:00
return (
<Modal
isOpen={isOpen}
onModalClose={onCancel}
>
<ModalContent onModalClose={onCancel}>
<ModalHeader>Unsaved Changes</ModalHeader>
<ModalBody>
You have unsaved changes, are you sure you want to leave this page?
</ModalBody>
<ModalFooter>
<Button
kind={kinds.DEFAULT}
onPress={onCancel}
>
Stay and review changes
</Button>
<Button
autoFocus={true}
2018-01-13 02:01:27 +00:00
kind={kinds.DANGER}
onPress={onConfirm}
>
Discard changes and leave
</Button>
</ModalFooter>
</ModalContent>
</Modal>
);
}
PendingChangesModal.propTypes = {
className: PropTypes.string,
isOpen: PropTypes.bool.isRequired,
kind: PropTypes.oneOf(kinds.all),
onConfirm: PropTypes.func.isRequired,
onCancel: PropTypes.func.isRequired,
bindShortcut: PropTypes.func.isRequired
2018-01-13 02:01:27 +00:00
};
PendingChangesModal.defaultProps = {
kind: kinds.PRIMARY
};
export default keyboardShortcuts(PendingChangesModal);