# AutoDS Frontend - React Version

基于 Vite + React + TypeScript + Ant Design 构建的 AutoDS AI 数据科学助手前端。

## 技术栈

- **构建工具**: Vite 5.x
- **框架**: React 18.x
- **语言**: TypeScript 5.x
- **UI 库**: Ant Design 5.x
- **状态管理**: Zustand (可选)
- **HTTP 客户端**: Axios
- **日期处理**: Day.js

## 功能特性

- 🤖 **AI 对话界面**: 类似智能体的聊天式交互
- 📊 **实时日志流**: WebSocket 连接实时显示终端输出
- 🎯 **运行管理**: 查看和管理数据分析任务
- 📁 **结果浏览**: 浏览和下载分析结果
- 🎨 **渐变主题**: 紫色渐变背景,现代化 UI 设计
- 🌐 **响应式布局**: 适配各种屏幕尺寸

## 项目结构

```
frontend-react/
├── src/
│   ├── components/          # React 组件
│   │   ├── ChatPanel.tsx    # 对话面板
│   │   ├── LogPanel.tsx     # 日志面板
│   │   └── *.css            # 组件样式
│   ├── services/            # API 服务层
│   │   ├── api.ts           # REST API 调用
│   │   └── websocket.ts     # WebSocket 服务
│   ├── types/               # TypeScript 类型定义
│   │   └── index.ts
│   ├── App.tsx              # 主应用组件
│   ├── App.css              # 全局样式
│   └── main.tsx             # 应用入口
├── index.html               # HTML 模板
├── vite.config.ts           # Vite 配置
├── tsconfig.json            # TypeScript 配置
└── package.json             # 项目依赖
```

## 开发指南

### 安装依赖

```bash
npm install
```

### 启动开发服务器

```bash
npm run dev
```

应用将在 http://localhost:3000 启动。

### 构建生产版本

```bash
npm run build
```

构建产物将输出到 `dist/` 目录。

### 预览生产构建

```bash
npm run preview
```

## API 集成

前端通过 Vite 代理连接到后端服务 (默认端口 8001):

- **REST API**: `/api/*` → `http://localhost:8001/api/*`
- **WebSocket**: `/ws/*` → `ws://localhost:8001/ws/*`

### 主要 API 端点

- `POST /api/run` - 启动新任务
- `POST /api/restart` - 重启任务
- `GET /api/runs` - 获取运行历史
- `GET /api/results` - 获取结果列表
- `GET /api/feedback/summary` - 获取反馈统计
- `WS /ws/logs?run_id=xxx` - WebSocket 日志流

## WebSocket 日志格式

```json
{
  "type": "log",
  "level": "INFO",
  "message": "日志内容",
  "timestamp": "2025-01-13 10:30:45"
}
```

支持的日志级别: `DEBUG`, `INFO`, `WARNING`, `ERROR`, `CRITICAL`

## 主题定制

在 `src/main.tsx` 中通过 Ant Design 的 ConfigProvider 配置主题:

```typescript
<ConfigProvider
  theme={{
    algorithm: theme.darkAlgorithm,
    token: {
      colorPrimary: '#667eea',
      colorBgContainer: 'rgba(255, 255, 255, 0.1)',
      colorBorder: 'rgba(255, 255, 255, 0.2)',
    },
  }}
>
```

## 部署说明

1. 构建生产版本: `npm run build`
2. 将 `dist/` 目录部署到静态文件服务器
3. 配置反向代理将 `/api` 和 `/ws` 转发到后端服务

### Nginx 配置示例

```nginx
server {
    listen 80;
    server_name yourdomain.com;

    root /path/to/dist;
    index index.html;

    location / {
        try_files $uri $uri/ /index.html;
    }

    location /api {
        proxy_pass http://localhost:8001;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }

    location /ws {
        proxy_pass http://localhost:8001;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
    }
}
```

## 待开发功能

- [ ] 运行历史面板完整实现
- [ ] 结果浏览器文件下载
- [ ] 知识库统计仪表盘
- [ ] 任务进度条显示
- [ ] 错误处理和重试机制
- [ ] 国际化支持 (i18n)
- [ ] 单元测试

## License

MIT
