mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-08 17:17:56 +08:00
86 lines
2.2 KiB
CoffeeScript
86 lines
2.2 KiB
CoffeeScript
React = require 'react'
|
|
ReactDOM = require 'react-dom'
|
|
ReactCSSTransitionGroup = require 'react-addons-css-transition-group'
|
|
_ = require 'underscore'
|
|
classNames = require 'classnames'
|
|
|
|
SyncActivity = require("./sync-activity").default
|
|
SyncbackActivity = require("./syncback-activity").default
|
|
|
|
{Utils,
|
|
Actions,
|
|
TaskQueue,
|
|
AccountStore,
|
|
FolderSyncProgressStore,
|
|
TaskQueue,
|
|
SendDraftTask} = require 'mailspring-exports'
|
|
|
|
SEND_TASK_CLASSES = [SendDraftTask]
|
|
|
|
class ActivitySidebar extends React.Component
|
|
@displayName: 'ActivitySidebar'
|
|
|
|
@containerRequired: false
|
|
@containerStyles:
|
|
minWidth: 165
|
|
maxWidth: 400
|
|
|
|
constructor: (@props) ->
|
|
@state = @_getStateFromStores()
|
|
|
|
shouldComponentUpdate: (nextProps, nextState) =>
|
|
not Utils.isEqualReact(nextProps, @props) or
|
|
not Utils.isEqualReact(nextState, @state)
|
|
|
|
componentDidMount: =>
|
|
@_unlisteners = []
|
|
@_unlisteners.push TaskQueue.listen @_onDataChanged
|
|
@_unlisteners.push FolderSyncProgressStore.listen @_onDataChanged
|
|
|
|
componentWillUnmount: =>
|
|
unlisten() for unlisten in @_unlisteners
|
|
|
|
render: =>
|
|
sendTasks = []
|
|
nonSendTasks = []
|
|
@state.tasks.forEach (task) ->
|
|
if SEND_TASK_CLASSES.some(((taskClass) -> task instanceof taskClass ))
|
|
sendTasks.push(task)
|
|
else
|
|
nonSendTasks.push(task)
|
|
|
|
|
|
names = classNames
|
|
"sidebar-activity": true
|
|
"sidebar-activity-error": error?
|
|
|
|
wrapperClass = "sidebar-activity-transition-wrapper "
|
|
|
|
inside = <ReactCSSTransitionGroup
|
|
className={names}
|
|
transitionLeaveTimeout={625}
|
|
transitionEnterTimeout={125}
|
|
transitionName="activity-opacity">
|
|
<SyncbackActivity syncbackTasks={sendTasks} />
|
|
<SyncActivity
|
|
initialSync={!@state.isInitialSyncComplete}
|
|
syncbackTasks={nonSendTasks}
|
|
/>
|
|
</ReactCSSTransitionGroup>
|
|
|
|
<ReactCSSTransitionGroup
|
|
className={wrapperClass}
|
|
transitionLeaveTimeout={625}
|
|
transitionEnterTimeout={125}
|
|
transitionName="activity-opacity">
|
|
{inside}
|
|
</ReactCSSTransitionGroup>
|
|
|
|
_onDataChanged: =>
|
|
@setState(@_getStateFromStores())
|
|
|
|
_getStateFromStores: =>
|
|
tasks: TaskQueue.queue()
|
|
isInitialSyncComplete: FolderSyncProgressStore.isSyncComplete()
|
|
|
|
module.exports = ActivitySidebar
|