2015-03-07 04:03:32 +08:00
|
|
|
React = require 'react'
|
2015-03-13 09:47:01 +08:00
|
|
|
{Actions, ThreadStore, Utils} = require 'inbox-exports'
|
2015-03-07 04:03:32 +08:00
|
|
|
{RetinaImg} = require 'ui-components'
|
|
|
|
|
|
|
|
# Note: These always have a thread, but only sometimes get a
|
|
|
|
# message, depending on where in the UI they are being displayed.
|
|
|
|
|
|
|
|
ReplyButton = React.createClass
|
|
|
|
render: ->
|
2015-03-13 06:09:10 +08:00
|
|
|
<button className="btn btn-toolbar"
|
|
|
|
data-tooltip="Reply"
|
|
|
|
onClick={@_onReply}>
|
2015-03-07 04:03:32 +08:00
|
|
|
<RetinaImg name="toolbar-reply.png" />
|
|
|
|
</button>
|
|
|
|
|
|
|
|
_onReply: (e) ->
|
2015-03-13 09:47:01 +08:00
|
|
|
return unless Utils.nodeIsVisible(e.currentTarget)
|
2015-03-07 04:03:32 +08:00
|
|
|
Actions.composeReply(threadId: ThreadStore.selectedId())
|
|
|
|
e.stopPropagation()
|
|
|
|
|
|
|
|
ReplyAllButton = React.createClass
|
|
|
|
render: ->
|
2015-03-13 06:09:10 +08:00
|
|
|
<button className="btn btn-toolbar"
|
|
|
|
data-tooltip="Reply All"
|
|
|
|
onClick={@_onReplyAll}>
|
2015-03-07 04:03:32 +08:00
|
|
|
<RetinaImg name="toolbar-reply-all.png" />
|
|
|
|
</button>
|
|
|
|
|
|
|
|
_onReplyAll: (e) ->
|
2015-03-13 09:47:01 +08:00
|
|
|
return unless Utils.nodeIsVisible(e.currentTarget)
|
2015-03-07 04:03:32 +08:00
|
|
|
Actions.composeReplyAll(threadId: ThreadStore.selectedId())
|
|
|
|
e.stopPropagation()
|
|
|
|
|
|
|
|
ForwardButton = React.createClass
|
|
|
|
render: ->
|
2015-03-13 06:09:10 +08:00
|
|
|
<button className="btn btn-toolbar"
|
|
|
|
data-tooltip="Forward"
|
|
|
|
onClick={@_onForward}>
|
2015-03-07 04:03:32 +08:00
|
|
|
<RetinaImg name="toolbar-forward.png" />
|
|
|
|
</button>
|
|
|
|
|
|
|
|
_onForward: (e) ->
|
2015-03-13 09:47:01 +08:00
|
|
|
return unless Utils.nodeIsVisible(e.currentTarget)
|
2015-03-07 04:03:32 +08:00
|
|
|
Actions.composeForward(threadId: ThreadStore.selectedId())
|
|
|
|
e.stopPropagation()
|
|
|
|
|
|
|
|
ArchiveButton = React.createClass
|
|
|
|
render: ->
|
2015-03-13 06:09:10 +08:00
|
|
|
<button className="btn btn-toolbar"
|
|
|
|
data-tooltip="Archive"
|
|
|
|
onClick={@_onArchive}>
|
2015-03-07 04:03:32 +08:00
|
|
|
<RetinaImg name="toolbar-archive.png" />
|
|
|
|
</button>
|
|
|
|
|
|
|
|
_onArchive: (e) ->
|
2015-03-13 09:47:01 +08:00
|
|
|
return unless Utils.nodeIsVisible(e.currentTarget)
|
2015-03-07 04:03:32 +08:00
|
|
|
# Calling archive() sends an Actions.queueTask with an archive task
|
|
|
|
# TODO Turn into an Action
|
|
|
|
ThreadStore.selectedThread().archive()
|
|
|
|
e.stopPropagation()
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = React.createClass
|
|
|
|
getInitialState: ->
|
2015-03-14 04:11:24 +08:00
|
|
|
threadIsSelected: ThreadStore.selectedId()?
|
2015-03-07 04:03:32 +08:00
|
|
|
|
|
|
|
render: ->
|
|
|
|
classes = React.addons.classSet
|
|
|
|
"message-toolbar-items": true
|
|
|
|
"hidden": !@state.threadIsSelected
|
|
|
|
|
|
|
|
<div className={classes}>
|
|
|
|
<div className="message-toolbar-items-inner">
|
|
|
|
<ArchiveButton />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
componentDidMount: ->
|
|
|
|
@_unsubscribers = []
|
|
|
|
@_unsubscribers.push ThreadStore.listen @_onChange
|
|
|
|
|
|
|
|
componentWillUnmount: ->
|
|
|
|
unsubscribe() for unsubscribe in @_unsubscribers
|
|
|
|
|
|
|
|
_onChange: ->
|
|
|
|
@setState
|
|
|
|
threadIsSelected: ThreadStore.selectedId()?
|