- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段 - 强制每个任务都必须有唯一 id,且由用户负责生成 - 修改合并模式逻辑,merge=true 下保留未提及的旧任务 - 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress) - 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled - 优化状态转换校验,允许特定状态间合法切换 - 简化任务变更消息,移除详细的新增/更新/移除统计 - 更新文档和示例,明确 id 必须由用户生成和使用 - 修复和补充测试,增强状态转换和合并模式验证 - 调整任务时间戳生成逻辑,统一使用当前时间及索引 - 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
5.5 KiB
5.5 KiB
连线系统
连线策略
| 连线数 | 策略 |
|---|---|
| ≤8 | 逐条画 |
| 9-15 | 代表性连线(每层选 1-2 个节点连到下一层) |
| >15 | 层到层连线,或回退精简分组 |
一个节点有 3+ 条连线时:入线从 top,出线从 bottom,同侧多条线用不同方向分散。
connector 必须放根 nodes 数组
// 错误:connector 放在 frame children 里
{ type: 'frame', children: [
{ type: 'connector', ... } // 会导致 Schema 报错或无法连线!
]}
// 正确:connector 放在根 nodes 数组
const doc: WBDocument = {
version: 2,
nodes: [
{ type: 'frame', id: 'box', ... },
{ type: 'connector', ... }, // 必须和顶层 frame 平级
],
};
箭头默认值
endArrow省略时默认为'arrow'(即连线末端默认带箭头)。startArrow省略时默认为'none'(即连线起始端默认无箭头)。
连线技巧
// 自动绕线(推荐):仅需指定节点 id(引擎可自动推断最优出线方向),并使用 polyline 或 rightAngle 形状
// 只要不传 waypoints,引擎会尝试自动避开障碍物并生成折线。
{ type: 'connector', connector: {
from: 'a', to: 'b', // fromAnchor 和 toAnchor 也可以省略,让引擎自己找最短路径
lineShape: 'polyline', lineColor: '#000000', lineWidth: 2, endArrow: 'arrow' }}
// 精确坐标(做注解箭头)
{ type: 'connector', connector: {
from: { x: 150, y: 200 }, to: 'b', toAnchor: 'left',
lineShape: 'curve', lineColor: '#BBBFC4', lineWidth: 2,
lineStyle: 'dashed', endArrow: 'triangle' }}
// 手动控制路径点 waypoints(仅在需要强制固定路线、或者自动路由不符合预期时使用)
// 注意:一旦提供了 waypoints,引擎将严格尊重这些点,不再进行自动避障。
{ type: 'connector', connector: {
from: { x: 300, y: 140 }, to: { x: 300, y: 340 },
waypoints: [{ x: 350, y: 140 }, { x: 350, y: 340 }],
lineShape: 'polyline', lineColor: '#000000', lineWidth: 2, endArrow: 'arrow' }}
// 绘制坐标轴/数轴(必须使用 straight,防止刻度文字触发自动避障导致线条弯曲)
{ type: 'connector', connector: {
from: { x: 100, y: 400 }, to: { x: 600, y: 400 },
lineShape: 'straight', lineColor: '#000000', lineWidth: 2, endArrow: 'arrow' }}
Important
1. 形状选用要求(核心),需明确
lineShape类型:
'polyline'(圆角折线):默认首选。适用于流程图、架构图等绝大多数场景。支持引擎的自动绕线与避障功能(只需指定from和to)。'rightAngle'(直角折线):适用于明确要求“总线/直角规约”、树状层级严格对齐的场景,同样支持自动绕线与避障。'straight'(直线):不受自动避障机制的影响,适用于坐标轴、数轴、几何图形边框、直接指向关系等要求线条绝对笔直、不允许出现任何绕行或弯曲的场景。'curve'(曲线):适用于优雅的跨层连线(S型弯)、自由发散的脑图分支、或做注解箭头时。- 注意:你需要根据当前绘制的图表类型和上下文语境,选择最合适的
lineShape。不要盲目全部使用polyline,例如在绘制坐标系时必须主动切换为straight。 2. 间距要求:有 connector 连线的卡片间 gap 需 ≥ 40,否则箭头挤在缝里看不清。 3. 顶层约束:connector必须直接放在WBDocument.nodes,严禁嵌套在children内。建议在数据末尾统一声明连线。[!TIP] 自动绕线 vs 手动控制
- 优先依赖自动绕线:对于
'polyline'和'rightAngle',引擎会自动规划路径并尝试避开障碍物(fromAnchor和toAnchor也可省略,引擎会自动推断最优出线方向),这是最推荐的方式。- 何时手动算 waypoints:仅在必要时(例如自动路由不符合预期,或者必须强制走特定形状绕开特定元素时),才需要通过
waypoints手动接管坐标序列。连线标签
- 连线文字说明:需要文字说明时,可用
label标注。
锚点方向规则
锚点(top/right/bottom/left)表示连线从节点的哪个边出发,方向含义与 CSS border 四边相同。
注意:由于目前自动绕线功能支持省略锚点让引擎自动推断,以下规则主要适用于你想强制控制出线方向,或者使用直线/曲线时的场景。
选择锚点时根据两个节点的相对位置:目标在下方用 fromAnchor: 'bottom' + toAnchor: 'top',目标在右侧用 fromAnchor: 'right' + toAnchor: 'left'。如果手动指定了锚点,必须与节点的实际相对位置匹配,否则可能导致连线反向绕行。
锚点绑定的常见范式:
- 同层横向推进(目标在正右):
fromAnchor: "right"->toAnchor: "left" - 垂直下沉推进(目标在正下):
fromAnchor: "bottom"->toAnchor: "top" - 跨层斜切推进(目标在左下或右下):首选
fromAnchor: "bottom"->toAnchor: "top"。由于线段自身带有重力倾向,从底部出线再弯曲进入下一层顶部,完美契合流水线的 S 型大弯,能画出最优雅顺滑的跨层曲线。避免使用左右锚点互相跨接。 - 逆流回捞(底部发散回指顶部原点):首选
fromAnchor: "top"->toAnchor: "bottom"配合lineStyle: "dashed"。