@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,27 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createOperationsListCommand } from './list.js';
|
|
3
|
-
import { createOperationGetCommand } from './get.js';
|
|
4
|
-
import { createOperationCreateCommand } from './create.js';
|
|
5
|
-
import { createOperationsUpdateCommand } from './update.js';
|
|
6
|
-
import { createOperationsDeleteCommand } from './delete.js';
|
|
7
|
-
import { createOperationsCopyCommand } from './copy.js';
|
|
8
|
-
import { createBatchDeleteCommand } from './batch-delete.js';
|
|
9
|
-
import { createOperationActiveCommand } from './active.js';
|
|
10
|
-
import { createOperationDeactiveCommand } from './deactive.js';
|
|
11
|
-
|
|
12
|
-
export function createOperationsCommand(): Command {
|
|
13
|
-
const operationsCommand = new Command('operations');
|
|
14
|
-
operationsCommand.description('Manage operations');
|
|
15
|
-
|
|
16
|
-
operationsCommand.addCommand(createOperationsListCommand());
|
|
17
|
-
operationsCommand.addCommand(createOperationGetCommand());
|
|
18
|
-
operationsCommand.addCommand(createOperationCreateCommand());
|
|
19
|
-
operationsCommand.addCommand(createOperationsUpdateCommand());
|
|
20
|
-
operationsCommand.addCommand(createOperationsDeleteCommand());
|
|
21
|
-
operationsCommand.addCommand(createOperationsCopyCommand());
|
|
22
|
-
operationsCommand.addCommand(createBatchDeleteCommand());
|
|
23
|
-
operationsCommand.addCommand(createOperationActiveCommand());
|
|
24
|
-
operationsCommand.addCommand(createOperationDeactiveCommand());
|
|
25
|
-
|
|
26
|
-
return operationsCommand;
|
|
27
|
-
}
|
|
@@ -1,180 +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 { OperationListResponse, OperationType, StatusFlag } from '../../../types/operation.js';
|
|
7
|
-
import { Environment } from '../../../types/index.js';
|
|
8
|
-
|
|
9
|
-
const OPERATION_TYPE_MAP: Record<OperationType, string> = {
|
|
10
|
-
EQUIPMENT: '机器',
|
|
11
|
-
HUMAN: '手工',
|
|
12
|
-
PACKAGE: '包装',
|
|
13
|
-
QUALITY_TESTING: '质检',
|
|
14
|
-
OTHER: '其它',
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
const OPERATION_TYPE_REVERSE: Record<string, OperationType> = {
|
|
18
|
-
EQUIPMENT: 'EQUIPMENT',
|
|
19
|
-
equipment: 'EQUIPMENT',
|
|
20
|
-
'机器': 'EQUIPMENT',
|
|
21
|
-
HUMAN: 'HUMAN',
|
|
22
|
-
human: 'HUMAN',
|
|
23
|
-
'手工': 'HUMAN',
|
|
24
|
-
PACKAGE: 'PACKAGE',
|
|
25
|
-
package: 'PACKAGE',
|
|
26
|
-
'包装': 'PACKAGE',
|
|
27
|
-
QUALITY_TESTING: 'QUALITY_TESTING',
|
|
28
|
-
quality_testing: 'QUALITY_TESTING',
|
|
29
|
-
qualitytesting: 'QUALITY_TESTING',
|
|
30
|
-
'质检': 'QUALITY_TESTING',
|
|
31
|
-
OTHER: 'OTHER',
|
|
32
|
-
other: 'OTHER',
|
|
33
|
-
'其它': 'OTHER',
|
|
34
|
-
'其他': 'OTHER',
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
function normalizeOperationType(input: string | undefined): OperationType | undefined {
|
|
38
|
-
if (!input) return undefined;
|
|
39
|
-
const normalized = input.trim().toUpperCase();
|
|
40
|
-
return OPERATION_TYPE_REVERSE[normalized] || OPERATION_TYPE_REVERSE[input];
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
function getOperationTypeDisplay(type: OperationType): string {
|
|
44
|
-
return OPERATION_TYPE_MAP[type] || type;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
export function createOperationsListCommand(): Command {
|
|
48
|
-
const listCommand = new Command('list');
|
|
49
|
-
listCommand.description('List operations with pagination');
|
|
50
|
-
|
|
51
|
-
listCommand
|
|
52
|
-
.option('-p, --page <number>', 'Page number', '1')
|
|
53
|
-
.option('-s, --size <number>', 'Page size', '20')
|
|
54
|
-
.option('--status <number>', 'Status filter (1=enable, 2=disable)')
|
|
55
|
-
.option('--keyword <string>', 'Filter by operation name or code (partial match)')
|
|
56
|
-
.option('--type <string>', 'Filter by operation type (EQUIPMENT/HUMAN/PACKAGE/QUALITY_TESTING/OTHER or Chinese: 机器/手工/包装/质检/其它)')
|
|
57
|
-
.option('--json', 'Output as JSON')
|
|
58
|
-
.action(async (options) => {
|
|
59
|
-
const context = configManager.getCurrentContext();
|
|
60
|
-
const environment = (options.env as Environment) || context.environment;
|
|
61
|
-
const tenant = options.tenant || context.tenant;
|
|
62
|
-
|
|
63
|
-
const page = parseInt(options.page as string, 10) - 1;
|
|
64
|
-
const size = parseInt(options.size as string, 10);
|
|
65
|
-
|
|
66
|
-
const params: {
|
|
67
|
-
pageNo: number;
|
|
68
|
-
pageSize: number;
|
|
69
|
-
status?: StatusFlag;
|
|
70
|
-
operationCode?: string;
|
|
71
|
-
operationName?: string;
|
|
72
|
-
operationType?: OperationType;
|
|
73
|
-
} = { pageNo: page, pageSize: size };
|
|
74
|
-
|
|
75
|
-
if (options.status !== undefined) {
|
|
76
|
-
const statusNum = parseInt(options.status as string, 10);
|
|
77
|
-
if (statusNum === 1 || statusNum === 2) {
|
|
78
|
-
params.status = statusNum as StatusFlag;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
if (options.keyword !== undefined) {
|
|
83
|
-
params.operationCode = options.keyword as string;
|
|
84
|
-
params.operationName = options.keyword as string;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
if (options.type !== undefined) {
|
|
88
|
-
const normalizedType = normalizeOperationType(options.type as string);
|
|
89
|
-
if (normalizedType) {
|
|
90
|
-
params.operationType = normalizedType;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
const response = await apiClient.listOperations(environment, tenant, params);
|
|
95
|
-
|
|
96
|
-
if (!response.success) {
|
|
97
|
-
console.error(chalk.red(`\n✗ Failed to list operations: ${response.error?.message || 'Unknown error'}`));
|
|
98
|
-
if (response.error?.code) {
|
|
99
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
100
|
-
}
|
|
101
|
-
console.error();
|
|
102
|
-
process.exit(1);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
const data = response.data as OperationListResponse | null;
|
|
106
|
-
|
|
107
|
-
if (!data) {
|
|
108
|
-
if (options.json) {
|
|
109
|
-
console.log(JSON.stringify({ success: true, data: { items: [], pagination: { pageNo: 0, pageSize: 20, totalRows: 0 } } }, null, 2));
|
|
110
|
-
} else {
|
|
111
|
-
console.log(chalk.bold('\n📋 Operation List\n'));
|
|
112
|
-
console.log(chalk.gray(' No operations found\n'));
|
|
113
|
-
}
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
if (options.json) {
|
|
118
|
-
console.log(
|
|
119
|
-
JSON.stringify(
|
|
120
|
-
{
|
|
121
|
-
success: true,
|
|
122
|
-
data: {
|
|
123
|
-
items: data.rows || [],
|
|
124
|
-
pagination: {
|
|
125
|
-
pageNo: data.pageNo,
|
|
126
|
-
pageSize: data.pageSize,
|
|
127
|
-
totalRows: data.totalRows,
|
|
128
|
-
},
|
|
129
|
-
},
|
|
130
|
-
},
|
|
131
|
-
null,
|
|
132
|
-
2
|
|
133
|
-
)
|
|
134
|
-
);
|
|
135
|
-
return;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
const records = data.rows || [];
|
|
139
|
-
|
|
140
|
-
if (records.length === 0) {
|
|
141
|
-
console.log(chalk.bold('\n📋 Operation List\n'));
|
|
142
|
-
console.log(chalk.gray(' No operations found\n'));
|
|
143
|
-
return;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
console.log(chalk.bold('\n📋 Operation List\n'));
|
|
147
|
-
|
|
148
|
-
const table = new Table({
|
|
149
|
-
head: [chalk.bold('ID'), chalk.bold('Code'), chalk.bold('Name'), chalk.bold('Type'), chalk.bold('Work Center'), chalk.bold('Status')],
|
|
150
|
-
colWidths: [12, 14, 22, 12, 18, 10],
|
|
151
|
-
style: {
|
|
152
|
-
head: [],
|
|
153
|
-
border: [],
|
|
154
|
-
},
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
for (const op of records) {
|
|
158
|
-
const statusText = op.statusFlag === 1 ? chalk.green('Enable') : chalk.red('Disable');
|
|
159
|
-
table.push([
|
|
160
|
-
op.operationId,
|
|
161
|
-
op.operationCode || '-',
|
|
162
|
-
op.operationName || '-',
|
|
163
|
-
getOperationTypeDisplay(op.operationType),
|
|
164
|
-
op.workCenterCode || '-',
|
|
165
|
-
statusText,
|
|
166
|
-
]);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
console.log(table.toString());
|
|
170
|
-
console.log();
|
|
171
|
-
console.log(
|
|
172
|
-
chalk.gray(
|
|
173
|
-
` Total: ${data.totalRows} | Page: ${data.pageNo + 1} / ${Math.ceil(data.totalRows / data.pageSize) || 1} | Size: ${data.pageSize}`
|
|
174
|
-
)
|
|
175
|
-
);
|
|
176
|
-
console.log();
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
return listCommand;
|
|
180
|
-
}
|
|
@@ -1,218 +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 { Operation, OperationUpdateRequest, StatusFlag } from '../../../types/operation.js';
|
|
6
|
-
import { Environment } from '../../../types/index.js';
|
|
7
|
-
|
|
8
|
-
// Dictionary mapping for operation type display
|
|
9
|
-
const OPERATION_TYPE_MAP: Record<string, string> = {
|
|
10
|
-
EQUIPMENT: '机器',
|
|
11
|
-
HUMAN: '手工',
|
|
12
|
-
PACKAGE: '包装',
|
|
13
|
-
QUALITY_TESTING: '质检',
|
|
14
|
-
OTHER: '其它',
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
// Reverse mapping for parsing CLI input
|
|
18
|
-
const OPERATION_TYPE_REVERSE: Record<string, string> = {
|
|
19
|
-
EQUIPMENT: 'EQUIPMENT',
|
|
20
|
-
equipment: 'EQUIPMENT',
|
|
21
|
-
'机器': 'EQUIPMENT',
|
|
22
|
-
HUMAN: 'HUMAN',
|
|
23
|
-
human: 'HUMAN',
|
|
24
|
-
'手工': 'HUMAN',
|
|
25
|
-
PACKAGE: 'PACKAGE',
|
|
26
|
-
package: 'PACKAGE',
|
|
27
|
-
'包装': 'PACKAGE',
|
|
28
|
-
QUALITY_TESTING: 'QUALITY_TESTING',
|
|
29
|
-
quality_testing: 'QUALITY_TESTING',
|
|
30
|
-
qualitytesting: 'QUALITY_TESTING',
|
|
31
|
-
'质检': 'QUALITY_TESTING',
|
|
32
|
-
OTHER: 'OTHER',
|
|
33
|
-
other: 'OTHER',
|
|
34
|
-
'其它': 'OTHER',
|
|
35
|
-
'其他': 'OTHER',
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
function normalizeOperationType(input: string | undefined): string | undefined {
|
|
39
|
-
if (!input) return undefined;
|
|
40
|
-
const normalized = input.trim().toUpperCase();
|
|
41
|
-
return OPERATION_TYPE_REVERSE[normalized] || OPERATION_TYPE_REVERSE[input];
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
function getOperationTypeDisplay(type: string): string {
|
|
45
|
-
return OPERATION_TYPE_MAP[type] || type;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
export function createOperationsUpdateCommand(): Command {
|
|
49
|
-
const updateCommand = new Command('update');
|
|
50
|
-
updateCommand
|
|
51
|
-
.description('Update operation information')
|
|
52
|
-
.option('--id <id>', 'Operation ID')
|
|
53
|
-
.option('-n, --name <name>', 'Operation name')
|
|
54
|
-
.option('-t, --type <type>', 'Operation type (EQUIPMENT/HUMAN/PACKAGE/QUALITY_TESTING/OTHER or Chinese: 机器/手工/包装/质检/其它)')
|
|
55
|
-
.option('-w, --work-center <workCenter>', 'Work center code')
|
|
56
|
-
.option('--mould-code <mouldCode>', 'Mould code')
|
|
57
|
-
.option('--mould-type <mouldType>', 'Mould type')
|
|
58
|
-
.option('--equipment-type <equipmentType>', 'Equipment type')
|
|
59
|
-
.option('--lead-time <leadTime>', 'Lead time (hours)', (val) => parseInt(val, 10))
|
|
60
|
-
.option('--remark <remark>', 'Remarks')
|
|
61
|
-
.option('--status <status>', 'Status (1=enable, 2=disable)', (val) => parseInt(val, 10))
|
|
62
|
-
.option('--dry-run', 'Preview changes without making API call')
|
|
63
|
-
.option('--json', 'Output result as JSON')
|
|
64
|
-
.action(async (options: Record<string, unknown>) => {
|
|
65
|
-
const operationId = options.id as string | undefined;
|
|
66
|
-
if (!operationId) {
|
|
67
|
-
console.error(chalk.red('\n✗ --id is required\n'));
|
|
68
|
-
process.exit(1);
|
|
69
|
-
}
|
|
70
|
-
const operationIdStr: string = operationId;
|
|
71
|
-
const context = configManager.getCurrentContext();
|
|
72
|
-
const environment: Environment = (options.env as Environment) || context.environment;
|
|
73
|
-
const tenant: string = (options.tenant as string) || context.tenant;
|
|
74
|
-
|
|
75
|
-
const fields: Partial<OperationUpdateRequest> = {};
|
|
76
|
-
if (options.name) fields.operationName = options.name as string;
|
|
77
|
-
if (options.type) {
|
|
78
|
-
const normalizedType = normalizeOperationType(options.type as string);
|
|
79
|
-
if (normalizedType) {
|
|
80
|
-
fields.operationType = normalizedType as 'EQUIPMENT' | 'HUMAN' | 'PACKAGE' | 'QUALITY_TESTING' | 'OTHER';
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
if (options.workCenter) fields.workCenterCode = options.workCenter as string;
|
|
84
|
-
if (options.mouldCode) fields.mouldCode = options.mouldCode as string;
|
|
85
|
-
if (options.mouldType) fields.mouldType = options.mouldType as string;
|
|
86
|
-
if (options.equipmentType) fields.equipmentType = options.equipmentType as string;
|
|
87
|
-
if (options.leadTime) fields.leadTime = options.leadTime as number;
|
|
88
|
-
if (options.remark) fields.remark = options.remark as string;
|
|
89
|
-
if (options.status) {
|
|
90
|
-
const statusVal = options.status as number;
|
|
91
|
-
if (statusVal === 1 || statusVal === 2) {
|
|
92
|
-
fields.statusFlag = statusVal as StatusFlag;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
const providedFields = Object.keys(fields).filter(
|
|
97
|
-
(k) => fields[k as keyof OperationUpdateRequest] !== undefined
|
|
98
|
-
);
|
|
99
|
-
|
|
100
|
-
if (providedFields.length === 0) {
|
|
101
|
-
console.error(
|
|
102
|
-
chalk.red('\n✗ No fields to update. Provide at least one of: --name, --type, --work-center, --mould-code, --mould-type, --equipment-type, --lead-time, --remark, --status\n')
|
|
103
|
-
);
|
|
104
|
-
process.exit(1);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Validate lead time
|
|
108
|
-
if (options.leadTime && (isNaN(options.leadTime as number) || (options.leadTime as number) < 0)) {
|
|
109
|
-
console.error(chalk.red('\n✗ Invalid lead time. Must be a non-negative number\n'));
|
|
110
|
-
process.exit(1);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
// Validate status
|
|
114
|
-
if (options.status) {
|
|
115
|
-
const statusVal = options.status as number;
|
|
116
|
-
if (statusVal !== 1 && statusVal !== 2) {
|
|
117
|
-
console.error(chalk.red('\n✗ Invalid status. Use 1 (enable) or 2 (disable)\n'));
|
|
118
|
-
process.exit(1);
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
if (options.dryRun) {
|
|
123
|
-
console.log(chalk.bold(`\n📋 Update Operation — Dry Run (${environment})\n`));
|
|
124
|
-
console.log(chalk.gray(` Operation ID: ${operationId}`));
|
|
125
|
-
console.log(chalk.gray('\n Changes to be applied:'));
|
|
126
|
-
for (const field of providedFields) {
|
|
127
|
-
const label = field.replace(/([A-Z])/g, (m) => ` ${m.toLowerCase()}`).trim();
|
|
128
|
-
if (field === 'operationType') {
|
|
129
|
-
const displayType = getOperationTypeDisplay(fields[field as keyof OperationUpdateRequest] as string);
|
|
130
|
-
console.log(chalk.cyan(` ${label}: "${displayType}"`));
|
|
131
|
-
} else {
|
|
132
|
-
console.log(chalk.cyan(` ${label}: "${fields[field as keyof OperationUpdateRequest]}"`));
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
console.log();
|
|
136
|
-
return;
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
let currentOperation: Operation | undefined;
|
|
140
|
-
try {
|
|
141
|
-
const operationResponse = await apiClient.getOperationDetail(environment, tenant, operationIdStr);
|
|
142
|
-
if (!operationResponse.success || !operationResponse.data || Array.isArray(operationResponse.data)) {
|
|
143
|
-
console.error(chalk.red(`\n✗ Operation not found: ${operationIdStr}`));
|
|
144
|
-
if (operationResponse.error?.message) {
|
|
145
|
-
console.error(chalk.gray(` ${operationResponse.error.message}`));
|
|
146
|
-
}
|
|
147
|
-
if (operationResponse.error?.code) {
|
|
148
|
-
console.error(chalk.gray(` Error code: ${operationResponse.error.code}`));
|
|
149
|
-
}
|
|
150
|
-
console.error();
|
|
151
|
-
process.exit(1);
|
|
152
|
-
}
|
|
153
|
-
currentOperation = operationResponse.data as Operation;
|
|
154
|
-
} catch (error) {
|
|
155
|
-
console.error(chalk.red(`\n✗ Failed to fetch operation: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
156
|
-
process.exit(1);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
console.log(chalk.bold(`\n📋 Update Operation (${environment})\n`));
|
|
160
|
-
console.log(chalk.gray(` Operation ID: ${operationId}`));
|
|
161
|
-
console.log(chalk.gray(` Current Name: ${currentOperation.operationName}`));
|
|
162
|
-
console.log(chalk.gray('\n Changes:'));
|
|
163
|
-
for (const field of providedFields) {
|
|
164
|
-
const label = field.replace(/([A-Z])/g, (m) => ` ${m.toLowerCase()}`).trim();
|
|
165
|
-
let currentVal = (currentOperation as unknown as Record<string, unknown>)[field] ?? '(not set)';
|
|
166
|
-
let newVal = fields[field as keyof OperationUpdateRequest];
|
|
167
|
-
|
|
168
|
-
if (field === 'operationType') {
|
|
169
|
-
currentVal = getOperationTypeDisplay(currentVal as string);
|
|
170
|
-
newVal = getOperationTypeDisplay(newVal as string) as typeof newVal;
|
|
171
|
-
}
|
|
172
|
-
if (field === 'statusFlag') {
|
|
173
|
-
currentVal = currentVal === 1 ? 'Enable' : 'Disable';
|
|
174
|
-
newVal = newVal === 1 ? 'Enable' : 'Disable';
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
console.log(chalk.cyan(` ${label}: "${currentVal}" → "${newVal}"`));
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
const updateData: OperationUpdateRequest = { operationId: operationIdStr, ...fields };
|
|
181
|
-
try {
|
|
182
|
-
const response = await apiClient.updateOperation(environment, tenant, updateData);
|
|
183
|
-
|
|
184
|
-
if (response.success) {
|
|
185
|
-
if (options.json) {
|
|
186
|
-
console.log(JSON.stringify({ success: true, data: response.data }, null, 2));
|
|
187
|
-
} else {
|
|
188
|
-
console.log(chalk.green('\n✓ Operation updated successfully\n'));
|
|
189
|
-
}
|
|
190
|
-
} else {
|
|
191
|
-
if (options.json) {
|
|
192
|
-
console.log(JSON.stringify({ success: false, error: response.error }, null, 2));
|
|
193
|
-
} else {
|
|
194
|
-
console.error(chalk.red(`\n✗ Update failed: ${response.error?.message || 'Unknown error'}`));
|
|
195
|
-
if (response.error?.code) {
|
|
196
|
-
console.error(chalk.gray(` Error code: ${response.error.code}`));
|
|
197
|
-
}
|
|
198
|
-
console.error();
|
|
199
|
-
}
|
|
200
|
-
process.exit(1);
|
|
201
|
-
}
|
|
202
|
-
} catch (error) {
|
|
203
|
-
if (options.json) {
|
|
204
|
-
console.log(
|
|
205
|
-
JSON.stringify({
|
|
206
|
-
success: false,
|
|
207
|
-
error: { message: error instanceof Error ? error.message : 'Unknown error' },
|
|
208
|
-
})
|
|
209
|
-
);
|
|
210
|
-
} else {
|
|
211
|
-
console.error(chalk.red(`\n✗ Error: ${error instanceof Error ? error.message : 'Unknown error'}\n`));
|
|
212
|
-
}
|
|
213
|
-
process.exit(1);
|
|
214
|
-
}
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
return updateCommand;
|
|
218
|
-
}
|
|
@@ -1,34 +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
|
-
|
|
7
|
-
export function createOrgsCommand(): Command {
|
|
8
|
-
const orgsCommand = new Command('orgs');
|
|
9
|
-
orgsCommand.description('List organizations');
|
|
10
|
-
|
|
11
|
-
orgsCommand
|
|
12
|
-
.command('list')
|
|
13
|
-
.description('List all organizations')
|
|
14
|
-
.option('--json', 'Output as JSON')
|
|
15
|
-
.action(async (options) => {
|
|
16
|
-
const context = configManager.getCurrentContext();
|
|
17
|
-
const environment = (options.env as Environment) || context.environment;
|
|
18
|
-
const tenant = options.tenant || context.tenant;
|
|
19
|
-
|
|
20
|
-
const response = await apiClient.getOrgListName(environment, tenant);
|
|
21
|
-
|
|
22
|
-
if (!response.success) {
|
|
23
|
-
console.error(chalk.red(`\n✗ Failed: ${response.error?.message}\n`));
|
|
24
|
-
process.exit(1);
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const orgs = response.data || [];
|
|
28
|
-
|
|
29
|
-
// Always show full IDs
|
|
30
|
-
console.log(JSON.stringify({ success: true, data: orgs }, null, 2));
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
return orgsCommand;
|
|
34
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { configManager } from '../../../core/config/manager.js';
|
|
3
|
-
import { apiClient } from '../../../core/api/client.js';
|
|
4
|
-
import { Environment } from '../../../types/index.js';
|
|
5
|
-
|
|
6
|
-
export function createPositionsCommand(): Command {
|
|
7
|
-
const positionsCommand = new Command('positions');
|
|
8
|
-
positionsCommand.description('List positions');
|
|
9
|
-
|
|
10
|
-
positionsCommand
|
|
11
|
-
.command('list')
|
|
12
|
-
.description('List all positions')
|
|
13
|
-
.action(async (options) => {
|
|
14
|
-
const context = configManager.getCurrentContext();
|
|
15
|
-
const environment = (options.env as Environment) || context.environment;
|
|
16
|
-
const tenant = options.tenant || context.tenant;
|
|
17
|
-
|
|
18
|
-
const response = await apiClient.listPositions(environment, tenant);
|
|
19
|
-
|
|
20
|
-
if (!response.success) {
|
|
21
|
-
console.error(`\n✗ Failed: ${response.error?.message}\n`);
|
|
22
|
-
process.exit(1);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const positions = response.data || [];
|
|
26
|
-
console.log(JSON.stringify({ success: true, data: positions }, null, 2));
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
return positionsCommand;
|
|
30
|
-
}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import chalk from 'chalk';
|
|
3
|
-
import Table from 'cli-table3';
|
|
4
|
-
import { apiClient } from '../../../core/api/client.js';
|
|
5
|
-
import { Environment } from '../../../types/index.js';
|
|
6
|
-
import { configManager } from '../../../core/config/manager.js';
|
|
7
|
-
|
|
8
|
-
export function createRolesCommand(): Command {
|
|
9
|
-
const rolesCommand = new Command('roles');
|
|
10
|
-
rolesCommand.description('List roles');
|
|
11
|
-
|
|
12
|
-
rolesCommand
|
|
13
|
-
.command('list')
|
|
14
|
-
.description('List all available roles')
|
|
15
|
-
.option('--json', 'Output as JSON')
|
|
16
|
-
.action(async (options) => {
|
|
17
|
-
const context = configManager.getCurrentContext();
|
|
18
|
-
const environment = (options.env as Environment) || context.environment;
|
|
19
|
-
const tenant = options.tenant || context.tenant;
|
|
20
|
-
|
|
21
|
-
try {
|
|
22
|
-
const response = await apiClient.listRoles(environment, tenant);
|
|
23
|
-
|
|
24
|
-
if (!response.success) {
|
|
25
|
-
console.error(chalk.red(`\n✗ Failed: ${response.error?.message}\n`));
|
|
26
|
-
process.exit(1);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const roles = response.data || [];
|
|
30
|
-
|
|
31
|
-
if (options.json) {
|
|
32
|
-
console.log(JSON.stringify({ success: true, data: roles }, null, 2));
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
const table = new Table({
|
|
37
|
-
head: [chalk.bold('ID'), chalk.bold('Role Code'), chalk.bold('Role Name'), chalk.bold('Status')],
|
|
38
|
-
colWidths: [20, 20, 20, 10],
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
for (const role of roles) {
|
|
42
|
-
table.push([
|
|
43
|
-
role.roleId,
|
|
44
|
-
role.roleCode || '-',
|
|
45
|
-
role.roleName || '-',
|
|
46
|
-
role.statusFlag === 1 ? chalk.green('Enabled') : chalk.red('Disabled'),
|
|
47
|
-
]);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
console.log(table.toString());
|
|
51
|
-
console.log(chalk.gray(`\nTotal: ${roles.length} roles`));
|
|
52
|
-
} catch (error: any) {
|
|
53
|
-
console.error(chalk.red(`\n✗ Error: ${error.message}\n`));
|
|
54
|
-
process.exit(1);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
return rolesCommand;
|
|
59
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createStockListCommand } from './list.js';
|
|
3
|
-
import { createStockLedgerCommand } from './ledger.js';
|
|
4
|
-
|
|
5
|
-
export function createStockCommand(): Command {
|
|
6
|
-
const stockCommand = new Command('stock');
|
|
7
|
-
stockCommand.description('Manage stock inventory and ledger');
|
|
8
|
-
|
|
9
|
-
stockCommand.addCommand(createStockListCommand());
|
|
10
|
-
stockCommand.addCommand(createStockLedgerCommand());
|
|
11
|
-
|
|
12
|
-
return stockCommand;
|
|
13
|
-
}
|