slate/scenes/SceneStatus.js

170 lines
4.6 KiB
JavaScript

import * as React from "react";
import * as Strings from "~/common/strings";
import * as Constants from "~/common/constants";
import * as System from "~/components/system";
import { css } from "@emotion/core";
import Section from "~/components/core/Section";
import ScenePage from "~/components/core/ScenePage";
const STYLES_ROW = css`
padding: 24px;
display: flex;
align-items: center;
justify-content: space-between;
`;
const STYLES_LEFT = css`
font-size: ${Constants.typescale.lvl2};
padding-right: 24px;
flex-shrink: 0;
min-width: 228px;
`;
const STYLES_RIGHT = css`
font-family: ${Constants.font.semiBold};
font-size: ${Constants.typescale.lvl2};
color: ${Constants.system.brand};
min-width: 10%;
width: 100%;
padding-left: 24px;
overflow-wrap: break-word;
`;
const STYLES_TEXT_CTA = css`
font-family: ${Constants.font.text};
text-decoration: underline;
color: ${Constants.system.brand};
font-weight: 400;
cursor: pointer;
transition: 200ms ease all;
:hover {
color: ${Constants.system.green};
}
`;
export default class SceneStatus extends React.Component {
state = {};
_handleChange = (e) => {
this.setState({ [e.target.name]: e.target.value });
};
render() {
return (
<ScenePage>
<System.H1>Status</System.H1>
<Section title="Node" onAction={this.props.onAction}>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Peer ID</div>
<div css={STYLES_RIGHT}>
Qma9T5YraSnpRDZqRR4krcSJabThc8nwZuJV3LercPHufi{" "}
<strong css={STYLES_TEXT_CTA}>(copy)</strong>
</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>
Peers <strong css={STYLES_TEXT_CTA}>(view)</strong>
</div>
<div css={STYLES_RIGHT}>4</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Version</div>
<div css={STYLES_RIGHT}>Lotus Testnet 3</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>
Miners <strong css={STYLES_TEXT_CTA}>(view)</strong>
</div>
<div css={STYLES_RIGHT}>1</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Workers</div>
<div css={STYLES_RIGHT}>
0 &nbsp;&nbsp;<strong css={STYLES_TEXT_CTA}>(copy)</strong>
</div>
</div>
</Section>
<Section
onAction={this.props.onAction}
title="Network connection"
buttons={[
{
name: "Disconnect",
type: "ACTION",
value: "ACTION_DISCONNECT",
},
]}
>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Network</div>
<div css={STYLES_RIGHT}>Mainnet</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Status</div>
<div css={STYLES_RIGHT}>Connected</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Genesis</div>
<div css={STYLES_RIGHT}>
pYqSDLCIthA3CPoVcmwoDOIWyw0pC6uTwDFmNZytEREPLLEV3nOBjnv+yoKqk7nNCgpYAVUwXMv+mcZ2XNusdSWcd6b0HNmeqzQeaB9pZSayy9AV5E2Qp56CGxifRGKC{" "}
&nbsp;&nbsp;<strong css={STYLES_TEXT_CTA}>(copy)</strong>{" "}
</div>
</div>
</Section>
<Section
onAction={this.props.onAction}
title="Chain sync"
buttons={[
{
name: "Import",
type: "ACTION",
value: "ACTION_IMPORT_CHAIN_DATA",
},
]}
>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Status</div>
<div css={STYLES_RIGHT}>Message Sync 30%</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Head</div>
<div css={STYLES_RIGHT}>Tipset hash</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Height</div>
<div css={STYLES_RIGHT}>96413</div>
</div>
<div css={STYLES_ROW}>
<div css={STYLES_LEFT}>Timestamp</div>
<div css={STYLES_RIGHT}>April 13th, 2020 4:42 PM</div>
</div>
</Section>
<System.DescriptionGroup
style={{ marginTop: 32 }}
label="Reset usage data"
tooltip="This action is irreversible."
description="Reset your usage data on this Filecoin Node."
/>
<System.ButtonSecondary style={{ marginTop: 16 }}>Reset</System.ButtonSecondary>
</ScenePage>
);
}
}