2016-05-28 05:05:27 +08:00
|
|
|
import React from 'react';
|
|
|
|
import ReactCSSTransitionGroup from 'react-addons-css-transition-group';
|
|
|
|
import OnboardingStore from './onboarding-store';
|
|
|
|
import PageTopBar from './page-top-bar';
|
|
|
|
|
|
|
|
import WelcomePage from './page-welcome';
|
|
|
|
import TutorialPage from './page-tutorial';
|
2016-07-22 04:59:43 +08:00
|
|
|
import SelfHostingSetupPage from './page-self-hosting-setup';
|
|
|
|
import SelfHostingConfigPage from './page-self-hosting-config';
|
2016-05-28 05:05:27 +08:00
|
|
|
import AuthenticatePage from './page-authenticate';
|
|
|
|
import AccountChoosePage from './page-account-choose';
|
|
|
|
import AccountSettingsPage from './page-account-settings';
|
|
|
|
import AccountSettingsPageGmail from './page-account-settings-gmail';
|
|
|
|
import AccountSettingsPageIMAP from './page-account-settings-imap';
|
|
|
|
import AccountSettingsPageExchange from './page-account-settings-exchange';
|
|
|
|
import InitialPreferencesPage from './page-initial-preferences';
|
|
|
|
|
|
|
|
const PageComponents = {
|
|
|
|
"welcome": WelcomePage,
|
|
|
|
"tutorial": TutorialPage,
|
2016-07-22 04:59:43 +08:00
|
|
|
"self-hosting-setup": SelfHostingSetupPage,
|
|
|
|
"self-hosting-config": SelfHostingConfigPage,
|
2016-05-28 05:05:27 +08:00
|
|
|
"authenticate": AuthenticatePage,
|
|
|
|
"account-choose": AccountChoosePage,
|
|
|
|
"account-settings": AccountSettingsPage,
|
|
|
|
"account-settings-gmail": AccountSettingsPageGmail,
|
|
|
|
"account-settings-imap": AccountSettingsPageIMAP,
|
|
|
|
"account-settings-exchange": AccountSettingsPageExchange,
|
|
|
|
"initial-preferences": InitialPreferencesPage,
|
|
|
|
}
|
|
|
|
|
|
|
|
export default class OnboardingRoot extends React.Component {
|
|
|
|
static displayName = 'OnboardingRoot';
|
|
|
|
static containerRequired = false;
|
|
|
|
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.state = this._getStateFromStore();
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
this.unsubscribe = OnboardingStore.listen(this._onStateChanged, this);
|
|
|
|
NylasEnv.center();
|
|
|
|
NylasEnv.displayWindow();
|
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
if (this.unsubscribe) {
|
|
|
|
this.unsubscribe();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_getStateFromStore = () => {
|
|
|
|
return {
|
|
|
|
page: OnboardingStore.page(),
|
|
|
|
pageDepth: OnboardingStore.pageDepth(),
|
|
|
|
accountInfo: OnboardingStore.accountInfo(),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
_onStateChanged = () => {
|
|
|
|
this.setState(this._getStateFromStore());
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const Component = PageComponents[this.state.page];
|
|
|
|
if (!Component) {
|
|
|
|
throw new Error(`Cannot find component for page: ${this.state.page}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="page-frame">
|
2016-06-09 04:47:53 +08:00
|
|
|
<PageTopBar
|
|
|
|
pageDepth={this.state.pageDepth}
|
2016-09-02 02:11:25 +08:00
|
|
|
allowMoveBack={!['initial-preferences', 'account-choose'].includes(this.state.page)}
|
2016-06-09 04:47:53 +08:00
|
|
|
/>
|
2016-05-28 05:05:27 +08:00
|
|
|
<ReactCSSTransitionGroup
|
|
|
|
transitionName="alpha-fade"
|
|
|
|
transitionLeaveTimeout={150}
|
|
|
|
transitionEnterTimeout={150}
|
|
|
|
>
|
|
|
|
<div key={this.state.page} className="page-container">
|
|
|
|
<Component accountInfo={this.state.accountInfo} ref="activePage" />
|
|
|
|
</div>
|
|
|
|
</ReactCSSTransitionGroup>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|