@aigne/doc-smith 0.8.11-beta → 0.8.11-beta.2

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 (257) hide show
  1. package/.aigne/doc-smith/config.yaml +2 -0
  2. package/.aigne/doc-smith/output/structure-plan.json +3 -3
  3. package/.aigne/doc-smith/upload-cache.yaml +252 -0
  4. package/.github/workflows/publish-docs.yml +67 -0
  5. package/.release-please-manifest.json +1 -1
  6. package/CHANGELOG.md +22 -0
  7. package/README.md +45 -115
  8. package/agents/clear/choose-contents.mjs +170 -0
  9. package/agents/clear/clear-auth-tokens.mjs +111 -0
  10. package/agents/clear/clear-document-config.mjs +39 -0
  11. package/agents/clear/clear-document-structure.mjs +106 -0
  12. package/agents/clear/clear-generated-docs.mjs +51 -0
  13. package/agents/clear/index.yaml +23 -0
  14. package/agents/evaluate/code-snippet.mjs +93 -0
  15. package/agents/evaluate/document-structure.yaml +70 -0
  16. package/agents/evaluate/document.yaml +79 -0
  17. package/agents/evaluate/generate-report.mjs +78 -0
  18. package/agents/evaluate/index.yaml +39 -0
  19. package/agents/generate/document-structure-tools/add-document.mjs +56 -0
  20. package/agents/generate/document-structure-tools/delete-document.mjs +49 -0
  21. package/agents/generate/document-structure-tools/move-document.mjs +82 -0
  22. package/agents/generate/document-structure-tools/update-document.mjs +50 -0
  23. package/agents/generate/generate-structure.yaml +1 -1
  24. package/agents/generate/update-document-structure.yaml +42 -0
  25. package/agents/generate/user-review-document-structure.mjs +6 -4
  26. package/agents/init/index.mjs +1 -1
  27. package/agents/publish/publish-docs.mjs +12 -3
  28. package/agents/translate/choose-language.mjs +1 -1
  29. package/agents/update/batch-update-document.yaml +7 -0
  30. package/agents/update/check-update-is-single.mjs +38 -0
  31. package/agents/update/document-tools/update-document-content.mjs +293 -0
  32. package/agents/update/index.yaml +4 -10
  33. package/agents/update/update-document-detail.yaml +52 -0
  34. package/agents/update/update-single-document.yaml +15 -0
  35. package/agents/update/user-review-document.mjs +248 -0
  36. package/agents/utils/choose-docs.mjs +4 -2
  37. package/agents/utils/format-document-structure.mjs +12 -2
  38. package/agents/utils/load-document-all-content.mjs +84 -0
  39. package/agents/utils/load-sources.mjs +4 -1
  40. package/aigne.yaml +59 -20
  41. package/assets/report-template/report.html +198 -0
  42. package/biome.json +14 -2
  43. package/docs/advanced-how-it-works.ja.md +101 -0
  44. package/docs/advanced-how-it-works.zh-TW.md +101 -0
  45. package/docs/advanced-how-it-works.zh.md +20 -20
  46. package/docs/advanced-quality-assurance.ja.md +96 -0
  47. package/docs/advanced-quality-assurance.zh-TW.md +96 -0
  48. package/docs/advanced-quality-assurance.zh.md +18 -18
  49. package/docs/advanced.ja.md +16 -0
  50. package/docs/advanced.zh-TW.md +16 -0
  51. package/docs/advanced.zh.md +4 -4
  52. package/docs/changelog.ja.md +309 -0
  53. package/docs/changelog.zh-TW.md +309 -0
  54. package/docs/changelog.zh.md +23 -23
  55. package/docs/cli-reference.ja.md +210 -0
  56. package/docs/cli-reference.zh-TW.md +210 -0
  57. package/docs/cli-reference.zh.md +21 -21
  58. package/docs/configuration-interactive-setup.ja.md +135 -0
  59. package/docs/configuration-interactive-setup.zh-TW.md +135 -0
  60. package/docs/configuration-interactive-setup.zh.md +29 -29
  61. package/docs/configuration-language-support.ja.md +94 -0
  62. package/docs/configuration-language-support.zh-TW.md +94 -0
  63. package/docs/configuration-language-support.zh.md +13 -13
  64. package/docs/configuration-llm-setup.ja.md +54 -0
  65. package/docs/configuration-llm-setup.zh-TW.md +54 -0
  66. package/docs/configuration-llm-setup.zh.md +12 -12
  67. package/docs/configuration-preferences.ja.md +129 -0
  68. package/docs/configuration-preferences.zh-TW.md +129 -0
  69. package/docs/configuration-preferences.zh.md +36 -36
  70. package/docs/configuration.ja.md +172 -0
  71. package/docs/configuration.zh-TW.md +172 -0
  72. package/docs/configuration.zh.md +49 -49
  73. package/docs/features-generate-documentation.ja.md +101 -0
  74. package/docs/features-generate-documentation.zh-TW.md +101 -0
  75. package/docs/features-generate-documentation.zh.md +17 -17
  76. package/docs/features-publish-your-docs.ja.md +107 -0
  77. package/docs/features-publish-your-docs.zh-TW.md +107 -0
  78. package/docs/features-publish-your-docs.zh.md +22 -22
  79. package/docs/features-translate-documentation.ja.md +79 -0
  80. package/docs/features-translate-documentation.zh-TW.md +79 -0
  81. package/docs/features-translate-documentation.zh.md +12 -12
  82. package/docs/features-update-and-refine.ja.md +138 -0
  83. package/docs/features-update-and-refine.zh-TW.md +138 -0
  84. package/docs/features-update-and-refine.zh.md +21 -21
  85. package/docs/features.ja.md +52 -0
  86. package/docs/features.zh-TW.md +52 -0
  87. package/docs/features.zh.md +8 -8
  88. package/docs/getting-started.ja.md +123 -0
  89. package/docs/getting-started.zh-TW.md +123 -0
  90. package/docs/getting-started.zh.md +24 -24
  91. package/docs/overview.ja.md +30 -0
  92. package/docs/overview.zh-TW.md +30 -0
  93. package/docs/overview.zh.md +8 -8
  94. package/package.json +19 -11
  95. package/prompts/common/document/content-rules-core.md +19 -0
  96. package/prompts/common/document/media-handling-rules.md +9 -0
  97. package/prompts/common/document/role-and-personality.md +15 -0
  98. package/prompts/common/document/user-preferences.md +9 -0
  99. package/prompts/common/document-structure/conflict-resolution-guidance.md +16 -0
  100. package/prompts/common/document-structure/document-structure-rules.md +45 -0
  101. package/prompts/common/document-structure/glossary.md +7 -0
  102. package/prompts/common/document-structure/intj-traits.md +5 -0
  103. package/prompts/common/document-structure/output-constraints.md +9 -0
  104. package/prompts/common/document-structure/user-locale-rules.md +10 -0
  105. package/prompts/common/document-structure/user-preferences.md +9 -0
  106. package/prompts/detail/custom/custom-components.md +9 -1
  107. package/prompts/detail/document-rules.md +6 -6
  108. package/prompts/detail/generate-document.md +5 -45
  109. package/prompts/detail/update-document.md +145 -0
  110. package/prompts/evaluate/document-structure.md +94 -0
  111. package/prompts/evaluate/document.md +149 -0
  112. package/prompts/structure/document-rules.md +1 -1
  113. package/prompts/structure/generate-structure-system.md +74 -0
  114. package/prompts/structure/generate-structure-user.md +41 -0
  115. package/prompts/structure/update-document-structure.md +118 -0
  116. package/prompts/translate/translate-document.md +1 -1
  117. package/prompts/utils/feedback-refiner.md +3 -3
  118. package/release-please-config.json +1 -7
  119. package/tests/agents/clear/choose-contents.test.mjs +280 -0
  120. package/tests/agents/clear/clear-auth-tokens.test.mjs +268 -0
  121. package/tests/agents/clear/clear-document-config.test.mjs +167 -0
  122. package/tests/agents/clear/clear-document-structure.test.mjs +374 -0
  123. package/tests/agents/clear/clear-generated-docs.test.mjs +222 -0
  124. package/tests/agents/evaluate/code-snippet.test.mjs +163 -0
  125. package/tests/agents/evaluate/fixtures/api-services.md +87 -0
  126. package/tests/agents/evaluate/fixtures/js-sdk.md +94 -0
  127. package/tests/agents/evaluate/generate-report.test.mjs +312 -0
  128. package/tests/agents/generate/check-document-structure.test.mjs +0 -6
  129. package/tests/agents/generate/document-structure-tools/add-document.test.mjs +449 -0
  130. package/tests/agents/generate/document-structure-tools/delete-document.test.mjs +410 -0
  131. package/tests/agents/generate/document-structure-tools/move-document.test.mjs +476 -0
  132. package/tests/agents/generate/document-structure-tools/update-document.test.mjs +548 -0
  133. package/tests/agents/generate/generate-structure.test.mjs +0 -6
  134. package/tests/agents/generate/user-review-document-structure.test.mjs +9 -9
  135. package/tests/agents/publish/publish-docs.test.mjs +2 -2
  136. package/tests/agents/update/check-update-is-single.test.mjs +300 -0
  137. package/tests/agents/update/document-tools/update-document-content.test.mjs +326 -0
  138. package/tests/agents/update/user-review-document.test.mjs +561 -0
  139. package/tests/agents/utils/format-document-structure.test.mjs +100 -0
  140. package/tests/utils/auth-utils.test.mjs +239 -1
  141. package/tests/utils/blocklet.test.mjs +9 -7
  142. package/tests/utils/constants.test.mjs +1 -1
  143. package/tests/utils/d2-utils.test.mjs +1 -1
  144. package/tests/utils/deploy.test.mjs +310 -366
  145. package/tests/utils/kroki-utils.test.mjs +2 -15
  146. package/tests/utils/linter/fixtures/css/keyword-error.css +1 -0
  147. package/tests/utils/linter/fixtures/css/missing-semicolon.css +1 -0
  148. package/tests/utils/linter/fixtures/css/syntax-error.css +1 -0
  149. package/tests/utils/linter/fixtures/css/undeclare-variable.css +1 -0
  150. package/tests/utils/linter/fixtures/css/unused-variable.css +2 -0
  151. package/tests/utils/linter/fixtures/css/valid-code.css +1 -0
  152. package/tests/utils/linter/fixtures/dockerfile/keyword-error.dockerfile +1 -0
  153. package/tests/utils/linter/fixtures/dockerfile/missing-semicolon.dockerfile +2 -0
  154. package/tests/utils/linter/fixtures/dockerfile/syntax-error.dockerfile +2 -0
  155. package/tests/utils/linter/fixtures/dockerfile/undeclare-variable.dockerfile +1 -0
  156. package/tests/utils/linter/fixtures/dockerfile/unused-variable.dockerfile +1 -0
  157. package/tests/utils/linter/fixtures/dockerfile/valid-code.dockerfile +2 -0
  158. package/tests/utils/linter/fixtures/go/keyword-error.go +5 -0
  159. package/tests/utils/linter/fixtures/go/missing-semicolon.go +5 -0
  160. package/tests/utils/linter/fixtures/go/syntax-error.go +6 -0
  161. package/tests/utils/linter/fixtures/go/undeclare-variable.go +5 -0
  162. package/tests/utils/linter/fixtures/go/unused-variable.go +5 -0
  163. package/tests/utils/linter/fixtures/go/valid-code.go +7 -0
  164. package/tests/utils/linter/fixtures/js/keyword-error.js +3 -0
  165. package/tests/utils/linter/fixtures/js/missing-semicolon.js +6 -0
  166. package/tests/utils/linter/fixtures/js/syntax-error.js +4 -0
  167. package/tests/utils/linter/fixtures/js/undeclare-variable.js +3 -0
  168. package/tests/utils/linter/fixtures/js/unused-variable.js +7 -0
  169. package/tests/utils/linter/fixtures/js/valid-code.js +15 -0
  170. package/tests/utils/linter/fixtures/json/keyword-error.json +1 -0
  171. package/tests/utils/linter/fixtures/json/missing-semicolon.json +1 -0
  172. package/tests/utils/linter/fixtures/json/syntax-error.json +1 -0
  173. package/tests/utils/linter/fixtures/json/undeclare-variable.json +1 -0
  174. package/tests/utils/linter/fixtures/json/unused-variable.json +1 -0
  175. package/tests/utils/linter/fixtures/json/valid-code.json +1 -0
  176. package/tests/utils/linter/fixtures/jsx/keyword-error.jsx +5 -0
  177. package/tests/utils/linter/fixtures/jsx/missing-semicolon.jsx +5 -0
  178. package/tests/utils/linter/fixtures/jsx/syntax-error.jsx +5 -0
  179. package/tests/utils/linter/fixtures/jsx/undeclare-variable.jsx +5 -0
  180. package/tests/utils/linter/fixtures/jsx/unused-variable.jsx +4 -0
  181. package/tests/utils/linter/fixtures/jsx/valid-code.jsx +5 -0
  182. package/tests/utils/linter/fixtures/python/keyword-error.py +3 -0
  183. package/tests/utils/linter/fixtures/python/missing-semicolon.py +2 -0
  184. package/tests/utils/linter/fixtures/python/syntax-error.py +3 -0
  185. package/tests/utils/linter/fixtures/python/undeclare-variable.py +3 -0
  186. package/tests/utils/linter/fixtures/python/unused-variable.py +6 -0
  187. package/tests/utils/linter/fixtures/python/valid-code.py +12 -0
  188. package/tests/utils/linter/fixtures/ruby/keyword-error.rb +2 -0
  189. package/tests/utils/linter/fixtures/ruby/missing-semicolon.rb +1 -0
  190. package/tests/utils/linter/fixtures/ruby/syntax-error.rb +2 -0
  191. package/tests/utils/linter/fixtures/ruby/undeclare-variable.rb +1 -0
  192. package/tests/utils/linter/fixtures/ruby/unused-variable.rb +2 -0
  193. package/tests/utils/linter/fixtures/ruby/valid-code.rb +1 -0
  194. package/tests/utils/linter/fixtures/sass/keyword-error.sass +2 -0
  195. package/tests/utils/linter/fixtures/sass/missing-semicolon.sass +3 -0
  196. package/tests/utils/linter/fixtures/sass/syntax-error.sass +3 -0
  197. package/tests/utils/linter/fixtures/sass/undeclare-variable.sass +2 -0
  198. package/tests/utils/linter/fixtures/sass/unused-variable.sass +4 -0
  199. package/tests/utils/linter/fixtures/sass/valid-code.sass +2 -0
  200. package/tests/utils/linter/fixtures/scss/keyword-error.scss +1 -0
  201. package/tests/utils/linter/fixtures/scss/missing-semicolon.scss +1 -0
  202. package/tests/utils/linter/fixtures/scss/syntax-error.scss +1 -0
  203. package/tests/utils/linter/fixtures/scss/undeclare-variable.scss +1 -0
  204. package/tests/utils/linter/fixtures/scss/unused-variable.scss +2 -0
  205. package/tests/utils/linter/fixtures/scss/valid-code.scss +1 -0
  206. package/tests/utils/linter/fixtures/shell/keyword-error.sh +5 -0
  207. package/tests/utils/linter/fixtures/shell/missing-semicolon.sh +3 -0
  208. package/tests/utils/linter/fixtures/shell/syntax-error.sh +4 -0
  209. package/tests/utils/linter/fixtures/shell/undeclare-variable.sh +3 -0
  210. package/tests/utils/linter/fixtures/shell/unused-variable.sh +4 -0
  211. package/tests/utils/linter/fixtures/shell/valid-code.sh +3 -0
  212. package/tests/utils/linter/fixtures/ts/keyword-error.ts +1 -0
  213. package/tests/utils/linter/fixtures/ts/missing-semicolon.ts +1 -0
  214. package/tests/utils/linter/fixtures/ts/syntax-error.ts +1 -0
  215. package/tests/utils/linter/fixtures/ts/undeclare-variable.ts +1 -0
  216. package/tests/utils/linter/fixtures/ts/unused-variable.ts +3 -0
  217. package/tests/utils/linter/fixtures/ts/valid-code.ts +3 -0
  218. package/tests/utils/linter/fixtures/tsx/keyword-error.tsx +5 -0
  219. package/tests/utils/linter/fixtures/tsx/missing-semicolon.tsx +5 -0
  220. package/tests/utils/linter/fixtures/tsx/syntax-error.tsx +5 -0
  221. package/tests/utils/linter/fixtures/tsx/undeclare-variable.tsx +6 -0
  222. package/tests/utils/linter/fixtures/tsx/unused-variable.tsx +6 -0
  223. package/tests/utils/linter/fixtures/tsx/valid-code.tsx +5 -0
  224. package/tests/utils/linter/fixtures/vue/keyword-error.vue +6 -0
  225. package/tests/utils/linter/fixtures/vue/missing-semicolon.vue +6 -0
  226. package/tests/utils/linter/fixtures/vue/syntax-error.vue +6 -0
  227. package/tests/utils/linter/fixtures/vue/undeclare-variable.vue +6 -0
  228. package/tests/utils/linter/fixtures/vue/unused-variable.vue +7 -0
  229. package/tests/utils/linter/fixtures/vue/valid-code.vue +6 -0
  230. package/tests/utils/linter/fixtures/yaml/keyword-error.yml +1 -0
  231. package/tests/utils/linter/fixtures/yaml/missing-semicolon.yml +2 -0
  232. package/tests/utils/linter/fixtures/yaml/syntax-error.yml +1 -0
  233. package/tests/utils/linter/fixtures/yaml/undeclare-variable.yml +1 -0
  234. package/tests/utils/linter/fixtures/yaml/unused-variable.yml +2 -0
  235. package/tests/utils/linter/fixtures/yaml/valid-code.yml +3 -0
  236. package/tests/utils/linter/index.test.mjs +440 -0
  237. package/tests/utils/linter/scan-results.mjs +42 -0
  238. package/tests/utils/markdown/index.test.mjs +478 -0
  239. package/tests/utils/mermaid-validator.test.mjs +2 -2
  240. package/tests/utils/utils.test.mjs +3 -1
  241. package/types/document-schema.mjs +54 -0
  242. package/types/document-structure-schema.mjs +244 -0
  243. package/utils/auth-utils.mjs +131 -6
  244. package/utils/conflict-detector.mjs +5 -1
  245. package/utils/{constants.mjs → constants/index.mjs} +109 -0
  246. package/utils/constants/linter.mjs +102 -0
  247. package/utils/d2-utils.mjs +2 -4
  248. package/utils/debug.mjs +3 -0
  249. package/utils/deploy.mjs +81 -385
  250. package/utils/evaluate/report-utils.mjs +131 -0
  251. package/utils/file-utils.mjs +36 -1
  252. package/utils/kroki-utils.mjs +1 -1
  253. package/utils/linter/index.mjs +50 -0
  254. package/utils/markdown/index.mjs +26 -0
  255. package/utils/markdown-checker.mjs +1 -1
  256. package/utils/utils.mjs +19 -7
  257. package/prompts/structure/generate-structure.md +0 -161
@@ -1,16 +1,16 @@
1
- # 管理偏好
1
+ # 管理偏好设置
2
2
 
3
- AIGNE DocSmith 旨在通过你的反馈进行学习。当你优化或更正生成的内容时,DocSmith 可以将该反馈转换为持久性规则,称为偏好。这些规则确保你特定的风格、结构要求和内容策略在未来的文档任务中得到一致应用。所有偏好都存储在项目根目录下一个名为 `.aigne/doc-smith/preferences.yml` 的人类可读 YAML 文件中。
3
+ AIGNE DocSmith 旨在从您的反馈中学习。当您优化或更正生成的内容时,DocSmith 可以将该反馈转换为持久性规则,称为偏好设置。这些规则确保您特定的风格、结构要求和内容策略在未来的文档任务中得到一致的应用。所有偏好设置都存储在项目根目录下一个人类可读的 YAML 文件中,路径为 `.aigne/doc-smith/preferences.yml`。
4
4
 
5
- ## 偏好生命周期
5
+ ## 偏好设置的生命周期
6
6
 
7
- 下图说明了你的反馈如何成为一个可重用的规则,该规则可应用于未来的任务,并可通过命令行进行管理。
7
+ 下图说明了您的反馈如何成为一个可重用的规则,该规则可以应用于未来的任务,并可以通过命令行进行管理。
8
8
 
9
- ```d2 偏好生命周期
9
+ ```d2 偏好设置的生命周期
10
10
  direction: down
11
11
 
12
12
  feedback: {
13
- label: "1. 用户在“优化”或“翻译”期间提供反馈"
13
+ label: "1. 用户在“优化”或“翻译”期间\n提供反馈"
14
14
  shape: rectangle
15
15
  }
16
16
 
@@ -30,7 +30,7 @@ pref_file: {
30
30
  }
31
31
 
32
32
  future_tasks: {
33
- label: "4. 未来任务\n应用已保存的规则"
33
+ label: "4. 未来的任务\n应用已保存的规则"
34
34
  shape: rectangle
35
35
  }
36
36
 
@@ -48,82 +48,82 @@ cli <-> pref_file: "管理"
48
48
 
49
49
  ```
50
50
 
51
- ### 如何创建偏好
51
+ ### 如何创建偏好设置
52
52
 
53
- 当你在 `refine` 或 `translate` 阶段提供反馈时,一个内部 Agent 会分析你的输入。它会判断该反馈是一次性修复(例如,更正一个拼写错误)还是一个可重用的策略(例如,“始终用英语编写代码注释”)。如果它代表一个持久性指令,它就会创建一个新的偏好规则。
53
+ 当您在 `refine` 或 `translate` 阶段提供反馈时,一个内部 Agent 会分析您的输入。它会判断反馈是一次性修复(例如,更正拼写错误)还是可重用的策略(例如,“始终用英语编写代码注释”)。如果它代表一个持久的指令,它就会创建一个新的偏好设置规则。
54
54
 
55
55
  ### 规则属性
56
56
 
57
57
  保存在 `preferences.yml` 中的每个规则都具有以下结构:
58
58
 
59
59
  <x-field data-name="id" data-type="string" data-desc="规则的唯一、随机生成的标识符(例如,pref_a1b2c3d4e5f6g7h8)。"></x-field>
60
- <x-field data-name="active" data-type="boolean" data-desc="指示规则当前是否已启用。未启用的规则在生成任务期间将被忽略。"></x-field>
61
- <x-field data-name="scope" data-type="string" data-desc="定义规则何时应用。有效范围为 'global'、'structure'、'document' 或 'translation'。"></x-field>
62
- <x-field data-name="rule" data-type="string" data-desc="将在未来任务中传递给 AI 的具体、提炼后的指令。"></x-field>
60
+ <x-field data-name="active" data-type="boolean" data-desc="指示规则当前是否已启用。在生成任务期间,非活动规则将被忽略。"></x-field>
61
+ <x-field data-name="scope" data-type="string" data-desc="定义规则应在何时应用。有效范围是 'global'、'structure'、'document' 或 'translation'。"></x-field>
62
+ <x-field data-name="rule" data-type="string" data-desc="将在未来任务中传递给 AI 的具体、精炼的指令。"></x-field>
63
63
  <x-field data-name="feedback" data-type="string" data-desc="用户提供的原始自然语言反馈,保留以供参考。"></x-field>
64
64
  <x-field data-name="createdAt" data-type="string" data-desc="表示规则创建时间的 ISO 8601 时间戳。"></x-field>
65
65
  <x-field data-name="paths" data-type="string[]" data-required="false" data-desc="一个可选的文件路径列表。如果存在,该规则仅适用于为这些特定源文件生成的内容。"></x-field>
66
66
 
67
- ## 使用 CLI 管理偏好
67
+ ## 使用 CLI 管理偏好设置
68
68
 
69
- 你可以使用 `aigne doc prefs` 命令查看和管理所有已保存的偏好。这允许你列出、激活、停用或永久删除规则。
69
+ 您可以使用 `aigne doc prefs` 命令查看和管理所有已保存的偏好设置。这允许您列出、激活、停用或永久删除规则。
70
70
 
71
- ### 列出所有偏好
71
+ ### 列出所有偏好设置
72
72
 
73
- 要查看所有已保存的偏好,包括已激活和未激活的,请使用 `--list` 标志。
73
+ 要查看所有已保存的偏好设置(包括活动的和非活动的),请使用 `--list` 标志。
74
74
 
75
- ```bash 列出所有偏好 icon=lucide:terminal
75
+ ```bash 列出所有偏好设置 icon=lucide:terminal
76
76
  aigne doc prefs --list
77
77
  ```
78
78
 
79
- 该命令会显示一个格式化列表,展示每个规则的状态、范围、ID 以及任何路径限制。
79
+ 该命令会显示一个格式化的列表,显示每个规则的状态、范围、ID 和任何路径限制。
80
80
 
81
- ```text 输出示例 icon=lucide:clipboard-list
82
- # 用户偏好
81
+ ```text 示例输出 icon=lucide:clipboard-list
82
+ # 用户偏好设置
83
83
 
84
84
  **格式说明:**
85
- - 🟢 = 已激活的偏好, = 未激活的偏好
86
- - [scope] = 偏好范围 (global, structure, document, translation)
87
- - ID = 唯一偏好标识符
88
- - Paths = 特定文件路径 (如果适用)
85
+ - 🟢 = 活动偏好设置,⚪ = 非活动偏好设置
86
+ - [scope] = 偏好设置范围 (global, structure, document, translation)
87
+ - ID = 唯一偏好设置标识符
88
+ - Paths = 特定文件路径(如果适用)
89
89
 
90
90
  🟢 [structure] pref_a1b2c3d4e5f6g7h8 | Paths: overview.md
91
- 在概览文档末尾添加“后续步骤”部分。
91
+ 在概述文档的末尾添加一个“后续步骤”部分。
92
92
 
93
93
  ⚪ [document] pref_i9j0k1l2m3n4o5p6
94
94
  代码注释必须用英语编写。
95
95
  ```
96
96
 
97
- ### 停用和重新激活偏好
97
+ ### 停用和重新激活偏好设置
98
98
 
99
- 如果你想临时禁用一个规则而不删除它,可以使用 `--toggle` 标志来切换其激活状态。不带 ID 运行该命令将启动一个交互模式,允许你选择一个或多个偏好进行切换。
99
+ 如果您想暂时禁用某个规则而不删除它,可以使用 `--toggle` 标志来切换其活动状态。在不带 ID 的情况下运行该命令将启动交互模式,允许您选择一个或多个偏好设置进行切换。
100
100
 
101
- ```bash 以交互方式切换偏好 icon=lucide:terminal
101
+ ```bash 以交互方式切换偏好设置 icon=lucide:terminal
102
102
  aigne doc prefs --toggle
103
103
  ```
104
104
 
105
105
  要直接切换特定规则,请使用 `--id` 标志提供其 ID。这对应于 `deactivateRule` 函数,该函数将规则的 `active` 属性设置为 `false`。
106
106
 
107
- ```bash 切换特定偏好 icon=lucide:terminal
107
+ ```bash 切换特定偏好设置 icon=lucide:terminal
108
108
  aigne doc prefs --toggle --id pref_i9j0k1l2m3n4o5p6
109
109
  ```
110
110
 
111
- ### 删除偏好
111
+ ### 删除偏好设置
112
112
 
113
- 要永久删除一个或多个偏好,请使用 `--remove` 标志。此操作对应于 `removeRule` 函数,且无法撤销。
113
+ 要永久删除一个或多个偏好设置,请使用 `--remove` 标志。此操作对应于 `removeRule` 函数,且无法撤销。
114
114
 
115
- 要进入交互式选择提示,请不带 ID 运行该命令。
115
+ 要进入交互式选择提示,请在不带 ID 的情况下运行该命令。
116
116
 
117
- ```bash 以交互方式删除偏好 icon=lucide:terminal
117
+ ```bash 以交互方式删除偏好设置 icon=lucide:terminal
118
118
  aigne doc prefs --remove
119
119
  ```
120
120
 
121
- 要通过 ID 直接删除特定规则,请使用 `--id` 标志。
121
+ 要通过其 ID 直接删除特定规则,请使用 `--id` 标志。
122
122
 
123
- ```bash 删除特定偏好 icon=lucide:terminal
123
+ ```bash 删除特定偏好设置 icon=lucide:terminal
124
124
  aigne doc prefs --remove --id pref_a1b2c3d4e5f6g7h8
125
125
  ```
126
126
 
127
127
  ## 后续步骤
128
128
 
129
- 管理偏好是根据项目特定需求定制 DocSmith 的关键部分。有关更多自定义选项,请查阅主要的[配置指南](./configuration.md)。
129
+ 管理偏好设置是根据项目特定需求定制 DocSmith 的关键部分。要了解更多自定义选项,请探索主要的[配置指南](./configuration.md)。
@@ -0,0 +1,172 @@
1
+ # 設定ガイド
2
+
3
+ AIGNE DocSmithの動作は、`.aigne/doc-smith/config.yaml`に配置されている中央ファイル、`config.yaml`によって制御されます。このファイルは、ドキュメントのスタイル、対象読者、言語、構造を決定します。
4
+
5
+ `aigne doc init`を実行することで、対話式セットアップウィザードを使用してこのファイルを作成および管理できます。ステップバイステップのウォークスルーについては、[対話式セットアップ](./configuration-interactive-setup.md)ガイドを参照してください。
6
+
7
+ ## 主要な設定エリア
8
+
9
+ ドキュメントは、いくつかの主要な設定エリアによって形成されます。これらのガイドを参照して、生成プロセスの各側面を微調整する方法を理解してください。
10
+
11
+ <x-cards data-columns="2">
12
+ <x-card data-title="対話式セットアップ" data-icon="lucide:wand-2" data-href="/configuration/interactive-setup">
13
+ 設定の推奨や競合の検出を含む、ドキュメントプロジェクトの設定を支援するガイド付きウィザードについて学びます。
14
+ </x-card>
15
+ <x-card data-title="LLMセットアップ" data-icon="lucide:brain-circuit" data-href="/configuration/llm-setup">
16
+ APIキーを必要としない組み込みのAIGNE Hubの使用を含む、さまざまなAIモデルの接続方法を発見します。
17
+ </x-card>
18
+ <x-card data-title="言語サポート" data-icon="lucide:languages" data-href="/configuration/language-support">
19
+ サポートされている言語の完全なリストを確認し、主要言語の設定方法や自動翻訳を有効にする方法を学びます。
20
+ </x-card>
21
+ <x-card data-title="設定の管理" data-icon="lucide:sliders-horizontal" data-href="/configuration/preferences">
22
+ DocSmithがフィードバックを使用して永続的なルールを作成する方法と、CLIを介してそれらを管理する方法を理解します。
23
+ </x-card>
24
+ </x-cards>
25
+
26
+ ## パラメータリファレンス
27
+
28
+ `config.yaml`ファイルには、ドキュメントの出力を制御するいくつかのキーと値のペアが含まれています。以下は、各パラメータの詳細なリファレンスです。
29
+
30
+ ### プロジェクト情報
31
+
32
+ これらの設定は、プロジェクトに関する基本的なコンテキストを提供し、ドキュメントを公開する際に使用されます。
33
+
34
+ | Parameter | Description |
35
+ |---|---|
36
+ | `projectName` | プロジェクトの名前。`package.json`が存在する場合、そこから検出されます。 |
37
+ | `projectDesc` | プロジェクトの短い説明。`package.json`から検出されます。 |
38
+ | `projectLogo` | プロジェクトのロゴ画像へのパスまたはURL。 |
39
+
40
+ ### ドキュメンテーション戦略
41
+
42
+ これらのパラメータは、生成されるコンテンツのトーン、スタイル、深さを定義します。
43
+
44
+ #### `documentPurpose`
45
+ 読者に達成してほしい主要な成果を定義します。この設定は、ドキュメント全体の構造と焦点に影響を与えます。
46
+
47
+ | Option | Name | Description |
48
+ |---|---|---|
49
+ | `getStarted` | すぐに始める | 新規ユーザーが30分未満でゼロから作業を開始できるように支援します。 |
50
+ | `completeTasks` | 特定のタスクを完了する | 一般的なワークフローとユースケースを通じてユーザーをガイドします。 |
51
+ | `findAnswers` | 素早く回答を見つける | すべての機能とAPIに対して検索可能なリファレンスを提供します。 |
52
+ | `understandSystem`| システムを理解する | それがどのように機能し、なぜ設計上の決定がなされたのかを説明します。 |
53
+ | `solveProblems` | 一般的な問題をトラブルシューティングする | ユーザーが問題をトラブルシューティングし、修正するのを支援します。 |
54
+ | `mixedPurpose` | 複数の目的を果たす | 複数のニーズをカバーするドキュメント。 |
55
+
56
+ #### `targetAudienceTypes`
57
+ このドキュメントを最も頻繁に読む人を定義します。この選択は、ライティングスタイルと例に影響を与えます。
58
+
59
+ | Option | Name | Description |
60
+ |---|---|---|
61
+ | `endUsers` | エンドユーザー(非技術者) | 製品を使用するがコーディングはしない人々。 |
62
+ | `developers` | 製品/APIを統合する開発者 | これを自分たちのプロジェクトに追加するエンジニア。 |
63
+ | `devops` | DevOps / SRE / インフラストラクチャチーム | システムのデプロイ、監視、保守を行うチーム。 |
64
+ | `decisionMakers`| 技術的な意思決定者 | 実装を評価または計画するアーキテクトやリード。 |
65
+ | `supportTeams` | サポートチーム | 他者が製品を使用するのを助ける人々。 |
66
+ | `mixedTechnical`| 混合技術者層 | 開発者、DevOps、およびその他の技術ユーザー。 |
67
+
68
+ #### `readerKnowledgeLevel`
69
+ 読者がアクセスした時点で通常知っていることを定義します。これにより、どの程度の基礎知識が前提とされるかが調整されます。
70
+
71
+ | Option | Name | Description |
72
+ |---|---|---|
73
+ | `completeBeginners` | 完全な初心者、ゼロから始める | このドメイン/技術に全くの初心者。 |
74
+ | `domainFamiliar` | 以前に類似のツールを使用したことがある | 問題領域は知っているが、この特定のソリューションには新しい。 |
75
+ | `experiencedUsers` | 特定のことをしようとしている専門家 | リファレンスや高度なトピックを必要とする通常のユーザー。 |
76
+ | `emergencyTroubleshooting`| 緊急/トラブルシューティング | 何かが壊れており、迅速に修正する必要がある。 |
77
+ | `exploringEvaluating` | このツールを他と比較して評価している | これが自分たちのニーズに合うかどうかを理解しようとしている。 |
78
+
79
+ #### `documentationDepth`
80
+ ドキュメントがどれだけ包括的であるべきかを定義します。
81
+
82
+ | Option | Name | Description |
83
+ |---|---|---|
84
+ | `essentialOnly` | 必須のみ | 80%のユースケースをカバーし、簡潔に保ちます。 |
85
+ | `balancedCoverage`| バランスの取れたカバレッジ | 実践的な例を伴う適切な深さ [推奨]。 |
86
+ | `comprehensive` | 包括的 | すべての機能、エッジケース、および高度なシナリオをカバーします。 |
87
+ | `aiDecide` | AIに決定させる | コードの複雑さを分析し、適切な深さを提案します。 |
88
+
89
+ ### カスタムディレクティブ
90
+
91
+ より詳細な制御のために、自由記述の指示を提供できます。
92
+
93
+ | Parameter | Description |
94
+ |---|---|
95
+ | `rules` | 特定のドキュメント生成ルールを定義できる複数行の文字列(例:「常にパフォーマンスベンチマークを含める」)。 |
96
+ | `targetAudience`| プリセットで許可されているよりも詳細に特定の対象読者を記述するための複数行の文字列。 |
97
+
98
+ ### 言語とパスの設定
99
+
100
+ これらの設定は、ローカリゼーションとファイルの場所を制御します。
101
+
102
+ | Parameter | Description |
103
+ |---|---|
104
+ | `locale` | ドキュメントの主要言語(例:`en`、`zh`)。 |
105
+ | `translateLanguages` | ドキュメントを翻訳する言語コードのリスト(例:`[ja, fr, es]`)。 |
106
+ | `docsDir` | 生成されたドキュメントファイルが保存されるディレクトリ。 |
107
+ | `sourcesPath` | DocSmithが分析するためのソースコードパスまたはglobパターンのリスト(例:`['./src', './lib/**/*.js']`)。 |
108
+ | `glossary` | 一貫した翻訳を保証するために、プロジェクト固有の用語を含むマークダウンファイル(`@glossary.md`)へのパス。 |
109
+
110
+ ## config.yamlの例
111
+
112
+ 以下は、完全な設定ファイルの例です。このファイルを直接編集して、いつでも設定を変更できます。
113
+
114
+ ```yaml Example config.yaml icon=logos:yaml
115
+ # ドキュメント公開のためのプロジェクト情報
116
+ projectName: AIGNE DocSmith
117
+ projectDesc: AI駆動のドキュメンテーション生成ツール。
118
+ projectLogo: https://docsmith.aigne.io/image-bin/uploads/def424c20bbdb3c77483894fe0e22819.png
119
+
120
+ # =============================================================================
121
+ # ドキュメンテーション設定
122
+ # =============================================================================
123
+
124
+ # 目的:読者に達成してほしい主要な成果は何か?
125
+ # オプション:getStarted, completeTasks, findAnswers, understandSystem, solveProblems, mixedPurpose
126
+ documentPurpose:
127
+ - completeTasks
128
+ - findAnswers
129
+
130
+ # 対象読者:誰がこれを最も頻繁に読むか?
131
+ # オプション:endUsers, developers, devops, decisionMakers, supportTeams, mixedTechnical
132
+ targetAudienceTypes:
133
+ - developers
134
+
135
+ # 読者の知識レベル:読者は通常、何を知ってアクセスするか?
136
+ # オプション:completeBeginners, domainFamiliar, experiencedUsers, emergencyTroubleshooting, exploringEvaluating
137
+ readerKnowledgeLevel: domainFamiliar
138
+
139
+ # ドキュメントの深さ:ドキュメントはどれだけ包括的であるべきか?
140
+ # オプション:essentialOnly, balancedCoverage, comprehensive, aiDecide
141
+ documentationDepth: balancedCoverage
142
+
143
+ # カスタムルール:特定のドキュメント生成ルールと要件を定義する
144
+ rules: |+
145
+
146
+
147
+ # 対象読者:特定の対象読者とその特徴を記述する
148
+ targetAudience: |+
149
+
150
+
151
+ # 用語集:プロジェクト固有の用語と定義を含むマークダウンファイルへのパス
152
+ # glossary: "@glossary.md"
153
+
154
+ # ドキュメントの主要言語
155
+ locale: en
156
+
157
+ # ドキュメントを翻訳する言語のリスト
158
+ # translateLanguages:
159
+ # - zh
160
+ # - fr
161
+
162
+ # 生成されたドキュメントを保存するディレクトリ
163
+ docsDir: .aigne/doc-smith/docs
164
+
165
+ # 分析するソースコードパス
166
+ sourcesPath:
167
+ - ./
168
+ ```
169
+
170
+ 設定が完了したら、プロジェクトのニーズに合ったドキュメントを作成する準備が整いました。次のステップは、生成コマンドを実行することです。
171
+
172
+ ➡️ **次へ:** [ドキュメントの生成](./features-generate-documentation.md)
@@ -0,0 +1,172 @@
1
+ # 設定指南
2
+
3
+ AIGNE DocSmith 的行為由一個中央檔案控制,即位於 `.aigne/doc-smith/config.yaml` 的 `config.yaml`。此檔案決定了您文件的風格、目標受眾、語言和結構。
4
+
5
+ 您可以透過執行 `aigne doc init`,使用互動式設定精靈來建立和管理此檔案。有關逐步說明,請參閱 [互動式設定](./configuration-interactive-setup.md) 指南。
6
+
7
+ ## 核心設定區域
8
+
9
+ 您的文件由幾個關鍵的設定區域塑造而成。探索這些指南,以了解如何微調生成過程的每個方面。
10
+
11
+ <x-cards data-columns="2">
12
+ <x-card data-title="互動式設定" data-icon="lucide:wand-2" data-href="/configuration/interactive-setup">
13
+ 了解引導式精靈如何幫助您設定文件專案,包括設定建議和衝突偵測。
14
+ </x-card>
15
+ <x-card data-title="LLM 設定" data-icon="lucide:brain-circuit" data-href="/configuration/llm-setup">
16
+ 探索如何連接不同的 AI 模型,包括使用內建的 AIGNE Hub,該中心無需 API 金鑰。
17
+ </x-card>
18
+ <x-card data-title="語言支援" data-icon="lucide:languages" data-href="/configuration/language-support">
19
+ 查看支援的語言完整列表,並了解如何設定主要語言和啟用自動翻譯。
20
+ </x-card>
21
+ <x-card data-title="管理偏好設定" data-icon="lucide:sliders-horizontal" data-href="/configuration/preferences">
22
+ 了解 DocSmith 如何利用您的回饋來建立持久性規則,以及如何透過 CLI 管理它們。
23
+ </x-card>
24
+ </x-cards>
25
+
26
+ ## 參數參考
27
+
28
+ `config.yaml` 檔案包含數個控制文件輸出的鍵值對。以下是每個參數的詳細參考。
29
+
30
+ ### 專案資訊
31
+
32
+ 這些設定提供了有關您專案的基本背景資訊,用於發布文件。
33
+
34
+ | 參數 | 說明 |
35
+ |---|---|
36
+ | `projectName` | 您的專案名稱。如果 `package.json` 存在,將從中偵測。 |
37
+ | `projectDesc` | 您的專案簡短描述。從 `package.json` 偵測。 |
38
+ | `projectLogo` | 您的專案標誌圖片的路徑或 URL。 |
39
+
40
+ ### 文件策略
41
+
42
+ 這些參數定義了生成內容的語氣、風格和深度。
43
+
44
+ #### `documentPurpose`
45
+ 定義您希望讀者達成的​​主要成果。此設定會影響文件的整體結構和重點。
46
+
47
+ | 選項 | 名稱 | 說明 |
48
+ |---|---|---|
49
+ | `getStarted` | 快速入門 | 幫助新使用者在 30 分鐘內從零開始上手。 |
50
+ | `completeTasks` | 完成特定任務 | 引導使用者完成常見的工作流程和使用案例。 |
51
+ | `findAnswers` | 快速找到答案 | 為所有功能和 API 提供可搜尋的參考資料。 |
52
+ | `understandSystem`| 了解系統 | 解釋其運作方式以及設計決策的原因。 |
53
+ | `solveProblems` | 解決常見問題 | 幫助使用者排除故障並解決問題。 |
54
+ | `mixedPurpose` | 服務多種目的 | 涵蓋多種需求的文件。 |
55
+
56
+ #### `targetAudienceTypes`
57
+ 定義最常閱讀此文件的對象。此選擇會影響寫作風格和範例。
58
+
59
+ | 選項 | 名稱 | 說明 |
60
+ |---|---|---|
61
+ | `endUsers` | 終端使用者(非技術人員) | 使用產品但不編寫程式碼的人。 |
62
+ | `developers` | 整合您的產品/API 的開發人員 | 將此添加到其專案中的工程師。 |
63
+ | `devops` | DevOps / SRE / 基礎設施團隊 | 部署、監控和維護系統的團隊。 |
64
+ | `decisionMakers`| 技術決策者 | 評估或規劃實施的架構師或主管。 |
65
+ | `supportTeams` | 支援團隊 | 協助他人使用產品的人員。 |
66
+ | `mixedTechnical`| 混合技術受眾 | 開發人員、DevOps 和其他技術使用者。 |
67
+
68
+ #### `readerKnowledgeLevel`
69
+ 定義讀者通常在接觸文件時已具備的知識。這會調整文件中假設的基礎知識量。
70
+
71
+ | 選項 | 名稱 | 說明 |
72
+ |---|---|---|
73
+ | `completeBeginners` | 完全是初學者,從零開始 | 完全不熟悉此領域/技術。 |
74
+ | `domainFamiliar` | 以前使用過類似工具 | 了解問題領域,但對此特定解決方案不熟悉。 |
75
+ | `experiencedUsers` | 是專家,試圖做一些特定的事情 | 需要參考資料或進階主題的常規使用者。 |
76
+ | `emergencyTroubleshooting`| 緊急/故障排除 | 有東西壞了,需要快速修復。 |
77
+ | `exploringEvaluating` | 正在將此工具與其他工具進行評估 | 試圖了解這是否符合他們的需求。 |
78
+
79
+ #### `documentationDepth`
80
+ 定義文件的全面程度。
81
+
82
+ | 選項 | 名稱 | 說明 |
83
+ |---|---|---|
84
+ | `essentialOnly` | 僅包含必要內容 | 涵蓋 80% 的使用案例,保持簡潔。 |
85
+ | `balancedCoverage`| 均衡的涵蓋範圍 | 具有良好深度和實用範例 [推薦]。 |
86
+ | `comprehensive` | 全面 | 涵蓋所有功能、邊緣案例和進階場景。 |
87
+ | `aiDecide` | 讓 AI 決定 | 分析程式碼複雜性並建議適當的深度。 |
88
+
89
+ ### 自訂指令
90
+
91
+ 為了更精細的控制,您可以提供自由文字指令。
92
+
93
+ | 參數 | 說明 |
94
+ |---|---|
95
+ | `rules` | 一個多行字串,您可以在其中定義特定的文件生成規則(例如,「始終包含效能基準測試」)。 |
96
+ | `targetAudience`| 一個多行字串,用以比預設選項更詳細地描述您的特定目標受眾。 |
97
+
98
+ ### 語言與路徑設定
99
+
100
+ 這些設定控制本地化和檔案位置。
101
+
102
+ | 參數 | 說明 |
103
+ |---|---|
104
+ | `locale` | 文件的主要語言(例如,`en`、`zh`)。 |
105
+ | `translateLanguages` | 要將文件翻譯成的語言代碼列表(例如,`[ja, fr, es]`)。 |
106
+ | `docsDir` | 儲存生成文件的目錄。 |
107
+ | `sourcesPath` | 供 DocSmith 分析的原始碼路徑或 glob 模式列表(例如,`['./src', './lib/**/*.js']`)。 |
108
+ | `glossary` | 包含專案特定術語的 markdown 檔案(`@glossary.md`)路徑,以確保翻譯一致。 |
109
+
110
+ ## config.yaml 範例
111
+
112
+ 這是一個完整的設定檔範例。您可以隨時直接編輯此檔案以變更設定。
113
+
114
+ ```yaml Example config.yaml icon=logos:yaml
115
+ # 用於文件發布的專案資訊
116
+ projectName: AIGNE DocSmith
117
+ projectDesc: 一個由 AI 驅動的文件生成工具。
118
+ projectLogo: https://docsmith.aigne.io/image-bin/uploads/def424c20bbdb3c77483894fe0e22819.png
119
+
120
+ # =============================================================================
121
+ # 文件設定
122
+ # =============================================================================
123
+
124
+ # 目的:您希望讀者達成的​​主要成果是什麼?
125
+ # 選項:getStarted, completeTasks, findAnswers, understandSystem, solveProblems, mixedPurpose
126
+ documentPurpose:
127
+ - completeTasks
128
+ - findAnswers
129
+
130
+ # 目標受眾:誰最常閱讀此文件?
131
+ # 選項:endUsers, developers, devops, decisionMakers, supportTeams, mixedTechnical
132
+ targetAudienceTypes:
133
+ - developers
134
+
135
+ # 讀者知識水平:讀者通常在接觸文件時已具備什麼知識?
136
+ # 選項:completeBeginners, domainFamiliar, experiencedUsers, emergencyTroubleshooting, exploringEvaluating
137
+ readerKnowledgeLevel: domainFamiliar
138
+
139
+ # 文件深度:文件應該有多全面?
140
+ # 選項:essentialOnly, balancedCoverage, comprehensive, aiDecide
141
+ documentationDepth: balancedCoverage
142
+
143
+ # 自訂規則:定義特定的文件生成規則和要求
144
+ rules: |+
145
+
146
+
147
+ # 目標受眾:描述您的特定目標受眾及其特徵
148
+ targetAudience: |+
149
+
150
+
151
+ # 詞彙表:包含專案特定術語和定義的 markdown 檔案路徑
152
+ # glossary: "@glossary.md"
153
+
154
+ # 文件的主要語言
155
+ locale: en
156
+
157
+ # 要將文件翻譯成的語言列表
158
+ # translateLanguages:
159
+ # - zh
160
+ # - fr
161
+
162
+ # 儲存生成文件的目錄
163
+ docsDir: .aigne/doc-smith/docs
164
+
165
+ # 要分析的原始碼路徑
166
+ sourcesPath:
167
+ - ./
168
+ ```
169
+
170
+ 設定完成後,您就可以開始建立符合您專案需求的文件了。下一步是執行生成指令。
171
+
172
+ ➡️ **下一步:** [生成文件](./features-generate-documentation.md)