import { useState, useEffect } from 'react'
import KnowledgePanel from './components/KnowledgePanel'
import { Layout, Tabs } from 'antd'
import {
  MessageOutlined,
  PlayCircleOutlined,
  FolderOpenOutlined,
} from '@ant-design/icons'
import ChatPanel from './components/ChatPanel'
import RunsPanel from './components/RunsPanel'
import ResultsPanel from './components/ResultsPanel'
import './App.css'

const { Header, Content } = Layout

// 自定义 AI 芯片图标组件
const AIChipIcon = () => (
  <svg
    width="1em"
    height="1em"
    viewBox="0 0 24 24"
    fill="currentColor"
    style={{ 
      display: 'inline-block',
      verticalAlign: 'middle',
      filter: 'drop-shadow(0 0 4px currentColor)'
    }}
  >
    {/* 中心芯片 */}
    <rect x="8" y="8" width="8" height="8" fill="currentColor" opacity="0.9" />
    
    {/* 芯片内部电路 */}
    <path d="M9 10 L11 10 L11 9 M13 10 L15 10 L15 9 M9 14 L11 14 L11 15 M13 14 L15 14 L15 15" 
          stroke="rgba(17, 24, 39, 0.8)" strokeWidth="0.5" fill="none" />
    
    {/* 四角连接点 */}
    <circle cx="7" cy="7" r="1.2" fill="currentColor" opacity="0.8" />
    <circle cx="17" cy="7" r="1.2" fill="currentColor" opacity="0.8" />
    <circle cx="7" cy="17" r="1.2" fill="currentColor" opacity="0.8" />
    <circle cx="17" cy="17" r="1.2" fill="currentColor" opacity="0.8" />
    
    {/* 上方引脚 */}
    <rect x="10" y="3" width="1" height="4" fill="currentColor" opacity="0.7" />
    <rect x="13" y="3" width="1" height="4" fill="currentColor" opacity="0.7" />
    
    {/* 下方引脚 */}
    <rect x="10" y="17" width="1" height="4" fill="currentColor" opacity="0.7" />
    <rect x="13" y="17" width="1" height="4" fill="currentColor" opacity="0.7" />
    
    {/* 左侧引脚 */}
    <rect x="3" y="10" width="4" height="1" fill="currentColor" opacity="0.7" />
    <rect x="3" y="13" width="4" height="1" fill="currentColor" opacity="0.7" />
    
    {/* 右侧引脚 */}
    <rect x="17" y="10" width="4" height="1" fill="currentColor" opacity="0.7" />
    <rect x="17" y="13" width="4" height="1" fill="currentColor" opacity="0.7" />
    
    {/* 能量脉冲环 */}
    <circle cx="12" cy="12" r="9" stroke="currentColor" strokeWidth="0.5" fill="none" opacity="0.3">
      <animate attributeName="r" values="9;10;9" dur="2s" repeatCount="indefinite" />
      <animate attributeName="opacity" values="0.3;0.6;0.3" dur="2s" repeatCount="indefinite" />
    </circle>
  </svg>
)

export default function App() {
  const [activeTab, setActiveTab] = useState('chat')

  // Global error handlers to surface runtime errors instead of blank page
  useEffect(() => {
    const onErr = (msg: any, url?: string, line?: number, col?: number, error?: any) => {
      console.error('Global error caught:', { msg, url, line, col, error })
      // show a visible alert to user
      try {
        // @ts-ignore
        window.__AUTO_DS_RUNTIME_ERROR__ = { msg, url, line, col, error }
      } catch (e) {}
    }

    const onRejection = (ev: PromiseRejectionEvent) => {
      console.error('Unhandled rejection:', ev.reason)
      try { window.__AUTO_DS_RUNTIME_ERROR__ = ev.reason } catch (e) {}
    }

    window.addEventListener('error', onErr as EventListener)
    window.addEventListener('unhandledrejection', onRejection)
    return () => {
      window.removeEventListener('error', onErr as EventListener)
      window.removeEventListener('unhandledrejection', onRejection)
    }
  }, [])

  const tabItems = [
    {
      key: 'chat',
      label: (
        <span>
          <MessageOutlined />
          AI 对话
        </span>
      ),
      children: <ChatPanel />,
    },
    {
      key: 'runs',
      label: (
        <span>
          <PlayCircleOutlined />
          运行历史
        </span>
      ),
      children: <RunsPanel />,
    },
    {
      key: 'results',
      label: (
        <span>
          <FolderOpenOutlined />
          结果浏览
        </span>
      ),
      children: <ResultsPanel />,
    },
    {
      key: 'knowledge',
      label: (
        <span>
          {/* 📘/📂/💡 可用 BookOutlined/FolderOutlined/BulbOutlined 或自定义 */}
          <span role="img" aria-label="knowledge" style={{ fontSize: 18, marginRight: 4 }}>💡</span>
          经验知识系统
        </span>
      ),
      children: <KnowledgePanel />,
    },
  ]

  return (
    <div className="app-container">
      <Layout className="app-layout">
        <Header className="app-header">
          <div className="header-content">
            <h1 className="app-title">
              <AIChipIcon /> AutoDS - AI 数据科学助手
            </h1>
          </div>
        </Header>

        <Content className="app-content">
          <div className="content-wrapper">
            <Tabs
              activeKey={activeTab}
              onChange={setActiveTab}
              items={tabItems}
              className="main-tabs"
              size="large"
            />
          </div>
        </Content>
      </Layout>
    </div>
  )
}
