React = require 'react' _ = require 'underscore' classNames = require 'classnames' NotificationStore = require './notifications-store' InitialSyncActivity = require './initial-sync-activity' {Actions, TaskQueue, AccountStore, NylasSyncStatusStore, TaskQueueStatusStore} = require 'nylas-exports' ActivitySidebarLongPollStore = require './activity-sidebar-long-poll-store' {TimeoutTransitionGroup, RetinaImg} = require 'nylas-component-kit' class ActivitySidebar extends React.Component @displayName: 'ActivitySidebar' @containerRequired: false @containerStyles: minWidth: 165 maxWidth: 400 constructor: (@props) -> @state = @_getStateFromStores() componentDidMount: => @_unlisteners = [] @_unlisteners.push TaskQueueStatusStore.listen @_onDataChanged @_unlisteners.push NotificationStore.listen @_onDataChanged @_unlisteners.push NylasSyncStatusStore.listen @_onDataChanged @_unlisteners.push ActivitySidebarLongPollStore.listen @_onDeltaReceived componentWillUnmount: => unlisten() for unlisten in @_unlisteners @_workerUnlisten() if @_workerUnlisten render: => items = [@_renderNotificationActivityItems(), @_renderTaskActivityItems()] if @state.isInitialSyncComplete if @state.receivingDelta items.push @_renderDeltaSyncActivityItem() else items.push names = classNames "sidebar-activity": true "sidebar-activity-error": error? wrapperClass = "sidebar-activity-transition-wrapper " if items.length is 0 wrapperClass += "sidebar-activity-empty" else inside = {items} {inside} _renderTaskActivityItems: => summary = {} @state.tasks.map (task) -> label = task.label?() return unless label summary[label] ?= 0 summary[label] += task.numberOfImpactedItems() _.pairs(summary).map ([label, count]) ->
{label} ({count})
_renderDeltaSyncActivityItem: =>
Syncing mail data…
_renderNotificationActivityItems: => @state.notifications.map (notification) ->
{notification.message}
_onDataChanged: => @setState(@_getStateFromStores()) _getStateFromStores: => notifications: NotificationStore.notifications() tasks: TaskQueueStatusStore.queue() isInitialSyncComplete: NylasSyncStatusStore.isComplete() _onDeltaReceived: (countDeltas) => tooSmallForNotification = countDeltas <= 10 return if tooSmallForNotification if @_timeoutId clearTimeout @_timeoutId @_timeoutId = setTimeout(( => delete @_timeoutId @setState receivingDelta: false ), 30000) @setState receivingDelta: true module.exports = ActivitySidebar