@yandy0725/pi-lark 0.1.0

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 (392) hide show
  1. package/README.md +30 -0
  2. package/README.zh.md +30 -0
  3. package/package.json +36 -0
  4. package/skills/lark-approval/SKILL.md +56 -0
  5. package/skills/lark-approval/references/lark-approval-initiate.md +196 -0
  6. package/skills/lark-approval/references/lark-approval-instance-form-control-parameters.md +606 -0
  7. package/skills/lark-approval/references/lark-approval-instance-value-sourcing.md +108 -0
  8. package/skills/lark-apps/SKILL.md +78 -0
  9. package/skills/lark-apps/references/lark-apps-access-scope-get.md +28 -0
  10. package/skills/lark-apps/references/lark-apps-access-scope-set.md +40 -0
  11. package/skills/lark-apps/references/lark-apps-cloud-dev.md +120 -0
  12. package/skills/lark-apps/references/lark-apps-create.md +40 -0
  13. package/skills/lark-apps/references/lark-apps-db-env-create.md +31 -0
  14. package/skills/lark-apps/references/lark-apps-db-execute.md +40 -0
  15. package/skills/lark-apps/references/lark-apps-db-table-get.md +29 -0
  16. package/skills/lark-apps/references/lark-apps-db-table-list.md +31 -0
  17. package/skills/lark-apps/references/lark-apps-env-pull.md +35 -0
  18. package/skills/lark-apps/references/lark-apps-git-credential.md +37 -0
  19. package/skills/lark-apps/references/lark-apps-html-publish.md +57 -0
  20. package/skills/lark-apps/references/lark-apps-init.md +37 -0
  21. package/skills/lark-apps/references/lark-apps-list.md +37 -0
  22. package/skills/lark-apps/references/lark-apps-local-dev.md +76 -0
  23. package/skills/lark-apps/references/lark-apps-release-create.md +30 -0
  24. package/skills/lark-apps/references/lark-apps-release-get.md +28 -0
  25. package/skills/lark-apps/references/lark-apps-release-list.md +31 -0
  26. package/skills/lark-apps/references/lark-apps-session-messages-list.md +53 -0
  27. package/skills/lark-apps/references/lark-apps-update.md +30 -0
  28. package/skills/lark-attendance/SKILL.md +57 -0
  29. package/skills/lark-base/SKILL.md +157 -0
  30. package/skills/lark-base/references/dashboard-block-data-config.md +350 -0
  31. package/skills/lark-base/references/formula-field-guide.md +737 -0
  32. package/skills/lark-base/references/lark-base-cell-value.md +153 -0
  33. package/skills/lark-base/references/lark-base-dashboard-block-get-data.md +717 -0
  34. package/skills/lark-base/references/lark-base-dashboard.md +238 -0
  35. package/skills/lark-base/references/lark-base-data-analysis-sop.md +210 -0
  36. package/skills/lark-base/references/lark-base-data-query-guide.md +61 -0
  37. package/skills/lark-base/references/lark-base-data-query.md +452 -0
  38. package/skills/lark-base/references/lark-base-field-create.md +103 -0
  39. package/skills/lark-base/references/lark-base-field-json.md +489 -0
  40. package/skills/lark-base/references/lark-base-field-update.md +171 -0
  41. package/skills/lark-base/references/lark-base-form-detail.md +71 -0
  42. package/skills/lark-base/references/lark-base-form-questions-create.md +118 -0
  43. package/skills/lark-base/references/lark-base-form-questions-update.md +92 -0
  44. package/skills/lark-base/references/lark-base-form-submit.md +170 -0
  45. package/skills/lark-base/references/lark-base-record-batch-create.md +57 -0
  46. package/skills/lark-base/references/lark-base-record-batch-update.md +52 -0
  47. package/skills/lark-base/references/lark-base-record-history-list.md +43 -0
  48. package/skills/lark-base/references/lark-base-record-upsert.md +63 -0
  49. package/skills/lark-base/references/lark-base-role-guide.md +65 -0
  50. package/skills/lark-base/references/lark-base-view-set-filter.md +189 -0
  51. package/skills/lark-base/references/lark-base-workflow-guide.md +830 -0
  52. package/skills/lark-base/references/lark-base-workflow-schema.md +1071 -0
  53. package/skills/lark-base/references/lookup-field-guide.md +512 -0
  54. package/skills/lark-base/references/role-config.md +549 -0
  55. package/skills/lark-calendar/SKILL.md +137 -0
  56. package/skills/lark-calendar/references/lark-calendar-agenda.md +78 -0
  57. package/skills/lark-calendar/references/lark-calendar-create.md +106 -0
  58. package/skills/lark-calendar/references/lark-calendar-freebusy.md +124 -0
  59. package/skills/lark-calendar/references/lark-calendar-meeting.md +40 -0
  60. package/skills/lark-calendar/references/lark-calendar-room-find.md +113 -0
  61. package/skills/lark-calendar/references/lark-calendar-rsvp.md +42 -0
  62. package/skills/lark-calendar/references/lark-calendar-schedule-meeting.md +265 -0
  63. package/skills/lark-calendar/references/lark-calendar-search-event.md +29 -0
  64. package/skills/lark-calendar/references/lark-calendar-suggestion.md +125 -0
  65. package/skills/lark-calendar/references/lark-calendar-update.md +105 -0
  66. package/skills/lark-contact/SKILL.md +59 -0
  67. package/skills/lark-contact/references/lark-contact-get-user.md +19 -0
  68. package/skills/lark-contact/references/lark-contact-search-user.md +124 -0
  69. package/skills/lark-doc/SKILL.md +79 -0
  70. package/skills/lark-doc/references/lark-doc-create.md +79 -0
  71. package/skills/lark-doc/references/lark-doc-fetch.md +138 -0
  72. package/skills/lark-doc/references/lark-doc-md.md +76 -0
  73. package/skills/lark-doc/references/lark-doc-media-download.md +50 -0
  74. package/skills/lark-doc/references/lark-doc-media-insert.md +114 -0
  75. package/skills/lark-doc/references/lark-doc-media-preview.md +41 -0
  76. package/skills/lark-doc/references/lark-doc-resource-cover.md +70 -0
  77. package/skills/lark-doc/references/lark-doc-update.md +259 -0
  78. package/skills/lark-doc/references/lark-doc-whiteboard.md +154 -0
  79. package/skills/lark-doc/references/lark-doc-xml.md +181 -0
  80. package/skills/lark-doc/references/style/lark-doc-create-workflow.md +59 -0
  81. package/skills/lark-doc/references/style/lark-doc-style.md +86 -0
  82. package/skills/lark-doc/references/style/lark-doc-update-workflow.md +55 -0
  83. package/skills/lark-drive/SKILL.md +215 -0
  84. package/skills/lark-drive/references/lark-drive-add-comment.md +193 -0
  85. package/skills/lark-drive/references/lark-drive-apply-permission.md +77 -0
  86. package/skills/lark-drive/references/lark-drive-comment-location.md +193 -0
  87. package/skills/lark-drive/references/lark-drive-comments-guide.md +72 -0
  88. package/skills/lark-drive/references/lark-drive-cover.md +79 -0
  89. package/skills/lark-drive/references/lark-drive-create-folder.md +73 -0
  90. package/skills/lark-drive/references/lark-drive-create-shortcut.md +103 -0
  91. package/skills/lark-drive/references/lark-drive-delete.md +79 -0
  92. package/skills/lark-drive/references/lark-drive-download.md +31 -0
  93. package/skills/lark-drive/references/lark-drive-export-download.md +50 -0
  94. package/skills/lark-drive/references/lark-drive-export.md +145 -0
  95. package/skills/lark-drive/references/lark-drive-files-list.md +158 -0
  96. package/skills/lark-drive/references/lark-drive-import.md +170 -0
  97. package/skills/lark-drive/references/lark-drive-inspect.md +50 -0
  98. package/skills/lark-drive/references/lark-drive-member-add.md +66 -0
  99. package/skills/lark-drive/references/lark-drive-move.md +120 -0
  100. package/skills/lark-drive/references/lark-drive-permission-guide.md +41 -0
  101. package/skills/lark-drive/references/lark-drive-preview.md +87 -0
  102. package/skills/lark-drive/references/lark-drive-pull.md +137 -0
  103. package/skills/lark-drive/references/lark-drive-push.md +162 -0
  104. package/skills/lark-drive/references/lark-drive-reactions.md +113 -0
  105. package/skills/lark-drive/references/lark-drive-search.md +269 -0
  106. package/skills/lark-drive/references/lark-drive-secure-label.md +52 -0
  107. package/skills/lark-drive/references/lark-drive-status.md +137 -0
  108. package/skills/lark-drive/references/lark-drive-task-result.md +302 -0
  109. package/skills/lark-drive/references/lark-drive-upload.md +101 -0
  110. package/skills/lark-drive/references/lark-drive-version-delete.md +38 -0
  111. package/skills/lark-drive/references/lark-drive-version-get.md +71 -0
  112. package/skills/lark-drive/references/lark-drive-version-history.md +73 -0
  113. package/skills/lark-drive/references/lark-drive-version-revert.md +35 -0
  114. package/skills/lark-drive/references/lark-drive-workflow-knowledge-organize-analysis.md +249 -0
  115. package/skills/lark-drive/references/lark-drive-workflow-knowledge-organize-discovery.md +253 -0
  116. package/skills/lark-drive/references/lark-drive-workflow-knowledge-organize-execution.md +200 -0
  117. package/skills/lark-drive/references/lark-drive-workflow-knowledge-organize-planning.md +336 -0
  118. package/skills/lark-drive/references/lark-drive-workflow-knowledge-organize-rollback.md +308 -0
  119. package/skills/lark-drive/references/lark-drive-workflow-knowledge-organize.md +226 -0
  120. package/skills/lark-drive/references/lark-drive-workflow-permission-governance-commands.md +168 -0
  121. package/skills/lark-drive/references/lark-drive-workflow-permission-governance-outputs.md +424 -0
  122. package/skills/lark-drive/references/lark-drive-workflow-permission-governance.md +207 -0
  123. package/skills/lark-drive/references/lark-drive-workflow.md +130 -0
  124. package/skills/lark-event/SKILL.md +154 -0
  125. package/skills/lark-event/references/lark-event-im.md +87 -0
  126. package/skills/lark-event/references/lark-event-minutes.md +54 -0
  127. package/skills/lark-event/references/lark-event-task.md +78 -0
  128. package/skills/lark-event/references/lark-event-vc.md +94 -0
  129. package/skills/lark-event/references/lark-event-whiteboard.md +67 -0
  130. package/skills/lark-im/SKILL.md +247 -0
  131. package/skills/lark-im/references/lark-im-card-action-reply.md +175 -0
  132. package/skills/lark-im/references/lark-im-chat-create.md +162 -0
  133. package/skills/lark-im/references/lark-im-chat-identity.md +55 -0
  134. package/skills/lark-im/references/lark-im-chat-list.md +166 -0
  135. package/skills/lark-im/references/lark-im-chat-messages-list.md +157 -0
  136. package/skills/lark-im/references/lark-im-chat-search.md +142 -0
  137. package/skills/lark-im/references/lark-im-chat-update.md +84 -0
  138. package/skills/lark-im/references/lark-im-feed-group-list-item.md +68 -0
  139. package/skills/lark-im/references/lark-im-feed-group-list.md +65 -0
  140. package/skills/lark-im/references/lark-im-feed-group-query-item.md +44 -0
  141. package/skills/lark-im/references/lark-im-feed-groups.md +452 -0
  142. package/skills/lark-im/references/lark-im-feed-shortcut-create.md +97 -0
  143. package/skills/lark-im/references/lark-im-feed-shortcut-list.md +103 -0
  144. package/skills/lark-im/references/lark-im-feed-shortcut-remove.md +48 -0
  145. package/skills/lark-im/references/lark-im-flag-cancel.md +67 -0
  146. package/skills/lark-im/references/lark-im-flag-create.md +67 -0
  147. package/skills/lark-im/references/lark-im-flag-list.md +100 -0
  148. package/skills/lark-im/references/lark-im-message-enrichment.md +54 -0
  149. package/skills/lark-im/references/lark-im-messages-mget.md +99 -0
  150. package/skills/lark-im/references/lark-im-messages-reply.md +267 -0
  151. package/skills/lark-im/references/lark-im-messages-resources-download.md +94 -0
  152. package/skills/lark-im/references/lark-im-messages-search.md +234 -0
  153. package/skills/lark-im/references/lark-im-messages-send.md +267 -0
  154. package/skills/lark-im/references/lark-im-reactions.md +299 -0
  155. package/skills/lark-im/references/lark-im-threads-messages-list.md +115 -0
  156. package/skills/lark-mail/SKILL.md +287 -0
  157. package/skills/lark-mail/assets/templates/job-application--resume.html +33 -0
  158. package/skills/lark-mail/assets/templates/newsletter--weekly-brief.html +50 -0
  159. package/skills/lark-mail/assets/templates/research--market-report.html +256 -0
  160. package/skills/lark-mail/assets/templates/weekly--personal-report.html +43 -0
  161. package/skills/lark-mail/assets/templates/weekly--team-report.html +9 -0
  162. package/skills/lark-mail/references/lark-mail-calendar-invite.md +36 -0
  163. package/skills/lark-mail/references/lark-mail-decline-receipt.md +115 -0
  164. package/skills/lark-mail/references/lark-mail-draft-create.md +127 -0
  165. package/skills/lark-mail/references/lark-mail-draft-edit.md +404 -0
  166. package/skills/lark-mail/references/lark-mail-forward.md +239 -0
  167. package/skills/lark-mail/references/lark-mail-html.md +333 -0
  168. package/skills/lark-mail/references/lark-mail-lint-html.md +243 -0
  169. package/skills/lark-mail/references/lark-mail-message.md +233 -0
  170. package/skills/lark-mail/references/lark-mail-messages.md +108 -0
  171. package/skills/lark-mail/references/lark-mail-recall.md +66 -0
  172. package/skills/lark-mail/references/lark-mail-recipient-search.md +59 -0
  173. package/skills/lark-mail/references/lark-mail-reply-all.md +213 -0
  174. package/skills/lark-mail/references/lark-mail-reply.md +249 -0
  175. package/skills/lark-mail/references/lark-mail-rules.md +31 -0
  176. package/skills/lark-mail/references/lark-mail-send-as.md +44 -0
  177. package/skills/lark-mail/references/lark-mail-send-receipt.md +120 -0
  178. package/skills/lark-mail/references/lark-mail-send-status.md +46 -0
  179. package/skills/lark-mail/references/lark-mail-send.md +222 -0
  180. package/skills/lark-mail/references/lark-mail-share-to-chat.md +87 -0
  181. package/skills/lark-mail/references/lark-mail-signature.md +98 -0
  182. package/skills/lark-mail/references/lark-mail-template-create.md +129 -0
  183. package/skills/lark-mail/references/lark-mail-template-update.md +150 -0
  184. package/skills/lark-mail/references/lark-mail-template.md +54 -0
  185. package/skills/lark-mail/references/lark-mail-thread.md +111 -0
  186. package/skills/lark-mail/references/lark-mail-triage.md +131 -0
  187. package/skills/lark-mail/references/lark-mail-watch.md +94 -0
  188. package/skills/lark-markdown/SKILL.md +69 -0
  189. package/skills/lark-markdown/references/lark-markdown-create.md +94 -0
  190. package/skills/lark-markdown/references/lark-markdown-diff.md +156 -0
  191. package/skills/lark-markdown/references/lark-markdown-fetch.md +79 -0
  192. package/skills/lark-markdown/references/lark-markdown-overwrite.md +85 -0
  193. package/skills/lark-markdown/references/lark-markdown-patch.md +160 -0
  194. package/skills/lark-minutes/SKILL.md +192 -0
  195. package/skills/lark-minutes/references/lark-minutes-detail.md +62 -0
  196. package/skills/lark-minutes/references/lark-minutes-download.md +137 -0
  197. package/skills/lark-minutes/references/lark-minutes-search.md +204 -0
  198. package/skills/lark-minutes/references/lark-minutes-speaker-replace.md +107 -0
  199. package/skills/lark-minutes/references/lark-minutes-summary.md +122 -0
  200. package/skills/lark-minutes/references/lark-minutes-todo.md +138 -0
  201. package/skills/lark-minutes/references/lark-minutes-update.md +41 -0
  202. package/skills/lark-minutes/references/lark-minutes-upload.md +104 -0
  203. package/skills/lark-note/SKILL.md +94 -0
  204. package/skills/lark-note/references/lark-note-detail.md +26 -0
  205. package/skills/lark-note/references/lark-note-transcript.md +23 -0
  206. package/skills/lark-okr/SKILL.md +115 -0
  207. package/skills/lark-okr/references/lark-okr-batch-create.md +106 -0
  208. package/skills/lark-okr/references/lark-okr-contentblock.md +359 -0
  209. package/skills/lark-okr/references/lark-okr-cycle-detail.md +84 -0
  210. package/skills/lark-okr/references/lark-okr-cycle-list.md +90 -0
  211. package/skills/lark-okr/references/lark-okr-entities.md +329 -0
  212. package/skills/lark-okr/references/lark-okr-image-upload.md +116 -0
  213. package/skills/lark-okr/references/lark-okr-indicator-update.md +80 -0
  214. package/skills/lark-okr/references/lark-okr-progress-create.md +81 -0
  215. package/skills/lark-okr/references/lark-okr-progress-delete.md +47 -0
  216. package/skills/lark-okr/references/lark-okr-progress-get.md +62 -0
  217. package/skills/lark-okr/references/lark-okr-progress-list.md +80 -0
  218. package/skills/lark-okr/references/lark-okr-progress-update.md +81 -0
  219. package/skills/lark-okr/references/lark-okr-reorder.md +81 -0
  220. package/skills/lark-okr/references/lark-okr-weight.md +96 -0
  221. package/skills/lark-openapi-explorer/SKILL.md +153 -0
  222. package/skills/lark-shared/SKILL.md +168 -0
  223. package/skills/lark-shared/references/lark-wiki-token-routing.md +42 -0
  224. package/skills/lark-sheets/SKILL.md +165 -0
  225. package/skills/lark-sheets/references/lark-sheets-batch-update.md +191 -0
  226. package/skills/lark-sheets/references/lark-sheets-chart.md +330 -0
  227. package/skills/lark-sheets/references/lark-sheets-conditional-format.md +179 -0
  228. package/skills/lark-sheets/references/lark-sheets-core-operations.md +103 -0
  229. package/skills/lark-sheets/references/lark-sheets-filter-view.md +137 -0
  230. package/skills/lark-sheets/references/lark-sheets-filter.md +130 -0
  231. package/skills/lark-sheets/references/lark-sheets-float-image.md +159 -0
  232. package/skills/lark-sheets/references/lark-sheets-formula-translation.md +267 -0
  233. package/skills/lark-sheets/references/lark-sheets-pivot-table.md +166 -0
  234. package/skills/lark-sheets/references/lark-sheets-range-operations.md +267 -0
  235. package/skills/lark-sheets/references/lark-sheets-read-data.md +235 -0
  236. package/skills/lark-sheets/references/lark-sheets-search-replace.md +111 -0
  237. package/skills/lark-sheets/references/lark-sheets-sheet-structure.md +212 -0
  238. package/skills/lark-sheets/references/lark-sheets-sparkline.md +149 -0
  239. package/skills/lark-sheets/references/lark-sheets-visual-standards.md +205 -0
  240. package/skills/lark-sheets/references/lark-sheets-workbook.md +395 -0
  241. package/skills/lark-sheets/references/lark-sheets-write-cells.md +565 -0
  242. package/skills/lark-sheets/scripts/sheets_df.py +32 -0
  243. package/skills/lark-skill-maker/SKILL.md +85 -0
  244. package/skills/lark-slides/SKILL.md +293 -0
  245. package/skills/lark-slides/assets/templates/administration--all_hands_meeting.xml +1999 -0
  246. package/skills/lark-slides/assets/templates/administration--annual_gala.xml +1160 -0
  247. package/skills/lark-slides/assets/templates/administration--company_intro.xml +1376 -0
  248. package/skills/lark-slides/assets/templates/administration--corporate_culture.xml +1765 -0
  249. package/skills/lark-slides/assets/templates/hr--employee_training.xml +912 -0
  250. package/skills/lark-slides/assets/templates/hr--employee_training_workshop.xml +1504 -0
  251. package/skills/lark-slides/assets/templates/hr--onboarding.xml +933 -0
  252. package/skills/lark-slides/assets/templates/marketing--brand_communication.xml +1367 -0
  253. package/skills/lark-slides/assets/templates/marketing--brand_logo_design.xml +1347 -0
  254. package/skills/lark-slides/assets/templates/marketing--brand_operations_plan.xml +1309 -0
  255. package/skills/lark-slides/assets/templates/marketing--business_plan.xml +1646 -0
  256. package/skills/lark-slides/assets/templates/marketing--marketing_plan.xml +1469 -0
  257. package/skills/lark-slides/assets/templates/marketing--marketing_strategy.xml +1484 -0
  258. package/skills/lark-slides/assets/templates/marketing--product_whitepaper.xml +1455 -0
  259. package/skills/lark-slides/assets/templates/marketing--roadshow_business_plan.xml +1506 -0
  260. package/skills/lark-slides/assets/templates/misc--book_sharing.xml +1338 -0
  261. package/skills/lark-slides/assets/templates/misc--club_event_plan.xml +4885 -0
  262. package/skills/lark-slides/assets/templates/misc--student_career_plan.xml +1854 -0
  263. package/skills/lark-slides/assets/templates/office--dark_general.xml +3763 -0
  264. package/skills/lark-slides/assets/templates/office--dept_annual_report.xml +1192 -0
  265. package/skills/lark-slides/assets/templates/office--light_general.xml +3378 -0
  266. package/skills/lark-slides/assets/templates/office--project_kickoff.xml +3152 -0
  267. package/skills/lark-slides/assets/templates/office--quarterly_review.xml +1253 -0
  268. package/skills/lark-slides/assets/templates/office--work_report.xml +1099 -0
  269. package/skills/lark-slides/assets/templates/office--work_summary.xml +4420 -0
  270. package/skills/lark-slides/assets/templates/office--work_summary_report.xml +1523 -0
  271. package/skills/lark-slides/assets/templates/operations--brand_logo_design.xml +1347 -0
  272. package/skills/lark-slides/assets/templates/operations--brand_operations_plan.xml +1309 -0
  273. package/skills/lark-slides/assets/templates/operations--marketing_plan.xml +1469 -0
  274. package/skills/lark-slides/assets/templates/operations--product_promotion.xml +687 -0
  275. package/skills/lark-slides/assets/templates/personal--experience_sharing.xml +2242 -0
  276. package/skills/lark-slides/assets/templates/personal--personal_resume.xml +2047 -0
  277. package/skills/lark-slides/assets/templates/personal--promotion_defense.xml +1099 -0
  278. package/skills/lark-slides/assets/templates/personal--promotion_report.xml +1039 -0
  279. package/skills/lark-slides/assets/templates/personal--self_intro.xml +696 -0
  280. package/skills/lark-slides/assets/templates/personal--teaching_sharing.xml +3013 -0
  281. package/skills/lark-slides/assets/templates/product--business_case_analysis.xml +1341 -0
  282. package/skills/lark-slides/assets/templates/product--market_analysis.xml +898 -0
  283. package/skills/lark-slides/assets/templates/product--product_analysis.xml +1537 -0
  284. package/skills/lark-slides/assets/templates/product--product_intro.xml +2838 -0
  285. package/skills/lark-slides/assets/templates/product--product_promotion.xml +687 -0
  286. package/skills/lark-slides/assets/templates/product--product_promotion_2.xml +687 -0
  287. package/skills/lark-slides/references/asset-planning.md +124 -0
  288. package/skills/lark-slides/references/examples.md +261 -0
  289. package/skills/lark-slides/references/iconpark-index.json +41901 -0
  290. package/skills/lark-slides/references/iconpark.md +46 -0
  291. package/skills/lark-slides/references/lark-slides-create.md +137 -0
  292. package/skills/lark-slides/references/lark-slides-edit-workflows.md +144 -0
  293. package/skills/lark-slides/references/lark-slides-media-upload.md +128 -0
  294. package/skills/lark-slides/references/lark-slides-replace-pages.md +95 -0
  295. package/skills/lark-slides/references/lark-slides-replace-slide.md +240 -0
  296. package/skills/lark-slides/references/lark-slides-screenshot.md +94 -0
  297. package/skills/lark-slides/references/lark-slides-whiteboard.md +330 -0
  298. package/skills/lark-slides/references/lark-slides-xml-presentation-slide-create.md +220 -0
  299. package/skills/lark-slides/references/lark-slides-xml-presentation-slide-delete.md +123 -0
  300. package/skills/lark-slides/references/lark-slides-xml-presentation-slide-get.md +110 -0
  301. package/skills/lark-slides/references/lark-slides-xml-presentation-slide-replace.md +187 -0
  302. package/skills/lark-slides/references/lark-slides-xml-presentations-get.md +98 -0
  303. package/skills/lark-slides/references/planning-layer.md +219 -0
  304. package/skills/lark-slides/references/slide-templates.md +201 -0
  305. package/skills/lark-slides/references/slides_demo.xml +226 -0
  306. package/skills/lark-slides/references/slides_xml_schema_definition.xml +3049 -0
  307. package/skills/lark-slides/references/template-catalog.md +463 -0
  308. package/skills/lark-slides/references/template-index.json +1853 -0
  309. package/skills/lark-slides/references/troubleshooting.md +63 -0
  310. package/skills/lark-slides/references/validation-checklist.md +110 -0
  311. package/skills/lark-slides/references/visual-planning.md +254 -0
  312. package/skills/lark-slides/references/xml-format-guide.md +369 -0
  313. package/skills/lark-slides/references/xml-schema-quick-ref.md +245 -0
  314. package/skills/lark-slides/scripts/iconpark_tool.py +362 -0
  315. package/skills/lark-slides/scripts/iconpark_tool_test.py +177 -0
  316. package/skills/lark-slides/scripts/template_tool.py +970 -0
  317. package/skills/lark-slides/scripts/template_tool_test.py +177 -0
  318. package/skills/lark-slides/scripts/xml_text_overlap_lint.py +367 -0
  319. package/skills/lark-slides/scripts/xml_text_overlap_lint_test.py +263 -0
  320. package/skills/lark-task/SKILL.md +167 -0
  321. package/skills/lark-task/references/lark-task-assign.md +38 -0
  322. package/skills/lark-task/references/lark-task-comment.md +28 -0
  323. package/skills/lark-task/references/lark-task-complete.md +27 -0
  324. package/skills/lark-task/references/lark-task-create.md +57 -0
  325. package/skills/lark-task/references/lark-task-followers.md +35 -0
  326. package/skills/lark-task/references/lark-task-get-my-tasks.md +61 -0
  327. package/skills/lark-task/references/lark-task-get-related-tasks.md +53 -0
  328. package/skills/lark-task/references/lark-task-reminder.md +36 -0
  329. package/skills/lark-task/references/lark-task-reopen.md +27 -0
  330. package/skills/lark-task/references/lark-task-search.md +41 -0
  331. package/skills/lark-task/references/lark-task-set-ancestor.md +32 -0
  332. package/skills/lark-task/references/lark-task-tasklist-create.md +35 -0
  333. package/skills/lark-task/references/lark-task-tasklist-members.md +36 -0
  334. package/skills/lark-task/references/lark-task-tasklist-search.md +38 -0
  335. package/skills/lark-task/references/lark-task-tasklist-task-add.md +38 -0
  336. package/skills/lark-task/references/lark-task-update.md +37 -0
  337. package/skills/lark-task/references/lark-task-upload-attachment.md +59 -0
  338. package/skills/lark-vc/SKILL.md +202 -0
  339. package/skills/lark-vc/references/lark-vc-detail.md +44 -0
  340. package/skills/lark-vc/references/lark-vc-recording.md +154 -0
  341. package/skills/lark-vc/references/lark-vc-search.md +163 -0
  342. package/skills/lark-vc/references/vc-domain-boundaries.md +188 -0
  343. package/skills/lark-vc-agent/SKILL.md +169 -0
  344. package/skills/lark-vc-agent/references/lark-vc-agent-meeting-events.md +287 -0
  345. package/skills/lark-vc-agent/references/lark-vc-agent-meeting-join.md +141 -0
  346. package/skills/lark-vc-agent/references/lark-vc-agent-meeting-leave.md +105 -0
  347. package/skills/lark-vc-agent/references/lark-vc-agent-meeting-list-active.md +91 -0
  348. package/skills/lark-whiteboard/SKILL.md +47 -0
  349. package/skills/lark-whiteboard/elements/connectors.md +102 -0
  350. package/skills/lark-whiteboard/elements/content.md +40 -0
  351. package/skills/lark-whiteboard/elements/image.md +80 -0
  352. package/skills/lark-whiteboard/elements/layout.md +374 -0
  353. package/skills/lark-whiteboard/elements/schema.md +357 -0
  354. package/skills/lark-whiteboard/elements/style.md +318 -0
  355. package/skills/lark-whiteboard/elements/typography.md +73 -0
  356. package/skills/lark-whiteboard/references/lark-whiteboard-query.md +60 -0
  357. package/skills/lark-whiteboard/references/lark-whiteboard-update.md +122 -0
  358. package/skills/lark-whiteboard/references/lark-whiteboard-workflow.md +94 -0
  359. package/skills/lark-whiteboard/routes/dsl.md +107 -0
  360. package/skills/lark-whiteboard/routes/mermaid.md +27 -0
  361. package/skills/lark-whiteboard/routes/svg-edit.md +85 -0
  362. package/skills/lark-whiteboard/routes/svg.md +54 -0
  363. package/skills/lark-whiteboard/scenes/architecture.md +433 -0
  364. package/skills/lark-whiteboard/scenes/bar-chart.md +187 -0
  365. package/skills/lark-whiteboard/scenes/comparison.md +135 -0
  366. package/skills/lark-whiteboard/scenes/fishbone.md +238 -0
  367. package/skills/lark-whiteboard/scenes/flowchart.md +185 -0
  368. package/skills/lark-whiteboard/scenes/flywheel.md +195 -0
  369. package/skills/lark-whiteboard/scenes/funnel.md +101 -0
  370. package/skills/lark-whiteboard/scenes/line-chart.md +214 -0
  371. package/skills/lark-whiteboard/scenes/mermaid.md +130 -0
  372. package/skills/lark-whiteboard/scenes/milestone.md +139 -0
  373. package/skills/lark-whiteboard/scenes/organization.md +173 -0
  374. package/skills/lark-whiteboard/scenes/photo-showcase.md +126 -0
  375. package/skills/lark-whiteboard/scenes/pyramid.md +99 -0
  376. package/skills/lark-whiteboard/scenes/swimlane.md +371 -0
  377. package/skills/lark-whiteboard/scenes/treemap.md +216 -0
  378. package/skills/lark-wiki/SKILL.md +110 -0
  379. package/skills/lark-wiki/references/lark-wiki-delete-space.md +205 -0
  380. package/skills/lark-wiki/references/lark-wiki-member-add.md +67 -0
  381. package/skills/lark-wiki/references/lark-wiki-member-list.md +76 -0
  382. package/skills/lark-wiki/references/lark-wiki-member-remove.md +61 -0
  383. package/skills/lark-wiki/references/lark-wiki-move.md +183 -0
  384. package/skills/lark-wiki/references/lark-wiki-node-copy.md +72 -0
  385. package/skills/lark-wiki/references/lark-wiki-node-create.md +127 -0
  386. package/skills/lark-wiki/references/lark-wiki-node-delete.md +62 -0
  387. package/skills/lark-wiki/references/lark-wiki-node-get.md +57 -0
  388. package/skills/lark-wiki/references/lark-wiki-node-list.md +88 -0
  389. package/skills/lark-wiki/references/lark-wiki-space-create.md +46 -0
  390. package/skills/lark-wiki/references/lark-wiki-space-list.md +68 -0
  391. package/skills/lark-workflow-meeting-summary/SKILL.md +122 -0
  392. package/skills/lark-workflow-standup-report/SKILL.md +122 -0
@@ -0,0 +1,830 @@
1
+ # Workflow guide
2
+
3
+ 本文档是 Workflow 的入口指南,帮助选择步骤组合、理解创建/更新边界,并引导到 steps JSON SSOT。
4
+
5
+ > **配套文档**:
6
+ > - Workflow 的数据结构参考:[lark-base-workflow-schema.md](lark-base-workflow-schema.md)
7
+ > - 创建/更新时重点构造 `title`、`status` 和 `steps`;复杂度集中在 `steps[].type/data/next`
8
+
9
+ ---
10
+
11
+ ## 快速开始
12
+
13
+ ### 最简单的 Workflow
14
+
15
+ 新增记录时发送消息通知:
16
+
17
+ ```json
18
+ {
19
+ "client_token": "1704067200",
20
+ "title": "新订单自动通知",
21
+ "steps": [
22
+ {
23
+ "id": "trigger_1",
24
+ "type": "AddRecordTrigger",
25
+ "title": "监控新订单",
26
+ "next": "action_1",
27
+ "data": {
28
+ "table_name": "订单表",
29
+ "watched_field_name": "订单号"
30
+ }
31
+ },
32
+ {
33
+ "id": "action_1",
34
+ "type": "LarkMessageAction",
35
+ "title": "发送通知",
36
+ "next": null,
37
+ "data": {
38
+ "receiver": [{ "value_type": "user", "value": {"id": "ou_xxxx", "name": "张三"} }],
39
+ "send_to_everyone": false,
40
+ "title": [{ "value_type": "text", "value": "新订单提醒" }],
41
+ "content": [
42
+ { "value_type": "text", "value": "收到新订单" }
43
+ ],
44
+ "btn_list": []
45
+ }
46
+ }
47
+ ]
48
+ }
49
+ ```
50
+
51
+ ---
52
+
53
+ ## 场景速查表
54
+
55
+ | 场景 | 步骤组合 | 示例 |
56
+ |------|---------|------|
57
+ | 新增触发+通知 | AddRecordTrigger → LarkMessageAction | [下方](#示例1-新增记录触发--发送消息) |
58
+ | 按钮点击+调用外部接口+写入日志 | ButtonTrigger → HTTPClientAction → AddRecordAction | [下方](#示例-6-按钮触发--调用外部接口--写入同步日志) |
59
+ | 定时+循环 | TimerTrigger → FindRecordAction → Loop → LarkMessageAction | [下方](#示例2-定时触发--查找记录--循环遍历--发送消息) |
60
+ | 条件判断 | ... → IfElseBranch → 分支处理 | [下方](#示例3-条件分支-ifelsebranch) |
61
+ | 多路分类 | ... → SwitchBranch → 多分支处理 | [下方](#示例4-多路分支-switchbranch) |
62
+ | 复杂组合 | 定时+查找+循环+分支+消息 | [下方](#示例5-组合场景-定时查找循环分支消息) |
63
+
64
+ ---
65
+
66
+ ## 完整示例
67
+
68
+ ### 示例 1: 新增记录触发 + 发送消息
69
+
70
+ **场景**: 当订单表新增记录时,发送飞书消息通知负责人。
71
+
72
+ ```json
73
+ {
74
+ "client_token": "1704067201",
75
+ "title": "新订单自动通知",
76
+ "steps": [
77
+ {
78
+ "id": "step_trigger",
79
+ "type": "AddRecordTrigger",
80
+ "title": "新增订单时触发",
81
+ "next": "step_notify",
82
+ "data": {
83
+ "table_name": "订单表",
84
+ "watched_field_name": "订单号",
85
+ "condition_list": null
86
+ }
87
+ },
88
+ {
89
+ "id": "step_notify",
90
+ "type": "LarkMessageAction",
91
+ "title": "发送订单通知",
92
+ "next": null,
93
+ "data": {
94
+ "receiver": [{ "value_type": "ref", "value": "$.step_trigger.fldManager" }],
95
+ "send_to_everyone": false,
96
+ "title": [{ "value_type": "text", "value": "新订单提醒" }],
97
+ "content": [
98
+ { "value_type": "text", "value": "客户 " },
99
+ { "value_type": "ref", "value": "$.step_trigger.fldCustomer" },
100
+ { "value_type": "text", "value": " 创建了新订单,金额:¥" },
101
+ { "value_type": "ref", "value": "$.step_trigger.fldAmount" }
102
+ ],
103
+ "btn_list": [
104
+ {
105
+ "text": "查看订单",
106
+ "btn_action": "openLink",
107
+ "link": [{ "value_type": "ref", "value": "$.step_trigger.recordLink" }]
108
+ }
109
+ ]
110
+ }
111
+ }
112
+ ]
113
+ }
114
+ ```
115
+
116
+ **关键点**:
117
+ - `AddRecordTrigger` 监控 `table_name` 表的 `watched_field_name` 字段
118
+ - 使用 `ref` 引用触发器输出的字段值(注意是 fieldId,不是字段名)
119
+ - `recordLink` 是触发器内置输出,表示记录链接
120
+
121
+ ---
122
+
123
+ ### 示例 2: 定时触发 + 查找记录 + 循环遍历 + 发送消息
124
+
125
+ **场景**: 每天早上 9 点,查找所有待处理订单,给每个客户发送提醒。
126
+
127
+ ```json
128
+ {
129
+ "client_token": "1704067202",
130
+ "title": "每日待处理订单提醒",
131
+ "steps": [
132
+ {
133
+ "id": "step_timer",
134
+ "type": "TimerTrigger",
135
+ "title": "每天早上9点触发",
136
+ "next": "step_find_orders",
137
+ "data": {
138
+ "rule": "DAILY",
139
+ "start_time": "2025-01-01 09:00",
140
+ "is_never_end": true
141
+ }
142
+ },
143
+ {
144
+ "id": "step_find_orders",
145
+ "type": "FindRecordAction",
146
+ "title": "查找所有待处理订单",
147
+ "next": "step_loop_customers",
148
+ "data": {
149
+ "table_name": "订单表",
150
+ "field_names": ["客户名称", "订单金额", "客户联系方式"],
151
+ "should_proceed_when_no_results": false,
152
+ "filter_info": {
153
+ "conjunction": "and",
154
+ "conditions": [
155
+ {
156
+ "field_name": "状态",
157
+ "operator": "is",
158
+ "value": [{ "value_type": "option", "value": { "name": "待处理" } }]
159
+ }
160
+ ]
161
+ }
162
+ }
163
+ },
164
+ {
165
+ "id": "step_loop_customers",
166
+ "type": "Loop",
167
+ "title": "遍历每个订单",
168
+ "children": {
169
+ "links": [
170
+ { "kind": "loop_start", "to": "step_send_reminder" }
171
+ ]
172
+ },
173
+ "next": null,
174
+ "data": {
175
+ "loop_mode": "continue",
176
+ "max_loop_times": 100,
177
+ "data": [{
178
+ "value_type": "ref",
179
+ "value": "$.step_find_orders.fieldRecords"
180
+ }]
181
+ }
182
+ },
183
+ {
184
+ "id": "step_send_reminder",
185
+ "type": "LarkMessageAction",
186
+ "title": "发送催办消息",
187
+ "next": null,
188
+ "data": {
189
+ "receiver": [{
190
+ "value_type": "ref",
191
+ "value": "$.step_loop_customers.item.fldContact"
192
+ }],
193
+ "send_to_everyone": false,
194
+ "title": [{ "value_type": "text", "value": "订单处理提醒" }],
195
+ "content": [
196
+ { "value_type": "text", "value": "您好,您的订单 " },
197
+ { "value_type": "ref", "value": "$.step_loop_customers.item.fldName" },
198
+ { "value_type": "text", "value": " 金额 ¥" },
199
+ { "value_type": "ref", "value": "$.step_loop_customers.item.fldAmount" },
200
+ { "value_type": "text", "value": " 正在处理中。" }
201
+ ],
202
+ "btn_list": []
203
+ }
204
+ }
205
+ ]
206
+ }
207
+ ```
208
+
209
+ **关键点**:
210
+ - `Loop.data` 必须传入 `ref` 类型的数据源(通常是 FindRecordAction 的 `fieldRecords`)
211
+ - `Loop.children.links` 必须包含 `kind: "loop_start"` 的链接指向循环体
212
+ - 循环体内用 `$.{loopStepId}.item.{fieldId}` 引用当前遍历记录的字段
213
+ - `$.{loopStepId}.index` 获取当前索引(从 0 开始)
214
+
215
+ ---
216
+
217
+ ### 示例 3: 条件分支(IfElseBranch)
218
+
219
+ **场景**: 根据订单金额判断,大额订单通知主管审批,小额订单自动通过。
220
+
221
+ ```json
222
+ {
223
+ "client_token": "1704067203",
224
+ "title": "订单金额自动判断",
225
+ "steps": [
226
+ {
227
+ "id": "step_trigger",
228
+ "type": "AddRecordTrigger",
229
+ "title": "新增订单时触发",
230
+ "next": "step_check_amount",
231
+ "data": {
232
+ "table_name": "订单表",
233
+ "watched_field_name": "订单金额"
234
+ }
235
+ },
236
+ {
237
+ "id": "step_check_amount",
238
+ "type": "IfElseBranch",
239
+ "title": "判断是否为大额订单",
240
+ "children": {
241
+ "links": [
242
+ { "kind": "if_true", "to": "step_notify_manager", "label": "high", "desc": "金额>=10000" },
243
+ { "kind": "if_false", "to": "step_auto_approve", "label": "normal", "desc": "金额<10000" }
244
+ ]
245
+ },
246
+ "next": "step_log",
247
+ "data": {
248
+ "condition": {
249
+ "conjunction": "or",
250
+ "conditions": [
251
+ {
252
+ "conjunction": "and",
253
+ "conditions": [
254
+ {
255
+ "left_value": { "value_type": "ref", "value": "$.step_trigger.fldAmount" },
256
+ "operator": "isGreaterEqual",
257
+ "right_value": [{ "value_type": "number", "value": 10000 }]
258
+ }
259
+ ]
260
+ }
261
+ ]
262
+ }
263
+ }
264
+ },
265
+ {
266
+ "id": "step_notify_manager",
267
+ "type": "LarkMessageAction",
268
+ "title": "通知主管审批大额订单",
269
+ "next": "step_log",
270
+ "data": {
271
+ "receiver": [{ "value_type": "user", "value": {"id": "ou_manager", "name": "主管"} }],
272
+ "send_to_everyone": false,
273
+ "title": [{ "value_type": "text", "value": "大额订单待审批" }],
274
+ "content": [
275
+ { "value_type": "text", "value": "有大额订单 ¥" },
276
+ { "value_type": "ref", "value": "$.step_trigger.fldAmount" },
277
+ { "value_type": "text", "value": " 需要您审批" }
278
+ ],
279
+ "btn_list": []
280
+ }
281
+ },
282
+ {
283
+ "id": "step_auto_approve",
284
+ "type": "SetRecordAction",
285
+ "title": "自动标记小额订单为已审核",
286
+ "next": "step_log",
287
+ "data": {
288
+ "table_name": "订单表",
289
+ "ref_info": { "step_id": "step_trigger" },
290
+ "field_values": [
291
+ {
292
+ "field_name": "审批状态",
293
+ "value": [{ "value_type": "option", "value": { "name": "已自动审核" } }]
294
+ }
295
+ ]
296
+ }
297
+ },
298
+ {
299
+ "id": "step_log",
300
+ "type": "GenerateAiTextAction",
301
+ "title": "生成订单处理日志",
302
+ "next": null,
303
+ "data": {
304
+ "prompt": [
305
+ { "value_type": "text", "value": "请生成订单处理日志,金额:" },
306
+ { "value_type": "ref", "value": "$.step_trigger.fldAmount" }
307
+ ]
308
+ }
309
+ }
310
+ ]
311
+ }
312
+ ```
313
+
314
+ **关键点**:
315
+ - `IfElseBranch.children.links` 必须包含 `if_true` 和 `if_false` 两个分支
316
+ - `next` 指向两个分支汇合后的步骤(可选,为 null 则分支结束)
317
+ - `condition` 使用 OrGroup 结构,支持 `(A and B) or (C and D)` 的复杂条件
318
+ - 分支内可以用 `ref_info` 引用触发记录,用 `filter_info` 批量筛选记录
319
+
320
+ ---
321
+
322
+ ### 示例 4: 多路分支(SwitchBranch)
323
+
324
+ **场景**: 根据订单优先级(P0/P1/P2)执行不同的处理流程。
325
+
326
+ ```json
327
+ {
328
+ "client_token": "1704067204",
329
+ "title": "按优先级分类处理订单",
330
+ "steps": [
331
+ {
332
+ "id": "step_trigger",
333
+ "type": "AddRecordTrigger",
334
+ "title": "新增订单时触发",
335
+ "next": "step_classify",
336
+ "data": {
337
+ "table_name": "订单表",
338
+ "watched_field_name": "优先级"
339
+ }
340
+ },
341
+ {
342
+ "id": "step_classify",
343
+ "type": "SwitchBranch",
344
+ "title": "按优先级分类",
345
+ "children": {
346
+ "links": [
347
+ { "kind": "case", "to": "step_p0_handler", "label": "p0", "desc": "P0-紧急" },
348
+ { "kind": "case", "to": "step_p1_handler", "label": "p1", "desc": "P1-高优先级" },
349
+ { "kind": "case", "to": "step_p2_handler", "label": "p2", "desc": "P2-普通" },
350
+ { "kind": "case", "to": "step_other_handler", "label": "other", "desc": "其他" }
351
+ ]
352
+ },
353
+ "next": null,
354
+ "data": {
355
+ "mode": "exclusive",
356
+ "no_match_action": "classifyToOther",
357
+ "child_branch_list": [
358
+ {
359
+ "name": "P0-紧急",
360
+ "condition": {
361
+ "conjunction": "or",
362
+ "conditions": [
363
+ {
364
+ "conjunction": "and",
365
+ "conditions": [
366
+ {
367
+ "left_value": { "value_type": "ref", "value": "$.step_trigger.fldPriority" },
368
+ "operator": "is",
369
+ "right_value": [{ "value_type": "option", "value": { "name": "P0" } }]
370
+ }
371
+ ]
372
+ }
373
+ ]
374
+ }
375
+ },
376
+ {
377
+ "name": "P1-高优先级",
378
+ "condition": {
379
+ "conjunction": "or",
380
+ "conditions": [
381
+ {
382
+ "conjunction": "and",
383
+ "conditions": [
384
+ {
385
+ "left_value": { "value_type": "ref", "value": "$.step_trigger.fldPriority" },
386
+ "operator": "is",
387
+ "right_value": [{ "value_type": "option", "value": { "name": "P1" } }]
388
+ }
389
+ ]
390
+ }
391
+ ]
392
+ }
393
+ },
394
+ {
395
+ "name": "P2-普通",
396
+ "condition": {
397
+ "conjunction": "or",
398
+ "conditions": [
399
+ {
400
+ "conjunction": "and",
401
+ "conditions": [
402
+ {
403
+ "left_value": { "value_type": "ref", "value": "$.step_trigger.fldPriority" },
404
+ "operator": "is",
405
+ "right_value": [{ "value_type": "option", "value": { "name": "P2" } }]
406
+ }
407
+ ]
408
+ }
409
+ ]
410
+ }
411
+ }
412
+ ]
413
+ }
414
+ },
415
+ {
416
+ "id": "step_p0_handler",
417
+ "type": "LarkMessageAction",
418
+ "title": "P0紧急处理",
419
+ "next": null,
420
+ "data": {
421
+ "receiver": [{ "value_type": "user", "value": {"id": "ou_director", "name": "总监"} }],
422
+ "send_to_everyone": false,
423
+ "title": [{ "value_type": "text", "value": "🚨 P0 紧急订单" }],
424
+ "content": [{ "value_type": "text", "value": "有新的 P0 紧急订单需要立即处理" }],
425
+ "btn_list": []
426
+ }
427
+ },
428
+ {
429
+ "id": "step_p1_handler",
430
+ "type": "SetRecordAction",
431
+ "title": "标记高优先级",
432
+ "next": null,
433
+ "data": {
434
+ "table_name": "订单表",
435
+ "ref_info": { "step_id": "step_trigger" },
436
+ "field_values": [
437
+ { "field_name": "处理状态", "value": [{ "value_type": "text", "value": "高优先级待处理" }] }
438
+ ]
439
+ }
440
+ },
441
+ {
442
+ "id": "step_p2_handler",
443
+ "type": "Delay",
444
+ "title": "普通订单延迟处理",
445
+ "next": null,
446
+ "data": { "duration": 60 }
447
+ },
448
+ {
449
+ "id": "step_other_handler",
450
+ "type": "SetRecordAction",
451
+ "title": "标记其他订单",
452
+ "next": null,
453
+ "data": {
454
+ "table_name": "订单表",
455
+ "ref_info": { "step_id": "step_trigger" },
456
+ "field_values": [
457
+ { "field_name": "处理状态", "value": [{ "value_type": "text", "value": "待分类" }] }
458
+ ]
459
+ }
460
+ }
461
+ ]
462
+ }
463
+ ```
464
+
465
+ **关键点**:
466
+ - `SwitchBranch` 适合 3 路及以上的分支场景(少于 3 路用 `IfElseBranch` 更简洁)
467
+ - `children.links` 中 `kind: "case"` 的 `label` 对应 `child_branch_list` 中的条件
468
+ - `mode: "exclusive"` 表示排他执行(第一个匹配的分支执行后停止)
469
+ - `no_match_action: "classifyToOther"` 表示无匹配时走最后一个 `case`(兜底分支)
470
+
471
+ ---
472
+
473
+ ### 示例 5: 组合场景(定时+查找+循环+分支+消息)
474
+
475
+ **场景**: 每天早上 9 点,查找昨天的订单,按金额分级,给不同级别的销售发送不同的通知。
476
+
477
+ ```json
478
+ {
479
+ "client_token": "1704067205",
480
+ "title": "每日订单分级通知",
481
+ "steps": [
482
+ {
483
+ "id": "step_timer",
484
+ "type": "TimerTrigger",
485
+ "title": "每天早上9点触发",
486
+ "next": "step_find_orders",
487
+ "data": {
488
+ "rule": "DAILY",
489
+ "start_time": "2025-01-01 09:00",
490
+ "is_never_end": true
491
+ }
492
+ },
493
+ {
494
+ "id": "step_find_orders",
495
+ "type": "FindRecordAction",
496
+ "title": "查找昨天所有订单",
497
+ "next": "step_loop",
498
+ "data": {
499
+ "table_name": "订单表",
500
+ "field_names": ["订单号", "客户名称", "金额", "销售负责人"],
501
+ "should_proceed_when_no_results": false,
502
+ "filter_info": {
503
+ "conjunction": "and",
504
+ "conditions": [
505
+ { "field_name": "创建时间", "operator": "isGreaterEqual", "value": [{ "value_type": "date", "value": "yesterday" }] }
506
+ ]
507
+ }
508
+ }
509
+ },
510
+ {
511
+ "id": "step_loop",
512
+ "type": "Loop",
513
+ "title": "遍历每个订单",
514
+ "children": {
515
+ "links": [
516
+ { "kind": "loop_start", "to": "step_classify" }
517
+ ]
518
+ },
519
+ "next": "step_summary",
520
+ "data": {
521
+ "loop_mode": "continue",
522
+ "max_loop_times": 500,
523
+ "data": [{ "value_type": "ref", "value": "$.step_find_orders.fieldRecords" }]
524
+ }
525
+ },
526
+ {
527
+ "id": "step_classify",
528
+ "type": "SwitchBranch",
529
+ "title": "按金额分类",
530
+ "children": {
531
+ "links": [
532
+ { "kind": "case", "to": "step_vip_notify", "label": "vip", "desc": "VIP >= 10万" },
533
+ { "kind": "case", "to": "step_normal_notify", "label": "normal", "desc": "普通 < 10万" }
534
+ ]
535
+ },
536
+ "next": null,
537
+ "data": {
538
+ "mode": "exclusive",
539
+ "no_match_action": "fail",
540
+ "child_branch_list": [
541
+ {
542
+ "name": "VIP订单",
543
+ "condition": {
544
+ "conjunction": "or",
545
+ "conditions": [
546
+ {
547
+ "conjunction": "and",
548
+ "conditions": [
549
+ {
550
+ "left_value": { "value_type": "ref", "value": "$.step_loop.item.fldAmount" },
551
+ "operator": "isGreaterEqual",
552
+ "right_value": [{ "value_type": "number", "value": 100000 }]
553
+ }
554
+ ]
555
+ }
556
+ ]
557
+ }
558
+ },
559
+ {
560
+ "name": "普通订单",
561
+ "condition": {
562
+ "conjunction": "or",
563
+ "conditions": [
564
+ {
565
+ "conjunction": "and",
566
+ "conditions": [
567
+ {
568
+ "left_value": { "value_type": "ref", "value": "$.step_loop.item.fldAmount" },
569
+ "operator": "isLess",
570
+ "right_value": [{ "value_type": "number", "value": 100000 }]
571
+ }
572
+ ]
573
+ }
574
+ ]
575
+ }
576
+ }
577
+ ]
578
+ }
579
+ },
580
+ {
581
+ "id": "step_vip_notify",
582
+ "type": "LarkMessageAction",
583
+ "title": "VIP订单通知",
584
+ "next": null,
585
+ "data": {
586
+ "receiver": [{ "value_type": "ref", "value": "$.step_loop.item.fldSales" }],
587
+ "send_to_everyone": false,
588
+ "title": [{ "value_type": "text", "value": "🌟 VIP大额订单" }],
589
+ "content": [
590
+ { "value_type": "text", "value": "恭喜!您有一笔 VIP 订单 ¥" },
591
+ { "value_type": "ref", "value": "$.step_loop.item.fldAmount" },
592
+ { "value_type": "text", "value": ",客户:" },
593
+ { "value_type": "ref", "value": "$.step_loop.item.fldCustomer" }
594
+ ],
595
+ "btn_list": []
596
+ }
597
+ },
598
+ {
599
+ "id": "step_normal_notify",
600
+ "type": "LarkMessageAction",
601
+ "title": "普通订单通知",
602
+ "next": null,
603
+ "data": {
604
+ "receiver": [{ "value_type": "ref", "value": "$.step_loop.item.fldSales" }],
605
+ "send_to_everyone": false,
606
+ "title": [{ "value_type": "text", "value": "新订单通知" }],
607
+ "content": [
608
+ { "value_type": "text", "value": "您有一笔新订单 ¥" },
609
+ { "value_type": "ref", "value": "$.step_loop.item.fldAmount" }
610
+ ],
611
+ "btn_list": []
612
+ }
613
+ },
614
+ {
615
+ "id": "step_summary",
616
+ "type": "GenerateAiTextAction",
617
+ "title": "生成日报",
618
+ "next": null,
619
+ "data": {
620
+ "prompt": [
621
+ { "value_type": "text", "value": "请生成昨日订单处理日报" }
622
+ ]
623
+ }
624
+ }
625
+ ]
626
+ }
627
+ ```
628
+
629
+ ---
630
+
631
+ ### 示例 6: 按钮触发 + 调用外部接口 + 写入同步日志
632
+
633
+ **场景**: 在「客户线索表」里给每条记录配置一个“同步到 CRM”按钮。销售点击按钮后,Workflow 调用外部 CRM 接口同步当前线索,再在「同步日志表」新增一条记录,方便后续审计和排查。
634
+
635
+ ```json
636
+ {
637
+ "client_token": "1704067206",
638
+ "title": "线索一键同步到 CRM",
639
+ "steps": [
640
+ {
641
+ "id": "step_button_trigger",
642
+ "type": "ButtonTrigger",
643
+ "title": "点击同步到 CRM 按钮时触发",
644
+ "next": "step_call_crm_api",
645
+ "data": {
646
+ "button_type": "buttonField",
647
+ "table_name": "客户线索表"
648
+ }
649
+ },
650
+ {
651
+ "id": "step_call_crm_api",
652
+ "type": "HTTPClientAction",
653
+ "title": "调用 CRM 同步接口",
654
+ "next": "step_add_sync_log",
655
+ "data": {
656
+ "method": "POST",
657
+ "url": [
658
+ { "value_type": "text", "value": "https://api.example-crm.com/v1/leads/sync" }
659
+ ],
660
+ "headers": [
661
+ { "key": "Content-Type", "value": [{ "value_type": "text", "value": "application/json" }] },
662
+ { "key": "X-System", "value": [{ "value_type": "text", "value": "lark_base_workflow" }] }
663
+ ],
664
+ "body_type": "raw",
665
+ "raw_body": [
666
+ { "value_type": "text", "value": "{\"lead_name\":\"" },
667
+ { "value_type": "ref", "value": "$.step_button_trigger.fldLeadName" },
668
+ { "value_type": "text", "value": "\",\"mobile\":\"" },
669
+ { "value_type": "ref", "value": "$.step_button_trigger.fldMobile" },
670
+ { "value_type": "text", "value": "\",\"company\":\"" },
671
+ { "value_type": "ref", "value": "$.step_button_trigger.fldCompany" },
672
+ { "value_type": "text", "value": "\",\"owner\":\"" },
673
+ { "value_type": "ref", "value": "$.step_button_trigger.fldOwner" },
674
+ { "value_type": "text", "value": "\",\"source_record_id\":\"" },
675
+ { "value_type": "ref", "value": "$.step_button_trigger.recordId" },
676
+ { "value_type": "text", "value": "\"}" }
677
+ ],
678
+ "response_type": "json",
679
+ "response_value": "{\"success\":true,\"message\":\"lead synced successfully\"}"
680
+ }
681
+ },
682
+ {
683
+ "id": "step_add_sync_log",
684
+ "type": "AddRecordAction",
685
+ "title": "写入同步日志",
686
+ "next": null,
687
+ "data": {
688
+ "table_name": "同步日志表",
689
+ "field_values": [
690
+ {
691
+ "field_name": "线索名称",
692
+ "value": [{ "value_type": "ref", "value": "$.step_button_trigger.fldLeadName" }]
693
+ },
694
+ {
695
+ "field_name": "手机号",
696
+ "value": [{ "value_type": "ref", "value": "$.step_button_trigger.fldMobile" }]
697
+ },
698
+ {
699
+ "field_name": "公司名称",
700
+ "value": [{ "value_type": "ref", "value": "$.step_button_trigger.fldCompany" }]
701
+ },
702
+ {
703
+ "field_name": "负责人",
704
+ "value": [{ "value_type": "ref", "value": "$.step_button_trigger.fldOwner" }]
705
+ },
706
+ {
707
+ "field_name": "来源记录ID",
708
+ "value": [{ "value_type": "ref", "value": "$.step_button_trigger.recordId" }]
709
+ },
710
+ {
711
+ "field_name": "同步状态",
712
+ "value": [{ "value_type": "text", "value": "已提交 CRM 同步" }]
713
+ },
714
+ {
715
+ "field_name": "同步是否成功",
716
+ "value": [{ "value_type": "ref", "value": "$.step_call_crm_api.body.success" }]
717
+ },
718
+ {
719
+ "field_name": "同步结果说明",
720
+ "value": [{ "value_type": "ref", "value": "$.step_call_crm_api.body.message" }]
721
+ },
722
+ {
723
+ "field_name": "备注",
724
+ "value": [{ "value_type": "text", "value": "由按钮触发自动发起同步请求" }]
725
+ }
726
+ ]
727
+ }
728
+ }
729
+ ]
730
+ }
731
+ ```
732
+
733
+ **关键点**:
734
+ - `ButtonTrigger` 适合“人工确认后再执行”的场景,比如同步 CRM、推送 ERP、发起审批等
735
+ - `button_type: "buttonField"` 表示按钮挂在记录上,因此可以直接引用当前记录的字段和值
736
+ - `HTTPClientAction.raw_body` 可以通过 `text + ref + text` 的方式动态拼接 JSON 请求体
737
+ - `HTTPClientAction` 的输出引用规则是:`response_type=none` 时不可引用;`response_type=text` 时只能用 `$.stepId` 引整个文本;`response_type=json` 时用 `$.stepId.body` 引整个 body、用 `$.stepId.body.字段名` 引 body 中字段,同时 `$.stepId.status_code` 表示 HTTP 返回状态码
738
+ - `HTTPClientAction.response_value` 中声明了哪些字段,后续节点就只能引用这些字段;例如 `$.step_call_crm_api.body.success`、`$.step_call_crm_api.body.message`
739
+ - `AddRecordAction` 常用于写日志表、操作审计表、同步结果表,便于追踪谁在什么时候触发了外部调用
740
+ - 示例里的 `fldLeadName` / `fldMobile` / `fldCompany` / `fldOwner` 只是占位的 fieldId,请以实际表字段 ID 为准
741
+
742
+ ---
743
+
744
+ ## 构造技巧
745
+
746
+ ### Loop 构造要点
747
+
748
+ 1. **数据源**: `Loop.data` 必须传入 `ref` 类型,通常是 `FindRecordAction` 的 `fieldRecords`
749
+ 2. **循环体**: `children.links` 必须包含 `kind: "loop_start"` 指向循环体入口
750
+ 3. **引用**: 循环体内用 `$.{loopStepId}.item.{fieldId}` 引用当前元素
751
+ 4. **索引**: 用 `$.{loopStepId}.index` 获取当前索引(从 0 开始)
752
+
753
+ ### 分支构造要点
754
+
755
+ 1. **IfElseBranch**:
756
+ - 适合二元判断(是/否、大于/小于)
757
+ - `children.links` 必须包含 `if_true` 和 `if_false`
758
+ - 可以用 `next` 指向汇合点
759
+
760
+ 2. **SwitchBranch**:
761
+ - 适合多路分类(3路及以上)
762
+ - `label` 对应 `child_branch_list` 中的条件顺序
763
+ - 建议加一个兜底分支(其他)
764
+
765
+ ### 字段值构造
766
+
767
+ | 字段类型 | value_type | 示例 |
768
+ |---------|------------|------|
769
+ | 文本 | `text` | `{"value_type": "text", "value": "张三"}` |
770
+ | 数字 | `number` | `{"value_type": "number", "value": 100}` |
771
+ | 单选 | `option` | `{"value_type": "option", "value": {"name": "已完成"}}` |
772
+ | 人员 | `user` | `{"value_type": "user", "value": {"id": "ou_xxxx"}}` |
773
+ | 引用 | `ref` | `{"value_type": "ref", "value": "$.step_1.fldxxx"}` |
774
+
775
+ ---
776
+
777
+ ## 常见错误避免
778
+
779
+ ### Top 10 高频错误
780
+
781
+ | # | 错误信息 | 原因 | 解决方案 |
782
+ |---|---------|------|---------|
783
+ | 1 | `path "xxx" does not exist in the output path tree` | ref 引用路径错误或 stepId 不存在 | 检查 stepId 是否在 steps 数组中;使用 fieldId 而非字段名;确保路径以 `$.` 开头 |
784
+ | 2 | `recordInfo.conditions must be non-empty` | `condition_list` 为空数组 `[]` | 改用 `null` 或省略该字段 |
785
+ | 3 | `At least one of filter info and ref info is required` | SetRecordAction/FindRecordAction 缺少定位条件 | 必须提供 `filter_info` 或 `ref_info` 之一 |
786
+ | 4 | `client token is empty` | 缺少 `client_token` | 每次请求传入唯一值(时间戳或随机字符串) |
787
+ | 5 | `valueType 'text' not allowed for fieldType '3'` | select 类型字段值格式错误 | 改用 `option` 类型 |
788
+ | 6 | `Undefined Step Type` | 使用了不支持的 StepType | 使用 `AddRecordTrigger` 而非 `CreateRecordTrigger` |
789
+ | 7 | `prompt references an unknown reference from step` | 引用的 stepId 不存在 | 确保引用的 step 在同一 workflow 的 steps 数组中 |
790
+ | 8 | `[2200] Internal Error` | 1. steps[].id 重复 2. next/children.links 引用了不存在的 step | 确保所有 step id 唯一;检查引用关系 |
791
+ | 9 | 工作流结构不完整 | Branch/Loop 节点缺少 `children` | 仅 Branch(IfElseBranch/SwitchBranch)和 Loop 节点需要 `children`,Trigger/Action 节点无需设置 |
792
+ | 10 | 嵌套分支过于复杂 | 多层 IfElseBranch 嵌套 | 3+ 路分支用 SwitchBranch 替代嵌套 IfElseBranch |
793
+
794
+ ### 其他常见错误
795
+
796
+ **1. condition_list 为空数组**
797
+ ```json
798
+ // ❌ 错误
799
+ { "condition_list": [] }
800
+
801
+ // ✅ 正确
802
+ { "condition_list": null }
803
+ // 或省略该字段
804
+ ```
805
+
806
+ **2. filter_info 和 ref_info 同时提供**
807
+ ```json
808
+ // ❌ 错误
809
+ { "filter_info": {...}, "ref_info": {...} }
810
+
811
+ // ✅ 正确(二选一)
812
+ { "filter_info": {...}, "ref_info": null }
813
+ { "filter_info": null, "ref_info": {...} }
814
+ ```
815
+
816
+ **3. 使用字段名而非 fieldId**
817
+ ```json
818
+ // ❌ 错误
819
+ { "value": "$.step_1.客户名称" }
820
+
821
+ // ✅ 正确
822
+ { "value": "$.step_1.fldXXXXXXXX" }
823
+ ```
824
+
825
+ ---
826
+
827
+ ## 参考
828
+
829
+ - [lark-base-workflow-schema.md](lark-base-workflow-schema.md) — 字段定义参考
830
+ - 创建/更新前先确认真实表名、字段名和目标 workflow ID;`steps` 结构按 schema 构造,不凭自然语言猜 `type`