2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2019-07-08 16:54:58 -04:00
|
|
|
import * as PAGES from 'constants/pages';
|
2020-06-19 16:18:12 -04:00
|
|
|
import * as ICONS from 'constants/icons';
|
2018-03-26 14:32:43 -07:00
|
|
|
import * as React from 'react';
|
2021-08-09 08:36:42 +08:00
|
|
|
import classnames from 'classnames';
|
2018-03-26 14:32:43 -07:00
|
|
|
import Button from 'component/button';
|
|
|
|
import Page from 'component/page';
|
2021-08-05 15:00:21 +08:00
|
|
|
import SettingAccount from 'component/settingAccount';
|
2021-08-05 17:18:16 +08:00
|
|
|
import SettingAppearance from 'component/settingAppearance';
|
2021-08-06 10:41:37 +08:00
|
|
|
import SettingContent from 'component/settingContent';
|
2021-08-05 16:41:45 +08:00
|
|
|
import SettingSystem from 'component/settingSystem';
|
2021-08-09 08:36:42 +08:00
|
|
|
import SettingUnauthenticated from 'component/settingUnauthenticated';
|
2020-11-10 00:21:04 -05:00
|
|
|
import Yrbl from 'component/yrbl';
|
2019-11-18 10:30:15 -08:00
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
type DaemonSettings = {
|
2019-02-12 12:26:50 -05:00
|
|
|
download_dir: string,
|
2018-03-26 14:32:43 -07:00
|
|
|
share_usage_data: boolean,
|
|
|
|
};
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
daemonSettings: DaemonSettings,
|
2019-11-22 16:13:00 -05:00
|
|
|
isAuthenticated: boolean,
|
2020-09-04 11:02:30 -04:00
|
|
|
enterSettings: () => void,
|
|
|
|
exitSettings: () => void,
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
|
|
|
|
2021-08-05 16:41:45 +08:00
|
|
|
class SettingsPage extends React.PureComponent<Props> {
|
2018-03-26 14:32:43 -07:00
|
|
|
componentDidMount() {
|
2021-08-05 15:00:21 +08:00
|
|
|
const { enterSettings } = this.props;
|
2020-09-04 11:02:30 -04:00
|
|
|
enterSettings();
|
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
const { exitSettings } = this.props;
|
|
|
|
exitSettings();
|
2017-05-17 04:10:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2021-08-08 16:26:43 +08:00
|
|
|
const { daemonSettings, isAuthenticated } = this.props;
|
2018-03-26 14:32:43 -07:00
|
|
|
const noDaemonSettings = !daemonSettings || Object.keys(daemonSettings).length === 0;
|
2019-02-12 12:26:50 -05:00
|
|
|
|
2021-08-09 09:08:36 +08:00
|
|
|
return (
|
2021-08-08 16:13:35 +08:00
|
|
|
<Page
|
|
|
|
noFooter
|
|
|
|
settingsPage
|
|
|
|
noSideNavigation
|
2021-12-23 16:49:18 +08:00
|
|
|
backout={{ title: __('Settings'), backLabel: __('Save') }}
|
2021-08-08 16:13:35 +08:00
|
|
|
className="card-stack"
|
|
|
|
>
|
2021-08-19 09:36:43 +08:00
|
|
|
{!isAuthenticated && IS_WEB && (
|
|
|
|
<>
|
|
|
|
<SettingUnauthenticated />
|
|
|
|
<div className="main--empty">
|
|
|
|
<Yrbl
|
|
|
|
type="happy"
|
|
|
|
title={__('Sign up for full control')}
|
|
|
|
subtitle={__('Unlock new buttons that change things.')}
|
|
|
|
actions={
|
|
|
|
<div className="section__actions">
|
|
|
|
<Button button="primary" icon={ICONS.SIGN_UP} label={__('Sign Up')} navigate={`/$/${PAGES.AUTH}`} />
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
/>
|
2021-08-08 16:13:35 +08:00
|
|
|
</div>
|
2021-08-19 09:36:43 +08:00
|
|
|
</>
|
|
|
|
)}
|
|
|
|
|
|
|
|
{!IS_WEB && noDaemonSettings ? (
|
|
|
|
<section className="card card--section">
|
|
|
|
<div className="card__title card__title--deprecated">{__('Failed to load settings.')}</div>
|
|
|
|
</section>
|
|
|
|
) : (
|
|
|
|
<div className={classnames('card-stack', { 'card--disabled': IS_WEB && !isAuthenticated })}>
|
|
|
|
<SettingAppearance />
|
|
|
|
<SettingAccount />
|
|
|
|
<SettingContent />
|
|
|
|
<SettingSystem />
|
|
|
|
</div>
|
|
|
|
)}
|
2018-03-26 14:32:43 -07:00
|
|
|
</Page>
|
2016-04-09 20:00:56 -04:00
|
|
|
);
|
|
|
|
}
|
2017-05-17 04:10:25 -04:00
|
|
|
}
|
2016-11-22 14:19:08 -06:00
|
|
|
|
2020-07-27 13:43:30 -04:00
|
|
|
export default SettingsPage;
|