From 3e2e245fa923efcca660dd7aabb4bb907606ec3f Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期二, 22 十月 2024 13:52:56 +0800 Subject: [PATCH] # --- zy-acs-flow/src/map/JsonShow.jsx | 86 +++++++++++++++++++++++++++++-------------- 1 files changed, 58 insertions(+), 28 deletions(-) diff --git a/zy-acs-flow/src/map/JsonShow.jsx b/zy-acs-flow/src/map/JsonShow.jsx index f2df704..fd70475 100644 --- a/zy-acs-flow/src/map/JsonShow.jsx +++ b/zy-acs-flow/src/map/JsonShow.jsx @@ -1,5 +1,10 @@ import React, { useState, useRef, useEffect } from 'react'; import { Box, Typography, Paper, useTheme } from '@mui/material'; +import { Light as SyntaxHighlighter } from 'react-syntax-highlighter'; +import jsonLang from 'react-syntax-highlighter/dist/esm/languages/hljs/json'; +import { xcode, atomOneDark, a11yLight } from 'react-syntax-highlighter/dist/esm/styles/hljs'; + +// https://react-syntax-highlighter.github.io/react-syntax-highlighter/demo/ const parseJson = (jsonStr) => { let json = ''; @@ -10,6 +15,59 @@ json = 'Invalid JSON'; } return json; +} + +SyntaxHighlighter.registerLanguage('json', jsonLang); + +const JsonShow = ({ data, height = 500 }) => { + const theme = useTheme(); + const themeMode = theme.palette.mode; + + const [json, setJson] = useState(null); + + useEffect(() => { + if (data) { + setJson(parseJson(data)); + } + }, [data]); + + return ( + <Paper + elevation={3} + sx={{ + padding: 2, + maxHeight: height, + overflow: 'auto', + backgroundColor: theme.palette.background.paper, + borderRadius: 2, + }} + > + <pre style={{ margin: 0, fontFamily: 'monospace', whiteSpace: 'pre-wrap' }}> + {json === 'Invalid JSON' ? ( + <Typography color="error">Invalid JSON</Typography> + ) : ( + + <SyntaxHighlighter + language="json" + style={themeMode === 'dark' ? atomOneDark : xcode} + customStyle={{ + backgroundColor: 'transparent', + padding: 0, + fontSize: '0.875rem', // 14px + fontFamily: 'monospace', + whiteSpace: 'pre-wrap', + wordBreak: 'break-word', + // fontWeight: 'bold', + }} + showLineNumbers + > + {json} + </SyntaxHighlighter> + // renderFormattedJson(json) + )} + </pre> + </Paper> + ); } const renderFormattedJson = (json) => { @@ -43,33 +101,5 @@ }; -const JsonShow = ({ data, height = 500 }) => { - const theme = useTheme(); - const themeMode = theme.palette.mode; - - let json = parseJson(data); - - return ( - <Paper - elevation={3} - sx={{ - padding: 2, - maxHeight: height, - overflow: 'auto', - backgroundColor: theme.palette.background.paper, - borderRadius: 2, - }} - > - <pre style={{ margin: 0, fontFamily: 'monospace', whiteSpace: 'pre-wrap' }}> - {json === 'Invalid JSON' ? ( - <Typography color="error">Invalid JSON</Typography> - ) : ( - renderFormattedJson(json) - )} - </pre> - </Paper> - ); - -} export default JsonShow; \ No newline at end of file -- Gitblit v1.9.1