From e26caef36889a8b1fe79d2a3bca448699100149f Mon Sep 17 00:00:00 2001 From: Dexter Date: Fri, 18 Feb 2022 17:58:05 +0000 Subject: [PATCH] json for genesis, assets, new component for syntax highlighting --- .../components/syntax-highlighter/index.tsx | 31 +++++++++++++++++++ apps/explorer/src/app/routes/assets/index.tsx | 16 ++++++++-- .../explorer/src/app/routes/genesis/index.tsx | 10 +++--- .../explorer/src/app/routes/markets/index.tsx | 28 ++--------------- 4 files changed, 52 insertions(+), 33 deletions(-) create mode 100644 apps/explorer/src/app/components/syntax-highlighter/index.tsx diff --git a/apps/explorer/src/app/components/syntax-highlighter/index.tsx b/apps/explorer/src/app/components/syntax-highlighter/index.tsx new file mode 100644 index 000000000..3ec630fda --- /dev/null +++ b/apps/explorer/src/app/components/syntax-highlighter/index.tsx @@ -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 ( + + {JSON.stringify(data, null, ' ')} + + ); +}; diff --git a/apps/explorer/src/app/routes/assets/index.tsx b/apps/explorer/src/app/routes/assets/index.tsx index 8291e8d4d..ed0cedcc6 100644 --- a/apps/explorer/src/app/routes/assets/index.tsx +++ b/apps/explorer/src/app/routes/assets/index.tsx @@ -1,5 +1,7 @@ -import { gql, useQuery } from "@apollo/client"; -import { AssetsQuery } from "./__generated__/AssetsQuery"; +import { gql, useQuery } from '@apollo/client'; +import React from 'react'; +import { SyntaxHighlighter } from '../../components/syntax-highlighter'; +import { AssetsQuery } from './__generated__/AssetsQuery'; export const ASSETS_QUERY = gql` query AssetsQuery { @@ -31,10 +33,18 @@ export const ASSETS_QUERY = gql` const Assets = () => { const { data } = useQuery(ASSETS_QUERY); + if (!data || !data.assets) return null; return (

Assets

-
{JSON.stringify(data, null, "  ")}
+ {data?.assets.map((a) => ( + +

+ {a.name} ({a.symbol}) +

+ +
+ ))}
); }; diff --git a/apps/explorer/src/app/routes/genesis/index.tsx b/apps/explorer/src/app/routes/genesis/index.tsx index d619ae4cb..cfbdb154c 100644 --- a/apps/explorer/src/app/routes/genesis/index.tsx +++ b/apps/explorer/src/app/routes/genesis/index.tsx @@ -1,15 +1,17 @@ -import { DATA_SOURCES } from "../../config"; -import useFetch from "../../hooks/use-fetch"; -import { TendermintGenesisResponse } from "./tendermint-genesis-response"; +import { SyntaxHighlighter } from '../../components/syntax-highlighter'; +import { DATA_SOURCES } from '../../config'; +import useFetch from '../../hooks/use-fetch'; +import { TendermintGenesisResponse } from './tendermint-genesis-response'; const Genesis = () => { const { data: genesis } = useFetch( `${DATA_SOURCES.tendermintUrl}/genesis` ); + if (!genesis?.result.genesis) return null; return (

Genesis

-
{JSON.stringify(genesis, null, "  ")}
+
); }; diff --git a/apps/explorer/src/app/routes/markets/index.tsx b/apps/explorer/src/app/routes/markets/index.tsx index f9f620910..4a1f60f3c 100644 --- a/apps/explorer/src/app/routes/markets/index.tsx +++ b/apps/explorer/src/app/routes/markets/index.tsx @@ -1,8 +1,8 @@ import { gql, useQuery } from '@apollo/client'; import { MarketsQuery } from './__generated__/MarketsQuery'; -import SyntaxHighlighter from 'react-syntax-highlighter'; import React from 'react'; +import { SyntaxHighlighter } from '../../components/syntax-highlighter'; const MARKETS_QUERY = gql` 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 { data } = useQuery(MARKETS_QUERY); @@ -176,9 +154,7 @@ const Markets = () => { {data.markets.map((m) => (

{m.name}

- - {JSON.stringify(m, null, ' ')} - +
))}