import { useEffect, useState } from 'react'
import { Table, Tag, Button, Space, Drawer, Modal, List, Image, Popconfirm, Spin, message } from 'antd'
import { apiService } from '../services/api'
import LogPanel from './LogPanel'
import type { Run } from '../types'

export default function RunsPanel() {
  const [runs, setRuns] = useState<Run[]>([])
  const [loading, setLoading] = useState(false)
  const [selectedRun, setSelectedRun] = useState<string | null>(null)
  const [filesVisible, setFilesVisible] = useState(false)
  const [files, setFiles] = useState<{ name: string; url: string; size: number }[]>([])
  const [drawerVisible, setDrawerVisible] = useState(false)

  const fetchRuns = async () => {
    setLoading(true)
    try {
      const data = await apiService.getRuns()
      const list = Array.isArray(data) ? data : (data as any).runs || []
      setRuns(list)
    } catch (e) {
      console.error(e)
    } finally {
      setLoading(false)
    }
  }

  useEffect(() => {
    fetchRuns()
    const timer = setInterval(fetchRuns, 10000)
    return () => clearInterval(timer)
  }, [])

  const openLogs = (runId: string) => {
    setSelectedRun(runId)
    setDrawerVisible(true)
  }

  const openFiles = async (runId: string) => {
    setSelectedRun(runId)
    setFilesVisible(true)
    try {
      const f = await apiService.getRunFiles(runId)
      setFiles(f || [])
    } catch (e) {
      console.error(e)
      message.error('获取文件失败')
    }
  }

  const handleTerminate = async (runId: string) => {
    try {
      await apiService.terminateRun(runId)
      message.success('已发送终止请求')
      fetchRuns()
    } catch (e) {
      console.error(e)
      message.error('终止失败')
    }
  }

  const handleRestart = async (runId: string) => {
    try {
      await apiService.restartRun(runId)
      message.success('重启任务已提交')
      fetchRuns()
    } catch (e) {
      console.error(e)
      message.error('重启失败')
    }
  }

  const columns = [
    {
      title: 'Run ID',
      dataIndex: 'run_id',
      key: 'run_id',
      width: 260,
      render: (t: string) => <code style={{ color: '#a3a3a3' }}>{t}</code>
    },
    {
      title: '状态',
      dataIndex: 'status',
      key: 'status',
      render: (s: string) => {
        const color = s === 'running' ? 'processing' : s === 'completed' ? 'success' : 'error'
        return <Tag color={color as any}>{s}</Tag>
      }
    },
    {
      title: '任务描述',
      dataIndex: 'requirement',
      key: 'requirement',
      ellipsis: true,
    },
    {
      title: '启动时间',
      dataIndex: 'started_at',
      key: 'started_at',
      render: (v: number) => v ? new Date(v*1000).toLocaleString() : '-',
    },
    {
      title: '耗时(s)',
      dataIndex: 'elapsed_seconds',
      key: 'elapsed_seconds',
      render: (v: number) => Math.round(v || 0),
    },
    {
      title: '操作',
      key: 'action',
      render: (_: any, record: any) => (
        <Space>
          <Button size="small" onClick={() => openLogs(record.run_id)}>查看日志</Button>
          <Button size="small" onClick={() => openFiles(record.run_id)}>查看文件</Button>
          {record.status === 'running' ? (
            <Popconfirm title="确定终止该运行吗？" onConfirm={() => handleTerminate(record.run_id)}>
              <Button danger size="small">终止</Button>
            </Popconfirm>
          ) : (
            <Button size="small" onClick={() => handleRestart(record.run_id)}>重启</Button>
          )}
        </Space>
      )
    }
  ]

  return (
    <div style={{ padding: 12 }}>
      <Spin spinning={loading}>
        <Table rowKey="run_id" dataSource={runs} columns={columns} pagination={{ pageSize: 8 }} />
      </Spin>

      <Drawer title={`日志 - ${selectedRun || ''}`} width={720} placement="right" onClose={() => setDrawerVisible(false)} open={drawerVisible}>
        {selectedRun ? <LogPanel runId={selectedRun} /> : null}
      </Drawer>

      <Modal title={`结果文件 - ${selectedRun || ''}`} 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>
    </div>
  )
}
