2016-12-20 04:39:56 +08:00
|
|
|
import _ from 'underscore';
|
2017-07-05 14:32:52 +08:00
|
|
|
import {AccountStore, FolderSyncProgressStore, React} from 'nylas-exports';
|
2016-12-20 04:39:56 +08:00
|
|
|
|
|
|
|
export default class InitialSyncActivity extends React.Component {
|
|
|
|
static displayName = 'InitialSyncActivity';
|
|
|
|
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
2016-12-21 20:28:21 +08:00
|
|
|
this.state = {
|
2017-03-09 04:24:59 +08:00
|
|
|
syncState: FolderSyncProgressStore.getSyncState(),
|
2016-12-21 20:28:21 +08:00
|
|
|
}
|
2017-01-04 05:24:10 +08:00
|
|
|
this.mounted = false;
|
2016-12-20 04:39:56 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
2017-01-04 05:24:10 +08:00
|
|
|
this.mounted = true;
|
2017-03-09 04:24:59 +08:00
|
|
|
this.unsub = FolderSyncProgressStore.listen(this.onDataChanged)
|
2016-12-20 04:39:56 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
2017-01-16 06:10:04 +08:00
|
|
|
this.unsub();
|
2017-01-04 05:24:10 +08:00
|
|
|
this.mounted = false;
|
2016-12-20 04:39:56 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
onDataChanged = () => {
|
2017-07-05 14:32:52 +08:00
|
|
|
this.setState({syncState: FolderSyncProgressStore.getSyncState()});
|
2016-12-20 04:39:56 +08:00
|
|
|
}
|
|
|
|
|
2017-07-05 14:32:52 +08:00
|
|
|
renderFolderProgress(folderPath, progress) {
|
2017-01-16 06:10:04 +08:00
|
|
|
let status = 'busy';
|
2017-07-05 13:38:53 +08:00
|
|
|
let progressLabel = `In Progress (${Math.round(progress * 100)}%)`;
|
2017-01-16 06:10:04 +08:00
|
|
|
if (progress === 1) {
|
|
|
|
status = 'complete';
|
|
|
|
progressLabel = '';
|
2017-01-04 05:24:10 +08:00
|
|
|
}
|
2017-01-16 06:10:04 +08:00
|
|
|
|
|
|
|
return (
|
2017-07-05 14:32:52 +08:00
|
|
|
<div className={`model-progress ${status}`} key={folderPath}>
|
|
|
|
{folderPath} <span className="progress-label">{progressLabel}</span>
|
2017-01-16 06:10:04 +08:00
|
|
|
</div>
|
|
|
|
)
|
2017-01-04 05:24:10 +08:00
|
|
|
}
|
|
|
|
|
2017-01-16 06:10:04 +08:00
|
|
|
render() {
|
2017-07-05 14:32:52 +08:00
|
|
|
if (FolderSyncProgressStore.isSyncComplete()) {
|
2017-01-16 06:10:04 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-07-05 14:32:52 +08:00
|
|
|
|
2017-01-04 05:24:10 +08:00
|
|
|
let maxHeight = 0;
|
|
|
|
let accounts = _.map(this.state.syncState, (accountSyncState, accountId) => {
|
2017-07-05 14:32:52 +08:00
|
|
|
const account = AccountStore.accountForId(accountId);
|
2016-12-20 04:39:56 +08:00
|
|
|
if (!account) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-07-05 14:32:52 +08:00
|
|
|
let folderStates = _.map(accountSyncState, ({progress}, folderPath) => {
|
|
|
|
return this.renderFolderProgress(folderPath, progress)
|
2016-12-20 04:39:56 +08:00
|
|
|
})
|
|
|
|
|
2017-01-04 05:24:10 +08:00
|
|
|
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;
|
|
|
|
|
2016-12-20 04:39:56 +08:00
|
|
|
return (
|
2017-01-14 03:56:20 +08:00
|
|
|
<div className="account" key={accountId}>
|
2016-12-20 04:39:56 +08:00
|
|
|
<h2>{account.emailAddress}</h2>
|
|
|
|
{folderStates}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
});
|
|
|
|
|
2017-01-04 05:24:10 +08:00
|
|
|
if (accounts.length === 0) {
|
|
|
|
accounts = <div><br />Looking for accounts...</div>
|
|
|
|
}
|
|
|
|
|
2016-12-20 04:39:56 +08:00
|
|
|
return (
|
2017-01-04 05:24:10 +08:00
|
|
|
<div
|
|
|
|
className="account-detail-area"
|
|
|
|
key="expanded-sync-state"
|
|
|
|
style={{maxHeight: `${maxHeight + 500}px`}}
|
|
|
|
>
|
2016-12-20 04:39:56 +08:00
|
|
|
{accounts}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|