import { forwardRef, useEffect, useImperativeHandle, useRef, useState, } from "react"; import { useTranslation } from "react-i18next"; import { useRecoilValue } from "recoil"; import { Button, Dialog, DialogActions, DialogContent, DialogTitle, Chip, } from "@mui/material"; import { atomThemeMode } from "@/services/states"; import { getRuntimeYaml } from "@/services/cmds"; import { DialogRef } from "@/components/base"; import { editor } from "monaco-editor/esm/vs/editor/editor.api"; import "monaco-editor/esm/vs/basic-languages/javascript/javascript.contribution.js"; import "monaco-editor/esm/vs/basic-languages/yaml/yaml.contribution.js"; import "monaco-editor/esm/vs/editor/contrib/folding/browser/folding.js"; export const ConfigViewer = forwardRef((props, ref) => { const { t } = useTranslation(); const [open, setOpen] = useState(false); const editorRef = useRef(); const instanceRef = useRef(null); const themeMode = useRecoilValue(atomThemeMode); useEffect(() => { return () => { if (instanceRef.current) { instanceRef.current.dispose(); instanceRef.current = null; } }; }, []); useImperativeHandle(ref, () => ({ open: () => { setOpen(true); getRuntimeYaml().then((data) => { const dom = editorRef.current; if (!dom) return; if (instanceRef.current) instanceRef.current.dispose(); instanceRef.current = editor.create(editorRef.current, { value: data ?? "# Error\n", language: "yaml", tabSize: 2, theme: themeMode === "light" ? "vs" : "vs-dark", minimap: { enabled: dom.clientWidth >= 1000 }, // 超过一定宽度显示minimap滚动条 mouseWheelZoom: true, // Ctrl+滚轮调节缩放 readOnly: true, // 只读 readOnlyMessage: { value: t("ReadOnlyMessage") }, }); }); }, close: () => setOpen(false), })); return ( setOpen(false)} maxWidth="xl" fullWidth> {t("Runtime Config")}
); });