mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 11:17:59 +00:00
55 lines
1.2 KiB
TypeScript
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);
|