mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-02-09 17:54:22 +00:00
* Add definition file for bn.js * Remove types-bn * make isBN a static property * progress commit -- swap out bignumber.js for bn.js * Swap out bignumber for bn in vendor * Change modn to number return * Start to strip out units lib for a string manipulation based lib * Convert codebase to only base units * Get rid of useless component * Handle only wei in values * Use unit conversion in sidebar * Automatically strip hex prefix, and handle decimal edge case * Handle base 16 wei in transactions * Make a render callback component for dealing with unit conversion * Switch contracts to use bn.js, and get transaction values from signedTx instead of state * Get send transaction working with bn.js * Remove redundant hex stripping, return base value of tokens * Cleanup unit file * Re-implement toFixed for strings * Use formatNumber in codebase * Cleanup code * Undo package test changes * Update snapshot and remove console logs * Use TokenValue / Wei more consistently where applicable * Add typing to deterministicWallets, fix confirmation modal, make UnitDisplay more flexible * Clean up prop handling in UnitDisplay * Change instanceof to typeof check, change boolean of displayBalance * Fix tsc errors * Fix token row displaying wrong decimals * Fix deterministic modal token display * Handle hex and non hex strings automatically in BN conversion * Fix handling of strings and numbers for BN * add web3 fixes & comments * Display short balances on deterministic modals * add more tests, fix rounding * Add spacer to balance sidebar network name * Fix tsc error
94 lines
2.5 KiB
TypeScript
94 lines
2.5 KiB
TypeScript
import { Token } from 'config/data';
|
|
import React from 'react';
|
|
import { TokenBalance } from 'selectors/wallet';
|
|
import translate from 'translations';
|
|
import AddCustomTokenForm from './AddCustomTokenForm';
|
|
import './index.scss';
|
|
import TokenRow from './TokenRow';
|
|
|
|
interface Props {
|
|
tokens: TokenBalance[];
|
|
onAddCustomToken(token: Token): any;
|
|
onRemoveCustomToken(symbol: string): any;
|
|
}
|
|
|
|
interface State {
|
|
showAllTokens: boolean;
|
|
showCustomTokenForm: boolean;
|
|
}
|
|
export default class TokenBalances extends React.Component<Props, State> {
|
|
public state = {
|
|
showAllTokens: false,
|
|
showCustomTokenForm: false
|
|
};
|
|
|
|
public render() {
|
|
const { tokens } = this.props;
|
|
const shownTokens = tokens.filter(
|
|
token => !token.balance.eqn(0) || token.custom || this.state.showAllTokens
|
|
);
|
|
|
|
return (
|
|
<section className="TokenBalances">
|
|
<h5 className="TokenBalances-title">{translate('sidebar_TokenBal')}</h5>
|
|
<table className="TokenBalances-rows">
|
|
<tbody>
|
|
{shownTokens.map(token => (
|
|
<TokenRow
|
|
key={token.symbol}
|
|
balance={token.balance}
|
|
symbol={token.symbol}
|
|
custom={token.custom}
|
|
decimal={token.decimal}
|
|
onRemove={this.props.onRemoveCustomToken}
|
|
/>
|
|
))}
|
|
</tbody>
|
|
</table>
|
|
|
|
<div className="TokenBalances-buttons">
|
|
<button
|
|
className="btn btn-default btn-xs"
|
|
onClick={this.toggleShowAllTokens}
|
|
>
|
|
{!this.state.showAllTokens ? 'Show All Tokens' : 'Hide Tokens'}
|
|
</button>{' '}
|
|
<button
|
|
className="btn btn-default btn-xs"
|
|
onClick={this.toggleShowCustomTokenForm}
|
|
>
|
|
<span>{translate('SEND_custom')}</span>
|
|
</button>
|
|
</div>
|
|
|
|
{this.state.showCustomTokenForm && (
|
|
<div className="TokenBalances-form">
|
|
<AddCustomTokenForm onSave={this.addCustomToken} />
|
|
</div>
|
|
)}
|
|
</section>
|
|
);
|
|
}
|
|
|
|
public toggleShowAllTokens = () => {
|
|
this.setState(state => {
|
|
return {
|
|
showAllTokens: !state.showAllTokens
|
|
};
|
|
});
|
|
};
|
|
|
|
public toggleShowCustomTokenForm = () => {
|
|
this.setState(state => {
|
|
return {
|
|
showCustomTokenForm: !state.showCustomTokenForm
|
|
};
|
|
});
|
|
};
|
|
|
|
public addCustomToken = (token: Token) => {
|
|
this.props.onAddCustomToken(token);
|
|
this.setState({ showCustomTokenForm: false });
|
|
};
|
|
}
|