Mailspring/app/internal_packages/undo-redo/lib/undo-send-toast.jsx

46 lines
1.2 KiB
JavaScript

import React from 'react'
import PropTypes from 'prop-types'
import {Actions} from 'nylas-exports'
import {KeyCommandsRegion, UndoToast, ListensToFluxStore} from 'nylas-component-kit'
import UndoSendStore from './undo-send-store'
function UndoSendToast(props) {
const {visible, sendActionTaskId} = props
return (
<KeyCommandsRegion
globalHandlers={{
'core:undo': (event) => {
if (!visible) { return }
event.preventDefault();
event.stopPropagation();
Actions.cancelTask(sendActionTaskId)
},
}}
>
<UndoToast
{...props}
className="undo-send-toast"
undoMessage="Sending draft"
visibleDuration={null}
onUndo={() => Actions.cancelTask(sendActionTaskId)}
/>
</KeyCommandsRegion>
)
}
UndoSendToast.displayName = 'UndoSendToast'
UndoSendToast.propTypes = {
visible: PropTypes.bool,
sendActionTaskId: PropTypes.string,
}
export default ListensToFluxStore(UndoSendToast, {
stores: [UndoSendStore],
getStateFromStores() {
return {
visible: UndoSendStore.shouldShowUndoSend(),
sendActionTaskId: UndoSendStore.sendActionTaskId(),
}
},
})