@newpeak/barista-cli 0.1.8 → 0.1.10

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 (340) hide show
  1. package/README.md +10 -10
  2. package/dist/commands/liberica/index.d.ts.map +1 -1
  3. package/dist/commands/liberica/index.js +9 -0
  4. package/dist/commands/liberica/index.js.map +1 -1
  5. package/dist/commands/liberica/materials/create.d.ts.map +1 -1
  6. package/dist/commands/liberica/materials/create.js +13 -6
  7. package/dist/commands/liberica/materials/create.js.map +1 -1
  8. package/dist/commands/liberica/materials/update.js +1 -1
  9. package/dist/commands/liberica/materials/update.js.map +1 -1
  10. package/dist/commands/liberica/mould/get.d.ts +3 -0
  11. package/dist/commands/liberica/mould/get.d.ts.map +1 -0
  12. package/dist/commands/liberica/mould/get.js +90 -0
  13. package/dist/commands/liberica/mould/get.js.map +1 -0
  14. package/dist/commands/liberica/mould/index.d.ts +3 -0
  15. package/dist/commands/liberica/mould/index.d.ts.map +1 -0
  16. package/dist/commands/liberica/mould/index.js +15 -0
  17. package/dist/commands/liberica/mould/index.js.map +1 -0
  18. package/dist/commands/liberica/mould/list.d.ts +3 -0
  19. package/dist/commands/liberica/mould/list.d.ts.map +1 -0
  20. package/dist/commands/liberica/mould/list.js +114 -0
  21. package/dist/commands/liberica/mould/list.js.map +1 -0
  22. package/dist/commands/liberica/mould/set-status.d.ts +3 -0
  23. package/dist/commands/liberica/mould/set-status.d.ts.map +1 -0
  24. package/dist/commands/liberica/mould/set-status.js +84 -0
  25. package/dist/commands/liberica/mould/set-status.js.map +1 -0
  26. package/dist/commands/liberica/mould/stock-in.d.ts +3 -0
  27. package/dist/commands/liberica/mould/stock-in.d.ts.map +1 -0
  28. package/dist/commands/liberica/mould/stock-in.js +160 -0
  29. package/dist/commands/liberica/mould/stock-in.js.map +1 -0
  30. package/dist/commands/liberica/teams/index.d.ts +3 -0
  31. package/dist/commands/liberica/teams/index.d.ts.map +1 -0
  32. package/dist/commands/liberica/teams/index.js +15 -0
  33. package/dist/commands/liberica/teams/index.js.map +1 -0
  34. package/dist/commands/liberica/teams/issues/close.d.ts +3 -0
  35. package/dist/commands/liberica/teams/issues/close.d.ts.map +1 -0
  36. package/dist/commands/liberica/teams/issues/close.js +99 -0
  37. package/dist/commands/liberica/teams/issues/close.js.map +1 -0
  38. package/dist/commands/liberica/teams/issues/create.d.ts +3 -0
  39. package/dist/commands/liberica/teams/issues/create.d.ts.map +1 -0
  40. package/dist/commands/liberica/teams/issues/create.js +255 -0
  41. package/dist/commands/liberica/teams/issues/create.js.map +1 -0
  42. package/dist/commands/liberica/teams/issues/delete.d.ts +3 -0
  43. package/dist/commands/liberica/teams/issues/delete.d.ts.map +1 -0
  44. package/dist/commands/liberica/teams/issues/delete.js +55 -0
  45. package/dist/commands/liberica/teams/issues/delete.js.map +1 -0
  46. package/dist/commands/liberica/teams/issues/get.d.ts +3 -0
  47. package/dist/commands/liberica/teams/issues/get.d.ts.map +1 -0
  48. package/dist/commands/liberica/teams/issues/get.js +68 -0
  49. package/dist/commands/liberica/teams/issues/get.js.map +1 -0
  50. package/dist/commands/liberica/teams/issues/index.d.ts +3 -0
  51. package/dist/commands/liberica/teams/issues/index.d.ts.map +1 -0
  52. package/dist/commands/liberica/teams/issues/index.js +19 -0
  53. package/dist/commands/liberica/teams/issues/index.js.map +1 -0
  54. package/dist/commands/liberica/teams/issues/list.d.ts +3 -0
  55. package/dist/commands/liberica/teams/issues/list.d.ts.map +1 -0
  56. package/dist/commands/liberica/teams/issues/list.js +111 -0
  57. package/dist/commands/liberica/teams/issues/list.js.map +1 -0
  58. package/dist/commands/liberica/teams/issues/update.d.ts +3 -0
  59. package/dist/commands/liberica/teams/issues/update.d.ts.map +1 -0
  60. package/dist/commands/liberica/teams/issues/update.js +132 -0
  61. package/dist/commands/liberica/teams/issues/update.js.map +1 -0
  62. package/dist/commands/liberica/teams/projects/create.d.ts +3 -0
  63. package/dist/commands/liberica/teams/projects/create.d.ts.map +1 -0
  64. package/dist/commands/liberica/teams/projects/create.js +164 -0
  65. package/dist/commands/liberica/teams/projects/create.js.map +1 -0
  66. package/dist/commands/liberica/teams/projects/delete.d.ts +3 -0
  67. package/dist/commands/liberica/teams/projects/delete.d.ts.map +1 -0
  68. package/dist/commands/liberica/teams/projects/delete.js +55 -0
  69. package/dist/commands/liberica/teams/projects/delete.js.map +1 -0
  70. package/dist/commands/liberica/teams/projects/get.d.ts +3 -0
  71. package/dist/commands/liberica/teams/projects/get.d.ts.map +1 -0
  72. package/dist/commands/liberica/teams/projects/get.js +77 -0
  73. package/dist/commands/liberica/teams/projects/get.js.map +1 -0
  74. package/dist/commands/liberica/teams/projects/index.d.ts +3 -0
  75. package/dist/commands/liberica/teams/projects/index.d.ts.map +1 -0
  76. package/dist/commands/liberica/teams/projects/index.js +17 -0
  77. package/dist/commands/liberica/teams/projects/index.js.map +1 -0
  78. package/dist/commands/liberica/teams/projects/list.d.ts +3 -0
  79. package/dist/commands/liberica/teams/projects/list.d.ts.map +1 -0
  80. package/dist/commands/liberica/teams/projects/list.js +115 -0
  81. package/dist/commands/liberica/teams/projects/list.js.map +1 -0
  82. package/dist/commands/liberica/teams/projects/update.d.ts +3 -0
  83. package/dist/commands/liberica/teams/projects/update.d.ts.map +1 -0
  84. package/dist/commands/liberica/teams/projects/update.js +115 -0
  85. package/dist/commands/liberica/teams/projects/update.js.map +1 -0
  86. package/dist/commands/liberica/teams/tasks/create.d.ts +3 -0
  87. package/dist/commands/liberica/teams/tasks/create.d.ts.map +1 -0
  88. package/dist/commands/liberica/teams/tasks/create.js +88 -0
  89. package/dist/commands/liberica/teams/tasks/create.js.map +1 -0
  90. package/dist/commands/liberica/teams/tasks/delete.d.ts +3 -0
  91. package/dist/commands/liberica/teams/tasks/delete.d.ts.map +1 -0
  92. package/dist/commands/liberica/teams/tasks/delete.js +73 -0
  93. package/dist/commands/liberica/teams/tasks/delete.js.map +1 -0
  94. package/dist/commands/liberica/teams/tasks/get.d.ts +3 -0
  95. package/dist/commands/liberica/teams/tasks/get.d.ts.map +1 -0
  96. package/dist/commands/liberica/teams/tasks/get.js +51 -0
  97. package/dist/commands/liberica/teams/tasks/get.js.map +1 -0
  98. package/dist/commands/liberica/teams/tasks/index.d.ts +3 -0
  99. package/dist/commands/liberica/teams/tasks/index.d.ts.map +1 -0
  100. package/dist/commands/liberica/teams/tasks/index.js +17 -0
  101. package/dist/commands/liberica/teams/tasks/index.js.map +1 -0
  102. package/dist/commands/liberica/teams/tasks/list.d.ts +3 -0
  103. package/dist/commands/liberica/teams/tasks/list.d.ts.map +1 -0
  104. package/dist/commands/liberica/teams/tasks/list.js +82 -0
  105. package/dist/commands/liberica/teams/tasks/list.js.map +1 -0
  106. package/dist/commands/liberica/teams/tasks/update.d.ts +3 -0
  107. package/dist/commands/liberica/teams/tasks/update.d.ts.map +1 -0
  108. package/dist/commands/liberica/teams/tasks/update.js +114 -0
  109. package/dist/commands/liberica/teams/tasks/update.js.map +1 -0
  110. package/dist/commands/liberica/teams/work-logs/create.d.ts +3 -0
  111. package/dist/commands/liberica/teams/work-logs/create.d.ts.map +1 -0
  112. package/dist/commands/liberica/teams/work-logs/create.js +183 -0
  113. package/dist/commands/liberica/teams/work-logs/create.js.map +1 -0
  114. package/dist/commands/liberica/teams/work-logs/delete.d.ts +3 -0
  115. package/dist/commands/liberica/teams/work-logs/delete.d.ts.map +1 -0
  116. package/dist/commands/liberica/teams/work-logs/delete.js +55 -0
  117. package/dist/commands/liberica/teams/work-logs/delete.js.map +1 -0
  118. package/dist/commands/liberica/teams/work-logs/get.d.ts +3 -0
  119. package/dist/commands/liberica/teams/work-logs/get.d.ts.map +1 -0
  120. package/dist/commands/liberica/teams/work-logs/get.js +77 -0
  121. package/dist/commands/liberica/teams/work-logs/get.js.map +1 -0
  122. package/dist/commands/liberica/teams/work-logs/index.d.ts +3 -0
  123. package/dist/commands/liberica/teams/work-logs/index.d.ts.map +1 -0
  124. package/dist/commands/liberica/teams/work-logs/index.js +17 -0
  125. package/dist/commands/liberica/teams/work-logs/index.js.map +1 -0
  126. package/dist/commands/liberica/teams/work-logs/list.d.ts +3 -0
  127. package/dist/commands/liberica/teams/work-logs/list.d.ts.map +1 -0
  128. package/dist/commands/liberica/teams/work-logs/list.js +109 -0
  129. package/dist/commands/liberica/teams/work-logs/list.js.map +1 -0
  130. package/dist/commands/liberica/teams/work-logs/update.d.ts +3 -0
  131. package/dist/commands/liberica/teams/work-logs/update.d.ts.map +1 -0
  132. package/dist/commands/liberica/teams/work-logs/update.js +105 -0
  133. package/dist/commands/liberica/teams/work-logs/update.js.map +1 -0
  134. package/dist/commands/liberica/transfer-in-forms/batch-delete.d.ts +3 -0
  135. package/dist/commands/liberica/transfer-in-forms/batch-delete.d.ts.map +1 -0
  136. package/dist/commands/liberica/transfer-in-forms/batch-delete.js +147 -0
  137. package/dist/commands/liberica/transfer-in-forms/batch-delete.js.map +1 -0
  138. package/dist/commands/liberica/transfer-in-forms/batch-review.d.ts +3 -0
  139. package/dist/commands/liberica/transfer-in-forms/batch-review.d.ts.map +1 -0
  140. package/dist/commands/liberica/transfer-in-forms/batch-review.js +146 -0
  141. package/dist/commands/liberica/transfer-in-forms/batch-review.js.map +1 -0
  142. package/dist/commands/liberica/transfer-in-forms/batch-unreview.d.ts +3 -0
  143. package/dist/commands/liberica/transfer-in-forms/batch-unreview.d.ts.map +1 -0
  144. package/dist/commands/liberica/transfer-in-forms/batch-unreview.js +147 -0
  145. package/dist/commands/liberica/transfer-in-forms/batch-unreview.js.map +1 -0
  146. package/dist/commands/liberica/transfer-in-forms/create.d.ts +3 -0
  147. package/dist/commands/liberica/transfer-in-forms/create.d.ts.map +1 -0
  148. package/dist/commands/liberica/transfer-in-forms/create.js +168 -0
  149. package/dist/commands/liberica/transfer-in-forms/create.js.map +1 -0
  150. package/dist/commands/liberica/transfer-in-forms/get.d.ts +3 -0
  151. package/dist/commands/liberica/transfer-in-forms/get.d.ts.map +1 -0
  152. package/dist/commands/liberica/transfer-in-forms/get.js +94 -0
  153. package/dist/commands/liberica/transfer-in-forms/get.js.map +1 -0
  154. package/dist/commands/liberica/transfer-in-forms/index.d.ts +3 -0
  155. package/dist/commands/liberica/transfer-in-forms/index.d.ts.map +1 -0
  156. package/dist/commands/liberica/transfer-in-forms/index.js +21 -0
  157. package/dist/commands/liberica/transfer-in-forms/index.js.map +1 -0
  158. package/dist/commands/liberica/transfer-in-forms/list.d.ts +3 -0
  159. package/dist/commands/liberica/transfer-in-forms/list.d.ts.map +1 -0
  160. package/dist/commands/liberica/transfer-in-forms/list.js +94 -0
  161. package/dist/commands/liberica/transfer-in-forms/list.js.map +1 -0
  162. package/dist/commands/liberica/transfer-in-forms/update.d.ts +3 -0
  163. package/dist/commands/liberica/transfer-in-forms/update.d.ts.map +1 -0
  164. package/dist/commands/liberica/transfer-in-forms/update.js +206 -0
  165. package/dist/commands/liberica/transfer-in-forms/update.js.map +1 -0
  166. package/dist/commands/liberica/transfer-out-forms/batch-delete.d.ts +3 -0
  167. package/dist/commands/liberica/transfer-out-forms/batch-delete.d.ts.map +1 -0
  168. package/dist/commands/liberica/transfer-out-forms/batch-delete.js +80 -0
  169. package/dist/commands/liberica/transfer-out-forms/batch-delete.js.map +1 -0
  170. package/dist/commands/liberica/transfer-out-forms/batch-review.d.ts +3 -0
  171. package/dist/commands/liberica/transfer-out-forms/batch-review.d.ts.map +1 -0
  172. package/dist/commands/liberica/transfer-out-forms/batch-review.js +142 -0
  173. package/dist/commands/liberica/transfer-out-forms/batch-review.js.map +1 -0
  174. package/dist/commands/liberica/transfer-out-forms/batch-unreview.d.ts +3 -0
  175. package/dist/commands/liberica/transfer-out-forms/batch-unreview.d.ts.map +1 -0
  176. package/dist/commands/liberica/transfer-out-forms/batch-unreview.js +53 -0
  177. package/dist/commands/liberica/transfer-out-forms/batch-unreview.js.map +1 -0
  178. package/dist/commands/liberica/transfer-out-forms/create.d.ts +3 -0
  179. package/dist/commands/liberica/transfer-out-forms/create.d.ts.map +1 -0
  180. package/dist/commands/liberica/transfer-out-forms/create.js +191 -0
  181. package/dist/commands/liberica/transfer-out-forms/create.js.map +1 -0
  182. package/dist/commands/liberica/transfer-out-forms/get.d.ts +3 -0
  183. package/dist/commands/liberica/transfer-out-forms/get.d.ts.map +1 -0
  184. package/dist/commands/liberica/transfer-out-forms/get.js +87 -0
  185. package/dist/commands/liberica/transfer-out-forms/get.js.map +1 -0
  186. package/dist/commands/liberica/transfer-out-forms/index.d.ts +3 -0
  187. package/dist/commands/liberica/transfer-out-forms/index.d.ts.map +1 -0
  188. package/dist/commands/liberica/transfer-out-forms/index.js +21 -0
  189. package/dist/commands/liberica/transfer-out-forms/index.js.map +1 -0
  190. package/dist/commands/liberica/transfer-out-forms/list.d.ts +3 -0
  191. package/dist/commands/liberica/transfer-out-forms/list.d.ts.map +1 -0
  192. package/dist/commands/liberica/transfer-out-forms/list.js +118 -0
  193. package/dist/commands/liberica/transfer-out-forms/list.js.map +1 -0
  194. package/dist/commands/liberica/transfer-out-forms/update.d.ts +3 -0
  195. package/dist/commands/liberica/transfer-out-forms/update.d.ts.map +1 -0
  196. package/dist/commands/liberica/transfer-out-forms/update.js +197 -0
  197. package/dist/commands/liberica/transfer-out-forms/update.js.map +1 -0
  198. package/dist/core/api/client.d.ts +59 -0
  199. package/dist/core/api/client.d.ts.map +1 -1
  200. package/dist/core/api/client.js +1106 -136
  201. package/dist/core/api/client.js.map +1 -1
  202. package/dist/index.js +1 -1
  203. package/dist/index.js.map +1 -1
  204. package/dist/types/index.d.ts +7 -0
  205. package/dist/types/index.d.ts.map +1 -1
  206. package/dist/types/index.js +5 -0
  207. package/dist/types/index.js.map +1 -1
  208. package/dist/types/material.d.ts +1 -1
  209. package/dist/types/material.d.ts.map +1 -1
  210. package/dist/types/mould-stock-in.d.ts +70 -0
  211. package/dist/types/mould-stock-in.d.ts.map +1 -0
  212. package/dist/types/mould-stock-in.js +3 -0
  213. package/dist/types/mould-stock-in.js.map +1 -0
  214. package/dist/types/mould.d.ts +61 -0
  215. package/dist/types/mould.d.ts.map +1 -0
  216. package/dist/types/mould.js +2 -0
  217. package/dist/types/mould.js.map +1 -0
  218. package/dist/types/team-issue.d.ts +87 -0
  219. package/dist/types/team-issue.d.ts.map +1 -0
  220. package/dist/types/team-issue.js +2 -0
  221. package/dist/types/team-issue.js.map +1 -0
  222. package/dist/types/team-project.d.ts +68 -0
  223. package/dist/types/team-project.d.ts.map +1 -0
  224. package/dist/types/team-project.js +2 -0
  225. package/dist/types/team-project.js.map +1 -0
  226. package/dist/types/team-task.d.ts +91 -0
  227. package/dist/types/team-task.d.ts.map +1 -0
  228. package/dist/types/team-task.js +2 -0
  229. package/dist/types/team-task.js.map +1 -0
  230. package/dist/types/team-work-log.d.ts +81 -0
  231. package/dist/types/team-work-log.d.ts.map +1 -0
  232. package/dist/types/team-work-log.js +2 -0
  233. package/dist/types/team-work-log.js.map +1 -0
  234. package/dist/types/transfer-in-form.d.ts +242 -0
  235. package/dist/types/transfer-in-form.d.ts.map +1 -0
  236. package/dist/types/transfer-in-form.js +2 -0
  237. package/dist/types/transfer-in-form.js.map +1 -0
  238. package/dist/types/transfer-out-form.d.ts +252 -0
  239. package/dist/types/transfer-out-form.d.ts.map +1 -0
  240. package/dist/types/transfer-out-form.js +4 -0
  241. package/dist/types/transfer-out-form.js.map +1 -0
  242. package/docs/commands/liberica/teams/issues/close.md +161 -0
  243. package/docs/commands/liberica/teams/issues/create.md +212 -0
  244. package/docs/commands/liberica/teams/issues/delete.md +179 -0
  245. package/docs/commands/liberica/teams/issues/get.md +167 -0
  246. package/docs/commands/liberica/teams/issues/list.md +182 -0
  247. package/docs/commands/liberica/teams/issues/tests-design.md +341 -0
  248. package/docs/commands/liberica/teams/issues/update.md +202 -0
  249. package/docs/commands/liberica/teams/projects/create.md +174 -0
  250. package/docs/commands/liberica/teams/projects/delete.md +180 -0
  251. package/docs/commands/liberica/teams/projects/get.md +150 -0
  252. package/docs/commands/liberica/teams/projects/list.md +179 -0
  253. package/docs/commands/liberica/teams/projects/update.md +175 -0
  254. package/docs/commands/liberica/teams/tasks/create.md +163 -0
  255. package/docs/commands/liberica/teams/tasks/delete.md +109 -0
  256. package/docs/commands/liberica/teams/tasks/get.md +121 -0
  257. package/docs/commands/liberica/teams/tasks/list.md +148 -0
  258. package/docs/commands/liberica/teams/tasks/update.md +158 -0
  259. package/docs/commands/liberica/teams/work-logs/create.md +151 -0
  260. package/docs/commands/liberica/teams/work-logs/delete.md +130 -0
  261. package/docs/commands/liberica/teams/work-logs/get.md +131 -0
  262. package/docs/commands/liberica/teams/work-logs/list.md +153 -0
  263. package/docs/commands/liberica/teams/work-logs/update.md +150 -0
  264. package/docs/commands/liberica/transfer-in-forms/batch-delete.md +157 -0
  265. package/docs/commands/liberica/transfer-in-forms/batch-review.md +157 -0
  266. package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +157 -0
  267. package/docs/commands/liberica/transfer-in-forms/create.md +220 -0
  268. package/docs/commands/liberica/transfer-in-forms/get.md +221 -0
  269. package/docs/commands/liberica/transfer-in-forms/list.md +242 -0
  270. package/docs/commands/liberica/transfer-in-forms/update.md +185 -0
  271. package/docs/commands/liberica/transfer-out-forms/batch-delete.md +187 -0
  272. package/docs/commands/liberica/transfer-out-forms/batch-review.md +157 -0
  273. package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +157 -0
  274. package/docs/commands/liberica/transfer-out-forms/create.md +280 -0
  275. package/docs/commands/liberica/transfer-out-forms/get.md +211 -0
  276. package/docs/commands/liberica/transfer-out-forms/list.md +233 -0
  277. package/docs/commands/liberica/transfer-out-forms/update.md +286 -0
  278. package/package.json +1 -1
  279. package/src/commands/liberica/index.ts +10 -1
  280. package/src/commands/liberica/materials/create.ts +13 -5
  281. package/src/commands/liberica/materials/update.ts +1 -1
  282. package/src/commands/liberica/mould/get.ts +111 -0
  283. package/src/commands/liberica/mould/index.ts +17 -0
  284. package/src/commands/liberica/mould/list.ts +157 -0
  285. package/src/commands/liberica/mould/set-status.ts +99 -0
  286. package/src/commands/liberica/mould/stock-in.ts +165 -0
  287. package/src/commands/liberica/teams/index.ts +17 -0
  288. package/src/commands/liberica/teams/issues/close.ts +104 -0
  289. package/src/commands/liberica/teams/issues/create.ts +254 -0
  290. package/src/commands/liberica/teams/issues/delete.ts +58 -0
  291. package/src/commands/liberica/teams/issues/get.ts +78 -0
  292. package/src/commands/liberica/teams/issues/index.ts +21 -0
  293. package/src/commands/liberica/teams/issues/list.ts +144 -0
  294. package/src/commands/liberica/teams/issues/update.ts +141 -0
  295. package/src/commands/liberica/teams/projects/create.ts +159 -0
  296. package/src/commands/liberica/teams/projects/delete.ts +58 -0
  297. package/src/commands/liberica/teams/projects/get.ts +87 -0
  298. package/src/commands/liberica/teams/projects/index.ts +19 -0
  299. package/src/commands/liberica/teams/projects/list.ts +147 -0
  300. package/src/commands/liberica/teams/projects/update.ts +117 -0
  301. package/src/commands/liberica/teams/tasks/create.ts +102 -0
  302. package/src/commands/liberica/teams/tasks/delete.ts +92 -0
  303. package/src/commands/liberica/teams/tasks/get.ts +64 -0
  304. package/src/commands/liberica/teams/tasks/index.ts +19 -0
  305. package/src/commands/liberica/teams/tasks/list.ts +102 -0
  306. package/src/commands/liberica/teams/tasks/update.ts +122 -0
  307. package/src/commands/liberica/teams/work-logs/create.ts +204 -0
  308. package/src/commands/liberica/teams/work-logs/delete.ts +58 -0
  309. package/src/commands/liberica/teams/work-logs/get.ts +87 -0
  310. package/src/commands/liberica/teams/work-logs/index.ts +19 -0
  311. package/src/commands/liberica/teams/work-logs/list.ts +141 -0
  312. package/src/commands/liberica/teams/work-logs/update.ts +120 -0
  313. package/src/commands/liberica/transfer-in-forms/batch-delete.ts +152 -0
  314. package/src/commands/liberica/transfer-in-forms/batch-review.ts +151 -0
  315. package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +152 -0
  316. package/src/commands/liberica/transfer-in-forms/create.ts +179 -0
  317. package/src/commands/liberica/transfer-in-forms/get.ts +107 -0
  318. package/src/commands/liberica/transfer-in-forms/index.ts +23 -0
  319. package/src/commands/liberica/transfer-in-forms/list.ts +97 -0
  320. package/src/commands/liberica/transfer-in-forms/update.ts +213 -0
  321. package/src/commands/liberica/transfer-out-forms/batch-delete.ts +83 -0
  322. package/src/commands/liberica/transfer-out-forms/batch-review.ts +148 -0
  323. package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +56 -0
  324. package/src/commands/liberica/transfer-out-forms/create.ts +194 -0
  325. package/src/commands/liberica/transfer-out-forms/get.ts +114 -0
  326. package/src/commands/liberica/transfer-out-forms/index.ts +23 -0
  327. package/src/commands/liberica/transfer-out-forms/list.ts +125 -0
  328. package/src/commands/liberica/transfer-out-forms/update.ts +197 -0
  329. package/src/core/api/client.ts +1351 -121
  330. package/src/index.ts +1 -1
  331. package/src/types/index.ts +7 -0
  332. package/src/types/material.ts +1 -1
  333. package/src/types/mould-stock-in.ts +82 -0
  334. package/src/types/mould.ts +74 -0
  335. package/src/types/team-issue.ts +94 -0
  336. package/src/types/team-project.ts +74 -0
  337. package/src/types/team-task.ts +98 -0
  338. package/src/types/team-work-log.ts +87 -0
  339. package/src/types/transfer-in-form.ts +265 -0
  340. package/src/types/transfer-out-form.ts +290 -0
@@ -0,0 +1,111 @@
1
+ import { Command } from 'commander';
2
+ import chalk from 'chalk';
3
+ import { configManager } from '../../../core/config/manager.js';
4
+ import { apiClient } from '../../../core/api/client.js';
5
+ import { MouldEntityApiResponse, MouldEntity } from '../../../types/mould.js';
6
+
7
+ function formatMouldStatus(status?: string): string {
8
+ if (!status) return chalk.gray('-');
9
+ switch (status) {
10
+ case 'FINE':
11
+ return chalk.green('FINE');
12
+ case 'REPAIR':
13
+ return chalk.yellow('REPAIR');
14
+ case 'SCRAP':
15
+ return chalk.red('SCRAP');
16
+ default:
17
+ return status;
18
+ }
19
+ }
20
+
21
+ function outputMouldDetails(mould: MouldEntity): void {
22
+ console.log(chalk.bold('\n🔧 Mould Details\n'));
23
+
24
+ console.log(chalk.gray(' ID: ') + mould.mouldEntityId);
25
+ console.log(chalk.gray(' Code: ') + (mould.mouldEntityCode || chalk.gray('-')));
26
+ console.log(chalk.gray(' Material Code: ') + (mould.materialCode || chalk.gray('-')));
27
+ console.log(chalk.gray(' Material Name: ') + (mould.materialName || chalk.gray('-')));
28
+ console.log(chalk.gray(' Material No: ') + (mould.materialNo || chalk.gray('-')));
29
+ console.log(chalk.gray(' Type: ') + (mould.mouldType || chalk.gray('-')));
30
+ console.log(chalk.gray(' Status: ') + formatMouldStatus(mould.mouldStatus));
31
+ console.log(chalk.gray(' Warehouse Code: ') + (mould.currentWarehouseCode || chalk.gray('-')));
32
+ console.log(chalk.gray(' Seq No: ') + (mould.seqNo || chalk.gray('-')));
33
+ console.log(chalk.gray(' Lot No: ') + (mould.lotNo || chalk.gray('-')));
34
+ console.log(chalk.gray(' Face Number: ') + (mould.mouldFaceNumber !== undefined ? String(mould.mouldFaceNumber) : chalk.gray('-')));
35
+ console.log(chalk.gray(' Unit Price: ') + (mould.unitPrice !== undefined ? `${mould.unitPrice} ${mould.currency || ''}` : chalk.gray('-')));
36
+ console.log(chalk.gray(' Produced Date: ') + (mould.producedDate || chalk.gray('-')));
37
+ console.log(chalk.gray(' Last Stock Out: ') + (mould.lastStockOutTime || chalk.gray('-')));
38
+ console.log(chalk.gray(' Remark: ') + (mould.remark || chalk.gray('-')));
39
+ console.log();
40
+ }
41
+
42
+ export function createMouldGetCommand(): Command {
43
+ const getCommand = new Command('get');
44
+ getCommand.description('Get mould entity details by ID');
45
+
46
+ getCommand
47
+ .argument('<mouldEntityId>', 'Mould entity ID (BigInteger string)')
48
+ .option('--json', 'Output as JSON')
49
+ .action(async (mouldEntityId: string, options: { json?: boolean }) => {
50
+ if (!mouldEntityId) {
51
+ console.error(chalk.red('\n✗ Mould ID is required\n'));
52
+ process.exit(1);
53
+ }
54
+
55
+ const context = configManager.getCurrentContext();
56
+ const environment = context.environment;
57
+ const tenant = context.tenant;
58
+
59
+ const response: MouldEntityApiResponse = await apiClient.getMouldEntity(
60
+ environment,
61
+ tenant,
62
+ mouldEntityId
63
+ );
64
+
65
+ if (!response.success) {
66
+ const errorMessage = response.error?.message || 'Unknown error';
67
+ const errorCode = response.error?.code;
68
+
69
+ if (errorMessage.includes('不存在') || errorMessage.includes('not exist')) {
70
+ console.error(chalk.red(`\n✗ Mould not found: ${mouldEntityId}\n`));
71
+ } else {
72
+ console.error(chalk.red(`\n✗ Failed to get mould: ${errorMessage}`));
73
+ if (errorCode) {
74
+ console.error(chalk.gray(` Error code: ${errorCode}`));
75
+ }
76
+ console.error();
77
+ }
78
+ process.exit(1);
79
+ }
80
+
81
+ const data = response.data as MouldEntity | null;
82
+
83
+ if (!data) {
84
+ if (options.json) {
85
+ console.log(JSON.stringify({ success: true, data: null }, null, 2));
86
+ } else {
87
+ console.log(chalk.bold('\n🔧 Mould Details\n'));
88
+ console.log(chalk.gray(' Not found\n'));
89
+ }
90
+ return;
91
+ }
92
+
93
+ if (options.json) {
94
+ console.log(
95
+ JSON.stringify(
96
+ {
97
+ success: true,
98
+ data,
99
+ },
100
+ null,
101
+ 2
102
+ )
103
+ );
104
+ return;
105
+ }
106
+
107
+ outputMouldDetails(data);
108
+ });
109
+
110
+ return getCommand;
111
+ }
@@ -0,0 +1,17 @@
1
+ import { Command } from 'commander';
2
+ import { createMouldListCommand } from './list.js';
3
+ import { createMouldGetCommand } from './get.js';
4
+ import { createMouldSetStatusCommand } from './set-status.js';
5
+ import { createMouldStockInCommand } from './stock-in.js';
6
+
7
+ export function createMouldCommand(): Command {
8
+ const mouldCommand = new Command('mould');
9
+ mouldCommand.description('Manage mould entities');
10
+
11
+ mouldCommand.addCommand(createMouldListCommand());
12
+ mouldCommand.addCommand(createMouldGetCommand());
13
+ mouldCommand.addCommand(createMouldSetStatusCommand());
14
+ mouldCommand.addCommand(createMouldStockInCommand());
15
+
16
+ return mouldCommand;
17
+ }
@@ -0,0 +1,157 @@
1
+ import { Command } from 'commander';
2
+ import chalk from 'chalk';
3
+ import Table from 'cli-table3';
4
+ import { configManager } from '../../../core/config/manager.js';
5
+ import { apiClient } from '../../../core/api/client.js';
6
+ import { MouldEntityListResponse, MouldStatus } from '../../../types/mould.js';
7
+
8
+ const VALID_STATUSES = ['FINE', 'REPAIR', 'SCRAP'] as const;
9
+
10
+ export function createMouldListCommand(): Command {
11
+ const listCommand = new Command('list');
12
+ listCommand.description('List mould entities with pagination');
13
+
14
+ listCommand
15
+ .option('-p, --page <number>', 'Page number', '1')
16
+ .option('-s, --size <number>', 'Page size', '20')
17
+ .option('--status <status>', `Mould status filter (${VALID_STATUSES.join('|')})`)
18
+ .option('--material-code <code>', 'Material code filter')
19
+ .option('--material-name <name>', 'Material name filter (fuzzy)')
20
+ .option('--json', 'Output as JSON')
21
+ .action(async (options) => {
22
+ const context = configManager.getCurrentContext();
23
+ const tenant = context.tenant;
24
+ const environment = context.environment;
25
+
26
+ const page = parseInt(options.page as string, 10);
27
+ const size = parseInt(options.size as string, 10);
28
+
29
+ const params: {
30
+ pageNo: number;
31
+ pageSize: number;
32
+ mouldStatus?: MouldStatus;
33
+ materialCode?: string;
34
+ materialName?: string;
35
+ } = { pageNo: page, pageSize: size };
36
+
37
+ if (options.status !== undefined) {
38
+ const status = options.status as MouldStatus;
39
+ if (VALID_STATUSES.includes(status)) {
40
+ params.mouldStatus = status;
41
+ }
42
+ }
43
+
44
+ if (options.materialCode !== undefined) {
45
+ params.materialCode = options.materialCode as string;
46
+ }
47
+
48
+ if (options.materialName !== undefined) {
49
+ params.materialName = options.materialName as string;
50
+ }
51
+
52
+ const response = await apiClient.listMouldEntities(environment, tenant, params);
53
+
54
+ if (!response.success) {
55
+ console.error(chalk.red(`\n✗ Failed to list moulds: ${response.error?.message || 'Unknown error'}`));
56
+ if (response.error?.code) {
57
+ console.error(chalk.gray(` Error code: ${response.error.code}`));
58
+ }
59
+ console.error();
60
+ process.exit(1);
61
+ }
62
+
63
+ const data = response.data as MouldEntityListResponse | null;
64
+
65
+ if (!data) {
66
+ if (options.json) {
67
+ console.log(
68
+ JSON.stringify(
69
+ { success: true, data: { rows: [], pagination: { pageNo: 0, pageSize: 20, totalRows: 0 } } },
70
+ null,
71
+ 2
72
+ )
73
+ );
74
+ } else {
75
+ console.log(chalk.bold('\n📋 Mould List\n'));
76
+ console.log(chalk.gray(' No moulds found\n'));
77
+ }
78
+ return;
79
+ }
80
+
81
+ if (options.json) {
82
+ console.log(
83
+ JSON.stringify(
84
+ {
85
+ success: true,
86
+ data: {
87
+ rows: data.rows || [],
88
+ pagination: {
89
+ pageNo: data.pageNo,
90
+ pageSize: data.pageSize,
91
+ totalRows: data.totalRows,
92
+ },
93
+ },
94
+ },
95
+ null,
96
+ 2
97
+ )
98
+ );
99
+ return;
100
+ }
101
+
102
+ const records = data.rows || [];
103
+
104
+ if (records.length === 0) {
105
+ console.log(chalk.bold('\n📋 Mould List\n'));
106
+ console.log(chalk.gray(' No moulds found\n'));
107
+ return;
108
+ }
109
+
110
+ console.log(chalk.bold('\n📋 Mould List\n'));
111
+
112
+ const table = new Table({
113
+ head: [
114
+ chalk.bold('Code'),
115
+ chalk.bold('Material'),
116
+ chalk.bold('Type'),
117
+ chalk.bold('Status'),
118
+ chalk.bold('Warehouse'),
119
+ chalk.bold('Produced'),
120
+ ],
121
+ colWidths: [16, 20, 14, 10, 14, 12],
122
+ style: {
123
+ head: [],
124
+ border: [],
125
+ },
126
+ });
127
+
128
+ for (const mould of records) {
129
+ const statusText =
130
+ mould.mouldStatus === 'FINE'
131
+ ? chalk.green('FINE')
132
+ : mould.mouldStatus === 'REPAIR'
133
+ ? chalk.yellow('REPAIR')
134
+ : chalk.red('SCRAP');
135
+
136
+ table.push([
137
+ mould.mouldEntityCode || '-',
138
+ mould.materialName || '-',
139
+ mould.mouldType || '-',
140
+ statusText,
141
+ mould.currentWarehouseCode || '-',
142
+ mould.producedDate || '-',
143
+ ]);
144
+ }
145
+
146
+ console.log(table.toString());
147
+ console.log();
148
+ console.log(
149
+ chalk.gray(
150
+ ` Total: ${data.totalRows} | Page: ${data.pageNo + 1} / ${Math.ceil(data.totalRows / data.pageSize) || 1} | Size: ${data.pageSize}`
151
+ )
152
+ );
153
+ console.log();
154
+ });
155
+
156
+ return listCommand;
157
+ }
@@ -0,0 +1,99 @@
1
+ import { Command } from 'commander';
2
+ import chalk from 'chalk';
3
+ import { configManager } from '../../../core/config/manager.js';
4
+ import { apiClient } from '../../../core/api/client.js';
5
+ import { MouldStatus, MouldEntitySetStatusRequest } from '../../../types/mould.js';
6
+
7
+ const VALID_STATUSES: MouldStatus[] = ['FINE', 'REPAIR', 'SCRAP'];
8
+
9
+ export function createMouldSetStatusCommand(): Command {
10
+ const cmd = new Command('set-status');
11
+ cmd.description('Set mould status (FINE | REPAIR | SCRAP)');
12
+
13
+ cmd
14
+ .argument('<mouldEntityId>', 'Mould entity ID')
15
+ .argument('<status>', 'New status (FINE, REPAIR, or SCRAP)')
16
+ .option('--remark <remark>', 'Remark for status change')
17
+ .option('--json', 'Output as JSON')
18
+ .action(async (mouldEntityId: string, status: string, options: { remark?: string; json?: boolean }) => {
19
+ const context = configManager.getCurrentContext();
20
+ const tenant = context.tenant;
21
+ const environment = context.environment;
22
+
23
+ const mouldStatus = status.toUpperCase() as MouldStatus;
24
+ if (!VALID_STATUSES.includes(mouldStatus)) {
25
+ const errMsg = `Invalid status value: ${status}. Must be one of: ${VALID_STATUSES.join(', ')}`;
26
+ if (options.json) {
27
+ console.log(
28
+ JSON.stringify({
29
+ success: false,
30
+ error: { code: 'INVALID_STATUS', message: errMsg },
31
+ })
32
+ );
33
+ } else {
34
+ console.error(chalk.red(`\n✗ ${errMsg}\n`));
35
+ }
36
+ process.exit(1);
37
+ }
38
+
39
+ const request: MouldEntitySetStatusRequest = {
40
+ mouldEntityId,
41
+ mouldStatus,
42
+ remark: options.remark,
43
+ };
44
+
45
+ if (!options.json) {
46
+ console.log(chalk.bold('\n🔧 Set Mould Status\n'));
47
+ console.log(` ${chalk.gray('Mould ID:')} ${mouldEntityId}`);
48
+ console.log(` ${chalk.gray('New Status:')} ${mouldStatus}`);
49
+ if (options.remark) {
50
+ console.log(` ${chalk.gray('Remark:')} ${options.remark}`);
51
+ }
52
+ console.log();
53
+ }
54
+
55
+ const response = await apiClient.setMouldStatus(environment, tenant, request);
56
+
57
+ if (!response.success) {
58
+ const errorMsg = response.error?.message || 'Failed to set mould status';
59
+ const errorCode = response.error?.code || 'SET_MOULD_STATUS_ERROR';
60
+
61
+ if (options.json) {
62
+ console.log(
63
+ JSON.stringify({
64
+ success: false,
65
+ error: { code: errorCode, message: errorMsg },
66
+ })
67
+ );
68
+ } else {
69
+ console.error(chalk.red(`\n✗ Failed to set mould status: ${errorMsg}`));
70
+ if (response.error?.code) {
71
+ console.error(chalk.gray(` Error code: ${response.error.code}`));
72
+ }
73
+ console.error();
74
+ }
75
+ process.exit(1);
76
+ }
77
+
78
+ const data = response.data as { mouldEntityId?: string; mouldEntityCode?: string; mouldName?: string; mouldStatus?: string } | undefined;
79
+
80
+ if (options.json) {
81
+ console.log(
82
+ JSON.stringify({
83
+ success: true,
84
+ data: {
85
+ mouldId: data?.mouldEntityId || mouldEntityId,
86
+ mouldName: data?.mouldName,
87
+ currentStatus: data?.mouldStatus || mouldStatus,
88
+ remark: options.remark,
89
+ },
90
+ })
91
+ );
92
+ } else {
93
+ console.log(chalk.green(`✓ Mould status set to ${mouldStatus}`));
94
+ console.log();
95
+ }
96
+ });
97
+
98
+ return cmd;
99
+ }
@@ -0,0 +1,165 @@
1
+ import { Command } from 'commander';
2
+ import chalk from 'chalk';
3
+ import { apiClient } from '../../../core/api/client.js';
4
+ import { configManager } from '../../../core/config/manager.js';
5
+ import { MouldEntityRegFormRequest } from '../../../types/mould-stock-in.js';
6
+
7
+ function formatTable(data: MouldEntityRegFormRequest): string {
8
+ const lines: string[] = [];
9
+ lines.push(` ${chalk.gray('Form Code:')} ${data.mouldEntityRegFormCode || '(auto)'}`);
10
+ lines.push(` ${chalk.gray('Stock Date:')} ${data.stockDate || '(today)'}`);
11
+ lines.push(` ${chalk.gray('Warehouse:')} ${data.mainWarehouseCode}`);
12
+ lines.push(` ${chalk.gray('Follower:')} ${data.follower}${data.followerName ? ` (${data.followerName})` : ''}`);
13
+ if (data.remark) lines.push(` ${chalk.gray('Remark:')} ${data.remark}`);
14
+
15
+ const item = data.itemList[0];
16
+ if (item) {
17
+ lines.push('');
18
+ lines.push(` ${chalk.gray('Material:')} ${item.materialCode}`);
19
+ if (item.materialName) lines.push(` ${chalk.gray('Material Name:')} ${item.materialName}`);
20
+ if (item.materialNo) lines.push(` ${chalk.gray('Material No:')} ${item.materialNo}`);
21
+ if (item.materialType) lines.push(` ${chalk.gray('Material Type:')} ${item.materialType}`);
22
+ lines.push(` ${chalk.gray('Quantity:')} ${item.formQuantity}`);
23
+ if (item.formMaterialUomCode) lines.push(` ${chalk.gray('Form UOM:')} ${item.formMaterialUomCode}`);
24
+ if (item.producedDate) lines.push(` ${chalk.gray('Produced Date:')} ${item.producedDate}`);
25
+ if (item.mouldType) lines.push(` ${chalk.gray('Mould Type:')} ${item.mouldType}`);
26
+ }
27
+
28
+ return lines.join('\n');
29
+ }
30
+
31
+ export function createMouldStockInCommand(): Command {
32
+ const cmd = new Command('stock-in');
33
+ cmd.description('Create a mould stock-in (入库单) to add mould materials to the entity list');
34
+
35
+ cmd
36
+ .requiredOption('-m, --material-code <code>', 'Material code (required)')
37
+ .requiredOption('-w, --warehouse-code <code>', 'Main warehouse code (required)')
38
+ .requiredOption('-f, --follower <id>', 'Follower (入库人员) ID (required)')
39
+ .option('--follower-name <name>', 'Follower name')
40
+ .option('-q, --quantity <number>', 'Form quantity (default: 1)', (val) => {
41
+ const n = parseInt(val, 10);
42
+ if (isNaN(n) || n <= 0) {
43
+ console.error(chalk.red('\n✗ Error: --quantity must be a positive integer\n'));
44
+ process.exit(1);
45
+ }
46
+ return n;
47
+ })
48
+ .option('--form-uom <code>', 'Form unit of measure code (required)')
49
+ .option('--material-no <no>', 'Material number')
50
+ .option('--material-name <name>', 'Material name')
51
+ .option('--material-type <type>', 'Material type')
52
+ .option('--produced-date <date>', 'Produced date (ISO format YYYY-MM-DD)')
53
+ .option('--mould-type <type>', 'Mould type')
54
+ .option('--remark <remark>', 'Remark / 备注')
55
+ .option('--stock-date <date>', 'Stock-in date (default: today YYYY-MM-DD)')
56
+ .option('--dry-run', 'Preview mode, do not call API')
57
+ .option('--json', 'Output as JSON');
58
+
59
+ cmd.action(async () => {
60
+ const context = configManager.getCurrentContext();
61
+ const opts = cmd.opts();
62
+
63
+ const materialCode = opts.materialCode as string;
64
+ const warehouseCode = opts.warehouseCode as string;
65
+ const follower = opts.follower as string;
66
+ const followerName = opts.followerName as string | undefined;
67
+ const quantity = opts.quantity as number | undefined;
68
+ const formUom = opts.formUom as string | undefined;
69
+ const materialNo = opts.materialNo as string | undefined;
70
+ const materialName = opts.materialName as string | undefined;
71
+ const materialType = opts.materialType as string | undefined;
72
+ const producedDate = opts.producedDate as string | undefined;
73
+ const mouldType = opts.mouldType as string | undefined;
74
+ const remark = opts.remark as string | undefined;
75
+ const stockDate = opts.stockDate as string | undefined;
76
+ const dryRun = opts.dryRun === true;
77
+ const jsonOutput = opts.json === true;
78
+
79
+ const request: MouldEntityRegFormRequest = {
80
+ mouldEntityRegFormCode: '',
81
+ stockDate: stockDate || new Date().toISOString().split('T')[0],
82
+ mainWarehouseCode: warehouseCode,
83
+ follower,
84
+ followerName,
85
+ remark,
86
+ itemList: [
87
+ {
88
+ materialCode,
89
+ materialNo,
90
+ materialName,
91
+ materialType,
92
+ formQuantity: quantity || 1,
93
+ formMaterialUomCode: formUom,
94
+ producedDate,
95
+ mouldType,
96
+ warehouseCode,
97
+ },
98
+ ],
99
+ };
100
+
101
+ if (dryRun) {
102
+ if (jsonOutput) {
103
+ console.log(JSON.stringify({ success: true, dryRun: true, data: request }));
104
+ } else {
105
+ console.log(chalk.bold('\n🔍 Dry-Run Mode: No changes will be made\n'));
106
+ console.log(' Mould stock-in to be created:');
107
+ console.log(formatTable(request));
108
+ console.log();
109
+ }
110
+ return;
111
+ }
112
+
113
+ if (!jsonOutput) {
114
+ console.log(chalk.bold('\n📥 Creating Mould Stock-In\n'));
115
+ }
116
+
117
+ const response = await apiClient.createMouldStockIn(context.environment, context.tenant, request);
118
+
119
+ if (!response.success) {
120
+ const errorMsg = response.error?.message || 'Failed to create stock-in';
121
+ const errorCode = response.error?.code || 'CREATE_MOULD_STOCK_IN_ERROR';
122
+ if (jsonOutput) {
123
+ console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
124
+ } else {
125
+ console.error(chalk.red(`\n✗ Failed to create stock-in: ${errorMsg}`));
126
+ if (response.error?.code) {
127
+ console.error(chalk.gray(` Error code: ${response.error.code}`));
128
+ }
129
+ console.error();
130
+ }
131
+ process.exit(1);
132
+ }
133
+
134
+ if (response.success) {
135
+ const data = response.data;
136
+
137
+ if (jsonOutput) {
138
+ console.log(JSON.stringify({ success: true, data }));
139
+ } else {
140
+ console.log(chalk.green('\n✓ Mould stock-in created successfully\n'));
141
+ if (data?.mouldEntityRegFormCode) {
142
+ console.log(` ${chalk.gray('Form Code:')} ${chalk.green(data.mouldEntityRegFormCode)}`);
143
+ }
144
+ if (data?.mouldEntityRegFormId) {
145
+ console.log(` ${chalk.gray('Form ID:')} ${data.mouldEntityRegFormId}`);
146
+ }
147
+ if (data?.stockDate) {
148
+ console.log(` ${chalk.gray('Stock Date:')} ${data.stockDate}`);
149
+ }
150
+ if (data?.mainWarehouseName) {
151
+ console.log(` ${chalk.gray('Warehouse:')} ${data.mainWarehouseName}`);
152
+ }
153
+ if (data?.followerName) {
154
+ console.log(` ${chalk.gray('Follower:')} ${data.followerName}`);
155
+ }
156
+ if (data?.status) {
157
+ console.log(` ${chalk.gray('Status:')} ${data.status}`);
158
+ }
159
+ console.log();
160
+ }
161
+ }
162
+ });
163
+
164
+ return cmd;
165
+ }
@@ -0,0 +1,17 @@
1
+ import { Command } from 'commander';
2
+ import { createTeamIssuesCommand } from './issues/index.js';
3
+ import { createTeamProjectsCommand } from './projects/index.js';
4
+ import { createTeamTasksCommand } from './tasks/index.js';
5
+ import { createTeamWorkLogsCommand } from './work-logs/index.js';
6
+
7
+ export function createTeamsCommand(): Command {
8
+ const teamsCommand = new Command('teams');
9
+ teamsCommand.description('Manage teams and issues');
10
+
11
+ teamsCommand.addCommand(createTeamIssuesCommand());
12
+ teamsCommand.addCommand(createTeamProjectsCommand());
13
+ teamsCommand.addCommand(createTeamTasksCommand());
14
+ teamsCommand.addCommand(createTeamWorkLogsCommand());
15
+
16
+ return teamsCommand;
17
+ }
@@ -0,0 +1,104 @@
1
+ import { Command, Option } from 'commander';
2
+ import chalk from 'chalk';
3
+ import { configManager } from '../../../../core/config/manager.js';
4
+ import { apiClient } from '../../../../core/api/client.js';
5
+ import { Environment } from '../../../../types/index.js';
6
+ import { UpdateTeamIssueRequest } from '../../../../types/team-issue.js';
7
+
8
+ export function createTeamIssueCloseCommand(): Command {
9
+ const closeCommand = new Command('close');
10
+ closeCommand
11
+ .description('Close a team issue (sets status to CLOSED)')
12
+ .argument('<issue-id>', 'Issue ID')
13
+ .addOption(new Option('--env <string>').hideHelp())
14
+ .addOption(new Option('--tenant <string>').hideHelp())
15
+ .option('--json', 'Output as JSON');
16
+
17
+ closeCommand.action(async (issueId: string, options: Record<string, unknown>) => {
18
+ const context = configManager.getCurrentContext();
19
+ const environment = context.environment as Environment;
20
+ const tenant = context.tenant;
21
+
22
+ if (!issueId || issueId.trim() === '') {
23
+ console.error(chalk.red('\n✗ Issue ID is required\n'));
24
+ process.exit(1);
25
+ }
26
+
27
+ // Fetch the issue first to get all required fields
28
+ let existingIssue: Record<string, unknown> | null = null;
29
+ try {
30
+ const getResponse = await apiClient.getTeamIssue(environment, tenant, issueId);
31
+ if (!getResponse.success || !getResponse.data) {
32
+ if (options.json) {
33
+ console.log(JSON.stringify({ success: false, error: getResponse.error }, null, 2));
34
+ } else {
35
+ console.error(chalk.red(`\n✗ Issue not found: ${getResponse.error?.message || 'Unknown error'}\n`));
36
+ }
37
+ process.exit(1);
38
+ }
39
+ existingIssue = getResponse.data as unknown as Record<string, unknown>;
40
+ } catch (error) {
41
+ if (options.json) {
42
+ console.log(JSON.stringify({ success: false, error: { message: error instanceof Error ? error.message : 'Unknown error' } }, null, 2));
43
+ } else {
44
+ console.error(chalk.red(`\n✗ Error fetching issue: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
45
+ }
46
+ process.exit(1);
47
+ }
48
+
49
+ const request: UpdateTeamIssueRequest = {
50
+ teamIssueId: issueId,
51
+ issueTitle: existingIssue.issueTitle as string,
52
+ issueDesc: existingIssue.issueDesc as string,
53
+ issueType: existingIssue.issueType as 'BUG' | 'REQUIREMENT' | 'QUESTION',
54
+ projectId: existingIssue.projectId as string,
55
+ projectCode: existingIssue.projectCode as string,
56
+ projectName: existingIssue.projectName as string,
57
+ reporterName: existingIssue.reporterName as string,
58
+ reporterEmail: existingIssue.reporterEmail as string,
59
+ priority: existingIssue.priority as 'LOW' | 'MEDIUM' | 'HIGH' | 'URGENT',
60
+ teamIssueStatus: 'CLOSED',
61
+ assignTo: existingIssue.assignTo as string[],
62
+ tags: existingIssue.tags as string[] | undefined,
63
+ };
64
+
65
+ try {
66
+ const response = await apiClient.updateTeamIssue(environment, tenant, request);
67
+
68
+ if (response.success) {
69
+ if (options.json) {
70
+ console.log(JSON.stringify({ success: true, data: response.data }, null, 2));
71
+ } else {
72
+ console.log(chalk.green(`\n✓ Issue ${issueId} closed successfully\n`));
73
+ }
74
+ } else {
75
+ if (options.json) {
76
+ console.log(JSON.stringify({ success: false, error: response.error }, null, 2));
77
+ } else {
78
+ console.error(chalk.red(`\n✗ Close failed: ${response.error?.message || 'Unknown error'}`));
79
+ if (response.error?.code) {
80
+ console.error(chalk.gray(` Error code: ${response.error.code}`));
81
+ }
82
+ console.error();
83
+ }
84
+ process.exit(1);
85
+ }
86
+ } catch (error) {
87
+ if (options.json) {
88
+ console.log(
89
+ JSON.stringify({
90
+ success: false,
91
+ error: { message: error instanceof Error ? error.message : 'Unknown error' },
92
+ })
93
+ );
94
+ } else {
95
+ console.error(
96
+ chalk.red(`\n✗ Error: ${error instanceof Error ? error.message : 'Unknown error'}\n`)
97
+ );
98
+ }
99
+ process.exit(1);
100
+ }
101
+ });
102
+
103
+ return closeCommand;
104
+ }