import { useState, useEffect, useCallback, Key, useRef } from 'react'; import { TreeSelect, Tree, Input } from 'antd'; import config from '@/utils/config'; import { PageContainer } from '@ant-design/pro-layout'; import Editor from '@monaco-editor/react'; import { request } from '@/utils/http'; import styles from './index.module.less'; import { Controlled as CodeMirror } from 'react-codemirror2'; import { useCtx, useTheme } from '@/utils/hooks'; import SplitPane from 'react-split-pane'; function getFilterData(keyword: string, data: any) { const expandedKeys: string[] = []; if (keyword) { const tree: any = []; data.forEach((item: any) => { if (item.title.toLocaleLowerCase().includes(keyword)) { tree.push(item); expandedKeys.push(...item.children.map((x: any) => x.key)); } else { const children: any[] = []; (item.children || []).forEach((subItem: any) => { if (subItem.title.toLocaleLowerCase().includes(keyword)) { children.push(subItem); } }); if (children.length > 0) { tree.push({ ...item, children, }); expandedKeys.push(...children.map((x) => x.key)); } } }); return { tree, expandedKeys }; } return { tree: data, expandedKeys }; } const Log = ({ headerStyle, isPhone, theme }: any) => { const [title, setTitle] = useState('请选择日志文件'); const [value, setValue] = useState('请选择日志文件'); const [select, setSelect] = useState(); const [data, setData] = useState([]); const [filterData, setFilterData] = useState([]); const [loading, setLoading] = useState(false); const [height, setHeight] = useState(); const treeDom = useRef(); const getLogs = () => { setLoading(true); request .get(`${config.apiPrefix}logs`) .then((data) => { const result = formatData(data.dirs) as any; setData(result); setFilterData(result); }) .finally(() => setLoading(false)); }; const formatData = (tree: any[]) => { return tree.map((x) => { x.title = x.name; x.value = x.name; x.disabled = x.isDir; x.key = x.name; x.children = x.files.map((y: string) => ({ title: y, value: `${x.name}/${y}`, key: `${x.name}/${y}`, parent: x.name, isLeaf: true, })); return x; }); }; const getLog = (node: any) => { request.get(`${config.apiPrefix}logs/${node.value}`).then((data) => { setValue(data.data); }); }; const onSelect = (value: any, node: any) => { setValue('加载中...'); setSelect(value); setTitle(node.parent || node.value); getLog(node); }; const onTreeSelect = useCallback((keys: Key[], e: any) => { onSelect(keys[0], e.node); }, []); const onSearch = useCallback( (e) => { const keyword = e.target.value; const { tree } = getFilterData(keyword.toLocaleLowerCase(), data); setFilterData(tree); }, [data, setFilterData], ); useEffect(() => { getLogs(); setHeight(treeDom.current.clientHeight); }, []); return ( , ] } header={{ style: headerStyle, }} >
{!isPhone && (
)} {isPhone && ( { setValue(value); }} onChange={(editor, data, value) => {}} /> )}
); }; export default Log;