Skip to content

Commit

Permalink
Fix tooltip of Celo Block Epoch (#2422)
Browse files Browse the repository at this point in the history
* up dappscout-iframe for react version compatibility

* Celo: Cross-link to epoch block on the regular block view and Epoch rewards CSV export (#2386)

* Celo: Cross-link to epoch block on the regular block view

Fixes #2365

* [skip ci] fix hover state for gray-blue tag

* CSV export of epoch transactions for address

* fix tooltip behavior on mobile

---------

Co-authored-by: isstuev <isstuev@gmail.com>
  • Loading branch information
tom2drum and isstuev authored Nov 25, 2024
1 parent f430602 commit ad1c4b2
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 35 deletions.
72 changes: 72 additions & 0 deletions ui/block/BlockCeloEpochTag.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
import { Tag, Tooltip, useDisclosure } from '@chakra-ui/react';
import React from 'react';

import { route } from 'nextjs-routes';

import config from 'configs/app';
import LinkInternal from 'ui/shared/links/LinkInternal';

import type { BlockQuery } from './useBlockQuery';

interface Props {
blockQuery: BlockQuery;
}

const BlockCeloEpochTag = ({ blockQuery }: Props) => {
// have to implement controlled tooltip because of the issue - https://github.com/chakra-ui/chakra-ui/issues/7107
const { isOpen, onOpen, onToggle, onClose } = useDisclosure();

if (!blockQuery.data?.celo) {
return null;
}

if (!blockQuery.data.celo.is_epoch_block) {
const celoConfig = config.features.celo;
const epochBlockNumber = celoConfig.isEnabled && celoConfig.L2UpgradeBlock && blockQuery.data.height <= celoConfig.L2UpgradeBlock ?
blockQuery.data.celo.epoch_number * celoConfig.BLOCKS_PER_EPOCH :
undefined;
const tag = (
<Tag
colorScheme={ epochBlockNumber ? 'gray-blue' : 'gray' }
onClick={ epochBlockNumber ? undefined : onToggle }
onMouseEnter={ onOpen }
onMouseLeave={ onClose }
>
Epoch #{ blockQuery.data.celo.epoch_number }
</Tag>
);
const content = epochBlockNumber ? (
<LinkInternal href={ route({ pathname: '/block/[height_or_hash]', query: { height_or_hash: String(epochBlockNumber) } }) }>
{ tag }
</LinkInternal>
) : tag;

return (
<Tooltip
label="Displays the epoch this block belongs to before the epoch is finalized"
maxW="280px"
textAlign="center"
isOpen={ isOpen }
onClose={ onClose }
>
{ content }
</Tooltip>
);
}

return (
<Tooltip
label="Displays the epoch finalized by this block"
maxW="280px"
textAlign="center"
isOpen={ isOpen }
onClose={ onClose }
>
<Tag bgColor="celo" color="blackAlpha.800" onClick={ onToggle } onMouseEnter={ onOpen } onMouseLeave={ onClose }>
Finalized epoch #{ blockQuery.data.celo.epoch_number }
</Tag>
</Tooltip>
);
};

export default React.memo(BlockCeloEpochTag);
38 changes: 3 additions & 35 deletions ui/pages/Block.tsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,19 @@
import { chakra, Skeleton, Tooltip } from '@chakra-ui/react';
import { chakra, Skeleton } from '@chakra-ui/react';
import capitalize from 'lodash/capitalize';
import { useRouter } from 'next/router';
import React from 'react';

import type { PaginationParams } from 'ui/shared/pagination/types';
import type { RoutedTab } from 'ui/shared/Tabs/types';

import { route } from 'nextjs-routes';

import config from 'configs/app';
import { useAppContext } from 'lib/contexts/app';
import throwOnAbsentParamError from 'lib/errors/throwOnAbsentParamError';
import throwOnResourceLoadError from 'lib/errors/throwOnResourceLoadError';
import useIsMobile from 'lib/hooks/useIsMobile';
import getNetworkValidationActionText from 'lib/networks/getNetworkValidationActionText';
import getQueryParamString from 'lib/router/getQueryParamString';
import BlockCeloEpochTag from 'ui/block/BlockCeloEpochTag';
import BlockDetails from 'ui/block/BlockDetails';
import BlockEpochRewards from 'ui/block/BlockEpochRewards';
import BlockWithdrawals from 'ui/block/BlockWithdrawals';
Expand All @@ -24,9 +23,7 @@ import useBlockTxsQuery from 'ui/block/useBlockTxsQuery';
import useBlockWithdrawalsQuery from 'ui/block/useBlockWithdrawalsQuery';
import TextAd from 'ui/shared/ad/TextAd';
import ServiceDegradationWarning from 'ui/shared/alerts/ServiceDegradationWarning';
import Tag from 'ui/shared/chakra/Tag';
import AddressEntity from 'ui/shared/entities/address/AddressEntity';
import LinkInternal from 'ui/shared/links/LinkInternal';
import NetworkExplorers from 'ui/shared/NetworkExplorers';
import PageTitle from 'ui/shared/Page/PageTitle';
import Pagination from 'ui/shared/pagination/Pagination';
Expand Down Expand Up @@ -149,36 +146,7 @@ const BlockPageContent = () => {
return `Block #${ blockQuery.data?.height }`;
}
})();
const contentAfter = (() => {
if (!blockQuery.data?.celo) {
return null;
}

if (!blockQuery.data.celo.is_epoch_block) {
const celoConfig = config.features.celo;
const epochBlockNumber = celoConfig.isEnabled && celoConfig.L2UpgradeBlock && blockQuery.data.height <= celoConfig.L2UpgradeBlock ?
blockQuery.data.celo.epoch_number * celoConfig.BLOCKS_PER_EPOCH :
undefined;
const tag = <Tag colorScheme={ epochBlockNumber ? 'gray-blue' : 'gray' }>Epoch #{ blockQuery.data.celo.epoch_number }</Tag>;
const content = epochBlockNumber ? (
<LinkInternal href={ route({ pathname: '/block/[height_or_hash]', query: { height_or_hash: String(epochBlockNumber) } }) }>
{ tag }
</LinkInternal>
) : tag;

return (
<Tooltip label="Displays the epoch this block belongs to before the epoch is finalized" maxW="280px" textAlign="center">
{ content }
</Tooltip>
);
}

return (
<Tooltip label="Displays the epoch finalized by this block" maxW="280px" textAlign="center">
<Tag bgColor="celo" color="blackAlpha.800">Finalized epoch #{ blockQuery.data.celo.epoch_number }</Tag>
</Tooltip>
);
})();
const titleSecondRow = (
<>
{ !config.UI.views.block.hiddenFields?.miner && blockQuery.data?.miner && (
Expand Down Expand Up @@ -206,7 +174,7 @@ const BlockPageContent = () => {
<PageTitle
title={ title }
backLink={ backLink }
contentAfter={ contentAfter }
contentAfter={ <BlockCeloEpochTag blockQuery={ blockQuery }/> }
secondRow={ titleSecondRow }
isLoading={ blockQuery.isPlaceholderData }
/>
Expand Down

0 comments on commit ad1c4b2

Please sign in to comment.