- 更新 argon_detect_spam_comment_sync() 使用统一接口 - 更新 argon_extract_keywords_from_comment() 使用统一接口 - 删除旧的 argon_call_ai_api_for_spam_detection() 函数 - 删除旧的 argon_call_ai_for_keyword_extraction() 函数 - 所有 AI 查询现在都通过 argon_ai_query() 统一接口 - 所有查询都会记录到 wp_argon_ai_query_log 数据表 - 支持按场景统计(summary/spam_detection/keyword_extraction)
233 lines
8.1 KiB
Markdown
233 lines
8.1 KiB
Markdown
# 实施计划:Mermaid 代码块渲染修复
|
||
|
||
## 概述
|
||
|
||
本实施计划旨在修复 Argon WordPress 主题中 Mermaid 图表渲染的关键问题,并增强交互体验。
|
||
|
||
**当前状态:** 所有核心功能已实现完成 ✅
|
||
|
||
**实施策略:**
|
||
- 问题优先:优先修复 PJAX 渲染和语法错误问题 ✅
|
||
- 功能完善:添加导出、全屏查看等功能 ✅
|
||
- 体验优化:优化交互体验和视觉效果 ✅
|
||
- 质量保证:确保代码质量和性能 ✅
|
||
|
||
## 任务
|
||
|
||
### 阶段 1: 核心问题修复 ✅
|
||
|
||
- [x] 1. 修复 PJAX 页面切换后 Mermaid 不渲染的问题
|
||
- [x] 1.1 实现 Mermaid 代码块检测函数 _需求:3.1-3.5_
|
||
- [x] 1.2 优化 PJAX complete 事件处理 _需求:1.1-1.5_
|
||
- [x] 1.3 添加渲染状态标记,避免重复渲染 _需求:3.5_
|
||
- [x] 1.4 测试 PJAX 跳转后的渲染效果 _需求:1.1-1.5_
|
||
|
||
- [x] 2. 修复 Mermaid 语法解析错误
|
||
- [x] 2.1 实现 Mermaid 库加载等待机制 _需求:2.6, 4.1-4.2_
|
||
- [x] 2.2 优化 Mermaid 初始化配置 _需求:2.1-2.4_
|
||
- [x] 2.3 添加语法错误处理和友好提示 _需求:2.5, 7.1-7.4_
|
||
- [x] 2.4 测试各种图表类型(flowchart、erDiagram、stateDiagram) _需求:2.2-2.4_
|
||
|
||
- [x] 3. 实现错误处理和降级方案
|
||
- [x] 3.1 创建错误提示组件 _需求:7.1-7.4_
|
||
- [x] 3.2 实现错误日志记录 _需求:14.1-14.6_
|
||
- [x] 3.3 添加原始代码查看功能 _需求:7.2_
|
||
- [x] 3.4 测试各种错误场景 _需求:7.1-7.6_
|
||
|
||
### 阶段 2: 交互功能实现 ✅
|
||
|
||
- [x] 4. 实现工具栏和基础交互
|
||
- [x] 4.1 创建工具栏组件 _需求:11.1-11.7_
|
||
- [x] 4.2 实现工具栏自动显示/隐藏 _需求:11.1-11.2_
|
||
- [x] 4.3 添加按钮提示(tooltip) _需求:11.4_
|
||
- [x] 4.4 优化工具栏样式(半透明背景) _需求:11.3_
|
||
|
||
- [x] 5. 实现缩放功能
|
||
- [x] 5.1 实现鼠标滚轮缩放 _需求:12.1-12.3_
|
||
- [x] 5.2 实现缩放按钮(放大、缩小、重置) _需求:12.4_
|
||
- [x] 5.3 实现双击智能缩放 _需求:12.5_
|
||
- [x] 5.4 优化缩放动画和性能 _需求:12.2-12.3_
|
||
|
||
- [x] 6. 实现拖拽功能
|
||
- [x] 6.1 实现鼠标拖拽移动 _需求:12.6-12.8_
|
||
- [x] 6.2 优化拖拽视觉反馈 _需求:12.6-12.7_
|
||
- [x] 6.3 智能启用/禁用拖拽 _需求:12.8_
|
||
- [x] 6.4 使用 requestAnimationFrame 优化性能 _需求:8.1-8.5_
|
||
|
||
### 阶段 3: 高级功能实现 ✅
|
||
|
||
- [x] 7. 实现图表导出功能
|
||
- [x] 7.1 创建导出菜单组件 _需求:5.1-5.3_
|
||
- [x] 7.2 实现 PNG 导出 _需求:5.4_
|
||
- [x] 7.3 实现 SVG 导出 _需求:5.5_
|
||
- [x] 7.4 添加导出错误处理 _需求:5.6, 7.5_
|
||
|
||
- [x] 8. 实现全屏查看功能
|
||
- [x] 8.1 实现全屏模式切换 _需求:6.1-6.2_
|
||
- [x] 8.2 实现全屏按钮和事件处理 _需求:6.1-6.2_
|
||
- [x] 8.3 支持键盘快捷键(ESC 退出) _需求:6.4_
|
||
- [x] 8.4 保持全屏模式下的交互功能 _需求:6.3-6.5_
|
||
|
||
- [x] 9. 实现主题同步功能
|
||
- [x] 9.1 监听主题切换事件 _需求:9.1-9.3_
|
||
- [x] 9.2 实现主题自动切换 _需求:9.1-9.2_
|
||
- [x] 9.3 保持图表状态(缩放、位置) _需求:9.4_
|
||
- [x] 9.4 测试主题切换效果 _需求:9.1-9.5_
|
||
|
||
### 阶段 4: 性能和体验优化 ✅
|
||
|
||
- [x] 10. 优化渲染性能
|
||
- [x] 10.1 实现批量渲染 _需求:8.1_
|
||
- [x] 10.2 实现延迟加载(优先渲染可见图表) _需求:8.2_
|
||
- [x] 10.3 添加加载动画 _需求:8.3, 11.7_
|
||
- [x] 10.4 优化渲染流程,避免阻塞 _需求:8.1-8.4_
|
||
|
||
- [x] 11. 优化移动端体验
|
||
- [x] 11.1 适配移动端工具栏 _需求:10.1_
|
||
- [x] 11.2 实现触摸手势支持(双指缩放、单指拖拽) _需求:10.2_
|
||
- [x] 11.3 优化触摸事件响应 _需求:10.5_
|
||
- [x] 11.4 测试移动端交互体验 _需求:10.1-10.5_
|
||
|
||
- [x] 12. 实现生命周期管理
|
||
- [x] 12.1 实现 PJAX 集成(清理和重新渲染) _需求:8.5, 16.1-16.5_
|
||
- [x] 12.2 实现资源清理函数 _需求:16.1-16.5_
|
||
- [x] 12.3 移除事件监听器,避免内存泄漏 _需求:16.2_
|
||
- [x] 12.4 测试内存泄漏情况 _需求:16.1-16.5_
|
||
|
||
### 阶段 5: 代码质量和测试 ✅
|
||
|
||
- [x] 13. 代码质量检查
|
||
- [x] 13.1 添加 JSDoc 注释 _需求:13.2_
|
||
- [x] 13.2 遵循项目代码规范(Tab 缩进、单引号等) _需求:13.1_
|
||
- [x] 13.3 使用 let/const 替代 var _需求:13.3_
|
||
- [x] 13.4 优化错误处理和日志记录 _需求:13.4, 14.1-14.6_
|
||
- [x] 13.5 代码审查和重构 _需求:13.1-13.7_
|
||
|
||
- [x] 14. 兼容性测试
|
||
- [x] 14.1 测试主流浏览器(Chrome、Firefox、Safari、Edge) _需求:15.1-15.5_
|
||
- [x] 14.2 测试移动端浏览器(iOS Safari、Android Chrome) _需求:15.4_
|
||
- [x] 14.3 测试降级方案 _需求:15.1-15.5_
|
||
- [x] 14.4 修复兼容性问题 _需求:15.1-15.5_
|
||
|
||
- [x] 15. 功能测试
|
||
- [x] 15.1 测试 PJAX 页面切换
|
||
- [x] 15.2 测试各种图表类型渲染
|
||
- [x] 15.3 测试交互功能(缩放、拖拽、全屏)
|
||
- [x] 15.4 测试导出功能(PNG、SVG)
|
||
- [x] 15.5 测试错误处理和降级方案
|
||
|
||
- [x] 16. 性能测试
|
||
- [x] 16.1 测试渲染性能(多图表页面)
|
||
- [x] 16.2 测试内存占用和泄漏
|
||
- [x] 16.3 测试交互性能(缩放、拖拽流畅度)
|
||
- [x] 16.4 优化性能瓶颈
|
||
|
||
- [x] 17. 文档和总结
|
||
- [x] 17.1 更新代码注释
|
||
- [x] 17.2 编写使用文档
|
||
- [x] 17.3 记录已知问题和限制
|
||
- [x] 17.4 总结优化效果
|
||
|
||
## 实施状态总结
|
||
|
||
### ✅ 已完成的功能
|
||
|
||
**核心渲染功能:**
|
||
- Mermaid 库加载等待机制(waitForMermaid)
|
||
- 代码块检测和过滤(detectMermaidBlocks, isRendered)
|
||
- 批量渲染和延迟加载(renderAllCharts, isInViewport)
|
||
- 错误处理和降级方案(handleRenderError, renderChartLegacy)
|
||
- 加载动画和淡入效果(applyStyles)
|
||
|
||
**交互功能:**
|
||
- 缩放控制(按钮、滚轮、双击)
|
||
- 拖拽移动(鼠标、触摸)
|
||
- 全屏模式(ESC 退出)
|
||
- 导出功能(PNG、SVG)
|
||
- 工具栏和提示
|
||
|
||
**移动端支持:**
|
||
- 双指缩放手势
|
||
- 单指拖拽移动
|
||
- 触摸事件优化
|
||
|
||
**主题同步:**
|
||
- 监听主题切换事件
|
||
- 自动重新渲染图表
|
||
- 保持缩放和位置状态
|
||
|
||
**性能优化:**
|
||
- requestAnimationFrame 优化
|
||
- 批量渲染避免阻塞
|
||
- 智能启用/禁用拖拽
|
||
- 内存泄漏防护
|
||
|
||
**代码质量:**
|
||
- 完整的 JSDoc 注释
|
||
- 遵循项目代码规范
|
||
- 使用 let/const
|
||
- 完善的错误处理
|
||
|
||
## 实施优先级
|
||
|
||
**P0 (必须完成 - 核心问题修复):** ✅ 已完成
|
||
- 任务 1: 修复 PJAX 渲染问题
|
||
- 任务 2: 修复语法解析错误
|
||
- 任务 3: 实现错误处理
|
||
|
||
**P1 (重要 - 基础交互):** ✅ 已完成
|
||
- 任务 4: 实现工具栏
|
||
- 任务 5: 实现缩放功能
|
||
- 任务 6: 实现拖拽功能
|
||
- 任务 12: 生命周期管理
|
||
|
||
**P2 (可选 - 高级功能):** ✅ 已完成
|
||
- 任务 7: 图表导出
|
||
- 任务 8: 全屏查看
|
||
- 任务 9: 主题同步
|
||
|
||
**P3 (增强 - 优化和测试):** ✅ 已完成
|
||
- 任务 10: 性能优化
|
||
- 任务 11: 移动端优化
|
||
- 任务 13-17: 质量保证和测试
|
||
|
||
## 实现效果
|
||
|
||
### 问题修复 ✅
|
||
- ✅ PJAX 页面切换后 Mermaid 图表正常渲染
|
||
- ✅ 语法解析错误得到修复
|
||
- ✅ 错误提示友好,保留原始代码
|
||
|
||
### 功能增强 ✅
|
||
- ✅ 支持图表导出(PNG、SVG)
|
||
- ✅ 支持全屏查看(自定义实现)
|
||
- ✅ 支持缩放和拖拽
|
||
- ✅ 工具栏自动显示/隐藏
|
||
|
||
### 体验优化 ✅
|
||
- ✅ 交互流畅,响应迅速
|
||
- ✅ 移动端体验良好
|
||
- ✅ 主题自动同步
|
||
- ✅ 加载动画和视觉反馈
|
||
|
||
### 代码质量 ✅
|
||
- ✅ 代码规范,注释完整
|
||
- ✅ 错误处理完善
|
||
- ✅ 性能优化到位
|
||
- ✅ 无内存泄漏
|
||
|
||
## 注意事项
|
||
|
||
1. **向后兼容**:保持现有 API 和配置不变
|
||
2. **性能优先**:避免阻塞主线程,使用批量渲染
|
||
3. **错误处理**:所有异步操作都要有错误处理
|
||
4. **内存管理**:确保事件监听器和 DOM 引用被正确清理
|
||
5. **测试充分**:测试各种边缘情况和错误场景
|
||
|
||
## 后续维护建议
|
||
|
||
1. **持续测试**:在实际使用中收集用户反馈,优化体验
|
||
2. **性能监控**:关注大量图表页面的性能表现
|
||
3. **兼容性跟进**:跟进 Mermaid 库的版本更新
|
||
4. **文档完善**:根据用户反馈完善使用文档
|