React = require "react/addons" classNames = require 'classnames' ThreadListStore = require './thread-list-store' {RetinaImg} = require 'ui-components' {Actions, FocusedContentStore} = require "inbox-exports" class ThreadBulkArchiveButton extends React.Component @displayName: 'ThreadBulkArchiveButton' @containerRequired: false @propTypes: selection: React.PropTypes.object.isRequired render: -> _onArchive: => Actions.archiveSelection() 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: ->
_classSet: -> classNames "message-toolbar-arrow": true "down": true "disabled": @state.disabled _onClick: -> return if @state.disabled atom.commands.dispatch(document.body, 'core:next-item') _getStateFromStores: -> disabled: @isLastThread() UpButton = React.createClass displayName: 'UpButton' mixins: [ThreadNavButtonMixin] render: ->
_classSet: -> classNames "message-toolbar-arrow": true "up": true "disabled": @state.disabled _onClick: -> return if @state.disabled atom.commands.dispatch(document.body, 'core:previous-item') _getStateFromStores: -> disabled: @isFirstThread() UpButton.containerRequired = false DownButton.containerRequired = false module.exports = {DownButton, UpButton, ThreadBulkArchiveButton}