import { useState, useEffect, useCallback, Key, useRef } from 'react'; import { TreeSelect, Tree, Input, Empty } 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 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); } 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(item.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 [expandedKeys, setExpandedKeys] = useState([]); 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) => { if (node.key === select || !value) { return; } 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, expandedKeys } = getFilterData( keyword.toLocaleLowerCase(), data, ); setFilterData(tree); setExpandedKeys(expandedKeys); }, [data, setFilterData], ); useEffect(() => { getLogs(); if (treeDom && treeDom.current) { setHeight(treeDom.current.clientHeight); } }, []); return ( , ] } header={{ style: headerStyle, }} >
{!isPhone && (
{data.length > 0 ? ( <>
) : (
)}
)} {isPhone && ( { setValue(value); }} onChange={(editor, data, value) => {}} /> )}
); }; export default Log;