import { useState, useEffect, useRef } from 'react'
import { Card, Empty } from 'antd'
import { wsService } from '../services/websocket'
import { apiService } from '../services/api'
import type { LogMessage } from '../types'
import './LogPanel.css'
import PlanTree from './PlanTree'
import TaskGraph from './TaskGraph'

interface LogPanelProps {
  runId: string | null
}

export default function LogPanel({ runId }: LogPanelProps) {
  const [logs, setLogs] = useState<LogMessage[]>([])
  const logsEndRef = useRef<HTMLDivElement>(null)
  const [loadingHistory, setLoadingHistory] = useState(false)

  useEffect(() => {
    if (!runId) {
      setLogs([])
      return
    }
    let cancelled = false
    const loadHistory = async () => {
      setLoadingHistory(true)
      try {
        const text = await apiService.getRunLog(runId)
        if (cancelled) return
        // 日志文件已经是格式化好的文本，每行保持原样展示即可
        const lines = text.split(/\r?\n/)
        const parsed: LogMessage[] = lines
          .filter((l) => l !== '')
          .map((line: string) => ({
            // 不解析，直接把整行放到 content；为满足类型，提供默认 level/timestamp（渲染时会优先展示原始行）
            level: 'INFO',
            content: line,
            timestamp: '',
          }))
        setLogs(parsed)
      } catch (e) {
        console.error('failed to load log history', e)
      } finally {
        setLoadingHistory(false)
      }
    }

    loadHistory()

    const handleLog = (log: LogMessage | any) => {
      // append live logs or file notifications
      try {
        if (log && (log.type === 'file')) {
          const fileEntry: LogMessage = {
            level: 'SUCCESS',
            content: `[file] ${log.url || log.name || ''}`,
            timestamp: log.timestamp || new Date().toLocaleString('zh-CN', { hour12: false, hour: '2-digit', minute: '2-digit', second: '2-digit' }),
            color: 'green',
          }
          setLogs(prev => [...prev, fileEntry])
        } else if (log && log.level && log.message) {
          // web socket message format from server
          const entry: LogMessage = {
            level: log.level,
            content: log.message,
            timestamp: log.timestamp || new Date().toLocaleString('zh-CN', { hour12: false, hour: '2-digit', minute: '2-digit', second: '2-digit' }),
            color: log.color,
          }
          setLogs(prev => [...prev, entry])
        } else {
          // fallback: treat as plain log-like object
          setLogs(prev => [...prev, log])
        }
      } catch (e) {
        console.error('handleLog error:', e, log)
      }
    }

    wsService.connect(runId, handleLog)

    return () => {
      cancelled = true
      wsService.removeCallback(handleLog)
    }
  }, [runId])

  // useEffect(() => {
  //   logsEndRef.current?.scrollIntoView({ behavior: 'smooth' })
  // }, [logs])

  const getLevelClass = (level: LogMessage['level']) => {
    if (!level) return `log-level-info`
    return `log-level-${level.toLowerCase()}`
  }

  if (!runId) {
    return (
      <div className="log-panel">
        <Card>
          <Empty description="请先启动一个任务" />
        </Card>
      </div>
    )
  }

  return (
    <div className="log-panel">
  <TaskGraph runId={runId} height={300} />
  <PlanTree runId={runId} />
      <Card className="log-card">
        <div className="log-container">
          {logs.length === 0 ? (
            <div className="log-empty">{loadingHistory ? '加载日志中...' : '等待日志输出...'}</div>
          ) : (
            logs.map((log, index) => {
              // 如果 content 已经是一整行格式化日志（例如以 YYYY-MM-DD 开头），直接显示原始行
              return (
                <div key={index} className={`log-line ${getLevelClass((log as any).level)}`}>
                  {(
                    <span className="log-content">{log.content}</span>
                  )}
                </div>
              )
            })
          )}
          <div ref={logsEndRef} />
        </div>
      </Card>
    </div>
  )
}
