@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,130 +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 { SupplierContactListResponse } from '../../../types/supplier-contact.js';
|
|
7
|
-
import { Environment } from '../../../types/index.js';
|
|
8
|
-
|
|
9
|
-
export function createSupplierContactListCommand(): Command {
|
|
10
|
-
const listCommand = new Command('list');
|
|
11
|
-
listCommand.description('List supplier contacts with pagination');
|
|
12
|
-
|
|
13
|
-
listCommand
|
|
14
|
-
.requiredOption('-s, --supplier-id <string>', 'Supplier ID')
|
|
15
|
-
.option('-p, --page <number>', 'Page number', '1')
|
|
16
|
-
.option('-z, --size <number>', 'Page size', '20')
|
|
17
|
-
.option('-S, --search <string>', 'Search keyword (contact name)')
|
|
18
|
-
.option('--json', 'Output as JSON')
|
|
19
|
-
.action(async (options) => {
|
|
20
|
-
const context = configManager.getCurrentContext();
|
|
21
|
-
const environment = (options.env as Environment) || context.environment;
|
|
22
|
-
const tenant = options.tenant || context.tenant;
|
|
23
|
-
|
|
24
|
-
const page = parseInt(options.page as string, 10) - 1;
|
|
25
|
-
const size = parseInt(options.size as string, 10);
|
|
26
|
-
|
|
27
|
-
const params: {
|
|
28
|
-
supplierId: string;
|
|
29
|
-
pageNo?: number;
|
|
30
|
-
pageSize?: number;
|
|
31
|
-
supplierContactName?: string;
|
|
32
|
-
} = { supplierId: options.supplierId };
|
|
33
|
-
|
|
34
|
-
if (page > 0) {
|
|
35
|
-
params.pageNo = page;
|
|
36
|
-
}
|
|
37
|
-
if (size > 0) {
|
|
38
|
-
params.pageSize = size;
|
|
39
|
-
}
|
|
40
|
-
if (options.search) {
|
|
41
|
-
params.supplierContactName = options.search as string;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
const response = await apiClient.listSupplierContacts(environment, tenant, params);
|
|
45
|
-
|
|
46
|
-
if (!response.success) {
|
|
47
|
-
console.error(chalk.red(`\n✗ Failed to list supplier contacts: ${response.error?.message || 'Unknown error'}`));
|
|
48
|
-
if (response.error?.code) {
|
|
49
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
50
|
-
}
|
|
51
|
-
console.error();
|
|
52
|
-
process.exit(1);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
const data = response.data as SupplierContactListResponse | null;
|
|
56
|
-
|
|
57
|
-
if (!data) {
|
|
58
|
-
if (options.json) {
|
|
59
|
-
console.log(JSON.stringify({ success: true, data: { items: [], pagination: { pageNo: 0, pageSize: 20, totalRows: 0 } } }, null, 2));
|
|
60
|
-
} else {
|
|
61
|
-
console.log(chalk.bold('\n📋 Supplier Contact List\n'));
|
|
62
|
-
console.log(chalk.gray(' No supplier contacts found\n'));
|
|
63
|
-
}
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
if (options.json) {
|
|
68
|
-
console.log(
|
|
69
|
-
JSON.stringify(
|
|
70
|
-
{
|
|
71
|
-
success: true,
|
|
72
|
-
data: {
|
|
73
|
-
items: data.rows || [],
|
|
74
|
-
pagination: {
|
|
75
|
-
pageNo: data.pageNo,
|
|
76
|
-
pageSize: data.pageSize,
|
|
77
|
-
totalRows: data.totalRows,
|
|
78
|
-
},
|
|
79
|
-
},
|
|
80
|
-
},
|
|
81
|
-
null,
|
|
82
|
-
2
|
|
83
|
-
)
|
|
84
|
-
);
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
const records = data.rows || [];
|
|
89
|
-
|
|
90
|
-
if (records.length === 0) {
|
|
91
|
-
console.log(chalk.bold('\n📋 Supplier Contact List\n'));
|
|
92
|
-
console.log(chalk.gray(' No supplier contacts found\n'));
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
console.log(chalk.bold('\n📋 Supplier Contact List\n'));
|
|
97
|
-
|
|
98
|
-
const table = new Table({
|
|
99
|
-
head: [chalk.bold('ID'), chalk.bold('NAME'), chalk.bold('PHONE'), chalk.bold('TELEPHONE'), chalk.bold('EMAIL'), chalk.bold('DEFAULT')],
|
|
100
|
-
colWidths: [10, 15, 15, 15, 25, 10],
|
|
101
|
-
style: {
|
|
102
|
-
head: [],
|
|
103
|
-
border: [],
|
|
104
|
-
},
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
for (const contact of records) {
|
|
108
|
-
const defaultText = contact.defaultFlag === 'Y' ? chalk.green('Y') : chalk.gray('N');
|
|
109
|
-
table.push([
|
|
110
|
-
contact.supplierContactId,
|
|
111
|
-
contact.supplierContactName || '-',
|
|
112
|
-
contact.supplierContactPhone || '-',
|
|
113
|
-
contact.supplierContactTelephone || '-',
|
|
114
|
-
contact.supplierContactEmail || '-',
|
|
115
|
-
defaultText,
|
|
116
|
-
]);
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
console.log(table.toString());
|
|
120
|
-
console.log();
|
|
121
|
-
console.log(
|
|
122
|
-
chalk.gray(
|
|
123
|
-
` Total: ${data.totalRows} | Page: ${data.pageNo + 1} / ${Math.ceil(data.totalRows / data.pageSize) || 1} | Size: ${data.pageSize}`
|
|
124
|
-
)
|
|
125
|
-
);
|
|
126
|
-
console.log();
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
return listCommand;
|
|
130
|
-
}
|
|
@@ -1,127 +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 { UpdateSupplierContactRequest } from '../../../types/supplier-contact.js';
|
|
6
|
-
|
|
7
|
-
export function createSupplierContactUpdateCommand(): Command {
|
|
8
|
-
const cmd = new Command('update');
|
|
9
|
-
cmd.description('Update an existing supplier contact');
|
|
10
|
-
|
|
11
|
-
cmd
|
|
12
|
-
.arguments('<contact-id>')
|
|
13
|
-
.option('-n, --name <string>', 'Contact name')
|
|
14
|
-
.option('-p, --phone <string>', 'Phone number')
|
|
15
|
-
.option('-t, --telephone <string>', 'Telephone number')
|
|
16
|
-
.option('-e, --email <string>', 'Email address')
|
|
17
|
-
.option('-x, --sex <string>', 'Sex')
|
|
18
|
-
.option('-b, --birthday <string>', 'Birthday (YYYY-MM-DD)')
|
|
19
|
-
.option('-q, --qq <string>', 'QQ number')
|
|
20
|
-
.option('-w, --wechat <string>', 'WeChat ID')
|
|
21
|
-
.option('-a, --address <string>', 'Address')
|
|
22
|
-
.option('-d, --default', 'Set as default contact')
|
|
23
|
-
.option('-r, --remark <string>', 'Remark')
|
|
24
|
-
.option('--dry-run', 'Preview the operation without executing')
|
|
25
|
-
.option('--json', 'Output as JSON')
|
|
26
|
-
.action(async (contactId: string, options: Record<string, unknown>) => {
|
|
27
|
-
const context = configManager.getCurrentContext();
|
|
28
|
-
const environment = context.environment;
|
|
29
|
-
const tenant = context.tenant;
|
|
30
|
-
const jsonOutput = options.json === true;
|
|
31
|
-
|
|
32
|
-
if (!contactId || contactId.trim() === '') {
|
|
33
|
-
if (jsonOutput) {
|
|
34
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'contact-id is required' } }));
|
|
35
|
-
} else {
|
|
36
|
-
console.error(chalk.red('\n✗ Contact ID is required\n'));
|
|
37
|
-
}
|
|
38
|
-
process.exit(1);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
const data: UpdateSupplierContactRequest = {
|
|
42
|
-
supplierContactId: contactId,
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
if (options.name) data.supplierContactName = options.name as string;
|
|
46
|
-
if (options.phone) data.supplierContactPhone = options.phone as string;
|
|
47
|
-
if (options.telephone) data.supplierContactTelephone = options.telephone as string;
|
|
48
|
-
if (options.email) data.supplierContactEmail = options.email as string;
|
|
49
|
-
if (options.sex) data.supplierContactSex = options.sex as string;
|
|
50
|
-
if (options.birthday) data.supplierContactBirthday = options.birthday as string;
|
|
51
|
-
if (options.qq) data.supplierContactQq = options.qq as string;
|
|
52
|
-
if (options.wechat) data.supplierContactWechat = options.wechat as string;
|
|
53
|
-
if (options.address) data.supplierContactAddress = options.address as string;
|
|
54
|
-
if (options.default === true) data.defaultFlag = 'Y';
|
|
55
|
-
else if (options.default === false) data.defaultFlag = 'N';
|
|
56
|
-
if (options.remark) data.remark = options.remark as string;
|
|
57
|
-
|
|
58
|
-
Object.keys(data).forEach(key => {
|
|
59
|
-
if (data[key as keyof UpdateSupplierContactRequest] === undefined) {
|
|
60
|
-
delete data[key as keyof UpdateSupplierContactRequest];
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
if (Object.keys(data).length <= 1) {
|
|
65
|
-
if (jsonOutput) {
|
|
66
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'At least one field must be provided to update' } }));
|
|
67
|
-
} else {
|
|
68
|
-
console.error(chalk.red('\n✗ At least one field must be provided to update\n'));
|
|
69
|
-
}
|
|
70
|
-
process.exit(1);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
if (options.dryRun) {
|
|
74
|
-
if (jsonOutput) {
|
|
75
|
-
console.log(JSON.stringify({ success: true, dryRun: true, data }));
|
|
76
|
-
} else {
|
|
77
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual API call will be made\n'));
|
|
78
|
-
console.log(chalk.gray(' This operation will update the following supplier contact:'));
|
|
79
|
-
console.log(` ${chalk.gray('Contact ID:')} ${contactId}`);
|
|
80
|
-
Object.keys(data).forEach(key => {
|
|
81
|
-
if (key !== 'supplierContactId' && data[key as keyof UpdateSupplierContactRequest] !== undefined) {
|
|
82
|
-
console.log(` ${chalk.gray(key + ':')} ${data[key as keyof UpdateSupplierContactRequest]}`);
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
console.log();
|
|
86
|
-
}
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
try {
|
|
91
|
-
const response = await apiClient.updateSupplierContact(environment, tenant, data);
|
|
92
|
-
|
|
93
|
-
if (response.success) {
|
|
94
|
-
if (jsonOutput) {
|
|
95
|
-
console.log(JSON.stringify({ success: true, data: response.data }));
|
|
96
|
-
} else {
|
|
97
|
-
console.log(chalk.green('\n✓ Supplier contact updated successfully\n'));
|
|
98
|
-
console.log(` ${chalk.gray('Contact ID:')} ${chalk.green(contactId)}`);
|
|
99
|
-
console.log();
|
|
100
|
-
}
|
|
101
|
-
} else {
|
|
102
|
-
const errorMsg = response.error?.message || 'Failed to update supplier contact';
|
|
103
|
-
const errorCode = response.error?.code || 'UPDATE_ERROR';
|
|
104
|
-
if (jsonOutput) {
|
|
105
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
106
|
-
} else {
|
|
107
|
-
console.error(chalk.red(`\n✗ Failed to update supplier contact: ${errorMsg}`));
|
|
108
|
-
if (response.error?.code) {
|
|
109
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
110
|
-
}
|
|
111
|
-
console.error();
|
|
112
|
-
}
|
|
113
|
-
process.exit(1);
|
|
114
|
-
}
|
|
115
|
-
} catch (error) {
|
|
116
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
117
|
-
if (jsonOutput) {
|
|
118
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
119
|
-
} else {
|
|
120
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
121
|
-
}
|
|
122
|
-
process.exit(1);
|
|
123
|
-
}
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
return cmd;
|
|
127
|
-
}
|
|
@@ -1,149 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import chalk from 'chalk';
|
|
3
|
-
import inquirer from 'inquirer';
|
|
4
|
-
import { apiClient } from '../../../core/api/client.js';
|
|
5
|
-
import { configManager } from '../../../core/config/manager.js';
|
|
6
|
-
import { CreateSupplierRequest } from '../../../types/supplier.js';
|
|
7
|
-
|
|
8
|
-
function formatTable(data: CreateSupplierRequest): string {
|
|
9
|
-
const lines: string[] = [];
|
|
10
|
-
lines.push(` ${chalk.gray('Name:')} ${data.supplierName || '(not set)'}`);
|
|
11
|
-
lines.push(` ${chalk.gray('Code:')} ${data.supplierCode}`);
|
|
12
|
-
if (data.supplierType) lines.push(` ${chalk.gray('Type:')} ${data.supplierType}`);
|
|
13
|
-
if (data.contactPerson) lines.push(` ${chalk.gray('Contact:')} ${data.contactPerson}`);
|
|
14
|
-
if (data.contactPhone) lines.push(` ${chalk.gray('Phone:')} ${data.contactPhone}`);
|
|
15
|
-
if (data.address) lines.push(` ${chalk.gray('Address:')} ${data.address}`);
|
|
16
|
-
return lines.join('\n');
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export function createSupplierCreateCommand(): Command {
|
|
20
|
-
const cmd = new Command('create');
|
|
21
|
-
cmd.description('Create a new supplier (auto-generates supplier code)');
|
|
22
|
-
|
|
23
|
-
cmd
|
|
24
|
-
.option('-n, --name <name>', 'Supplier name (required)')
|
|
25
|
-
.option('-c, --code <code>', 'Supplier code (auto-generated if not provided)')
|
|
26
|
-
.option('-t, --type <type>', 'Supplier type')
|
|
27
|
-
.option('--contact <contact>', 'Contact person')
|
|
28
|
-
.option('-p, --phone <phone>', 'Contact phone')
|
|
29
|
-
.option('-a, --address <address>', 'Address')
|
|
30
|
-
.option('--dry-run', 'Preview without making API call')
|
|
31
|
-
.option('--json', 'Output as JSON');
|
|
32
|
-
|
|
33
|
-
cmd.action(async () => {
|
|
34
|
-
const context = configManager.getCurrentContext();
|
|
35
|
-
const opts = cmd.opts();
|
|
36
|
-
|
|
37
|
-
let name = opts.name as string | undefined;
|
|
38
|
-
let code = opts.code as string | undefined;
|
|
39
|
-
const type = opts.type as string | undefined;
|
|
40
|
-
const contact = opts.contact as string | undefined;
|
|
41
|
-
const phone = opts.phone as string | undefined;
|
|
42
|
-
const address = opts.address as string | undefined;
|
|
43
|
-
const dryRun = opts.dryRun === true;
|
|
44
|
-
const jsonOutput = opts.json === true;
|
|
45
|
-
|
|
46
|
-
if (!name) {
|
|
47
|
-
const { inputName } = await inquirer.prompt([
|
|
48
|
-
{
|
|
49
|
-
type: 'input',
|
|
50
|
-
name: 'inputName',
|
|
51
|
-
message: 'Enter supplier name:',
|
|
52
|
-
validate: (input: string) => input.trim().length > 0 || 'Supplier name is required',
|
|
53
|
-
},
|
|
54
|
-
]);
|
|
55
|
-
name = inputName;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
if (!code) {
|
|
59
|
-
const codeResponse = await apiClient.getCodeByType(context.environment, context.tenant, 'TenantSupplierCode');
|
|
60
|
-
if (codeResponse.success && codeResponse.data) {
|
|
61
|
-
code = codeResponse.data;
|
|
62
|
-
} else {
|
|
63
|
-
const errMsg = codeResponse.error?.message || 'Failed to generate supplier code';
|
|
64
|
-
if (jsonOutput) {
|
|
65
|
-
console.log(JSON.stringify({ success: false, error: { code: 'CODE_GENERATION_ERROR', message: errMsg } }));
|
|
66
|
-
} else {
|
|
67
|
-
console.error(chalk.red(`\n✗ Failed to generate supplier code: ${errMsg}\n`));
|
|
68
|
-
}
|
|
69
|
-
process.exit(1);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const data: CreateSupplierRequest = {
|
|
74
|
-
supplierName: name,
|
|
75
|
-
supplierCode: code!,
|
|
76
|
-
supplierType: type,
|
|
77
|
-
contactPerson: contact,
|
|
78
|
-
contactPhone: phone,
|
|
79
|
-
address: address,
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
if (dryRun) {
|
|
83
|
-
if (jsonOutput) {
|
|
84
|
-
console.log(JSON.stringify({ success: true, dryRun: true, data }));
|
|
85
|
-
} else {
|
|
86
|
-
console.log(chalk.bold('\n🔍 Dry-Run Mode: No changes will be made\n'));
|
|
87
|
-
console.log(' Supplier to be created:');
|
|
88
|
-
console.log(formatTable(data));
|
|
89
|
-
console.log();
|
|
90
|
-
}
|
|
91
|
-
return;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
if (!jsonOutput) {
|
|
95
|
-
console.log(chalk.bold('\n📝 Creating Supplier\n'));
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
const response = await apiClient.createSupplier(context.environment, context.tenant, data);
|
|
99
|
-
|
|
100
|
-
if (!response.success) {
|
|
101
|
-
const errorMsg = response.error?.message || 'Failed to create supplier';
|
|
102
|
-
const errorCode = response.error?.code || 'CREATE_SUPPLIER_ERROR';
|
|
103
|
-
if (jsonOutput) {
|
|
104
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
105
|
-
} else {
|
|
106
|
-
console.error(chalk.red(`\n✗ Failed to create supplier: ${errorMsg}`));
|
|
107
|
-
if (response.error?.code) {
|
|
108
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
109
|
-
}
|
|
110
|
-
console.error();
|
|
111
|
-
}
|
|
112
|
-
process.exit(1);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
if (response.success) {
|
|
116
|
-
const supplier = response.data as {
|
|
117
|
-
supplierId?: number;
|
|
118
|
-
supplierCode?: string;
|
|
119
|
-
supplierName?: string;
|
|
120
|
-
supplierType?: string;
|
|
121
|
-
contactPerson?: string;
|
|
122
|
-
contactPhone?: string;
|
|
123
|
-
address?: string;
|
|
124
|
-
statusFlag?: number;
|
|
125
|
-
createTime?: string;
|
|
126
|
-
} | undefined;
|
|
127
|
-
|
|
128
|
-
if (jsonOutput) {
|
|
129
|
-
console.log(JSON.stringify({ success: true, data: supplier }));
|
|
130
|
-
} else {
|
|
131
|
-
console.log(chalk.green('✓ Supplier created successfully\n'));
|
|
132
|
-
if (supplier?.supplierId) console.log(` ${chalk.gray('Supplier ID:')} ${chalk.green(String(supplier.supplierId))}`);
|
|
133
|
-
if (supplier?.supplierName) console.log(` ${chalk.gray('Name:')} ${supplier.supplierName}`);
|
|
134
|
-
if (supplier?.supplierCode) console.log(` ${chalk.gray('Code:')} ${supplier.supplierCode}`);
|
|
135
|
-
if (supplier?.supplierType) console.log(` ${chalk.gray('Type:')} ${supplier.supplierType}`);
|
|
136
|
-
if (supplier?.contactPerson) console.log(` ${chalk.gray('Contact:')} ${supplier.contactPerson}`);
|
|
137
|
-
if (supplier?.contactPhone) console.log(` ${chalk.gray('Phone:')} ${supplier.contactPhone}`);
|
|
138
|
-
if (supplier?.address) console.log(` ${chalk.gray('Address:')} ${supplier.address}`);
|
|
139
|
-
if (supplier?.statusFlag !== undefined) {
|
|
140
|
-
const statusText = supplier.statusFlag === 1 ? 'Enabled' : 'Disabled';
|
|
141
|
-
console.log(` ${chalk.gray('Status:')} ${chalk.green(statusText)}`);
|
|
142
|
-
}
|
|
143
|
-
console.log();
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
return cmd;
|
|
149
|
-
}
|
|
@@ -1,102 +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 { Supplier } from '../../../types/supplier.js';
|
|
7
|
-
|
|
8
|
-
export function createSupplierDeleteCommand(): Command {
|
|
9
|
-
const deleteCommand = new Command('delete');
|
|
10
|
-
deleteCommand
|
|
11
|
-
.description('Delete a supplier')
|
|
12
|
-
.argument('<supplierId>', 'Supplier ID')
|
|
13
|
-
.option('--force', 'Skip confirmation and delete directly')
|
|
14
|
-
.option('--json', 'Output as JSON')
|
|
15
|
-
.action(async (supplierId: string, options: Record<string, unknown>) => {
|
|
16
|
-
const context = configManager.getCurrentContext();
|
|
17
|
-
const environment = context.environment as Environment;
|
|
18
|
-
const tenant = context.tenant;
|
|
19
|
-
const jsonOutput = options.json === true;
|
|
20
|
-
|
|
21
|
-
if (!jsonOutput) {
|
|
22
|
-
console.log(chalk.bold(`\n🗑️ Delete Supplier (${environment})\n`));
|
|
23
|
-
console.log(chalk.gray(` Supplier ID: ${supplierId}`));
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
let supplier: Supplier | undefined;
|
|
27
|
-
try {
|
|
28
|
-
const supplierResponse = await apiClient.getSupplier(environment, tenant, supplierId);
|
|
29
|
-
if (!supplierResponse.success || !supplierResponse.data || !('supplierId' in supplierResponse.data)) {
|
|
30
|
-
const errMsg = `Supplier not found: ${supplierId}`;
|
|
31
|
-
if (jsonOutput) {
|
|
32
|
-
console.log(JSON.stringify({ success: false, error: { code: 'NOT_FOUND', message: errMsg } }));
|
|
33
|
-
} else {
|
|
34
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
35
|
-
}
|
|
36
|
-
process.exit(1);
|
|
37
|
-
}
|
|
38
|
-
supplier = supplierResponse.data as Supplier;
|
|
39
|
-
} catch (error) {
|
|
40
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
41
|
-
if (jsonOutput) {
|
|
42
|
-
console.log(JSON.stringify({ success: false, error: { code: 'FETCH_ERROR', message: `Failed to fetch supplier: ${errMsg}` } }));
|
|
43
|
-
} else {
|
|
44
|
-
console.error(chalk.red(`\n✗ Failed to fetch supplier: ${errMsg}\n`));
|
|
45
|
-
}
|
|
46
|
-
process.exit(1);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
if (!jsonOutput) {
|
|
50
|
-
console.log(chalk.gray(` Name: ${supplier.supplierName}`));
|
|
51
|
-
console.log(chalk.gray(` Code: ${supplier.supplierCode}`));
|
|
52
|
-
if (supplier.contactPerson) {
|
|
53
|
-
console.log(chalk.gray(` Contact: ${supplier.contactPerson} (${supplier.contactPhone || 'N/A'})`));
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
if (!options.force) {
|
|
58
|
-
if (jsonOutput) {
|
|
59
|
-
console.log(JSON.stringify({ success: true, dryRun: true, supplier }));
|
|
60
|
-
} else {
|
|
61
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual deletion will be made\n'));
|
|
62
|
-
console.log(chalk.yellow(' To delete, add: --force\n'));
|
|
63
|
-
}
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
try {
|
|
68
|
-
const response = await apiClient.deleteSupplier(environment, tenant, supplierId);
|
|
69
|
-
|
|
70
|
-
if (response.success) {
|
|
71
|
-
if (jsonOutput) {
|
|
72
|
-
console.log(JSON.stringify({ success: true, supplierId, name: supplier.supplierName }));
|
|
73
|
-
} else {
|
|
74
|
-
console.log(chalk.green(`\n✓ Supplier "${supplier.supplierName}" (ID: ${supplierId}) deleted\n`));
|
|
75
|
-
}
|
|
76
|
-
} else {
|
|
77
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
78
|
-
const errorCode = response.error?.code || 'DELETE_ERROR';
|
|
79
|
-
if (jsonOutput) {
|
|
80
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
81
|
-
} else {
|
|
82
|
-
console.error(chalk.red(`\n✗ Failed to delete supplier: ${errorMsg}`));
|
|
83
|
-
if (response.error?.code) {
|
|
84
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
85
|
-
}
|
|
86
|
-
console.error();
|
|
87
|
-
}
|
|
88
|
-
process.exit(1);
|
|
89
|
-
}
|
|
90
|
-
} catch (error) {
|
|
91
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
92
|
-
if (jsonOutput) {
|
|
93
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
94
|
-
} else {
|
|
95
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
96
|
-
}
|
|
97
|
-
process.exit(1);
|
|
98
|
-
}
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
return deleteCommand;
|
|
102
|
-
}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import chalk from 'chalk';
|
|
3
|
-
import inquirer from 'inquirer';
|
|
4
|
-
import { configManager } from '../../../core/config/manager.js';
|
|
5
|
-
import { apiClient } from '../../../core/api/client.js';
|
|
6
|
-
import { Environment } from '../../../types/index.js';
|
|
7
|
-
import { Supplier } from '../../../types/supplier.js';
|
|
8
|
-
|
|
9
|
-
export function createSupplierDisableCommand(): Command {
|
|
10
|
-
const disableCommand = new Command('disable');
|
|
11
|
-
disableCommand
|
|
12
|
-
.description('Disable (deactivate) a supplier')
|
|
13
|
-
.argument('<supplierId>', 'Supplier ID')
|
|
14
|
-
.option('--force', 'Skip confirmation prompt')
|
|
15
|
-
.option('--dry-run', 'Preview the operation without executing')
|
|
16
|
-
.option('--json', 'Output as JSON')
|
|
17
|
-
.action(async (supplierId: string, 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
|
-
|
|
25
|
-
if (!supplierId || supplierId.trim() === '') {
|
|
26
|
-
const errMsg = 'Invalid supplier ID';
|
|
27
|
-
if (jsonOutput) {
|
|
28
|
-
console.log(JSON.stringify({ success: false, error: { code: 'INVALID_ID', message: errMsg } }));
|
|
29
|
-
} else {
|
|
30
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
31
|
-
}
|
|
32
|
-
process.exit(1);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (!jsonOutput) {
|
|
36
|
-
console.log(chalk.bold(`\n⬇ Disable Supplier (${environment})\n`));
|
|
37
|
-
console.log(chalk.gray(` Supplier ID: ${supplierId}`));
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
if (dryRun) {
|
|
41
|
-
if (jsonOutput) {
|
|
42
|
-
console.log(JSON.stringify({ success: true, dryRun: true, message: 'No actual API call will be made' }));
|
|
43
|
-
} else {
|
|
44
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual API call will be made\n'));
|
|
45
|
-
console.log(chalk.gray(' This operation will disable the supplier.'));
|
|
46
|
-
console.log();
|
|
47
|
-
}
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
let supplier: Supplier | undefined;
|
|
52
|
-
try {
|
|
53
|
-
const supplierResponse = await apiClient.getSupplier(environment, tenant, supplierId);
|
|
54
|
-
if (!supplierResponse.success || !supplierResponse.data || !('supplierId' in supplierResponse.data)) {
|
|
55
|
-
const errMsg = `Supplier not found: ${supplierId}`;
|
|
56
|
-
if (jsonOutput) {
|
|
57
|
-
console.log(JSON.stringify({ success: false, error: { code: 'NOT_FOUND', message: errMsg } }));
|
|
58
|
-
} else {
|
|
59
|
-
console.error(chalk.red(`\n✗ ${errMsg}\n`));
|
|
60
|
-
}
|
|
61
|
-
process.exit(1);
|
|
62
|
-
}
|
|
63
|
-
supplier = supplierResponse.data as Supplier;
|
|
64
|
-
} catch (error) {
|
|
65
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
66
|
-
const jsonErr = { success: false, error: { code: 'FETCH_ERROR', message: 'Failed to fetch supplier: ' + errMsg } };
|
|
67
|
-
if (jsonOutput) {
|
|
68
|
-
console.log(JSON.stringify(jsonErr));
|
|
69
|
-
} else {
|
|
70
|
-
console.error(chalk.red(`\n✗ Failed to fetch supplier: ${errMsg}\n`));
|
|
71
|
-
}
|
|
72
|
-
process.exit(1);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
if (supplier.statusFlag === 2) {
|
|
76
|
-
const errMsg = `Supplier "${supplier.supplierName}" is already disabled`;
|
|
77
|
-
if (jsonOutput) {
|
|
78
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ALREADY_DISABLED', message: errMsg } }));
|
|
79
|
-
} else {
|
|
80
|
-
console.error(chalk.yellow(`\n⚠ ${errMsg}\n`));
|
|
81
|
-
}
|
|
82
|
-
process.exit(1);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
if (!force) {
|
|
86
|
-
if (!jsonOutput) {
|
|
87
|
-
console.log(chalk.gray(` Name: ${supplier.supplierName}`));
|
|
88
|
-
console.log(chalk.gray(` Code: ${supplier.supplierCode}`));
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
const { confirm } = await inquirer.prompt([
|
|
92
|
-
{
|
|
93
|
-
type: 'confirm',
|
|
94
|
-
name: 'confirm',
|
|
95
|
-
message: `Disable supplier "${supplier.supplierName}"?`,
|
|
96
|
-
default: false,
|
|
97
|
-
},
|
|
98
|
-
]);
|
|
99
|
-
|
|
100
|
-
if (!confirm) {
|
|
101
|
-
if (jsonOutput) {
|
|
102
|
-
console.log(JSON.stringify({ success: false, error: { code: 'CANCELLED', message: 'Operation cancelled' } }));
|
|
103
|
-
} else {
|
|
104
|
-
console.log(chalk.gray('\n Operation cancelled.\n'));
|
|
105
|
-
}
|
|
106
|
-
process.exit(0);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
try {
|
|
111
|
-
const response = await apiClient.disableSupplier(environment, tenant, supplierId);
|
|
112
|
-
|
|
113
|
-
if (response.success) {
|
|
114
|
-
if (jsonOutput) {
|
|
115
|
-
console.log(JSON.stringify({ success: true, supplierId, name: supplier?.supplierName }));
|
|
116
|
-
} else {
|
|
117
|
-
console.log(chalk.green(`\n✓ Supplier ${supplier?.supplierName || supplierId} disabled\n`));
|
|
118
|
-
}
|
|
119
|
-
} else {
|
|
120
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
121
|
-
const errorCode = response.error?.code || 'DISABLE_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 disable supplier: ${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
|
-
} catch (error) {
|
|
134
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
135
|
-
if (jsonOutput) {
|
|
136
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
137
|
-
} else {
|
|
138
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
139
|
-
}
|
|
140
|
-
process.exit(1);
|
|
141
|
-
}
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
return disableCommand;
|
|
145
|
-
}
|