* Render Dapps via SectionList * Initial rendering of accounts via SectionList * Width vars * Allow classNames in certifications & tags * Overlay of info on hover * Adjust hover balances * Large owner icons (align with vaults) * Consistent block mined at message * Attach ParityBackground to html * Adjust page padding to align * Lint fixes * Link to different types of addresses * Make content parts clickable only (a within a) * Force Chrome hardware acceleration * Trust the vendors... don't go crazy with transform :) * Use faster & default transitions * Add VaultMeta edit dialog * Updated (WIP) * Meta & password edit completed * Added SelectionList component for selections * Use SelectionList in DappPermisions * AddDapps uses SelectionList * Fix AccountCard to consistent height * Display type icons in creation dialog * Complimentary colours * Convert Signer defaults to SelectionList * Fix Geth import - actually pass addresses through * Work from addresses returned via RPC * Display actual addresses imported (not selected) * Update tests to cover bug fixed * Prettyfy Geth import * Description on selection actions * SelectionList as entry point * Update failing tests * Subtle selection border * Styling updates for account details * Add ModalBox summary * AddAddress updated * Display account vault information * Allow invalid addresses to display icons (e.g. vaults) * Display vault on edit meta * Convert VaultAccounts to SelectionList * Allow editing of Vault in meta * Add tests for SectionList component * Add tests for ModalBox component * Add tests for VaultSelector component * Add vaultsOpened in store * Add ~/ui/Form/VaultSelect * WIP * Fix failing tests * Move account to vault when selected * Fix circular build deps * EditMeta uses Form/VaultSelect * Vault move into meta store (alignment) * Re-apply stretch fix * Display vault in account summary * Add busy indicators to relevant modals * Auto-focus description field (aligns with #4657) * Remove extra container (double scrolling) * Remove unused container style * Apply scroll fixes from lates commit in #4621 * Remove unneeded logs * Remove extra div, fixing ParityBar overflow * Make dapp iframe background white * Stop event propgation on tag click * ChangeVault component (re-usable) * Use ChangeVault component * Pass vaultStores in * Icon highlight colour * Tag-ify vault name display * ChangeVault location * Bothced merge, selector rendering twice * Value can be undefined (no vault) * Close selector on Select bug * Fix toggle botched merge * Update tests * Add Vault Tags to Account Header
101 lines
2.5 KiB
JavaScript
101 lines
2.5 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 { observer } from 'mobx-react';
|
|
import React, { Component, PropTypes } from 'react';
|
|
import { FormattedMessage } from 'react-intl';
|
|
|
|
import Portal from '~/ui/Portal';
|
|
import SelectionList from '~/ui/SelectionList';
|
|
import VaultCard from '~/ui/VaultCard';
|
|
|
|
@observer
|
|
export default class VaultSelector extends Component {
|
|
static propTypes = {
|
|
onClose: PropTypes.func.isRequired,
|
|
onSelect: PropTypes.func.isRequired,
|
|
selected: PropTypes.string,
|
|
vaultStore: PropTypes.object.isRequired
|
|
};
|
|
|
|
render () {
|
|
return (
|
|
<Portal
|
|
isChildModal
|
|
onClose={ this.onClose }
|
|
open
|
|
title={
|
|
<FormattedMessage
|
|
id='vaults.selector.title'
|
|
defaultMessage='Select Account Vault'
|
|
/>
|
|
}
|
|
>
|
|
{ this.renderList() }
|
|
</Portal>
|
|
);
|
|
}
|
|
|
|
renderList () {
|
|
const { vaultsOpened } = this.props.vaultStore;
|
|
|
|
if (vaultsOpened.length === 0) {
|
|
return (
|
|
<FormattedMessage
|
|
id='vaults.selector.noneAvailable'
|
|
defaultMessage='There are currently no vaults opened and available for selection. Create and open some first before attempting to select a vault for an account move.'
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<SelectionList
|
|
items={ vaultsOpened }
|
|
isChecked={ this.isSelected }
|
|
noStretch
|
|
onSelectClick={ this.onSelect }
|
|
renderItem={ this.renderVault }
|
|
/>
|
|
);
|
|
}
|
|
|
|
renderVault = (vault) => {
|
|
return (
|
|
<VaultCard
|
|
hideAccounts
|
|
hideButtons
|
|
vault={ vault }
|
|
/>
|
|
);
|
|
}
|
|
|
|
isSelected = (vault) => {
|
|
return this.props.selected === vault.name;
|
|
}
|
|
|
|
onSelect = (vault) => {
|
|
this.props.onSelect(
|
|
this.props.selected === vault.name
|
|
? ''
|
|
: vault.name
|
|
);
|
|
}
|
|
|
|
onClose = () => {
|
|
this.props.onClose();
|
|
}
|
|
}
|