import { useState, useRef, useEffect, type ChangeEvent, type KeyboardEvent } from 'react'
import { Card, Input, Button, Space, Tag, Spin, message as antMessage } from 'antd'
import { SendOutlined, RobotOutlined, LoadingOutlined } from '@ant-design/icons'
import type { Message } from '../types'
import { apiService } from '../services/api'
import { wsService } from '../services/websocket'
import type { LogMessage } from '../types'
import './ChatPanel.css'
// import LogPanel from './LogPanel'

const { TextArea } = Input

export default function ChatPanel() {
  const [messages, setMessages] = useState<Message[]>([
    {
      id: '1',
      role: 'system',
      content: '👋 欢迎使用 AutoDS - AI 数据科学助手！\n\n我可以帮您进行数据分析、建模和可视化。请告诉我您的任务需求，例如：\n- 数据集名称\n- 分析目标\n- 需要的模型或方法',
      timestamp: new Date(),
    },
  ])
  const [inputValue, setInputValue] = useState('')
  const [isLoading, setIsLoading] = useState(false)
  const [currentRunId, setCurrentRunId] = useState<string | null>(null)
  const messagesEndRef = useRef<HTMLDivElement>(null)

  const scrollToBottom = () => {
    messagesEndRef.current?.scrollIntoView({ behavior: 'smooth' })
  }

  useEffect(() => {
    scrollToBottom()
  }, [messages])

  // 添加日志消息或文件消息到对话中（后端已经合并了多行日志）
  const addLogMessage = (data: any) => {
    // 文件通知：区分图片与非图片，避免将 plan.json 等当作图片渲染
    if (data && data.type === 'file') {
      const name: string = String(data.name || '')
      const url: string = String(data.url || '')
      const subtype: string = String(data.subtype || '')
      const isImage = subtype === 'image' || /\.(png|jpe?g|gif|svg)$/i.test(name) || /\.(png|jpe?g|gif|svg)$/i.test(url)

      if (isImage) {
        const imgMsg: Message = {
          id: `file-${Date.now()}-${Math.random()}`,
          role: 'assistant',
          content: name || 'image',
          timestamp: new Date(),
          imageUrl: url,
        }
        setMessages(prev => [...prev, imgMsg])
      } else {
        const fileMsg: Message = {
          id: `file-${Date.now()}-${Math.random()}`,
          role: 'assistant',
          content: `[file] ${name} -> ${url}`,
          timestamp: new Date(),
        }
        setMessages(prev => [...prev, fileMsg])
      }
      return
    }

    // 否则按日志消息处理
    const log: LogMessage = data as LogMessage
    const logMsg: Message = {
      id: `log-${Date.now()}-${Math.random()}`,
      role: 'assistant',
      content: log.content, // 后端已经把完整的日志条目（包括多行）发送过来了
      timestamp: new Date(),
      color: log.color, // 保留后端传来的颜色
    }
    setMessages(prev => [...prev, logMsg])
  }

  // 监听 WebSocket 日志
  useEffect(() => {
    if (currentRunId) {
      wsService.connect(currentRunId, addLogMessage)
      return () => {
        wsService.removeCallback(addLogMessage)
      }
    }
  }, [currentRunId])

  const handleSend = async () => {
    if (!inputValue.trim() || isLoading) return

    const userMessage: Message = {
      id: Date.now().toString(),
      role: 'user',
      content: inputValue,
      timestamp: new Date(),
    }

    setMessages(prev => [...prev, userMessage])
    const taskInput = inputValue
    setInputValue('')
    setIsLoading(true)

    try {
      // 调用后端 API 启动任务
      const response = await apiService.startRun(taskInput)
      
      if (response.run_id) {
        setCurrentRunId(response.run_id)
        
        // // 添加任务启动成功消息
        // const startMsg: Message = {
        //   id: `start-${Date.now()}`,
        //   role: 'assistant',
        //   content: `✅ 任务已启动 (ID: ${response.run_id})\n\n开始执行分析...`,
        //   timestamp: new Date(),
        // }
        // setMessages(prev => [...prev, startMsg])

        antMessage.success('任务已启动，正在执行中...')
      }
    } catch (error) {
      console.error('启动任务失败:', error)
      
      const errorMsg: Message = {
        id: `error-${Date.now()}`,
        role: 'assistant',
        content: `❌ 任务启动失败: ${error instanceof Error ? error.message : '未知错误'}`,
        timestamp: new Date(),
      }
      setMessages(prev => [...prev, errorMsg])
      
      antMessage.error('任务启动失败，请重试')
    } finally {
      setIsLoading(false)
    }
  }

  const getRoleIcon = (role: Message['role']) => {
    switch (role) {
      case 'system':
        return <RobotOutlined />
      // case 'user':
      //   return <UserOutlined />
      // default:
      //   return <RobotOutlined />
    }
  }

  const getRoleTag = (role: Message['role']) => {
    switch (role) {
      case 'assistant':
        return <Tag color="blue">AI助手</Tag>
      case 'user':
        return <Tag color="gold">用户</Tag>
      default:
        return <Tag color="purple">系统</Tag>
    }
  }

  // 格式化消息内容，支持多行和特殊标记
  const formatMessageContent = (content: string, color?: string) => {
    // 如果后端提供了颜色，使用后端的颜色
    if (color) {
      // 将后端的颜色名映射为实际颜色值
      const colorMap: Record<string, string> = {
        white: '#ffffff',
        grey: '#8a8a8a',
        blue: '#61afef',
        yellow: '#e5c07b',
        red: '#e06c75',
        green: '#98c379',
        cyan: '#56b6c2',
      }
      
      const actualColor = colorMap[color] || color
      
      return (
        <span style={{ 
          fontFamily: 'Consolas, Monaco, "Courier New", monospace', 
          fontSize: '13px',
          color: actualColor,
          whiteSpace: 'pre-wrap',
        }}>
          {content}
        </span>
      )
    }

    // 检测日志级别并着色（降级方案）
    const logLevelColors: Record<string, string> = {
      DEBUG: '#8be9fd',
      INFO: '#50fa7b',
      WARNING: '#f1fa8c',
      ERROR: '#ff5555',
      CRITICAL: '#ff79c6',
    }

    // 如果是日志消息，应用颜色
    const logMatch = content.match(/^\[(DEBUG|INFO|WARNING|ERROR|CRITICAL)\]/)
    if (logMatch) {
      const level = logMatch[1]
      const color = logLevelColors[level]
      return (
        <span style={{ fontFamily: 'Consolas, Monaco, monospace', fontSize: '13px' }}>
          <span style={{ color, fontWeight: 'bold' }}>[{level}]</span>
          {content.substring(logMatch[0].length)}
        </span>
      )
    }

    // 普通消息，保留换行
    return content.split('\n').map((line, index) => (
      <span key={index}>
        {line}
        {index < content.split('\n').length - 1 && <br />}
      </span>
    ))
  }

  return (
    <div className="chat-panel">
      <div className="chat-content">
        <div className="chat-left">
          <div className="messages-container">
            {messages.map((msg) => (
              <div key={msg.id} className={`message message-${msg.role}`}>
                <div className="message-header">
                  <Space>
                    {getRoleIcon(msg.role)}
                    {getRoleTag(msg.role)}
                    <span className="message-time">
                      {msg.timestamp.toLocaleTimeString()}
                    </span>
                  </Space>
                </div>
                <div className="message-content">
                  {msg.imageUrl ? (
                    <div className="message-image">
                      <img
                        src={msg.imageUrl}
                        alt={msg.content}
                        style={{ maxWidth: '100%', borderRadius: 8 }}
                        onError={(e) => {
                          // show a small inline SVG placeholder and log the error
                          const target = e.currentTarget as HTMLImageElement
                          console.error('Image load failed:', target.src)
                          const svg = encodeURIComponent('<svg xmlns="http://www.w3.org/2000/svg" width="400" height="240"><rect width="100%" height="100%" fill="#222"/><text x="50%" y="50%" fill="#888" font-size="18" text-anchor="middle" dominant-baseline="middle">Image failed to load</text></svg>')
                          target.src = `data:image/svg+xml;utf8,${svg}`
                        }}
                      />
                    </div>
                  ) : (
                    formatMessageContent(msg.content, msg.color)
                  )}
                </div>
              </div>
            ))}
            {isLoading && (
              <div className="message message-assistant">
                <div className="message-header">
                  <Space>
                    <LoadingOutlined />
                    <Tag color="purple">AI助手</Tag>
                  </Space>
                </div>
                <div className="message-content">
                  <Spin size="small" /> 正在处理...
                </div>
              </div>
            )}
            <div ref={messagesEndRef} />
          </div>

          <Card className="input-card">
            <div className="input-area">
              <div className="textarea-wrapper">
                <TextArea
                  value={inputValue}
                  onChange={(e: ChangeEvent<HTMLTextAreaElement>) => setInputValue(e.target.value)}
                  onPressEnter={(e: KeyboardEvent<HTMLTextAreaElement>) => {
                    if (!e.shiftKey) {
                      e.preventDefault()
                      handleSend()
                    }
                  }}
                  placeholder="输入数据分析任务，例如：使用 iris 数据集进行分类分析... (Shift+Enter 换行)"
                  autoSize={{ minRows: 2, maxRows: 6 }}
                  style={{ resize: 'none'}}
                  disabled={isLoading}
                  className="chat-input"
                />
                {!inputValue && (
                  <div className="input-suggestions">
                    <div className="suggestion-title">快速开始:</div>
                    <div className="suggestion-items">
                      <span onClick={() => setInputValue("在sklearn Iris数据集上做数据分析，绘图并训练简单模型")}>
                        Iris 数据分类
                      </span>
                      <span onClick={() => setInputValue("对泰坦尼克号乘客数据进行分析，找出影响生存率的关键因素，并训练一个预测模型")}>
                        泰坦尼克生存预测
                      </span>
                      <span onClick={() => setInputValue("使用波士顿房价数据集进行回归分析")}>
                        房价回归分析
                      </span>
                    </div>
                  </div>
                )}
              </div>
              <Button
                type="primary"
                icon={isLoading ? <LoadingOutlined /> : <SendOutlined />}
                onClick={handleSend}
                disabled={!inputValue.trim() || isLoading}
                loading={isLoading}
                className="send-button"
              >
                {isLoading ? '执行中' : '发送'}
              </Button>
            </div>
          </Card>
        </div>
        {/* <div className="chat-right">
          <LogPanel runId={currentRunId} />
        </div> */}
      </div>
    </div>
  )
}
