99 lines
2.9 KiB
JavaScript
99 lines
2.9 KiB
JavaScript
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||
|
// This file is part of Parity.
|
||
|
|
||
|
// Parity is free software: you can redistribute it and/or modify
|
||
|
// it under the terms of the GNU General Public License as published by
|
||
|
// the Free Software Foundation, either version 3 of the License, or
|
||
|
// (at your option) any later version.
|
||
|
|
||
|
// Parity is distributed in the hope that it will be useful,
|
||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
// GNU General Public License for more details.
|
||
|
|
||
|
// You should have received a copy of the GNU General Public License
|
||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||
|
|
||
|
import React, { Component, PropTypes } from 'react';
|
||
|
import { FormattedMessage } from 'react-intl';
|
||
|
import { Tab, Tabs } from 'material-ui';
|
||
|
import ActionSettingsEthernet from 'material-ui/svg-icons/action/settings-ethernet';
|
||
|
import ImageBlurOn from 'material-ui/svg-icons/image/blur-on';
|
||
|
import ImageRemoveRedEye from 'material-ui/svg-icons/image/remove-red-eye';
|
||
|
|
||
|
import { Actionbar, Page } from '~/ui';
|
||
|
import imagesEthcoreBlock from '../../../assets/images/parity-logo-white-no-text.svg';
|
||
|
|
||
|
import styles from './settings.css';
|
||
|
|
||
|
export default class Settings extends Component {
|
||
|
static contextTypes = {
|
||
|
router: PropTypes.object.isRequired
|
||
|
}
|
||
|
|
||
|
static propTypes = {
|
||
|
children: PropTypes.object.isRequired
|
||
|
}
|
||
|
|
||
|
render () {
|
||
|
const { children } = this.props;
|
||
|
const hash = (window.location.hash || '').split('?')[0].split('/')[2];
|
||
|
const isProxied = window.location.hostname.indexOf('.parity') !== -1;
|
||
|
let proxy = null;
|
||
|
|
||
|
if (!isProxied) {
|
||
|
proxy = this.renderTab(hash, 'proxy', <ActionSettingsEthernet />);
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<div>
|
||
|
<Actionbar
|
||
|
className={ styles.bar }
|
||
|
title={
|
||
|
<FormattedMessage id='settings.label' />
|
||
|
}
|
||
|
>
|
||
|
<Tabs className={ styles.tabs } value={ hash }>
|
||
|
{ this.renderTab(hash, 'views', <ImageRemoveRedEye />) }
|
||
|
{ this.renderTab(hash, 'background', <ImageBlurOn />) }
|
||
|
{ proxy }
|
||
|
{ this.renderTab(hash, 'parity', <img src={ imagesEthcoreBlock } className={ styles.imageIcon } />) }
|
||
|
</Tabs>
|
||
|
</Actionbar>
|
||
|
<Page>
|
||
|
{ children }
|
||
|
</Page>
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
renderTab (hash, section, icon) {
|
||
|
return (
|
||
|
<Tab
|
||
|
className={
|
||
|
hash === section
|
||
|
? styles.tabactive
|
||
|
: styles.tab
|
||
|
}
|
||
|
icon={ icon }
|
||
|
key={ section }
|
||
|
label={
|
||
|
<div className={ styles.menu }>
|
||
|
<FormattedMessage id={ `settings.${section}.label` } />
|
||
|
</div>
|
||
|
}
|
||
|
onActive={ this.onActivate(section) }
|
||
|
value={ section }
|
||
|
/>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
onActivate = (section) => {
|
||
|
const { router } = this.context;
|
||
|
|
||
|
return (event) => {
|
||
|
router.push(`/settings/${section}`);
|
||
|
};
|
||
|
}
|
||
|
}
|