@tailor-platform/erp-kit 0.3.0 → 0.4.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 (616) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/README.md +35 -7
  3. package/dist/cli.mjs +779 -268
  4. package/package.json +5 -4
  5. package/skills/erp-kit-app-1-requirements/SKILL.md +8 -9
  6. package/skills/erp-kit-app-2-requirements-review/references/best-practices-check.md +4 -0
  7. package/skills/erp-kit-app-2-requirements-review/references/boundary-consistency-check.md +4 -0
  8. package/skills/erp-kit-app-3-plan/SKILL.md +27 -27
  9. package/skills/erp-kit-app-3-plan/references/resolver-extraction.md +21 -17
  10. package/skills/erp-kit-app-3-plan/references/screen-extraction.md +15 -1
  11. package/skills/erp-kit-app-3-plan/references/story-extraction.md +8 -2
  12. package/skills/erp-kit-app-5-impl-backend/SKILL.md +9 -11
  13. package/skills/erp-kit-app-5-impl-backend/references/app-config.md +1 -22
  14. package/skills/erp-kit-app-5-impl-backend/references/module-wiring.md +0 -1
  15. package/skills/erp-kit-app-5-impl-backend/references/resolver-patterns.md +13 -4
  16. package/skills/erp-kit-app-6-impl-frontend/SKILL.md +5 -0
  17. package/skills/erp-kit-app-6-impl-frontend/references/pages.md +16 -46
  18. package/skills/erp-kit-app-7-impl-review/SKILL.md +13 -11
  19. package/skills/erp-kit-app-7-impl-review/references/resolver-doc-code-parity.md +16 -17
  20. package/skills/erp-kit-module-1-requirements/SKILL.md +6 -12
  21. package/skills/erp-kit-module-2-requirements-review/SKILL.md +21 -5
  22. package/skills/erp-kit-module-2-requirements-review/references/requirements-report-format.md +19 -0
  23. package/skills/erp-kit-module-3-plan/SKILL.md +2 -4
  24. package/skills/erp-kit-module-4-plan-review/SKILL.md +21 -5
  25. package/skills/erp-kit-module-4-plan-review/references/parity-report-format.md +15 -0
  26. package/skills/erp-kit-module-6-impl-review/SKILL.md +21 -7
  27. package/skills/erp-kit-module-6-impl-review/references/impl-parity-report-format.md +15 -0
  28. package/skills/erp-kit-module-shared/SKILL.md +4 -0
  29. package/src/commands/app/index.ts +28 -17
  30. package/src/commands/check.test.ts +1 -1
  31. package/src/commands/check.ts +2 -35
  32. package/src/commands/doc/index.ts +83 -0
  33. package/src/commands/doc/module.test.ts +119 -0
  34. package/src/commands/doc/module.ts +114 -0
  35. package/src/commands/doc/modules.test.ts +103 -0
  36. package/src/commands/doc/modules.ts +98 -0
  37. package/src/commands/doc/search.test.ts +94 -0
  38. package/src/commands/doc/search.ts +111 -0
  39. package/src/commands/generate-doc.ts +17 -10
  40. package/src/commands/index.ts +20 -8
  41. package/src/commands/lib/command-result.ts +30 -0
  42. package/src/commands/lib/discovery.test.ts +74 -0
  43. package/src/commands/lib/discovery.ts +106 -0
  44. package/src/commands/lib/paths.ts +22 -0
  45. package/src/commands/lib/sync-check-source.test.ts +197 -0
  46. package/src/commands/lib/sync-check-source.ts +100 -0
  47. package/src/commands/lib/sync-check-tests.test.ts +178 -0
  48. package/src/commands/lib/sync-check-tests.ts +69 -0
  49. package/src/commands/mock/index.ts +11 -6
  50. package/src/commands/module/generate.ts +13 -8
  51. package/src/commands/module/index.ts +17 -21
  52. package/src/commands/parse-doc-test-cases.ts +13 -2
  53. package/src/commands/sync-check.test.ts +6 -364
  54. package/src/commands/sync-check.ts +7 -251
  55. package/src/generator/generate-app-code.test.ts +121 -0
  56. package/src/generator/generate-app-code.ts +51 -0
  57. package/src/generator/generate-code-boilerplate.test.ts +1 -1
  58. package/src/generator/generate-code.test.ts +33 -6
  59. package/src/generator/generate-code.ts +12 -226
  60. package/src/generator/generate-errors.ts +34 -0
  61. package/src/generator/generate-permissions.ts +12 -0
  62. package/src/generator/generate-shells.ts +28 -0
  63. package/src/generator/generate-stubs.ts +31 -0
  64. package/src/generator/parse-resolver-doc.test.ts +89 -0
  65. package/src/generator/parse-resolver-doc.ts +125 -0
  66. package/src/generator/scaffold.ts +57 -0
  67. package/src/generator/stub-templates.test.ts +55 -0
  68. package/src/generator/stub-templates.ts +145 -0
  69. package/src/modules/audit/README.md +46 -0
  70. package/src/modules/audit/command/activateAuditPolicy.generated.ts +6 -0
  71. package/src/modules/audit/command/activateAuditPolicy.test.ts +186 -0
  72. package/src/modules/audit/command/activateAuditPolicy.ts +97 -0
  73. package/src/modules/audit/command/createAuditPolicy.generated.ts +6 -0
  74. package/src/modules/audit/command/createAuditPolicy.test.ts +395 -0
  75. package/src/modules/audit/command/createAuditPolicy.ts +131 -0
  76. package/src/modules/audit/command/deactivateAuditPolicy.generated.ts +6 -0
  77. package/src/modules/audit/command/deactivateAuditPolicy.test.ts +138 -0
  78. package/src/modules/audit/command/deactivateAuditPolicy.ts +58 -0
  79. package/src/modules/audit/command/deleteAuditPolicy.generated.ts +6 -0
  80. package/src/modules/audit/command/deleteAuditPolicy.test.ts +121 -0
  81. package/src/modules/audit/command/deleteAuditPolicy.ts +52 -0
  82. package/src/modules/audit/command/logAuditEvent.generated.ts +6 -0
  83. package/src/modules/audit/command/logAuditEvent.test.ts +991 -0
  84. package/src/modules/audit/command/logAuditEvent.ts +357 -0
  85. package/src/modules/audit/command/reactivateAuditPolicy.generated.ts +6 -0
  86. package/src/modules/audit/command/reactivateAuditPolicy.test.ts +143 -0
  87. package/src/modules/audit/command/reactivateAuditPolicy.ts +79 -0
  88. package/src/modules/audit/command/registerAuditableEntity.generated.ts +6 -0
  89. package/src/modules/audit/command/registerAuditableEntity.test.ts +268 -0
  90. package/src/modules/audit/command/registerAuditableEntity.ts +94 -0
  91. package/src/modules/audit/command/replaceAuditPolicy.generated.ts +6 -0
  92. package/src/modules/audit/command/replaceAuditPolicy.test.ts +242 -0
  93. package/src/modules/audit/command/replaceAuditPolicy.ts +91 -0
  94. package/src/modules/audit/command/updateAuditPolicy.generated.ts +6 -0
  95. package/src/modules/audit/command/updateAuditPolicy.test.ts +284 -0
  96. package/src/modules/audit/command/updateAuditPolicy.ts +151 -0
  97. package/src/modules/audit/db/auditEntry.ts +47 -0
  98. package/src/modules/audit/db/auditPolicy.ts +33 -0
  99. package/src/modules/audit/db/auditableEntity.ts +22 -0
  100. package/src/modules/audit/db/changeDetail.ts +28 -0
  101. package/src/modules/audit/db/policyFieldRule.ts +23 -0
  102. package/src/modules/audit/docs/commands/ActivateAuditPolicy.md +69 -0
  103. package/src/modules/audit/docs/commands/CreateAuditPolicy.md +79 -0
  104. package/src/modules/audit/docs/commands/DeactivateAuditPolicy.md +55 -0
  105. package/src/modules/audit/docs/commands/DeleteAuditPolicy.md +55 -0
  106. package/src/modules/audit/docs/commands/LogAuditEvent.md +137 -0
  107. package/src/modules/audit/docs/commands/ReactivateAuditPolicy.md +58 -0
  108. package/src/modules/audit/docs/commands/RegisterAuditableEntity.md +62 -0
  109. package/src/modules/audit/docs/commands/ReplaceAuditPolicy.md +72 -0
  110. package/src/modules/audit/docs/commands/UpdateAuditPolicy.md +77 -0
  111. package/src/modules/audit/docs/features/audit-event-logging.md +126 -0
  112. package/src/modules/audit/docs/features/audit-policy-configuration.md +135 -0
  113. package/src/modules/audit/docs/features/field-level-change-tracking.md +95 -0
  114. package/src/modules/audit/docs/models/AuditEntry.md +55 -0
  115. package/src/modules/audit/docs/models/AuditPolicy.md +79 -0
  116. package/src/modules/audit/docs/models/AuditableEntity.md +38 -0
  117. package/src/modules/audit/docs/models/ChangeDetail.md +55 -0
  118. package/src/modules/audit/docs/models/PolicyFieldRule.md +45 -0
  119. package/src/modules/audit/docs/queries/GetAuditEntry.md +49 -0
  120. package/src/modules/audit/docs/queries/GetAuditPolicy.md +54 -0
  121. package/src/modules/audit/docs/queries/GetAuditSummary.md +84 -0
  122. package/src/modules/audit/docs/queries/GetChangeDetails.md +56 -0
  123. package/src/modules/audit/docs/queries/ListAuditPolicies.md +58 -0
  124. package/src/modules/audit/docs/queries/SearchAuditEntries.md +91 -0
  125. package/src/modules/audit/generated/kysely-tailordb.ts +92 -0
  126. package/src/modules/audit/index.ts +2 -0
  127. package/src/modules/audit/lib/_db_deps.ts +13 -0
  128. package/src/modules/audit/lib/errors.generated.ts +120 -0
  129. package/src/modules/audit/lib/permissions.generated.ts +14 -0
  130. package/src/modules/audit/lib/types.ts +28 -0
  131. package/src/modules/audit/module.ts +57 -0
  132. package/src/modules/audit/permissions.ts +39 -0
  133. package/src/modules/audit/query/getAuditEntry.generated.ts +5 -0
  134. package/src/modules/audit/query/getAuditEntry.test.ts +123 -0
  135. package/src/modules/audit/query/getAuditEntry.ts +36 -0
  136. package/src/modules/audit/query/getAuditPolicy.generated.ts +5 -0
  137. package/src/modules/audit/query/getAuditPolicy.test.ts +169 -0
  138. package/src/modules/audit/query/getAuditPolicy.ts +42 -0
  139. package/src/modules/audit/query/getAuditSummary.generated.ts +5 -0
  140. package/src/modules/audit/query/getAuditSummary.test.ts +632 -0
  141. package/src/modules/audit/query/getAuditSummary.ts +164 -0
  142. package/src/modules/audit/query/getChangeDetails.generated.ts +5 -0
  143. package/src/modules/audit/query/getChangeDetails.test.ts +195 -0
  144. package/src/modules/audit/query/getChangeDetails.ts +42 -0
  145. package/src/modules/audit/query/listAuditPolicies.generated.ts +5 -0
  146. package/src/modules/audit/query/listAuditPolicies.test.ts +239 -0
  147. package/src/modules/audit/query/listAuditPolicies.ts +100 -0
  148. package/src/modules/audit/query/searchAuditEntries.generated.ts +5 -0
  149. package/src/modules/audit/query/searchAuditEntries.test.ts +424 -0
  150. package/src/modules/audit/query/searchAuditEntries.ts +121 -0
  151. package/src/modules/audit/tailor.config.ts +13 -0
  152. package/src/modules/audit/tailor.d.ts +13 -0
  153. package/src/modules/audit/testing/fixtures.ts +215 -0
  154. package/src/modules/business-partner/README.md +60 -0
  155. package/src/modules/business-partner/command/.gitkeep +0 -0
  156. package/src/modules/business-partner/command/activatePartner.generated.ts +6 -0
  157. package/src/modules/business-partner/command/activatePartner.test.ts +59 -0
  158. package/src/modules/business-partner/command/activatePartner.ts +45 -0
  159. package/src/modules/business-partner/command/assignRoleToPartner.generated.ts +6 -0
  160. package/src/modules/business-partner/command/assignRoleToPartner.test.ts +113 -0
  161. package/src/modules/business-partner/command/assignRoleToPartner.ts +72 -0
  162. package/src/modules/business-partner/command/createContactPerson.generated.ts +6 -0
  163. package/src/modules/business-partner/command/createContactPerson.test.ts +193 -0
  164. package/src/modules/business-partner/command/createContactPerson.ts +98 -0
  165. package/src/modules/business-partner/command/createPartner.generated.ts +6 -0
  166. package/src/modules/business-partner/command/createPartner.test.ts +179 -0
  167. package/src/modules/business-partner/command/createPartner.ts +83 -0
  168. package/src/modules/business-partner/command/createPartnerAddress.generated.ts +6 -0
  169. package/src/modules/business-partner/command/createPartnerAddress.test.ts +195 -0
  170. package/src/modules/business-partner/command/createPartnerAddress.ts +119 -0
  171. package/src/modules/business-partner/command/createPartnerBankAccount.generated.ts +6 -0
  172. package/src/modules/business-partner/command/createPartnerBankAccount.test.ts +297 -0
  173. package/src/modules/business-partner/command/createPartnerBankAccount.ts +114 -0
  174. package/src/modules/business-partner/command/createPartnerIdentification.generated.ts +6 -0
  175. package/src/modules/business-partner/command/createPartnerIdentification.test.ts +255 -0
  176. package/src/modules/business-partner/command/createPartnerIdentification.ts +97 -0
  177. package/src/modules/business-partner/command/deactivateContactPerson.generated.ts +6 -0
  178. package/src/modules/business-partner/command/deactivateContactPerson.test.ts +70 -0
  179. package/src/modules/business-partner/command/deactivateContactPerson.ts +54 -0
  180. package/src/modules/business-partner/command/deactivatePartner.generated.ts +6 -0
  181. package/src/modules/business-partner/command/deactivatePartner.test.ts +59 -0
  182. package/src/modules/business-partner/command/deactivatePartner.ts +46 -0
  183. package/src/modules/business-partner/command/deleteContactPerson.generated.ts +6 -0
  184. package/src/modules/business-partner/command/deleteContactPerson.test.ts +61 -0
  185. package/src/modules/business-partner/command/deleteContactPerson.ts +48 -0
  186. package/src/modules/business-partner/command/deletePartner.generated.ts +6 -0
  187. package/src/modules/business-partner/command/deletePartner.test.ts +58 -0
  188. package/src/modules/business-partner/command/deletePartner.ts +46 -0
  189. package/src/modules/business-partner/command/deletePartnerAddress.generated.ts +6 -0
  190. package/src/modules/business-partner/command/deletePartnerAddress.test.ts +74 -0
  191. package/src/modules/business-partner/command/deletePartnerAddress.ts +52 -0
  192. package/src/modules/business-partner/command/deletePartnerBankAccount.generated.ts +6 -0
  193. package/src/modules/business-partner/command/deletePartnerBankAccount.test.ts +55 -0
  194. package/src/modules/business-partner/command/deletePartnerBankAccount.ts +36 -0
  195. package/src/modules/business-partner/command/deletePartnerIdentification.generated.ts +6 -0
  196. package/src/modules/business-partner/command/deletePartnerIdentification.test.ts +47 -0
  197. package/src/modules/business-partner/command/deletePartnerIdentification.ts +37 -0
  198. package/src/modules/business-partner/command/reactivateContactPerson.generated.ts +6 -0
  199. package/src/modules/business-partner/command/reactivateContactPerson.test.ts +48 -0
  200. package/src/modules/business-partner/command/reactivateContactPerson.ts +48 -0
  201. package/src/modules/business-partner/command/reactivatePartner.generated.ts +6 -0
  202. package/src/modules/business-partner/command/reactivatePartner.test.ts +59 -0
  203. package/src/modules/business-partner/command/reactivatePartner.ts +46 -0
  204. package/src/modules/business-partner/command/removeRoleFromPartner.generated.ts +6 -0
  205. package/src/modules/business-partner/command/removeRoleFromPartner.test.ts +82 -0
  206. package/src/modules/business-partner/command/removeRoleFromPartner.ts +73 -0
  207. package/src/modules/business-partner/command/setDefaultPartnerAddress.generated.ts +6 -0
  208. package/src/modules/business-partner/command/setDefaultPartnerAddress.test.ts +60 -0
  209. package/src/modules/business-partner/command/setDefaultPartnerAddress.ts +48 -0
  210. package/src/modules/business-partner/command/setDefaultPartnerBankAccount.generated.ts +6 -0
  211. package/src/modules/business-partner/command/setDefaultPartnerBankAccount.test.ts +56 -0
  212. package/src/modules/business-partner/command/setDefaultPartnerBankAccount.ts +51 -0
  213. package/src/modules/business-partner/command/setPrimaryContactPerson.generated.ts +6 -0
  214. package/src/modules/business-partner/command/setPrimaryContactPerson.test.ts +63 -0
  215. package/src/modules/business-partner/command/setPrimaryContactPerson.ts +55 -0
  216. package/src/modules/business-partner/command/updateContactPerson.generated.ts +6 -0
  217. package/src/modules/business-partner/command/updateContactPerson.test.ts +193 -0
  218. package/src/modules/business-partner/command/updateContactPerson.ts +92 -0
  219. package/src/modules/business-partner/command/updatePartner.generated.ts +6 -0
  220. package/src/modules/business-partner/command/updatePartner.test.ts +101 -0
  221. package/src/modules/business-partner/command/updatePartner.ts +76 -0
  222. package/src/modules/business-partner/command/updatePartnerAddress.generated.ts +6 -0
  223. package/src/modules/business-partner/command/updatePartnerAddress.test.ts +148 -0
  224. package/src/modules/business-partner/command/updatePartnerAddress.ts +64 -0
  225. package/src/modules/business-partner/command/updatePartnerBankAccount.generated.ts +6 -0
  226. package/src/modules/business-partner/command/updatePartnerBankAccount.test.ts +249 -0
  227. package/src/modules/business-partner/command/updatePartnerBankAccount.ts +109 -0
  228. package/src/modules/business-partner/command/updatePartnerIdentification.generated.ts +6 -0
  229. package/src/modules/business-partner/command/updatePartnerIdentification.test.ts +162 -0
  230. package/src/modules/business-partner/command/updatePartnerIdentification.ts +105 -0
  231. package/src/modules/business-partner/db/.gitkeep +0 -0
  232. package/src/modules/business-partner/db/businessPartner.ts +59 -0
  233. package/src/modules/business-partner/db/contactPerson.ts +49 -0
  234. package/src/modules/business-partner/db/partnerAddress.ts +45 -0
  235. package/src/modules/business-partner/db/partnerBankAccount.ts +53 -0
  236. package/src/modules/business-partner/db/partnerIdentification.ts +53 -0
  237. package/src/modules/business-partner/db/partnerRole.ts +43 -0
  238. package/src/modules/business-partner/docs/commands/ActivatePartner.md +39 -0
  239. package/src/modules/business-partner/docs/commands/AssignRoleToPartner.md +49 -0
  240. package/src/modules/business-partner/docs/commands/CreateContactPerson.md +59 -0
  241. package/src/modules/business-partner/docs/commands/CreatePartner.md +54 -0
  242. package/src/modules/business-partner/docs/commands/CreatePartnerAddress.md +60 -0
  243. package/src/modules/business-partner/docs/commands/CreatePartnerBankAccount.md +68 -0
  244. package/src/modules/business-partner/docs/commands/CreatePartnerIdentification.md +59 -0
  245. package/src/modules/business-partner/docs/commands/DeactivateContactPerson.md +42 -0
  246. package/src/modules/business-partner/docs/commands/DeactivatePartner.md +39 -0
  247. package/src/modules/business-partner/docs/commands/DeleteContactPerson.md +43 -0
  248. package/src/modules/business-partner/docs/commands/DeletePartner.md +40 -0
  249. package/src/modules/business-partner/docs/commands/DeletePartnerAddress.md +40 -0
  250. package/src/modules/business-partner/docs/commands/DeletePartnerBankAccount.md +35 -0
  251. package/src/modules/business-partner/docs/commands/DeletePartnerIdentification.md +33 -0
  252. package/src/modules/business-partner/docs/commands/ReactivateContactPerson.md +38 -0
  253. package/src/modules/business-partner/docs/commands/ReactivatePartner.md +39 -0
  254. package/src/modules/business-partner/docs/commands/RemoveRoleFromPartner.md +46 -0
  255. package/src/modules/business-partner/docs/commands/SetDefaultPartnerAddress.md +38 -0
  256. package/src/modules/business-partner/docs/commands/SetDefaultPartnerBankAccount.md +38 -0
  257. package/src/modules/business-partner/docs/commands/SetPrimaryContactPerson.md +43 -0
  258. package/src/modules/business-partner/docs/commands/UpdateContactPerson.md +66 -0
  259. package/src/modules/business-partner/docs/commands/UpdatePartner.md +48 -0
  260. package/src/modules/business-partner/docs/commands/UpdatePartnerAddress.md +46 -0
  261. package/src/modules/business-partner/docs/commands/UpdatePartnerBankAccount.md +64 -0
  262. package/src/modules/business-partner/docs/commands/UpdatePartnerIdentification.md +52 -0
  263. package/src/modules/business-partner/docs/features/contact-person-management.md +70 -0
  264. package/src/modules/business-partner/docs/features/partner-address-management.md +96 -0
  265. package/src/modules/business-partner/docs/features/partner-bank-account.md +70 -0
  266. package/src/modules/business-partner/docs/features/partner-identification.md +76 -0
  267. package/src/modules/business-partner/docs/features/partner-lifecycle.md +59 -0
  268. package/src/modules/business-partner/docs/features/partner-role-classification.md +73 -0
  269. package/src/modules/business-partner/docs/models/BusinessPartner.md +64 -0
  270. package/src/modules/business-partner/docs/models/ContactPerson.md +62 -0
  271. package/src/modules/business-partner/docs/models/PartnerAddress.md +52 -0
  272. package/src/modules/business-partner/docs/models/PartnerBankAccount.md +50 -0
  273. package/src/modules/business-partner/docs/models/PartnerIdentification.md +46 -0
  274. package/src/modules/business-partner/docs/models/PartnerRole.md +42 -0
  275. package/src/modules/business-partner/docs/queries/GetContactPerson.md +34 -0
  276. package/src/modules/business-partner/docs/queries/GetDefaultPartnerAddress.md +40 -0
  277. package/src/modules/business-partner/docs/queries/GetDefaultPartnerBankAccount.md +36 -0
  278. package/src/modules/business-partner/docs/queries/GetPartner.md +35 -0
  279. package/src/modules/business-partner/docs/queries/GetPartnerAddress.md +34 -0
  280. package/src/modules/business-partner/docs/queries/GetPartnerBankAccount.md +34 -0
  281. package/src/modules/business-partner/docs/queries/GetPartnerIdentification.md +34 -0
  282. package/src/modules/business-partner/docs/queries/GetPartnerRole.md +34 -0
  283. package/src/modules/business-partner/docs/queries/GetPrimaryContactPerson.md +36 -0
  284. package/src/modules/business-partner/docs/queries/ListContactPersonsByPartner.md +39 -0
  285. package/src/modules/business-partner/docs/queries/ListPartnerAddressesByPartner.md +41 -0
  286. package/src/modules/business-partner/docs/queries/ListPartnerBankAccountsByPartner.md +39 -0
  287. package/src/modules/business-partner/docs/queries/ListPartnerIdentificationsByPartner.md +41 -0
  288. package/src/modules/business-partner/docs/queries/ListPartnersByRole.md +47 -0
  289. package/src/modules/business-partner/executor/.gitkeep +0 -0
  290. package/src/modules/business-partner/generated/.gitkeep +0 -0
  291. package/src/modules/business-partner/generated/enums.ts +60 -0
  292. package/src/modules/business-partner/generated/kysely-tailordb.ts +114 -0
  293. package/src/modules/business-partner/index.ts +2 -0
  294. package/src/modules/business-partner/lib/_db_deps.ts +17 -0
  295. package/src/modules/business-partner/lib/errors.generated.ts +172 -0
  296. package/src/modules/business-partner/lib/errors.ts +2 -0
  297. package/src/modules/business-partner/lib/permissions.generated.ts +30 -0
  298. package/src/modules/business-partner/lib/types.ts +53 -0
  299. package/src/modules/business-partner/module.ts +181 -0
  300. package/src/modules/business-partner/permissions.ts +3 -0
  301. package/src/modules/business-partner/query/.gitkeep +0 -0
  302. package/src/modules/business-partner/query/getContactPerson.generated.ts +5 -0
  303. package/src/modules/business-partner/query/getContactPerson.test.ts +31 -0
  304. package/src/modules/business-partner/query/getContactPerson.ts +16 -0
  305. package/src/modules/business-partner/query/getDefaultPartnerAddress.generated.ts +5 -0
  306. package/src/modules/business-partner/query/getDefaultPartnerAddress.test.ts +45 -0
  307. package/src/modules/business-partner/query/getDefaultPartnerAddress.ts +30 -0
  308. package/src/modules/business-partner/query/getDefaultPartnerBankAccount.generated.ts +5 -0
  309. package/src/modules/business-partner/query/getDefaultPartnerBankAccount.test.ts +43 -0
  310. package/src/modules/business-partner/query/getDefaultPartnerBankAccount.ts +17 -0
  311. package/src/modules/business-partner/query/getPartner.generated.ts +5 -0
  312. package/src/modules/business-partner/query/getPartner.test.ts +31 -0
  313. package/src/modules/business-partner/query/getPartner.ts +16 -0
  314. package/src/modules/business-partner/query/getPartnerAddress.generated.ts +5 -0
  315. package/src/modules/business-partner/query/getPartnerAddress.test.ts +31 -0
  316. package/src/modules/business-partner/query/getPartnerAddress.ts +16 -0
  317. package/src/modules/business-partner/query/getPartnerBankAccount.generated.ts +5 -0
  318. package/src/modules/business-partner/query/getPartnerBankAccount.test.ts +31 -0
  319. package/src/modules/business-partner/query/getPartnerBankAccount.ts +16 -0
  320. package/src/modules/business-partner/query/getPartnerIdentification.generated.ts +5 -0
  321. package/src/modules/business-partner/query/getPartnerIdentification.test.ts +31 -0
  322. package/src/modules/business-partner/query/getPartnerIdentification.ts +16 -0
  323. package/src/modules/business-partner/query/getPartnerRole.generated.ts +5 -0
  324. package/src/modules/business-partner/query/getPartnerRole.test.ts +31 -0
  325. package/src/modules/business-partner/query/getPartnerRole.ts +19 -0
  326. package/src/modules/business-partner/query/getPrimaryContactPerson.generated.ts +5 -0
  327. package/src/modules/business-partner/query/getPrimaryContactPerson.test.ts +43 -0
  328. package/src/modules/business-partner/query/getPrimaryContactPerson.ts +17 -0
  329. package/src/modules/business-partner/query/listContactPersonsByPartner.generated.ts +5 -0
  330. package/src/modules/business-partner/query/listContactPersonsByPartner.test.ts +77 -0
  331. package/src/modules/business-partner/query/listContactPersonsByPartner.ts +32 -0
  332. package/src/modules/business-partner/query/listPartnerAddressesByPartner.generated.ts +5 -0
  333. package/src/modules/business-partner/query/listPartnerAddressesByPartner.test.ts +71 -0
  334. package/src/modules/business-partner/query/listPartnerAddressesByPartner.ts +37 -0
  335. package/src/modules/business-partner/query/listPartnerBankAccountsByPartner.generated.ts +5 -0
  336. package/src/modules/business-partner/query/listPartnerBankAccountsByPartner.test.ts +59 -0
  337. package/src/modules/business-partner/query/listPartnerBankAccountsByPartner.ts +32 -0
  338. package/src/modules/business-partner/query/listPartnerIdentificationsByPartner.generated.ts +5 -0
  339. package/src/modules/business-partner/query/listPartnerIdentificationsByPartner.test.ts +72 -0
  340. package/src/modules/business-partner/query/listPartnerIdentificationsByPartner.ts +40 -0
  341. package/src/modules/business-partner/query/listPartnersByRole.generated.ts +5 -0
  342. package/src/modules/business-partner/query/listPartnersByRole.test.ts +103 -0
  343. package/src/modules/business-partner/query/listPartnersByRole.ts +47 -0
  344. package/src/modules/business-partner/tailor.config.ts +13 -0
  345. package/src/modules/business-partner/tailor.d.ts +13 -0
  346. package/src/modules/business-partner/testing/fixtures.ts +204 -0
  347. package/src/modules/coa-management/README.md +61 -0
  348. package/src/modules/coa-management/command/.gitkeep +0 -0
  349. package/src/modules/coa-management/command/activateAccount.generated.ts +6 -0
  350. package/src/modules/coa-management/command/activateAccount.test.ts +125 -0
  351. package/src/modules/coa-management/command/activateAccount.ts +105 -0
  352. package/src/modules/coa-management/command/activateChartOfAccounts.generated.ts +6 -0
  353. package/src/modules/coa-management/command/activateChartOfAccounts.test.ts +113 -0
  354. package/src/modules/coa-management/command/activateChartOfAccounts.ts +104 -0
  355. package/src/modules/coa-management/command/createAccount.generated.ts +6 -0
  356. package/src/modules/coa-management/command/createAccount.test.ts +767 -0
  357. package/src/modules/coa-management/command/createAccount.ts +247 -0
  358. package/src/modules/coa-management/command/createAccountGroup.generated.ts +6 -0
  359. package/src/modules/coa-management/command/createAccountGroup.test.ts +494 -0
  360. package/src/modules/coa-management/command/createAccountGroup.ts +207 -0
  361. package/src/modules/coa-management/command/createChartOfAccounts.generated.ts +6 -0
  362. package/src/modules/coa-management/command/createChartOfAccounts.test.ts +502 -0
  363. package/src/modules/coa-management/command/createChartOfAccounts.ts +267 -0
  364. package/src/modules/coa-management/command/deactivateAccount.generated.ts +6 -0
  365. package/src/modules/coa-management/command/deactivateAccount.test.ts +199 -0
  366. package/src/modules/coa-management/command/deactivateAccount.ts +142 -0
  367. package/src/modules/coa-management/command/deactivateChartOfAccounts.generated.ts +6 -0
  368. package/src/modules/coa-management/command/deactivateChartOfAccounts.test.ts +91 -0
  369. package/src/modules/coa-management/command/deactivateChartOfAccounts.ts +88 -0
  370. package/src/modules/coa-management/command/deleteAccount.generated.ts +6 -0
  371. package/src/modules/coa-management/command/deleteAccount.test.ts +122 -0
  372. package/src/modules/coa-management/command/deleteAccount.ts +103 -0
  373. package/src/modules/coa-management/command/deleteAccountGroup.generated.ts +6 -0
  374. package/src/modules/coa-management/command/deleteAccountGroup.test.ts +120 -0
  375. package/src/modules/coa-management/command/deleteAccountGroup.ts +113 -0
  376. package/src/modules/coa-management/command/deleteChartOfAccounts.generated.ts +6 -0
  377. package/src/modules/coa-management/command/deleteChartOfAccounts.test.ts +154 -0
  378. package/src/modules/coa-management/command/deleteChartOfAccounts.ts +133 -0
  379. package/src/modules/coa-management/command/moveAccountGroup.generated.ts +6 -0
  380. package/src/modules/coa-management/command/moveAccountGroup.test.ts +199 -0
  381. package/src/modules/coa-management/command/moveAccountGroup.ts +145 -0
  382. package/src/modules/coa-management/command/reactivateAccount.generated.ts +6 -0
  383. package/src/modules/coa-management/command/reactivateAccount.test.ts +126 -0
  384. package/src/modules/coa-management/command/reactivateAccount.ts +123 -0
  385. package/src/modules/coa-management/command/updateAccount.generated.ts +6 -0
  386. package/src/modules/coa-management/command/updateAccount.test.ts +669 -0
  387. package/src/modules/coa-management/command/updateAccount.ts +370 -0
  388. package/src/modules/coa-management/command/updateAccountGroup.generated.ts +6 -0
  389. package/src/modules/coa-management/command/updateAccountGroup.test.ts +253 -0
  390. package/src/modules/coa-management/command/updateAccountGroup.ts +191 -0
  391. package/src/modules/coa-management/command/updateChartOfAccounts.generated.ts +6 -0
  392. package/src/modules/coa-management/command/updateChartOfAccounts.test.ts +153 -0
  393. package/src/modules/coa-management/command/updateChartOfAccounts.ts +133 -0
  394. package/src/modules/coa-management/db/.gitkeep +0 -0
  395. package/src/modules/coa-management/db/account.ts +119 -0
  396. package/src/modules/coa-management/db/accountGroup.ts +57 -0
  397. package/src/modules/coa-management/db/chartOfAccounts.ts +55 -0
  398. package/src/modules/coa-management/docs/commands/ActivateAccount.md +49 -0
  399. package/src/modules/coa-management/docs/commands/ActivateChartOfAccounts.md +47 -0
  400. package/src/modules/coa-management/docs/commands/CreateAccount.md +94 -0
  401. package/src/modules/coa-management/docs/commands/CreateAccountGroup.md +70 -0
  402. package/src/modules/coa-management/docs/commands/CreateChartOfAccounts.md +72 -0
  403. package/src/modules/coa-management/docs/commands/DeactivateAccount.md +65 -0
  404. package/src/modules/coa-management/docs/commands/DeactivateChartOfAccounts.md +44 -0
  405. package/src/modules/coa-management/docs/commands/DeleteAccount.md +52 -0
  406. package/src/modules/coa-management/docs/commands/DeleteAccountGroup.md +50 -0
  407. package/src/modules/coa-management/docs/commands/DeleteChartOfAccounts.md +48 -0
  408. package/src/modules/coa-management/docs/commands/MoveAccountGroup.md +57 -0
  409. package/src/modules/coa-management/docs/commands/ReactivateAccount.md +50 -0
  410. package/src/modules/coa-management/docs/commands/UpdateAccount.md +102 -0
  411. package/src/modules/coa-management/docs/commands/UpdateAccountGroup.md +62 -0
  412. package/src/modules/coa-management/docs/commands/UpdateChartOfAccounts.md +49 -0
  413. package/src/modules/coa-management/docs/features/account-group-hierarchy.md +81 -0
  414. package/src/modules/coa-management/docs/features/account-lifecycle.md +80 -0
  415. package/src/modules/coa-management/docs/features/account-management.md +114 -0
  416. package/src/modules/coa-management/docs/features/chart-of-accounts-setup.md +86 -0
  417. package/src/modules/coa-management/docs/models/Account.md +84 -0
  418. package/src/modules/coa-management/docs/models/AccountGroup.md +55 -0
  419. package/src/modules/coa-management/docs/models/ChartOfAccounts.md +65 -0
  420. package/src/modules/coa-management/docs/queries/DetectCircularReference.md +52 -0
  421. package/src/modules/coa-management/docs/queries/GetAccount.md +42 -0
  422. package/src/modules/coa-management/docs/queries/GetAccountGroup.md +42 -0
  423. package/src/modules/coa-management/docs/queries/GetChartOfAccounts.md +48 -0
  424. package/src/modules/coa-management/docs/queries/ListAccountGroups.md +42 -0
  425. package/src/modules/coa-management/docs/queries/ListAccounts.md +54 -0
  426. package/src/modules/coa-management/docs/queries/ListUnassignedAccounts.md +40 -0
  427. package/src/modules/coa-management/executor/.gitkeep +0 -0
  428. package/src/modules/coa-management/generated/.gitkeep +0 -0
  429. package/src/modules/coa-management/generated/enums.ts +45 -0
  430. package/src/modules/coa-management/generated/kysely-tailordb.ts +81 -0
  431. package/src/modules/coa-management/index.ts +2 -0
  432. package/src/modules/coa-management/lib/_db_deps.ts +17 -0
  433. package/src/modules/coa-management/lib/errors.generated.ts +162 -0
  434. package/src/modules/coa-management/lib/errors.ts +0 -0
  435. package/src/modules/coa-management/lib/permissions.generated.ts +20 -0
  436. package/src/modules/coa-management/lib/types.ts +22 -0
  437. package/src/modules/coa-management/module.ts +136 -0
  438. package/src/modules/coa-management/permissions.ts +3 -0
  439. package/src/modules/coa-management/query/.gitkeep +0 -0
  440. package/src/modules/coa-management/query/detectCircularReference.generated.ts +5 -0
  441. package/src/modules/coa-management/query/detectCircularReference.test.ts +88 -0
  442. package/src/modules/coa-management/query/detectCircularReference.ts +46 -0
  443. package/src/modules/coa-management/query/getAccount.generated.ts +5 -0
  444. package/src/modules/coa-management/query/getAccount.test.ts +55 -0
  445. package/src/modules/coa-management/query/getAccount.ts +25 -0
  446. package/src/modules/coa-management/query/getAccountGroup.generated.ts +5 -0
  447. package/src/modules/coa-management/query/getAccountGroup.test.ts +55 -0
  448. package/src/modules/coa-management/query/getAccountGroup.ts +25 -0
  449. package/src/modules/coa-management/query/getChartOfAccounts.generated.ts +5 -0
  450. package/src/modules/coa-management/query/getChartOfAccounts.test.ts +79 -0
  451. package/src/modules/coa-management/query/getChartOfAccounts.ts +28 -0
  452. package/src/modules/coa-management/query/listAccountGroups.generated.ts +5 -0
  453. package/src/modules/coa-management/query/listAccountGroups.test.ts +72 -0
  454. package/src/modules/coa-management/query/listAccountGroups.ts +49 -0
  455. package/src/modules/coa-management/query/listAccounts.generated.ts +5 -0
  456. package/src/modules/coa-management/query/listAccounts.test.ts +136 -0
  457. package/src/modules/coa-management/query/listAccounts.ts +82 -0
  458. package/src/modules/coa-management/query/listUnassignedAccounts.generated.ts +5 -0
  459. package/src/modules/coa-management/query/listUnassignedAccounts.test.ts +96 -0
  460. package/src/modules/coa-management/query/listUnassignedAccounts.ts +39 -0
  461. package/src/modules/coa-management/tailor.config.ts +13 -0
  462. package/src/modules/coa-management/tailor.d.ts +13 -0
  463. package/src/modules/coa-management/testing/fixtures.ts +201 -0
  464. package/src/modules/item-management/README.md +1 -1
  465. package/src/modules/organization/README.md +57 -0
  466. package/src/modules/organization/command/.gitkeep +0 -0
  467. package/src/modules/organization/command/activateCompany.generated.ts +6 -0
  468. package/src/modules/organization/command/activateCompany.test.ts +184 -0
  469. package/src/modules/organization/command/activateCompany.ts +92 -0
  470. package/src/modules/organization/command/createCompany.generated.ts +6 -0
  471. package/src/modules/organization/command/createCompany.test.ts +156 -0
  472. package/src/modules/organization/command/createCompany.ts +80 -0
  473. package/src/modules/organization/command/createDepartment.generated.ts +6 -0
  474. package/src/modules/organization/command/createDepartment.test.ts +239 -0
  475. package/src/modules/organization/command/createDepartment.ts +98 -0
  476. package/src/modules/organization/command/createSite.generated.ts +6 -0
  477. package/src/modules/organization/command/createSite.test.ts +262 -0
  478. package/src/modules/organization/command/createSite.ts +155 -0
  479. package/src/modules/organization/command/deactivateCompany.generated.ts +6 -0
  480. package/src/modules/organization/command/deactivateCompany.test.ts +58 -0
  481. package/src/modules/organization/command/deactivateCompany.ts +47 -0
  482. package/src/modules/organization/command/deactivateDepartment.generated.ts +6 -0
  483. package/src/modules/organization/command/deactivateDepartment.test.ts +115 -0
  484. package/src/modules/organization/command/deactivateDepartment.ts +63 -0
  485. package/src/modules/organization/command/deactivateSite.generated.ts +6 -0
  486. package/src/modules/organization/command/deactivateSite.test.ts +53 -0
  487. package/src/modules/organization/command/deactivateSite.ts +47 -0
  488. package/src/modules/organization/command/deleteCompany.generated.ts +6 -0
  489. package/src/modules/organization/command/deleteCompany.test.ts +99 -0
  490. package/src/modules/organization/command/deleteCompany.ts +66 -0
  491. package/src/modules/organization/command/reactivateCompany.generated.ts +6 -0
  492. package/src/modules/organization/command/reactivateCompany.test.ts +58 -0
  493. package/src/modules/organization/command/reactivateCompany.ts +47 -0
  494. package/src/modules/organization/command/reactivateDepartment.generated.ts +6 -0
  495. package/src/modules/organization/command/reactivateDepartment.test.ts +59 -0
  496. package/src/modules/organization/command/reactivateDepartment.ts +47 -0
  497. package/src/modules/organization/command/reactivateSite.generated.ts +6 -0
  498. package/src/modules/organization/command/reactivateSite.test.ts +53 -0
  499. package/src/modules/organization/command/reactivateSite.ts +47 -0
  500. package/src/modules/organization/command/updateCompany.generated.ts +6 -0
  501. package/src/modules/organization/command/updateCompany.test.ts +239 -0
  502. package/src/modules/organization/command/updateCompany.ts +127 -0
  503. package/src/modules/organization/command/updateDepartment.generated.ts +6 -0
  504. package/src/modules/organization/command/updateDepartment.test.ts +232 -0
  505. package/src/modules/organization/command/updateDepartment.ts +120 -0
  506. package/src/modules/organization/command/updateSite.generated.ts +6 -0
  507. package/src/modules/organization/command/updateSite.test.ts +274 -0
  508. package/src/modules/organization/command/updateSite.ts +176 -0
  509. package/src/modules/organization/db/.gitkeep +0 -0
  510. package/src/modules/organization/db/company.ts +44 -0
  511. package/src/modules/organization/db/department.ts +46 -0
  512. package/src/modules/organization/db/site.ts +44 -0
  513. package/src/modules/organization/docs/commands/ActivateCompany.md +62 -0
  514. package/src/modules/organization/docs/commands/CreateCompany.md +49 -0
  515. package/src/modules/organization/docs/commands/CreateDepartment.md +62 -0
  516. package/src/modules/organization/docs/commands/CreateSite.md +74 -0
  517. package/src/modules/organization/docs/commands/DeactivateCompany.md +40 -0
  518. package/src/modules/organization/docs/commands/DeactivateDepartment.md +44 -0
  519. package/src/modules/organization/docs/commands/DeactivateSite.md +38 -0
  520. package/src/modules/organization/docs/commands/DeleteCompany.md +50 -0
  521. package/src/modules/organization/docs/commands/ReactivateCompany.md +39 -0
  522. package/src/modules/organization/docs/commands/ReactivateDepartment.md +37 -0
  523. package/src/modules/organization/docs/commands/ReactivateSite.md +37 -0
  524. package/src/modules/organization/docs/commands/UpdateCompany.md +58 -0
  525. package/src/modules/organization/docs/commands/UpdateDepartment.md +64 -0
  526. package/src/modules/organization/docs/commands/UpdateSite.md +80 -0
  527. package/src/modules/organization/docs/features/company-lifecycle.md +76 -0
  528. package/src/modules/organization/docs/features/department-management.md +66 -0
  529. package/src/modules/organization/docs/features/site-management.md +86 -0
  530. package/src/modules/organization/docs/models/Company.md +60 -0
  531. package/src/modules/organization/docs/models/Department.md +57 -0
  532. package/src/modules/organization/docs/models/Site.md +57 -0
  533. package/src/modules/organization/docs/queries/DetectDepartmentCircularReference.md +50 -0
  534. package/src/modules/organization/docs/queries/GetCompany.md +40 -0
  535. package/src/modules/organization/docs/queries/GetDepartment.md +44 -0
  536. package/src/modules/organization/docs/queries/GetDepartmentChildren.md +40 -0
  537. package/src/modules/organization/docs/queries/GetSite.md +37 -0
  538. package/src/modules/organization/docs/queries/ListDepartmentsByCompany.md +54 -0
  539. package/src/modules/organization/docs/queries/ListSitesByCompany.md +54 -0
  540. package/src/modules/organization/executor/.gitkeep +0 -0
  541. package/src/modules/organization/generated/.gitkeep +0 -0
  542. package/src/modules/organization/generated/kysely-tailordb.ts +77 -0
  543. package/src/modules/organization/index.ts +2 -0
  544. package/src/modules/organization/lib/_db_deps.ts +10 -0
  545. package/src/modules/organization/lib/errors.generated.ts +117 -0
  546. package/src/modules/organization/lib/errors.ts +1 -0
  547. package/src/modules/organization/lib/permissions.generated.ts +19 -0
  548. package/src/modules/organization/lib/types.ts +16 -0
  549. package/src/modules/organization/module.ts +89 -0
  550. package/src/modules/organization/permissions.ts +3 -0
  551. package/src/modules/organization/query/.gitkeep +0 -0
  552. package/src/modules/organization/query/detectDepartmentCircularReference.generated.ts +5 -0
  553. package/src/modules/organization/query/detectDepartmentCircularReference.test.ts +102 -0
  554. package/src/modules/organization/query/detectDepartmentCircularReference.ts +27 -0
  555. package/src/modules/organization/query/getCompany.generated.ts +5 -0
  556. package/src/modules/organization/query/getCompany.test.ts +70 -0
  557. package/src/modules/organization/query/getCompany.ts +16 -0
  558. package/src/modules/organization/query/getDepartment.generated.ts +5 -0
  559. package/src/modules/organization/query/getDepartment.test.ts +85 -0
  560. package/src/modules/organization/query/getDepartment.ts +17 -0
  561. package/src/modules/organization/query/getDepartmentChildren.generated.ts +5 -0
  562. package/src/modules/organization/query/getDepartmentChildren.test.ts +75 -0
  563. package/src/modules/organization/query/getDepartmentChildren.ts +21 -0
  564. package/src/modules/organization/query/getSite.generated.ts +5 -0
  565. package/src/modules/organization/query/getSite.test.ts +55 -0
  566. package/src/modules/organization/query/getSite.ts +16 -0
  567. package/src/modules/organization/query/listDepartmentsByCompany.generated.ts +5 -0
  568. package/src/modules/organization/query/listDepartmentsByCompany.test.ts +124 -0
  569. package/src/modules/organization/query/listDepartmentsByCompany.ts +43 -0
  570. package/src/modules/organization/query/listSitesByCompany.generated.ts +5 -0
  571. package/src/modules/organization/query/listSitesByCompany.test.ts +126 -0
  572. package/src/modules/organization/query/listSitesByCompany.ts +41 -0
  573. package/src/modules/organization/tailor.config.ts +13 -0
  574. package/src/modules/organization/tailor.d.ts +13 -0
  575. package/src/modules/organization/testing/fixtures.ts +155 -0
  576. package/src/modules/primitives/README.md +1 -1
  577. package/src/modules/primitives/command/setBaseCurrency.test.ts +8 -64
  578. package/src/modules/primitives/command/setBaseCurrency.ts +6 -64
  579. package/src/modules/primitives/docs/commands/ActivateCategory.md +1 -1
  580. package/src/modules/primitives/docs/commands/ActivateCurrency.md +1 -1
  581. package/src/modules/primitives/docs/commands/ActivateUnit.md +1 -1
  582. package/src/modules/primitives/docs/commands/CreateExchangeRate.md +2 -2
  583. package/src/modules/primitives/docs/commands/CreateUnit.md +1 -1
  584. package/src/modules/primitives/docs/commands/DeactivateCategory.md +1 -1
  585. package/src/modules/primitives/docs/commands/DeactivateCurrency.md +1 -1
  586. package/src/modules/primitives/docs/commands/DeactivateUnit.md +1 -1
  587. package/src/modules/primitives/docs/commands/SetBaseCurrency.md +13 -23
  588. package/src/modules/primitives/docs/commands/SetReferenceUnit.md +1 -1
  589. package/src/modules/primitives/docs/features/currency-definitions.md +13 -14
  590. package/src/modules/primitives/docs/models/Currency.md +3 -4
  591. package/src/modules/primitives/docs/queries/ConvertAmount.md +2 -2
  592. package/src/modules/primitives/docs/queries/ConvertQuantity.md +2 -2
  593. package/src/modules/primitives/lib/errors.generated.ts +5 -0
  594. package/src/modules/product-management/README.md +1 -1
  595. package/src/modules/user-management/docs/commands/CreatePermission.md +3 -3
  596. package/src/modules/user-management/docs/commands/CreateRole.md +1 -1
  597. package/src/modules/user-management/docs/queries/ListRolePermissionsByRole.md +39 -0
  598. package/src/modules/user-management/docs/queries/ListUserRolesByUser.md +39 -0
  599. package/src/modules/user-management/generated/enums.ts +0 -15
  600. package/src/modules/user-management/generated/kysely-tailordb.ts +0 -11
  601. package/src/shared/createContext.ts +2 -1
  602. package/src/shared/defineQuery.ts +36 -1
  603. package/src/shared/requirePermission.ts +3 -3
  604. package/src/shared/types.ts +3 -0
  605. package/templates/scaffold/app/backend/package.json +4 -3
  606. package/templates/scaffold/app/frontend/eslint.config.js +12 -0
  607. package/templates/scaffold/app/frontend/package.json +10 -7
  608. package/templates/scaffold/app/frontend/src/hooks/use-toast.ts +30 -0
  609. package/templates/scaffold/app/frontend/src/pages/user-management/user/create/components/create-user-form.tsx +3 -2
  610. package/templates/scaffold/app/frontend/vite.config.ts +5 -5
  611. package/src/commands/module/list.test.ts +0 -57
  612. package/src/commands/module/list.ts +0 -64
  613. /package/src/modules/{accounting → audit/db}/.gitkeep +0 -0
  614. /package/src/modules/audit/{.gitkeep → executor/.gitkeep} +0 -0
  615. /package/src/modules/{coa-management/.gitkeep → audit/lib/errors.ts} +0 -0
  616. /package/src/modules/{supplier-management → business-partner}/.gitkeep +0 -0
@@ -0,0 +1,43 @@
1
+ import {
2
+ ok,
3
+ type ReadonlyDB,
4
+ type PaginationInput,
5
+ buildPaginatedResult,
6
+ DEFAULT_PAGE_SIZE,
7
+ } from "../../../shared";
8
+ import type { DB } from "../generated/kysely-tailordb";
9
+
10
+ type DepartmentOrderByField = "name" | "code" | "createdAt";
11
+
12
+ export interface ListDepartmentsByCompanyInput extends PaginationInput<DepartmentOrderByField> {
13
+ companyId: string;
14
+ status?: string;
15
+ parentDepartmentId?: string | null;
16
+ }
17
+
18
+ export async function run(db: ReadonlyDB<DB>, input: ListDepartmentsByCompanyInput) {
19
+ const limit = input.limit ?? DEFAULT_PAGE_SIZE;
20
+ const offset = input.offset ?? 0;
21
+ const orderBy = input.orderBy ?? "name";
22
+ const orderDirection = input.orderDirection ?? "asc";
23
+
24
+ let query = db.selectFrom("Department").selectAll().where("companyId", "=", input.companyId);
25
+
26
+ if (input.status !== undefined) {
27
+ query = query.where("status", "=", input.status);
28
+ }
29
+
30
+ if (input.parentDepartmentId === null) {
31
+ query = query.where("parentDepartmentId", "is", null);
32
+ } else if (input.parentDepartmentId !== undefined) {
33
+ query = query.where("parentDepartmentId", "=", input.parentDepartmentId);
34
+ }
35
+
36
+ const departments = await query
37
+ .orderBy(orderBy, orderDirection)
38
+ .limit(limit + 1)
39
+ .offset(offset)
40
+ .execute();
41
+
42
+ return ok(buildPaginatedResult(departments, limit));
43
+ }
@@ -0,0 +1,5 @@
1
+ // @generated — do not edit
2
+ import { defineQuery } from "../../../shared";
3
+ import { run } from "./listSitesByCompany";
4
+
5
+ export const listSitesByCompany = defineQuery(run);
@@ -0,0 +1,126 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { createMockDb } from "../../../testing/index";
3
+ import type { DB } from "../generated/kysely-tailordb";
4
+ import { activeSite, inactiveSite } from "../testing/fixtures";
5
+ import { run } from "./listSitesByCompany";
6
+
7
+ describe("listSitesByCompany", () => {
8
+ it("returns sites for a company", async () => {
9
+ const { db, spies } = createMockDb<DB>();
10
+ spies.select.mockReturnValue([activeSite, inactiveSite]);
11
+
12
+ const result = await run(db, { companyId: "company-2" });
13
+
14
+ expect(result.ok).toBe(true);
15
+ if (result.ok) {
16
+ expect(result.value.items).toHaveLength(2);
17
+ }
18
+ });
19
+
20
+ it("returns empty list when no sites exist", async () => {
21
+ const { db, spies } = createMockDb<DB>();
22
+ spies.select.mockReturnValue([]);
23
+
24
+ const result = await run(db, { companyId: "company-999" });
25
+
26
+ expect(result.ok).toBe(true);
27
+ if (result.ok) {
28
+ expect(result.value.items).toHaveLength(0);
29
+ expect(result.value.hasNextPage).toBe(false);
30
+ }
31
+ });
32
+
33
+ it("filters by status when provided", async () => {
34
+ const { db, spies } = createMockDb<DB>();
35
+ spies.select.mockReturnValue([activeSite]);
36
+
37
+ const result = await run(db, { companyId: "company-2", status: "ACTIVE" });
38
+
39
+ expect(result.ok).toBe(true);
40
+ if (result.ok) {
41
+ expect(result.value.items).toHaveLength(1);
42
+ }
43
+ });
44
+
45
+ it("filters by type when provided", async () => {
46
+ const { db, spies } = createMockDb<DB>();
47
+ spies.select.mockReturnValue([inactiveSite]);
48
+
49
+ const result = await run(db, { companyId: "company-2", type: "WAREHOUSE" });
50
+
51
+ expect(result.ok).toBe(true);
52
+ if (result.ok) {
53
+ expect(result.value.items).toHaveLength(1);
54
+ }
55
+ });
56
+
57
+ it("filters sites by INACTIVE status", async () => {
58
+ const { db, spies } = createMockDb<DB>();
59
+ spies.select.mockReturnValue([inactiveSite]);
60
+
61
+ const result = await run(db, { companyId: "company-2", status: "INACTIVE" });
62
+
63
+ expect(result.ok).toBe(true);
64
+ if (result.ok) {
65
+ expect(result.value.items).toHaveLength(1);
66
+ expect(result.value.items[0].status).toBe("INACTIVE");
67
+ }
68
+ });
69
+
70
+ it("combines status and type filters", async () => {
71
+ const { db, spies } = createMockDb<DB>();
72
+ spies.select.mockReturnValue([inactiveSite]);
73
+
74
+ const result = await run(db, { companyId: "company-2", status: "INACTIVE", type: "WAREHOUSE" });
75
+
76
+ expect(result.ok).toBe(true);
77
+ if (result.ok) {
78
+ expect(result.value.items).toHaveLength(1);
79
+ expect(result.value.items[0].status).toBe("INACTIVE");
80
+ expect(result.value.items[0].type).toBe("WAREHOUSE");
81
+ }
82
+ });
83
+
84
+ it("returns sites ordered by name", async () => {
85
+ const { db, spies } = createMockDb<DB>();
86
+ spies.select.mockReturnValue([activeSite, inactiveSite]);
87
+
88
+ const result = await run(db, {
89
+ companyId: "company-2",
90
+ orderBy: "name",
91
+ orderDirection: "asc",
92
+ });
93
+
94
+ expect(result.ok).toBe(true);
95
+ if (result.ok) {
96
+ expect(result.value.items).toHaveLength(2);
97
+ }
98
+ });
99
+
100
+ it("returns hasNextPage true when more results exist", async () => {
101
+ const { db, spies } = createMockDb<DB>();
102
+ // Simulate limit+1 strategy: 2 rows returned for limit=1 means hasNextPage=true
103
+ spies.select.mockReturnValue([activeSite, inactiveSite]);
104
+
105
+ const result = await run(db, { companyId: "company-2", limit: 1 });
106
+
107
+ expect(result.ok).toBe(true);
108
+ if (result.ok) {
109
+ expect(result.value.items).toHaveLength(1);
110
+ expect(result.value.hasNextPage).toBe(true);
111
+ }
112
+ });
113
+
114
+ it("respects limit parameter", async () => {
115
+ const { db, spies } = createMockDb<DB>();
116
+ spies.select.mockReturnValue([activeSite]);
117
+
118
+ const result = await run(db, { companyId: "company-2", limit: 5 });
119
+
120
+ expect(result.ok).toBe(true);
121
+ if (result.ok) {
122
+ expect(result.value.items).toHaveLength(1);
123
+ expect(result.value.hasNextPage).toBe(false);
124
+ }
125
+ });
126
+ });
@@ -0,0 +1,41 @@
1
+ import {
2
+ ok,
3
+ type ReadonlyDB,
4
+ type PaginationInput,
5
+ buildPaginatedResult,
6
+ DEFAULT_PAGE_SIZE,
7
+ } from "../../../shared";
8
+ import type { DB } from "../generated/kysely-tailordb";
9
+
10
+ type SiteOrderByField = "name" | "type" | "createdAt";
11
+
12
+ export interface ListSitesByCompanyInput extends PaginationInput<SiteOrderByField> {
13
+ companyId: string;
14
+ status?: string;
15
+ type?: string;
16
+ }
17
+
18
+ export async function run(db: ReadonlyDB<DB>, input: ListSitesByCompanyInput) {
19
+ const limit = input.limit ?? DEFAULT_PAGE_SIZE;
20
+ const offset = input.offset ?? 0;
21
+ const orderBy = input.orderBy ?? "name";
22
+ const orderDirection = input.orderDirection ?? "asc";
23
+
24
+ let query = db.selectFrom("Site").selectAll().where("companyId", "=", input.companyId);
25
+
26
+ if (input.status !== undefined) {
27
+ query = query.where("status", "=", input.status);
28
+ }
29
+
30
+ if (input.type !== undefined) {
31
+ query = query.where("type", "=", input.type);
32
+ }
33
+
34
+ const sites = await query
35
+ .orderBy(orderBy, orderDirection)
36
+ .limit(limit + 1)
37
+ .offset(offset)
38
+ .execute();
39
+
40
+ return ok(buildPaginatedResult(sites, limit));
41
+ }
@@ -0,0 +1,13 @@
1
+ import { defineConfig, definePlugins } from "@tailor-platform/sdk";
2
+ import { kyselyTypePlugin } from "@tailor-platform/sdk/plugin/kysely-type";
3
+ import { enumConstantsPlugin } from "@tailor-platform/sdk/plugin/enum-constants";
4
+
5
+ export default defineConfig({
6
+ name: "organization",
7
+ db: { "main-db": { files: [`./db/*.ts`, `./lib/_db_deps.ts`] } },
8
+ });
9
+
10
+ export const plugins = definePlugins(
11
+ kyselyTypePlugin({ distPath: `./generated/kysely-tailordb.ts` }),
12
+ enumConstantsPlugin({ distPath: "./generated/enums.ts" }),
13
+ );
@@ -0,0 +1,13 @@
1
+ // This file is auto-generated by @tailor-platform/sdk
2
+ // Do not edit this file manually
3
+ // Regenerated automatically when running 'tailor-sdk apply' or 'tailor-sdk generate'
4
+
5
+ declare module "@tailor-platform/sdk" {
6
+ interface AttributeMap {}
7
+ interface AttributeList {
8
+ __tuple?: [];
9
+ }
10
+ interface Env {}
11
+ }
12
+
13
+ export {};
@@ -0,0 +1,155 @@
1
+ import type { Company, Department, Schema, Site } from "../lib/types";
2
+
3
+ // Company fixtures
4
+ export const draftCompany = {
5
+ id: "company-1",
6
+ legalName: "Acme Corp",
7
+ taxId: "TAX-12345",
8
+ registrationNumber: "REG-67890",
9
+ baseCurrencyId: "currency-usd",
10
+ street: "123 Main St",
11
+ city: "Tokyo",
12
+ state: "Tokyo",
13
+ postalCode: "100-0001",
14
+ country: "JP",
15
+ status: "DRAFT",
16
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
17
+ updatedAt: null,
18
+ } as const satisfies Company<Schema>;
19
+
20
+ export const activeCompany = {
21
+ id: "company-2",
22
+ legalName: "Beta Ltd",
23
+ taxId: "TAX-99999",
24
+ registrationNumber: "REG-88888",
25
+ baseCurrencyId: "currency-usd",
26
+ street: "456 Business Ave",
27
+ city: "Osaka",
28
+ state: "Osaka",
29
+ postalCode: "530-0001",
30
+ country: "JP",
31
+ status: "ACTIVE",
32
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
33
+ updatedAt: null,
34
+ } as const satisfies Company<Schema>;
35
+
36
+ export const inactiveCompany = {
37
+ id: "company-3",
38
+ legalName: "Gamma Inc",
39
+ taxId: "TAX-77777",
40
+ registrationNumber: "REG-66666",
41
+ baseCurrencyId: "currency-usd",
42
+ street: "789 Closed Rd",
43
+ city: "Nagoya",
44
+ state: "Aichi",
45
+ postalCode: "460-0001",
46
+ country: "JP",
47
+ status: "INACTIVE",
48
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
49
+ updatedAt: null,
50
+ } as const satisfies Company<Schema>;
51
+
52
+ export const draftCompanyNoCurrency = {
53
+ id: "company-4",
54
+ legalName: "Delta Corp",
55
+ taxId: null,
56
+ registrationNumber: null,
57
+ baseCurrencyId: null,
58
+ street: null,
59
+ city: null,
60
+ state: null,
61
+ postalCode: null,
62
+ country: null,
63
+ status: "DRAFT",
64
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
65
+ updatedAt: null,
66
+ } as const satisfies Company<Schema>;
67
+
68
+ // Site fixtures
69
+ export const activeSite = {
70
+ id: "site-1",
71
+ name: "Tokyo HQ",
72
+ type: "OFFICE",
73
+ companyId: "company-2",
74
+ street: "123 Office St",
75
+ city: "Tokyo",
76
+ state: "Tokyo",
77
+ postalCode: "100-0001",
78
+ country: "JP",
79
+ timezone: "Asia/Tokyo",
80
+ status: "ACTIVE",
81
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
82
+ updatedAt: null,
83
+ } as const satisfies Site<Schema>;
84
+
85
+ export const inactiveSite = {
86
+ id: "site-2",
87
+ name: "Osaka Warehouse",
88
+ type: "WAREHOUSE",
89
+ companyId: "company-2",
90
+ street: "456 Warehouse Rd",
91
+ city: "Osaka",
92
+ state: "Osaka",
93
+ postalCode: "530-0001",
94
+ country: "JP",
95
+ timezone: "Asia/Tokyo",
96
+ status: "INACTIVE",
97
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
98
+ updatedAt: null,
99
+ } as const satisfies Site<Schema>;
100
+
101
+ // Department fixtures
102
+ export const activeDepartment = {
103
+ id: "dept-1",
104
+ code: "ENG",
105
+ name: "Engineering",
106
+ companyId: "company-2",
107
+ parentDepartmentId: null,
108
+ status: "ACTIVE",
109
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
110
+ updatedAt: null,
111
+ } as const satisfies Department<Schema>;
112
+
113
+ export const childDepartment = {
114
+ id: "dept-2",
115
+ code: "ENG-BE",
116
+ name: "Backend Engineering",
117
+ companyId: "company-2",
118
+ parentDepartmentId: "dept-1",
119
+ status: "ACTIVE",
120
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
121
+ updatedAt: null,
122
+ } as const satisfies Department<Schema>;
123
+
124
+ export const grandchildDepartment = {
125
+ id: "dept-3",
126
+ code: "ENG-BE-PLAT",
127
+ name: "Platform Team",
128
+ companyId: "company-2",
129
+ parentDepartmentId: "dept-2",
130
+ status: "ACTIVE",
131
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
132
+ updatedAt: null,
133
+ } as const satisfies Department<Schema>;
134
+
135
+ export const inactiveDepartment = {
136
+ id: "dept-4",
137
+ code: "FIN",
138
+ name: "Finance",
139
+ companyId: "company-2",
140
+ parentDepartmentId: null,
141
+ status: "INACTIVE",
142
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
143
+ updatedAt: null,
144
+ } as const satisfies Department<Schema>;
145
+
146
+ export const otherCompanyDepartment = {
147
+ id: "dept-5",
148
+ code: "ENG",
149
+ name: "Engineering",
150
+ companyId: "company-3",
151
+ parentDepartmentId: null,
152
+ status: "ACTIVE",
153
+ createdAt: new Date("2024-01-01T00:00:00.000Z"),
154
+ updatedAt: null,
155
+ } as const satisfies Department<Schema>;
@@ -13,7 +13,7 @@ This module combines related configuration primitives to simplify dependency man
13
13
  - **Quantity Conversion**: Convert quantities between any two units within the same category using automatic factor calculation
14
14
  - **Rounding Precision**: Configure decimal precision per unit to ensure appropriate rounding for business operations
15
15
  - **Currency Definitions**: Define currencies with ISO 4217 codes, symbols, and decimal precision
16
- - **Base Currency**: Designate a company base currency for reporting and consolidation
16
+ - **Base Currency**: Provide the currency catalog that companies reference for base currency assignment (company→currency mapping is owned by the organization module)
17
17
  - **Exchange Rates**: Maintain date-based exchange rates between currency pairs
18
18
  - **Amount Conversion**: Convert monetary amounts between currencies using applicable rates
19
19
 
@@ -1,83 +1,27 @@
1
1
  import { describe, expect, it } from "vitest";
2
2
  import { createMockDb } from "../../../testing/index";
3
3
  import { Transaction } from "../generated/kysely-tailordb";
4
- import {
5
- CannotSetInactiveAsBaseCurrencyError,
6
- CurrencyNotFoundError,
7
- } from "../lib/errors.generated";
8
- import { baseCurrencyEUR, baseCurrencyUSD, inactiveCurrency } from "../testing/fixtures";
4
+ import { SetBaseCurrencyDeprecatedError } from "../lib/errors.generated";
9
5
  import { run } from "./setBaseCurrency";
10
6
 
11
7
  describe("setBaseCurrency", () => {
12
- // Error cases
13
- it("throws when currency doesn't exist", async () => {
14
- const { db, spies } = createMockDb<Transaction>();
15
- spies.select.mockReturnValue(undefined);
16
-
17
- const result = await run(db, {
18
- currencyId: "nonexistent-currency",
19
- });
20
-
21
- expect(result.ok).toBe(false);
22
- if (!result.ok) {
23
- expect(result.error).toBeInstanceOf(CurrencyNotFoundError);
24
- }
25
- });
26
-
27
- it("throws when currency is inactive", async () => {
28
- const { db, spies } = createMockDb<Transaction>();
29
- spies.select.mockReturnValue(inactiveCurrency);
8
+ it("Calling SetBaseCurrency returns a deprecation error directing the caller to the organization module", async () => {
9
+ const { db } = createMockDb<Transaction>();
30
10
 
31
- const result = await run(db, {
32
- currencyId: inactiveCurrency.id,
33
- });
11
+ const result = await run(db, { currencyId: "any-currency-id" });
34
12
 
35
13
  expect(result.ok).toBe(false);
36
14
  if (!result.ok) {
37
- expect(result.error).toBeInstanceOf(CannotSetInactiveAsBaseCurrencyError);
15
+ expect(result.error).toBeInstanceOf(SetBaseCurrencyDeprecatedError);
38
16
  }
39
17
  });
40
18
 
41
- // Idempotent cases
42
- it("returns currency unchanged when already base", async () => {
19
+ it("No currency is modified when SetBaseCurrency is invoked", async () => {
43
20
  const { db, spies } = createMockDb<Transaction>();
44
- spies.select.mockReturnValue(baseCurrencyUSD); // Already base currency
45
21
 
46
- const result = await run(db, {
47
- currencyId: baseCurrencyUSD.id,
48
- });
22
+ await run(db, { currencyId: "any-currency-id" });
49
23
 
50
- expect(result.ok).toBe(true);
51
- if (result.ok) {
52
- expect(result.value.currency).toEqual(baseCurrencyUSD);
53
- }
24
+ expect(spies.select).not.toHaveBeenCalled();
54
25
  expect(spies.update).not.toHaveBeenCalled();
55
26
  });
56
-
57
- // Success cases
58
- it("changes base currency", async () => {
59
- const { db, spies } = createMockDb<Transaction>();
60
- const newBaseCurrency = {
61
- ...baseCurrencyEUR,
62
- isBaseCurrency: true,
63
- updatedAt: new Date("2024-01-15T00:00:00.000Z"),
64
- };
65
-
66
- spies.select
67
- .mockReturnValueOnce(baseCurrencyEUR) // Target currency lookup
68
- .mockReturnValueOnce(baseCurrencyUSD); // Current base currency lookup
69
- spies.update
70
- .mockReturnValueOnce({ ...baseCurrencyUSD, isBaseCurrency: false }) // Remove base from old
71
- .mockReturnValueOnce(newBaseCurrency); // Set base on new
72
-
73
- const result = await run(db, {
74
- currencyId: baseCurrencyEUR.id,
75
- });
76
-
77
- expect(result.ok).toBe(true);
78
- if (result.ok) {
79
- expect(result.value.currency.isBaseCurrency).toBe(true);
80
- }
81
- expect(spies.update).toHaveBeenCalled();
82
- });
83
27
  });
@@ -1,9 +1,6 @@
1
- import { ok, err } from "../../../shared";
1
+ import { err } from "../../../shared";
2
2
  import { Transaction } from "../generated/kysely-tailordb";
3
- import {
4
- CannotSetInactiveAsBaseCurrencyError,
5
- CurrencyNotFoundError,
6
- } from "../lib/errors.generated";
3
+ import { SetBaseCurrencyDeprecatedError } from "../lib/errors.generated";
7
4
 
8
5
  export interface SetBaseCurrencyInput {
9
6
  currencyId: string;
@@ -12,64 +9,9 @@ export interface SetBaseCurrencyInput {
12
9
  /**
13
10
  * Function: setBaseCurrency
14
11
  *
15
- * Changes the organization's base currency to a different active currency.
16
- * The base currency serves as the default for financial reporting.
12
+ * @deprecated Base currency assignment is per company and owned by the organization module.
13
+ * Use the organization module's company-level base currency assignment instead.
17
14
  */
18
- export async function run(db: Transaction, input: SetBaseCurrencyInput) {
19
- // 1. Find currency by ID
20
- const currency = await db
21
- .selectFrom("Currency")
22
- .selectAll()
23
- .where("id", "=", input.currencyId)
24
- .forUpdate()
25
- .executeTakeFirst();
26
-
27
- // 2. If not found, throw error
28
- if (!currency) {
29
- return err(new CurrencyNotFoundError(input.currencyId));
30
- }
31
-
32
- // 3. Check if currency is active
33
- if (!currency.isActive) {
34
- return err(new CannotSetInactiveAsBaseCurrencyError(input.currencyId));
35
- }
36
-
37
- // 4. If already base currency, return (idempotent)
38
- if (currency.isBaseCurrency) {
39
- return ok({ currency });
40
- }
41
-
42
- // 5. Find current base currency
43
- const currentBase = await db
44
- .selectFrom("Currency")
45
- .selectAll()
46
- .where("isBaseCurrency", "=", true)
47
- .forUpdate()
48
- .executeTakeFirst();
49
-
50
- // 6. Remove base flag from current base
51
- if (currentBase) {
52
- await db
53
- .updateTable("Currency")
54
- .set({
55
- isBaseCurrency: false,
56
- updatedAt: new Date(),
57
- })
58
- .where("id", "=", currentBase.id)
59
- .returningAll()
60
- .executeTakeFirst();
61
- }
62
-
63
- // 7. Set base flag on target currency
64
- const updatedCurrency = await db
65
- .updateTable("Currency")
66
- .set({
67
- isBaseCurrency: true,
68
- updatedAt: new Date(),
69
- })
70
- .where("id", "=", input.currencyId)
71
- .returningAll()
72
- .executeTakeFirst();
73
-
74
- return ok({ currency: updatedCurrency! });
15
+ export function run(_db: Transaction, _input: SetBaseCurrencyInput) {
16
+ return Promise.resolve(err(new SetBaseCurrencyDeprecatedError("")));
75
17
  }
@@ -34,6 +34,6 @@ flowchart TD
34
34
 
35
35
  ## Test Cases
36
36
 
37
- - throws when category doesn
37
+ - throws when category doesn't exist
38
38
  - returns category unchanged when already active
39
39
  - activates inactive category
@@ -33,6 +33,6 @@ flowchart TD
33
33
 
34
34
  ## Test Cases
35
35
 
36
- - throws when currency doesn
36
+ - throws when currency doesn't exist
37
37
  - returns currency unchanged when already active
38
38
  - activates inactive currency
@@ -34,6 +34,6 @@ flowchart TD
34
34
 
35
35
  ## Test Cases
36
36
 
37
- - throws when unit doesn
37
+ - throws when unit doesn't exist
38
38
  - returns unit unchanged when already active
39
39
  - activates inactive unit
@@ -48,9 +48,9 @@ flowchart TD
48
48
 
49
49
  ## Test Cases
50
50
 
51
- - throws when source currency doesn
51
+ - throws when source currency doesn't exist
52
52
  - throws when source currency is inactive
53
- - throws when target currency doesn
53
+ - throws when target currency doesn't exist
54
54
  - throws when target currency is inactive
55
55
  - throws when source and target are the same
56
56
  - throws when rate is not positive
@@ -49,7 +49,7 @@ flowchart TD
49
49
 
50
50
  ## Test Cases
51
51
 
52
- - throws when category doesn
52
+ - throws when category doesn't exist
53
53
  - throws when category is inactive
54
54
  - throws when symbol already exists in category
55
55
  - throws when conversion factor is not positive
@@ -38,7 +38,7 @@ flowchart TD
38
38
 
39
39
  ## Test Cases
40
40
 
41
- - throws when category doesn
41
+ - throws when category doesn't exist
42
42
  - throws when category has active units
43
43
  - returns category unchanged when already inactive
44
44
  - deactivates active category with no active units
@@ -38,7 +38,7 @@ flowchart TD
38
38
 
39
39
  ## Test Cases
40
40
 
41
- - throws when currency doesn
41
+ - throws when currency doesn't exist
42
42
  - throws when attempting to deactivate base currency
43
43
  - returns currency unchanged when already inactive
44
44
  - deactivates active non-base currency
@@ -38,7 +38,7 @@ flowchart TD
38
38
 
39
39
  ## Test Cases
40
40
 
41
- - throws when unit doesn
41
+ - throws when unit doesn't exist
42
42
  - throws when attempting to deactivate reference unit
43
43
  - returns unit unchanged when already inactive
44
44
  - deactivates active non-reference unit