Mailspring/packages/client-app/internal_packages/notifications/lib/sidebar/initial-sync-activity.jsx

100 lines
2.6 KiB
React
Raw Normal View History

import _ from 'underscore';
import _str from 'underscore.string';
import {Utils, AccountStore, FolderSyncProgressStore, React} from 'nylas-exports';
export default class InitialSyncActivity extends React.Component {
static displayName = 'InitialSyncActivity';
constructor(props) {
super(props);
this.state = {
syncState: FolderSyncProgressStore.getSyncState(),
}
this.mounted = false;
}
componentDidMount() {
this.mounted = true;
this.unsub = FolderSyncProgressStore.listen(this.onDataChanged)
}
shouldComponentUpdate(nextProps, nextState) {
return !Utils.isEqualReact(nextProps, this.props) ||
!Utils.isEqualReact(nextState, this.state);
}
componentWillUnmount() {
this.unsub();
this.mounted = false;
}
onDataChanged = () => {
const syncState = Utils.deepClone(FolderSyncProgressStore.getSyncState())
this.setState({syncState});
}
renderFolderProgress(name, progress) {
let status = 'busy';
let progressLabel = `In Progress (${Math.round(progress * 100)}%)`;
if (progress === 1) {
status = 'complete';
progressLabel = '';
}
return (
<div className={`model-progress ${status}`} key={name}>
{_str.titleize(name)} <span className="progress-label">{progressLabel}</span>
</div>
)
}
render() {
if (!AccountStore.accountsAreSyncing() || FolderSyncProgressStore.isSyncComplete()) {
return false;
}
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}, name) => {
return this.renderFolderProgress(name, progress)
})
if (folderStates.length === 0) {
folderStates = <div><br />Gathering folders...</div>
}
// A row for the account email address plus a row for each folder state,
const numRows = 1 + (folderStates.length || 1)
maxHeight += 50 * numRows;
return (
<div className="account" key={accountId}>
<h2>{account.emailAddress}</h2>
{folderStates}
</div>
)
});
if (accounts.length === 0) {
accounts = <div><br />Looking for accounts...</div>
}
return (
<div
className="account-detail-area"
key="expanded-sync-state"
style={{maxHeight: `${maxHeight + 500}px`}}
>
{accounts}
</div>
)
}
}