docs(wiki): 记录 Veepoo M2 BLE SDK 对接踩坑和正确流程

- wiki/index.md 症状导航新增 5 条:??语法错误、useRef白屏、扫描匹配、认证超时三层根因
- wiki/index.md 关键数字更新:Git 提交 1061 次,小程序描述补充原生分包页面
- docs/discussions/ 新增 SDK 对接流程文档:
  - 连接回调 4 次触发机制(只响应 connection:true)
  - veepooWeiXinSDKNotifyMonitorValueChange 必须在连接后注册
  - VPDeviceAck vs VPDevicepassword 字段区别
  - deviceChipStatus 布尔值兼容
  - 完整踩坑清单(9 项)
This commit is contained in:
iven
2026-05-30 23:07:03 +08:00
parent f96e88b17b
commit 6d073840aa
2 changed files with 214 additions and 3 deletions

View File

@@ -4,7 +4,7 @@
## 关键数字
> 最后更新: 2026-05-25 | 数据截止: feat/media-library-banner 分支(小程序 DevTools 卡死排查 + 构建优化
> 最后更新: 2026-05-30 | 数据截止: feat/media-library-banner 分支(Veepoo M2 BLE 实时测量 + SDK 对接全流程修复
| 指标 | 值 |
|------|-----|
@@ -18,7 +18,7 @@
| erp-ai 实体 | 20 个 Entity95 文件4 AI Providerchat_handler 支持 FC/Ollama fallback |
| 全系统 Entity | **115 个**58 health + 20 ai + 33 基础 + 4 core |
| Web 前端 | 316 个 TS/TSX 文件54 活跃路由83 API 模块108 页面) |
| 微信小程序 | Taro 4.2 + React 18180 个 TS/TSX 文件 / 61 页面(15 主包 + 46 分包) / 4 TabBar + 医生端独立分包34 组件(ui 21 + patterns 4 + 独立 9) / 45 service 文件 / 4 Zustand store / 12 hooks统一组件库 + CSS 变量主题102 SCSS 全量接入 `var(--tk-*)`,字号 token 对齐原型统计,医生端 `.doctor-mode` 靛蓝覆盖,登录页账号密码+微信一键登录);**Phase 2+3 完成**Token 构建时生成 + Canvas 适老 + PII 清理 + 缓存加密 + any 清零 + 大文件拆分(3→6) + 触觉反馈 + 导航状态保持 + 独立分包 + CI 集成 + HMAC 请求签名;**并发安全**:长轮询独立通道 `requestUnlimited` + ConcurrencyLimiter(12) + safeNavigateTo 全局页栈保护 + reLaunch 去重 + 分包预加载 preloadRule**构建优化**`lazyCodeLoading: requiredComponents` 仅生产构建启用dev 下已知 DevTools 卡死 bug`addChunkPages` 仅 TabBar 页注入 common chunk主包 dev 892KB / prod 766KBtaro.js 526→131KB / vendors.js 230→28KB**DevTools 兼容**:游客首页 Swiper dev 模式禁用 circular + 间隔 15s防 DevTools Chromium 渲染进程逐渐卡死;**离线抑制**指数退避3s→6s→12s→30s cap防请求洪泛**五维度分析评分 6.7/10**架构7.25/安全6.0/UX7.4/工程6.2 |
| 微信小程序 | Taro 4.2 + React 18185 个 TS/TSX 文件 / 62 页面(15 主包 + 47 分包) / 4 TabBar + 医生端独立分包34 组件(ui 21 + patterns 4 + 独立 9) / 49 service 文件 / 5 Zustand store / 12 hooks统一组件库 + CSS 变量主题103 SCSS 全量接入 `var(--tk-*)`,字号 token 对齐原型统计,医生端 `.doctor-mode` 靛蓝覆盖,登录页账号密码+微信一键登录);**Phase 2+3 完成**Token 构建时生成 + Canvas 适老 + PII 清理 + 缓存加密 + any 清零 + 大文件拆分(3→6) + 触觉反馈 + 导航状态保持 + 独立分包 + CI 集成 + HMAC 请求签名;**并发安全**:长轮询独立通道 `requestUnlimited` + ConcurrencyLimiter(12) + safeNavigateTo 全局页栈保护 + reLaunch 去重**Veepoo M2 BLE 管线**独立管线VeepooBridge 14 API + VeepooPipeline 事件路由 + VeepooStore 状态管理)+ **原生分包页面**`pkg-veepoo` 原生 JS+WXML脱离 Taro 直接调用 SDK绕过框架兼容性限制+ 实时测量页面(心率/血氧/血压/体温/压力 5 指标,圆环仪表盘 + 长者模式适配)+ 3 天历史数据同步VeepooHistoryReader 分批上传 + 断点续传);**preloadRule 已移除 pkg-health** 防止 380KB SDK 预加载导致首页 DevTools 卡死;**构建优化**`lazyCodeLoading: requiredComponents` 仅生产构建启用dev 下已知 DevTools 卡死 bug`addChunkPages` 仅 TabBar 页注入 common chunk主包 dev 892KB / prod 766KB**五维度分析评分 6.7/10**架构7.25/安全6.0/UX7.4/工程6.2 |
| 前端测试 | Web 62 单元测试文件(~693 断言) + 17 E2E spec(13 Web + 4 MP~64 断言);小程序 12 单元测试文件(127 断言) + 4 E2E spec(~16 断言),覆盖率 ~6% |
| 后端测试 | **1030 个函数**839 同步 + 191 异步96 个文件含测试 |
| 事件系统 | 31 事件类型health/ 51 全系统 / 82 发布点 / 15 消费者模块 / Outbox + LISTEN/NOTIFY |
@@ -27,7 +27,7 @@
| Clippy | **全 workspace 0 警告**2026-05-07 清零) |
| 依赖版本 | 全部最新主版本线Rust edition 2024 |
| API 文档 | `http://localhost:3000/api/docs/openapi.json` |
| Git 提交 | **996** |
| Git 提交 | **1,061** |
| Graphify 知识图谱 | **18,517 节点** / 22,666 边 / 1,841 社区(`graphify-out/`AST 解析,无 API 成本) |
| 系统分析评分 | **6.9/10 (B)**多专家组生产就绪度分析2026-05-21业务 8.5 / 医疗合规 6.5 / 前端 8.0 / 安全 7.5 / DevOps 4.0 |
| 审计状态 | V1: 83% → V2: 85%P0 安全修复已完成E2E 测试 157 端点(Health 63% / AI+Plugin 92.4%)CRITICAL×2 待修复 |
@@ -148,6 +148,11 @@
| TS 编译错误 `readonly Tab[]` 不可赋值给 `Tab[]` | [[miniprogram]] SegmentTabs | 页面组件用 `as const` 创建的 readonly 数组无法传入 mutable `Tab[]` 类型 | **已修复:** SegmentTabs 的 `Tab` 属性改为 `readonly` + `tabs` prop 改为 `readonly Tab[]`2026-05-24 |
| 重建失败 `dist/` 被锁定 | [[miniprogram]] 构建流程 | 微信 DevTools 进程持有 dist 目录文件句柄taro build 无法写入 | **解决:** `taskkill /F /IM wechatdevtools.exe` 后重新构建2026-05-24 |
| DevTools 打开即卡死所有项目Taro/原生均复现) | [[miniprogram]] appid 配置 | appid `wx20f4ef9cc2ec66c5` 的微信后台配置触发 `WAServiceMainContext.js` 内部 timeout导致 DevTools 渲染进程逐渐无响应;**根因定位:** 换用其他 appid如测试 appid `wx97debf52c9547da4`)后 Taro/原生均不卡死,确认是 appid 后台服务配置问题而非框架/代码问题 | **待解决:** 需到微信公众平台mp.weixin.qq.com检查该 appid 是否开通了云开发/云函数/第三方插件等导致 DevTools 初始化时连接超时的服务;临时方案:开发调试时使用测试 appid2026-05-24 |
| 首页加载后 DevTools 卡死Veepoo SDK 预加载触发) | [[miniprogram]] preloadRule | `preloadRule` 首页预加载 `pkg-health` 分包 → `sub-vendors.js` 含 380KB Veepoo SDK → SDK 初始化调用蓝牙 API → DevTools Chromium 渲染进程卡死 | **已修复:**`preloadRule` 首页/健康页移除 `pkg-health` 预加载SDK 仅在用户导航到设备同步/测量页时才加载2026-05-30 |
| 原生页面 `??` 运算符报 SyntaxError | [[miniprogram]] 原生页面 | 微信小程序 JS 引擎不支持 ES2020 `??`nullish coalescing`?.`optional chaining | **已修复:** `values.systolic ?? '--'` 改为 `values.systolic != null ? values.systolic : '--'`2026-05-30 |
| veepoo-measure 页面空白useRef is not defined | [[miniprogram]] 原生页面桥接 | TSX 文件使用 `useRef` 但仅 `import React from 'react'` 未解构导入 | **已修复:** 改为 `import React, { useRef } from 'react'`2026-05-30 |
| M2 设备扫描不到(名称匹配过严) | [[miniprogram]] 原生页面扫描 | 过滤条件 `name.indexOf('M2')` 过严,设备可能广播为 VPM/VEEPOO | **已修复:** 放宽匹配 M2/VPM/VEEPOO 三种前缀2026-05-30 |
| M2 设备认证超时3 层根因) | [[miniprogram]] 原生页面认证 | **根因链**:①连接回调 `errno:0` 在第 1 次回调就匹配,认证在特征值订阅前发送 → 修复为只匹配 `connection:true`;②`veepooWeiXinSDKNotifyMonitorValueChange``onLoad` 注册时内部调用 `wx.notifyBLECharacteristicValueChange`,适配器未初始化 → `not init` 错误,改到 `connection:true` 后注册;③认证结果字段检查错误:代码检查 `VPDevicepassword`(值="0000")而非 `VPDeviceAck`(值="successfulVerification" | **已修复:** 三层修复 — connection:true 唯一匹配 + 监听器时序 + VPDeviceAck 字段2026-05-30 |
## 模块导航