generate-workflow-diagram
关于
This skill generates themed Mermaid flowchart diagrams from putior workflow data. It offers multiple themes, output formats, and interactive features for embedding in documentation. Use it to create or update visual workflow diagrams after annotating source files or when you need to change themes for different audiences.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/generate-workflow-diagram在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
生工作流程圖
自 putior 工作流程資料生帶主題之 Mermaid 流程圖並嵌於文件。
適用時機
- 已註源檔後欲產視覺圖
- 工作流程變更後重生圖
- 為不同讀者換主題或輸出格式
- 於 README、Quarto 或 R Markdown 中嵌工作流程圖
輸入
- 必要:
put()、put_auto()或put_merge()之工作流程資料 - 選擇性:主題名(預設:
"light";選項:light、dark、auto、minimal、github、viridis、magma、plasma、cividis) - 選擇性:輸出目標:主控台、檔案路徑、剪貼簿或原始字串
- 選擇性:互動特徵:
show_source_info、enable_clicks
步驟
步驟一:提取工作流程資料
自三源之一取工作流程資料。
library(putior)
# 自手動註解
workflow <- put("./src/")
# 自手動註解,排除特定檔
workflow <- put("./src/", exclude = c("build-workflow\\.R$", "test_"))
# 僅自動偵測
workflow <- put_auto("./src/")
# 合併(手動 + 自動)
workflow <- put_merge("./src/", merge_strategy = "supplement")
工作流程資料框可含自註解而來之 node_type 欄。節點類型控 Mermaid 形狀:
node_type | Mermaid 形狀 | 用例 |
|---|---|---|
"input" | 體育場 ([...]) | 資料源、配置檔 |
"output" | 子程序 [[...]] | 生成工件、報告 |
"process" | 矩形 [...] | 處理步驟(預設) |
"decision" | 菱形 {...} | 條件邏輯、分支 |
"start" / "end" | 體育場 ([...]) | 入/終節點 |
每 node_type 亦得對應 CSS 類(如 class nodeId input;)以供主題式樣設。
預期: 資料框至少一列,含 id、label 及可選 input、output、source_file、node_type 欄。
失敗時: 若資料框空,則無註解或模式得。先執行 analyze-codebase-workflow,或以 put("./src/", validate = TRUE) 核註解語法有效。
步驟二:擇主題與選項
擇合目標讀者之主題。
# 列所有可用主題
get_diagram_themes()
# 標準主題
# "light" — 預設,明色
# "dark" — 暗模式環境
# "auto" — GitHub 自適應實色
# "minimal" — 灰階,宜列印
# "github" — 為 GitHub README 優化
# 色盲安全主題(viridis 家族)
# "viridis" — 紫→藍→綠→黃,通用可及性
# "magma" — 紫→紅→黃,列印高對比
# "plasma" — 紫→粉→橙→黃,簡報
# "cividis" — 藍→灰→黃,最大可及性(無紅綠)
附加參數:
direction:圖流向——"TD"(上下,預設)、"LR"(左右)、"RL"、"BT"show_artifacts:TRUE/FALSE——示工件節點(檔、資料);大工作流程可吵(如十六加附加節點)show_workflow_boundaries:TRUE/FALSE——於 Mermaid 子圖中包每源檔之節點source_info_style:源檔資訊於節點上之顯示法(如副標)node_labels:節點標籤文字之格式
預期: 主題名印出。依情境擇一。
失敗時: 若主題名未識,put_diagram() 退至 "light"。核拼字。
步驟三:以 put_theme() 自訂調色盤(選擇性)
若九內建主題不配專案調色盤,以 put_theme() 建自訂主題。
# 建自訂調色盤——未指定類型繼承自基主題
cyberpunk <- put_theme(
base = "dark",
input = c(fill = "#1a1a2e", stroke = "#00ff88", color = "#00ff88"),
process = c(fill = "#16213e", stroke = "#44ddff", color = "#44ddff"),
output = c(fill = "#0f3460", stroke = "#ff3366", color = "#ff3366"),
decision = c(fill = "#1a1a2e", stroke = "#ffaa33", color = "#ffaa33")
)
# 用 palette 參數(覆蓋 theme)
mermaid_content <- put_diagram(workflow, palette = cyberpunk, output = "raw")
writeLines(mermaid_content, "workflow.mmd")
put_theme() 接受 input、process、output、decision、artifact、start、end 節點類型。各取具名向量 c(fill = "#hex", stroke = "#hex", color = "#hex")。未設類型繼承自 base 主題。
預期: Mermaid 輸出含自訂 classDef 行。自 node_type 之節點形狀保留;僅色變。所有節點類型用 stroke-width:2px——put_theme() 目前不支援覆寫。
失敗時: 若調色盤物件非 putior_theme 類,put_diagram() 引描述性錯。確傳 put_theme() 之返回值,非原始列表。
退路——手動 classDef 替換: 為超越 put_theme() 之細粒度控制(如每類型筆寬),以基主題生成並手動替換 classDef 行:
mermaid_content <- put_diagram(workflow, theme = "dark", output = "raw")
lines <- strsplit(mermaid_content, "\n")[[1]]
lines <- lines[!grepl("^\\s*classDef ", lines)]
custom_defs <- c(" classDef input fill:#1a1a2e,stroke:#00ff88,stroke-width:3px,color:#00ff88")
mermaid_content <- paste(c(lines, custom_defs), collapse = "\n")
步驟四:生 Mermaid 輸出
以所欲輸出模式產圖。
# 印至主控台(預設)
cat(put_diagram(workflow, theme = "github"))
# 存至檔
writeLines(put_diagram(workflow, theme = "github"), "docs/workflow.md")
# 取原始字串以嵌入
mermaid_code <- put_diagram(workflow, output = "raw", theme = "github")
# 附源檔資訊(示每節點來自何檔)
cat(put_diagram(workflow, theme = "github", show_source_info = TRUE))
# 附可點節點(VS Code、RStudio 或 file:// 協定)
cat(put_diagram(workflow,
theme = "github",
enable_clicks = TRUE,
click_protocol = "vscode" # 或 "rstudio"、"file"
))
# 全特徵
cat(put_diagram(workflow,
theme = "viridis",
show_source_info = TRUE,
enable_clicks = TRUE,
click_protocol = "vscode"
))
預期: 有效 Mermaid 代碼以 flowchart TD(或依方向之 LR)始。節點以箭頭示資料流連。
失敗時: 若輸出為 flowchart TD 無節點,工作流程資料框空。若連結缺,核輸出檔名於節點間配合輸入檔名。
步驟五:嵌於目標文件
將圖插入合宜文件格式。
GitHub README(```mermaid 代碼圍欄):
## Workflow
```mermaid
flowchart TD
A["Extract Data"] --> B["Transform"]
B --> C["Load"]
```
Quarto 文件(經 knit_child 之原生 mermaid 段):
# 段一:生代碼(可見、可摺)
workflow <- put("./src/")
mermaid_code <- put_diagram(workflow, output = "raw", theme = "github")
# 段二:輸出為原生 mermaid 段(隱藏)
#| output: asis
#| echo: false
mermaid_chunk <- paste0("```{mermaid}\n", mermaid_code, "\n```")
cat(knitr::knit_child(text = mermaid_chunk, quiet = TRUE))
R Markdown(以 mermaid.js CDN 或 DiagrammeR):
DiagrammeR::mermaid(put_diagram(workflow, output = "raw"))
預期: 圖於目標格式正確渲染。GitHub 原生渲染 mermaid 代碼圍欄。
失敗時: 若 GitHub 不渲染圖,確代碼圍欄用確切 ```mermaid(無附屬)。Quarto 須用 knit_child() 法,因 {mermaid} 段中直接變數插值不支援。
驗證
-
put_diagram()產有效 Mermaid 代碼(以flowchart始) - 所有預期節點現於圖
- 已連節點間有資料流連結(箭頭)
- 所擇主題已施(核輸出之 init 區塊主題專屬色)
- 圖於目標格式(GitHub、Quarto 等)正確渲染
常見陷阱
- 空圖:通常示
put()返回無列。核註解存且語法有效。 - 所有節點脫離:輸出檔名須確配輸入檔名(含副檔名)putior 方能繪連結。
data.csv與Data.csv為不同。 - GitHub 上主題不可見:GitHub 之 mermaid 渲染器主題支援有限。
"github"主題為 GitHub 渲染所特別設計。%%{init:...}%%主題區塊恐為部分渲染器忽略。 - Quarto mermaid 變數插值:Quarto 之
{mermaid}段不支援 R 變數直接。用步驟五所述knit_child()技法。 - 可點節點不工作:點擊指令需支援 Mermaid 互動事件之渲染器。GitHub 之靜態渲染器不支援點擊。用本地 Mermaid 渲染器或 putior Shiny 沙箱。
- 自參考元管線檔:掃含生圖之建置腳本之目錄致重複子圖 ID 與 Mermaid 錯。用
exclude參數於掃描時略之:workflow <- put("./src/", exclude = c("build-workflow\\.R$", "build-workflow\\.js$")) show_artifacts = TRUE過吵:大專案可生多工件節點(十至二十加),雜亂圖。用show_artifacts = FALSE並賴node_type註解明標關鍵輸入/輸出。
相關技能
annotate-source-files— 前提:生圖前檔須已註analyze-codebase-workflow— 自動偵測可補手動註解setup-putior-ci— 於 CI/CD 中自動重生圖create-quarto-report— 於 Quarto 報告中嵌圖build-pkgdown-site— 於 pkgdown 文件站中嵌圖
GitHub 仓库
相关推荐技能
content-collections
元Content Collections 是一个 TypeScript 优先的构建工具,可将本地 Markdown/MDX 文件转换为类型安全的数据集合。它专为构建博客、文档站和内容密集型 Vite+React 应用而设计,提供基于 Zod 的自动模式验证。该工具涵盖从 Vite 插件配置、MDX 编译到生产环境部署的完整工作流。
polymarket
元这个Claude Skill为开发者提供完整的Polymarket预测市场开发支持,涵盖API调用、交易执行和市场数据分析。关键特性包括实时WebSocket数据流,可监控实时交易、订单和市场动态。开发者可用它构建预测市场应用、实施交易策略并集成实时市场预测功能。
creating-opencode-plugins
元该Skill帮助开发者创建OpenCode插件,用于接入命令、文件、LSP等25+种事件。它提供了插件结构、事件API规范和JavaScript/TypeScript实现模式,适合需要拦截操作、扩展功能或自定义事件处理的场景。开发者可通过它快速构建响应式模块来增强OpenCode AI助手的能力。
sglang
元SGLang是一个专为LLM设计的高性能推理框架,特别适用于需要结构化输出的场景。它通过RadixAttention前缀缓存技术,在处理JSON、正则表达式、工具调用等具有重复前缀的复杂工作流时,能实现极速生成。如果你正在构建智能体或多轮对话系统,并追求远超vLLM的推理性能,SGLang是理想选择。
