@tailor-platform/erp-kit 0.1.2 → 0.2.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 (325) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +81 -12
  3. package/dist/cli.js +1070 -450
  4. package/package.json +11 -8
  5. package/schemas/module/model.yml +5 -0
  6. package/skills/{app-compose-1-requirement-analysis → erp-kit-app-1-requirements}/SKILL.md +2 -2
  7. package/skills/{app-compose-2-requirements-breakdown → erp-kit-app-2-breakdown}/SKILL.md +3 -3
  8. package/skills/{app-compose-3-doc-review → erp-kit-app-3-doc-review}/SKILL.md +2 -2
  9. package/skills/{app-compose-4-design-mock → erp-kit-app-4-design}/SKILL.md +3 -3
  10. package/skills/{app-compose-5-design-mock-review → erp-kit-app-5-design-review}/SKILL.md +4 -4
  11. package/skills/{app-compose-6-implementation-spec → erp-kit-app-6-impl-spec}/SKILL.md +3 -3
  12. package/skills/{mock-scenario → erp-kit-mock-scenario}/SKILL.md +1 -1
  13. package/skills/{1-module-docs → erp-kit-module-1-docs}/SKILL.md +2 -2
  14. package/skills/{2-module-feature-breakdown → erp-kit-module-2-feature-breakdown}/SKILL.md +13 -9
  15. package/skills/erp-kit-module-2-feature-breakdown/references/naming.md +59 -0
  16. package/skills/{3-module-doc-review → erp-kit-module-3-doc-review}/SKILL.md +83 -25
  17. package/skills/erp-kit-module-4-tdd/SKILL.md +94 -0
  18. package/skills/erp-kit-module-4-tdd/references/cross-module-dependency.md +133 -0
  19. package/skills/{4-module-tdd-implementation → erp-kit-module-4-tdd}/references/db-relations.md +5 -1
  20. package/skills/{4-module-tdd-implementation → erp-kit-module-4-tdd}/references/exports.md +1 -1
  21. package/skills/erp-kit-module-4-tdd/references/generated-code.md +32 -0
  22. package/skills/{5-module-implementation-review → erp-kit-module-5-impl-review}/SKILL.md +46 -44
  23. package/skills/erp-kit-module-5-impl-review/references/commands.md +62 -0
  24. package/skills/erp-kit-module-5-impl-review/references/errors.md +10 -0
  25. package/skills/{5-module-implementation-review → erp-kit-module-5-impl-review}/references/testing.md +1 -1
  26. package/skills/erp-kit-module-shared/SKILL.md +16 -0
  27. package/skills/erp-kit-module-shared/references/commands.md +203 -0
  28. package/skills/erp-kit-module-shared/references/errors.md +35 -0
  29. package/skills/erp-kit-module-shared/references/queries.md +168 -0
  30. package/skills/erp-kit-module-shared/references/structure.md +36 -0
  31. package/skills/{3-module-doc-review → erp-kit-module-shared}/references/testing.md +4 -3
  32. package/skills/erp-kit-update/SKILL.md +64 -0
  33. package/src/cli.doc.test.ts +65 -0
  34. package/src/cli.ts +3 -35
  35. package/src/commands/app/index.ts +3 -3
  36. package/src/commands/check.test.ts +1 -1
  37. package/src/commands/check.ts +2 -2
  38. package/src/commands/index.ts +73 -0
  39. package/src/commands/init.test.ts +22 -5
  40. package/src/commands/init.ts +25 -16
  41. package/src/commands/license.ts +193 -0
  42. package/src/commands/mock/index.ts +2 -2
  43. package/src/commands/mock/start.ts +1 -1
  44. package/src/commands/mock/validate.test.ts +1 -1
  45. package/src/commands/module/generate.ts +35 -0
  46. package/src/commands/module/index.ts +6 -4
  47. package/src/commands/module/list.test.ts +7 -12
  48. package/src/commands/module/list.ts +1 -1
  49. package/src/commands/scaffold-templates.ts +65 -0
  50. package/src/commands/scaffold.test.ts +92 -2
  51. package/src/commands/scaffold.ts +22 -2
  52. package/src/commands/sync-check.test.ts +60 -1
  53. package/src/commands/sync-check.ts +35 -2
  54. package/src/generator/generate-code.test.ts +200 -0
  55. package/src/generator/generate-code.ts +260 -0
  56. package/src/generator/parse-command-doc.test.ts +159 -0
  57. package/src/generator/parse-command-doc.ts +116 -0
  58. package/src/integration.test.ts +2 -2
  59. package/src/module.ts +6 -6
  60. package/src/modules/item-management/README.md +38 -0
  61. package/src/modules/item-management/command/activateItem.generated.ts +6 -0
  62. package/src/modules/item-management/command/activateItem.test.ts +76 -0
  63. package/src/modules/item-management/command/activateItem.ts +42 -0
  64. package/src/modules/item-management/command/assignItemToTaxonomy.generated.ts +6 -0
  65. package/src/modules/item-management/command/assignItemToTaxonomy.test.ts +88 -0
  66. package/src/modules/item-management/command/assignItemToTaxonomy.ts +63 -0
  67. package/src/modules/item-management/command/createItem.generated.ts +6 -0
  68. package/src/modules/item-management/command/createItem.test.ts +152 -0
  69. package/src/modules/item-management/command/createItem.ts +72 -0
  70. package/src/modules/item-management/command/createTaxonomyNode.generated.ts +6 -0
  71. package/src/modules/item-management/command/createTaxonomyNode.test.ts +126 -0
  72. package/src/modules/item-management/command/createTaxonomyNode.ts +70 -0
  73. package/src/modules/item-management/command/deactivateItem.generated.ts +6 -0
  74. package/src/modules/item-management/command/deactivateItem.test.ts +76 -0
  75. package/src/modules/item-management/command/deactivateItem.ts +42 -0
  76. package/src/modules/item-management/command/deleteItem.generated.ts +6 -0
  77. package/src/modules/item-management/command/deleteItem.test.ts +61 -0
  78. package/src/modules/item-management/command/deleteItem.ts +38 -0
  79. package/src/modules/item-management/command/deleteTaxonomyNode.generated.ts +6 -0
  80. package/src/modules/item-management/command/deleteTaxonomyNode.test.ts +73 -0
  81. package/src/modules/item-management/command/deleteTaxonomyNode.ts +50 -0
  82. package/src/modules/item-management/command/moveTaxonomyNode.generated.ts +6 -0
  83. package/src/modules/item-management/command/moveTaxonomyNode.test.ts +136 -0
  84. package/src/modules/item-management/command/moveTaxonomyNode.ts +85 -0
  85. package/src/modules/item-management/command/reactivateItem.generated.ts +6 -0
  86. package/src/modules/item-management/command/reactivateItem.test.ts +76 -0
  87. package/src/modules/item-management/command/reactivateItem.ts +42 -0
  88. package/src/modules/item-management/command/removeItemFromTaxonomy.generated.ts +6 -0
  89. package/src/modules/item-management/command/removeItemFromTaxonomy.test.ts +43 -0
  90. package/src/modules/item-management/command/removeItemFromTaxonomy.ts +30 -0
  91. package/src/modules/item-management/command/updateItem.generated.ts +6 -0
  92. package/src/modules/item-management/command/updateItem.test.ts +178 -0
  93. package/src/modules/item-management/command/updateItem.ts +103 -0
  94. package/src/modules/item-management/command/updateTaxonomyNode.generated.ts +6 -0
  95. package/src/modules/item-management/command/updateTaxonomyNode.test.ts +88 -0
  96. package/src/modules/item-management/command/updateTaxonomyNode.ts +62 -0
  97. package/src/modules/item-management/db/item.ts +47 -0
  98. package/src/modules/item-management/db/itemTaxonomyAssignment.ts +49 -0
  99. package/src/modules/item-management/db/taxonomyNode.ts +34 -0
  100. package/src/modules/item-management/docs/commands/ActivateItem.md +32 -0
  101. package/src/modules/item-management/docs/commands/AssignItemToTaxonomy.md +38 -0
  102. package/src/modules/item-management/docs/commands/CreateItem.md +44 -0
  103. package/src/modules/item-management/docs/commands/CreateTaxonomyNode.md +44 -0
  104. package/src/modules/item-management/docs/commands/DeactivateItem.md +34 -0
  105. package/src/modules/item-management/docs/commands/DeleteItem.md +35 -0
  106. package/src/modules/item-management/docs/commands/DeleteTaxonomyNode.md +39 -0
  107. package/src/modules/item-management/docs/commands/MoveTaxonomyNode.md +45 -0
  108. package/src/modules/item-management/docs/commands/ReactivateItem.md +34 -0
  109. package/src/modules/item-management/docs/commands/RemoveItemFromTaxonomy.md +30 -0
  110. package/src/modules/item-management/docs/commands/UpdateItem.md +55 -0
  111. package/src/modules/item-management/docs/commands/UpdateTaxonomyNode.md +36 -0
  112. package/src/modules/item-management/docs/features/item-lifecycle.md +60 -0
  113. package/src/modules/item-management/docs/features/item-taxonomy.md +65 -0
  114. package/src/modules/item-management/docs/models/ItemTaxonomyAssignment.md +36 -0
  115. package/src/modules/item-management/docs/models/TaxonomyNode.md +47 -0
  116. package/src/modules/item-management/docs/models/item.md +59 -0
  117. package/src/modules/item-management/docs/queries/CalculateNodeDepth.md +36 -0
  118. package/src/modules/item-management/docs/queries/CalculateSubtreeDepth.md +40 -0
  119. package/src/modules/item-management/docs/queries/DetectCircularReference.md +41 -0
  120. package/src/modules/item-management/docs/queries/GetItem.md +38 -0
  121. package/src/modules/item-management/docs/queries/GetItemTaxonomyAssignment.md +29 -0
  122. package/src/modules/item-management/docs/queries/GetTaxonomyNode.md +35 -0
  123. package/src/modules/item-management/docs/queries/GetTaxonomyNodeAssignments.md +29 -0
  124. package/src/modules/item-management/docs/queries/GetTaxonomyNodeChildren.md +29 -0
  125. package/src/modules/item-management/generated/enums.ts +9 -0
  126. package/src/modules/item-management/generated/kysely-tailordb.ts +62 -0
  127. package/src/modules/item-management/index.ts +53 -0
  128. package/src/modules/item-management/lib/_db_deps.ts +13 -0
  129. package/src/modules/item-management/lib/errors.generated.ts +117 -0
  130. package/src/modules/item-management/lib/permissions.generated.ts +17 -0
  131. package/src/modules/item-management/lib/types.ts +19 -0
  132. package/src/modules/item-management/module.ts +97 -0
  133. package/src/modules/item-management/query/calculateNodeDepth.generated.ts +5 -0
  134. package/src/modules/item-management/query/calculateNodeDepth.test.ts +56 -0
  135. package/src/modules/item-management/query/calculateNodeDepth.ts +28 -0
  136. package/src/modules/item-management/query/calculateSubtreeDepth.generated.ts +5 -0
  137. package/src/modules/item-management/query/calculateSubtreeDepth.test.ts +75 -0
  138. package/src/modules/item-management/query/calculateSubtreeDepth.ts +29 -0
  139. package/src/modules/item-management/query/detectCircularReference.generated.ts +5 -0
  140. package/src/modules/item-management/query/detectCircularReference.test.ts +61 -0
  141. package/src/modules/item-management/query/detectCircularReference.ts +32 -0
  142. package/src/modules/item-management/query/getItem.generated.ts +5 -0
  143. package/src/modules/item-management/query/getItem.test.ts +67 -0
  144. package/src/modules/item-management/query/getItem.ts +20 -0
  145. package/src/modules/item-management/query/getItemTaxonomyAssignment.generated.ts +5 -0
  146. package/src/modules/item-management/query/getItemTaxonomyAssignment.test.ts +25 -0
  147. package/src/modules/item-management/query/getItemTaxonomyAssignment.ts +18 -0
  148. package/src/modules/item-management/query/getTaxonomyNode.generated.ts +5 -0
  149. package/src/modules/item-management/query/getTaxonomyNode.test.ts +47 -0
  150. package/src/modules/item-management/query/getTaxonomyNode.ts +18 -0
  151. package/src/modules/item-management/query/getTaxonomyNodeAssignments.generated.ts +5 -0
  152. package/src/modules/item-management/query/getTaxonomyNodeAssignments.test.ts +25 -0
  153. package/src/modules/item-management/query/getTaxonomyNodeAssignments.ts +16 -0
  154. package/src/modules/item-management/query/getTaxonomyNodeChildren.generated.ts +5 -0
  155. package/src/modules/item-management/query/getTaxonomyNodeChildren.test.ts +34 -0
  156. package/src/modules/item-management/query/getTaxonomyNodeChildren.ts +16 -0
  157. package/src/modules/item-management/tailor.config.ts +11 -0
  158. package/src/modules/item-management/testing/fixtures.ts +81 -0
  159. package/src/modules/primitives/command/activateCategory.generated.ts +6 -0
  160. package/src/modules/primitives/command/activateCategory.test.ts +11 -29
  161. package/src/modules/primitives/command/activateCategory.ts +27 -34
  162. package/src/modules/primitives/command/activateCurrency.generated.ts +6 -0
  163. package/src/modules/primitives/command/activateCurrency.test.ts +11 -29
  164. package/src/modules/primitives/command/activateCurrency.ts +27 -34
  165. package/src/modules/primitives/command/activateUnit.generated.ts +6 -0
  166. package/src/modules/primitives/command/activateUnit.test.ts +11 -15
  167. package/src/modules/primitives/command/activateUnit.ts +27 -34
  168. package/src/modules/primitives/command/createCategory.generated.ts +6 -0
  169. package/src/modules/primitives/command/createCategory.test.ts +27 -39
  170. package/src/modules/primitives/command/createCategory.ts +53 -62
  171. package/src/modules/primitives/command/createCurrency.generated.ts +6 -0
  172. package/src/modules/primitives/command/createCurrency.test.ts +78 -71
  173. package/src/modules/primitives/command/createCurrency.ts +43 -48
  174. package/src/modules/primitives/command/createExchangeRate.generated.ts +6 -0
  175. package/src/modules/primitives/command/createExchangeRate.test.ts +101 -100
  176. package/src/modules/primitives/command/createExchangeRate.ts +50 -59
  177. package/src/modules/primitives/command/createUnit.generated.ts +6 -0
  178. package/src/modules/primitives/command/createUnit.test.ts +92 -95
  179. package/src/modules/primitives/command/createUnit.ts +54 -57
  180. package/src/modules/primitives/command/deactivateCategory.generated.ts +6 -0
  181. package/src/modules/primitives/command/deactivateCategory.test.ts +27 -28
  182. package/src/modules/primitives/command/deactivateCategory.ts +43 -50
  183. package/src/modules/primitives/command/deactivateCurrency.generated.ts +6 -0
  184. package/src/modules/primitives/command/deactivateCurrency.test.ts +23 -38
  185. package/src/modules/primitives/command/deactivateCurrency.ts +31 -38
  186. package/src/modules/primitives/command/deactivateUnit.generated.ts +6 -0
  187. package/src/modules/primitives/command/deactivateUnit.test.ts +27 -23
  188. package/src/modules/primitives/command/deactivateUnit.ts +39 -49
  189. package/src/modules/primitives/command/setBaseCurrency.generated.ts +6 -0
  190. package/src/modules/primitives/command/setBaseCurrency.test.ts +40 -33
  191. package/src/modules/primitives/command/setBaseCurrency.ts +43 -50
  192. package/src/modules/primitives/command/setReferenceUnit.generated.ts +6 -0
  193. package/src/modules/primitives/command/setReferenceUnit.test.ts +39 -35
  194. package/src/modules/primitives/command/setReferenceUnit.ts +46 -59
  195. package/src/modules/primitives/db/unit.ts +13 -3
  196. package/src/modules/primitives/docs/commands/ActivateCategory.md +1 -2
  197. package/src/modules/primitives/docs/commands/ActivateCurrency.md +1 -2
  198. package/src/modules/primitives/docs/commands/ActivateUnit.md +1 -2
  199. package/src/modules/primitives/docs/commands/CreateCategory.md +1 -4
  200. package/src/modules/primitives/docs/commands/CreateCurrency.md +3 -4
  201. package/src/modules/primitives/docs/commands/CreateExchangeRate.md +4 -5
  202. package/src/modules/primitives/docs/commands/CreateUnit.md +5 -5
  203. package/src/modules/primitives/docs/commands/DeactivateCategory.md +2 -3
  204. package/src/modules/primitives/docs/commands/DeactivateCurrency.md +2 -3
  205. package/src/modules/primitives/docs/commands/DeactivateUnit.md +2 -3
  206. package/src/modules/primitives/docs/commands/SetBaseCurrency.md +2 -3
  207. package/src/modules/primitives/docs/commands/SetReferenceUnit.md +2 -3
  208. package/src/modules/primitives/docs/queries/ConvertAmount.md +3 -5
  209. package/src/modules/primitives/docs/queries/ConvertQuantity.md +3 -5
  210. package/src/modules/primitives/docs/queries/GetBaseCurrency.md +32 -0
  211. package/src/modules/primitives/docs/queries/GetCurrency.md +36 -0
  212. package/src/modules/primitives/docs/queries/GetUnit.md +36 -0
  213. package/src/modules/primitives/docs/queries/GetUoMCategory.md +36 -0
  214. package/src/modules/primitives/docs/queries/ListUnitsByCategory.md +26 -0
  215. package/src/modules/primitives/generated/kysely-tailordb.ts +24 -45
  216. package/src/modules/primitives/index.ts +15 -4
  217. package/src/modules/primitives/lib/errors.generated.ts +112 -0
  218. package/src/modules/primitives/{permissions.ts → lib/permissions.generated.ts} +9 -8
  219. package/src/modules/primitives/module.ts +37 -27
  220. package/src/modules/primitives/query/convertAmount.generated.ts +5 -0
  221. package/src/modules/primitives/query/convertAmount.test.ts +2 -2
  222. package/src/modules/primitives/query/convertAmount.ts +27 -28
  223. package/src/modules/primitives/query/convertQuantity.generated.ts +5 -0
  224. package/src/modules/primitives/query/convertQuantity.test.ts +6 -2
  225. package/src/modules/primitives/query/convertQuantity.ts +49 -57
  226. package/src/modules/primitives/query/getBaseCurrency.generated.ts +5 -0
  227. package/src/modules/primitives/query/getBaseCurrency.test.ts +28 -0
  228. package/src/modules/primitives/query/getBaseCurrency.ts +16 -0
  229. package/src/modules/primitives/query/getCurrency.generated.ts +5 -0
  230. package/src/modules/primitives/query/getCurrency.test.ts +47 -0
  231. package/src/modules/primitives/query/getCurrency.ts +18 -0
  232. package/src/modules/primitives/query/getUnit.generated.ts +5 -0
  233. package/src/modules/primitives/query/getUnit.test.ts +47 -0
  234. package/src/modules/primitives/query/getUnit.ts +18 -0
  235. package/src/modules/primitives/query/getUoMCategory.generated.ts +5 -0
  236. package/src/modules/primitives/query/getUoMCategory.test.ts +47 -0
  237. package/src/modules/primitives/query/getUoMCategory.ts +18 -0
  238. package/src/modules/primitives/query/listUnitsByCategory.generated.ts +5 -0
  239. package/src/modules/primitives/query/listUnitsByCategory.ts +16 -0
  240. package/src/modules/primitives/tailor.config.ts +3 -3
  241. package/src/modules/shared/defineCommand.test.ts +23 -10
  242. package/src/modules/shared/defineCommand.ts +23 -10
  243. package/src/modules/shared/internal.ts +1 -0
  244. package/src/modules/shared/requirePermission.test.ts +22 -21
  245. package/src/modules/shared/requirePermission.ts +8 -2
  246. package/src/modules/shared/result.ts +12 -0
  247. package/src/modules/testing/index.ts +36 -11
  248. package/src/modules/user-management/command/activateUser.generated.ts +6 -0
  249. package/src/modules/user-management/command/activateUser.test.ts +27 -27
  250. package/src/modules/user-management/command/activateUser.ts +40 -48
  251. package/src/modules/user-management/command/assignPermissionToRole.generated.ts +6 -0
  252. package/src/modules/user-management/command/assignPermissionToRole.test.ts +42 -43
  253. package/src/modules/user-management/command/assignPermissionToRole.ts +59 -62
  254. package/src/modules/user-management/command/assignRoleToUser.generated.ts +6 -0
  255. package/src/modules/user-management/command/assignRoleToUser.test.ts +70 -63
  256. package/src/modules/user-management/command/assignRoleToUser.ts +63 -66
  257. package/src/modules/user-management/command/createPermission.generated.ts +6 -0
  258. package/src/modules/user-management/command/createPermission.test.ts +45 -38
  259. package/src/modules/user-management/command/createPermission.ts +42 -46
  260. package/src/modules/user-management/command/createRole.generated.ts +6 -0
  261. package/src/modules/user-management/command/createRole.test.ts +30 -29
  262. package/src/modules/user-management/command/createRole.ts +33 -33
  263. package/src/modules/user-management/command/createUser.generated.ts +6 -0
  264. package/src/modules/user-management/command/createUser.test.ts +64 -42
  265. package/src/modules/user-management/command/createUser.ts +54 -56
  266. package/src/modules/user-management/command/deactivateUser.generated.ts +6 -0
  267. package/src/modules/user-management/command/deactivateUser.test.ts +27 -27
  268. package/src/modules/user-management/command/deactivateUser.ts +40 -48
  269. package/src/modules/user-management/command/logAuditEvent.generated.ts +6 -0
  270. package/src/modules/user-management/command/logAuditEvent.test.ts +50 -42
  271. package/src/modules/user-management/command/logAuditEvent.ts +25 -28
  272. package/src/modules/user-management/command/reactivateUser.generated.ts +6 -0
  273. package/src/modules/user-management/command/reactivateUser.test.ts +31 -27
  274. package/src/modules/user-management/command/reactivateUser.ts +40 -48
  275. package/src/modules/user-management/command/revokePermissionFromRole.generated.ts +6 -0
  276. package/src/modules/user-management/command/revokePermissionFromRole.test.ts +52 -51
  277. package/src/modules/user-management/command/revokePermissionFromRole.ts +60 -57
  278. package/src/modules/user-management/command/revokeRoleFromUser.generated.ts +6 -0
  279. package/src/modules/user-management/command/revokeRoleFromUser.test.ts +53 -48
  280. package/src/modules/user-management/command/revokeRoleFromUser.ts +58 -57
  281. package/src/modules/user-management/docs/commands/CreatePermission.md +2 -2
  282. package/src/modules/user-management/docs/commands/CreateRole.md +1 -1
  283. package/src/modules/user-management/generated/enums.ts +11 -11
  284. package/src/modules/user-management/generated/kysely-tailordb.ts +27 -56
  285. package/src/modules/user-management/index.ts +2 -2
  286. package/src/modules/user-management/lib/errors.generated.ts +67 -0
  287. package/src/modules/user-management/{permissions.ts → lib/permissions.generated.ts} +8 -7
  288. package/src/modules/user-management/module.ts +22 -22
  289. package/src/modules/user-management/tailor.config.ts +3 -3
  290. package/src/schemas.ts +1 -1
  291. package/skills/1-module-docs/references/structure.md +0 -22
  292. package/skills/2-module-feature-breakdown/references/commands.md +0 -48
  293. package/skills/2-module-feature-breakdown/references/structure.md +0 -22
  294. package/skills/3-module-doc-review/references/commands.md +0 -54
  295. package/skills/3-module-doc-review/references/models.md +0 -29
  296. package/skills/4-module-tdd-implementation/SKILL.md +0 -74
  297. package/skills/4-module-tdd-implementation/references/commands.md +0 -45
  298. package/skills/4-module-tdd-implementation/references/errors.md +0 -7
  299. package/skills/4-module-tdd-implementation/references/models.md +0 -30
  300. package/skills/4-module-tdd-implementation/references/structure.md +0 -22
  301. package/skills/4-module-tdd-implementation/references/testing.md +0 -37
  302. package/skills/5-module-implementation-review/references/commands.md +0 -45
  303. package/skills/5-module-implementation-review/references/errors.md +0 -7
  304. package/skills/5-module-implementation-review/references/exports.md +0 -8
  305. package/skills/5-module-implementation-review/references/models.md +0 -30
  306. package/src/modules/primitives/lib/errors.ts +0 -138
  307. package/src/modules/user-management/lib/errors.ts +0 -81
  308. /package/skills/{app-compose-1-requirement-analysis → erp-kit-app-1-requirements}/references/structure.md +0 -0
  309. /package/skills/{app-compose-2-requirements-breakdown → erp-kit-app-2-breakdown}/references/screen-detailview.md +0 -0
  310. /package/skills/{app-compose-2-requirements-breakdown → erp-kit-app-2-breakdown}/references/screen-form.md +0 -0
  311. /package/skills/{app-compose-2-requirements-breakdown → erp-kit-app-2-breakdown}/references/screen-listview.md +0 -0
  312. /package/skills/{app-compose-2-requirements-breakdown → erp-kit-app-2-breakdown}/references/structure.md +0 -0
  313. /package/skills/{app-compose-3-doc-review → erp-kit-app-3-doc-review}/references/structure.md +0 -0
  314. /package/skills/{app-compose-4-design-mock → erp-kit-app-4-design}/references/component.md +0 -0
  315. /package/skills/{app-compose-4-design-mock → erp-kit-app-4-design}/references/screen-detailview.md +0 -0
  316. /package/skills/{app-compose-4-design-mock → erp-kit-app-4-design}/references/screen-form.md +0 -0
  317. /package/skills/{app-compose-4-design-mock → erp-kit-app-4-design}/references/screen-listview.md +0 -0
  318. /package/skills/{app-compose-4-design-mock → erp-kit-app-4-design}/references/structure.md +0 -0
  319. /package/skills/{app-compose-5-design-mock-review → erp-kit-app-5-design-review}/references/component.md +0 -0
  320. /package/skills/{app-compose-5-design-mock-review → erp-kit-app-5-design-review}/references/screen-detailview.md +0 -0
  321. /package/skills/{app-compose-5-design-mock-review → erp-kit-app-5-design-review}/references/screen-form.md +0 -0
  322. /package/skills/{app-compose-5-design-mock-review → erp-kit-app-5-design-review}/references/screen-listview.md +0 -0
  323. /package/skills/{app-compose-6-implementation-spec → erp-kit-app-6-impl-spec}/references/auth.md +0 -0
  324. /package/skills/{app-compose-6-implementation-spec → erp-kit-app-6-impl-spec}/references/structure.md +0 -0
  325. /package/skills/{2-module-feature-breakdown → erp-kit-module-4-tdd}/references/models.md +0 -0
@@ -1,22 +0,0 @@
1
- # Module Directory Structure
2
-
3
- ```
4
- src/
5
- ├── db/ # Database models (one file per model)
6
- ├── executor/ # Async executors (record triggers, job functions)
7
- ├── command/ # Domain commands + tests (*.test.ts co-located)
8
- ├── lib/ # Internal shared code (errors.ts, types.ts)
9
- ├── testing/ # Test fixtures and helpers
10
- ├── generated/ # Auto-generated code (do not edit)
11
- ├── index.ts # Public exports
12
- └── module.ts # Module definition
13
- ```
14
-
15
- ## Rules
16
-
17
- - `db/`: Only documentable model definitions, no helpers
18
- - `executor/`: Async executors as factory functions (see executors.md)
19
- - `command/`: Domain commands + co-located tests, no utilities
20
- - `lib/`: Internal errors and types (not documented)
21
- - `testing/`: Fixtures for tests only
22
- - Run `pnpm generate` after modifying `db/` models
@@ -1,37 +0,0 @@
1
- # Testing Patterns
2
-
3
- ## Test Coverage Goal
4
-
5
- Tests should cover all paths in the corresponding `docs/commands/*.md`:
6
-
7
- - **Process Flow**: Each branch in the mermaid flowchart = one test case
8
- - **Error Scenarios**: Each error code listed = one test case
9
- - **Idempotent paths**: If flowchart shows "Already exists? → Return existing"
10
-
11
- ## Mock Database
12
-
13
- ```typescript
14
- const { db, spies } = createMockDb<DB>();
15
-
16
- // Single return
17
- spies.select.mockReturnValue(entity);
18
-
19
- // Sequential returns (in query execution order)
20
- spies.select.mockReturnValueOnce(first).mockReturnValueOnce(second);
21
- ```
22
-
23
- ## Custom Fields Passthrough
24
-
25
- For `makeCreateX` factory commands, add one test verifying custom fields reach `.values()`:
26
-
27
- - Instantiate with concrete type: `makeCreateX<{ myField: string }>()`
28
- - Assert with `spies.values`: `expect(spies.values).toHaveBeenNthCalledWith(1, expect.objectContaining({ myField: "value" }))`
29
- - Use `toHaveBeenNthCalledWith(n, ...)` when multiple inserts occur (e.g., audit events)
30
-
31
- ## Fixtures (`src/testing/fixtures.ts`)
32
-
33
- - Import `Schema` from `lib/types` (not `Namespace` from generated code)
34
- - Pattern: `export const baseEntity = { ... } as const satisfies Entity<Schema>`
35
- - Fixed IDs for traceability: `"entity-1"`
36
- - Consistent timestamp: `new Date("2024-01-01T00:00:00.000Z")`
37
- - `updatedAt: null` for base fixtures
@@ -1,45 +0,0 @@
1
- # Command Implementation
2
-
3
- ## Dual Function Pattern
4
-
5
- Two functions per operation: internal `_fn` and public `fn`.
6
-
7
- **Internal function (`_myFunction`):**
8
-
9
- - Takes concrete `DB` type from `generated/kysely-tailordb`
10
- - Return type uses `Schema` from `lib/types`: `Promise<{ entity: Entity<Schema> }>`
11
- - Contains actual implementation
12
-
13
- **Public function (`myFunction`):**
14
-
15
- - Generic signature: `<T extends { Entity: object }>(db: Kysely<T>, ...)`
16
- - Return type uses generic `T`: `Promise<{ entity: Entity<T> }>`
17
- - Delegates to internal with type casting: `_fn(db as unknown as DB, ...) as unknown as Result`
18
-
19
- ## Implementation Considerations
20
-
21
- - **Validation**: Check referenced entities exist before operating
22
- - **Idempotency**: For assign/revoke, return existing instead of throwing
23
- - **Return format**: Wrap in object `{ entity }` not just `entity`
24
-
25
- ## Conventions
26
-
27
- - Input types: exported interfaces (`export interface MyFunctionInput`)
28
- - Use `.executeTakeFirst()` for single results
29
- - Include JSDoc: `/** Function: name \n Description */`
30
-
31
- ## State Transitions
32
-
33
- For commands that transition between statuses, accept `from?: string[]` with a default:
34
-
35
- ```typescript
36
- from?: string[]; // Default: ["ACTIVE"]
37
-
38
- const validFromStatuses = input.from ?? ["ACTIVE"];
39
- if (!validFromStatuses.includes(user.status)) {
40
- throw new InvalidStatusTransitionError(user.status, targetStatus);
41
- }
42
- ```
43
-
44
- - Default `from` contains the base valid source status
45
- - Parent modules can override to allow transitions from additional statuses
@@ -1,7 +0,0 @@
1
- # Error Classes
2
-
3
- Naming convention:
4
-
5
- - `name`: Class name exactly, `as const`
6
- - `code`: SCREAMING_SNAKE_CASE, `as const`
7
- - Constructor includes context (IDs, values)
@@ -1,8 +0,0 @@
1
- # Module Exports
2
-
3
- Export order:
4
-
5
- 1. `defineModule` from module.ts
6
- 2. Generated types (enum values + types separately)
7
- 3. Error classes (for typed catch blocks)
8
- 4. Domain functions with input types
@@ -1,30 +0,0 @@
1
- # Database Models
2
-
3
- ## Factory Function Pattern
4
-
5
- ```typescript
6
- export function createEntityType(params: {
7
- fields?: Record<string, unknown>;
8
- additionalStatuses?: string[];
9
- });
10
- ```
11
-
12
- - Include `...db.fields.timestamps()`
13
- - Use `.description()` for field docs
14
- - Apply permissions at model level
15
-
16
- ## Stateful Model Enums
17
-
18
- Status enums are tied to the module's state machine. Base module defines core statuses; parent callers can only **extend, not replace**.
19
-
20
- ```typescript
21
- // Good: extension only
22
- const BASE_STATUSES = ["PENDING", "ACTIVE", "INACTIVE"] as const;
23
- const statuses = [...BASE_STATUSES, ...(params.additionalStatuses ?? [])];
24
-
25
- // Bad: allows replacement
26
- const statuses = params.statuses ?? ["PENDING", "ACTIVE", "INACTIVE"];
27
- ```
28
-
29
- - Name parameter `additionalX` to signal extension-only
30
- - Parent modules handle their additional status transitions
@@ -1,138 +0,0 @@
1
- import { createDomainError } from "../../shared/internal";
2
-
3
- export const UoMCategoryNotFoundError = createDomainError(
4
- "UoMCategoryNotFoundError",
5
- "UOM_CATEGORY_NOT_FOUND",
6
- (identifier: string) => `UoM category not found: ${identifier}`,
7
- );
8
-
9
- export const UnitNotFoundError = createDomainError(
10
- "UnitNotFoundError",
11
- "UNIT_NOT_FOUND",
12
- (symbol: string) => `Unit not found: ${symbol}`,
13
- );
14
-
15
- export const IncompatibleUnitsError = createDomainError(
16
- "IncompatibleUnitsError",
17
- "INCOMPATIBLE_UNITS",
18
- (sourceSymbol: string, targetSymbol: string) =>
19
- `Cannot convert between incompatible units: ${sourceSymbol} and ${targetSymbol} belong to different categories`,
20
- );
21
-
22
- export const InactiveUnitError = createDomainError(
23
- "InactiveUnitError",
24
- "INACTIVE_UNIT",
25
- (symbol: string) => `Unit is inactive: ${symbol}`,
26
- );
27
-
28
- export const CurrencyNotFoundError = createDomainError(
29
- "CurrencyNotFoundError",
30
- "CURRENCY_NOT_FOUND",
31
- (code: string) => `Currency not found: ${code}`,
32
- );
33
-
34
- export const InactiveCurrencyError = createDomainError(
35
- "InactiveCurrencyError",
36
- "INACTIVE_CURRENCY",
37
- (code: string) => `Currency is inactive: ${code}`,
38
- );
39
-
40
- export const ExchangeRateNotFoundError = createDomainError(
41
- "ExchangeRateNotFoundError",
42
- "EXCHANGE_RATE_NOT_FOUND",
43
- (sourceCode: string, targetCode: string, date: string) =>
44
- `No exchange rate found for ${sourceCode} to ${targetCode} on or before ${date}`,
45
- );
46
-
47
- export const CannotDeactivateReferenceUnitError = createDomainError(
48
- "CannotDeactivateReferenceUnitError",
49
- "CANNOT_DEACTIVATE_REFERENCE_UNIT",
50
- (unitId: string) => `Cannot deactivate reference unit: ${unitId}. Change reference unit first.`,
51
- );
52
-
53
- export const CategoryNotActiveError = createDomainError(
54
- "CategoryNotActiveError",
55
- "CATEGORY_NOT_ACTIVE",
56
- (categoryId: string) => `Category is not active: ${categoryId}`,
57
- );
58
-
59
- export const DuplicateUnitSymbolError = createDomainError(
60
- "DuplicateUnitSymbolError",
61
- "DUPLICATE_UNIT_SYMBOL",
62
- (symbol: string, categoryId: string) =>
63
- `Unit with symbol "${symbol}" already exists in category ${categoryId}`,
64
- );
65
-
66
- export const InvalidConversionFactorError = createDomainError(
67
- "InvalidConversionFactorError",
68
- "INVALID_CONVERSION_FACTOR",
69
- (factor: number) => `Conversion factor must be positive: ${factor}`,
70
- );
71
-
72
- export const InvalidRoundingPrecisionError = createDomainError(
73
- "InvalidRoundingPrecisionError",
74
- "INVALID_ROUNDING_PRECISION",
75
- (precision: number) => `Rounding precision must be non-negative: ${precision}`,
76
- );
77
-
78
- export const DuplicateCategoryNameError = createDomainError(
79
- "DuplicateCategoryNameError",
80
- "DUPLICATE_CATEGORY_NAME",
81
- (name: string) => `Category with name "${name}" already exists`,
82
- );
83
-
84
- export const CategoryHasActiveUnitsError = createDomainError(
85
- "CategoryHasActiveUnitsError",
86
- "CATEGORY_HAS_ACTIVE_UNITS",
87
- (categoryId: string) => `Cannot deactivate category ${categoryId}: has active units`,
88
- );
89
-
90
- export const UnitNotInCategoryError = createDomainError(
91
- "UnitNotInCategoryError",
92
- "UNIT_NOT_IN_CATEGORY",
93
- (unitId: string, categoryId: string) =>
94
- `Unit ${unitId} does not belong to category ${categoryId}`,
95
- );
96
-
97
- export const InvalidISOCodeError = createDomainError(
98
- "InvalidISOCodeError",
99
- "INVALID_ISO_CODE",
100
- (code: string) => `Invalid ISO 4217 code: "${code}". Must be exactly 3 uppercase letters.`,
101
- );
102
-
103
- export const DuplicateCurrencyCodeError = createDomainError(
104
- "DuplicateCurrencyCodeError",
105
- "DUPLICATE_CURRENCY_CODE",
106
- (code: string) => `Currency with code "${code}" already exists`,
107
- );
108
-
109
- export const InvalidDecimalPlacesError = createDomainError(
110
- "InvalidDecimalPlacesError",
111
- "INVALID_DECIMAL_PLACES",
112
- (decimalPlaces: number) => `Decimal places must be between 0 and 4: ${decimalPlaces}`,
113
- );
114
-
115
- export const CannotDeactivateBaseCurrencyError = createDomainError(
116
- "CannotDeactivateBaseCurrencyError",
117
- "CANNOT_DEACTIVATE_BASE_CURRENCY",
118
- (currencyId: string) =>
119
- `Cannot deactivate base currency: ${currencyId}. Change base currency first.`,
120
- );
121
-
122
- export const CannotSetInactiveAsBaseCurrencyError = createDomainError(
123
- "CannotSetInactiveAsBaseCurrencyError",
124
- "CANNOT_SET_INACTIVE_AS_BASE_CURRENCY",
125
- (currencyId: string) => `Cannot set inactive currency as base: ${currencyId}. Activate it first.`,
126
- );
127
-
128
- export const SameCurrencyPairError = createDomainError(
129
- "SameCurrencyPairError",
130
- "SAME_CURRENCY_PAIR",
131
- (currencyId: string) => `Source and target currency cannot be the same: ${currencyId}`,
132
- );
133
-
134
- export const InvalidExchangeRateError = createDomainError(
135
- "InvalidExchangeRateError",
136
- "INVALID_EXCHANGE_RATE",
137
- (rate: number) => `Exchange rate must be positive: ${rate}`,
138
- );
@@ -1,81 +0,0 @@
1
- import { createDomainError } from "../../shared/internal";
2
-
3
- export const UserNotFoundError = createDomainError(
4
- "UserNotFoundError",
5
- "USER_NOT_FOUND",
6
- (userId: string) => `User not found: ${userId}`,
7
- );
8
-
9
- export const UserAlreadyExistsError = createDomainError(
10
- "UserAlreadyExistsError",
11
- "USER_ALREADY_EXISTS",
12
- (email: string) => `User with email "${email}" already exists`,
13
- );
14
-
15
- export const UserNotActiveError = createDomainError(
16
- "UserNotActiveError",
17
- "USER_NOT_ACTIVE",
18
- (userId: string, status: string) => `User ${userId} is not active (current status: ${status})`,
19
- );
20
-
21
- export const InvalidEmailError = createDomainError(
22
- "InvalidEmailError",
23
- "INVALID_EMAIL",
24
- (email: string) => `Invalid email format: ${email}`,
25
- );
26
-
27
- export const MissingRequiredFieldError = createDomainError(
28
- "MissingRequiredFieldError",
29
- "MISSING_REQUIRED_FIELD",
30
- (field: string) => `Missing required field: ${field}`,
31
- );
32
-
33
- export const InvalidStatusTransitionError = createDomainError(
34
- "InvalidStatusTransitionError",
35
- "INVALID_STATUS_TRANSITION",
36
- (currentStatus: string, targetStatus: string) =>
37
- `Invalid status transition from ${currentStatus} to ${targetStatus}`,
38
- );
39
-
40
- export const PermissionNotFoundError = createDomainError(
41
- "PermissionNotFoundError",
42
- "PERMISSION_NOT_FOUND",
43
- (permissionId: string) => `Permission not found: ${permissionId}`,
44
- );
45
-
46
- export const DuplicatePermissionKeyError = createDomainError(
47
- "DuplicatePermissionKeyError",
48
- "DUPLICATE_PERMISSION_KEY",
49
- (key: string) => `Permission with key "${key}" already exists`,
50
- );
51
-
52
- export const InvalidPermissionKeyFormatError = createDomainError(
53
- "InvalidPermissionKeyFormatError",
54
- "INVALID_PERMISSION_KEY_FORMAT",
55
- (key: string) => `Invalid permission key format: "${key}". Expected format: resource:action`,
56
- );
57
-
58
- export const RoleNotFoundError = createDomainError(
59
- "RoleNotFoundError",
60
- "ROLE_NOT_FOUND",
61
- (roleId: string) => `Role not found: ${roleId}`,
62
- );
63
-
64
- export const DuplicateRoleNameError = createDomainError(
65
- "DuplicateRoleNameError",
66
- "DUPLICATE_ROLE_NAME",
67
- (name: string) => `Role with name "${name}" already exists`,
68
- );
69
-
70
- export const AssignmentNotFoundError = createDomainError(
71
- "AssignmentNotFoundError",
72
- "ASSIGNMENT_NOT_FOUND",
73
- (sourceType: string, sourceId: string, targetType: string, targetId: string) =>
74
- `Assignment not found: ${sourceType} ${sourceId} -> ${targetType} ${targetId}`,
75
- );
76
-
77
- export const InvalidEventTypeError = createDomainError(
78
- "InvalidEventTypeError",
79
- "INVALID_EVENT_TYPE",
80
- (eventType: string) => `Invalid event type: ${eventType}`,
81
- );