polkadot-js/apps

View on GitHub
packages/react-query/src/TotalIssuance.tsx

Summary

Maintainability
B
6 hrs
Test Coverage
// Copyright 2017-2024 @polkadot/react-query authors & contributors
// SPDX-License-Identifier: Apache-2.0

import React from 'react';

import { useApi, useCall } from '@polkadot/react-hooks';

import FormatBalance from './FormatBalance.js';

interface Props {
  children?: React.ReactNode;
  className?: string;
  label?: React.ReactNode;
}

function TotalIssuance ({ children, className = '', label }: Props): React.ReactElement<Props> | null {
  const { api } = useApi();
  const totalIssuance = useCall<string>(api.query.balances?.totalIssuance);

  return (
    <div className={className}>
      {label || ''}
      <FormatBalance
        className={totalIssuance ? '' : '--tmp'}
        value={totalIssuance || 1}
        withSi
      />
      {children}
    </div>
  );
}

export default React.memo(TotalIssuance);