import _ from 'underscore'; import _str from 'underscore.string'; import classNames from 'classnames'; import {Actions, AccountStore, NylasSyncStatusStore, React} from 'nylas-exports'; const MONTH_SHORT_FORMATS = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']; export default class InitialSyncActivity extends React.Component { static displayName = 'InitialSyncActivity'; constructor(props) { super(props); this.state = { isExpanded: false, syncState: NylasSyncStatusStore.getSyncState(), syncProgress: NylasSyncStatusStore.getSyncProgress(), } this.mounted = false; } componentDidMount() { this.mounted = true; this.unsubs = [ NylasSyncStatusStore.listen(this.onDataChanged), Actions.expandInitialSyncState.listen(this.showExpandedState), ] } componentWillUnmount() { if (this.unsubs) { this.unsubs.forEach((unsub) => unsub()) } this.mounted = false; } onDataChanged = () => { const syncState = NylasSyncStatusStore.getSyncState() const syncProgress = NylasSyncStatusStore.getSyncProgress() this.setState({syncState, syncProgress}); } hideExpandedState = () => { this.setState({isExpanded: false}); } showExpandedState = () => { if (!this.state.isExpanded) { this.setState({isExpanded: true}); } else { this.setState({blink: true}); setTimeout(() => { if (this.mounted) { this.setState({blink: false}); } }, 1000) } } renderExpandedSyncState() { let maxHeight = 0; let accounts = _.map(this.state.syncState, (accountSyncState, accountId) => { const account = _.findWhere(AccountStore.accounts(), {id: accountId}); if (!account) { return false; } const {folderSyncProgress} = accountSyncState let folderStates = _.map(folderSyncProgress, ({progress, oldestProcessedDate}, name) => { return this.renderFolderProgress(name, progress, oldestProcessedDate) }) if (folderStates.length === 0) { folderStates =

Gathering folders...
} // A row for the account email address plus a row for each folder state, const numRows = 1 + (folderStates.length || 1) maxHeight += 50 * numRows; return (

{account.emailAddress}

{folderStates}
) }); if (accounts.length === 0) { accounts =

Looking for accounts...
} return (
Hide {accounts}
) } renderFolderProgress(name, progress, oldestProcessedDate) { let status = 'busy'; let progressLabel = 'In Progress' let syncedThrough = 'Syncing this past month'; if (progress === 1) { status = 'complete'; progressLabel = ''; syncedThrough = 'Up to date' } else { let month = oldestProcessedDate.getMonth(); let year = oldestProcessedDate.getFullYear(); const currentDate = new Date(); if (month !== currentDate.getMonth() || year !== currentDate.getFullYear()) { // We're currently syncing in `month`, which mean's we've synced through all // of the month *after* it. month++; if (month === 12) { month = 0; year++; } syncedThrough = `Synced through ${MONTH_SHORT_FORMATS[month]} ${year}`; } } return (
{_str.titleize(name)} {progressLabel}
) } render() { if (!AccountStore.accountsAreSyncing()) { return false; } const {syncProgress: {progress}} = this.state if (progress === 1) { return false; } const classSet = classNames({ 'item': true, 'expanded-sync': this.state.isExpanded, 'blink': this.state.blink, }); return (
(this.setState({isExpanded: !this.state.isExpanded}))} >
Syncing your mailbox
{this.state.isExpanded ? this.renderExpandedSyncState() : false}
) } }