@newpeak/barista-cli 0.1.10 → 0.1.12
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/index.js +1 -1
- package/package.json +7 -3
- package/docs/ARCHITECTURE.md +0 -184
- package/docs/COMMANDS.md +0 -352
- package/docs/COMMAND_DESIGN_SPEC.md +0 -840
- package/docs/INTEGRATION_NOTES.md +0 -270
- package/docs/commands/REFERENCE.md +0 -323
- package/docs/commands/arabica/auth/index.md +0 -296
- package/docs/commands/liberica/auth/index.md +0 -133
- package/docs/commands/liberica/calendar/DESIGN.md +0 -333
- package/docs/commands/liberica/client-contacts/create.md +0 -152
- package/docs/commands/liberica/client-contacts/delete.md +0 -123
- package/docs/commands/liberica/client-contacts/get.md +0 -133
- package/docs/commands/liberica/client-contacts/list.md +0 -143
- package/docs/commands/liberica/client-contacts/update.md +0 -158
- package/docs/commands/liberica/context/index.md +0 -60
- package/docs/commands/liberica/currency/create.md +0 -145
- package/docs/commands/liberica/currency/delete.md +0 -121
- package/docs/commands/liberica/currency/disable.md +0 -119
- package/docs/commands/liberica/currency/enable.md +0 -115
- package/docs/commands/liberica/currency/get.md +0 -118
- package/docs/commands/liberica/currency/list.md +0 -149
- package/docs/commands/liberica/currency/update.md +0 -141
- package/docs/commands/liberica/employees/create.md +0 -185
- package/docs/commands/liberica/employees/disable.md +0 -138
- package/docs/commands/liberica/employees/enable.md +0 -137
- package/docs/commands/liberica/employees/get.md +0 -153
- package/docs/commands/liberica/employees/list.md +0 -168
- package/docs/commands/liberica/employees/update.md +0 -180
- package/docs/commands/liberica/locations/create.md +0 -195
- package/docs/commands/liberica/locations/list.md +0 -171
- package/docs/commands/liberica/materials/create.md +0 -293
- package/docs/commands/liberica/materials/delete.md +0 -240
- package/docs/commands/liberica/materials/disable.md +0 -150
- package/docs/commands/liberica/materials/enable.md +0 -146
- package/docs/commands/liberica/materials/get.md +0 -188
- package/docs/commands/liberica/materials/list.md +0 -198
- package/docs/commands/liberica/materials/update.md +0 -250
- package/docs/commands/liberica/orgs/list.md +0 -62
- package/docs/commands/liberica/positions/list.md +0 -61
- package/docs/commands/liberica/roles/list.md +0 -67
- package/docs/commands/liberica/stock/ledger.md +0 -209
- package/docs/commands/liberica/stock/list.md +0 -165
- package/docs/commands/liberica/supplier-contacts/create.md +0 -152
- package/docs/commands/liberica/supplier-contacts/delete.md +0 -123
- package/docs/commands/liberica/supplier-contacts/get.md +0 -133
- package/docs/commands/liberica/supplier-contacts/list.md +0 -143
- package/docs/commands/liberica/supplier-contacts/update.md +0 -158
- package/docs/commands/liberica/teams/issues/close.md +0 -161
- package/docs/commands/liberica/teams/issues/create.md +0 -212
- package/docs/commands/liberica/teams/issues/delete.md +0 -179
- package/docs/commands/liberica/teams/issues/get.md +0 -167
- package/docs/commands/liberica/teams/issues/list.md +0 -182
- package/docs/commands/liberica/teams/issues/tests-design.md +0 -341
- package/docs/commands/liberica/teams/issues/update.md +0 -202
- package/docs/commands/liberica/teams/projects/create.md +0 -174
- package/docs/commands/liberica/teams/projects/delete.md +0 -180
- package/docs/commands/liberica/teams/projects/get.md +0 -150
- package/docs/commands/liberica/teams/projects/list.md +0 -179
- package/docs/commands/liberica/teams/projects/update.md +0 -175
- package/docs/commands/liberica/teams/tasks/create.md +0 -163
- package/docs/commands/liberica/teams/tasks/delete.md +0 -109
- package/docs/commands/liberica/teams/tasks/get.md +0 -121
- package/docs/commands/liberica/teams/tasks/list.md +0 -148
- package/docs/commands/liberica/teams/tasks/update.md +0 -158
- package/docs/commands/liberica/teams/work-logs/create.md +0 -151
- package/docs/commands/liberica/teams/work-logs/delete.md +0 -130
- package/docs/commands/liberica/teams/work-logs/get.md +0 -131
- package/docs/commands/liberica/teams/work-logs/list.md +0 -153
- package/docs/commands/liberica/teams/work-logs/update.md +0 -150
- package/docs/commands/liberica/transfer-in-forms/batch-delete.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/batch-review.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/create.md +0 -220
- package/docs/commands/liberica/transfer-in-forms/get.md +0 -221
- package/docs/commands/liberica/transfer-in-forms/list.md +0 -242
- package/docs/commands/liberica/transfer-in-forms/update.md +0 -185
- package/docs/commands/liberica/transfer-out-forms/batch-delete.md +0 -187
- package/docs/commands/liberica/transfer-out-forms/batch-review.md +0 -157
- package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +0 -157
- package/docs/commands/liberica/transfer-out-forms/create.md +0 -280
- package/docs/commands/liberica/transfer-out-forms/get.md +0 -211
- package/docs/commands/liberica/transfer-out-forms/list.md +0 -233
- package/docs/commands/liberica/transfer-out-forms/update.md +0 -286
- package/docs/commands/liberica/uoms/create.md +0 -136
- package/docs/commands/liberica/uoms/delete.md +0 -119
- package/docs/commands/liberica/uoms/disable.md +0 -117
- package/docs/commands/liberica/uoms/enable.md +0 -115
- package/docs/commands/liberica/uoms/get.md +0 -119
- package/docs/commands/liberica/uoms/list.md +0 -155
- package/docs/commands/liberica/uoms/update.md +0 -148
- package/docs/commands/liberica/users/create.md +0 -170
- package/docs/commands/liberica/users/get.md +0 -151
- package/docs/commands/liberica/users/list.md +0 -175
- package/docs/commands/liberica/warehouses/create.md +0 -222
- package/docs/commands/liberica/warehouses/list.md +0 -184
- package/src/commands/arabica/auth/index.ts +0 -277
- package/src/commands/arabica/auth/login.ts +0 -5
- package/src/commands/arabica/auth/logout.ts +0 -5
- package/src/commands/arabica/auth/register.ts +0 -5
- package/src/commands/arabica/auth/status.ts +0 -5
- package/src/commands/arabica/index.ts +0 -23
- package/src/commands/auth.ts +0 -107
- package/src/commands/context.ts +0 -60
- package/src/commands/liberica/auth/index.ts +0 -176
- package/src/commands/liberica/calendar/index.ts +0 -13
- package/src/commands/liberica/calendar/list.ts +0 -214
- package/src/commands/liberica/calendar/set.ts +0 -130
- package/src/commands/liberica/client-contacts/create.ts +0 -115
- package/src/commands/liberica/client-contacts/delete.ts +0 -140
- package/src/commands/liberica/client-contacts/get.ts +0 -103
- package/src/commands/liberica/client-contacts/index.ts +0 -19
- package/src/commands/liberica/client-contacts/list.ts +0 -118
- package/src/commands/liberica/client-contacts/update.ts +0 -137
- package/src/commands/liberica/clients/create.ts +0 -122
- package/src/commands/liberica/clients/delete.ts +0 -125
- package/src/commands/liberica/clients/get.ts +0 -88
- package/src/commands/liberica/clients/index.ts +0 -19
- package/src/commands/liberica/clients/list.ts +0 -123
- package/src/commands/liberica/clients/update.ts +0 -103
- package/src/commands/liberica/context/index.ts +0 -43
- package/src/commands/liberica/currency/create.ts +0 -183
- package/src/commands/liberica/currency/delete.ts +0 -124
- package/src/commands/liberica/currency/disable.ts +0 -147
- package/src/commands/liberica/currency/enable.ts +0 -128
- package/src/commands/liberica/currency/get.ts +0 -91
- package/src/commands/liberica/currency/index.ts +0 -23
- package/src/commands/liberica/currency/list.ts +0 -140
- package/src/commands/liberica/currency/update.ts +0 -129
- package/src/commands/liberica/dict-types/get.ts +0 -74
- package/src/commands/liberica/dict-types/index.ts +0 -15
- package/src/commands/liberica/dict-types/list.ts +0 -118
- package/src/commands/liberica/dict-types/update.ts +0 -134
- package/src/commands/liberica/dicts/create.ts +0 -175
- package/src/commands/liberica/dicts/delete.ts +0 -107
- package/src/commands/liberica/dicts/get.ts +0 -80
- package/src/commands/liberica/dicts/index.ts +0 -19
- package/src/commands/liberica/dicts/list.ts +0 -114
- package/src/commands/liberica/dicts/update.ts +0 -116
- package/src/commands/liberica/employees/create.ts +0 -275
- package/src/commands/liberica/employees/delete.ts +0 -122
- package/src/commands/liberica/employees/disable.ts +0 -97
- package/src/commands/liberica/employees/enable.ts +0 -97
- package/src/commands/liberica/employees/get.ts +0 -115
- package/src/commands/liberica/employees/index.ts +0 -23
- package/src/commands/liberica/employees/list.ts +0 -131
- package/src/commands/liberica/employees/update.ts +0 -157
- package/src/commands/liberica/index.ts +0 -81
- package/src/commands/liberica/materials/create.ts +0 -199
- package/src/commands/liberica/materials/delete.ts +0 -105
- package/src/commands/liberica/materials/disable.ts +0 -148
- package/src/commands/liberica/materials/enable.ts +0 -129
- package/src/commands/liberica/materials/get.ts +0 -83
- package/src/commands/liberica/materials/index.ts +0 -23
- package/src/commands/liberica/materials/list.ts +0 -142
- package/src/commands/liberica/materials/update.ts +0 -125
- package/src/commands/liberica/mould/get.ts +0 -111
- package/src/commands/liberica/mould/index.ts +0 -17
- package/src/commands/liberica/mould/list.ts +0 -157
- package/src/commands/liberica/mould/set-status.ts +0 -99
- package/src/commands/liberica/mould/stock-in.ts +0 -165
- package/src/commands/liberica/operations/active.ts +0 -153
- package/src/commands/liberica/operations/batch-delete.ts +0 -131
- package/src/commands/liberica/operations/copy.ts +0 -138
- package/src/commands/liberica/operations/create.ts +0 -223
- package/src/commands/liberica/operations/deactive.ts +0 -152
- package/src/commands/liberica/operations/delete.ts +0 -128
- package/src/commands/liberica/operations/design.md +0 -587
- package/src/commands/liberica/operations/get.ts +0 -112
- package/src/commands/liberica/operations/index.ts +0 -27
- package/src/commands/liberica/operations/list.ts +0 -180
- package/src/commands/liberica/operations/update.ts +0 -218
- package/src/commands/liberica/orgs/index.ts +0 -34
- package/src/commands/liberica/positions/index.ts +0 -30
- package/src/commands/liberica/roles/index.ts +0 -59
- package/src/commands/liberica/stock/index.ts +0 -13
- package/src/commands/liberica/stock/ledger.ts +0 -159
- package/src/commands/liberica/stock/list.ts +0 -128
- package/src/commands/liberica/supplier-contacts/create.ts +0 -120
- package/src/commands/liberica/supplier-contacts/delete.ts +0 -88
- package/src/commands/liberica/supplier-contacts/get.ts +0 -94
- package/src/commands/liberica/supplier-contacts/index.ts +0 -19
- package/src/commands/liberica/supplier-contacts/list.ts +0 -130
- package/src/commands/liberica/supplier-contacts/update.ts +0 -127
- package/src/commands/liberica/suppliers/create.ts +0 -149
- package/src/commands/liberica/suppliers/delete.ts +0 -102
- package/src/commands/liberica/suppliers/disable.ts +0 -145
- package/src/commands/liberica/suppliers/enable.ts +0 -126
- package/src/commands/liberica/suppliers/get.ts +0 -86
- package/src/commands/liberica/suppliers/index.ts +0 -23
- package/src/commands/liberica/suppliers/list.ts +0 -134
- package/src/commands/liberica/suppliers/update.ts +0 -128
- package/src/commands/liberica/teams/index.ts +0 -17
- package/src/commands/liberica/teams/issues/close.ts +0 -104
- package/src/commands/liberica/teams/issues/create.ts +0 -254
- package/src/commands/liberica/teams/issues/delete.ts +0 -58
- package/src/commands/liberica/teams/issues/get.ts +0 -78
- package/src/commands/liberica/teams/issues/index.ts +0 -21
- package/src/commands/liberica/teams/issues/list.ts +0 -144
- package/src/commands/liberica/teams/issues/update.ts +0 -141
- package/src/commands/liberica/teams/projects/create.ts +0 -159
- package/src/commands/liberica/teams/projects/delete.ts +0 -58
- package/src/commands/liberica/teams/projects/get.ts +0 -87
- package/src/commands/liberica/teams/projects/index.ts +0 -19
- package/src/commands/liberica/teams/projects/list.ts +0 -147
- package/src/commands/liberica/teams/projects/update.ts +0 -117
- package/src/commands/liberica/teams/tasks/create.ts +0 -102
- package/src/commands/liberica/teams/tasks/delete.ts +0 -92
- package/src/commands/liberica/teams/tasks/get.ts +0 -64
- package/src/commands/liberica/teams/tasks/index.ts +0 -19
- package/src/commands/liberica/teams/tasks/list.ts +0 -102
- package/src/commands/liberica/teams/tasks/update.ts +0 -122
- package/src/commands/liberica/teams/work-logs/create.ts +0 -204
- package/src/commands/liberica/teams/work-logs/delete.ts +0 -58
- package/src/commands/liberica/teams/work-logs/get.ts +0 -87
- package/src/commands/liberica/teams/work-logs/index.ts +0 -19
- package/src/commands/liberica/teams/work-logs/list.ts +0 -141
- package/src/commands/liberica/teams/work-logs/update.ts +0 -120
- package/src/commands/liberica/transfer-in-forms/batch-delete.ts +0 -152
- package/src/commands/liberica/transfer-in-forms/batch-review.ts +0 -151
- package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +0 -152
- package/src/commands/liberica/transfer-in-forms/create.ts +0 -179
- package/src/commands/liberica/transfer-in-forms/get.ts +0 -107
- package/src/commands/liberica/transfer-in-forms/index.ts +0 -23
- package/src/commands/liberica/transfer-in-forms/list.ts +0 -97
- package/src/commands/liberica/transfer-in-forms/update.ts +0 -213
- package/src/commands/liberica/transfer-out-forms/batch-delete.ts +0 -83
- package/src/commands/liberica/transfer-out-forms/batch-review.ts +0 -148
- package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +0 -56
- package/src/commands/liberica/transfer-out-forms/create.ts +0 -194
- package/src/commands/liberica/transfer-out-forms/get.ts +0 -114
- package/src/commands/liberica/transfer-out-forms/index.ts +0 -23
- package/src/commands/liberica/transfer-out-forms/list.ts +0 -125
- package/src/commands/liberica/transfer-out-forms/update.ts +0 -197
- package/src/commands/liberica/uoms/create.ts +0 -134
- package/src/commands/liberica/uoms/delete.ts +0 -105
- package/src/commands/liberica/uoms/disable.ts +0 -148
- package/src/commands/liberica/uoms/enable.ts +0 -129
- package/src/commands/liberica/uoms/get.ts +0 -83
- package/src/commands/liberica/uoms/index.ts +0 -23
- package/src/commands/liberica/uoms/list.ts +0 -129
- package/src/commands/liberica/uoms/update.ts +0 -124
- package/src/commands/liberica/users/create.ts +0 -133
- package/src/commands/liberica/users/delete.ts +0 -49
- package/src/commands/liberica/users/disable.ts +0 -41
- package/src/commands/liberica/users/enable.ts +0 -30
- package/src/commands/liberica/users/get.ts +0 -46
- package/src/commands/liberica/users/index.ts +0 -27
- package/src/commands/liberica/users/list.ts +0 -68
- package/src/commands/liberica/users/me.ts +0 -42
- package/src/commands/liberica/users/reset-password.ts +0 -42
- package/src/commands/liberica/users/update.ts +0 -48
- package/src/commands/liberica/warehouses/create.ts +0 -204
- package/src/commands/liberica/warehouses/delete.ts +0 -112
- package/src/commands/liberica/warehouses/disable.ts +0 -174
- package/src/commands/liberica/warehouses/enable.ts +0 -174
- package/src/commands/liberica/warehouses/get.ts +0 -101
- package/src/commands/liberica/warehouses/index.ts +0 -25
- package/src/commands/liberica/warehouses/list.ts +0 -136
- package/src/commands/liberica/warehouses/locations/create.ts +0 -209
- package/src/commands/liberica/warehouses/locations/delete.ts +0 -116
- package/src/commands/liberica/warehouses/locations/disable.ts +0 -174
- package/src/commands/liberica/warehouses/locations/enable.ts +0 -174
- package/src/commands/liberica/warehouses/locations/get.ts +0 -84
- package/src/commands/liberica/warehouses/locations/index.ts +0 -23
- package/src/commands/liberica/warehouses/locations/list.ts +0 -140
- package/src/commands/liberica/warehouses/locations/update.ts +0 -135
- package/src/commands/liberica/warehouses/update.ts +0 -142
- package/src/core/api/client.ts +0 -4443
- package/src/core/auth/token-manager.ts +0 -183
- package/src/core/config/manager.ts +0 -164
- package/src/index.ts +0 -35
- package/src/types/calendar.ts +0 -36
- package/src/types/client-contact.ts +0 -78
- package/src/types/client.ts +0 -115
- package/src/types/currency.ts +0 -90
- package/src/types/dict.ts +0 -121
- package/src/types/employee.ts +0 -102
- package/src/types/index.ts +0 -93
- package/src/types/location.ts +0 -66
- package/src/types/material.ts +0 -61
- package/src/types/mould-stock-in.ts +0 -82
- package/src/types/mould.ts +0 -74
- package/src/types/operation.ts +0 -72
- package/src/types/org.ts +0 -25
- package/src/types/position.ts +0 -24
- package/src/types/stock.ts +0 -161
- package/src/types/supplier-contact.ts +0 -78
- package/src/types/supplier.ts +0 -66
- package/src/types/team-issue.ts +0 -94
- package/src/types/team-project.ts +0 -74
- package/src/types/team-task.ts +0 -98
- package/src/types/team-work-log.ts +0 -87
- package/src/types/transfer-in-form.ts +0 -265
- package/src/types/transfer-out-form.ts +0 -290
- package/src/types/uom.ts +0 -60
- package/src/types/user.ts +0 -64
- package/src/types/warehouse.ts +0 -82
|
@@ -1,99 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,165 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,153 +0,0 @@
|
|
|
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 { Environment } from '../../../types/index.js';
|
|
6
|
-
import { Operation } from '../../../types/operation.js';
|
|
7
|
-
|
|
8
|
-
export function createOperationActiveCommand(): Command {
|
|
9
|
-
const activeCommand = new Command('active');
|
|
10
|
-
activeCommand
|
|
11
|
-
.description('Enable (activate) operation(s)')
|
|
12
|
-
.argument('[operation-id]', 'Operation ID (mutually exclusive with --ids)')
|
|
13
|
-
.option('--ids <ids>', 'Comma-separated operation IDs for batch operations')
|
|
14
|
-
.option('--force', 'Execute the operation (skip dry-run preview)')
|
|
15
|
-
.option('--dry-run', 'Preview the operation without executing (default)')
|
|
16
|
-
.option('--json', 'Output as JSON')
|
|
17
|
-
.action(async (operationId: string | undefined, options: Record<string, unknown>) => {
|
|
18
|
-
const context = configManager.getCurrentContext();
|
|
19
|
-
const environment = context.environment as Environment;
|
|
20
|
-
const tenant = context.tenant;
|
|
21
|
-
const force = options.force === true;
|
|
22
|
-
const dryRun = !force;
|
|
23
|
-
|
|
24
|
-
const batchIds = options.ids
|
|
25
|
-
? (options.ids as string).split(',').map((id) => id.trim()).filter((id) => id !== '')
|
|
26
|
-
: [];
|
|
27
|
-
|
|
28
|
-
const jsonOutput = options.json === true;
|
|
29
|
-
|
|
30
|
-
if (!operationId && batchIds.length === 0) {
|
|
31
|
-
const errMsg = 'Invalid operation ID. Provide <operation-id> or use --ids for batch operations.';
|
|
32
|
-
if (jsonOutput) {
|
|
33
|
-
console.log(JSON.stringify({ success: false, error: { code: 'INVALID_ID', message: errMsg } }));
|
|
34
|
-
} else {
|
|
35
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
36
|
-
}
|
|
37
|
-
process.exit(1);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
const allIds = operationId ? [operationId] : batchIds;
|
|
41
|
-
|
|
42
|
-
if (!jsonOutput) {
|
|
43
|
-
console.log(chalk.bold(`\n↑ Enable Operation(s) (${environment})\n`));
|
|
44
|
-
if (batchIds.length > 0) {
|
|
45
|
-
console.log(chalk.gray(` Operation IDs: ${batchIds.join(', ')}`));
|
|
46
|
-
} else {
|
|
47
|
-
console.log(chalk.gray(` Operation ID: ${operationId}`));
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
if (dryRun) {
|
|
52
|
-
if (jsonOutput) {
|
|
53
|
-
console.log(JSON.stringify({
|
|
54
|
-
success: true,
|
|
55
|
-
dryRun: true,
|
|
56
|
-
operationIds: allIds,
|
|
57
|
-
message: 'No actual API call will be made',
|
|
58
|
-
}));
|
|
59
|
-
} else {
|
|
60
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual API call will be made\n'));
|
|
61
|
-
console.log(chalk.gray(` This operation will enable ${allIds.length} operation(s).`));
|
|
62
|
-
console.log(chalk.gray('\n To execute, add --force flag.\n'));
|
|
63
|
-
}
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
const operations: Operation[] = [];
|
|
68
|
-
for (const id of allIds) {
|
|
69
|
-
try {
|
|
70
|
-
const response = await apiClient.getOperationDetail(environment, tenant, id);
|
|
71
|
-
if (!response.success || !response.data || !('operationId' in response.data)) {
|
|
72
|
-
const errMsg = `Operation not found: ${id}`;
|
|
73
|
-
if (jsonOutput) {
|
|
74
|
-
console.log(JSON.stringify({ success: false, error: { code: 'NOT_FOUND', message: errMsg } }));
|
|
75
|
-
} else {
|
|
76
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
77
|
-
}
|
|
78
|
-
process.exit(1);
|
|
79
|
-
}
|
|
80
|
-
operations.push(response.data as Operation);
|
|
81
|
-
} catch (error) {
|
|
82
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
83
|
-
const jsonErr = { success: false, error: { code: 'FETCH_ERROR', message: 'Failed to fetch operation: ' + errMsg } };
|
|
84
|
-
if (jsonOutput) {
|
|
85
|
-
console.log(JSON.stringify(jsonErr));
|
|
86
|
-
} else {
|
|
87
|
-
console.error(chalk.red(`\n✗ Failed to fetch operation: ${errMsg}\n`));
|
|
88
|
-
}
|
|
89
|
-
process.exit(1);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
const allAlreadyEnabled = operations.every((op) => op.statusFlag === 1);
|
|
94
|
-
if (allAlreadyEnabled) {
|
|
95
|
-
const names = operations.map((op) => `"${op.operationName}"`).join(', ');
|
|
96
|
-
const errMsg = `Operation(s) ${names} ${operations.length === 1 ? 'is' : 'are'} already enabled`;
|
|
97
|
-
if (jsonOutput) {
|
|
98
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ALREADY_ENABLED', message: errMsg } }));
|
|
99
|
-
} else {
|
|
100
|
-
console.error(chalk.yellow(`\n⚠ ${errMsg}\n`));
|
|
101
|
-
}
|
|
102
|
-
process.exit(1);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
if (!jsonOutput) {
|
|
106
|
-
if (operations.length === 1) {
|
|
107
|
-
console.log(chalk.gray(` Name: ${operations[0].operationName}`));
|
|
108
|
-
console.log(chalk.gray(` Code: ${operations[0].operationCode}`));
|
|
109
|
-
} else {
|
|
110
|
-
operations.forEach((op, i) => {
|
|
111
|
-
console.log(chalk.gray(` [${i + 1}] ${op.operationName} (${op.operationCode})`));
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
console.log();
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
try {
|
|
118
|
-
const response = await apiClient.batchActiveOperations(environment, tenant, allIds);
|
|
119
|
-
|
|
120
|
-
if (response.success) {
|
|
121
|
-
if (jsonOutput) {
|
|
122
|
-
console.log(JSON.stringify({ success: true, operationIds: allIds }));
|
|
123
|
-
} else {
|
|
124
|
-
const names = operations.map((op) => op.operationName).join(', ');
|
|
125
|
-
console.log(chalk.green(`\n✓ Operation(s) ${names || allIds.join(', ')} enabled\n`));
|
|
126
|
-
}
|
|
127
|
-
} else {
|
|
128
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
129
|
-
const errorCode = response.error?.code || 'ACTIVE_ERROR';
|
|
130
|
-
if (jsonOutput) {
|
|
131
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
132
|
-
} else {
|
|
133
|
-
console.error(chalk.red(`\n✗ Failed to enable operation(s): ${errorMsg}`));
|
|
134
|
-
if (response.error?.code) {
|
|
135
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
136
|
-
}
|
|
137
|
-
console.error();
|
|
138
|
-
}
|
|
139
|
-
process.exit(1);
|
|
140
|
-
}
|
|
141
|
-
} catch (error) {
|
|
142
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
143
|
-
if (jsonOutput) {
|
|
144
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
145
|
-
} else {
|
|
146
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
147
|
-
}
|
|
148
|
-
process.exit(1);
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
return activeCommand;
|
|
153
|
-
}
|
|
@@ -1,131 +0,0 @@
|
|
|
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 { Environment } from '../../../types/index.js';
|
|
6
|
-
import { Operation } from '../../../types/operation.js';
|
|
7
|
-
|
|
8
|
-
export function createBatchDeleteCommand(): Command {
|
|
9
|
-
const batchDeleteCommand = new Command('batch-delete');
|
|
10
|
-
batchDeleteCommand
|
|
11
|
-
.description('Batch delete operations')
|
|
12
|
-
.requiredOption('--ids <ids>', 'Comma-separated operation IDs')
|
|
13
|
-
.option('--force', 'Skip confirmation and delete directly')
|
|
14
|
-
.option('--dry-run', 'Preview without API call (default)')
|
|
15
|
-
.option('--json', 'Output as JSON')
|
|
16
|
-
.action(async (options: Record<string, unknown>) => {
|
|
17
|
-
const context = configManager.getCurrentContext();
|
|
18
|
-
const environment = context.environment as Environment;
|
|
19
|
-
const tenant = context.tenant;
|
|
20
|
-
const force = options.force === true;
|
|
21
|
-
const dryRun = options.dryRun === true || !force;
|
|
22
|
-
const jsonOutput = options.json === true;
|
|
23
|
-
const idsParam = options.ids as string;
|
|
24
|
-
|
|
25
|
-
if (!idsParam) {
|
|
26
|
-
const errMsg = 'Missing required option: --ids';
|
|
27
|
-
if (jsonOutput) {
|
|
28
|
-
console.log(JSON.stringify({ success: false, error: { code: 'MISSING_IDS', message: errMsg } }));
|
|
29
|
-
} else {
|
|
30
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
31
|
-
}
|
|
32
|
-
process.exit(1);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const ids = idsParam.split(',').map((id) => id.trim()).filter((id) => id !== '');
|
|
36
|
-
|
|
37
|
-
if (ids.length === 0) {
|
|
38
|
-
const errMsg = 'No valid operation IDs provided';
|
|
39
|
-
if (jsonOutput) {
|
|
40
|
-
console.log(JSON.stringify({ success: false, error: { code: 'INVALID_IDS', message: errMsg } }));
|
|
41
|
-
} else {
|
|
42
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
43
|
-
}
|
|
44
|
-
process.exit(1);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
if (!jsonOutput) {
|
|
48
|
-
console.log(chalk.bold(`\n🗑️ Batch Delete Operations (${environment})\n`));
|
|
49
|
-
console.log(chalk.gray(` Operation IDs: ${ids.join(', ')}`));
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
if (dryRun) {
|
|
53
|
-
const operations: Operation[] = [];
|
|
54
|
-
for (const id of ids) {
|
|
55
|
-
try {
|
|
56
|
-
const response = await apiClient.getOperationDetail(environment, tenant, id);
|
|
57
|
-
if (response.success && response.data && 'operationId' in response.data) {
|
|
58
|
-
operations.push(response.data as Operation);
|
|
59
|
-
}
|
|
60
|
-
} catch {
|
|
61
|
-
// skip fetch errors
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
if (jsonOutput) {
|
|
66
|
-
console.log(JSON.stringify({
|
|
67
|
-
success: true,
|
|
68
|
-
dryRun: true,
|
|
69
|
-
operationIds: ids,
|
|
70
|
-
operations: operations.map((op) => ({
|
|
71
|
-
operationId: op.operationId,
|
|
72
|
-
operationCode: op.operationCode,
|
|
73
|
-
operationName: op.operationName,
|
|
74
|
-
operationType: op.operationType,
|
|
75
|
-
})),
|
|
76
|
-
message: 'Dry-run mode: no actual deletion will be performed',
|
|
77
|
-
}));
|
|
78
|
-
} else {
|
|
79
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual deletion will be performed\n'));
|
|
80
|
-
if (operations.length > 0) {
|
|
81
|
-
console.log(chalk.gray(' Operations to be deleted:'));
|
|
82
|
-
operations.forEach((op) => {
|
|
83
|
-
console.log(chalk.gray(` - ${op.operationName} (${op.operationCode}) [${op.operationId}]`));
|
|
84
|
-
});
|
|
85
|
-
} else {
|
|
86
|
-
console.log(chalk.gray(` ${ids.length} operation(s) will be deleted.`));
|
|
87
|
-
}
|
|
88
|
-
console.log();
|
|
89
|
-
console.log(chalk.yellow(' To delete, run with --force flag'));
|
|
90
|
-
console.log();
|
|
91
|
-
}
|
|
92
|
-
return;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
// Actual deletion with --force
|
|
96
|
-
try {
|
|
97
|
-
const response = await apiClient.batchDeleteOperations(environment, tenant, ids);
|
|
98
|
-
|
|
99
|
-
if (response.success) {
|
|
100
|
-
if (jsonOutput) {
|
|
101
|
-
console.log(JSON.stringify({ success: true, operationIds: ids }));
|
|
102
|
-
} else {
|
|
103
|
-
console.log(chalk.green(`\n✓ Deleted ${ids.length} operation(s)\n`));
|
|
104
|
-
}
|
|
105
|
-
} else {
|
|
106
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
107
|
-
const errorCode = response.error?.code || 'DELETE_ERROR';
|
|
108
|
-
if (jsonOutput) {
|
|
109
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
110
|
-
} else {
|
|
111
|
-
console.error(chalk.red(`\n✗ Failed to delete operations: ${errorMsg}`));
|
|
112
|
-
if (response.error?.code) {
|
|
113
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
114
|
-
}
|
|
115
|
-
console.error();
|
|
116
|
-
}
|
|
117
|
-
process.exit(1);
|
|
118
|
-
}
|
|
119
|
-
} catch (error) {
|
|
120
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
121
|
-
if (jsonOutput) {
|
|
122
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
123
|
-
} else {
|
|
124
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
125
|
-
}
|
|
126
|
-
process.exit(1);
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
return batchDeleteCommand;
|
|
131
|
-
}
|
|
@@ -1,138 +0,0 @@
|
|
|
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 { Environment } from '../../../types/index.js';
|
|
6
|
-
import { Operation } from '../../../types/operation.js';
|
|
7
|
-
|
|
8
|
-
export function createOperationsCopyCommand(): Command {
|
|
9
|
-
const copyCommand = new Command('copy');
|
|
10
|
-
copyCommand
|
|
11
|
-
.description('Copy an operation')
|
|
12
|
-
.option('--id <id>', 'Source operation ID')
|
|
13
|
-
.option('-n, --name <name>', 'New operation name (optional, defaults to "Copy of {originalName}")')
|
|
14
|
-
.option('--force', 'Skip confirmation and copy directly')
|
|
15
|
-
.option('--dry-run', 'Preview without making API call')
|
|
16
|
-
.option('--json', 'Output as JSON')
|
|
17
|
-
.action(async (options: Record<string, unknown>) => {
|
|
18
|
-
const context = configManager.getCurrentContext();
|
|
19
|
-
const environment = context.environment as Environment;
|
|
20
|
-
const tenant = context.tenant;
|
|
21
|
-
const force = options.force === true;
|
|
22
|
-
const dryRun = options.dryRun === true;
|
|
23
|
-
const jsonOutput = options.json === true;
|
|
24
|
-
const newName = options.name as string | undefined;
|
|
25
|
-
|
|
26
|
-
const operationId = options.id as string | undefined;
|
|
27
|
-
if (!operationId) {
|
|
28
|
-
if (jsonOutput) {
|
|
29
|
-
console.log(JSON.stringify({ success: false, error: { code: 'MISSING_ID', message: '--id is required' } }));
|
|
30
|
-
} else {
|
|
31
|
-
console.error(chalk.red('\n✗ --id is required\n'));
|
|
32
|
-
}
|
|
33
|
-
process.exit(1);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if (!jsonOutput) {
|
|
37
|
-
console.log(chalk.bold(`\n📋 Copy Operation (${environment})\n`));
|
|
38
|
-
console.log(chalk.gray(` Source ID: ${operationId}`));
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
let operation: Operation | undefined;
|
|
42
|
-
try {
|
|
43
|
-
const operationResponse = await apiClient.getOperationDetail(environment, tenant, operationId);
|
|
44
|
-
if (!operationResponse.success || !operationResponse.data || !('operationId' in operationResponse.data)) {
|
|
45
|
-
const errMsg = `Operation not found: ${operationId}`;
|
|
46
|
-
if (jsonOutput) {
|
|
47
|
-
console.log(JSON.stringify({ success: false, error: { code: 'NOT_FOUND', message: errMsg } }));
|
|
48
|
-
} else {
|
|
49
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
50
|
-
}
|
|
51
|
-
process.exit(1);
|
|
52
|
-
}
|
|
53
|
-
operation = operationResponse.data as Operation;
|
|
54
|
-
} catch (error) {
|
|
55
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
56
|
-
if (jsonOutput) {
|
|
57
|
-
console.log(JSON.stringify({ success: false, error: { code: 'FETCH_ERROR', message: `Failed to fetch operation: ${errMsg}` } }));
|
|
58
|
-
} else {
|
|
59
|
-
console.error(chalk.red(`\n✗ Failed to fetch operation: ${errMsg}\n`));
|
|
60
|
-
}
|
|
61
|
-
process.exit(1);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const operationName = newName || `Copy of ${operation.operationName}`;
|
|
65
|
-
|
|
66
|
-
if (!jsonOutput) {
|
|
67
|
-
console.log(chalk.gray(` Source Name: ${operation.operationName}`));
|
|
68
|
-
console.log(chalk.gray(` Source Code: ${operation.operationCode}`));
|
|
69
|
-
console.log(chalk.gray(` Type: ${operation.operationType}`));
|
|
70
|
-
if (operation.workCenterCode) {
|
|
71
|
-
console.log(chalk.gray(` Work Center: ${operation.workCenterCode}`));
|
|
72
|
-
}
|
|
73
|
-
if (operation.leadTime) {
|
|
74
|
-
console.log(chalk.gray(` Lead Time: ${operation.leadTime}h`));
|
|
75
|
-
}
|
|
76
|
-
console.log(chalk.cyan(`\n → New Name: ${operationName}\n`));
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
if (dryRun) {
|
|
80
|
-
if (jsonOutput) {
|
|
81
|
-
console.log(JSON.stringify({ success: true, dryRun: true, sourceOperation: operation, newName: operationName }));
|
|
82
|
-
} else {
|
|
83
|
-
console.log(chalk.cyan('🔍 Dry-Run Mode: No actual copy will be made\n'));
|
|
84
|
-
console.log(chalk.yellow(' To copy, run without --dry-run\n'));
|
|
85
|
-
}
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
if (!force) {
|
|
90
|
-
if (jsonOutput) {
|
|
91
|
-
console.log(JSON.stringify({ success: true, dryRun: true, sourceOperation: operation, newName: operationName }));
|
|
92
|
-
} else {
|
|
93
|
-
console.log(chalk.cyan('🔍 Dry-Run Mode: No actual copy will be made\n'));
|
|
94
|
-
console.log(chalk.yellow(' To copy, add --force flag\n'));
|
|
95
|
-
}
|
|
96
|
-
return;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
try {
|
|
100
|
-
const response = await apiClient.copyOperation(environment, tenant, operationId);
|
|
101
|
-
|
|
102
|
-
if (response.success && response.data && 'operationId' in response.data) {
|
|
103
|
-
const newOperation = response.data as Operation;
|
|
104
|
-
if (jsonOutput) {
|
|
105
|
-
console.log(JSON.stringify({ success: true, operation: newOperation }));
|
|
106
|
-
} else {
|
|
107
|
-
console.log(chalk.green(`\n✓ Operation copied successfully\n`));
|
|
108
|
-
console.log(chalk.gray(` New ID: ${newOperation.operationId}`));
|
|
109
|
-
console.log(chalk.gray(` New Code: ${newOperation.operationCode}`));
|
|
110
|
-
console.log(chalk.gray(` New Name: ${newOperation.operationName}\n`));
|
|
111
|
-
}
|
|
112
|
-
} else {
|
|
113
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
114
|
-
const errorCode = response.error?.code || 'COPY_ERROR';
|
|
115
|
-
if (jsonOutput) {
|
|
116
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
117
|
-
} else {
|
|
118
|
-
console.error(chalk.red(`\n✗ Failed to copy operation: ${errorMsg}`));
|
|
119
|
-
if (response.error?.code) {
|
|
120
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
121
|
-
}
|
|
122
|
-
console.error();
|
|
123
|
-
}
|
|
124
|
-
process.exit(1);
|
|
125
|
-
}
|
|
126
|
-
} catch (error) {
|
|
127
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
128
|
-
if (jsonOutput) {
|
|
129
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
130
|
-
} else {
|
|
131
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
132
|
-
}
|
|
133
|
-
process.exit(1);
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
return copyCommand;
|
|
138
|
-
}
|