import { useEffect, useState } from 'react'
import { Card, Button, Spin, message } from 'antd'
import { apiService } from '../services/api'
import { wsService } from '../services/websocket'
import JsonTree from './JsonTree'

interface PlanTreeProps {
  runId: string
}

export default function PlanTree({ runId }: PlanTreeProps) {
  const [plan, setPlan] = useState<any | null>(null)
  const [loading, setLoading] = useState(false)
  const [expandDepth, setExpandDepth] = useState(2)
  const [key, setKey] = useState(0)

  const loadPlan = async () => {
    if (!runId) return
    setLoading(true)
    try {
      const text = await apiService.getResultPlan(runId)
      if (!text) {
        setPlan(null)
        return
      }
      try {
        const obj = JSON.parse(text)
        setPlan(obj)
      } catch (e) {
        // 非 JSON 时，作为纯文本展示
        setPlan({ __raw: text })
      }
    } catch (e) {
      console.error(e)
      message.error('加载 plan 失败')
    } finally {
      setLoading(false)
    }
  }

  useEffect(() => {
    loadPlan()
    const onWs = (data: any) => {
      try {
        if (data && data.type === 'file') {
          const name = (data.name || '').toLowerCase()
          const url = String(data.url || '')
          if (name === 'plan.json' || url.endsWith('/plan.json')) {
            loadPlan()
          }
        }
      } catch (e) {
        // ignore
      }
    }
    if (runId) {
      wsService.connect(runId, onWs)
    }
    return () => {
      wsService.removeCallback(onWs)
    }
    // eslint-disable-next-line react-hooks/exhaustive-deps
  }, [runId])

  return (
    <Card
      size="small"
      title={`任务分解树（${runId}）`}
      extra={
        <>
          <Button size="small" onClick={() => { setExpandDepth(0); setKey(k => k + 1) }}>折叠</Button>
          <Button size="small" style={{ marginLeft: 8 }} onClick={() => { setExpandDepth(6); setKey(k => k + 1) }}>展开</Button>
          <Button size="small" style={{ marginLeft: 8 }} onClick={() => loadPlan()}>刷新</Button>
        </>
      }
      style={{ marginBottom: 12 }}
    >
      {loading ? (
        <Spin />
      ) : plan ? (
        plan.__raw ? (
          <pre style={{ whiteSpace: 'pre-wrap', maxHeight: 320, overflow: 'auto' }}>{String(plan.__raw)}</pre>
        ) : (
          <div style={{ maxHeight: 320, overflow: 'auto' }}>
            <JsonTree key={key} data={plan} defaultExpandDepth={expandDepth} />
          </div>
        )
      ) : (
        <div style={{ color: '#888' }}>暂无 plan.json</div>
      )}
    </Card>
  )
}
