You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

121 lines
3.7 KiB

4 years ago
import React from "https://esm.sh/react@17.0.2";
4 years ago
import styled from "https://esm.sh/styled-components";
import config from "../back/config/config.ts";
import { computeStats } from "../back/common/data.ts";
4 years ago
import { Container } from "../components/Container.ts";
import { Content } from "../components/Content.ts";
4 years ago
import { BlockContainer, Block } from "../components/Block.tsx";
import { Donation } from "../components/Donation.tsx";
import SiteTitle from "../components/SiteTitle.tsx";
4 years ago
import SiteMenu from "../components/SiteMenu.tsx";
import ProgressBar from "../components/ProgressBar.tsx";
4 years ago
import Text from "../components/Text.tsx";
import ContactTwitter from "../components/ContactTwitter.tsx";
import { useStoreState } from "../state/index.ts";
4 years ago
const DescriptionBlock = styled.div`
max-width: 600px;
margin: auto;
text-align: center;
`;
4 years ago
const TopSection = styled.div`
display: flex;
justify-content: space-between;
align-items: center;
`;
const CurrentPeriod = styled.h2`
4 years ago
font-size: 24px;
margin-bottom: 10px;
color: #ff9b20;
text-shadow: #000 2px 2px 0px;
4 years ago
`;
4 years ago
const LockinInfo = styled.h2`
font-size: 16px;
text-align: right;
4 years ago
margin-bottom: 10px;
color: #ff9b20;
text-shadow: #000 2px 2px 0px;
4 years ago
`;
const BootstrappingInProgress = styled.p`
color: #efefef;
text-align: center;
`;
4 years ago
export default function Blocks() {
const blocks = useStoreState((store) => store.blocks);
const forkName = config.fork.name;
const {
blocksLeftForActivation,
lockedIn,
currentPeriodFailed,
currentSignallingPercentage,
willProbablyActivate,
} = computeStats(blocks);
4 years ago
return (
<Container>
<head>
4 years ago
<title>{forkName} activation</title>
4 years ago
</head>
<Content>
<SiteTitle />
4 years ago
<SiteMenu />
4 years ago
<DescriptionBlock>
{config.fork.info.map((text, index) => (
<Text key={index}>{text}</Text>
))}
</DescriptionBlock>
{blocks.length > 0 && <ProgressBar />}
4 years ago
<TopSection>
<CurrentPeriod>Current signalling period of 2016 blocks</CurrentPeriod>
{/* <LockinInfo>90% of blocks within the period have to signal.</LockinInfo> */}
4 years ago
<LockinInfo>
{lockedIn && <>{forkName.toUpperCase()} IS LOCKED IN FOR DEPLOYMENT!</>}
4 years ago
{!lockedIn && (
<>
{!currentPeriodFailed && (
<>
{blocksLeftForActivation} {forkName} blocks left until softfork is locked in.
<br />
{willProbablyActivate && (
<>Taproot will lock in with the current signalling ratio ({currentSignallingPercentage}%)!</>
)}
{!willProbablyActivate && (
<>Taproot will not lock in with the current signalling ratio ({currentSignallingPercentage}%)</>
)}
</>
)}
4 years ago
{currentPeriodFailed && (
<>
{forkName} cannot be locked in within this period.
4 years ago
<br />
(90% of the blocks have to signal).
4 years ago
</>
)}
</>
)}
</LockinInfo>
</TopSection>
4 years ago
<BlockContainer>
{blocks.length === 0 && (
<BootstrappingInProgress>
Server is currently loading blocks, please try soon again.
</BootstrappingInProgress>
)}
4 years ago
{blocks.map((block, i) => (
<Block key={i} height={block.height} signals={block.signals} miner={block.miner} />
4 years ago
))}
</BlockContainer>
4 years ago
{config.frontend.twitterHandle && <ContactTwitter />}
{config.donation && <Donation />}
4 years ago
</Content>
</Container>
);
}