@newpeak/barista-cli 0.1.9 → 0.1.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commands/liberica/index.d.ts.map +1 -1
- package/dist/commands/liberica/index.js +7 -0
- package/dist/commands/liberica/index.js.map +1 -1
- package/dist/commands/liberica/teams/index.d.ts +3 -0
- package/dist/commands/liberica/teams/index.d.ts.map +1 -0
- package/dist/commands/liberica/teams/index.js +15 -0
- package/dist/commands/liberica/teams/index.js.map +1 -0
- package/dist/commands/liberica/teams/issues/close.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/close.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/close.js +99 -0
- package/dist/commands/liberica/teams/issues/close.js.map +1 -0
- package/dist/commands/liberica/teams/issues/create.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/create.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/create.js +255 -0
- package/dist/commands/liberica/teams/issues/create.js.map +1 -0
- package/dist/commands/liberica/teams/issues/delete.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/delete.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/delete.js +55 -0
- package/dist/commands/liberica/teams/issues/delete.js.map +1 -0
- package/dist/commands/liberica/teams/issues/get.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/get.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/get.js +68 -0
- package/dist/commands/liberica/teams/issues/get.js.map +1 -0
- package/dist/commands/liberica/teams/issues/index.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/index.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/index.js +19 -0
- package/dist/commands/liberica/teams/issues/index.js.map +1 -0
- package/dist/commands/liberica/teams/issues/list.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/list.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/list.js +111 -0
- package/dist/commands/liberica/teams/issues/list.js.map +1 -0
- package/dist/commands/liberica/teams/issues/update.d.ts +3 -0
- package/dist/commands/liberica/teams/issues/update.d.ts.map +1 -0
- package/dist/commands/liberica/teams/issues/update.js +132 -0
- package/dist/commands/liberica/teams/issues/update.js.map +1 -0
- package/dist/commands/liberica/teams/projects/create.d.ts +3 -0
- package/dist/commands/liberica/teams/projects/create.d.ts.map +1 -0
- package/dist/commands/liberica/teams/projects/create.js +164 -0
- package/dist/commands/liberica/teams/projects/create.js.map +1 -0
- package/dist/commands/liberica/teams/projects/delete.d.ts +3 -0
- package/dist/commands/liberica/teams/projects/delete.d.ts.map +1 -0
- package/dist/commands/liberica/teams/projects/delete.js +55 -0
- package/dist/commands/liberica/teams/projects/delete.js.map +1 -0
- package/dist/commands/liberica/teams/projects/get.d.ts +3 -0
- package/dist/commands/liberica/teams/projects/get.d.ts.map +1 -0
- package/dist/commands/liberica/teams/projects/get.js +77 -0
- package/dist/commands/liberica/teams/projects/get.js.map +1 -0
- package/dist/commands/liberica/teams/projects/index.d.ts +3 -0
- package/dist/commands/liberica/teams/projects/index.d.ts.map +1 -0
- package/dist/commands/liberica/teams/projects/index.js +17 -0
- package/dist/commands/liberica/teams/projects/index.js.map +1 -0
- package/dist/commands/liberica/teams/projects/list.d.ts +3 -0
- package/dist/commands/liberica/teams/projects/list.d.ts.map +1 -0
- package/dist/commands/liberica/teams/projects/list.js +115 -0
- package/dist/commands/liberica/teams/projects/list.js.map +1 -0
- package/dist/commands/liberica/teams/projects/update.d.ts +3 -0
- package/dist/commands/liberica/teams/projects/update.d.ts.map +1 -0
- package/dist/commands/liberica/teams/projects/update.js +115 -0
- package/dist/commands/liberica/teams/projects/update.js.map +1 -0
- package/dist/commands/liberica/teams/tasks/create.d.ts +3 -0
- package/dist/commands/liberica/teams/tasks/create.d.ts.map +1 -0
- package/dist/commands/liberica/teams/tasks/create.js +88 -0
- package/dist/commands/liberica/teams/tasks/create.js.map +1 -0
- package/dist/commands/liberica/teams/tasks/delete.d.ts +3 -0
- package/dist/commands/liberica/teams/tasks/delete.d.ts.map +1 -0
- package/dist/commands/liberica/teams/tasks/delete.js +73 -0
- package/dist/commands/liberica/teams/tasks/delete.js.map +1 -0
- package/dist/commands/liberica/teams/tasks/get.d.ts +3 -0
- package/dist/commands/liberica/teams/tasks/get.d.ts.map +1 -0
- package/dist/commands/liberica/teams/tasks/get.js +51 -0
- package/dist/commands/liberica/teams/tasks/get.js.map +1 -0
- package/dist/commands/liberica/teams/tasks/index.d.ts +3 -0
- package/dist/commands/liberica/teams/tasks/index.d.ts.map +1 -0
- package/dist/commands/liberica/teams/tasks/index.js +17 -0
- package/dist/commands/liberica/teams/tasks/index.js.map +1 -0
- package/dist/commands/liberica/teams/tasks/list.d.ts +3 -0
- package/dist/commands/liberica/teams/tasks/list.d.ts.map +1 -0
- package/dist/commands/liberica/teams/tasks/list.js +82 -0
- package/dist/commands/liberica/teams/tasks/list.js.map +1 -0
- package/dist/commands/liberica/teams/tasks/update.d.ts +3 -0
- package/dist/commands/liberica/teams/tasks/update.d.ts.map +1 -0
- package/dist/commands/liberica/teams/tasks/update.js +114 -0
- package/dist/commands/liberica/teams/tasks/update.js.map +1 -0
- package/dist/commands/liberica/teams/work-logs/create.d.ts +3 -0
- package/dist/commands/liberica/teams/work-logs/create.d.ts.map +1 -0
- package/dist/commands/liberica/teams/work-logs/create.js +183 -0
- package/dist/commands/liberica/teams/work-logs/create.js.map +1 -0
- package/dist/commands/liberica/teams/work-logs/delete.d.ts +3 -0
- package/dist/commands/liberica/teams/work-logs/delete.d.ts.map +1 -0
- package/dist/commands/liberica/teams/work-logs/delete.js +55 -0
- package/dist/commands/liberica/teams/work-logs/delete.js.map +1 -0
- package/dist/commands/liberica/teams/work-logs/get.d.ts +3 -0
- package/dist/commands/liberica/teams/work-logs/get.d.ts.map +1 -0
- package/dist/commands/liberica/teams/work-logs/get.js +77 -0
- package/dist/commands/liberica/teams/work-logs/get.js.map +1 -0
- package/dist/commands/liberica/teams/work-logs/index.d.ts +3 -0
- package/dist/commands/liberica/teams/work-logs/index.d.ts.map +1 -0
- package/dist/commands/liberica/teams/work-logs/index.js +17 -0
- package/dist/commands/liberica/teams/work-logs/index.js.map +1 -0
- package/dist/commands/liberica/teams/work-logs/list.d.ts +3 -0
- package/dist/commands/liberica/teams/work-logs/list.d.ts.map +1 -0
- package/dist/commands/liberica/teams/work-logs/list.js +109 -0
- package/dist/commands/liberica/teams/work-logs/list.js.map +1 -0
- package/dist/commands/liberica/teams/work-logs/update.d.ts +3 -0
- package/dist/commands/liberica/teams/work-logs/update.d.ts.map +1 -0
- package/dist/commands/liberica/teams/work-logs/update.js +105 -0
- package/dist/commands/liberica/teams/work-logs/update.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/batch-delete.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/batch-delete.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/batch-delete.js +147 -0
- package/dist/commands/liberica/transfer-in-forms/batch-delete.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/batch-review.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/batch-review.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/batch-review.js +146 -0
- package/dist/commands/liberica/transfer-in-forms/batch-review.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/batch-unreview.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/batch-unreview.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/batch-unreview.js +147 -0
- package/dist/commands/liberica/transfer-in-forms/batch-unreview.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/create.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/create.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/create.js +168 -0
- package/dist/commands/liberica/transfer-in-forms/create.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/get.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/get.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/get.js +94 -0
- package/dist/commands/liberica/transfer-in-forms/get.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/index.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/index.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/index.js +21 -0
- package/dist/commands/liberica/transfer-in-forms/index.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/list.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/list.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/list.js +94 -0
- package/dist/commands/liberica/transfer-in-forms/list.js.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/update.d.ts +3 -0
- package/dist/commands/liberica/transfer-in-forms/update.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-in-forms/update.js +206 -0
- package/dist/commands/liberica/transfer-in-forms/update.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/batch-delete.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/batch-delete.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/batch-delete.js +80 -0
- package/dist/commands/liberica/transfer-out-forms/batch-delete.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/batch-review.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/batch-review.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/batch-review.js +142 -0
- package/dist/commands/liberica/transfer-out-forms/batch-review.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/batch-unreview.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/batch-unreview.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/batch-unreview.js +53 -0
- package/dist/commands/liberica/transfer-out-forms/batch-unreview.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/create.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/create.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/create.js +191 -0
- package/dist/commands/liberica/transfer-out-forms/create.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/get.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/get.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/get.js +87 -0
- package/dist/commands/liberica/transfer-out-forms/get.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/index.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/index.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/index.js +21 -0
- package/dist/commands/liberica/transfer-out-forms/index.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/list.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/list.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/list.js +118 -0
- package/dist/commands/liberica/transfer-out-forms/list.js.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/update.d.ts +3 -0
- package/dist/commands/liberica/transfer-out-forms/update.d.ts.map +1 -0
- package/dist/commands/liberica/transfer-out-forms/update.js +197 -0
- package/dist/commands/liberica/transfer-out-forms/update.js.map +1 -0
- package/dist/core/api/client.d.ts +42 -0
- package/dist/core/api/client.d.ts.map +1 -1
- package/dist/core/api/client.js +798 -0
- package/dist/core/api/client.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +5 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/team-issue.d.ts +87 -0
- package/dist/types/team-issue.d.ts.map +1 -0
- package/dist/types/team-issue.js +2 -0
- package/dist/types/team-issue.js.map +1 -0
- package/dist/types/team-project.d.ts +68 -0
- package/dist/types/team-project.d.ts.map +1 -0
- package/dist/types/team-project.js +2 -0
- package/dist/types/team-project.js.map +1 -0
- package/dist/types/team-task.d.ts +91 -0
- package/dist/types/team-task.d.ts.map +1 -0
- package/dist/types/team-task.js +2 -0
- package/dist/types/team-task.js.map +1 -0
- package/dist/types/team-work-log.d.ts +81 -0
- package/dist/types/team-work-log.d.ts.map +1 -0
- package/dist/types/team-work-log.js +2 -0
- package/dist/types/team-work-log.js.map +1 -0
- package/dist/types/transfer-in-form.d.ts +242 -0
- package/dist/types/transfer-in-form.d.ts.map +1 -0
- package/dist/types/transfer-in-form.js +2 -0
- package/dist/types/transfer-in-form.js.map +1 -0
- package/dist/types/transfer-out-form.d.ts +252 -0
- package/dist/types/transfer-out-form.d.ts.map +1 -0
- package/dist/types/transfer-out-form.js +4 -0
- package/dist/types/transfer-out-form.js.map +1 -0
- package/docs/commands/liberica/teams/issues/close.md +161 -0
- package/docs/commands/liberica/teams/issues/create.md +212 -0
- package/docs/commands/liberica/teams/issues/delete.md +179 -0
- package/docs/commands/liberica/teams/issues/get.md +167 -0
- package/docs/commands/liberica/teams/issues/list.md +182 -0
- package/docs/commands/liberica/teams/issues/tests-design.md +341 -0
- package/docs/commands/liberica/teams/issues/update.md +202 -0
- package/docs/commands/liberica/teams/projects/create.md +174 -0
- package/docs/commands/liberica/teams/projects/delete.md +180 -0
- package/docs/commands/liberica/teams/projects/get.md +150 -0
- package/docs/commands/liberica/teams/projects/list.md +179 -0
- package/docs/commands/liberica/teams/projects/update.md +175 -0
- package/docs/commands/liberica/teams/tasks/create.md +163 -0
- package/docs/commands/liberica/teams/tasks/delete.md +109 -0
- package/docs/commands/liberica/teams/tasks/get.md +121 -0
- package/docs/commands/liberica/teams/tasks/list.md +148 -0
- package/docs/commands/liberica/teams/tasks/update.md +158 -0
- package/docs/commands/liberica/teams/work-logs/create.md +151 -0
- package/docs/commands/liberica/teams/work-logs/delete.md +130 -0
- package/docs/commands/liberica/teams/work-logs/get.md +131 -0
- package/docs/commands/liberica/teams/work-logs/list.md +153 -0
- package/docs/commands/liberica/teams/work-logs/update.md +150 -0
- package/docs/commands/liberica/transfer-in-forms/batch-delete.md +157 -0
- package/docs/commands/liberica/transfer-in-forms/batch-review.md +157 -0
- package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +157 -0
- package/docs/commands/liberica/transfer-in-forms/create.md +220 -0
- package/docs/commands/liberica/transfer-in-forms/get.md +221 -0
- package/docs/commands/liberica/transfer-in-forms/list.md +242 -0
- package/docs/commands/liberica/transfer-in-forms/update.md +185 -0
- package/docs/commands/liberica/transfer-out-forms/batch-delete.md +187 -0
- package/docs/commands/liberica/transfer-out-forms/batch-review.md +157 -0
- package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +157 -0
- package/docs/commands/liberica/transfer-out-forms/create.md +280 -0
- package/docs/commands/liberica/transfer-out-forms/get.md +211 -0
- package/docs/commands/liberica/transfer-out-forms/list.md +233 -0
- package/docs/commands/liberica/transfer-out-forms/update.md +286 -0
- package/package.json +1 -1
- package/src/commands/liberica/index.ts +8 -1
- package/src/commands/liberica/teams/index.ts +17 -0
- package/src/commands/liberica/teams/issues/close.ts +104 -0
- package/src/commands/liberica/teams/issues/create.ts +254 -0
- package/src/commands/liberica/teams/issues/delete.ts +58 -0
- package/src/commands/liberica/teams/issues/get.ts +78 -0
- package/src/commands/liberica/teams/issues/index.ts +21 -0
- package/src/commands/liberica/teams/issues/list.ts +144 -0
- package/src/commands/liberica/teams/issues/update.ts +141 -0
- package/src/commands/liberica/teams/projects/create.ts +159 -0
- package/src/commands/liberica/teams/projects/delete.ts +58 -0
- package/src/commands/liberica/teams/projects/get.ts +87 -0
- package/src/commands/liberica/teams/projects/index.ts +19 -0
- package/src/commands/liberica/teams/projects/list.ts +147 -0
- package/src/commands/liberica/teams/projects/update.ts +117 -0
- package/src/commands/liberica/teams/tasks/create.ts +102 -0
- package/src/commands/liberica/teams/tasks/delete.ts +92 -0
- package/src/commands/liberica/teams/tasks/get.ts +64 -0
- package/src/commands/liberica/teams/tasks/index.ts +19 -0
- package/src/commands/liberica/teams/tasks/list.ts +102 -0
- package/src/commands/liberica/teams/tasks/update.ts +122 -0
- package/src/commands/liberica/teams/work-logs/create.ts +204 -0
- package/src/commands/liberica/teams/work-logs/delete.ts +58 -0
- package/src/commands/liberica/teams/work-logs/get.ts +87 -0
- package/src/commands/liberica/teams/work-logs/index.ts +19 -0
- package/src/commands/liberica/teams/work-logs/list.ts +141 -0
- package/src/commands/liberica/teams/work-logs/update.ts +120 -0
- package/src/commands/liberica/transfer-in-forms/batch-delete.ts +152 -0
- package/src/commands/liberica/transfer-in-forms/batch-review.ts +151 -0
- package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +152 -0
- package/src/commands/liberica/transfer-in-forms/create.ts +179 -0
- package/src/commands/liberica/transfer-in-forms/get.ts +107 -0
- package/src/commands/liberica/transfer-in-forms/index.ts +23 -0
- package/src/commands/liberica/transfer-in-forms/list.ts +97 -0
- package/src/commands/liberica/transfer-in-forms/update.ts +213 -0
- package/src/commands/liberica/transfer-out-forms/batch-delete.ts +83 -0
- package/src/commands/liberica/transfer-out-forms/batch-review.ts +148 -0
- package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +56 -0
- package/src/commands/liberica/transfer-out-forms/create.ts +194 -0
- package/src/commands/liberica/transfer-out-forms/get.ts +114 -0
- package/src/commands/liberica/transfer-out-forms/index.ts +23 -0
- package/src/commands/liberica/transfer-out-forms/list.ts +125 -0
- package/src/commands/liberica/transfer-out-forms/update.ts +197 -0
- package/src/core/api/client.ts +1218 -190
- package/src/index.ts +1 -1
- package/src/types/index.ts +5 -0
- package/src/types/team-issue.ts +94 -0
- package/src/types/team-project.ts +74 -0
- package/src/types/team-task.ts +98 -0
- package/src/types/team-work-log.ts +87 -0
- package/src/types/transfer-in-form.ts +265 -0
- package/src/types/transfer-out-form.ts +290 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import chalk from 'chalk';
|
|
3
|
+
import inquirer from 'inquirer';
|
|
4
|
+
import { configManager } from '../../../core/config/manager.js';
|
|
5
|
+
import { apiClient } from '../../../core/api/client.js';
|
|
6
|
+
import { Environment } from '../../../types/index.js';
|
|
7
|
+
import { TransferInForm } from '../../../types/transfer-in-form.js';
|
|
8
|
+
|
|
9
|
+
export function createTransferInFormBatchDeleteCommand(): Command {
|
|
10
|
+
const cmd = new Command('batch-delete');
|
|
11
|
+
cmd
|
|
12
|
+
.description('Batch delete transfer-in forms')
|
|
13
|
+
.argument('<ids...>', 'Transfer-in form IDs to delete')
|
|
14
|
+
.option('--force', 'Skip confirmation and delete directly')
|
|
15
|
+
.option('--dry-run', 'Preview what would be deleted')
|
|
16
|
+
.option('--json', 'Output as JSON');
|
|
17
|
+
|
|
18
|
+
cmd.action(async (ids: string[], options: Record<string, unknown>) => {
|
|
19
|
+
const context = configManager.getCurrentContext();
|
|
20
|
+
const environment = context.environment as Environment;
|
|
21
|
+
const tenant = context.tenant;
|
|
22
|
+
const jsonOutput = options.json === true;
|
|
23
|
+
const dryRun = options.dryRun === true;
|
|
24
|
+
const force = options.force === true;
|
|
25
|
+
|
|
26
|
+
if (ids.length === 0) {
|
|
27
|
+
const errMsg = 'No transfer-in form IDs provided';
|
|
28
|
+
if (jsonOutput) {
|
|
29
|
+
console.log(JSON.stringify({ success: false, error: { code: 'MISSING_IDS', message: errMsg } }));
|
|
30
|
+
} else {
|
|
31
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
32
|
+
}
|
|
33
|
+
process.exit(1);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Validate IDs are non-empty strings
|
|
37
|
+
const validIds = ids.filter(id => id.trim() !== '');
|
|
38
|
+
if (validIds.length === 0) {
|
|
39
|
+
const errMsg = 'No valid transfer-in form IDs provided';
|
|
40
|
+
if (jsonOutput) {
|
|
41
|
+
console.log(JSON.stringify({ success: false, error: { code: 'INVALID_IDS', message: errMsg } }));
|
|
42
|
+
} else {
|
|
43
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
44
|
+
}
|
|
45
|
+
process.exit(1);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Fetch details for dry-run or confirmation
|
|
49
|
+
const forms: TransferInForm[] = [];
|
|
50
|
+
if (!force || dryRun) {
|
|
51
|
+
for (const id of validIds) {
|
|
52
|
+
try {
|
|
53
|
+
const response = await apiClient.getTransferInForm(environment, tenant, id);
|
|
54
|
+
if (response.success && response.data && 'transferInFormId' in response.data) {
|
|
55
|
+
forms.push(response.data as TransferInForm);
|
|
56
|
+
} else {
|
|
57
|
+
// If not found, still continue but note missing
|
|
58
|
+
}
|
|
59
|
+
} catch {
|
|
60
|
+
// ignore fetch errors
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (dryRun) {
|
|
66
|
+
if (jsonOutput) {
|
|
67
|
+
console.log(JSON.stringify({
|
|
68
|
+
success: true,
|
|
69
|
+
dryRun: true,
|
|
70
|
+
ids: validIds,
|
|
71
|
+
forms: forms.map(form => ({
|
|
72
|
+
transferInFormId: form.transferInFormId,
|
|
73
|
+
transferInFormCode: form.transferInFormCode,
|
|
74
|
+
mainWarehouseCode: form.mainWarehouseCode,
|
|
75
|
+
stockDate: form.stockDate,
|
|
76
|
+
reviewFlag: form.reviewFlag,
|
|
77
|
+
})),
|
|
78
|
+
message: 'Dry-run mode: no actual deletion will be performed',
|
|
79
|
+
}));
|
|
80
|
+
} else {
|
|
81
|
+
console.log(chalk.bold('\n🔍 Dry-Run Mode: No changes will be made\n'));
|
|
82
|
+
console.log(chalk.gray(` IDs to delete: ${validIds.join(', ')}\n`));
|
|
83
|
+
if (forms.length > 0) {
|
|
84
|
+
console.log(chalk.gray(' Transfer-in forms to be deleted:'));
|
|
85
|
+
forms.forEach(form => {
|
|
86
|
+
console.log(chalk.gray(` • ${form.transferInFormCode} (ID: ${form.transferInFormId})`));
|
|
87
|
+
});
|
|
88
|
+
console.log();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if (!force) {
|
|
95
|
+
// Show confirmation prompt with details
|
|
96
|
+
if (!jsonOutput) {
|
|
97
|
+
console.log(chalk.bold('\n🗑️ Batch Delete Transfer-In Forms\n'));
|
|
98
|
+
console.log(chalk.gray(` IDs: ${validIds.join(', ')}\n`));
|
|
99
|
+
if (forms.length > 0) {
|
|
100
|
+
console.log(chalk.gray(' Transfer-in forms to delete:'));
|
|
101
|
+
forms.forEach(form => {
|
|
102
|
+
console.log(chalk.gray(` • ${form.transferInFormCode} (ID: ${form.transferInFormId})`));
|
|
103
|
+
});
|
|
104
|
+
console.log();
|
|
105
|
+
}
|
|
106
|
+
console.log(chalk.red('⚠️ This operation cannot be undone.\n'));
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
const { confirm } = await inquirer.prompt([
|
|
110
|
+
{
|
|
111
|
+
type: 'confirm',
|
|
112
|
+
name: 'confirm',
|
|
113
|
+
message: `Delete ${validIds.length} transfer-in form(s)?`,
|
|
114
|
+
default: false,
|
|
115
|
+
},
|
|
116
|
+
]);
|
|
117
|
+
|
|
118
|
+
if (!confirm) {
|
|
119
|
+
if (jsonOutput) {
|
|
120
|
+
console.log(JSON.stringify({ success: false, error: { code: 'CANCELLED', message: 'Operation cancelled by user' } }));
|
|
121
|
+
} else {
|
|
122
|
+
console.log(chalk.gray('\n Operation cancelled.\n'));
|
|
123
|
+
}
|
|
124
|
+
process.exit(0);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
if (!jsonOutput) {
|
|
129
|
+
console.log(chalk.bold(`\n🗑️ Deleting ${validIds.length} Transfer-In Form(s)\n`));
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
const response = await apiClient.batchDeleteTransferInForms(environment, tenant, validIds);
|
|
133
|
+
|
|
134
|
+
if (response.success) {
|
|
135
|
+
if (jsonOutput) {
|
|
136
|
+
console.log(JSON.stringify({ success: true, deletedCount: validIds.length, ids: validIds }));
|
|
137
|
+
} else {
|
|
138
|
+
console.log(chalk.green(`\n✓ ${validIds.length} transfer-in form(s) deleted\n`));
|
|
139
|
+
}
|
|
140
|
+
} else {
|
|
141
|
+
const errMsg = response.error?.message || 'Failed to delete';
|
|
142
|
+
if (jsonOutput) {
|
|
143
|
+
console.log(JSON.stringify({ success: false, error: { code: response.error?.code, message: errMsg } }));
|
|
144
|
+
} else {
|
|
145
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
146
|
+
}
|
|
147
|
+
process.exit(1);
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
return cmd;
|
|
152
|
+
}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import chalk from 'chalk';
|
|
3
|
+
import inquirer from 'inquirer';
|
|
4
|
+
import { configManager } from '../../../core/config/manager.js';
|
|
5
|
+
import { apiClient } from '../../../core/api/client.js';
|
|
6
|
+
import { Environment } from '../../../types/index.js';
|
|
7
|
+
import { TransferInForm } from '../../../types/transfer-in-form.js';
|
|
8
|
+
|
|
9
|
+
export function createTransferInFormBatchReviewCommand(): Command {
|
|
10
|
+
const cmd = new Command('batch-review');
|
|
11
|
+
cmd
|
|
12
|
+
.description('Batch review (审核) transfer-in forms')
|
|
13
|
+
.argument('<ids...>', 'Transfer-in form IDs to review')
|
|
14
|
+
.option('--force', 'Skip confirmation and review directly')
|
|
15
|
+
.option('--dry-run', 'Preview what would be reviewed')
|
|
16
|
+
.option('--json', 'Output as JSON');
|
|
17
|
+
|
|
18
|
+
cmd.action(async (ids: string[], options: Record<string, unknown>) => {
|
|
19
|
+
const context = configManager.getCurrentContext();
|
|
20
|
+
const environment = context.environment as Environment;
|
|
21
|
+
const tenant = context.tenant;
|
|
22
|
+
const jsonOutput = options.json === true;
|
|
23
|
+
const dryRun = options.dryRun === true;
|
|
24
|
+
const force = options.force === true;
|
|
25
|
+
|
|
26
|
+
if (ids.length === 0) {
|
|
27
|
+
const errMsg = 'No transfer-in form IDs provided';
|
|
28
|
+
if (jsonOutput) {
|
|
29
|
+
console.log(JSON.stringify({ success: false, error: { code: 'MISSING_IDS', message: errMsg } }));
|
|
30
|
+
} else {
|
|
31
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
32
|
+
}
|
|
33
|
+
process.exit(1);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Validate IDs are non-empty strings
|
|
37
|
+
const validIds = ids.filter(id => id.trim() !== '');
|
|
38
|
+
if (validIds.length === 0) {
|
|
39
|
+
const errMsg = 'No valid transfer-in form IDs provided';
|
|
40
|
+
if (jsonOutput) {
|
|
41
|
+
console.log(JSON.stringify({ success: false, error: { code: 'INVALID_IDS', message: errMsg } }));
|
|
42
|
+
} else {
|
|
43
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
44
|
+
}
|
|
45
|
+
process.exit(1);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Fetch details for dry-run or confirmation
|
|
49
|
+
const forms: TransferInForm[] = [];
|
|
50
|
+
if (!force || dryRun) {
|
|
51
|
+
for (const id of validIds) {
|
|
52
|
+
try {
|
|
53
|
+
const response = await apiClient.getTransferInForm(environment, tenant, id);
|
|
54
|
+
if (response.success && response.data && 'transferInFormId' in response.data) {
|
|
55
|
+
forms.push(response.data as TransferInForm);
|
|
56
|
+
} else {
|
|
57
|
+
// If not found, still continue but note missing
|
|
58
|
+
}
|
|
59
|
+
} catch {
|
|
60
|
+
// ignore fetch errors
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (dryRun) {
|
|
66
|
+
if (jsonOutput) {
|
|
67
|
+
console.log(JSON.stringify({
|
|
68
|
+
success: true,
|
|
69
|
+
dryRun: true,
|
|
70
|
+
ids: validIds,
|
|
71
|
+
forms: forms.map(form => ({
|
|
72
|
+
transferInFormId: form.transferInFormId,
|
|
73
|
+
transferInFormCode: form.transferInFormCode,
|
|
74
|
+
mainWarehouseCode: form.mainWarehouseCode,
|
|
75
|
+
stockDate: form.stockDate,
|
|
76
|
+
reviewFlag: form.reviewFlag,
|
|
77
|
+
})),
|
|
78
|
+
message: 'Dry-run mode: no actual review will be performed',
|
|
79
|
+
}));
|
|
80
|
+
} else {
|
|
81
|
+
console.log(chalk.bold('\n🔍 Dry-Run Mode: No changes will be made\n'));
|
|
82
|
+
console.log(chalk.gray(` IDs to review: ${validIds.join(', ')}\n`));
|
|
83
|
+
if (forms.length > 0) {
|
|
84
|
+
console.log(chalk.gray(' Transfer-in forms to be reviewed:'));
|
|
85
|
+
forms.forEach(form => {
|
|
86
|
+
console.log(chalk.gray(` • ${form.transferInFormCode} (ID: ${form.transferInFormId})`));
|
|
87
|
+
});
|
|
88
|
+
console.log();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if (!force) {
|
|
95
|
+
// Show confirmation prompt with details
|
|
96
|
+
if (!jsonOutput) {
|
|
97
|
+
console.log(chalk.bold('\n📝 Batch Review Transfer-In Forms\n'));
|
|
98
|
+
console.log(chalk.gray(` IDs: ${validIds.join(', ')}\n`));
|
|
99
|
+
if (forms.length > 0) {
|
|
100
|
+
console.log(chalk.gray(' Transfer-in forms to review:'));
|
|
101
|
+
forms.forEach(form => {
|
|
102
|
+
console.log(chalk.gray(` • ${form.transferInFormCode} (ID: ${form.transferInFormId})`));
|
|
103
|
+
});
|
|
104
|
+
console.log();
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const { confirm } = await inquirer.prompt([
|
|
109
|
+
{
|
|
110
|
+
type: 'confirm',
|
|
111
|
+
name: 'confirm',
|
|
112
|
+
message: `Review ${validIds.length} transfer-in form(s)?`,
|
|
113
|
+
default: false,
|
|
114
|
+
},
|
|
115
|
+
]);
|
|
116
|
+
|
|
117
|
+
if (!confirm) {
|
|
118
|
+
if (jsonOutput) {
|
|
119
|
+
console.log(JSON.stringify({ success: false, error: { code: 'CANCELLED', message: 'Operation cancelled by user' } }));
|
|
120
|
+
} else {
|
|
121
|
+
console.log(chalk.gray('\n Operation cancelled.\n'));
|
|
122
|
+
}
|
|
123
|
+
process.exit(0);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
if (!jsonOutput) {
|
|
128
|
+
console.log(chalk.bold(`\n📝 Reviewing ${validIds.length} Transfer-In Form(s)\n`));
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
const response = await apiClient.batchReviewTransferInForms(environment, tenant, validIds);
|
|
132
|
+
|
|
133
|
+
if (response.success) {
|
|
134
|
+
if (jsonOutput) {
|
|
135
|
+
console.log(JSON.stringify({ success: true, reviewedCount: validIds.length, ids: validIds }));
|
|
136
|
+
} else {
|
|
137
|
+
console.log(chalk.green(`\n✓ ${validIds.length} transfer-in form(s) reviewed\n`));
|
|
138
|
+
}
|
|
139
|
+
} else {
|
|
140
|
+
const errMsg = response.error?.message || 'Failed to review';
|
|
141
|
+
if (jsonOutput) {
|
|
142
|
+
console.log(JSON.stringify({ success: false, error: { code: response.error?.code, message: errMsg } }));
|
|
143
|
+
} else {
|
|
144
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
145
|
+
}
|
|
146
|
+
process.exit(1);
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
return cmd;
|
|
151
|
+
}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import chalk from 'chalk';
|
|
3
|
+
import inquirer from 'inquirer';
|
|
4
|
+
import { configManager } from '../../../core/config/manager.js';
|
|
5
|
+
import { apiClient } from '../../../core/api/client.js';
|
|
6
|
+
import { Environment } from '../../../types/index.js';
|
|
7
|
+
import { TransferInForm } from '../../../types/transfer-in-form.js';
|
|
8
|
+
|
|
9
|
+
export function createTransferInFormBatchUnreviewCommand(): Command {
|
|
10
|
+
const cmd = new Command('batch-unreview');
|
|
11
|
+
cmd
|
|
12
|
+
.description('Batch unreview (反审核) transfer-in forms')
|
|
13
|
+
.argument('<ids...>', 'Transfer-in form IDs to unreview')
|
|
14
|
+
.option('--force', 'Skip confirmation and unreview directly')
|
|
15
|
+
.option('--dry-run', 'Preview what would be unreviewed')
|
|
16
|
+
.option('--json', 'Output as JSON');
|
|
17
|
+
|
|
18
|
+
cmd.action(async (ids: string[], options: Record<string, unknown>) => {
|
|
19
|
+
const context = configManager.getCurrentContext();
|
|
20
|
+
const environment = context.environment as Environment;
|
|
21
|
+
const tenant = context.tenant;
|
|
22
|
+
const jsonOutput = options.json === true;
|
|
23
|
+
const dryRun = options.dryRun === true;
|
|
24
|
+
const force = options.force === true;
|
|
25
|
+
|
|
26
|
+
if (ids.length === 0) {
|
|
27
|
+
const errMsg = 'No transfer-in form IDs provided';
|
|
28
|
+
if (jsonOutput) {
|
|
29
|
+
console.log(JSON.stringify({ success: false, error: { code: 'MISSING_IDS', message: errMsg } }));
|
|
30
|
+
} else {
|
|
31
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
32
|
+
}
|
|
33
|
+
process.exit(1);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Validate IDs are non-empty strings
|
|
37
|
+
const validIds = ids.filter(id => id.trim() !== '');
|
|
38
|
+
if (validIds.length === 0) {
|
|
39
|
+
const errMsg = 'No valid transfer-in form IDs provided';
|
|
40
|
+
if (jsonOutput) {
|
|
41
|
+
console.log(JSON.stringify({ success: false, error: { code: 'INVALID_IDS', message: errMsg } }));
|
|
42
|
+
} else {
|
|
43
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
44
|
+
}
|
|
45
|
+
process.exit(1);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Fetch details for dry-run or confirmation
|
|
49
|
+
const forms: TransferInForm[] = [];
|
|
50
|
+
if (!force || dryRun) {
|
|
51
|
+
for (const id of validIds) {
|
|
52
|
+
try {
|
|
53
|
+
const response = await apiClient.getTransferInForm(environment, tenant, id);
|
|
54
|
+
if (response.success && response.data && 'transferInFormId' in response.data) {
|
|
55
|
+
forms.push(response.data as TransferInForm);
|
|
56
|
+
} else {
|
|
57
|
+
// If not found, still continue but note missing
|
|
58
|
+
}
|
|
59
|
+
} catch {
|
|
60
|
+
// ignore fetch errors
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (dryRun) {
|
|
66
|
+
if (jsonOutput) {
|
|
67
|
+
console.log(JSON.stringify({
|
|
68
|
+
success: true,
|
|
69
|
+
dryRun: true,
|
|
70
|
+
ids: validIds,
|
|
71
|
+
forms: forms.map(form => ({
|
|
72
|
+
transferInFormId: form.transferInFormId,
|
|
73
|
+
transferInFormCode: form.transferInFormCode,
|
|
74
|
+
mainWarehouseCode: form.mainWarehouseCode,
|
|
75
|
+
stockDate: form.stockDate,
|
|
76
|
+
reviewFlag: form.reviewFlag,
|
|
77
|
+
})),
|
|
78
|
+
message: 'Dry-run mode: no actual unreview will be performed',
|
|
79
|
+
}));
|
|
80
|
+
} else {
|
|
81
|
+
console.log(chalk.bold('\n🔍 Dry-Run Mode: No changes will be made\n'));
|
|
82
|
+
console.log(chalk.gray(` IDs to unreview: ${validIds.join(', ')}\n`));
|
|
83
|
+
if (forms.length > 0) {
|
|
84
|
+
console.log(chalk.gray(' Transfer-in forms to be unreviewed:'));
|
|
85
|
+
forms.forEach(form => {
|
|
86
|
+
console.log(chalk.gray(` • ${form.transferInFormCode} (ID: ${form.transferInFormId})`));
|
|
87
|
+
});
|
|
88
|
+
console.log();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if (!force) {
|
|
95
|
+
// Show confirmation prompt with details
|
|
96
|
+
if (!jsonOutput) {
|
|
97
|
+
console.log(chalk.bold('\n↩️ Batch Unreview Transfer-In Forms\n'));
|
|
98
|
+
console.log(chalk.gray(` IDs: ${validIds.join(', ')}\n`));
|
|
99
|
+
if (forms.length > 0) {
|
|
100
|
+
console.log(chalk.gray(' Transfer-in forms to unreview:'));
|
|
101
|
+
forms.forEach(form => {
|
|
102
|
+
console.log(chalk.gray(` • ${form.transferInFormCode} (ID: ${form.transferInFormId})`));
|
|
103
|
+
});
|
|
104
|
+
console.log();
|
|
105
|
+
}
|
|
106
|
+
console.log(chalk.yellow('⚠️ Unreview will make these forms editable again.\n'));
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
const { confirm } = await inquirer.prompt([
|
|
110
|
+
{
|
|
111
|
+
type: 'confirm',
|
|
112
|
+
name: 'confirm',
|
|
113
|
+
message: `Unreview ${validIds.length} transfer-in form(s)?`,
|
|
114
|
+
default: false,
|
|
115
|
+
},
|
|
116
|
+
]);
|
|
117
|
+
|
|
118
|
+
if (!confirm) {
|
|
119
|
+
if (jsonOutput) {
|
|
120
|
+
console.log(JSON.stringify({ success: false, error: { code: 'CANCELLED', message: 'Operation cancelled by user' } }));
|
|
121
|
+
} else {
|
|
122
|
+
console.log(chalk.gray('\n Operation cancelled.\n'));
|
|
123
|
+
}
|
|
124
|
+
process.exit(0);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
if (!jsonOutput) {
|
|
129
|
+
console.log(chalk.bold(`\n↩️ Unreviewing ${validIds.length} Transfer-In Form(s)\n`));
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
const response = await apiClient.batchUnreviewTransferInForms(environment, tenant, validIds);
|
|
133
|
+
|
|
134
|
+
if (response.success) {
|
|
135
|
+
if (jsonOutput) {
|
|
136
|
+
console.log(JSON.stringify({ success: true, unreviewedCount: validIds.length, ids: validIds }));
|
|
137
|
+
} else {
|
|
138
|
+
console.log(chalk.green(`\n✓ ${validIds.length} transfer-in form(s) unreviewed\n`));
|
|
139
|
+
}
|
|
140
|
+
} else {
|
|
141
|
+
const errMsg = response.error?.message || 'Failed to unreview';
|
|
142
|
+
if (jsonOutput) {
|
|
143
|
+
console.log(JSON.stringify({ success: false, error: { code: response.error?.code, message: errMsg } }));
|
|
144
|
+
} else {
|
|
145
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
146
|
+
}
|
|
147
|
+
process.exit(1);
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
return cmd;
|
|
152
|
+
}
|
|
@@ -0,0 +1,179 @@
|
|
|
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 { CreateTransferInFormRequest, TransferInFormItemRequest } from '../../../types/transfer-in-form.js';
|
|
6
|
+
import { Environment } from '../../../types/index.js';
|
|
7
|
+
|
|
8
|
+
export function createTransferInFormCreateCommand(): Command {
|
|
9
|
+
const cmd = new Command('create');
|
|
10
|
+
cmd.description('Create a transfer-in form');
|
|
11
|
+
|
|
12
|
+
cmd
|
|
13
|
+
.option('-c, --code <code>', 'Transfer-in form code (optional, auto-generated if empty)')
|
|
14
|
+
.requiredOption('-w, --warehouse-code <code>', 'Main warehouse code (required)')
|
|
15
|
+
.requiredOption('-t, --type <type>', 'Transfer-in type (required)')
|
|
16
|
+
.requiredOption('-f, --follower <id>', 'Follower ID (required)')
|
|
17
|
+
.option('--follower-name <name>', 'Follower name')
|
|
18
|
+
.option('--stock-date <date>', 'Stock date (YYYY-MM-DD, default: today)')
|
|
19
|
+
.option('--remark <remark>', 'Remark')
|
|
20
|
+
// Individual item options (for single item)
|
|
21
|
+
.option('--item-warehouse-code <code>', 'Item warehouse code (defaults to main warehouse code)')
|
|
22
|
+
.option('-m, --material-code <code>', 'Material code (required if not using --items)')
|
|
23
|
+
.option('--material-no <no>', 'Material number')
|
|
24
|
+
.option('--material-name <name>', 'Material name')
|
|
25
|
+
.option('--material-type <type>', 'Material type')
|
|
26
|
+
.option('-q, --quantity <number>', 'Form quantity (default: 1)')
|
|
27
|
+
.option('--form-uom <code>', 'Form UOM code (required if not using --items)')
|
|
28
|
+
.option('--unit-price <price>', 'Unit price (required if not using --items)')
|
|
29
|
+
.option('--produced-date <date>', 'Produced date (YYYY-MM-DD)')
|
|
30
|
+
.option('--lot-no <no>', 'Lot number')
|
|
31
|
+
.option('--item-remark <remark>', 'Item remark')
|
|
32
|
+
// JSON items array (alternative to individual options)
|
|
33
|
+
.option('--items <json>', 'JSON array of items (overrides individual item options)')
|
|
34
|
+
.option('--dry-run', 'Preview mode')
|
|
35
|
+
.option('--json', 'Output as JSON');
|
|
36
|
+
|
|
37
|
+
cmd.action(async () => {
|
|
38
|
+
const context = configManager.getCurrentContext();
|
|
39
|
+
const opts = cmd.opts();
|
|
40
|
+
const environment = context.environment as Environment;
|
|
41
|
+
const tenant = context.tenant;
|
|
42
|
+
const dryRun = opts.dryRun === true;
|
|
43
|
+
const jsonOutput = opts.json === true;
|
|
44
|
+
|
|
45
|
+
// Validate stock date format
|
|
46
|
+
if (opts.stockDate && !/^\d{4}-\d{2}-\d{2}$/.test(opts.stockDate)) {
|
|
47
|
+
console.error(chalk.red('\n✗ Invalid stock-date format. Use YYYY-MM-DD\n'));
|
|
48
|
+
process.exit(1);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
let itemList: TransferInFormItemRequest[] = [];
|
|
52
|
+
|
|
53
|
+
if (opts.items) {
|
|
54
|
+
// Parse JSON items
|
|
55
|
+
try {
|
|
56
|
+
const parsed = JSON.parse(opts.items);
|
|
57
|
+
if (!Array.isArray(parsed) || parsed.length === 0) {
|
|
58
|
+
console.error(chalk.red('\n✗ --items must be a non-empty JSON array\n'));
|
|
59
|
+
process.exit(1);
|
|
60
|
+
}
|
|
61
|
+
// Validate each item has required fields
|
|
62
|
+
for (const item of parsed) {
|
|
63
|
+
if (!item.warehouseCode || !item.materialCode || !item.formQuantity || !item.formMaterialUomCode || item.formUnitPrice == null) {
|
|
64
|
+
console.error(chalk.red('\n✗ Each item must have warehouseCode, materialCode, formQuantity, formMaterialUomCode, formUnitPrice\n'));
|
|
65
|
+
process.exit(1);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
itemList = parsed;
|
|
69
|
+
} catch (error) {
|
|
70
|
+
console.error(chalk.red('\n✗ Invalid JSON for --items: ' + (error instanceof Error ? error.message : 'Unknown error') + '\n'));
|
|
71
|
+
process.exit(1);
|
|
72
|
+
}
|
|
73
|
+
} else {
|
|
74
|
+
// Individual item options
|
|
75
|
+
// Validate required fields
|
|
76
|
+
if (!opts.materialCode) {
|
|
77
|
+
console.error(chalk.red('\n✗ Material code is required (--material-code)\n'));
|
|
78
|
+
process.exit(1);
|
|
79
|
+
}
|
|
80
|
+
if (!opts.formUom) {
|
|
81
|
+
console.error(chalk.red('\n✗ Form UOM code is required (--form-uom)\n'));
|
|
82
|
+
process.exit(1);
|
|
83
|
+
}
|
|
84
|
+
if (!opts.unitPrice) {
|
|
85
|
+
console.error(chalk.red('\n✗ Unit price is required (--unit-price)\n'));
|
|
86
|
+
process.exit(1);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
// Validate quantity
|
|
90
|
+
let quantity = 1;
|
|
91
|
+
if (opts.quantity) {
|
|
92
|
+
const q = parseFloat(opts.quantity);
|
|
93
|
+
if (isNaN(q) || q <= 0) {
|
|
94
|
+
console.error(chalk.red('\n✗ Quantity must be a positive number\n'));
|
|
95
|
+
process.exit(1);
|
|
96
|
+
}
|
|
97
|
+
quantity = q;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// Validate unit price
|
|
101
|
+
const unitPrice = parseFloat(opts.unitPrice);
|
|
102
|
+
if (isNaN(unitPrice) || unitPrice < 0) {
|
|
103
|
+
console.error(chalk.red('\n✗ Unit price must be a non-negative number\n'));
|
|
104
|
+
process.exit(1);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// Validate produced date format
|
|
108
|
+
if (opts.producedDate && !/^\d{4}-\d{2}-\d{2}$/.test(opts.producedDate)) {
|
|
109
|
+
console.error(chalk.red('\n✗ Invalid produced-date format. Use YYYY-MM-DD\n'));
|
|
110
|
+
process.exit(1);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
const item: TransferInFormItemRequest = {
|
|
114
|
+
warehouseCode: opts.itemWarehouseCode || opts.warehouseCode,
|
|
115
|
+
materialCode: opts.materialCode,
|
|
116
|
+
materialNo: opts.materialNo,
|
|
117
|
+
materialName: opts.materialName,
|
|
118
|
+
materialType: opts.materialType,
|
|
119
|
+
formQuantity: quantity,
|
|
120
|
+
formMaterialUomCode: opts.formUom,
|
|
121
|
+
formUnitPrice: unitPrice,
|
|
122
|
+
producedDate: opts.producedDate,
|
|
123
|
+
lotNo: opts.lotNo,
|
|
124
|
+
remark: opts.itemRemark,
|
|
125
|
+
};
|
|
126
|
+
itemList = [item];
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const request: CreateTransferInFormRequest = {
|
|
130
|
+
transferInFormCode: opts.code,
|
|
131
|
+
mainWarehouseCode: opts.warehouseCode,
|
|
132
|
+
stockDate: opts.stockDate || new Date().toISOString().split('T')[0],
|
|
133
|
+
transferInType: opts.type,
|
|
134
|
+
follower: opts.follower,
|
|
135
|
+
followerName: opts.followerName,
|
|
136
|
+
remark: opts.remark,
|
|
137
|
+
itemList,
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
if (dryRun) {
|
|
141
|
+
if (jsonOutput) {
|
|
142
|
+
console.log(JSON.stringify({ success: true, dryRun: true, data: request }));
|
|
143
|
+
} else {
|
|
144
|
+
console.log(chalk.bold('\n🔍 Dry-Run Mode: No changes will be made\n'));
|
|
145
|
+
console.log(' Transfer-in form to be created:');
|
|
146
|
+
console.log(` Warehouse: ${request.mainWarehouseCode}`);
|
|
147
|
+
console.log(` Type: ${request.transferInType}`);
|
|
148
|
+
console.log(` Follower: ${request.follower}`);
|
|
149
|
+
console.log(` Items: ${request.itemList.length}`);
|
|
150
|
+
console.log();
|
|
151
|
+
}
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
if (!jsonOutput) {
|
|
156
|
+
console.log(chalk.bold('\n📥 Creating Transfer-In Form\n'));
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
const response = await apiClient.createTransferInForm(environment, tenant, request);
|
|
160
|
+
|
|
161
|
+
if (response.success) {
|
|
162
|
+
if (jsonOutput) {
|
|
163
|
+
console.log(JSON.stringify({ success: true, data: response.data }));
|
|
164
|
+
} else {
|
|
165
|
+
console.log(chalk.green('\n✓ Transfer-in form created successfully\n'));
|
|
166
|
+
}
|
|
167
|
+
} else {
|
|
168
|
+
const errMsg = response.error?.message || 'Failed to create';
|
|
169
|
+
if (jsonOutput) {
|
|
170
|
+
console.log(JSON.stringify({ success: false, error: { code: response.error?.code, message: errMsg } }));
|
|
171
|
+
} else {
|
|
172
|
+
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
173
|
+
}
|
|
174
|
+
process.exit(1);
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
return cmd;
|
|
179
|
+
}
|