* Start removing duplicated functionality (v1 inside v2) * Update compilation targets * Update locks * Fix js-old build * Update with removed extra references * Adapt dev.{parity,web3}.html for extra debug info * Update dependencies * Remove Tooltips * Update dependencies * Only inject window.ethereum once * Fix versions to 2.0.x for @parity libraries * Update to @parity/api 2.1.x * Update for @parity/api 2.1.x * Freeze signer plugin dependency hashes * Fix lint * Move local account handling from API * Update for 2.2.x @parity/{shared,ui} * Update API references for middleware * Install updated dependencies * Update for build * Always do local builds for development * Remove unused hasAccounts property * Fix Windows build for js-old * Adjust inclusing rules to be Windows friendly * Explicitly add --config option to webpack * Add process.env.EMBED flag for Windows compatability * Revert embed flag * Fix build * Merge changes from beta * Update packages after merge * Update Accounts from beta * Update with beta * Remove upgrade check * Fix CI build script execution * Make rm -rf commands cross-platform * Remove ability to deploy wallets (only watch) * Update path references for js-old (Windows) * Render local dapps first * Cleanup dependencies
143 lines
3.6 KiB
JavaScript
143 lines
3.6 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 { connect } from 'react-redux';
|
|
import { Link } from 'react-router';
|
|
import { Toolbar, ToolbarGroup } from 'material-ui/Toolbar';
|
|
import { isEqual } from 'lodash';
|
|
|
|
import { StatusIndicator } from '~/ui';
|
|
|
|
import Tab from './Tab';
|
|
import styles from './tabBar.css';
|
|
|
|
class TabBar extends Component {
|
|
static contextTypes = {
|
|
router: PropTypes.object.isRequired
|
|
};
|
|
|
|
static propTypes = {
|
|
pending: PropTypes.array,
|
|
health: PropTypes.object.isRequired,
|
|
views: PropTypes.array.isRequired
|
|
};
|
|
|
|
static defaultProps = {
|
|
pending: []
|
|
};
|
|
|
|
render () {
|
|
const { health } = this.props;
|
|
|
|
return (
|
|
<Toolbar className={ styles.toolbar }>
|
|
<ToolbarGroup className={ styles.first }>
|
|
<div />
|
|
</ToolbarGroup>
|
|
<div className={ styles.tabs }>
|
|
<Link
|
|
activeClassName={ styles.tabactive }
|
|
className={ `${styles.tabLink} ${styles.indicatorTab}` }
|
|
key='status'
|
|
to='/status'
|
|
>
|
|
<div className={ styles.indicator }>
|
|
<StatusIndicator
|
|
type='signal'
|
|
id='topbar.health'
|
|
status={ health.overall.status }
|
|
title={ health.overall.message }
|
|
/>
|
|
</div>
|
|
</Link>
|
|
{ this.renderTabItems() }
|
|
</div>
|
|
<ToolbarGroup className={ styles.last }>
|
|
<div />
|
|
</ToolbarGroup>
|
|
</Toolbar>
|
|
);
|
|
}
|
|
|
|
renderTabItems () {
|
|
const { views, pending } = this.props;
|
|
|
|
return views.map((view, index) => {
|
|
return (
|
|
<Link
|
|
activeClassName={ styles.tabactive }
|
|
className={ styles.tabLink }
|
|
key={ view.id }
|
|
to={ view.route }
|
|
>
|
|
<Tab
|
|
pendings={ pending.length }
|
|
view={ view }
|
|
/>
|
|
</Link>
|
|
);
|
|
});
|
|
}
|
|
}
|
|
|
|
function mapStateToProps (initState) {
|
|
const { views } = initState.settings;
|
|
|
|
let filteredViewIds = Object
|
|
.keys(views)
|
|
.filter((id) => views[id].fixed || views[id].active);
|
|
|
|
let filteredViews = filteredViewIds.map((id) => ({
|
|
...views[id],
|
|
id
|
|
}));
|
|
|
|
return (state) => {
|
|
const { availability = 'unknown' } = state.nodeStatus.nodeKind || {};
|
|
const { views } = state.settings;
|
|
const { health } = state.nodeStatus;
|
|
|
|
const viewIds = Object
|
|
.keys(views)
|
|
.filter((id) => {
|
|
const view = views[id];
|
|
|
|
const isEnabled = view.fixed || view.active;
|
|
const isAllowed = !view.onlyPersonal || availability === 'personal';
|
|
|
|
return isEnabled && isAllowed;
|
|
});
|
|
|
|
if (isEqual(viewIds, filteredViewIds)) {
|
|
return { views: filteredViews, health };
|
|
}
|
|
|
|
filteredViewIds = viewIds;
|
|
filteredViews = viewIds.map((id) => ({
|
|
...views[id],
|
|
id
|
|
}));
|
|
|
|
return { views: filteredViews, health };
|
|
};
|
|
}
|
|
|
|
export default connect(
|
|
mapStateToProps,
|
|
null
|
|
)(TabBar);
|