Files
pezkuwi-apps/packages/react-query/src/BlockToTime.tsx
T

55 lines
1.2 KiB
TypeScript

// 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<Props> | null {
const [, text] = useBlockTime(value, api);
if (!value || value.isZero()) {
return null;
}
return (
<StyledDiv className={`${className} ui--BlockToTime ${isInline ? 'isInline' : ''}`}>
{label || ''}{text.split(' ').map((v, index) =>
<span
className={index % 2 ? 'timeUnits' : undefined}
key={index}
>{v}</span>
)}{children}
</StyledDiv>
);
}
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);