MyCrypto/common/components/BalanceSidebar/index.tsx

63 lines
1.4 KiB
TypeScript

import React from 'react';
import AccountInfo from './AccountInfo';
import Promos from './Promos';
import TokenBalances from './TokenBalances';
import { AppState } from 'reducers';
import { getWalletInst } from 'selectors/wallet';
import { connect } from 'react-redux';
import EquivalentValues from './EquivalentValues';
interface Block {
name: string;
content: React.ReactElement<any>;
isFullWidth?: boolean;
}
interface StateProps {
wallet: AppState['wallet']['inst'];
}
export class BalanceSidebar extends React.Component<StateProps> {
public render() {
const { wallet } = this.props;
if (!wallet) {
return null;
}
const blocks: Block[] = [
{
name: 'Account Info',
content: <AccountInfo wallet={wallet} />
},
{
name: 'Promos',
isFullWidth: true,
content: <Promos />
},
{
name: 'Token Balances',
content: <TokenBalances />
},
{
name: 'Equivalent Values',
content: <EquivalentValues />
}
];
return (
<aside>
{blocks.map(block => (
<section className={`Block ${block.isFullWidth ? 'is-full-width' : ''}`} key={block.name}>
{block.content}
</section>
))}
</aside>
);
}
}
const mapStateToProps = (state: AppState): StateProps => ({ wallet: getWalletInst(state) });
export default connect(mapStateToProps)(BalanceSidebar);