@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,137 +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 { UpdateClientContactRequest } from '../../../types/client-contact.js';
|
|
7
|
-
|
|
8
|
-
export function createClientContactUpdateCommand(): Command {
|
|
9
|
-
const cmd = new Command('update');
|
|
10
|
-
cmd.description('Update a client contact');
|
|
11
|
-
cmd.arguments('<contact-id>');
|
|
12
|
-
|
|
13
|
-
cmd
|
|
14
|
-
.option('-n, --name <string>', 'Contact name')
|
|
15
|
-
.option('-p, --phone <string>', 'Mobile phone')
|
|
16
|
-
.option('-t, --telephone <string>', 'Telephone')
|
|
17
|
-
.option('-e, --email <string>', 'Email')
|
|
18
|
-
.option('-s, --sex <string>', 'Sex')
|
|
19
|
-
.option('-b, --birthday <string>', 'Birthday (YYYY-MM-DD)')
|
|
20
|
-
.option('-q, --qq <string>', 'QQ number')
|
|
21
|
-
.option('-w, --wechat <string>', 'WeChat ID')
|
|
22
|
-
.option('-a, --address <string>', 'Address')
|
|
23
|
-
.option('-d, --default', 'Set as default contact')
|
|
24
|
-
.option('-r, --remark <string>', 'Remark')
|
|
25
|
-
.option('--dry-run', 'Preview the operation without executing')
|
|
26
|
-
.option('--json', 'Output as JSON')
|
|
27
|
-
.action(async (contactId: string, options: Record<string, unknown>) => {
|
|
28
|
-
const context = configManager.getCurrentContext();
|
|
29
|
-
const environment = context.environment as Environment;
|
|
30
|
-
const tenant = context.tenant;
|
|
31
|
-
const jsonOutput = options.json === true;
|
|
32
|
-
|
|
33
|
-
if (!contactId) {
|
|
34
|
-
if (jsonOutput) {
|
|
35
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'Contact ID is required' } }));
|
|
36
|
-
} else {
|
|
37
|
-
console.error(chalk.red('\nā Contact ID is required\n'));
|
|
38
|
-
}
|
|
39
|
-
process.exit(1);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
const fields: Partial<UpdateClientContactRequest> = {
|
|
43
|
-
clientContactId: contactId,
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
if (options.name) fields.clientContactName = options.name as string;
|
|
47
|
-
if (options.phone) fields.clientContactPhone = options.phone as string;
|
|
48
|
-
if (options.telephone) fields.clientContactTelephone = options.telephone as string;
|
|
49
|
-
if (options.email) fields.clientContactEmail = options.email as string;
|
|
50
|
-
if (options.sex) fields.clientContactSex = options.sex as string;
|
|
51
|
-
if (options.birthday) fields.clientContactBirthday = options.birthday as string;
|
|
52
|
-
if (options.qq) fields.clientContactQq = options.qq as string;
|
|
53
|
-
if (options.wechat) fields.clientContactWechat = options.wechat as string;
|
|
54
|
-
if (options.address) fields.clientContactAddress = options.address as string;
|
|
55
|
-
if (options.default) fields.defaultFlag = 'Y';
|
|
56
|
-
if (options.remark) fields.remark = options.remark as string;
|
|
57
|
-
|
|
58
|
-
const updateFields = Object.keys(fields).filter(k => k !== 'clientContactId' && fields[k as keyof UpdateClientContactRequest] !== undefined);
|
|
59
|
-
if (updateFields.length === 0) {
|
|
60
|
-
if (jsonOutput) {
|
|
61
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'No fields to update. Provide at least one of: --name, --phone, --telephone, --email, --sex, --birthday, --qq, --wechat, --address, --default, --remark' } }));
|
|
62
|
-
} else {
|
|
63
|
-
console.error(chalk.red('\nā No fields to update. Provide at least one of: --name, --phone, --telephone, --email, --sex, --birthday, --qq, --wechat, --address, --default, --remark\n'));
|
|
64
|
-
}
|
|
65
|
-
process.exit(1);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
const updateData: UpdateClientContactRequest = fields as UpdateClientContactRequest;
|
|
69
|
-
|
|
70
|
-
if (options.dryRun) {
|
|
71
|
-
if (jsonOutput) {
|
|
72
|
-
console.log(JSON.stringify({ success: true, dryRun: true, data: updateData }));
|
|
73
|
-
} else {
|
|
74
|
-
console.log(chalk.cyan('\nš Dry-Run Mode: No actual API call will be made\n'));
|
|
75
|
-
console.log(chalk.gray(' This operation will update the client contact with the following fields:'));
|
|
76
|
-
console.log(` ${chalk.gray('Contact ID:')} ${contactId}`);
|
|
77
|
-
if (fields.clientContactName) console.log(` ${chalk.gray('Name:')} ${fields.clientContactName}`);
|
|
78
|
-
if (fields.clientContactPhone) console.log(` ${chalk.gray('Phone:')} ${fields.clientContactPhone}`);
|
|
79
|
-
if (fields.clientContactTelephone) console.log(` ${chalk.gray('Telephone:')} ${fields.clientContactTelephone}`);
|
|
80
|
-
if (fields.clientContactEmail) console.log(` ${chalk.gray('Email:')} ${fields.clientContactEmail}`);
|
|
81
|
-
if (fields.clientContactSex) console.log(` ${chalk.gray('Sex:')} ${fields.clientContactSex}`);
|
|
82
|
-
if (fields.clientContactBirthday) console.log(` ${chalk.gray('Birthday:')} ${fields.clientContactBirthday}`);
|
|
83
|
-
if (fields.clientContactQq) console.log(` ${chalk.gray('QQ:')} ${fields.clientContactQq}`);
|
|
84
|
-
if (fields.clientContactWechat) console.log(` ${chalk.gray('WeChat:')} ${fields.clientContactWechat}`);
|
|
85
|
-
if (fields.clientContactAddress) console.log(` ${chalk.gray('Address:')} ${fields.clientContactAddress}`);
|
|
86
|
-
if (fields.defaultFlag) console.log(` ${chalk.gray('Default:')} ${fields.defaultFlag}`);
|
|
87
|
-
if (fields.remark) console.log(` ${chalk.gray('Remark:')} ${fields.remark}`);
|
|
88
|
-
console.log();
|
|
89
|
-
}
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
try {
|
|
94
|
-
const response = await apiClient.updateClientContact(environment, tenant, updateData);
|
|
95
|
-
|
|
96
|
-
if (response.success) {
|
|
97
|
-
if (jsonOutput) {
|
|
98
|
-
console.log(JSON.stringify({ success: true, data: response.data }));
|
|
99
|
-
} else {
|
|
100
|
-
console.log(chalk.green('\nā Client contact updated successfully\n'));
|
|
101
|
-
}
|
|
102
|
-
} else {
|
|
103
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
104
|
-
const errorCode = response.error?.code || 'UPDATE_CLIENT_CONTACT_ERROR';
|
|
105
|
-
|
|
106
|
-
if (errorCode === '01001207001' || errorMsg.includes('äøååØ')) {
|
|
107
|
-
if (jsonOutput) {
|
|
108
|
-
console.log(JSON.stringify({ success: false, error: { code: 'NOT_FOUND', message: `Client contact not found: ${contactId}` } }));
|
|
109
|
-
} else {
|
|
110
|
-
console.error(chalk.red(`\nā Client contact not found: ${contactId}\n`));
|
|
111
|
-
}
|
|
112
|
-
} else {
|
|
113
|
-
if (jsonOutput) {
|
|
114
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
115
|
-
} else {
|
|
116
|
-
console.error(chalk.red(`\nā Failed to update client contact: ${errorMsg}`));
|
|
117
|
-
if (response.error?.code) {
|
|
118
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
119
|
-
}
|
|
120
|
-
console.error();
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
process.exit(1);
|
|
124
|
-
}
|
|
125
|
-
} catch (error) {
|
|
126
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
127
|
-
if (jsonOutput) {
|
|
128
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
129
|
-
} else {
|
|
130
|
-
console.error(chalk.red(`\nā Error: ${errMsg}\n`));
|
|
131
|
-
}
|
|
132
|
-
process.exit(1);
|
|
133
|
-
}
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
return cmd;
|
|
137
|
-
}
|
|
@@ -1,122 +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 { CreateClientRequest, StatusFlag } from '../../../types/client.js';
|
|
6
|
-
|
|
7
|
-
export function createClientCreateCommand(): Command {
|
|
8
|
-
const cmd = new Command('create');
|
|
9
|
-
cmd.description('Create a new client (auto-generates client code if not provided)');
|
|
10
|
-
|
|
11
|
-
cmd
|
|
12
|
-
.option('--client-code <code>', 'Client code (auto-generated if not provided)')
|
|
13
|
-
.option('--client-name <name>', 'Client name')
|
|
14
|
-
.option('--follower <name>', 'Follower/salesperson')
|
|
15
|
-
.option('--office-address <address>', 'Office address')
|
|
16
|
-
.option('--office-telephone <phone>', 'Office telephone')
|
|
17
|
-
.option('--status <status>', 'Status (1=enable, 2=disable)')
|
|
18
|
-
.option('--remark <remark>', 'Remark')
|
|
19
|
-
.option('--dry-run', 'Preview the operation without executing')
|
|
20
|
-
.option('--json', 'Output as JSON')
|
|
21
|
-
.action(async (options: Record<string, unknown>) => {
|
|
22
|
-
const context = configManager.getCurrentContext();
|
|
23
|
-
const environment = context.environment;
|
|
24
|
-
const tenant = context.tenant;
|
|
25
|
-
const jsonOutput = options.json === true;
|
|
26
|
-
|
|
27
|
-
let clientCode = options.clientCode as string | undefined;
|
|
28
|
-
const clientName = options.clientName as string | undefined;
|
|
29
|
-
const follower = options.follower as string | undefined;
|
|
30
|
-
const officeAddress = options.officeAddress as string | undefined;
|
|
31
|
-
const officeTelephone = options.officeTelephone as string | undefined;
|
|
32
|
-
const status = options.status as string | undefined;
|
|
33
|
-
const remark = options.remark as string | undefined;
|
|
34
|
-
|
|
35
|
-
if (!clientCode) {
|
|
36
|
-
const codeResponse = await apiClient.getCodeByType(environment, tenant, 'TenantClientCode');
|
|
37
|
-
if (codeResponse.success && codeResponse.data) {
|
|
38
|
-
clientCode = codeResponse.data;
|
|
39
|
-
} else {
|
|
40
|
-
const errMsg = codeResponse.error?.message || 'Failed to generate client code';
|
|
41
|
-
if (jsonOutput) {
|
|
42
|
-
console.log(JSON.stringify({ success: false, error: { code: 'CODE_GENERATION_ERROR', message: errMsg } }));
|
|
43
|
-
} else {
|
|
44
|
-
console.error(chalk.red(`\nā Failed to generate client code: ${errMsg}\n`));
|
|
45
|
-
}
|
|
46
|
-
process.exit(1);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
const data: CreateClientRequest = {
|
|
51
|
-
clientCode,
|
|
52
|
-
clientName,
|
|
53
|
-
follower,
|
|
54
|
-
officeAddress,
|
|
55
|
-
officeTelephone,
|
|
56
|
-
statusFlag: status ? parseInt(status) as StatusFlag : undefined,
|
|
57
|
-
remark,
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
Object.keys(data).forEach(key => {
|
|
61
|
-
if (data[key as keyof CreateClientRequest] === undefined) {
|
|
62
|
-
delete data[key as keyof CreateClientRequest];
|
|
63
|
-
}
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
if (options.dryRun) {
|
|
67
|
-
if (jsonOutput) {
|
|
68
|
-
console.log(JSON.stringify({ success: true, dryRun: true, data }));
|
|
69
|
-
} else {
|
|
70
|
-
console.log(chalk.cyan('\nš Dry-Run Mode: No actual API call will be made\n'));
|
|
71
|
-
console.log(chalk.gray(' This operation will create the following client:'));
|
|
72
|
-
console.log(` ${chalk.gray('Client Code:')} ${clientCode}`);
|
|
73
|
-
if (clientName) console.log(` ${chalk.gray('Client Name:')} ${clientName}`);
|
|
74
|
-
if (follower) console.log(` ${chalk.gray('Follower:')} ${follower}`);
|
|
75
|
-
if (officeAddress) console.log(` ${chalk.gray('Office:')} ${officeAddress}`);
|
|
76
|
-
console.log();
|
|
77
|
-
}
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
try {
|
|
82
|
-
const response = await apiClient.createClient(environment, tenant, data);
|
|
83
|
-
|
|
84
|
-
if (response.success) {
|
|
85
|
-
if (jsonOutput) {
|
|
86
|
-
console.log(JSON.stringify({ success: true, data: response.data }));
|
|
87
|
-
} else {
|
|
88
|
-
console.log(chalk.green('\nā Client created successfully\n'));
|
|
89
|
-
if (response.data && typeof response.data === 'object' && 'clientId' in response.data) {
|
|
90
|
-
console.log(` ${chalk.gray('Client ID:')} ${chalk.green(String((response.data as { clientId: string }).clientId))}`);
|
|
91
|
-
}
|
|
92
|
-
if (clientCode) console.log(` ${chalk.gray('Client Code:')} ${chalk.green(clientCode)}`);
|
|
93
|
-
if (clientName) console.log(` ${chalk.gray('Client Name:')} ${clientName}`);
|
|
94
|
-
console.log();
|
|
95
|
-
}
|
|
96
|
-
} else {
|
|
97
|
-
const errorMsg = response.error?.message || 'Failed to create client';
|
|
98
|
-
const errorCode = response.error?.code || 'CREATE_CLIENT_ERROR';
|
|
99
|
-
if (jsonOutput) {
|
|
100
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
101
|
-
} else {
|
|
102
|
-
console.error(chalk.red(`\nā Failed to create client: ${errorMsg}`));
|
|
103
|
-
if (response.error?.code) {
|
|
104
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
105
|
-
}
|
|
106
|
-
console.error();
|
|
107
|
-
}
|
|
108
|
-
process.exit(1);
|
|
109
|
-
}
|
|
110
|
-
} catch (error) {
|
|
111
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
112
|
-
if (jsonOutput) {
|
|
113
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
114
|
-
} else {
|
|
115
|
-
console.error(chalk.red(`\nā Error: ${errMsg}\n`));
|
|
116
|
-
}
|
|
117
|
-
process.exit(1);
|
|
118
|
-
}
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
return cmd;
|
|
122
|
-
}
|
|
@@ -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 { MasterClientResponse } from '../../../types/client.js';
|
|
7
|
-
|
|
8
|
-
export function createClientDeleteCommand(): Command {
|
|
9
|
-
const deleteCommand = new Command('delete');
|
|
10
|
-
deleteCommand
|
|
11
|
-
.description('Delete a client')
|
|
12
|
-
.argument('<id>', 'Client ID')
|
|
13
|
-
.option('--force', 'Skip confirmation prompt')
|
|
14
|
-
.option('--dry-run', 'Preview the operation without executing')
|
|
15
|
-
.option('--json', 'Output as JSON')
|
|
16
|
-
.action(async (id: string, options: Record<string, unknown>) => {
|
|
17
|
-
const context = configManager.getCurrentContext();
|
|
18
|
-
const environment = context.environment as Environment;
|
|
19
|
-
const tenant = context.tenant;
|
|
20
|
-
const jsonOutput = options.json === true;
|
|
21
|
-
|
|
22
|
-
const clientId = id;
|
|
23
|
-
|
|
24
|
-
if (!clientId) {
|
|
25
|
-
if (jsonOutput) {
|
|
26
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'Client ID is required' } }));
|
|
27
|
-
} else {
|
|
28
|
-
console.error(chalk.red('\nā Client ID is required\n'));
|
|
29
|
-
}
|
|
30
|
-
process.exit(1);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
if (!jsonOutput) {
|
|
34
|
-
console.log(chalk.bold(`\nšļø Delete Client (${environment})\n`));
|
|
35
|
-
console.log(chalk.gray(` Client ID: ${clientId}`));
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (options.dryRun) {
|
|
39
|
-
if (jsonOutput) {
|
|
40
|
-
console.log(JSON.stringify({ success: true, dryRun: true, clientId }));
|
|
41
|
-
} else {
|
|
42
|
-
console.log(chalk.cyan('\nš Dry-Run Mode: No actual API call will be made\n'));
|
|
43
|
-
console.log(chalk.gray(' This operation will delete the client.'));
|
|
44
|
-
console.log();
|
|
45
|
-
}
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
let client: MasterClientResponse | undefined;
|
|
50
|
-
try {
|
|
51
|
-
const clientResponse = await apiClient.getClient(environment, tenant, clientId);
|
|
52
|
-
if (!clientResponse.success || !clientResponse.data) {
|
|
53
|
-
const errMsg = `Client not found: ${clientId}`;
|
|
54
|
-
if (jsonOutput) {
|
|
55
|
-
console.log(JSON.stringify({ success: false, error: { code: 'NOT_FOUND', message: errMsg } }));
|
|
56
|
-
} else {
|
|
57
|
-
console.error(chalk.red(`\nā ${errMsg}\n`));
|
|
58
|
-
}
|
|
59
|
-
process.exit(1);
|
|
60
|
-
}
|
|
61
|
-
client = clientResponse.data as MasterClientResponse;
|
|
62
|
-
} catch (error) {
|
|
63
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
64
|
-
if (jsonOutput) {
|
|
65
|
-
console.log(JSON.stringify({ success: false, error: { code: 'FETCH_ERROR', message: `Failed to fetch client: ${errMsg}` } }));
|
|
66
|
-
} else {
|
|
67
|
-
console.error(chalk.red(`\nā Failed to fetch client: ${errMsg}\n`));
|
|
68
|
-
}
|
|
69
|
-
process.exit(1);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
if (!options.force) {
|
|
73
|
-
if (!jsonOutput) {
|
|
74
|
-
console.log(chalk.gray(` Client Name: ${client.clientName}`));
|
|
75
|
-
console.log(chalk.gray(` Client Code: ${client.clientCode}`));
|
|
76
|
-
console.log(chalk.yellow(`\nā ļø This action cannot be undone.`));
|
|
77
|
-
console.log(chalk.gray(' Use --force to skip this confirmation.\n'));
|
|
78
|
-
} else {
|
|
79
|
-
console.log(JSON.stringify({
|
|
80
|
-
success: false,
|
|
81
|
-
error: {
|
|
82
|
-
code: 'CONFIRMATION_REQUIRED',
|
|
83
|
-
message: `Delete client "${client.clientName}"? Use --force to confirm.`
|
|
84
|
-
}
|
|
85
|
-
}));
|
|
86
|
-
}
|
|
87
|
-
process.exit(1);
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
try {
|
|
91
|
-
const response = await apiClient.deleteClient(environment, tenant, clientId);
|
|
92
|
-
|
|
93
|
-
if (response.success) {
|
|
94
|
-
if (jsonOutput) {
|
|
95
|
-
console.log(JSON.stringify({ success: true, clientId, name: client.clientName }));
|
|
96
|
-
} else {
|
|
97
|
-
console.log(chalk.green(`\nā Client "${client.clientName}" (ID: ${clientId}) deleted\n`));
|
|
98
|
-
}
|
|
99
|
-
} else {
|
|
100
|
-
const errorMsg = response.error?.message || 'Unknown error';
|
|
101
|
-
const errorCode = response.error?.code || 'DELETE_ERROR';
|
|
102
|
-
if (jsonOutput) {
|
|
103
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
104
|
-
} else {
|
|
105
|
-
console.error(chalk.red(`\nā Failed to delete client: ${errorMsg}`));
|
|
106
|
-
if (response.error?.code) {
|
|
107
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
108
|
-
}
|
|
109
|
-
console.error();
|
|
110
|
-
}
|
|
111
|
-
process.exit(1);
|
|
112
|
-
}
|
|
113
|
-
} catch (error) {
|
|
114
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
115
|
-
if (jsonOutput) {
|
|
116
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
117
|
-
} else {
|
|
118
|
-
console.error(chalk.red(`\nā Error: ${errMsg}\n`));
|
|
119
|
-
}
|
|
120
|
-
process.exit(1);
|
|
121
|
-
}
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
return deleteCommand;
|
|
125
|
-
}
|
|
@@ -1,88 +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 { MasterClientResponse } from '../../../types/client.js';
|
|
7
|
-
|
|
8
|
-
export function createClientGetCommand(): Command {
|
|
9
|
-
const getCommand = new Command('get');
|
|
10
|
-
getCommand.description('Get client details by ID');
|
|
11
|
-
getCommand.arguments('<id>');
|
|
12
|
-
getCommand.option('--json', 'Output as JSON');
|
|
13
|
-
|
|
14
|
-
getCommand.action(async (id: 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 (!id) {
|
|
20
|
-
console.error(chalk.red('\nā Client ID is required\n'));
|
|
21
|
-
process.exit(1);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const clientId = id;
|
|
25
|
-
if (!clientId || clientId.trim() === '') {
|
|
26
|
-
console.error(chalk.red('\nā Invalid client ID.\n'));
|
|
27
|
-
process.exit(1);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
try {
|
|
31
|
-
const response = await apiClient.getClient(environment, tenant, clientId);
|
|
32
|
-
|
|
33
|
-
if (!response.success) {
|
|
34
|
-
const errorCode = response.error?.code || 'UNKNOWN_ERROR';
|
|
35
|
-
const errorMessage = response.error?.message || 'Unknown error';
|
|
36
|
-
|
|
37
|
-
if (errorCode === '01001150001' || errorMessage.includes('äøååØ')) {
|
|
38
|
-
console.error(chalk.red(`\nā Client not found: ${clientId}\n`));
|
|
39
|
-
} else {
|
|
40
|
-
console.error(chalk.red(`\nā Error: ${errorMessage} (${errorCode})\n`));
|
|
41
|
-
}
|
|
42
|
-
process.exit(1);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const client = response.data as MasterClientResponse | null;
|
|
46
|
-
|
|
47
|
-
if (!client) {
|
|
48
|
-
console.error(chalk.red('\nā Client not found\n'));
|
|
49
|
-
process.exit(1);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
if (options.json) {
|
|
53
|
-
console.log(JSON.stringify({
|
|
54
|
-
success: true,
|
|
55
|
-
data: client,
|
|
56
|
-
}, null, 2));
|
|
57
|
-
return;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
console.log(chalk.bold('\nš¢ Client Details\n'));
|
|
61
|
-
console.log(` ${chalk.gray('Client ID:')} ${client.clientId}`);
|
|
62
|
-
console.log(` ${chalk.gray('Client Code:')} ${client.clientCode}`);
|
|
63
|
-
console.log(` ${chalk.gray('Client Name:')} ${client.clientName}`);
|
|
64
|
-
if (client.follower) {
|
|
65
|
-
console.log(` ${chalk.gray('Follower:')} ${client.follower}`);
|
|
66
|
-
}
|
|
67
|
-
if (client.officeAddress) {
|
|
68
|
-
console.log(` ${chalk.gray('Office:')} ${client.officeAddress}`);
|
|
69
|
-
}
|
|
70
|
-
if (client.officeTelephone) {
|
|
71
|
-
console.log(` ${chalk.gray('Telephone:')} ${client.officeTelephone}`);
|
|
72
|
-
}
|
|
73
|
-
if (client.statusFlag !== undefined) {
|
|
74
|
-
const statusText = client.statusFlag === 1 ? chalk.green('Enable') : chalk.red('Disable');
|
|
75
|
-
console.log(` ${chalk.gray('Status:')} ${statusText}`);
|
|
76
|
-
}
|
|
77
|
-
if (client.remark) {
|
|
78
|
-
console.log(` ${chalk.gray('Remark:')} ${client.remark}`);
|
|
79
|
-
}
|
|
80
|
-
console.log();
|
|
81
|
-
} catch (error) {
|
|
82
|
-
console.error(chalk.red(`\nā Unexpected error: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
83
|
-
process.exit(1);
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
return getCommand;
|
|
88
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createClientListCommand } from './list.js';
|
|
3
|
-
import { createClientGetCommand } from './get.js';
|
|
4
|
-
import { createClientCreateCommand } from './create.js';
|
|
5
|
-
import { createClientUpdateCommand } from './update.js';
|
|
6
|
-
import { createClientDeleteCommand } from './delete.js';
|
|
7
|
-
|
|
8
|
-
export function createClientsCommand(): Command {
|
|
9
|
-
const clientsCommand = new Command('clients');
|
|
10
|
-
clientsCommand.description('Manage clients');
|
|
11
|
-
|
|
12
|
-
clientsCommand.addCommand(createClientListCommand());
|
|
13
|
-
clientsCommand.addCommand(createClientGetCommand());
|
|
14
|
-
clientsCommand.addCommand(createClientCreateCommand());
|
|
15
|
-
clientsCommand.addCommand(createClientUpdateCommand());
|
|
16
|
-
clientsCommand.addCommand(createClientDeleteCommand());
|
|
17
|
-
|
|
18
|
-
return clientsCommand;
|
|
19
|
-
}
|
|
@@ -1,123 +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 { ClientListResponse, StatusFlag } from '../../../types/client.js';
|
|
7
|
-
import { Environment } from '../../../types/index.js';
|
|
8
|
-
|
|
9
|
-
export function createClientListCommand(): Command {
|
|
10
|
-
const listCommand = new Command('list');
|
|
11
|
-
listCommand.description('List clients with pagination');
|
|
12
|
-
|
|
13
|
-
listCommand
|
|
14
|
-
.option('-p, --page <number>', 'Page number', '1')
|
|
15
|
-
.option('-s, --size <number>', 'Page size', '20')
|
|
16
|
-
.option('--status <number>', 'Status filter (1=enable, 2=disable)')
|
|
17
|
-
.option('--json', 'Output as JSON')
|
|
18
|
-
.action(async (options) => {
|
|
19
|
-
const context = configManager.getCurrentContext();
|
|
20
|
-
const environment = (options.env as Environment) || context.environment;
|
|
21
|
-
const tenant = options.tenant || context.tenant;
|
|
22
|
-
|
|
23
|
-
const page = parseInt(options.page as string, 10) - 1; // API uses 0-based pagination
|
|
24
|
-
const size = parseInt(options.size as string, 10);
|
|
25
|
-
|
|
26
|
-
const params: {
|
|
27
|
-
pageNo: number;
|
|
28
|
-
pageSize: number;
|
|
29
|
-
status?: StatusFlag;
|
|
30
|
-
} = { pageNo: page, pageSize: size };
|
|
31
|
-
|
|
32
|
-
if (options.status !== undefined) {
|
|
33
|
-
const statusNum = parseInt(options.status as string, 10);
|
|
34
|
-
if (statusNum === 1 || statusNum === 2) {
|
|
35
|
-
params.status = statusNum as StatusFlag;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const response = await apiClient.listClients(environment, tenant, params);
|
|
40
|
-
|
|
41
|
-
if (!response.success) {
|
|
42
|
-
console.error(chalk.red(`\nā Failed to list clients: ${response.error?.message || 'Unknown error'}`));
|
|
43
|
-
if (response.error?.code) {
|
|
44
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
45
|
-
}
|
|
46
|
-
console.error();
|
|
47
|
-
process.exit(1);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
const data = response.data as ClientListResponse | null;
|
|
51
|
-
|
|
52
|
-
if (!data) {
|
|
53
|
-
if (options.json) {
|
|
54
|
-
console.log(JSON.stringify({ success: true, data: { items: [], pagination: { pageNo: 0, pageSize: 20, totalRows: 0 } } }, null, 2));
|
|
55
|
-
} else {
|
|
56
|
-
console.log(chalk.bold('\nš Client List\n'));
|
|
57
|
-
console.log(chalk.gray(' No clients found\n'));
|
|
58
|
-
}
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
if (options.json) {
|
|
63
|
-
console.log(
|
|
64
|
-
JSON.stringify(
|
|
65
|
-
{
|
|
66
|
-
success: true,
|
|
67
|
-
data: {
|
|
68
|
-
items: data.rows || [],
|
|
69
|
-
pagination: {
|
|
70
|
-
pageNo: data.pageNo,
|
|
71
|
-
pageSize: data.pageSize,
|
|
72
|
-
totalRows: data.totalRows,
|
|
73
|
-
},
|
|
74
|
-
},
|
|
75
|
-
},
|
|
76
|
-
null,
|
|
77
|
-
2
|
|
78
|
-
)
|
|
79
|
-
);
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
const records = data.rows || [];
|
|
84
|
-
|
|
85
|
-
if (records.length === 0) {
|
|
86
|
-
console.log(chalk.bold('\nš Client List\n'));
|
|
87
|
-
console.log(chalk.gray(' No clients found\n'));
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
console.log(chalk.bold('\nš Client List\n'));
|
|
92
|
-
|
|
93
|
-
const table = new Table({
|
|
94
|
-
head: [chalk.bold('CLIENT CODE'), chalk.bold('CLIENT NAME'), chalk.bold('FOLLOWER'), chalk.bold('STATUS')],
|
|
95
|
-
colWidths: [15, 25, 20, 10],
|
|
96
|
-
style: {
|
|
97
|
-
head: [],
|
|
98
|
-
border: [],
|
|
99
|
-
},
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
for (const client of records) {
|
|
103
|
-
const statusText = client.statusFlag === 1 ? chalk.green('Enable') : chalk.red('Disable');
|
|
104
|
-
table.push([
|
|
105
|
-
client.clientCode,
|
|
106
|
-
client.clientName || '-',
|
|
107
|
-
client.follower || '-',
|
|
108
|
-
statusText,
|
|
109
|
-
]);
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
console.log(table.toString());
|
|
113
|
-
console.log();
|
|
114
|
-
console.log(
|
|
115
|
-
chalk.gray(
|
|
116
|
-
` Total: ${data.totalRows} | Page: ${data.pageNo + 1} / ${Math.ceil(data.totalRows / data.pageSize) || 1} | Size: ${data.pageSize}`
|
|
117
|
-
)
|
|
118
|
-
);
|
|
119
|
-
console.log();
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
return listCommand;
|
|
123
|
-
}
|