@newpeak/barista-cli 0.1.11 ā 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,83 +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 { Material } from '../../../types/material.js';
|
|
7
|
-
|
|
8
|
-
export function createMaterialsGetCommand(): Command {
|
|
9
|
-
const getCommand = new Command('get');
|
|
10
|
-
getCommand.description('Get material details by ID');
|
|
11
|
-
getCommand.arguments('<materialId>');
|
|
12
|
-
getCommand.option('--json', 'Output as JSON');
|
|
13
|
-
|
|
14
|
-
getCommand.action(async (materialId: string, options: Record<string, unknown>) => {
|
|
15
|
-
const context = configManager.getCurrentContext();
|
|
16
|
-
const environment = (options.env as Environment) || context.environment;
|
|
17
|
-
const tenant = (options.tenant as string) || context.tenant;
|
|
18
|
-
|
|
19
|
-
if (!materialId) {
|
|
20
|
-
console.error(chalk.red('\nā Material ID is required\n'));
|
|
21
|
-
process.exit(1);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if (!materialId || materialId.trim() === '') {
|
|
25
|
-
console.error(chalk.red('\nā Invalid material ID.\n'));
|
|
26
|
-
process.exit(1);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
try {
|
|
30
|
-
const response = await apiClient.getMaterial(environment, tenant, materialId);
|
|
31
|
-
|
|
32
|
-
if (!response.success) {
|
|
33
|
-
const errorCode = response.error?.code || 'UNKNOWN_ERROR';
|
|
34
|
-
const errorMessage = response.error?.message || 'Unknown error';
|
|
35
|
-
|
|
36
|
-
// Handle "material not found" case
|
|
37
|
-
if (errorCode === '01001150001' || errorMessage.includes('äøååØ')) {
|
|
38
|
-
console.error(chalk.red(`\nā Material not found: ${materialId}\n`));
|
|
39
|
-
} else {
|
|
40
|
-
console.error(chalk.red(`\nā Error: ${errorMessage} (${errorCode})\n`));
|
|
41
|
-
}
|
|
42
|
-
process.exit(1);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const material = response.data as Material | null;
|
|
46
|
-
|
|
47
|
-
// Workaround: Commander.js doesn't propagate --json to nested subcommands properly
|
|
48
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
49
|
-
(options as any).json = process.argv.includes('--json');
|
|
50
|
-
const outputJson = (options as Record<string, unknown>).json === true;
|
|
51
|
-
|
|
52
|
-
if (!material) {
|
|
53
|
-
console.error(chalk.red('\nā Material not found\n'));
|
|
54
|
-
process.exit(1);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
if (outputJson) {
|
|
58
|
-
console.log(JSON.stringify({
|
|
59
|
-
success: true,
|
|
60
|
-
data: material,
|
|
61
|
-
}, null, 2));
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// Table output
|
|
66
|
-
console.log(chalk.bold('\nš¦ Material Details\n'));
|
|
67
|
-
console.log(` ${chalk.gray('ID:')} ${material.materialId}`);
|
|
68
|
-
console.log(` ${chalk.gray('Code:')} ${material.materialCode}`);
|
|
69
|
-
console.log(` ${chalk.gray('No:')} ${material.materialNo}`);
|
|
70
|
-
console.log(` ${chalk.gray('Name:')} ${material.materialName}`);
|
|
71
|
-
if (material.materialClass) {
|
|
72
|
-
console.log(` ${chalk.gray('Class:')} ${material.materialClass}`);
|
|
73
|
-
}
|
|
74
|
-
console.log(` ${chalk.gray('Status:')} ${material.statusFlag === 1 ? 'Enable' : 'Disable'}`);
|
|
75
|
-
console.log();
|
|
76
|
-
} catch (error) {
|
|
77
|
-
console.error(chalk.red(`\nā Unexpected error: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
78
|
-
process.exit(1);
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
return getCommand;
|
|
83
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createMaterialsCreateCommand } from './create.js';
|
|
3
|
-
import { createMaterialListCommand } from './list.js';
|
|
4
|
-
import { createMaterialsGetCommand } from './get.js';
|
|
5
|
-
import { createMaterialEnableCommand } from './enable.js';
|
|
6
|
-
import { createMaterialDisableCommand } from './disable.js';
|
|
7
|
-
import { createMaterialUpdateCommand } from './update.js';
|
|
8
|
-
import { createMaterialDeleteCommand } from './delete.js';
|
|
9
|
-
|
|
10
|
-
export function createMaterialsCommand(): Command {
|
|
11
|
-
const materialsCommand = new Command('materials');
|
|
12
|
-
materialsCommand.description('Manage materials');
|
|
13
|
-
|
|
14
|
-
materialsCommand.addCommand(createMaterialsCreateCommand());
|
|
15
|
-
materialsCommand.addCommand(createMaterialListCommand());
|
|
16
|
-
materialsCommand.addCommand(createMaterialsGetCommand());
|
|
17
|
-
materialsCommand.addCommand(createMaterialEnableCommand());
|
|
18
|
-
materialsCommand.addCommand(createMaterialDisableCommand());
|
|
19
|
-
materialsCommand.addCommand(createMaterialUpdateCommand());
|
|
20
|
-
materialsCommand.addCommand(createMaterialDeleteCommand());
|
|
21
|
-
|
|
22
|
-
return materialsCommand;
|
|
23
|
-
}
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import chalk from 'chalk';
|
|
3
|
-
import Table from 'cli-table3';
|
|
4
|
-
import { configManager } from '../../../core/config/manager.js';
|
|
5
|
-
import { apiClient } from '../../../core/api/client.js';
|
|
6
|
-
import { MaterialListResponse, MaterialStatusFlag } from '../../../types/material.js';
|
|
7
|
-
import { Environment } from '../../../types/index.js';
|
|
8
|
-
|
|
9
|
-
export function createMaterialListCommand(): Command {
|
|
10
|
-
const listCommand = new Command('list');
|
|
11
|
-
listCommand.description('List materials with pagination');
|
|
12
|
-
|
|
13
|
-
listCommand
|
|
14
|
-
.option('-p, --page <number>', 'Page number', '1')
|
|
15
|
-
.option('-s, --size <number>', 'Page size', '20')
|
|
16
|
-
.option('--status <string>', 'Status filter (enable/disable)')
|
|
17
|
-
.option('-c, --class <string>', 'Material class filter')
|
|
18
|
-
.option('-k, --keyword <string>', 'Keyword search')
|
|
19
|
-
.option('--json', 'Output as JSON')
|
|
20
|
-
.action(async (options) => {
|
|
21
|
-
// Commander.js boolean flag parsing workaround
|
|
22
|
-
const outputJson = options.json === true || process.argv.includes('--json');
|
|
23
|
-
|
|
24
|
-
const context = configManager.getCurrentContext();
|
|
25
|
-
const environment = (options.env as Environment) || context.environment;
|
|
26
|
-
const tenant = options.tenant || context.tenant;
|
|
27
|
-
|
|
28
|
-
const page = parseInt(options.page as string, 10) - 1;
|
|
29
|
-
const size = parseInt(options.size as string, 10);
|
|
30
|
-
|
|
31
|
-
const params: {
|
|
32
|
-
pageNo: number;
|
|
33
|
-
pageSize: number;
|
|
34
|
-
statusFlag?: MaterialStatusFlag;
|
|
35
|
-
materialClass?: string;
|
|
36
|
-
keyword?: string;
|
|
37
|
-
} = { pageNo: page, pageSize: size };
|
|
38
|
-
|
|
39
|
-
if (options.status !== undefined) {
|
|
40
|
-
const statusVal = (options.status as string).toLowerCase();
|
|
41
|
-
if (statusVal === 'enable' || statusVal === '1') {
|
|
42
|
-
params.statusFlag = 1;
|
|
43
|
-
} else if (statusVal === 'disable' || statusVal === '2') {
|
|
44
|
-
params.statusFlag = 2;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
if (options.class !== undefined) {
|
|
49
|
-
params.materialClass = options.class as string;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
if (options.keyword !== undefined) {
|
|
53
|
-
params.keyword = options.keyword as string;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
const response = await apiClient.listMaterials(environment, tenant, params);
|
|
57
|
-
|
|
58
|
-
if (!response.success) {
|
|
59
|
-
console.error(chalk.red(`\nā Failed to list materials: ${response.error?.message || 'Unknown error'}`));
|
|
60
|
-
if (response.error?.code) {
|
|
61
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
62
|
-
}
|
|
63
|
-
console.error();
|
|
64
|
-
process.exit(1);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
const data = response.data as MaterialListResponse | null;
|
|
68
|
-
|
|
69
|
-
if (!data) {
|
|
70
|
-
if (outputJson) {
|
|
71
|
-
console.log(JSON.stringify({ success: true, data: { items: [], pagination: { pageNo: 0, pageSize: 20, totalRows: 0 } } }, null, 2));
|
|
72
|
-
} else {
|
|
73
|
-
console.log(chalk.bold('\nš¦ Material List\n'));
|
|
74
|
-
console.log(chalk.gray(' No materials found\n'));
|
|
75
|
-
}
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
if (outputJson) {
|
|
80
|
-
console.log(
|
|
81
|
-
JSON.stringify(
|
|
82
|
-
{
|
|
83
|
-
success: true,
|
|
84
|
-
data: {
|
|
85
|
-
items: data.rows || [],
|
|
86
|
-
pagination: {
|
|
87
|
-
pageNo: data.pageNo,
|
|
88
|
-
pageSize: data.pageSize,
|
|
89
|
-
totalRows: data.totalRows,
|
|
90
|
-
},
|
|
91
|
-
},
|
|
92
|
-
},
|
|
93
|
-
null,
|
|
94
|
-
2
|
|
95
|
-
)
|
|
96
|
-
);
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
const records = data.rows || [];
|
|
101
|
-
|
|
102
|
-
if (records.length === 0) {
|
|
103
|
-
console.log(chalk.bold('\nš¦ Material List\n'));
|
|
104
|
-
console.log(chalk.gray(' No materials found\n'));
|
|
105
|
-
return;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
console.log(chalk.bold('\nš¦ Material List\n'));
|
|
109
|
-
|
|
110
|
-
const table = new Table({
|
|
111
|
-
head: [chalk.bold('ID'), chalk.bold('Code'), chalk.bold('No'), chalk.bold('Name'), chalk.bold('Class'), chalk.bold('Status')],
|
|
112
|
-
colWidths: [14, 14, 14, 30, 16, 10],
|
|
113
|
-
style: {
|
|
114
|
-
head: [],
|
|
115
|
-
border: [],
|
|
116
|
-
},
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
for (const material of records) {
|
|
120
|
-
const statusText = material.statusFlag === 1 ? chalk.green('Enable') : chalk.red('Disable');
|
|
121
|
-
table.push([
|
|
122
|
-
material.materialId,
|
|
123
|
-
material.materialCode || '-',
|
|
124
|
-
material.materialNo || '-',
|
|
125
|
-
material.materialName || '-',
|
|
126
|
-
material.materialClass || '-',
|
|
127
|
-
statusText,
|
|
128
|
-
]);
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
console.log(table.toString());
|
|
132
|
-
console.log();
|
|
133
|
-
console.log(
|
|
134
|
-
chalk.gray(
|
|
135
|
-
` Total: ${data.totalRows} | Page: ${data.pageNo + 1} / ${Math.ceil(data.totalRows / data.pageSize) || 1} | Size: ${data.pageSize}`
|
|
136
|
-
)
|
|
137
|
-
);
|
|
138
|
-
console.log();
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
return listCommand;
|
|
142
|
-
}
|
|
@@ -1,125 +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 { Material, MaterialRequest } from '../../../types/material.js';
|
|
7
|
-
|
|
8
|
-
export function createMaterialUpdateCommand(): Command {
|
|
9
|
-
const updateCommand = new Command('update');
|
|
10
|
-
updateCommand
|
|
11
|
-
.description('Update material information')
|
|
12
|
-
.argument('<materialId>', 'Material ID')
|
|
13
|
-
.option('-n, --name <name>', 'Material name')
|
|
14
|
-
.option('-c, --class <class>', 'Material class')
|
|
15
|
-
.option('--type <type>', 'Material type')
|
|
16
|
-
.option('--unit <unit>', 'Material unit')
|
|
17
|
-
.option('--dry-run', 'Preview changes without making API call')
|
|
18
|
-
.option('--json', 'Output result as JSON')
|
|
19
|
-
.action(async (materialId: string, options: Record<string, unknown>) => {
|
|
20
|
-
const context = configManager.getCurrentContext();
|
|
21
|
-
const environment = context.environment as Environment;
|
|
22
|
-
const tenant = context.tenant;
|
|
23
|
-
|
|
24
|
-
const fields: Partial<MaterialRequest> = {};
|
|
25
|
-
if (options.name) fields.materialName = options.name as string;
|
|
26
|
-
if (options.class) fields.materialClass = options.class as string;
|
|
27
|
-
if (options.type) fields.materialType = options.type as string;
|
|
28
|
-
if (options.unit) fields.materialUomCode = options.unit as string;
|
|
29
|
-
|
|
30
|
-
const providedFields = Object.keys(fields).filter(
|
|
31
|
-
(k) => fields[k as keyof MaterialRequest] !== undefined
|
|
32
|
-
);
|
|
33
|
-
if (providedFields.length === 0) {
|
|
34
|
-
console.error(
|
|
35
|
-
chalk.red('\nā No fields to update. Provide at least one of: --name, --class, --type, --unit\n')
|
|
36
|
-
);
|
|
37
|
-
process.exit(1);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
if (options.dryRun) {
|
|
41
|
-
console.log(chalk.bold(`\nš¦ Update Material ā Dry Run (${environment})\n`));
|
|
42
|
-
console.log(chalk.gray(` Material ID: ${materialId}`));
|
|
43
|
-
console.log(chalk.gray('\n Changes to be applied:'));
|
|
44
|
-
for (const field of providedFields) {
|
|
45
|
-
const label = field.replace(/([A-Z])/g, (m) => ` ${m.toLowerCase()}`).trim();
|
|
46
|
-
console.log(chalk.cyan(` ${label}: "${fields[field as keyof MaterialRequest]}"`));
|
|
47
|
-
}
|
|
48
|
-
console.log();
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
let currentMaterial: Material | undefined;
|
|
53
|
-
try {
|
|
54
|
-
const materialResponse = await apiClient.getMaterial(environment, tenant, materialId);
|
|
55
|
-
if (!materialResponse.success || !materialResponse.data) {
|
|
56
|
-
console.error(chalk.red(`\nā Material not found: ${materialId}`));
|
|
57
|
-
if (materialResponse.error?.message) {
|
|
58
|
-
console.error(chalk.gray(` ${materialResponse.error.message}`));
|
|
59
|
-
}
|
|
60
|
-
if (materialResponse.error?.code) {
|
|
61
|
-
console.error(chalk.gray(` Error code: ${materialResponse.error.code}`));
|
|
62
|
-
}
|
|
63
|
-
console.error();
|
|
64
|
-
process.exit(1);
|
|
65
|
-
}
|
|
66
|
-
currentMaterial = materialResponse.data as Material;
|
|
67
|
-
} catch (error) {
|
|
68
|
-
console.error(chalk.red(`\nā Failed to fetch material: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
69
|
-
process.exit(1);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
73
|
-
(options as any).json = process.argv.includes('--json');
|
|
74
|
-
const outputJson = (options as Record<string, unknown>).json === true;
|
|
75
|
-
|
|
76
|
-
console.log(chalk.bold(`\nš¦ Update Material (${environment})\n`));
|
|
77
|
-
console.log(chalk.gray(` Material ID: ${materialId}`));
|
|
78
|
-
console.log(chalk.gray(` Current Name: ${currentMaterial.materialName}`));
|
|
79
|
-
console.log(chalk.gray('\n Changes:'));
|
|
80
|
-
for (const field of providedFields) {
|
|
81
|
-
const label = field.replace(/([A-Z])/g, (m) => ` ${m.toLowerCase()}`).trim();
|
|
82
|
-
const currentVal = (currentMaterial as unknown as Record<string, unknown>)[field] ?? '(not set)';
|
|
83
|
-
const newVal = fields[field as keyof MaterialRequest];
|
|
84
|
-
console.log(chalk.cyan(` ${label}: "${currentVal}" ā "${newVal}"`));
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
const updateData = { materialId, ...fields } as MaterialRequest;
|
|
88
|
-
try {
|
|
89
|
-
const response = await apiClient.updateMaterial(environment, tenant, materialId, updateData);
|
|
90
|
-
|
|
91
|
-
if (response.success) {
|
|
92
|
-
if (outputJson) {
|
|
93
|
-
console.log(JSON.stringify({ success: true, data: response.data }, null, 2));
|
|
94
|
-
} else {
|
|
95
|
-
console.log(chalk.green(`\nā Material updated successfully\n`));
|
|
96
|
-
}
|
|
97
|
-
} else {
|
|
98
|
-
if (outputJson) {
|
|
99
|
-
console.log(JSON.stringify({ success: false, error: response.error }, null, 2));
|
|
100
|
-
} else {
|
|
101
|
-
console.error(chalk.red(`\nā Update failed: ${response.error?.message || 'Unknown error'}`));
|
|
102
|
-
if (response.error?.code) {
|
|
103
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
104
|
-
}
|
|
105
|
-
console.error();
|
|
106
|
-
}
|
|
107
|
-
process.exit(1);
|
|
108
|
-
}
|
|
109
|
-
} catch (error) {
|
|
110
|
-
if (outputJson) {
|
|
111
|
-
console.log(
|
|
112
|
-
JSON.stringify({
|
|
113
|
-
success: false,
|
|
114
|
-
error: { message: error instanceof Error ? error.message : 'Unknown error' },
|
|
115
|
-
})
|
|
116
|
-
);
|
|
117
|
-
} else {
|
|
118
|
-
console.error(chalk.red(`\nā Error: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
119
|
-
}
|
|
120
|
-
process.exit(1);
|
|
121
|
-
}
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
return updateCommand;
|
|
125
|
-
}
|
|
@@ -1,111 +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 { MouldEntityApiResponse, MouldEntity } from '../../../types/mould.js';
|
|
6
|
-
|
|
7
|
-
function formatMouldStatus(status?: string): string {
|
|
8
|
-
if (!status) return chalk.gray('-');
|
|
9
|
-
switch (status) {
|
|
10
|
-
case 'FINE':
|
|
11
|
-
return chalk.green('FINE');
|
|
12
|
-
case 'REPAIR':
|
|
13
|
-
return chalk.yellow('REPAIR');
|
|
14
|
-
case 'SCRAP':
|
|
15
|
-
return chalk.red('SCRAP');
|
|
16
|
-
default:
|
|
17
|
-
return status;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
function outputMouldDetails(mould: MouldEntity): void {
|
|
22
|
-
console.log(chalk.bold('\nš§ Mould Details\n'));
|
|
23
|
-
|
|
24
|
-
console.log(chalk.gray(' ID: ') + mould.mouldEntityId);
|
|
25
|
-
console.log(chalk.gray(' Code: ') + (mould.mouldEntityCode || chalk.gray('-')));
|
|
26
|
-
console.log(chalk.gray(' Material Code: ') + (mould.materialCode || chalk.gray('-')));
|
|
27
|
-
console.log(chalk.gray(' Material Name: ') + (mould.materialName || chalk.gray('-')));
|
|
28
|
-
console.log(chalk.gray(' Material No: ') + (mould.materialNo || chalk.gray('-')));
|
|
29
|
-
console.log(chalk.gray(' Type: ') + (mould.mouldType || chalk.gray('-')));
|
|
30
|
-
console.log(chalk.gray(' Status: ') + formatMouldStatus(mould.mouldStatus));
|
|
31
|
-
console.log(chalk.gray(' Warehouse Code: ') + (mould.currentWarehouseCode || chalk.gray('-')));
|
|
32
|
-
console.log(chalk.gray(' Seq No: ') + (mould.seqNo || chalk.gray('-')));
|
|
33
|
-
console.log(chalk.gray(' Lot No: ') + (mould.lotNo || chalk.gray('-')));
|
|
34
|
-
console.log(chalk.gray(' Face Number: ') + (mould.mouldFaceNumber !== undefined ? String(mould.mouldFaceNumber) : chalk.gray('-')));
|
|
35
|
-
console.log(chalk.gray(' Unit Price: ') + (mould.unitPrice !== undefined ? `${mould.unitPrice} ${mould.currency || ''}` : chalk.gray('-')));
|
|
36
|
-
console.log(chalk.gray(' Produced Date: ') + (mould.producedDate || chalk.gray('-')));
|
|
37
|
-
console.log(chalk.gray(' Last Stock Out: ') + (mould.lastStockOutTime || chalk.gray('-')));
|
|
38
|
-
console.log(chalk.gray(' Remark: ') + (mould.remark || chalk.gray('-')));
|
|
39
|
-
console.log();
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
export function createMouldGetCommand(): Command {
|
|
43
|
-
const getCommand = new Command('get');
|
|
44
|
-
getCommand.description('Get mould entity details by ID');
|
|
45
|
-
|
|
46
|
-
getCommand
|
|
47
|
-
.argument('<mouldEntityId>', 'Mould entity ID (BigInteger string)')
|
|
48
|
-
.option('--json', 'Output as JSON')
|
|
49
|
-
.action(async (mouldEntityId: string, options: { json?: boolean }) => {
|
|
50
|
-
if (!mouldEntityId) {
|
|
51
|
-
console.error(chalk.red('\nā Mould ID is required\n'));
|
|
52
|
-
process.exit(1);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
const context = configManager.getCurrentContext();
|
|
56
|
-
const environment = context.environment;
|
|
57
|
-
const tenant = context.tenant;
|
|
58
|
-
|
|
59
|
-
const response: MouldEntityApiResponse = await apiClient.getMouldEntity(
|
|
60
|
-
environment,
|
|
61
|
-
tenant,
|
|
62
|
-
mouldEntityId
|
|
63
|
-
);
|
|
64
|
-
|
|
65
|
-
if (!response.success) {
|
|
66
|
-
const errorMessage = response.error?.message || 'Unknown error';
|
|
67
|
-
const errorCode = response.error?.code;
|
|
68
|
-
|
|
69
|
-
if (errorMessage.includes('äøååØ') || errorMessage.includes('not exist')) {
|
|
70
|
-
console.error(chalk.red(`\nā Mould not found: ${mouldEntityId}\n`));
|
|
71
|
-
} else {
|
|
72
|
-
console.error(chalk.red(`\nā Failed to get mould: ${errorMessage}`));
|
|
73
|
-
if (errorCode) {
|
|
74
|
-
console.error(chalk.gray(` Error code: ${errorCode}`));
|
|
75
|
-
}
|
|
76
|
-
console.error();
|
|
77
|
-
}
|
|
78
|
-
process.exit(1);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
const data = response.data as MouldEntity | null;
|
|
82
|
-
|
|
83
|
-
if (!data) {
|
|
84
|
-
if (options.json) {
|
|
85
|
-
console.log(JSON.stringify({ success: true, data: null }, null, 2));
|
|
86
|
-
} else {
|
|
87
|
-
console.log(chalk.bold('\nš§ Mould Details\n'));
|
|
88
|
-
console.log(chalk.gray(' Not found\n'));
|
|
89
|
-
}
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (options.json) {
|
|
94
|
-
console.log(
|
|
95
|
-
JSON.stringify(
|
|
96
|
-
{
|
|
97
|
-
success: true,
|
|
98
|
-
data,
|
|
99
|
-
},
|
|
100
|
-
null,
|
|
101
|
-
2
|
|
102
|
-
)
|
|
103
|
-
);
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
outputMouldDetails(data);
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
return getCommand;
|
|
111
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createMouldListCommand } from './list.js';
|
|
3
|
-
import { createMouldGetCommand } from './get.js';
|
|
4
|
-
import { createMouldSetStatusCommand } from './set-status.js';
|
|
5
|
-
import { createMouldStockInCommand } from './stock-in.js';
|
|
6
|
-
|
|
7
|
-
export function createMouldCommand(): Command {
|
|
8
|
-
const mouldCommand = new Command('mould');
|
|
9
|
-
mouldCommand.description('Manage mould entities');
|
|
10
|
-
|
|
11
|
-
mouldCommand.addCommand(createMouldListCommand());
|
|
12
|
-
mouldCommand.addCommand(createMouldGetCommand());
|
|
13
|
-
mouldCommand.addCommand(createMouldSetStatusCommand());
|
|
14
|
-
mouldCommand.addCommand(createMouldStockInCommand());
|
|
15
|
-
|
|
16
|
-
return mouldCommand;
|
|
17
|
-
}
|
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import chalk from 'chalk';
|
|
3
|
-
import Table from 'cli-table3';
|
|
4
|
-
import { configManager } from '../../../core/config/manager.js';
|
|
5
|
-
import { apiClient } from '../../../core/api/client.js';
|
|
6
|
-
import { MouldEntityListResponse, MouldStatus } from '../../../types/mould.js';
|
|
7
|
-
|
|
8
|
-
const VALID_STATUSES = ['FINE', 'REPAIR', 'SCRAP'] as const;
|
|
9
|
-
|
|
10
|
-
export function createMouldListCommand(): Command {
|
|
11
|
-
const listCommand = new Command('list');
|
|
12
|
-
listCommand.description('List mould entities with pagination');
|
|
13
|
-
|
|
14
|
-
listCommand
|
|
15
|
-
.option('-p, --page <number>', 'Page number', '1')
|
|
16
|
-
.option('-s, --size <number>', 'Page size', '20')
|
|
17
|
-
.option('--status <status>', `Mould status filter (${VALID_STATUSES.join('|')})`)
|
|
18
|
-
.option('--material-code <code>', 'Material code filter')
|
|
19
|
-
.option('--material-name <name>', 'Material name filter (fuzzy)')
|
|
20
|
-
.option('--json', 'Output as JSON')
|
|
21
|
-
.action(async (options) => {
|
|
22
|
-
const context = configManager.getCurrentContext();
|
|
23
|
-
const tenant = context.tenant;
|
|
24
|
-
const environment = context.environment;
|
|
25
|
-
|
|
26
|
-
const page = parseInt(options.page as string, 10);
|
|
27
|
-
const size = parseInt(options.size as string, 10);
|
|
28
|
-
|
|
29
|
-
const params: {
|
|
30
|
-
pageNo: number;
|
|
31
|
-
pageSize: number;
|
|
32
|
-
mouldStatus?: MouldStatus;
|
|
33
|
-
materialCode?: string;
|
|
34
|
-
materialName?: string;
|
|
35
|
-
} = { pageNo: page, pageSize: size };
|
|
36
|
-
|
|
37
|
-
if (options.status !== undefined) {
|
|
38
|
-
const status = options.status as MouldStatus;
|
|
39
|
-
if (VALID_STATUSES.includes(status)) {
|
|
40
|
-
params.mouldStatus = status;
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
if (options.materialCode !== undefined) {
|
|
45
|
-
params.materialCode = options.materialCode as string;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
if (options.materialName !== undefined) {
|
|
49
|
-
params.materialName = options.materialName as string;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const response = await apiClient.listMouldEntities(environment, tenant, params);
|
|
53
|
-
|
|
54
|
-
if (!response.success) {
|
|
55
|
-
console.error(chalk.red(`\nā Failed to list moulds: ${response.error?.message || 'Unknown error'}`));
|
|
56
|
-
if (response.error?.code) {
|
|
57
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
58
|
-
}
|
|
59
|
-
console.error();
|
|
60
|
-
process.exit(1);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
const data = response.data as MouldEntityListResponse | null;
|
|
64
|
-
|
|
65
|
-
if (!data) {
|
|
66
|
-
if (options.json) {
|
|
67
|
-
console.log(
|
|
68
|
-
JSON.stringify(
|
|
69
|
-
{ success: true, data: { rows: [], pagination: { pageNo: 0, pageSize: 20, totalRows: 0 } } },
|
|
70
|
-
null,
|
|
71
|
-
2
|
|
72
|
-
)
|
|
73
|
-
);
|
|
74
|
-
} else {
|
|
75
|
-
console.log(chalk.bold('\nš Mould List\n'));
|
|
76
|
-
console.log(chalk.gray(' No moulds found\n'));
|
|
77
|
-
}
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
if (options.json) {
|
|
82
|
-
console.log(
|
|
83
|
-
JSON.stringify(
|
|
84
|
-
{
|
|
85
|
-
success: true,
|
|
86
|
-
data: {
|
|
87
|
-
rows: data.rows || [],
|
|
88
|
-
pagination: {
|
|
89
|
-
pageNo: data.pageNo,
|
|
90
|
-
pageSize: data.pageSize,
|
|
91
|
-
totalRows: data.totalRows,
|
|
92
|
-
},
|
|
93
|
-
},
|
|
94
|
-
},
|
|
95
|
-
null,
|
|
96
|
-
2
|
|
97
|
-
)
|
|
98
|
-
);
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
const records = data.rows || [];
|
|
103
|
-
|
|
104
|
-
if (records.length === 0) {
|
|
105
|
-
console.log(chalk.bold('\nš Mould List\n'));
|
|
106
|
-
console.log(chalk.gray(' No moulds found\n'));
|
|
107
|
-
return;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
console.log(chalk.bold('\nš Mould List\n'));
|
|
111
|
-
|
|
112
|
-
const table = new Table({
|
|
113
|
-
head: [
|
|
114
|
-
chalk.bold('Code'),
|
|
115
|
-
chalk.bold('Material'),
|
|
116
|
-
chalk.bold('Type'),
|
|
117
|
-
chalk.bold('Status'),
|
|
118
|
-
chalk.bold('Warehouse'),
|
|
119
|
-
chalk.bold('Produced'),
|
|
120
|
-
],
|
|
121
|
-
colWidths: [16, 20, 14, 10, 14, 12],
|
|
122
|
-
style: {
|
|
123
|
-
head: [],
|
|
124
|
-
border: [],
|
|
125
|
-
},
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
for (const mould of records) {
|
|
129
|
-
const statusText =
|
|
130
|
-
mould.mouldStatus === 'FINE'
|
|
131
|
-
? chalk.green('FINE')
|
|
132
|
-
: mould.mouldStatus === 'REPAIR'
|
|
133
|
-
? chalk.yellow('REPAIR')
|
|
134
|
-
: chalk.red('SCRAP');
|
|
135
|
-
|
|
136
|
-
table.push([
|
|
137
|
-
mould.mouldEntityCode || '-',
|
|
138
|
-
mould.materialName || '-',
|
|
139
|
-
mould.mouldType || '-',
|
|
140
|
-
statusText,
|
|
141
|
-
mould.currentWarehouseCode || '-',
|
|
142
|
-
mould.producedDate || '-',
|
|
143
|
-
]);
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
console.log(table.toString());
|
|
147
|
-
console.log();
|
|
148
|
-
console.log(
|
|
149
|
-
chalk.gray(
|
|
150
|
-
` Total: ${data.totalRows} | Page: ${data.pageNo + 1} / ${Math.ceil(data.totalRows / data.pageSize) || 1} | Size: ${data.pageSize}`
|
|
151
|
-
)
|
|
152
|
-
);
|
|
153
|
-
console.log();
|
|
154
|
-
});
|
|
155
|
-
|
|
156
|
-
return listCommand;
|
|
157
|
-
}
|