@colinlu50/openclaw-lark-stream 2026.3.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (361) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +141 -0
  3. package/README.zh.md +70 -0
  4. package/bin/openclaw-lark.js +48 -0
  5. package/index.d.ts +36 -0
  6. package/index.js +118 -0
  7. package/openclaw.plugin.json +10 -0
  8. package/package.json +66 -0
  9. package/skills/feishu-bitable/SKILL.md +248 -0
  10. package/skills/feishu-bitable/references/examples.md +813 -0
  11. package/skills/feishu-bitable/references/field-properties.md +763 -0
  12. package/skills/feishu-bitable/references/record-values.md +911 -0
  13. package/skills/feishu-calendar/SKILL.md +244 -0
  14. package/skills/feishu-channel-rules/SKILL.md +24 -0
  15. package/skills/feishu-channel-rules/references/markdown-syntax.md +138 -0
  16. package/skills/feishu-create-doc/SKILL.md +719 -0
  17. package/skills/feishu-fetch-doc/SKILL.md +93 -0
  18. package/skills/feishu-im-read/SKILL.md +163 -0
  19. package/skills/feishu-task/SKILL.md +293 -0
  20. package/skills/feishu-troubleshoot/SKILL.md +70 -0
  21. package/skills/feishu-update-doc/SKILL.md +285 -0
  22. package/src/card/builder.d.ts +106 -0
  23. package/src/card/builder.js +443 -0
  24. package/src/card/cardkit.d.ts +90 -0
  25. package/src/card/cardkit.js +181 -0
  26. package/src/card/flush-controller.d.ts +45 -0
  27. package/src/card/flush-controller.js +134 -0
  28. package/src/card/image-resolver.d.ts +45 -0
  29. package/src/card/image-resolver.js +112 -0
  30. package/src/card/markdown-style.d.ts +16 -0
  31. package/src/card/markdown-style.js +97 -0
  32. package/src/card/reply-dispatcher-types.d.ts +120 -0
  33. package/src/card/reply-dispatcher-types.js +57 -0
  34. package/src/card/reply-dispatcher.d.ts +15 -0
  35. package/src/card/reply-dispatcher.js +299 -0
  36. package/src/card/reply-mode.d.ts +38 -0
  37. package/src/card/reply-mode.js +65 -0
  38. package/src/card/streaming-card-controller.d.ts +101 -0
  39. package/src/card/streaming-card-controller.js +810 -0
  40. package/src/card/unavailable-guard.d.ts +35 -0
  41. package/src/card/unavailable-guard.js +83 -0
  42. package/src/channel/abort-detect.d.ts +34 -0
  43. package/src/channel/abort-detect.js +124 -0
  44. package/src/channel/chat-queue.d.ts +41 -0
  45. package/src/channel/chat-queue.js +58 -0
  46. package/src/channel/config-adapter.d.ts +23 -0
  47. package/src/channel/config-adapter.js +101 -0
  48. package/src/channel/directory.d.ts +57 -0
  49. package/src/channel/directory.js +191 -0
  50. package/src/channel/event-handlers.d.ts +15 -0
  51. package/src/channel/event-handlers.js +221 -0
  52. package/src/channel/monitor.d.ts +17 -0
  53. package/src/channel/monitor.js +129 -0
  54. package/src/channel/onboarding-config.d.ts +17 -0
  55. package/src/channel/onboarding-config.js +88 -0
  56. package/src/channel/onboarding-migrate.d.ts +25 -0
  57. package/src/channel/onboarding-migrate.js +67 -0
  58. package/src/channel/onboarding.d.ts +12 -0
  59. package/src/channel/onboarding.js +296 -0
  60. package/src/channel/plugin.d.ts +13 -0
  61. package/src/channel/plugin.js +278 -0
  62. package/src/channel/probe.d.ts +14 -0
  63. package/src/channel/probe.js +21 -0
  64. package/src/channel/types.d.ts +36 -0
  65. package/src/channel/types.js +7 -0
  66. package/src/commands/auth.d.ts +21 -0
  67. package/src/commands/auth.js +161 -0
  68. package/src/commands/diagnose.d.ts +69 -0
  69. package/src/commands/diagnose.js +807 -0
  70. package/src/commands/doctor.d.ts +26 -0
  71. package/src/commands/doctor.js +584 -0
  72. package/src/commands/index.d.ts +25 -0
  73. package/src/commands/index.js +212 -0
  74. package/src/commands/locale.d.ts +7 -0
  75. package/src/commands/locale.js +7 -0
  76. package/src/core/accounts.d.ts +37 -0
  77. package/src/core/accounts.js +163 -0
  78. package/src/core/agent-config.d.ts +100 -0
  79. package/src/core/agent-config.js +139 -0
  80. package/src/core/api-error.d.ts +48 -0
  81. package/src/core/api-error.js +112 -0
  82. package/src/core/app-owner-fallback.d.ts +21 -0
  83. package/src/core/app-owner-fallback.js +38 -0
  84. package/src/core/app-scope-checker.d.ts +87 -0
  85. package/src/core/app-scope-checker.js +190 -0
  86. package/src/core/auth-errors.d.ts +144 -0
  87. package/src/core/auth-errors.js +154 -0
  88. package/src/core/chat-info-cache.d.ts +57 -0
  89. package/src/core/chat-info-cache.js +152 -0
  90. package/src/core/config-schema.d.ts +448 -0
  91. package/src/core/config-schema.js +200 -0
  92. package/src/core/device-flow.d.ts +77 -0
  93. package/src/core/device-flow.js +212 -0
  94. package/src/core/domains.d.ts +18 -0
  95. package/src/core/domains.js +28 -0
  96. package/src/core/feishu-fetch.d.ts +18 -0
  97. package/src/core/feishu-fetch.js +25 -0
  98. package/src/core/footer-config.d.ts +24 -0
  99. package/src/core/footer-config.js +39 -0
  100. package/src/core/lark-client.d.ts +108 -0
  101. package/src/core/lark-client.js +353 -0
  102. package/src/core/lark-logger.d.ts +23 -0
  103. package/src/core/lark-logger.js +154 -0
  104. package/src/core/lark-ticket.d.ts +29 -0
  105. package/src/core/lark-ticket.js +35 -0
  106. package/src/core/message-unavailable.d.ts +53 -0
  107. package/src/core/message-unavailable.js +130 -0
  108. package/src/core/owner-policy.d.ts +31 -0
  109. package/src/core/owner-policy.js +52 -0
  110. package/src/core/permission-url.d.ts +22 -0
  111. package/src/core/permission-url.js +72 -0
  112. package/src/core/raw-request.d.ts +27 -0
  113. package/src/core/raw-request.js +62 -0
  114. package/src/core/scope-manager.d.ts +168 -0
  115. package/src/core/scope-manager.js +213 -0
  116. package/src/core/security-check.d.ts +72 -0
  117. package/src/core/security-check.js +174 -0
  118. package/src/core/shutdown-hooks.d.ts +22 -0
  119. package/src/core/shutdown-hooks.js +56 -0
  120. package/src/core/targets.d.ts +60 -0
  121. package/src/core/targets.js +164 -0
  122. package/src/core/token-store.d.ts +54 -0
  123. package/src/core/token-store.js +314 -0
  124. package/src/core/tool-client.d.ts +176 -0
  125. package/src/core/tool-client.js +380 -0
  126. package/src/core/tool-scopes.d.ts +153 -0
  127. package/src/core/tool-scopes.js +326 -0
  128. package/src/core/tools-config.d.ts +55 -0
  129. package/src/core/tools-config.js +137 -0
  130. package/src/core/types.d.ts +87 -0
  131. package/src/core/types.js +11 -0
  132. package/src/core/uat-client.d.ts +46 -0
  133. package/src/core/uat-client.js +187 -0
  134. package/src/core/version.d.ts +25 -0
  135. package/src/core/version.js +49 -0
  136. package/src/messaging/converters/audio.d.ts +8 -0
  137. package/src/messaging/converters/audio.js +21 -0
  138. package/src/messaging/converters/calendar.d.ts +13 -0
  139. package/src/messaging/converters/calendar.js +50 -0
  140. package/src/messaging/converters/content-converter.d.ts +41 -0
  141. package/src/messaging/converters/content-converter.js +106 -0
  142. package/src/messaging/converters/file.d.ts +8 -0
  143. package/src/messaging/converters/file.js +20 -0
  144. package/src/messaging/converters/folder.d.ts +8 -0
  145. package/src/messaging/converters/folder.js +20 -0
  146. package/src/messaging/converters/hongbao.d.ts +8 -0
  147. package/src/messaging/converters/hongbao.js +16 -0
  148. package/src/messaging/converters/image.d.ts +8 -0
  149. package/src/messaging/converters/image.js +18 -0
  150. package/src/messaging/converters/index.d.ts +8 -0
  151. package/src/messaging/converters/index.js +50 -0
  152. package/src/messaging/converters/interactive/card-converter.d.ts +76 -0
  153. package/src/messaging/converters/interactive/card-converter.js +1173 -0
  154. package/src/messaging/converters/interactive/card-utils.d.ts +9 -0
  155. package/src/messaging/converters/interactive/card-utils.js +42 -0
  156. package/src/messaging/converters/interactive/index.d.ts +8 -0
  157. package/src/messaging/converters/interactive/index.js +21 -0
  158. package/src/messaging/converters/interactive/legacy.d.ts +11 -0
  159. package/src/messaging/converters/interactive/legacy.js +57 -0
  160. package/src/messaging/converters/interactive/types.d.ts +23 -0
  161. package/src/messaging/converters/interactive/types.js +24 -0
  162. package/src/messaging/converters/location.d.ts +8 -0
  163. package/src/messaging/converters/location.js +19 -0
  164. package/src/messaging/converters/merge-forward.d.ts +32 -0
  165. package/src/messaging/converters/merge-forward.js +225 -0
  166. package/src/messaging/converters/post.d.ts +11 -0
  167. package/src/messaging/converters/post.js +135 -0
  168. package/src/messaging/converters/share.d.ts +9 -0
  169. package/src/messaging/converters/share.js +23 -0
  170. package/src/messaging/converters/sticker.d.ts +8 -0
  171. package/src/messaging/converters/sticker.js +18 -0
  172. package/src/messaging/converters/system.d.ts +12 -0
  173. package/src/messaging/converters/system.js +32 -0
  174. package/src/messaging/converters/text.d.ts +8 -0
  175. package/src/messaging/converters/text.js +14 -0
  176. package/src/messaging/converters/todo.d.ts +8 -0
  177. package/src/messaging/converters/todo.js +41 -0
  178. package/src/messaging/converters/types.d.ts +107 -0
  179. package/src/messaging/converters/types.js +7 -0
  180. package/src/messaging/converters/unknown.d.ts +8 -0
  181. package/src/messaging/converters/unknown.js +16 -0
  182. package/src/messaging/converters/utils.d.ts +22 -0
  183. package/src/messaging/converters/utils.js +51 -0
  184. package/src/messaging/converters/video-chat.d.ts +8 -0
  185. package/src/messaging/converters/video-chat.js +23 -0
  186. package/src/messaging/converters/video.d.ts +8 -0
  187. package/src/messaging/converters/video.js +32 -0
  188. package/src/messaging/converters/vote.d.ts +8 -0
  189. package/src/messaging/converters/vote.js +24 -0
  190. package/src/messaging/inbound/dedup.d.ts +59 -0
  191. package/src/messaging/inbound/dedup.js +116 -0
  192. package/src/messaging/inbound/dispatch-builders.d.ts +84 -0
  193. package/src/messaging/inbound/dispatch-builders.js +152 -0
  194. package/src/messaging/inbound/dispatch-commands.d.ts +27 -0
  195. package/src/messaging/inbound/dispatch-commands.js +112 -0
  196. package/src/messaging/inbound/dispatch-context.d.ts +67 -0
  197. package/src/messaging/inbound/dispatch-context.js +136 -0
  198. package/src/messaging/inbound/dispatch.d.ts +47 -0
  199. package/src/messaging/inbound/dispatch.js +264 -0
  200. package/src/messaging/inbound/enrich.d.ts +102 -0
  201. package/src/messaging/inbound/enrich.js +227 -0
  202. package/src/messaging/inbound/gate-effects.d.ts +23 -0
  203. package/src/messaging/inbound/gate-effects.js +43 -0
  204. package/src/messaging/inbound/gate.d.ts +60 -0
  205. package/src/messaging/inbound/gate.js +233 -0
  206. package/src/messaging/inbound/handler.d.ts +35 -0
  207. package/src/messaging/inbound/handler.js +173 -0
  208. package/src/messaging/inbound/media-resolver.d.ts +32 -0
  209. package/src/messaging/inbound/media-resolver.js +87 -0
  210. package/src/messaging/inbound/mention.d.ts +39 -0
  211. package/src/messaging/inbound/mention.js +81 -0
  212. package/src/messaging/inbound/parse-io.d.ts +50 -0
  213. package/src/messaging/inbound/parse-io.js +81 -0
  214. package/src/messaging/inbound/parse.d.ts +28 -0
  215. package/src/messaging/inbound/parse.js +106 -0
  216. package/src/messaging/inbound/permission.d.ts +17 -0
  217. package/src/messaging/inbound/permission.js +40 -0
  218. package/src/messaging/inbound/policy.d.ts +94 -0
  219. package/src/messaging/inbound/policy.js +160 -0
  220. package/src/messaging/inbound/reaction-handler.d.ts +61 -0
  221. package/src/messaging/inbound/reaction-handler.js +221 -0
  222. package/src/messaging/inbound/user-name-cache.d.ts +82 -0
  223. package/src/messaging/inbound/user-name-cache.js +241 -0
  224. package/src/messaging/outbound/actions.d.ts +16 -0
  225. package/src/messaging/outbound/actions.js +309 -0
  226. package/src/messaging/outbound/chat-manage.d.ts +64 -0
  227. package/src/messaging/outbound/chat-manage.js +111 -0
  228. package/src/messaging/outbound/deliver.d.ts +155 -0
  229. package/src/messaging/outbound/deliver.js +298 -0
  230. package/src/messaging/outbound/fetch.d.ts +12 -0
  231. package/src/messaging/outbound/fetch.js +12 -0
  232. package/src/messaging/outbound/forward.d.ts +26 -0
  233. package/src/messaging/outbound/forward.js +48 -0
  234. package/src/messaging/outbound/media-url-utils.d.ts +29 -0
  235. package/src/messaging/outbound/media-url-utils.js +130 -0
  236. package/src/messaging/outbound/media.d.ts +260 -0
  237. package/src/messaging/outbound/media.js +758 -0
  238. package/src/messaging/outbound/outbound.d.ts +89 -0
  239. package/src/messaging/outbound/outbound.js +121 -0
  240. package/src/messaging/outbound/reactions.d.ts +124 -0
  241. package/src/messaging/outbound/reactions.js +378 -0
  242. package/src/messaging/outbound/send.d.ts +152 -0
  243. package/src/messaging/outbound/send.js +355 -0
  244. package/src/messaging/outbound/typing.d.ts +71 -0
  245. package/src/messaging/outbound/typing.js +179 -0
  246. package/src/messaging/shared/message-lookup.d.ts +54 -0
  247. package/src/messaging/shared/message-lookup.js +117 -0
  248. package/src/messaging/types.d.ts +176 -0
  249. package/src/messaging/types.js +10 -0
  250. package/src/tools/auto-auth.d.ts +56 -0
  251. package/src/tools/auto-auth.js +919 -0
  252. package/src/tools/helpers.d.ts +260 -0
  253. package/src/tools/helpers.js +364 -0
  254. package/src/tools/mcp/doc/create.d.ts +12 -0
  255. package/src/tools/mcp/doc/create.js +44 -0
  256. package/src/tools/mcp/doc/fetch.d.ts +12 -0
  257. package/src/tools/mcp/doc/fetch.js +36 -0
  258. package/src/tools/mcp/doc/index.d.ts +12 -0
  259. package/src/tools/mcp/doc/index.js +41 -0
  260. package/src/tools/mcp/doc/update.d.ts +12 -0
  261. package/src/tools/mcp/doc/update.js +61 -0
  262. package/src/tools/mcp/shared.d.ts +59 -0
  263. package/src/tools/mcp/shared.js +226 -0
  264. package/src/tools/oapi/bitable/app-table-field.d.ts +16 -0
  265. package/src/tools/oapi/bitable/app-table-field.js +222 -0
  266. package/src/tools/oapi/bitable/app-table-record.d.ts +20 -0
  267. package/src/tools/oapi/bitable/app-table-record.js +436 -0
  268. package/src/tools/oapi/bitable/app-table-view.d.ts +17 -0
  269. package/src/tools/oapi/bitable/app-table-view.js +195 -0
  270. package/src/tools/oapi/bitable/app-table.d.ts +19 -0
  271. package/src/tools/oapi/bitable/app-table.js +247 -0
  272. package/src/tools/oapi/bitable/app.d.ts +18 -0
  273. package/src/tools/oapi/bitable/app.js +186 -0
  274. package/src/tools/oapi/bitable/index.d.ts +9 -0
  275. package/src/tools/oapi/bitable/index.js +9 -0
  276. package/src/tools/oapi/calendar/calendar.d.ts +15 -0
  277. package/src/tools/oapi/calendar/calendar.js +122 -0
  278. package/src/tools/oapi/calendar/event-attendee.d.ts +16 -0
  279. package/src/tools/oapi/calendar/event-attendee.js +263 -0
  280. package/src/tools/oapi/calendar/event.d.ts +16 -0
  281. package/src/tools/oapi/calendar/event.js +709 -0
  282. package/src/tools/oapi/calendar/freebusy.d.ts +13 -0
  283. package/src/tools/oapi/calendar/freebusy.js +111 -0
  284. package/src/tools/oapi/calendar/index.d.ts +8 -0
  285. package/src/tools/oapi/calendar/index.js +8 -0
  286. package/src/tools/oapi/chat/chat.d.ts +16 -0
  287. package/src/tools/oapi/chat/chat.js +124 -0
  288. package/src/tools/oapi/chat/index.d.ts +10 -0
  289. package/src/tools/oapi/chat/index.js +15 -0
  290. package/src/tools/oapi/chat/members.d.ts +11 -0
  291. package/src/tools/oapi/chat/members.js +81 -0
  292. package/src/tools/oapi/common/get-user.d.ts +12 -0
  293. package/src/tools/oapi/common/get-user.js +106 -0
  294. package/src/tools/oapi/common/index.d.ts +6 -0
  295. package/src/tools/oapi/common/index.js +6 -0
  296. package/src/tools/oapi/common/search-user.d.ts +11 -0
  297. package/src/tools/oapi/common/search-user.js +73 -0
  298. package/src/tools/oapi/drive/doc-comments.d.ts +15 -0
  299. package/src/tools/oapi/drive/doc-comments.js +279 -0
  300. package/src/tools/oapi/drive/doc-media.d.ts +19 -0
  301. package/src/tools/oapi/drive/doc-media.js +335 -0
  302. package/src/tools/oapi/drive/file.d.ts +19 -0
  303. package/src/tools/oapi/drive/file.js +483 -0
  304. package/src/tools/oapi/drive/index.d.ts +12 -0
  305. package/src/tools/oapi/drive/index.js +36 -0
  306. package/src/tools/oapi/helpers.d.ts +182 -0
  307. package/src/tools/oapi/helpers.js +354 -0
  308. package/src/tools/oapi/im/format-messages.d.ts +50 -0
  309. package/src/tools/oapi/im/format-messages.js +165 -0
  310. package/src/tools/oapi/im/index.d.ts +10 -0
  311. package/src/tools/oapi/im/index.js +17 -0
  312. package/src/tools/oapi/im/message-read.d.ts +13 -0
  313. package/src/tools/oapi/im/message-read.js +411 -0
  314. package/src/tools/oapi/im/message.d.ts +16 -0
  315. package/src/tools/oapi/im/message.js +149 -0
  316. package/src/tools/oapi/im/resource.d.ts +13 -0
  317. package/src/tools/oapi/im/resource.js +150 -0
  318. package/src/tools/oapi/im/time-utils.d.ts +46 -0
  319. package/src/tools/oapi/im/time-utils.js +201 -0
  320. package/src/tools/oapi/im/user-name-uat.d.ts +26 -0
  321. package/src/tools/oapi/im/user-name-uat.js +140 -0
  322. package/src/tools/oapi/index.d.ts +11 -0
  323. package/src/tools/oapi/index.js +58 -0
  324. package/src/tools/oapi/sdk-types.d.ts +96 -0
  325. package/src/tools/oapi/sdk-types.js +12 -0
  326. package/src/tools/oapi/search/doc-search.d.ts +13 -0
  327. package/src/tools/oapi/search/doc-search.js +191 -0
  328. package/src/tools/oapi/search/index.d.ts +12 -0
  329. package/src/tools/oapi/search/index.js +33 -0
  330. package/src/tools/oapi/sheets/index.d.ts +12 -0
  331. package/src/tools/oapi/sheets/index.js +31 -0
  332. package/src/tools/oapi/sheets/sheet.d.ts +16 -0
  333. package/src/tools/oapi/sheets/sheet.js +652 -0
  334. package/src/tools/oapi/task/comment.d.ts +15 -0
  335. package/src/tools/oapi/task/comment.js +140 -0
  336. package/src/tools/oapi/task/index.d.ts +8 -0
  337. package/src/tools/oapi/task/index.js +8 -0
  338. package/src/tools/oapi/task/subtask.d.ts +14 -0
  339. package/src/tools/oapi/task/subtask.js +162 -0
  340. package/src/tools/oapi/task/task.d.ts +16 -0
  341. package/src/tools/oapi/task/task.js +344 -0
  342. package/src/tools/oapi/task/tasklist.d.ts +21 -0
  343. package/src/tools/oapi/task/tasklist.js +321 -0
  344. package/src/tools/oapi/wiki/index.d.ts +12 -0
  345. package/src/tools/oapi/wiki/index.js +34 -0
  346. package/src/tools/oapi/wiki/space-node.d.ts +17 -0
  347. package/src/tools/oapi/wiki/space-node.js +230 -0
  348. package/src/tools/oapi/wiki/space.d.ts +15 -0
  349. package/src/tools/oapi/wiki/space.js +130 -0
  350. package/src/tools/oauth-batch-auth.d.ts +11 -0
  351. package/src/tools/oauth-batch-auth.js +142 -0
  352. package/src/tools/oauth-cards.d.ts +39 -0
  353. package/src/tools/oauth-cards.js +315 -0
  354. package/src/tools/oauth.d.ts +47 -0
  355. package/src/tools/oauth.js +620 -0
  356. package/src/tools/onboarding-auth.d.ts +27 -0
  357. package/src/tools/onboarding-auth.js +130 -0
  358. package/src/tools/tat/im/index.d.ts +15 -0
  359. package/src/tools/tat/im/index.js +18 -0
  360. package/src/tools/tat/im/resource.d.ts +15 -0
  361. package/src/tools/tat/im/resource.js +157 -0
@@ -0,0 +1,285 @@
1
+ ---
2
+ name: feishu-update-doc
3
+ description: |
4
+ 更新飞书云文档。支持 7 种更新模式:追加、覆盖、定位替换、全文替换、前/后插入、删除。
5
+ ---
6
+
7
+ # feishu__update_doc
8
+
9
+ 更新飞书云文档内容,支持 7 种更新模式。优先使用局部更新(replace_range/append/insert_before/insert_after),慎用 overwrite(会清空文档重写,可能丢失图片、评论等)。
10
+
11
+ # 定位方式
12
+
13
+ 定位模式(replace_range/replace_all/insert_before/insert_after/delete_range)支持两种定位方式,二选一:
14
+
15
+ ## selection_with_ellipsis - 内容定位
16
+
17
+ 支持两种格式:
18
+
19
+ 1. **范围匹配**:`开头内容...结尾内容`
20
+ - 匹配从开头到结尾的所有内容(包含中间内容)
21
+ - 建议 10-20 字符确保唯一性
22
+
23
+ 2. **精确匹配**:`完整内容`(不含 `...`)
24
+ - 匹配完整的文本内容
25
+ - 适合替换短文本、关键词等
26
+
27
+ **转义说明**:如果要匹配的内容本身包含 `...`,使用 `\.\.\.` 表示字面量的三个点。
28
+
29
+ 示例:
30
+ - `你好...世界` → 匹配从"你好"到"世界"之间的任意内容
31
+ - `你好\.\.\.世界` → 匹配字面量 "你好...世界"
32
+
33
+ **建议**:如果文档中有多个 `...`,建议使用更长的上下文来精确定位,避免歧义。
34
+
35
+ ## selection_by_title - 标题定位
36
+
37
+ 格式:`## 章节标题`(可带或不带 # 前缀)
38
+
39
+ 自动定位整个章节(从该标题到下一个同级或更高级标题之前)。
40
+
41
+ **示例**:
42
+ - `## 功能说明` → 定位二级标题"功能说明"及其下所有内容
43
+ - `功能说明` → 定位任意级别的"功能说明"标题及其内容
44
+
45
+ # 可选参数
46
+
47
+ ## new_title
48
+
49
+ 更新文档标题。如果提供此参数,将在更新文档内容后同步更新文档标题。
50
+
51
+ **特性**:
52
+ - 仅支持纯文本,不支持富文本格式
53
+ - 长度限制:1-800 字符
54
+ - 可以与任何 mode 配合使用
55
+ - 标题更新在内容更新之后执行
56
+
57
+
58
+ # 返回值
59
+
60
+ ## 成功
61
+
62
+ ```json
63
+ {
64
+ "success": true,
65
+ "doc_id": "文档ID",
66
+ "mode": "使用的模式",
67
+ "message": "文档更新成功(xxx模式)",
68
+ "warnings": ["可选警告列表"],
69
+ "log_id": "请求日志ID"
70
+ }
71
+ ```
72
+
73
+ ## 异步模式(大文档超时)
74
+
75
+ ```json
76
+ {
77
+ "task_id": "async_task_xxxx",
78
+ "message": "文档更新已提交异步处理,请使用 task_id 查询状态",
79
+ "log_id": "请求日志ID"
80
+ }
81
+ ```
82
+
83
+ 使用返回的 `task_id` 再次调用 update-doc(仅传 task_id 参数)查询状态。
84
+
85
+ ## 错误
86
+
87
+ ```json
88
+ {
89
+ "error": "[错误码] 错误消息\n💡 Suggestion: 修复建议\n📍 Context: 上下文信息",
90
+ "log_id": "请求日志ID"
91
+ }
92
+ ```
93
+
94
+ ---
95
+
96
+ # 使用示例
97
+
98
+ ## append - 追加到末尾
99
+
100
+ ```json
101
+ {
102
+ "doc_id": "文档ID或URL",
103
+ "mode": "append",
104
+ "markdown": "## 新章节\n\n追加的内容..."
105
+ }
106
+ ```
107
+
108
+ ## replace_range - 定位替换
109
+
110
+ 使用 `selection_with_ellipsis`:
111
+ ```json
112
+ {
113
+ "doc_id": "文档ID或URL",
114
+ "mode": "replace_range",
115
+ "selection_with_ellipsis": "## 旧章节标题...旧章节结尾。",
116
+ "markdown": "## 新章节标题\n\n新的内容..."
117
+ }
118
+ ```
119
+
120
+ 使用 `selection_by_title`(替换整个章节):
121
+ ```json
122
+ {
123
+ "doc_id": "文档ID或URL",
124
+ "mode": "replace_range",
125
+ "selection_by_title": "## 功能说明",
126
+ "markdown": "## 功能说明\n\n更新后的功能说明内容..."
127
+ }
128
+ ```
129
+
130
+ ## replace_all - 全文替换
131
+
132
+ 与 replace_range 类似,但支持多处同时替换(replace_range 要求匹配唯一):
133
+ ```json
134
+ {
135
+ "doc_id": "文档ID或URL",
136
+ "mode": "replace_all",
137
+ "selection_with_ellipsis": "张三",
138
+ "markdown": "李四"
139
+ }
140
+ ```
141
+
142
+ **返回值**包含 `replace_count` 字段,表示替换的次数:
143
+ ```json
144
+ {
145
+ "success": true,
146
+ "replace_count": 4,
147
+ "message": "文档更新成功(replace_all模式,替换4处)"
148
+ }
149
+ ```
150
+
151
+ **注意**:
152
+ - 与 `replace_range` 不同,`replace_all` 允许多个匹配
153
+ - 如果没有找到匹配内容,会返回错误
154
+ - `markdown` 可以为空字符串,表示删除所有匹配内容
155
+
156
+ ## insert_before - 前插入
157
+
158
+ ```json
159
+ {
160
+ "doc_id": "文档ID或URL",
161
+ "mode": "insert_before",
162
+ "selection_with_ellipsis": "## 危险操作...数据丢失风险。",
163
+ "markdown": "> **警告**:以下操作需谨慎!"
164
+ }
165
+ ```
166
+
167
+ ## insert_after - 后插入
168
+
169
+ ```json
170
+ {
171
+ "doc_id": "文档ID或URL",
172
+ "mode": "insert_after",
173
+ "selection_with_ellipsis": "```python...```",
174
+ "markdown": "**输出示例**:\n```\nresult = 42\n```"
175
+ }
176
+ ```
177
+
178
+ ## delete_range - 删除内容
179
+
180
+ 使用 `selection_with_ellipsis`:
181
+ ```json
182
+ {
183
+ "doc_id": "文档ID或URL",
184
+ "mode": "delete_range",
185
+ "selection_with_ellipsis": "## 废弃章节...不再需要的内容。"
186
+ }
187
+ ```
188
+
189
+ 使用 `selection_by_title`(删除整个章节):
190
+ ```json
191
+ {
192
+ "doc_id": "文档ID或URL",
193
+ "mode": "delete_range",
194
+ "selection_by_title": "## 废弃章节"
195
+ }
196
+ ```
197
+
198
+ 注意:delete_range 模式不需要 markdown 参数。
199
+
200
+ ## 同时更新标题和内容
201
+
202
+ 可以在任何更新模式中添加 `new_title` 参数来同时更新文档标题:
203
+
204
+ ```json
205
+ {
206
+ "doc_id": "文档ID或URL",
207
+ "mode": "overwrite",
208
+ "markdown": "# 项目文档 v2.0\n\n全新的内容...",
209
+ "new_title": "项目文档 v2.0"
210
+ }
211
+ ```
212
+
213
+ ```json
214
+ {
215
+ "doc_id": "文档ID或URL",
216
+ "mode": "append",
217
+ "markdown": "## 更新日志\n\n2025-12-18: 新增功能...",
218
+ "new_title": "项目文档(已更新)"
219
+ }
220
+ ```
221
+
222
+ ## overwrite - 完全覆盖
223
+
224
+ ⚠️ 会清空文档后重写,可能丢失图片、评论等,仅在需要完全重建文档时使用。
225
+
226
+ ```json
227
+ {
228
+ "doc_id": "文档ID或URL",
229
+ "mode": "overwrite",
230
+ "markdown": "# 新文档\n\n全新的内容..."
231
+ }
232
+ ```
233
+
234
+ ---
235
+
236
+ # 最佳实践
237
+
238
+ ## 小粒度精确替换
239
+
240
+ 修改文档内容时,**定位范围越小越安全**。尤其是表格、分栏等嵌套块,应精确定位到需要修改的文本,避免影响其他内容。
241
+
242
+ **示例**:表格单元格中有图片和文字,只需修改文字
243
+ - ❌ 替换整个表格或整行 → 可能破坏图片引用
244
+ - ✅ 只定位需要修改的文本 → 图片等其他内容不受影响
245
+
246
+
247
+ ## 保护不可重建的内容
248
+
249
+ 图片、画板、电子表格、多维表格、任务等内容以 token 形式存储,**无法读出后原样写入**。
250
+
251
+ **保护策略**:
252
+ - 替换时避开包含这些内容的区域
253
+ - 精确定位到纯文本部分进行修改
254
+
255
+ ## 分步更新优于整体覆盖
256
+
257
+ 修改多处内容时:
258
+ - ✅ 多次小范围替换,逐步修改
259
+ - ⚠️ 谨慎使用 `overwrite` 重写整个文档, 除非你认为风险完全可控
260
+
261
+ **原因**:局部更新保留原有媒体、评论、协作历史,更安全可靠。
262
+
263
+ ## insert 模式扩大定位范围时注意插入位置
264
+
265
+ 使用 `insert_before` 或 `insert_after` 时,如果目标内容重复出现,需要扩大 `selection_with_ellipsis` 范围来唯一定位。
266
+
267
+ **关键**:插入位置基于匹配范围的**边界**:
268
+ - `insert_after` → 插入在匹配范围的**结尾**之后
269
+ - `insert_before` → 插入在匹配范围的**开头**之前
270
+
271
+ 扩大范围时,确保边界仍然是期望的插入点。
272
+
273
+ ## 修复画板语法错误
274
+
275
+ 当 create-doc 或 update-doc 返回画板写入失败的 warning 时:
276
+ 1. warning 中包含 whiteboard 标签(如 `<whiteboard token="xxx"/>`)
277
+ 2. 分析错误信息,修正 Mermaid/PlantUML 语法
278
+ 3. 用 `replace_range` 替换:`selection_with_ellipsis` 使用 warning 中的 whiteboard 标签,`markdown` 提供修正后的代码块
279
+ 4. 重新提交验证
280
+
281
+ ---
282
+
283
+ # 注意事项
284
+
285
+ - **Markdown 语法**:支持飞书扩展语法,详见 create-doc 工具文档
@@ -0,0 +1,106 @@
1
+ /**
2
+ * Copyright (c) 2026 ByteDance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ *
5
+ * Interactive card building for Lark/Feishu.
6
+ *
7
+ * Provides utilities to construct Feishu Interactive Message Cards for
8
+ * different agent response states (thinking, streaming, complete, confirm).
9
+ */
10
+ /**
11
+ * Element ID used for the streaming text area in cards. The CardKit
12
+ * `cardElement.content()` API targets this element for typewriter-effect
13
+ * streaming updates.
14
+ */
15
+ export declare const STREAMING_ELEMENT_ID = "streaming_content";
16
+ export declare const REASONING_ELEMENT_ID = "reasoning_content";
17
+ export interface ToolCallInfo {
18
+ name: string;
19
+ status: 'running' | 'complete' | 'error';
20
+ args?: Record<string, unknown>;
21
+ result?: string;
22
+ durationMs?: number;
23
+ startTime?: number;
24
+ }
25
+ export interface CardElement {
26
+ tag: string;
27
+ [key: string]: unknown;
28
+ }
29
+ export interface FeishuCard {
30
+ config: {
31
+ wide_screen_mode: boolean;
32
+ update_multi?: boolean;
33
+ locales?: string[];
34
+ summary?: {
35
+ content: string;
36
+ };
37
+ };
38
+ header?: {
39
+ title: {
40
+ tag: 'plain_text';
41
+ content: string;
42
+ i18n_content?: Record<string, string>;
43
+ };
44
+ template: string;
45
+ };
46
+ elements: CardElement[];
47
+ }
48
+ export type CardState = 'thinking' | 'streaming' | 'complete' | 'confirm';
49
+ export interface ConfirmData {
50
+ operationDescription: string;
51
+ pendingOperationId: string;
52
+ preview?: string;
53
+ }
54
+ /**
55
+ * Split a payload text into optional `reasoningText` and `answerText`.
56
+ *
57
+ * Handles two formats produced by the framework:
58
+ * 1. "Reasoning:\n_italic line_\n…" prefix (from `formatReasoningMessage`)
59
+ * 2. `<think>…</think>` / `<thinking>…</thinking>` XML tags
60
+ *
61
+ * Equivalent to the framework's `splitTelegramReasoningText()`.
62
+ */
63
+ export declare function splitReasoningText(text?: string): {
64
+ reasoningText?: string;
65
+ answerText?: string;
66
+ };
67
+ /**
68
+ * Strip reasoning blocks — both XML tags with their content and any
69
+ * "Reasoning:\n" prefixed content.
70
+ */
71
+ export declare function stripReasoningTags(text: string): string;
72
+ /**
73
+ * Format reasoning duration into a human-readable i18n pair.
74
+ * e.g. { zh: "思考了 3.2s", en: "Thought for 3.2s" }
75
+ */
76
+ export declare function formatReasoningDuration(ms: number): {
77
+ zh: string;
78
+ en: string;
79
+ };
80
+ /**
81
+ * Format milliseconds into a human-readable duration string.
82
+ */
83
+ export declare function formatElapsed(ms: number): string;
84
+ /**
85
+ * Build a full Feishu Interactive Message Card JSON object for the
86
+ * given state.
87
+ */
88
+ export declare function buildCardContent(state: CardState, data?: {
89
+ text?: string;
90
+ reasoningText?: string;
91
+ reasoningElapsedMs?: number;
92
+ toolCalls?: ToolCallInfo[];
93
+ confirmData?: ConfirmData;
94
+ elapsedMs?: number;
95
+ isError?: boolean;
96
+ isAborted?: boolean;
97
+ footer?: {
98
+ status?: boolean;
99
+ elapsed?: boolean;
100
+ };
101
+ }): FeishuCard;
102
+ /**
103
+ * Convert an old-format FeishuCard to CardKit JSON 2.0 format.
104
+ * JSON 2.0 uses `body.elements` instead of top-level `elements`.
105
+ */
106
+ export declare function toCardKit2(card: FeishuCard): Record<string, unknown>;