json for genesis, assets, new component for syntax highlighting

This commit is contained in:
Dexter 2022-02-18 17:58:05 +00:00 committed by Dexter Edwards
parent 04df5aeed6
commit e26caef368
4 changed files with 52 additions and 33 deletions

View File

@ -0,0 +1,31 @@
import Highlighter from 'react-syntax-highlighter';
const vegaJsonTheme = {
hljs: {
fontSize: '1rem',
fontFamily: "Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace",
display: 'block',
overflowX: 'auto',
padding: '1em',
color: '#26ff8a',
background: '#2C2C2C',
border: '1px solid #696969',
},
'hljs-literal': {
color: '#ff2d5e',
},
'hljs-number': {
color: '#ff7a1a',
},
'hljs-string': {
color: '#48aff0',
},
};
export const SyntaxHighlighter = ({ data }: { data: unknown }) => {
return (
<Highlighter language="json" style={vegaJsonTheme}>
{JSON.stringify(data, null, ' ')}
</Highlighter>
);
};

View File

@ -1,5 +1,7 @@
import { gql, useQuery } from "@apollo/client"; import { gql, useQuery } from '@apollo/client';
import { AssetsQuery } from "./__generated__/AssetsQuery"; import React from 'react';
import { SyntaxHighlighter } from '../../components/syntax-highlighter';
import { AssetsQuery } from './__generated__/AssetsQuery';
export const ASSETS_QUERY = gql` export const ASSETS_QUERY = gql`
query AssetsQuery { query AssetsQuery {
@ -31,10 +33,18 @@ export const ASSETS_QUERY = gql`
const Assets = () => { const Assets = () => {
const { data } = useQuery<AssetsQuery>(ASSETS_QUERY); const { data } = useQuery<AssetsQuery>(ASSETS_QUERY);
if (!data || !data.assets) return null;
return ( return (
<section> <section>
<h1>Assets</h1> <h1>Assets</h1>
<pre>{JSON.stringify(data, null, " ")}</pre> {data?.assets.map((a) => (
<React.Fragment key={a.id}>
<h2>
{a.name} ({a.symbol})
</h2>
<SyntaxHighlighter data={a} />
</React.Fragment>
))}
</section> </section>
); );
}; };

View File

@ -1,15 +1,17 @@
import { DATA_SOURCES } from "../../config"; import { SyntaxHighlighter } from '../../components/syntax-highlighter';
import useFetch from "../../hooks/use-fetch"; import { DATA_SOURCES } from '../../config';
import { TendermintGenesisResponse } from "./tendermint-genesis-response"; import useFetch from '../../hooks/use-fetch';
import { TendermintGenesisResponse } from './tendermint-genesis-response';
const Genesis = () => { const Genesis = () => {
const { data: genesis } = useFetch<TendermintGenesisResponse>( const { data: genesis } = useFetch<TendermintGenesisResponse>(
`${DATA_SOURCES.tendermintUrl}/genesis` `${DATA_SOURCES.tendermintUrl}/genesis`
); );
if (!genesis?.result.genesis) return null;
return ( return (
<section> <section>
<h1>Genesis</h1> <h1>Genesis</h1>
<pre>{JSON.stringify(genesis, null, " ")}</pre> <SyntaxHighlighter data={genesis?.result.genesis} />
</section> </section>
); );
}; };

View File

@ -1,8 +1,8 @@
import { gql, useQuery } from '@apollo/client'; import { gql, useQuery } from '@apollo/client';
import { MarketsQuery } from './__generated__/MarketsQuery'; import { MarketsQuery } from './__generated__/MarketsQuery';
import SyntaxHighlighter from 'react-syntax-highlighter';
import React from 'react'; import React from 'react';
import { SyntaxHighlighter } from '../../components/syntax-highlighter';
const MARKETS_QUERY = gql` const MARKETS_QUERY = gql`
query MarketsQuery { query MarketsQuery {
@ -144,28 +144,6 @@ const MARKETS_QUERY = gql`
} }
`; `;
const vegaJsonTheme = {
hljs: {
fontSize: '1rem',
fontFamily: "Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace",
display: 'block',
overflowX: 'auto',
padding: '1em',
color: '#26ff8a',
background: '#2C2C2C',
border: '1px solid #696969',
},
'hljs-literal': {
color: '#ff2d5e',
},
'hljs-number': {
color: '#ff7a1a',
},
'hljs-string': {
color: '#48aff0',
},
};
const Markets = () => { const Markets = () => {
const { data } = useQuery<MarketsQuery>(MARKETS_QUERY); const { data } = useQuery<MarketsQuery>(MARKETS_QUERY);
@ -176,9 +154,7 @@ const Markets = () => {
{data.markets.map((m) => ( {data.markets.map((m) => (
<React.Fragment key={m.id}> <React.Fragment key={m.id}>
<h2>{m.name}</h2> <h2>{m.name}</h2>
<SyntaxHighlighter language="json" style={vegaJsonTheme}> <SyntaxHighlighter data={m} />
{JSON.stringify(m, null, ' ')}
</SyntaxHighlighter>
</React.Fragment> </React.Fragment>
))} ))}
</section> </section>