// 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 . import { observer } from 'mobx-react'; import React, { Component, PropTypes } from 'react'; import { FormattedMessage } from 'react-intl'; import { DappCard, Page, SelectionList } from '@parity/ui'; import Store from './store'; import styles from './dappVisible.css'; @observer export default class DappVisible extends Component { static contextTypes = { api: PropTypes.object.isRequired }; store = new Store(this.context.api); render () { return ( } >
{ this.renderList(this.store.sortedLocal, this.store.displayApps, , ) } { this.renderList(this.store.sortedBuiltin, this.store.displayApps, , ) } { this.renderList(this.store.sortedNetwork, this.store.displayApps, , ) } ); } renderList (items, visibleItems, header, byline) { if (!items || !items.length) { return null; } return (
{ header }
{ byline }
); } renderApp = (app) => { return ( ); } isVisible = (app) => { return (this.store.displayApps[app.id] && this.store.displayApps[app.id].visible) || false; } onSelect = (app) => { if (this.isVisible(app)) { this.store.hideApp(app.id); } else { this.store.showApp(app.id); } } }