// Copyright 2017-2026 @pezkuwi/react-query authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { ApiPromise } from '@pezkuwi/api'; import type { BN } from '@pezkuwi/util'; import React from 'react'; import { styled } from '@pezkuwi/react-components/styled'; import { useBlockTime } from '@pezkuwi/react-hooks'; interface Props { api?: ApiPromise; children?: React.ReactNode; className?: string; isInline?: boolean; label?: React.ReactNode; value?: BN; } function BlockToTime ({ api, children, className = '', isInline, label, value }: Props): React.ReactElement | null { const [, text] = useBlockTime(value, api); if (!value || value.isZero()) { return null; } return ( {label || ''}{text.split(' ').map((v, index) => {v} )}{children} ); } const StyledDiv = styled.div` &.isInline { display: inline-block; } span+span { padding-left: 0.25em; } span.timeUnits { font-size: var(--font-percent-tiny); } `; export default React.memo(BlockToTime);