React = require "react/addons" classNames = require 'classnames' ThreadListStore = require './thread-list-store' {RetinaImg} = require 'nylas-component-kit' {Actions, RemoveThreadHelper, FocusedContentStore, FocusedMailViewStore} = require "nylas-exports" class ThreadBulkRemoveButton extends React.Component @displayName: 'ThreadBulkRemoveButton' @containerRequired: false @propTypes: selection: React.PropTypes.object.isRequired render: -> focusedMailViewFilter = FocusedMailViewStore.mailView() return false unless focusedMailViewFilter?.canRemoveThreads() if RemoveThreadHelper.removeType() is RemoveThreadHelper.Type.Archive tooltip = "Archive" imgName = "toolbar-archive.png" else if RemoveThreadHelper.removeType() is RemoveThreadHelper.Type.Trash tooltip = "Trash" imgName = "toolbar-trash.png" _onRemove: => Actions.removeSelection() class ThreadBulkStarButton extends React.Component @displayName: 'ThreadBulkStarButton' @containerRequired: false @propTypes: selection: React.PropTypes.object.isRequired render: -> _onStar: => Actions.toggleStarSelection() class ThreadBulkToggleUnreadButton extends React.Component @displayName: 'ThreadBulkToggleUnreadButton' @containerRequired: false @propTypes: selection: React.PropTypes.object.isRequired constructor: -> @state = @_getStateFromStores() super componentDidMount: => @unsubscribers = [] @unsubscribers.push ThreadListStore.listen @_onStoreChange componentWillUnmount: => unsubscribe() for unsubscribe in @unsubscribers render: => fragment = if @state.canMarkUnread then "unread" else "read" _onClick: => Actions.toggleUnreadSelection() _onStoreChange: => @setState @_getStateFromStores() _getStateFromStores: => selections = ThreadListStore.view().selection.items() canMarkUnread: not selections.every (s) -> s.unread is true ThreadNavButtonMixin = getInitialState: -> @_getStateFromStores() componentDidMount: -> @_unsubscribe = ThreadListStore.listen @_onStoreChange @_unsubscribe_focus = FocusedContentStore.listen @_onStoreChange isFirstThread: -> selectedId = FocusedContentStore.focusedId('thread') ThreadListStore.view().get(0)?.id is selectedId isLastThread: -> selectedId = FocusedContentStore.focusedId('thread') lastIndex = ThreadListStore.view().count() - 1 ThreadListStore.view().get(lastIndex)?.id is selectedId componentWillUnmount: -> @_unsubscribe() @_unsubscribe_focus() _onStoreChange: -> @setState @_getStateFromStores() DownButton = React.createClass displayName: 'DownButton' mixins: [ThreadNavButtonMixin] render: ->