mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-09 17:55:35 +08:00
46 lines
1.2 KiB
JavaScript
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(),
|
|
}
|
|
},
|
|
})
|
|
|