Skip to content

Commit

Permalink
chore: addr blklist feedback. load blks btn + last block
Browse files Browse the repository at this point in the history
  • Loading branch information
BLuEScioN committed Aug 13, 2024
1 parent 9945bcc commit 962c1f8
Show file tree
Hide file tree
Showing 23 changed files with 522 additions and 342 deletions.
80 changes: 39 additions & 41 deletions src/app/_components/BlockList/BlockCount.tsx
Original file line number Diff line number Diff line change
@@ -1,68 +1,66 @@
import { useColorModeValue } from '@chakra-ui/react';
import { ArrowUpRight } from '@phosphor-icons/react';
import { CaretDown } from '@phosphor-icons/react';
import pluralize from 'pluralize';
import { memo, useMemo } from 'react';
import { memo } from 'react';

import { Circle } from '../../../common/components/Circle';
import { ExplorerLink } from '../../../common/components/ExplorerLinks';
import { Flex } from '../../../ui/Flex';
import { Button } from '../../../ui/Button';
import { Icon } from '../../../ui/Icon';
import { Text } from '../../../ui/Text';

export const BlockCount = memo(function ({
count,
btcBlockHash,
isFirst,
loadMoreStxBlocksHandler,
minimized = false,
}: {
count: number;
btcBlockHash?: string;
isFirst?: boolean;
loadMoreStxBlocksHandler?: () => void;
minimized?: boolean;
}) {
// TODO: remove. use theme
const bgColor = useColorModeValue('purple.100', 'slate.900');
const bgColorHover = useColorModeValue('purple.200', 'slate.850');
const textColor = useColorModeValue('purple.600', 'purple.400');
const iconColor = useColorModeValue('purple.600', 'purple.200');
const content = useMemo(() => {
return (
const canLoadMore = !minimized && !isFirst;

return (
<Button
onClick={canLoadMore ? loadMoreStxBlocksHandler : () => {}}
cursor={canLoadMore ? 'pointer' : 'default'}
py={3}
px={2}
width="fit-content"
height={8}
bg={bgColor}
rounded="full"
_hover={
canLoadMore
? {
bg: bgColorHover,
}
: {
bg: bgColor,
}
}
>
<Text
display={'flex'}
color={textColor}
fontSize={'xs'}
bg={bgColor}
rounded={'full'}
px={2}
alignItems={'center'}
display="flex"
color={canLoadMore ? textColor : 'text'}
fontSize="xs"
alignItems="center"
gap={1}
width={'fit-content'}
height={8}
_hover={
isFirst
? {}
: {
textDecoration: 'underline',
bg: bgColorHover,
_groupHover={
canLoadMore
? {
textDecorationColor: textColor,
}
: {}
}
>
+{count} {pluralize('block', count)}
<Circle size={4.5} bg="surface">
<Icon as={ArrowUpRight} size={2.5} color={iconColor} />
</Circle>
{canLoadMore ? <Icon as={CaretDown} size={2.5} color={iconColor} /> : null}
</Text>
);
}, [count, bgColor, bgColorHover, textColor, iconColor, isFirst]);

return (
<Flex py={3}>
{isFirst ? (
<>{content}</>
) : (
<ExplorerLink href={btcBlockHash ? `btcblock/${btcBlockHash}` : '/blocks'}>
{content}
</ExplorerLink>
)}
</Flex>
</Button>
);
});
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,7 @@ function BlocksPageBlockListGroupedBase() {
<>
{!liveUpdates && <UpdateBar onClick={updateBlockList} latestBlock={latestBlock} />}
<Flex flexDirection="column" gap={4} pt={4}>
<BlockListGrouped
blockList={blockList}
minimized={false}
stxBlocksLimit={10}
onlyShowStxBlocksForFirstBtcBlock={true}
/>
<BlockListGrouped blockList={blockList} minimized={false} stxBlocksLimit={undefined} />
</Flex>
<Box pt={5} pb={5}>
<ListFooter
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ function BlocksPageBlockListUngroupedBase() {
return (
<Box pb={6}>
{!liveUpdates && <UpdateBar onClick={updateBlockList} latestBlock={latestBlock} />}
<BlockListUngrouped blockList={blockList} stxBlocksLimit={10} />
<BlockListUngrouped blockList={blockList} stxBlocksLimit={undefined} />
<Box pt={4}>
<ListFooter
isLoading={isFetchingNextPage}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,9 @@ function AverageStacksBlockTimeCard() {
}

function LastConfirmedBitcoinBlockCard() {
const response = useSuspenseBurnBlocks(1);
const burnBlocks = useSuspenseInfiniteQueryResult<BurnBlock>(response);
const btcBlock = burnBlocks[0];
return (
<Stack py={5} px={9} gap={3} alignItems="flex-start" flexWrap="nowrap">
<Text fontSize="xs" fontWeight="medium" whiteSpace="nowrap">
Expand All @@ -84,15 +87,15 @@ function LastConfirmedBitcoinBlockCard() {
<Flex width="full" display="grid" gridTemplateColumns={['repeat(2, 50%)']}>
<Stack gap={2}>
<Text fontSize="xl" fontWeight="medium" whiteSpace="nowrap" display="inline-block" mr={1}>
214
{btcBlock.stacks_blocks.length}
</Text>
<Text fontSize="xs" fontWeight="medium" color="textSubdued">
Stacks blocks
</Text>
</Stack>
<Stack gap={2}>
<Text fontSize="xl" fontWeight="medium" whiteSpace="nowrap" display="inline-block" mr={1}>
4354
{btcBlock.total_tx_count}
</Text>
<Text fontSize="xs" fontWeight="medium" color="textSubdued">
Stacks transactions
Expand Down
Loading

0 comments on commit 962c1f8

Please sign in to comment.