mirror of
https://github.com/Foundry376/Mailspring.git
synced 2024-11-14 05:41:05 +08:00
39 lines
925 B
React
39 lines
925 B
React
|
import React, {PropTypes} from 'react'
|
||
|
import {UndoRedoStore} from 'nylas-exports'
|
||
|
import {UndoToast, ListensToFluxStore} from 'nylas-component-kit'
|
||
|
|
||
|
|
||
|
function onUndo() {
|
||
|
NylasEnv.commands.dispatch('core:undo')
|
||
|
}
|
||
|
|
||
|
function UndoRedoThreadListToast(props) {
|
||
|
const {tasks} = props
|
||
|
return (
|
||
|
<UndoToast
|
||
|
{...props}
|
||
|
onUndo={onUndo}
|
||
|
visibleDuration={3000}
|
||
|
className="undo-redo-thread-list-toast"
|
||
|
undoMessage={tasks.map((t) => t.description()).join(', ')}
|
||
|
/>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
UndoRedoThreadListToast.displayName = 'UndoRedoThreadListToast'
|
||
|
UndoRedoThreadListToast.containerRequired = false
|
||
|
UndoRedoThreadListToast.propTypes = {
|
||
|
tasks: PropTypes.array,
|
||
|
}
|
||
|
|
||
|
export default ListensToFluxStore(UndoRedoThreadListToast, {
|
||
|
stores: [UndoRedoStore],
|
||
|
getStateFromStores() {
|
||
|
const tasks = UndoRedoStore.getMostRecent()
|
||
|
return {
|
||
|
tasks,
|
||
|
visible: tasks && tasks.length > 0,
|
||
|
}
|
||
|
},
|
||
|
})
|