import React, { useState, useEffect } from 'react';
import { Card, Row, Col, Typography, Spin, Empty, Tag, Tooltip, Space } from 'antd';
import { BookOutlined, FolderOutlined, BulbOutlined, ReloadOutlined } from '@ant-design/icons';

const { Title, Paragraph, Text } = Typography;

interface KnowledgeItem {
  id: string;
  task_type: string;
  recommendation: string;
  rationale: string;
  score: number;
  tags: string[];
  source: string;
}

interface KnowledgeSummary {
  external_knowledge: KnowledgeItem[];
  kaggle_cases: KnowledgeItem[];
  expert_feedback: KnowledgeItem[];
  total: {
    external: number;
    kaggle: number;
    expert: number;
  };
}

const KnowledgePanel: React.FC = () => {
  const [data, setData] = useState<KnowledgeSummary | null>(null);
  const [loading, setLoading] = useState(false);

  const fetchKnowledge = async () => {
    setLoading(true);
    try {
      const resp = await fetch('/api/knowledgeBase/summary');
      const result: KnowledgeSummary = await resp.json();
      setData(result);
    } catch (err) {
      console.error('Failed to fetch knowledge:', err);
    } finally {
      setLoading(false);
    }
  };

  useEffect(() => {
    fetchKnowledge();
  }, []);

  const sections = [
    {
      type: 'external',
      icon: <BookOutlined style={{ color: '#fff', fontSize: 24 }} />,
      title: '外部知识库',
      description: '来自外部系统的结构化知识资源',
      bgColor: '#1976d2',
      itemBgColor: '#e3f2fd',
      textColor: '#000',
      items: data?.external_knowledge || [],
      total: data?.total.external || 0,
    },
    {
      type: 'kaggle',
      icon: <FolderOutlined style={{ color: '#fff', fontSize: 24 }} />,
      title: 'Kaggle案例库',
      description: '精选Kaggle竞赛案例与方案',
      bgColor: '#ff9800',
      itemBgColor: '#fff3e0',
      textColor: '#000',
      items: data?.kaggle_cases || [],
      total: data?.total.kaggle || 0,
    },
    {
      type: 'expert',
      icon: <BulbOutlined style={{ color: '#fff', fontSize: 24 }} />,
      title: '专家经验库',
      description: '领域专家沉淀的最佳实践',
      bgColor: '#f57c00',
      itemBgColor: '#ffe0b2',
      textColor: '#000',
      items: data?.expert_feedback || [],
      total: data?.total.expert || 0,
    },
  ];

  return (
    <Spin spinning={loading}>
      <div style={{ padding: 24 }}>
        <div style={{ display: 'flex', justifyContent: 'space-between', alignItems: 'center', marginBottom: 24 }}>
          <Title level={3} style={{ marginBottom: 0 }}>经验知识系统</Title>
          <Tooltip title="刷新">
            <ReloadOutlined onClick={fetchKnowledge} style={{ cursor: 'pointer', fontSize: 18 }} />
          </Tooltip>
        </div>

        <Row gutter={[24, 24]}>
          {sections.map((section: any) => (
            <Col xs={24} md={8} key={section.type}>
              <Card
                title={
                  <span style={{ color: '#fff', fontWeight: 'bold' }}>
                    {section.icon} {section.title}
                  </span>
                }
                bordered={false}
                headStyle={{ backgroundColor: section.bgColor, borderRadius: '4px 4px 0 0' }}
                style={{
                  minHeight: 400,
                  boxShadow: '0 2px 8px rgba(0,0,0,0.1)',
                  backgroundColor: '#fafafa',
                }}
              >
                <Paragraph type="secondary" style={{ marginBottom: 12, fontSize: 12, color: '#666' }}>
                  {section.description}
                </Paragraph>
                <div style={{ marginBottom: 12 }}>
                  <Tag color={section.bgColor === '#1976d2' ? 'blue' : section.bgColor === '#ff9800' ? 'orange' : 'default'}>
                    共 {section.total} 条
                  </Tag>
                </div>

                {section.items.length > 0 ? (
                  <div style={{ maxHeight: 320, overflowY: 'auto' }}>
                    <Space direction="vertical" size="small" style={{ width: '100%' }}>
                      {section.items.map((item: any, idx: number) => (
                        <div
                          key={idx}
                          style={{
                            padding: 10,
                            backgroundColor: section.itemBgColor,
                            borderRadius: 4,
                            borderLeft: `4px solid ${section.bgColor}`,
                            color: section.textColor,
                          }}
                        >
                          <div style={{ marginBottom: 4 }}>
                            <Text strong style={{ color: section.textColor }}>{item.task_type}</Text>
                            {item.score && (
                              <Tag color={item.score > 0.7 ? 'green' : 'orange'} style={{ marginLeft: 8 }}>
                                {(item.score * 100).toFixed(0)}%
                              </Tag>
                            )}
                          </div>
                          <Paragraph ellipsis={{ rows: 2 }} style={{ marginBottom: 6, fontSize: 12, color: '#333' }}>
                            {item.recommendation}
                          </Paragraph>
                          {item.tags.length > 0 && (
                            <div style={{ marginTop: 4 }}>
                              {item.tags.slice(0, 2).map((tag: string, tidx: number) => (
                                <Tag key={tidx} style={{ fontSize: 10, marginRight: 4, color: '#666' }}>
                                  {tag}
                                </Tag>
                              ))}
                            </div>
                          )}
                        </div>
                      ))}
                    </Space>
                  </div>
                ) : (
                  <Empty description="暂无数据" style={{ marginTop: 40 }} />
                )}
              </Card>
            </Col>
          ))}
        </Row>
      </div>
    </Spin>
  );
};

export default KnowledgePanel;
