123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- import { I18nProps } from '@polkadot/react-components/types';
- import BN from 'bn.js';
- import React from 'react';
- import { SummaryBox, CardSummary } from '@polkadot/react-components';
- import { withCalls } from '@polkadot/react-api';
- import { formatBalance, formatNumber } from '@polkadot/util';
- import translate from '../translate';
- interface Props extends I18nProps {
- treasury_proposalCount?: BN;
- treasury_approvals?: BN[];
- treasury_pot?: BN;
- }
- function Summary ({ treasury_proposalCount, treasury_approvals, treasury_pot, t }: Props): React.ReactElement<Props> {
- const value = treasury_pot && treasury_pot.gtn(0)
- ? treasury_pot.toString()
- : null;
- return (
- <SummaryBox>
- <section>
- <CardSummary label={t('proposals')}>
- {formatNumber(treasury_proposalCount)}
- </CardSummary>
- <CardSummary label={t('approved')}>
- {treasury_approvals ? treasury_approvals.length : '0'}
- </CardSummary>
- </section>
- <section>
- {value && (
- <CardSummary label={t('pot')}>
- {formatBalance(value, false)}{formatBalance.calcSi(value).value}
- </CardSummary>
- )}
- </section>
- </SummaryBox>
- );
- }
- export default translate(
- withCalls<Props>(
- 'query.treasury.proposalCount',
- 'query.treasury.approvals',
- 'query.treasury.pot'
- )(Summary)
- );
|