@newpeak/barista-cli 0.1.11 → 0.1.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +1 -1
- package/package.json +7 -3
- package/docs/ARCHITECTURE.md +0 -184
- package/docs/COMMANDS.md +0 -352
- package/docs/COMMAND_DESIGN_SPEC.md +0 -840
- package/docs/INTEGRATION_NOTES.md +0 -270
- package/docs/commands/REFERENCE.md +0 -323
- package/docs/commands/arabica/auth/index.md +0 -296
- package/docs/commands/liberica/auth/index.md +0 -133
- package/docs/commands/liberica/calendar/DESIGN.md +0 -333
- package/docs/commands/liberica/client-contacts/create.md +0 -152
- package/docs/commands/liberica/client-contacts/delete.md +0 -123
- package/docs/commands/liberica/client-contacts/get.md +0 -133
- package/docs/commands/liberica/client-contacts/list.md +0 -143
- package/docs/commands/liberica/client-contacts/update.md +0 -158
- package/docs/commands/liberica/context/index.md +0 -60
- package/docs/commands/liberica/currency/create.md +0 -145
- package/docs/commands/liberica/currency/delete.md +0 -121
- package/docs/commands/liberica/currency/disable.md +0 -119
- package/docs/commands/liberica/currency/enable.md +0 -115
- package/docs/commands/liberica/currency/get.md +0 -118
- package/docs/commands/liberica/currency/list.md +0 -149
- package/docs/commands/liberica/currency/update.md +0 -141
- package/docs/commands/liberica/employees/create.md +0 -185
- package/docs/commands/liberica/employees/disable.md +0 -138
- package/docs/commands/liberica/employees/enable.md +0 -137
- package/docs/commands/liberica/employees/get.md +0 -153
- package/docs/commands/liberica/employees/list.md +0 -168
- package/docs/commands/liberica/employees/update.md +0 -180
- package/docs/commands/liberica/locations/create.md +0 -195
- package/docs/commands/liberica/locations/list.md +0 -171
- package/docs/commands/liberica/materials/create.md +0 -293
- package/docs/commands/liberica/materials/delete.md +0 -240
- package/docs/commands/liberica/materials/disable.md +0 -150
- package/docs/commands/liberica/materials/enable.md +0 -146
- package/docs/commands/liberica/materials/get.md +0 -188
- package/docs/commands/liberica/materials/list.md +0 -198
- package/docs/commands/liberica/materials/update.md +0 -250
- package/docs/commands/liberica/orgs/list.md +0 -62
- package/docs/commands/liberica/positions/list.md +0 -61
- package/docs/commands/liberica/roles/list.md +0 -67
- package/docs/commands/liberica/stock/ledger.md +0 -209
- package/docs/commands/liberica/stock/list.md +0 -165
- package/docs/commands/liberica/supplier-contacts/create.md +0 -152
- package/docs/commands/liberica/supplier-contacts/delete.md +0 -123
- package/docs/commands/liberica/supplier-contacts/get.md +0 -133
- package/docs/commands/liberica/supplier-contacts/list.md +0 -143
- package/docs/commands/liberica/supplier-contacts/update.md +0 -158
- package/docs/commands/liberica/teams/issues/close.md +0 -161
- package/docs/commands/liberica/teams/issues/create.md +0 -212
- package/docs/commands/liberica/teams/issues/delete.md +0 -179
- package/docs/commands/liberica/teams/issues/get.md +0 -167
- package/docs/commands/liberica/teams/issues/list.md +0 -182
- package/docs/commands/liberica/teams/issues/tests-design.md +0 -341
- package/docs/commands/liberica/teams/issues/update.md +0 -202
- package/docs/commands/liberica/teams/projects/create.md +0 -174
- package/docs/commands/liberica/teams/projects/delete.md +0 -180
- package/docs/commands/liberica/teams/projects/get.md +0 -150
- package/docs/commands/liberica/teams/projects/list.md +0 -179
- package/docs/commands/liberica/teams/projects/update.md +0 -175
- package/docs/commands/liberica/teams/tasks/create.md +0 -163
- package/docs/commands/liberica/teams/tasks/delete.md +0 -109
- package/docs/commands/liberica/teams/tasks/get.md +0 -121
- package/docs/commands/liberica/teams/tasks/list.md +0 -148
- package/docs/commands/liberica/teams/tasks/update.md +0 -158
- package/docs/commands/liberica/teams/work-logs/create.md +0 -151
- package/docs/commands/liberica/teams/work-logs/delete.md +0 -130
- package/docs/commands/liberica/teams/work-logs/get.md +0 -131
- package/docs/commands/liberica/teams/work-logs/list.md +0 -153
- package/docs/commands/liberica/teams/work-logs/update.md +0 -150
- package/docs/commands/liberica/transfer-in-forms/batch-delete.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/batch-review.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/create.md +0 -220
- package/docs/commands/liberica/transfer-in-forms/get.md +0 -221
- package/docs/commands/liberica/transfer-in-forms/list.md +0 -242
- package/docs/commands/liberica/transfer-in-forms/update.md +0 -185
- package/docs/commands/liberica/transfer-out-forms/batch-delete.md +0 -187
- package/docs/commands/liberica/transfer-out-forms/batch-review.md +0 -157
- package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +0 -157
- package/docs/commands/liberica/transfer-out-forms/create.md +0 -280
- package/docs/commands/liberica/transfer-out-forms/get.md +0 -211
- package/docs/commands/liberica/transfer-out-forms/list.md +0 -233
- package/docs/commands/liberica/transfer-out-forms/update.md +0 -286
- package/docs/commands/liberica/uoms/create.md +0 -136
- package/docs/commands/liberica/uoms/delete.md +0 -119
- package/docs/commands/liberica/uoms/disable.md +0 -117
- package/docs/commands/liberica/uoms/enable.md +0 -115
- package/docs/commands/liberica/uoms/get.md +0 -119
- package/docs/commands/liberica/uoms/list.md +0 -155
- package/docs/commands/liberica/uoms/update.md +0 -148
- package/docs/commands/liberica/users/create.md +0 -170
- package/docs/commands/liberica/users/get.md +0 -151
- package/docs/commands/liberica/users/list.md +0 -175
- package/docs/commands/liberica/warehouses/create.md +0 -222
- package/docs/commands/liberica/warehouses/list.md +0 -184
- package/src/commands/arabica/auth/index.ts +0 -277
- package/src/commands/arabica/auth/login.ts +0 -5
- package/src/commands/arabica/auth/logout.ts +0 -5
- package/src/commands/arabica/auth/register.ts +0 -5
- package/src/commands/arabica/auth/status.ts +0 -5
- package/src/commands/arabica/index.ts +0 -23
- package/src/commands/auth.ts +0 -107
- package/src/commands/context.ts +0 -60
- package/src/commands/liberica/auth/index.ts +0 -176
- package/src/commands/liberica/calendar/index.ts +0 -13
- package/src/commands/liberica/calendar/list.ts +0 -214
- package/src/commands/liberica/calendar/set.ts +0 -130
- package/src/commands/liberica/client-contacts/create.ts +0 -115
- package/src/commands/liberica/client-contacts/delete.ts +0 -140
- package/src/commands/liberica/client-contacts/get.ts +0 -103
- package/src/commands/liberica/client-contacts/index.ts +0 -19
- package/src/commands/liberica/client-contacts/list.ts +0 -118
- package/src/commands/liberica/client-contacts/update.ts +0 -137
- package/src/commands/liberica/clients/create.ts +0 -122
- package/src/commands/liberica/clients/delete.ts +0 -125
- package/src/commands/liberica/clients/get.ts +0 -88
- package/src/commands/liberica/clients/index.ts +0 -19
- package/src/commands/liberica/clients/list.ts +0 -123
- package/src/commands/liberica/clients/update.ts +0 -103
- package/src/commands/liberica/context/index.ts +0 -43
- package/src/commands/liberica/currency/create.ts +0 -183
- package/src/commands/liberica/currency/delete.ts +0 -124
- package/src/commands/liberica/currency/disable.ts +0 -147
- package/src/commands/liberica/currency/enable.ts +0 -128
- package/src/commands/liberica/currency/get.ts +0 -91
- package/src/commands/liberica/currency/index.ts +0 -23
- package/src/commands/liberica/currency/list.ts +0 -140
- package/src/commands/liberica/currency/update.ts +0 -129
- package/src/commands/liberica/dict-types/get.ts +0 -74
- package/src/commands/liberica/dict-types/index.ts +0 -15
- package/src/commands/liberica/dict-types/list.ts +0 -118
- package/src/commands/liberica/dict-types/update.ts +0 -134
- package/src/commands/liberica/dicts/create.ts +0 -175
- package/src/commands/liberica/dicts/delete.ts +0 -107
- package/src/commands/liberica/dicts/get.ts +0 -80
- package/src/commands/liberica/dicts/index.ts +0 -19
- package/src/commands/liberica/dicts/list.ts +0 -114
- package/src/commands/liberica/dicts/update.ts +0 -116
- package/src/commands/liberica/employees/create.ts +0 -275
- package/src/commands/liberica/employees/delete.ts +0 -122
- package/src/commands/liberica/employees/disable.ts +0 -97
- package/src/commands/liberica/employees/enable.ts +0 -97
- package/src/commands/liberica/employees/get.ts +0 -115
- package/src/commands/liberica/employees/index.ts +0 -23
- package/src/commands/liberica/employees/list.ts +0 -131
- package/src/commands/liberica/employees/update.ts +0 -157
- package/src/commands/liberica/index.ts +0 -81
- package/src/commands/liberica/materials/create.ts +0 -199
- package/src/commands/liberica/materials/delete.ts +0 -105
- package/src/commands/liberica/materials/disable.ts +0 -148
- package/src/commands/liberica/materials/enable.ts +0 -129
- package/src/commands/liberica/materials/get.ts +0 -83
- package/src/commands/liberica/materials/index.ts +0 -23
- package/src/commands/liberica/materials/list.ts +0 -142
- package/src/commands/liberica/materials/update.ts +0 -125
- package/src/commands/liberica/mould/get.ts +0 -111
- package/src/commands/liberica/mould/index.ts +0 -17
- package/src/commands/liberica/mould/list.ts +0 -157
- package/src/commands/liberica/mould/set-status.ts +0 -99
- package/src/commands/liberica/mould/stock-in.ts +0 -165
- package/src/commands/liberica/operations/active.ts +0 -153
- package/src/commands/liberica/operations/batch-delete.ts +0 -131
- package/src/commands/liberica/operations/copy.ts +0 -138
- package/src/commands/liberica/operations/create.ts +0 -223
- package/src/commands/liberica/operations/deactive.ts +0 -152
- package/src/commands/liberica/operations/delete.ts +0 -128
- package/src/commands/liberica/operations/design.md +0 -587
- package/src/commands/liberica/operations/get.ts +0 -112
- package/src/commands/liberica/operations/index.ts +0 -27
- package/src/commands/liberica/operations/list.ts +0 -180
- package/src/commands/liberica/operations/update.ts +0 -218
- package/src/commands/liberica/orgs/index.ts +0 -34
- package/src/commands/liberica/positions/index.ts +0 -30
- package/src/commands/liberica/roles/index.ts +0 -59
- package/src/commands/liberica/stock/index.ts +0 -13
- package/src/commands/liberica/stock/ledger.ts +0 -159
- package/src/commands/liberica/stock/list.ts +0 -128
- package/src/commands/liberica/supplier-contacts/create.ts +0 -120
- package/src/commands/liberica/supplier-contacts/delete.ts +0 -88
- package/src/commands/liberica/supplier-contacts/get.ts +0 -94
- package/src/commands/liberica/supplier-contacts/index.ts +0 -19
- package/src/commands/liberica/supplier-contacts/list.ts +0 -130
- package/src/commands/liberica/supplier-contacts/update.ts +0 -127
- package/src/commands/liberica/suppliers/create.ts +0 -149
- package/src/commands/liberica/suppliers/delete.ts +0 -102
- package/src/commands/liberica/suppliers/disable.ts +0 -145
- package/src/commands/liberica/suppliers/enable.ts +0 -126
- package/src/commands/liberica/suppliers/get.ts +0 -86
- package/src/commands/liberica/suppliers/index.ts +0 -23
- package/src/commands/liberica/suppliers/list.ts +0 -134
- package/src/commands/liberica/suppliers/update.ts +0 -128
- package/src/commands/liberica/teams/index.ts +0 -17
- package/src/commands/liberica/teams/issues/close.ts +0 -104
- package/src/commands/liberica/teams/issues/create.ts +0 -254
- package/src/commands/liberica/teams/issues/delete.ts +0 -58
- package/src/commands/liberica/teams/issues/get.ts +0 -78
- package/src/commands/liberica/teams/issues/index.ts +0 -21
- package/src/commands/liberica/teams/issues/list.ts +0 -144
- package/src/commands/liberica/teams/issues/update.ts +0 -141
- package/src/commands/liberica/teams/projects/create.ts +0 -159
- package/src/commands/liberica/teams/projects/delete.ts +0 -58
- package/src/commands/liberica/teams/projects/get.ts +0 -87
- package/src/commands/liberica/teams/projects/index.ts +0 -19
- package/src/commands/liberica/teams/projects/list.ts +0 -147
- package/src/commands/liberica/teams/projects/update.ts +0 -117
- package/src/commands/liberica/teams/tasks/create.ts +0 -102
- package/src/commands/liberica/teams/tasks/delete.ts +0 -92
- package/src/commands/liberica/teams/tasks/get.ts +0 -64
- package/src/commands/liberica/teams/tasks/index.ts +0 -19
- package/src/commands/liberica/teams/tasks/list.ts +0 -102
- package/src/commands/liberica/teams/tasks/update.ts +0 -122
- package/src/commands/liberica/teams/work-logs/create.ts +0 -204
- package/src/commands/liberica/teams/work-logs/delete.ts +0 -58
- package/src/commands/liberica/teams/work-logs/get.ts +0 -87
- package/src/commands/liberica/teams/work-logs/index.ts +0 -19
- package/src/commands/liberica/teams/work-logs/list.ts +0 -141
- package/src/commands/liberica/teams/work-logs/update.ts +0 -120
- package/src/commands/liberica/transfer-in-forms/batch-delete.ts +0 -152
- package/src/commands/liberica/transfer-in-forms/batch-review.ts +0 -151
- package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +0 -152
- package/src/commands/liberica/transfer-in-forms/create.ts +0 -179
- package/src/commands/liberica/transfer-in-forms/get.ts +0 -107
- package/src/commands/liberica/transfer-in-forms/index.ts +0 -23
- package/src/commands/liberica/transfer-in-forms/list.ts +0 -97
- package/src/commands/liberica/transfer-in-forms/update.ts +0 -213
- package/src/commands/liberica/transfer-out-forms/batch-delete.ts +0 -83
- package/src/commands/liberica/transfer-out-forms/batch-review.ts +0 -148
- package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +0 -56
- package/src/commands/liberica/transfer-out-forms/create.ts +0 -194
- package/src/commands/liberica/transfer-out-forms/get.ts +0 -114
- package/src/commands/liberica/transfer-out-forms/index.ts +0 -23
- package/src/commands/liberica/transfer-out-forms/list.ts +0 -125
- package/src/commands/liberica/transfer-out-forms/update.ts +0 -197
- package/src/commands/liberica/uoms/create.ts +0 -134
- package/src/commands/liberica/uoms/delete.ts +0 -105
- package/src/commands/liberica/uoms/disable.ts +0 -148
- package/src/commands/liberica/uoms/enable.ts +0 -129
- package/src/commands/liberica/uoms/get.ts +0 -83
- package/src/commands/liberica/uoms/index.ts +0 -23
- package/src/commands/liberica/uoms/list.ts +0 -129
- package/src/commands/liberica/uoms/update.ts +0 -124
- package/src/commands/liberica/users/create.ts +0 -133
- package/src/commands/liberica/users/delete.ts +0 -49
- package/src/commands/liberica/users/disable.ts +0 -41
- package/src/commands/liberica/users/enable.ts +0 -30
- package/src/commands/liberica/users/get.ts +0 -46
- package/src/commands/liberica/users/index.ts +0 -27
- package/src/commands/liberica/users/list.ts +0 -68
- package/src/commands/liberica/users/me.ts +0 -42
- package/src/commands/liberica/users/reset-password.ts +0 -42
- package/src/commands/liberica/users/update.ts +0 -48
- package/src/commands/liberica/warehouses/create.ts +0 -204
- package/src/commands/liberica/warehouses/delete.ts +0 -112
- package/src/commands/liberica/warehouses/disable.ts +0 -174
- package/src/commands/liberica/warehouses/enable.ts +0 -174
- package/src/commands/liberica/warehouses/get.ts +0 -101
- package/src/commands/liberica/warehouses/index.ts +0 -25
- package/src/commands/liberica/warehouses/list.ts +0 -136
- package/src/commands/liberica/warehouses/locations/create.ts +0 -209
- package/src/commands/liberica/warehouses/locations/delete.ts +0 -116
- package/src/commands/liberica/warehouses/locations/disable.ts +0 -174
- package/src/commands/liberica/warehouses/locations/enable.ts +0 -174
- package/src/commands/liberica/warehouses/locations/get.ts +0 -84
- package/src/commands/liberica/warehouses/locations/index.ts +0 -23
- package/src/commands/liberica/warehouses/locations/list.ts +0 -140
- package/src/commands/liberica/warehouses/locations/update.ts +0 -135
- package/src/commands/liberica/warehouses/update.ts +0 -142
- package/src/core/api/client.ts +0 -4443
- package/src/core/auth/token-manager.ts +0 -183
- package/src/core/config/manager.ts +0 -164
- package/src/index.ts +0 -35
- package/src/types/calendar.ts +0 -36
- package/src/types/client-contact.ts +0 -78
- package/src/types/client.ts +0 -115
- package/src/types/currency.ts +0 -90
- package/src/types/dict.ts +0 -121
- package/src/types/employee.ts +0 -102
- package/src/types/index.ts +0 -93
- package/src/types/location.ts +0 -66
- package/src/types/material.ts +0 -61
- package/src/types/mould-stock-in.ts +0 -82
- package/src/types/mould.ts +0 -74
- package/src/types/operation.ts +0 -72
- package/src/types/org.ts +0 -25
- package/src/types/position.ts +0 -24
- package/src/types/stock.ts +0 -161
- package/src/types/supplier-contact.ts +0 -78
- package/src/types/supplier.ts +0 -66
- package/src/types/team-issue.ts +0 -94
- package/src/types/team-project.ts +0 -74
- package/src/types/team-task.ts +0 -98
- package/src/types/team-work-log.ts +0 -87
- package/src/types/transfer-in-form.ts +0 -265
- package/src/types/transfer-out-form.ts +0 -290
- package/src/types/uom.ts +0 -60
- package/src/types/user.ts +0 -64
- package/src/types/warehouse.ts +0 -82
|
@@ -1,159 +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 { StockJourneyQueryParams, StockJourneyApiResponse, StockJourneySummaryApiResponse } from '../../../types/stock.js';
|
|
7
|
-
import { Environment } from '../../../types/index.js';
|
|
8
|
-
|
|
9
|
-
export function createStockLedgerCommand(): Command {
|
|
10
|
-
const ledgerCommand = new Command('ledger');
|
|
11
|
-
ledgerCommand.description('Query stock ledger/journey (inbound/outbound history)');
|
|
12
|
-
|
|
13
|
-
ledgerCommand
|
|
14
|
-
.option('--stock-id <string>', 'Stock/Journey ID')
|
|
15
|
-
.option('--stock-form-code <string>', 'Stock form document code')
|
|
16
|
-
.option('--stock-type <string>', 'Stock type (e.g. PURCHASE_STOCK_IN)')
|
|
17
|
-
.option('--stock-flag <INBOUND|OUTBOUND>', 'Stock flag (INBOUND or OUTBOUND)')
|
|
18
|
-
.option('--warehouse-code <string>', 'Warehouse code')
|
|
19
|
-
.option('--material-code <string>', 'Material code')
|
|
20
|
-
.option('--material-no <string>', 'Material number')
|
|
21
|
-
.option('--material-name <string>', 'Material name')
|
|
22
|
-
.option('--material-type <string>', 'Material type/spec')
|
|
23
|
-
.option('--color <string>', 'Color')
|
|
24
|
-
.option('--lot-no <string>', 'Lot/Batch number')
|
|
25
|
-
.option('--lot-code <string>', 'System lot code')
|
|
26
|
-
.option('--source-type <string>', 'Source document type')
|
|
27
|
-
.option('--source-code <string>', 'Source document code')
|
|
28
|
-
.option('--start-date <YYYY-MM-DD>', 'Stock date range start')
|
|
29
|
-
.option('--end-date <YYYY-MM-DD>', 'Stock date range end')
|
|
30
|
-
.option('--posting-month <YYYY-MM>', 'Posting month (e.g. 2026-01)')
|
|
31
|
-
.option('--summary', 'Show only summary (no detail list)')
|
|
32
|
-
.option('-p, --page <number>', 'Page number (1-based)', '1')
|
|
33
|
-
.option('-s, --size <number>', 'Page size', '20')
|
|
34
|
-
.option('--json', 'Output as JSON')
|
|
35
|
-
.action(async (options) => {
|
|
36
|
-
const context = configManager.getCurrentContext();
|
|
37
|
-
const environment = (options.env as Environment) || context.environment;
|
|
38
|
-
const tenant = (options.tenant as string) || context.tenant;
|
|
39
|
-
|
|
40
|
-
if (!tenant) {
|
|
41
|
-
console.error(chalk.red('\n✗ No tenant configured. Run "barista liberica auth login" first.\n'));
|
|
42
|
-
process.exit(1);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const pageNo = parseInt(options.page as string, 10) - 1;
|
|
46
|
-
const pageSize = parseInt(options.size as string, 10);
|
|
47
|
-
|
|
48
|
-
const params: StockJourneyQueryParams = {
|
|
49
|
-
pageNo,
|
|
50
|
-
pageSize,
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
if (options.stockId) params.stockId = options.stockId;
|
|
54
|
-
if (options.stockFormCode) params.stockFormCode = options.stockFormCode;
|
|
55
|
-
if (options.stockType) params.stockType = options.stockType;
|
|
56
|
-
if (options.stockFlag) params.stockFlag = options.stockFlag;
|
|
57
|
-
if (options.warehouseCode) params.warehouseCode = options.warehouseCode;
|
|
58
|
-
if (options.materialCode) params.materialCode = options.materialCode;
|
|
59
|
-
if (options.materialNo) params.materialNo = options.materialNo;
|
|
60
|
-
if (options.materialName) params.materialName = options.materialName;
|
|
61
|
-
if (options.materialType) params.materialType = options.materialType;
|
|
62
|
-
if (options.color) params.color = options.color;
|
|
63
|
-
if (options.lotNo) params.lotNo = options.lotNo;
|
|
64
|
-
if (options.lotCode) params.lotCode = options.lotCode;
|
|
65
|
-
if (options.sourceType) params.sourceType = options.sourceType;
|
|
66
|
-
if (options.sourceCode) params.sourceCode = options.sourceCode;
|
|
67
|
-
if (options.startDate) params.startDate = options.startDate;
|
|
68
|
-
if (options.endDate) params.endDate = options.endDate;
|
|
69
|
-
if (options.postingMonth) params.postingMonth = options.postingMonth;
|
|
70
|
-
|
|
71
|
-
const showOnlySummary = options.summary === true;
|
|
72
|
-
|
|
73
|
-
const summaryResponse: StockJourneySummaryApiResponse = await apiClient.getStockLedgerSummary(environment, tenant, params);
|
|
74
|
-
|
|
75
|
-
if (!summaryResponse.success) {
|
|
76
|
-
console.error(chalk.red(`\n✗ Failed to get summary: ${summaryResponse.error?.message}\n`));
|
|
77
|
-
process.exit(1);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
const summary = summaryResponse.data;
|
|
81
|
-
|
|
82
|
-
if (options.json) {
|
|
83
|
-
if (showOnlySummary) {
|
|
84
|
-
console.log(JSON.stringify({ success: true, summary }, null, 2));
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
const listResponse: StockJourneyApiResponse = await apiClient.listStockLedger(environment, tenant, params);
|
|
88
|
-
if (!listResponse.success) {
|
|
89
|
-
console.error(chalk.red(`\n✗ Failed: ${listResponse.error?.message}\n`));
|
|
90
|
-
process.exit(1);
|
|
91
|
-
}
|
|
92
|
-
console.log(JSON.stringify({ success: true, summary, data: listResponse.data }, null, 2));
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
console.log(chalk.bold('\n Stock Ledger Summary\n'));
|
|
97
|
-
if (summary) {
|
|
98
|
-
console.log(` ${chalk.gray('Total Inbound:')} ${chalk.green(summary.totalInboundCount?.toLocaleString() || 0)} units ${chalk.green('¥' + (summary.totalInboundAmount || 0).toLocaleString())}`);
|
|
99
|
-
console.log(` ${chalk.gray('Total Outbound:')} ${chalk.red(summary.totalOutboundCount?.toLocaleString() || 0)} units ${chalk.red('¥' + (summary.totalOutboundAmount || 0).toLocaleString())}`);
|
|
100
|
-
}
|
|
101
|
-
console.log();
|
|
102
|
-
|
|
103
|
-
if (showOnlySummary) {
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
const listResponse: StockJourneyApiResponse = await apiClient.listStockLedger(environment, tenant, params);
|
|
108
|
-
if (!listResponse.success) {
|
|
109
|
-
console.error(chalk.red(`\n✗ Failed: ${listResponse.error?.message}\n`));
|
|
110
|
-
process.exit(1);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
const data = listResponse.data!;
|
|
114
|
-
const items = data.rows || [];
|
|
115
|
-
|
|
116
|
-
if (items.length === 0) {
|
|
117
|
-
console.log(chalk.yellow(' No ledger records found.\n'));
|
|
118
|
-
return;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
const table = new Table({
|
|
122
|
-
head: [
|
|
123
|
-
chalk.bold('Date'),
|
|
124
|
-
chalk.bold('Flag'),
|
|
125
|
-
chalk.bold('Warehouse'),
|
|
126
|
-
chalk.bold('Material'),
|
|
127
|
-
chalk.bold('Lot No'),
|
|
128
|
-
chalk.bold('In Qty'),
|
|
129
|
-
chalk.bold('Out Qty'),
|
|
130
|
-
chalk.bold('Doc No'),
|
|
131
|
-
],
|
|
132
|
-
colWidths: [12, 8, 10, 16, 12, 8, 8, 16],
|
|
133
|
-
style: { border: [], head: [] },
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
for (const item of items) {
|
|
137
|
-
const flagColor = item.stockFlag === 'INBOUND' ? chalk.green : chalk.red;
|
|
138
|
-
table.push([
|
|
139
|
-
item.stockDate || '-',
|
|
140
|
-
flagColor(item.stockFlag || '-'),
|
|
141
|
-
item.warehouseCode || '-',
|
|
142
|
-
item.materialCode || '-',
|
|
143
|
-
item.lotNo || '-',
|
|
144
|
-
item.inboundCount != null ? item.inboundCount.toLocaleString() : '-',
|
|
145
|
-
item.outboundCount != null ? item.outboundCount.toLocaleString() : '-',
|
|
146
|
-
item.stockFormCode || '-',
|
|
147
|
-
]);
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
console.log(chalk.bold(' Stock Ledger Detail\n'));
|
|
151
|
-
console.log(table.toString());
|
|
152
|
-
|
|
153
|
-
const totalPages = Math.ceil(data.totalRows / pageSize);
|
|
154
|
-
const currentPage = pageNo + 1;
|
|
155
|
-
console.log(chalk.gray(`\n Page ${currentPage} of ${totalPages} (Total: ${data.totalRows.toLocaleString()})\n`));
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
return ledgerCommand;
|
|
159
|
-
}
|
|
@@ -1,128 +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 { MasterStockQueryParams, MasterStockApiResponse } from '../../../types/stock.js';
|
|
7
|
-
import { Environment } from '../../../types/index.js';
|
|
8
|
-
|
|
9
|
-
export function createStockListCommand(): Command {
|
|
10
|
-
const listCommand = new Command('list');
|
|
11
|
-
listCommand.description('Query warehouse stock inventory (paginated)');
|
|
12
|
-
|
|
13
|
-
listCommand
|
|
14
|
-
.option('--warehouse-code <string>', 'Warehouse code')
|
|
15
|
-
.option('--material-code <string>', 'Material code')
|
|
16
|
-
.option('--material-no <string>', 'Material number')
|
|
17
|
-
.option('--material-name <string>', 'Material name')
|
|
18
|
-
.option('--material-type <string>', 'Material type/spec')
|
|
19
|
-
.option('--lot-no <string>', 'Lot/Batch number')
|
|
20
|
-
.option('--color <string>', 'Color')
|
|
21
|
-
.option('--long-x <number>', 'Length', parseFloat)
|
|
22
|
-
.option('--wide-y <number>', 'Width', parseFloat)
|
|
23
|
-
.option('--high-z <number>', 'Height', parseFloat)
|
|
24
|
-
.option('--source-type <string>', 'Source document type')
|
|
25
|
-
.option('--source-code <string>', 'Source document code')
|
|
26
|
-
.option('--stock-id <string>', 'Stock ID')
|
|
27
|
-
.option('--exclude-zero', 'Exclude zero stock items')
|
|
28
|
-
.option('--start-date <YYYY-MM-DD>', 'Stock date range start')
|
|
29
|
-
.option('--end-date <YYYY-MM-DD>', 'Stock date range end')
|
|
30
|
-
.option('-p, --page <number>', 'Page number (1-based)', '1')
|
|
31
|
-
.option('-s, --size <number>', 'Page size', '20')
|
|
32
|
-
.option('--json', 'Output as JSON')
|
|
33
|
-
.action(async (options) => {
|
|
34
|
-
const context = configManager.getCurrentContext();
|
|
35
|
-
const environment = (options.env as Environment) || context.environment;
|
|
36
|
-
const tenant = (options.tenant as string) || context.tenant;
|
|
37
|
-
|
|
38
|
-
if (!tenant) {
|
|
39
|
-
console.error(chalk.red('\n✗ No tenant configured. Run "barista liberica auth login" first.\n'));
|
|
40
|
-
process.exit(1);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
// Convert 1-based CLI page to 0-based API page
|
|
44
|
-
const pageNo = parseInt(options.page as string, 10) - 1;
|
|
45
|
-
const pageSize = parseInt(options.size as string, 10);
|
|
46
|
-
|
|
47
|
-
const params: MasterStockQueryParams = {
|
|
48
|
-
pageNo,
|
|
49
|
-
pageSize,
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
if (options.warehouseCode) params.warehouseCode = options.warehouseCode;
|
|
53
|
-
if (options.materialCode) params.materialCode = options.materialCode;
|
|
54
|
-
if (options.materialNo) params.materialNo = options.materialNo;
|
|
55
|
-
if (options.materialName) params.materialName = options.materialName;
|
|
56
|
-
if (options.materialType) params.materialType = options.materialType;
|
|
57
|
-
if (options.lotNo) params.lotNo = options.lotNo;
|
|
58
|
-
if (options.color) params.color = options.color;
|
|
59
|
-
if (options.longX !== undefined) params.longX = options.longX;
|
|
60
|
-
if (options.wideY !== undefined) params.wideY = options.wideY;
|
|
61
|
-
if (options.highZ !== undefined) params.highZ = options.highZ;
|
|
62
|
-
if (options.sourceType) params.sourceType = options.sourceType;
|
|
63
|
-
if (options.sourceCode) params.sourceCode = options.sourceCode;
|
|
64
|
-
if (options.stockId) params.stockId = options.stockId;
|
|
65
|
-
if (options.excludeZero) params.excludeZeroStock = true;
|
|
66
|
-
if (options.startDate) params.startDate = options.startDate;
|
|
67
|
-
if (options.endDate) params.endDate = options.endDate;
|
|
68
|
-
|
|
69
|
-
const response: MasterStockApiResponse = await apiClient.listStock(environment, tenant, params);
|
|
70
|
-
|
|
71
|
-
if (!response.success) {
|
|
72
|
-
console.error(chalk.red(`\n✗ Failed: ${response.error?.message}\n`));
|
|
73
|
-
process.exit(1);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
const data = response.data!;
|
|
77
|
-
const items = data.rows || [];
|
|
78
|
-
|
|
79
|
-
if (options.json) {
|
|
80
|
-
console.log(JSON.stringify({ success: true, data }, null, 2));
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
if (items.length === 0) {
|
|
85
|
-
console.log(chalk.yellow('\n No stock records found.\n'));
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
const table = new Table({
|
|
90
|
-
head: [
|
|
91
|
-
chalk.bold('Warehouse'),
|
|
92
|
-
chalk.bold('Material'),
|
|
93
|
-
chalk.bold('Name'),
|
|
94
|
-
chalk.bold('Type'),
|
|
95
|
-
chalk.bold('Color'),
|
|
96
|
-
chalk.bold('Stock'),
|
|
97
|
-
chalk.bold('UOM'),
|
|
98
|
-
chalk.bold('Price'),
|
|
99
|
-
chalk.bold('Amount'),
|
|
100
|
-
],
|
|
101
|
-
colWidths: [12, 14, 20, 12, 8, 10, 6, 10, 12],
|
|
102
|
-
style: { border: [], head: [] },
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
for (const item of items) {
|
|
106
|
-
table.push([
|
|
107
|
-
item.warehouseCode || '-',
|
|
108
|
-
item.materialCode || '-',
|
|
109
|
-
item.materialName || '-',
|
|
110
|
-
item.materialType || '-',
|
|
111
|
-
item.color || '-',
|
|
112
|
-
item.stockCount?.toLocaleString() || '0',
|
|
113
|
-
item.materialUomCode || '-',
|
|
114
|
-
item.unitPrice != null ? `¥${item.unitPrice.toFixed(2)}` : '-',
|
|
115
|
-
item.stockAmount != null ? `¥${item.stockAmount.toLocaleString()}` : '-',
|
|
116
|
-
]);
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
console.log(chalk.bold('\n Stock Inventory List\n'));
|
|
120
|
-
console.log(table.toString());
|
|
121
|
-
|
|
122
|
-
const totalPages = Math.ceil(data.totalRows / pageSize);
|
|
123
|
-
const currentPage = pageNo + 1;
|
|
124
|
-
console.log(chalk.gray(`\n Page ${currentPage} of ${totalPages} (Total: ${data.totalRows.toLocaleString()})\n`));
|
|
125
|
-
});
|
|
126
|
-
|
|
127
|
-
return listCommand;
|
|
128
|
-
}
|
|
@@ -1,120 +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 { CreateSupplierContactRequest } from '../../../types/supplier-contact.js';
|
|
6
|
-
|
|
7
|
-
export function createSupplierContactCreateCommand(): Command {
|
|
8
|
-
const cmd = new Command('create');
|
|
9
|
-
cmd.description('Create a new supplier contact');
|
|
10
|
-
|
|
11
|
-
cmd
|
|
12
|
-
.requiredOption('-s, --supplier-id <string>', 'Supplier ID')
|
|
13
|
-
.requiredOption('-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 (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
|
-
const supplierId = options.supplierId as string;
|
|
33
|
-
const supplierContactName = options.name as string;
|
|
34
|
-
|
|
35
|
-
if (!supplierId || !supplierContactName) {
|
|
36
|
-
if (jsonOutput) {
|
|
37
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'supplier-id and name are required' } }));
|
|
38
|
-
} else {
|
|
39
|
-
console.error(chalk.red('\n✗ supplier-id and name are required\n'));
|
|
40
|
-
}
|
|
41
|
-
process.exit(1);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
const data: CreateSupplierContactRequest = {
|
|
45
|
-
supplierId,
|
|
46
|
-
supplierContactName,
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
if (options.phone) data.supplierContactPhone = options.phone as string;
|
|
50
|
-
if (options.telephone) data.supplierContactTelephone = options.telephone as string;
|
|
51
|
-
if (options.email) data.supplierContactEmail = options.email as string;
|
|
52
|
-
if (options.sex) data.supplierContactSex = options.sex as string;
|
|
53
|
-
if (options.birthday) data.supplierContactBirthday = options.birthday as string;
|
|
54
|
-
if (options.qq) data.supplierContactQq = options.qq as string;
|
|
55
|
-
if (options.wechat) data.supplierContactWechat = options.wechat as string;
|
|
56
|
-
if (options.address) data.supplierContactAddress = options.address as string;
|
|
57
|
-
if (options.default) data.defaultFlag = 'Y';
|
|
58
|
-
else data.defaultFlag = 'N';
|
|
59
|
-
if (options.remark) data.remark = options.remark as string;
|
|
60
|
-
|
|
61
|
-
Object.keys(data).forEach(key => {
|
|
62
|
-
if (data[key as keyof CreateSupplierContactRequest] === undefined) {
|
|
63
|
-
delete data[key as keyof CreateSupplierContactRequest];
|
|
64
|
-
}
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
if (options.dryRun) {
|
|
68
|
-
if (jsonOutput) {
|
|
69
|
-
console.log(JSON.stringify({ success: true, dryRun: true, data }));
|
|
70
|
-
} else {
|
|
71
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual API call will be made\n'));
|
|
72
|
-
console.log(chalk.gray(' This operation will create the following supplier contact:'));
|
|
73
|
-
console.log(` ${chalk.gray('Supplier ID:')} ${supplierId}`);
|
|
74
|
-
console.log(` ${chalk.gray('Name:')} ${supplierContactName}`);
|
|
75
|
-
if (options.phone) console.log(` ${chalk.gray('Phone:')} ${options.phone}`);
|
|
76
|
-
if (options.email) console.log(` ${chalk.gray('Email:')} ${options.email}`);
|
|
77
|
-
console.log();
|
|
78
|
-
}
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
try {
|
|
83
|
-
const response = await apiClient.createSupplierContact(environment, tenant, data);
|
|
84
|
-
|
|
85
|
-
if (response.success) {
|
|
86
|
-
if (jsonOutput) {
|
|
87
|
-
console.log(JSON.stringify({ success: true, data: response.data }));
|
|
88
|
-
} else {
|
|
89
|
-
console.log(chalk.green('\n✓ Supplier contact created successfully\n'));
|
|
90
|
-
console.log(` ${chalk.gray('Supplier ID:')} ${chalk.green(supplierId)}`);
|
|
91
|
-
console.log(` ${chalk.gray('Name:')} ${chalk.green(supplierContactName)}`);
|
|
92
|
-
console.log();
|
|
93
|
-
}
|
|
94
|
-
} else {
|
|
95
|
-
const errorMsg = response.error?.message || 'Failed to create supplier contact';
|
|
96
|
-
const errorCode = response.error?.code || 'CREATE_ERROR';
|
|
97
|
-
if (jsonOutput) {
|
|
98
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
99
|
-
} else {
|
|
100
|
-
console.error(chalk.red(`\n✗ Failed to create supplier contact: ${errorMsg}`));
|
|
101
|
-
if (response.error?.code) {
|
|
102
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
103
|
-
}
|
|
104
|
-
console.error();
|
|
105
|
-
}
|
|
106
|
-
process.exit(1);
|
|
107
|
-
}
|
|
108
|
-
} catch (error) {
|
|
109
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
110
|
-
if (jsonOutput) {
|
|
111
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
112
|
-
} else {
|
|
113
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
114
|
-
}
|
|
115
|
-
process.exit(1);
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
return cmd;
|
|
120
|
-
}
|
|
@@ -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
|
-
|
|
6
|
-
export function createSupplierContactDeleteCommand(): Command {
|
|
7
|
-
const cmd = new Command('delete');
|
|
8
|
-
cmd.description('Delete a supplier contact (requires --force to actually delete)');
|
|
9
|
-
|
|
10
|
-
cmd
|
|
11
|
-
.arguments('<contact-id>')
|
|
12
|
-
.option('--force', 'Skip confirmation and actually delete')
|
|
13
|
-
.option('--dry-run', 'Preview the operation (default)')
|
|
14
|
-
.option('--json', 'Output as JSON')
|
|
15
|
-
.action(async (contactId: string, options: Record<string, unknown>) => {
|
|
16
|
-
const context = configManager.getCurrentContext();
|
|
17
|
-
const environment = context.environment;
|
|
18
|
-
const tenant = context.tenant;
|
|
19
|
-
const jsonOutput = options.json === true;
|
|
20
|
-
|
|
21
|
-
if (!contactId || contactId.trim() === '') {
|
|
22
|
-
if (jsonOutput) {
|
|
23
|
-
console.log(JSON.stringify({ success: false, error: { code: 'VALIDATION_ERROR', message: 'contact-id is required' } }));
|
|
24
|
-
} else {
|
|
25
|
-
console.error(chalk.red('\n✗ Contact ID is required\n'));
|
|
26
|
-
}
|
|
27
|
-
process.exit(1);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
const isDryRun = !options.force;
|
|
31
|
-
|
|
32
|
-
if (isDryRun) {
|
|
33
|
-
if (jsonOutput) {
|
|
34
|
-
console.log(JSON.stringify({
|
|
35
|
-
success: true,
|
|
36
|
-
dryRun: true,
|
|
37
|
-
message: 'Dry-Run Mode: No actual API call will be made',
|
|
38
|
-
data: { supplierContactId: contactId }
|
|
39
|
-
}));
|
|
40
|
-
} else {
|
|
41
|
-
console.log(chalk.cyan('\n🔍 Dry-Run Mode: No actual API call will be made\n'));
|
|
42
|
-
console.log(chalk.gray(' This operation will delete the following supplier contact:'));
|
|
43
|
-
console.log(` ${chalk.gray('Contact ID:')} ${contactId}`);
|
|
44
|
-
console.log();
|
|
45
|
-
console.log(chalk.yellow(' ⚠️ Add --force option to confirm deletion'));
|
|
46
|
-
console.log();
|
|
47
|
-
}
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
try {
|
|
52
|
-
const response = await apiClient.deleteSupplierContact(environment, tenant, contactId);
|
|
53
|
-
|
|
54
|
-
if (response.success) {
|
|
55
|
-
if (jsonOutput) {
|
|
56
|
-
console.log(JSON.stringify({ success: true, data: { supplierContactId: contactId } }));
|
|
57
|
-
} else {
|
|
58
|
-
console.log(chalk.green('\n✓ Supplier contact deleted successfully\n'));
|
|
59
|
-
console.log(` ${chalk.gray('Contact ID:')} ${chalk.green(contactId)}`);
|
|
60
|
-
console.log();
|
|
61
|
-
}
|
|
62
|
-
} else {
|
|
63
|
-
const errorMsg = response.error?.message || 'Failed to delete supplier contact';
|
|
64
|
-
const errorCode = response.error?.code || 'DELETE_ERROR';
|
|
65
|
-
if (jsonOutput) {
|
|
66
|
-
console.log(JSON.stringify({ success: false, error: { code: errorCode, message: errorMsg } }));
|
|
67
|
-
} else {
|
|
68
|
-
console.error(chalk.red(`\n✗ Failed to delete supplier contact: ${errorMsg}`));
|
|
69
|
-
if (response.error?.code) {
|
|
70
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
71
|
-
}
|
|
72
|
-
console.error();
|
|
73
|
-
}
|
|
74
|
-
process.exit(1);
|
|
75
|
-
}
|
|
76
|
-
} catch (error) {
|
|
77
|
-
const errMsg = error instanceof Error ? error.message : 'Unknown error';
|
|
78
|
-
if (jsonOutput) {
|
|
79
|
-
console.log(JSON.stringify({ success: false, error: { code: 'ERROR', message: errMsg } }));
|
|
80
|
-
} else {
|
|
81
|
-
console.error(chalk.red(`\n✗ Error: ${errMsg}\n`));
|
|
82
|
-
}
|
|
83
|
-
process.exit(1);
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
return cmd;
|
|
88
|
-
}
|
|
@@ -1,94 +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 { SupplierContact } from '../../../types/supplier-contact.js';
|
|
6
|
-
import { Environment } from '../../../types/index.js';
|
|
7
|
-
|
|
8
|
-
export function createSupplierContactGetCommand(): Command {
|
|
9
|
-
const getCommand = new Command('get');
|
|
10
|
-
getCommand.description('Get supplier contact details by ID');
|
|
11
|
-
getCommand.arguments('<contact-id>');
|
|
12
|
-
getCommand.option('--json', 'Output as JSON');
|
|
13
|
-
|
|
14
|
-
getCommand.action(async (contactId: 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 (!contactId || contactId.trim() === '') {
|
|
20
|
-
console.error(chalk.red('\n✗ Contact ID is required\n'));
|
|
21
|
-
process.exit(1);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
try {
|
|
25
|
-
const response = await apiClient.getSupplierContact(environment, tenant, contactId);
|
|
26
|
-
|
|
27
|
-
if (!response.success) {
|
|
28
|
-
const errorCode = response.error?.code || 'UNKNOWN_ERROR';
|
|
29
|
-
const errorMessage = response.error?.message || 'Unknown error';
|
|
30
|
-
|
|
31
|
-
if (errorCode === '01001XXX001' || errorMessage.includes('不存在')) {
|
|
32
|
-
console.error(chalk.red(`\n✗ Supplier contact not found: ${contactId}\n`));
|
|
33
|
-
} else {
|
|
34
|
-
console.error(chalk.red(`\n✗ Error: ${errorMessage} (${errorCode})\n`));
|
|
35
|
-
}
|
|
36
|
-
process.exit(1);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const contact = response.data as SupplierContact | null;
|
|
40
|
-
|
|
41
|
-
if (!contact) {
|
|
42
|
-
console.error(chalk.red('\n✗ Supplier contact not found\n'));
|
|
43
|
-
process.exit(1);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
if (options.json) {
|
|
47
|
-
console.log(JSON.stringify({
|
|
48
|
-
success: true,
|
|
49
|
-
data: contact,
|
|
50
|
-
}, null, 2));
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
console.log(chalk.bold('\n👤 Supplier Contact Details\n'));
|
|
55
|
-
console.log(` ${chalk.gray('Contact ID:')} ${contact.supplierContactId}`);
|
|
56
|
-
console.log(` ${chalk.gray('Supplier ID:')} ${contact.supplierId}`);
|
|
57
|
-
console.log(` ${chalk.gray('Name:')} ${contact.supplierContactName || '-'}`);
|
|
58
|
-
if (contact.supplierContactPhone) {
|
|
59
|
-
console.log(` ${chalk.gray('Phone:')} ${contact.supplierContactPhone}`);
|
|
60
|
-
}
|
|
61
|
-
if (contact.supplierContactTelephone) {
|
|
62
|
-
console.log(` ${chalk.gray('Telephone:')} ${contact.supplierContactTelephone}`);
|
|
63
|
-
}
|
|
64
|
-
if (contact.supplierContactEmail) {
|
|
65
|
-
console.log(` ${chalk.gray('Email:')} ${contact.supplierContactEmail}`);
|
|
66
|
-
}
|
|
67
|
-
if (contact.supplierContactSex) {
|
|
68
|
-
console.log(` ${chalk.gray('Sex:')} ${contact.supplierContactSex}`);
|
|
69
|
-
}
|
|
70
|
-
if (contact.supplierContactBirthday) {
|
|
71
|
-
console.log(` ${chalk.gray('Birthday:')} ${contact.supplierContactBirthday}`);
|
|
72
|
-
}
|
|
73
|
-
if (contact.supplierContactQq) {
|
|
74
|
-
console.log(` ${chalk.gray('QQ:')} ${contact.supplierContactQq}`);
|
|
75
|
-
}
|
|
76
|
-
if (contact.supplierContactWechat) {
|
|
77
|
-
console.log(` ${chalk.gray('WeChat:')} ${contact.supplierContactWechat}`);
|
|
78
|
-
}
|
|
79
|
-
if (contact.supplierContactAddress) {
|
|
80
|
-
console.log(` ${chalk.gray('Address:')} ${contact.supplierContactAddress}`);
|
|
81
|
-
}
|
|
82
|
-
console.log(` ${chalk.gray('Default:')} ${contact.defaultFlag === 'Y' ? chalk.green('Yes') : 'No'}`);
|
|
83
|
-
if (contact.remark) {
|
|
84
|
-
console.log(` ${chalk.gray('Remark:')} ${contact.remark}`);
|
|
85
|
-
}
|
|
86
|
-
console.log();
|
|
87
|
-
} catch (error) {
|
|
88
|
-
console.error(chalk.red(`\n✗ Unexpected error: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
89
|
-
process.exit(1);
|
|
90
|
-
}
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
return getCommand;
|
|
94
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createSupplierContactListCommand } from './list.js';
|
|
3
|
-
import { createSupplierContactGetCommand } from './get.js';
|
|
4
|
-
import { createSupplierContactCreateCommand } from './create.js';
|
|
5
|
-
import { createSupplierContactUpdateCommand } from './update.js';
|
|
6
|
-
import { createSupplierContactDeleteCommand } from './delete.js';
|
|
7
|
-
|
|
8
|
-
export function createSupplierContactsCommand(): Command {
|
|
9
|
-
const supplierContactsCommand = new Command('supplier-contacts');
|
|
10
|
-
supplierContactsCommand.description('Manage supplier contacts');
|
|
11
|
-
|
|
12
|
-
supplierContactsCommand.addCommand(createSupplierContactListCommand());
|
|
13
|
-
supplierContactsCommand.addCommand(createSupplierContactGetCommand());
|
|
14
|
-
supplierContactsCommand.addCommand(createSupplierContactCreateCommand());
|
|
15
|
-
supplierContactsCommand.addCommand(createSupplierContactUpdateCommand());
|
|
16
|
-
supplierContactsCommand.addCommand(createSupplierContactDeleteCommand());
|
|
17
|
-
|
|
18
|
-
return supplierContactsCommand;
|
|
19
|
-
}
|