polkadot-js/apps

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

Summary

Maintainability
A
25 mins
Test Coverage
// Copyright 2017-2024 @polkadot/react-query authors & contributors
// SPDX-License-Identifier: Apache-2.0

import type { BlockNumber } from '@polkadot/types/interfaces';

import React from 'react';

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

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

function BestNumber ({ children, className = '', isFinalized, label, withPound }: Props): React.ReactElement<Props> {
  const { api, isApiReady } = useApi();
  const bestNumber = useCall<BlockNumber>(isApiReady && (isFinalized ? api.derive.chain.bestNumberFinalized : api.derive.chain.bestNumber));

  return (
    <div className={`${className} ${bestNumber ? '' : '--tmp'}`}>
      {label || ''}{withPound && '#'}{
        <span className='--digits'>{formatNumber(bestNumber || 1234)}</span>
      }{children}
    </div>
  );
}

export default React.memo(BestNumber);