import { useEffect, useState } from 'react'
import { List, Card, Button, Empty, message, Modal, Image, Tabs } from 'antd'
import { apiService } from '../services/api'
import JsonTree from './JsonTree'
import TaskGraph from './TaskGraph'

export default function ResultsPanel() {
  const [items, setItems] = useState<any[]>([])
  const [loading, setLoading] = useState(false)
  const [filesVisible, setFilesVisible] = useState(false)
  const [files, setFiles] = useState<{ name: string; url: string; size: number }[]>([])
  const [planVisible, setPlanVisible] = useState(false)
  const [planContent, setPlanContent] = useState<string>('')
  const [planExpandDepth, setPlanExpandDepth] = useState<number>(1)
  const [planKey, setPlanKey] = useState<number>(0)
  const [selectedRunId, setSelectedRunId] = useState<string>('')

  const fetch = async () => {
    setLoading(true)
    try {
      const data = await apiService.getResults()
      // data may be { results: [...] } or an array
      const list = Array.isArray(data) ? data : (data as any).results || []
      setItems(list)
    } catch (e) {
      console.error(e)
      message.error('获取结果列表失败')
    } finally {
      setLoading(false)
    }
  }

  useEffect(() => {
    fetch()
  }, [])

  if (!items.length) {
    return (
      <div style={{ padding: 24 }}>
        <Card>
          <Empty description="没有已保存的结果" />
        </Card>
      </div>
    )
  }

  return (
    <div style={{ padding: 12 }}>
      <List
        loading={loading}
        grid={{ gutter: 16, column: 2 }}
        dataSource={items}
        renderItem={(it: any) => {
          // dir like output/results/<folder> (may use Windows backslashes)
          const dir = it.dir || it.folder || ''
          // normalize separators then take last segment
          const normalized = dir.replace(/\\/g, '/')
          const parts = normalized.split('/').filter(Boolean)
          const name = parts.length ? parts[parts.length - 1] : ''
          const notebook = it.notebook ? it.notebook.replace(/\\/g, '/').split('/').pop() : null
          const planName = it.plan ? String(it.plan).replace(/\\/g, '/').split('/').pop() : null
          const openNotebookUrl = notebook ? `/results/${encodeURIComponent(name)}/${encodeURIComponent(notebook)}` : null
          return (
            <List.Item>
              <Card title={name} extra={<Button onClick={async () => {
                try {
                  const f = await apiService.getResultFiles(name)
                  setFiles(f || [])
                  setFilesVisible(true)
                } catch (e) {
                  console.error(e)
                  message.error('获取文件失败')
                }
              }}>打开目录</Button>}>
                {planName && <div>plan: {planName}</div>}
                {notebook && (
                  <div style={{ marginTop: 8 }}>
                    <a href={openNotebookUrl || '#'} target="_blank" rel="noreferrer">打开 Notebook</a>
                  </div>
                )}
                <div style={{ marginTop: 8 }}>
                  <Button onClick={async () => {
                    // fetch plan.json for this results folder and open modal (with graph)
                    try {
                      const text = await apiService.getResultPlan(name)
                      setPlanContent(text || '')
                      setSelectedRunId(name)
                      setPlanVisible(true)
                    } catch (e) {
                      console.error(e)
                      message.error('获取 plan 失败')
                    }
                  }}>查看任务分解</Button>
                </div>
              </Card>
            </List.Item>
          )
        }}
      />
      <Modal title="结果文件" open={filesVisible} onCancel={() => setFilesVisible(false)} footer={null} width={800}>
        <List
          grid={{ gutter: 16, column: 3 }}
          dataSource={files}
          renderItem={(item) => (
            <List.Item>
              <Image src={item.url} alt={item.name} style={{ maxHeight: 200, objectFit: 'contain' }} />
              <div style={{ marginTop: 8 }}>{item.name}</div>
            </List.Item>
          )}
        />
      </Modal>
      <Modal title="任务分解" open={planVisible} onCancel={() => setPlanVisible(false)} footer={null} width={1280}>
        <Tabs
          defaultActiveKey="graph"
          items={[
            {
              key: 'graph',
              label: '任务分解图',
              children: (
                selectedRunId ? <TaskGraph runId={selectedRunId} height={750} /> : <div style={{ color: '#888' }}>未选择运行</div>
              )
            },
            {
              key: 'json',
              label: 'Plan(JSON)',
              children: (
                planContent ? (
                  <div style={{ maxHeight: '60vh', overflow: 'auto' }}>
                    <div style={{ marginBottom: 8, display: 'flex', gap: 8 }}>
                      <Button size="small" onClick={() => { setPlanExpandDepth(99); setPlanKey(k => k + 1) }}>展开所有</Button>
                      <Button size="small" onClick={() => { setPlanExpandDepth(0); setPlanKey(k => k + 1) }}>折叠所有</Button>
                    </div>
                    {(() => {
                      try {
                        const obj = JSON.parse(planContent)
                        return <JsonTree key={planKey} data={obj} defaultExpandDepth={planExpandDepth} />
                      } catch (e) {
                        return <pre style={{ whiteSpace: 'pre-wrap' }}>{planContent}</pre>
                      }
                    })()}
                  </div>
                ) : <div>未找到 plan.json 或内容为空</div>
              )
            }
          ]}
        />
      </Modal>
    </div>
  )
}
