flowbook 0.1.4 → 0.1.6

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.
package/README.ru.md DELETED
@@ -1,220 +0,0 @@
1
- # Flowbook
2
-
3
- > [English](./README.md) | [한국어](./README.ko.md) | [简体中文](./README.zh-CN.md) | [日本語](./README.ja.md) | [Español](./README.es.md) | [Português (BR)](./README.pt-BR.md) | [Français](./README.fr.md) | **Русский** | [Deutsch](./README.de.md)
4
-
5
- Storybook для блок-схем. Автоматически обнаруживает файлы диаграмм Mermaid в вашем коде, организует их по категориям и отображает в удобном просмотрщике.
6
-
7
- ![Vite](https://img.shields.io/badge/vite-6.x-646CFF?logo=vite&logoColor=white)
8
- ![React](https://img.shields.io/badge/react-19.x-61DAFB?logo=react&logoColor=white)
9
- ![Mermaid](https://img.shields.io/badge/mermaid-11.x-FF3670?logo=mermaid&logoColor=white)
10
- ![TypeScript](https://img.shields.io/badge/typescript-5.x-3178C6?logo=typescript&logoColor=white)
11
-
12
- ## Быстрый Старт
13
-
14
- ```bash
15
- # Инициализация — добавляет скрипты + файл-пример
16
- npx flowbook@latest init
17
-
18
- # Запуск сервера разработки
19
- npm run flowbook
20
- # → http://localhost:6200
21
-
22
- # Сборка статического сайта
23
- npm run build-flowbook
24
- # → flowbook-static/
25
- ```
26
-
27
- ## CLI
28
-
29
- ```
30
- flowbook init Настроить Flowbook в проекте
31
- flowbook dev [--port 6200] Запустить сервер разработки
32
- flowbook build [--out-dir d] Собрать статический сайт
33
- ```
34
-
35
- ### `flowbook init`
36
-
37
- - Добавляет скрипты `"flowbook"` и `"build-flowbook"` в ваш `package.json`
38
- - Создаёт `flows/example.flow.md` в качестве стартового шаблона
39
-
40
- ### `flowbook dev`
41
-
42
- Запускает сервер разработки Vite на `http://localhost:6200` с поддержкой HMR. Любые изменения в файлах `.flow.md` или `.flowchart.md` отображаются мгновенно.
43
-
44
- ### `flowbook build`
45
-
46
- Собирает статический сайт в `flowbook-static/` (настраивается через `--out-dir`). Разверните его где угодно.
47
-
48
- ## Создание Файлов Потоков
49
-
50
- Создайте файл `.flow.md` (или `.flowchart.md`) в любом месте вашего проекта:
51
-
52
- ````markdown
53
- ---
54
- title: Поток Авторизации
55
- category: Аутентификация
56
- tags: [auth, login, oauth]
57
- order: 1
58
- description: Поток аутентификации пользователя с OAuth2
59
- ---
60
-
61
- ```mermaid
62
- flowchart TD
63
- A[Пользователь] --> B{Авторизован?}
64
- B -->|Да| C[Панель управления]
65
- B -->|Нет| D[Страница входа]
66
- ```
67
- ````
68
-
69
- Flowbook автоматически обнаружит файл и добавит его в просмотрщик.
70
-
71
- ## Схема Frontmatter
72
-
73
- | Поле | Тип | Обязательно | Описание |
74
- |---------------|------------|-------------|---------------------------------------|
75
- | `title` | `string` | Нет | Отображаемый заголовок (по умолчанию: имя файла) |
76
- | `category` | `string` | Нет | Категория в боковой панели (по умолчанию: "Uncategorized") |
77
- | `tags` | `string[]` | Нет | Фильтруемые теги |
78
- | `order` | `number` | Нет | Порядок сортировки в категории (по умолчанию: 999) |
79
- | `description` | `string` | Нет | Описание в детальном просмотре |
80
-
81
- ## Обнаружение Файлов
82
-
83
- Flowbook по умолчанию сканирует следующие шаблоны:
84
-
85
- ```
86
- **/*.flow.md
87
- **/*.flowchart.md
88
- ```
89
-
90
- Игнорирует `node_modules/`, `.git/` и `dist/`.
91
-
92
- ## Навык AI-агента
93
-
94
- `flowbook init` автоматически устанавливает навыки AI-агента во все поддерживаемые директории агентов кодирования.
95
- Когда агент кодирования (Claude Code, OpenAI Codex, VS Code Copilot, Cursor, Gemini CLI и т.д.) обнаружит ключевое слово **"flowbook"** в вашем промпте, он:
96
-
97
- 1. Анализирует вашу базу кода на предмет логических потоков (API маршруты, аутентификация, управление состоянием, бизнес-логика и т.д.)
98
- 2. Настраивает Flowbook, если он еще не инициализирован
99
- 3. Генерирует файлы `.flow.md` с диаграммами Mermaid для каждого значимого потока
100
- 4. Проверяет сборку
101
-
102
- ### Установка навыка через CLI
103
-
104
- Вы также можете установить навык отдельно с помощью [skills.sh](https://skills.sh):
105
-
106
- ```bash
107
- npx skills add Epsilondelta-ai/flowbook
108
- ```
109
-
110
- Автоматически определяет установленные агенты кодирования и устанавливает навык в нужные директории.
111
-
112
- ### Совместимые агенты
113
-
114
- | Агент | Местонахождение навыка |
115
- |-------|---------------|
116
- | Claude Code | `.claude/skills/flowbook/SKILL.md` |
117
- | OpenAI Codex | `.agents/skills/flowbook/SKILL.md` |
118
- | VS Code / GitHub Copilot | `.github/skills/flowbook/SKILL.md` |
119
- | Google Antigravity | `.agent/skills/flowbook/SKILL.md` |
120
- | Gemini CLI | `.gemini/skills/flowbook/SKILL.md` |
121
- | Cursor | `.cursor/skills/flowbook/SKILL.md` |
122
- | Windsurf (Codeium) | `.windsurf/skills/flowbook/SKILL.md` |
123
- | AmpCode | `.amp/skills/flowbook/SKILL.md` |
124
- | OpenCode / oh-my-opencode | `.opencode/skills/flowbook/SKILL.md` |
125
-
126
- <details>
127
- <summary>Ручная установка навыка</summary>
128
-
129
- Если вы не использовали `flowbook init` или `npx skills add`, скопируйте навык вручную:
130
-
131
- ```bash
132
- # Пример: Claude Code
133
- mkdir -p .claude/skills/flowbook
134
- cp node_modules/flowbook/src/skills/flowbook/SKILL.md .claude/skills/flowbook/
135
-
136
- # Пример: Cursor
137
- mkdir -p .cursor/skills/flowbook
138
- cp node_modules/flowbook/src/skills/flowbook/SKILL.md .cursor/skills/flowbook/
139
- ```
140
-
141
- Замените директорию на подходящий путь из таблицы совместимых агентов.
142
-
143
- </details>
144
- ## Как Это Работает
145
-
146
- ```
147
- файлы .flow.md ──→ Плагин Vite ──→ Виртуальный модуль ──→ React-просмотрщик
148
- │ │
149
- ├─ сканирование ├─ export default { flows: [...] }
150
- │ fast-glob │
151
- ├─ gray-matter └─ HMR при изменении файла
152
- │ парсинг
153
- └─ блок mermaid
154
- извлечение
155
- ```
156
-
157
- 1. **Обнаружение** — `fast-glob` сканирует проект в поисках `*.flow.md` / `*.flowchart.md`
158
- 2. **Парсинг** — `gray-matter` извлекает YAML frontmatter; регулярные выражения извлекают блоки `` ```mermaid ``
159
- 3. **Виртуальный модуль** — Плагин Vite предоставляет распарсенные данные как `virtual:flowbook-data`
160
- 4. **Рендеринг** — React-приложение рендерит диаграммы Mermaid через `mermaid.render()`
161
- 5. **HMR** — Изменения файлов инвалидируют виртуальный модуль, запуская перезагрузку
162
-
163
- ## Структура Проекта
164
-
165
- ```
166
- src/
167
- ├── types.ts # Общие типы (FlowEntry, FlowbookData)
168
- ├── node/
169
- │ ├── cli.ts # Точка входа CLI (init, dev, build)
170
- │ ├── server.ts # Программный сервер Vite и сборка
171
- │ ├── init.ts # Логика инициализации проекта
172
- │ ├── discovery.ts # Сканер файлов (fast-glob)
173
- │ ├── parser.ts # Извлечение frontmatter + mermaid
174
- │ └── plugin.ts # Плагин виртуального модуля Vite
175
- └── client/
176
- ├── index.html # Входной HTML
177
- ├── main.tsx # Точка входа React
178
- ├── App.tsx # Макет с поиском + боковая панель + просмотрщик
179
- ├── vite-env.d.ts # Объявления типов виртуального модуля
180
- ├── styles/globals.css # Tailwind v4 + пользовательские стили
181
- └── components/
182
- ├── Header.tsx # Логотип, поиск, количество потоков
183
- ├── Sidebar.tsx # Сворачиваемое дерево категорий
184
- ├── MermaidRenderer.tsx # Рендеринг диаграмм Mermaid
185
- ├── FlowView.tsx # Детальный просмотр отдельного потока
186
- └── EmptyState.tsx # Пустое состояние с инструкцией
187
- ```
188
-
189
- ## Разработка (Вклад)
190
-
191
- ```bash
192
- git clone https://github.com/Epsilondelta-ai/flowbook.git
193
- cd flowbook
194
- npm install
195
-
196
- # Локальная разработка (используется корневой vite.config.ts)
197
- npm run dev
198
-
199
- # Сборка CLI
200
- npm run build
201
-
202
- # Локальное тестирование CLI
203
- node dist/cli.js dev
204
- node dist/cli.js build
205
- ```
206
-
207
- ## Технологический Стек
208
-
209
- - **Vite** — Сервер разработки с HMR
210
- - **React 19** — Пользовательский интерфейс
211
- - **Mermaid 11** — Рендеринг диаграмм
212
- - **Tailwind CSS v4** — Стилизация
213
- - **gray-matter** — Парсинг YAML frontmatter
214
- - **fast-glob** — Обнаружение файлов
215
- - **tsup** — Сборщик CLI
216
- - **TypeScript** — Типобезопасность
217
-
218
- ## Лицензия
219
-
220
- MIT
package/README.zh-CN.md DELETED
@@ -1,219 +0,0 @@
1
- # Flowbook
2
-
3
- > [English](./README.md) | [한국어](./README.ko.md) | **简体中文** | [日本語](./README.ja.md) | [Español](./README.es.md) | [Português (BR)](./README.pt-BR.md) | [Français](./README.fr.md) | [Русский](./README.ru.md) | [Deutsch](./README.de.md)
4
-
5
- 流程图的 Storybook。自动发现代码库中的 Mermaid 图表文件,按类别组织,并在可浏览的查看器中渲染。
6
-
7
- ![Vite](https://img.shields.io/badge/vite-6.x-646CFF?logo=vite&logoColor=white)
8
- ![React](https://img.shields.io/badge/react-19.x-61DAFB?logo=react&logoColor=white)
9
- ![Mermaid](https://img.shields.io/badge/mermaid-11.x-FF3670?logo=mermaid&logoColor=white)
10
- ![TypeScript](https://img.shields.io/badge/typescript-5.x-3178C6?logo=typescript&logoColor=white)
11
-
12
- ## 快速开始
13
-
14
- ```bash
15
- # 初始化 — 添加脚本 + 示例文件
16
- npx flowbook@latest init
17
-
18
- # 启动开发服务器
19
- npm run flowbook
20
- # → http://localhost:6200
21
-
22
- # 构建静态站点
23
- npm run build-flowbook
24
- # → flowbook-static/
25
- ```
26
-
27
- ## CLI
28
-
29
- ```
30
- flowbook init 在项目中设置 Flowbook
31
- flowbook dev [--port 6200] 启动开发服务器
32
- flowbook build [--out-dir d] 构建静态站点
33
- ```
34
-
35
- ### `flowbook init`
36
-
37
- - 在 `package.json` 中添加 `"flowbook"` 和 `"build-flowbook"` 脚本
38
- - 创建 `flows/example.flow.md` 作为入门模板
39
-
40
- ### `flowbook dev`
41
-
42
- 在 `http://localhost:6200` 启动支持 HMR 的 Vite 开发服务器。任何 `.flow.md` 或 `.flowchart.md` 文件的更改都会即时生效。
43
-
44
- ### `flowbook build`
45
-
46
- 将静态站点构建到 `flowbook-static/` 目录(可通过 `--out-dir` 配置)。可部署到任何地方。
47
-
48
- ## 编写流程文件
49
-
50
- 在项目中任意位置创建 `.flow.md`(或 `.flowchart.md`)文件:
51
-
52
- ````markdown
53
- ---
54
- title: 登录流程
55
- category: 认证
56
- tags: [auth, login, oauth]
57
- order: 1
58
- description: 使用 OAuth2 的用户认证流程
59
- ---
60
-
61
- ```mermaid
62
- flowchart TD
63
- A[用户] --> B{已认证?}
64
- B -->|是| C[仪表盘]
65
- B -->|否| D[登录页面]
66
- ```
67
- ````
68
-
69
- Flowbook 会自动发现文件并将其添加到查看器中。
70
-
71
- ## Frontmatter 模式
72
-
73
- | 字段 | 类型 | 必填 | 说明 |
74
- |---------------|------------|------|-------------------------------------|
75
- | `title` | `string` | 否 | 显示标题(默认为文件名) |
76
- | `category` | `string` | 否 | 侧边栏分类(默认为 "Uncategorized")|
77
- | `tags` | `string[]` | 否 | 可筛选的标签 |
78
- | `order` | `number` | 否 | 分类内排序(默认:999) |
79
- | `description` | `string` | 否 | 详情视图中显示的描述 |
80
-
81
- ## 文件发现
82
-
83
- Flowbook 默认扫描以下模式:
84
-
85
- ```
86
- **/*.flow.md
87
- **/*.flowchart.md
88
- ```
89
-
90
- 忽略 `node_modules/`、`.git/` 和 `dist/`。
91
-
92
- ## AI Agent Skill
93
-
94
- `flowbook init` 自动将 AI 代理技能安装到所有支持的编码代理目录中。
95
- 当编码代理(Claude Code、OpenAI Codex、VS Code Copilot、Cursor、Gemini CLI 等)检测到你的提示中有 **"flowbook"** 关键字时,它会:
96
-
97
- 1. 分析你的代码库中的逻辑流(API 路由、认证、状态管理、业务逻辑等)
98
- 2. 如果尚未初始化,设置 Flowbook
99
- 3. 为每个重要流程生成包含 Mermaid 图表的 `.flow.md` 文件
100
- 4. 验证构建
101
-
102
- ### 通过 CLI 安装技能
103
-
104
- 你也可以使用 [skills.sh](https://skills.sh) 独立安装技能:
105
-
106
- ```bash
107
- npx skills add Epsilondelta-ai/flowbook
108
- ```
109
-
110
- 自动检测已安装的编码代理并将技能安装到正确的目录。
111
-
112
- ### 兼容代理
113
-
114
- | 代理 | 技能位置 |
115
- |-------|---------------|
116
- | Claude Code | `.claude/skills/flowbook/SKILL.md` |
117
- | OpenAI Codex | `.agents/skills/flowbook/SKILL.md` |
118
- | VS Code / GitHub Copilot | `.github/skills/flowbook/SKILL.md` |
119
- | Google Antigravity | `.agent/skills/flowbook/SKILL.md` |
120
- | Gemini CLI | `.gemini/skills/flowbook/SKILL.md` |
121
- | Cursor | `.cursor/skills/flowbook/SKILL.md` |
122
- | Windsurf (Codeium) | `.windsurf/skills/flowbook/SKILL.md` |
123
- | AmpCode | `.amp/skills/flowbook/SKILL.md` |
124
- | OpenCode / oh-my-opencode | `.opencode/skills/flowbook/SKILL.md` |
125
-
126
- <details>
127
- <summary>手动技能安装</summary>
128
-
129
- 如果你没有使用 `flowbook init` 或 `npx skills add`,请手动复制技能:
130
-
131
- ```bash
132
- # 示例:Claude Code
133
- mkdir -p .claude/skills/flowbook
134
- cp node_modules/flowbook/src/skills/flowbook/SKILL.md .claude/skills/flowbook/
135
-
136
- # 示例:Cursor
137
- mkdir -p .cursor/skills/flowbook
138
- cp node_modules/flowbook/src/skills/flowbook/SKILL.md .cursor/skills/flowbook/
139
- ```
140
-
141
- 请参考上方兼容代理表格中的路径替换为适当的目录。
142
-
143
- </details>
144
- ## 工作原理
145
-
146
- ```
147
- .flow.md 文件 ──→ Vite 插件 ──→ 虚拟模块 ──→ React 查看器
148
- │ │
149
- ├─ fast-glob 扫描 ├─ export default { flows: [...] }
150
- ├─ gray-matter │
151
- │ 解析 └─ 文件更改时 HMR
152
- └─ mermaid 块
153
- 提取
154
- ```
155
-
156
- 1. **发现** — `fast-glob` 扫描项目中的 `*.flow.md` / `*.flowchart.md`
157
- 2. **解析** — `gray-matter` 提取 YAML frontmatter;正则表达式提取 `` ```mermaid `` 块
158
- 3. **虚拟模块** — Vite 插件将解析后的数据作为 `virtual:flowbook-data` 提供
159
- 4. **渲染** — React 应用通过 `mermaid.render()` 渲染 Mermaid 图表
160
- 5. **HMR** — 文件更改时使虚拟模块失效,触发重新加载
161
-
162
- ## 项目结构
163
-
164
- ```
165
- src/
166
- ├── types.ts # 共享类型 (FlowEntry, FlowbookData)
167
- ├── node/
168
- │ ├── cli.ts # CLI 入口 (init, dev, build)
169
- │ ├── server.ts # 编程式 Vite 服务器与构建
170
- │ ├── init.ts # 项目初始化逻辑
171
- │ ├── discovery.ts # 文件扫描器 (fast-glob)
172
- │ ├── parser.ts # Frontmatter + mermaid 提取
173
- │ └── plugin.ts # Vite 虚拟模块插件
174
- └── client/
175
- ├── index.html # 入口 HTML
176
- ├── main.tsx # React 入口
177
- ├── App.tsx # 搜索 + 侧边栏 + 查看器布局
178
- ├── vite-env.d.ts # 虚拟模块类型声明
179
- ├── styles/globals.css # Tailwind v4 + 自定义样式
180
- └── components/
181
- ├── Header.tsx # Logo、搜索栏、流程计数
182
- ├── Sidebar.tsx # 可折叠分类树
183
- ├── MermaidRenderer.tsx # Mermaid 图表渲染
184
- ├── FlowView.tsx # 单个流程详情视图
185
- └── EmptyState.tsx # 空状态引导
186
- ```
187
-
188
- ## 开发(贡献)
189
-
190
- ```bash
191
- git clone https://github.com/Epsilondelta-ai/flowbook.git
192
- cd flowbook
193
- npm install
194
-
195
- # 本地开发(使用根目录 vite.config.ts)
196
- npm run dev
197
-
198
- # 构建 CLI
199
- npm run build
200
-
201
- # 本地测试 CLI
202
- node dist/cli.js dev
203
- node dist/cli.js build
204
- ```
205
-
206
- ## 技术栈
207
-
208
- - **Vite** — 支持 HMR 的开发服务器
209
- - **React 19** — 用户界面
210
- - **Mermaid 11** — 图表渲染
211
- - **Tailwind CSS v4** — 样式
212
- - **gray-matter** — YAML frontmatter 解析
213
- - **fast-glob** — 文件发现
214
- - **tsup** — CLI 打包工具
215
- - **TypeScript** — 类型安全
216
-
217
- ## 许可证
218
-
219
- MIT