@things-factory/worksheet-base 4.3.753 → 4.3.756
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-server/controllers/outbound/picking-worksheet-controller.js +97 -27
- package/dist-server/controllers/outbound/picking-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/sorting-worksheet-controller.js +117 -24
- package/dist-server/controllers/outbound/sorting-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/render-ro-do.js +324 -96
- package/dist-server/controllers/render-ro-do.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.js +244 -123
- package/dist-server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/index.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/index.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading/index.js +3 -1
- package/dist-server/graphql/resolvers/worksheet/loading/index.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/loading/validate-qc-seals.js +79 -0
- package/dist-server/graphql/resolvers/worksheet/loading/validate-qc-seals.js.map +1 -0
- package/dist-server/graphql/types/worksheet/index.js +5 -1
- package/dist-server/graphql/types/worksheet/index.js.map +1 -1
- package/dist-server/graphql/types/worksheet/validate-qc-seals-result.js +12 -0
- package/dist-server/graphql/types/worksheet/validate-qc-seals-result.js.map +1 -0
- package/dist-server/graphql/types/worksheet/worksheet-info.js +1 -0
- package/dist-server/graphql/types/worksheet/worksheet-info.js.map +1 -1
- package/package.json +21 -21
- package/server/controllers/outbound/picking-worksheet-controller.ts +105 -31
- package/server/controllers/outbound/sorting-worksheet-controller.ts +137 -25
- package/server/controllers/render-ro-do.ts +378 -136
- package/server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.ts +305 -128
- package/server/graphql/resolvers/worksheet/index.ts +3 -2
- package/server/graphql/resolvers/worksheet/loading/index.ts +5 -0
- package/server/graphql/resolvers/worksheet/loading/validate-qc-seals.ts +91 -0
- package/server/graphql/types/worksheet/index.ts +5 -1
- package/server/graphql/types/worksheet/validate-qc-seals-result.ts +9 -0
- package/server/graphql/types/worksheet/worksheet-info.ts +1 -0
|
@@ -1,145 +1,266 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.findSortingReleaseOrdersByTaskNoResolver = void 0;
|
|
4
|
-
const typeorm_1 = require("typeorm");
|
|
5
4
|
const sales_base_1 = require("@things-factory/sales-base");
|
|
6
|
-
const shell_1 = require("@things-factory/shell");
|
|
7
5
|
const auth_base_1 = require("@things-factory/auth-base");
|
|
8
|
-
const warehouse_base_1 = require("@things-factory/warehouse-base");
|
|
9
6
|
const controllers_1 = require("../../../controllers/");
|
|
10
7
|
const setting_base_1 = require("@things-factory/setting-base");
|
|
11
8
|
const constants_1 = require("../../../constants");
|
|
12
9
|
const entities_1 = require("../../../entities");
|
|
10
|
+
// Simple in-memory cache for settings with TTL
|
|
11
|
+
const settingsCache = new Map();
|
|
12
|
+
const SETTINGS_CACHE_TTL = 5 * 60 * 1000; // 5 minutes
|
|
13
|
+
/**
|
|
14
|
+
* Get setting with caching to avoid repeated database queries
|
|
15
|
+
*/
|
|
16
|
+
async function getCachedSetting(tx, domain, category, name) {
|
|
17
|
+
const cacheKey = `${domain.id}:${category}:${name}`;
|
|
18
|
+
const cached = settingsCache.get(cacheKey);
|
|
19
|
+
if (cached && cached.expiry > Date.now()) {
|
|
20
|
+
return cached.value;
|
|
21
|
+
}
|
|
22
|
+
const setting = await tx.getRepository(setting_base_1.Setting).findOne({
|
|
23
|
+
where: { domain, category, name }
|
|
24
|
+
});
|
|
25
|
+
settingsCache.set(cacheKey, { value: setting || null, expiry: Date.now() + SETTINGS_CACHE_TTL });
|
|
26
|
+
return setting || null;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Find worksheet by release good name - returns task info if found
|
|
30
|
+
*/
|
|
31
|
+
async function findWorksheetByReleaseGoodName(tx, domain, taskNo) {
|
|
32
|
+
const result = await tx
|
|
33
|
+
.getRepository(entities_1.Worksheet)
|
|
34
|
+
.createQueryBuilder('ws')
|
|
35
|
+
.select('ws.task_no', 'taskNo')
|
|
36
|
+
.addSelect('ws.status', 'wsStatus')
|
|
37
|
+
.addSelect('rg.name', 'releaseGoodName')
|
|
38
|
+
.addSelect('rg.status', 'releaseGoodStatus')
|
|
39
|
+
.innerJoin('worksheet_details', 'wd', `ws.id = wd.worksheet_id`)
|
|
40
|
+
.innerJoin('order_inventories', 'oi', `wd.target_inventory_id = oi.id AND wd."type" = 'SORTING'`)
|
|
41
|
+
.innerJoin('release_goods', 'rg', `rg.id = oi.release_good_id`)
|
|
42
|
+
.where('rg.domain_id = :domainId', { domainId: domain.id })
|
|
43
|
+
.andWhere('rg.name = :name', { name: taskNo })
|
|
44
|
+
.andWhere('rg.status IN (:...statuses)', {
|
|
45
|
+
statuses: [sales_base_1.ORDER_STATUS.READY_TO_SORT, sales_base_1.ORDER_STATUS.SORTING, sales_base_1.ORDER_STATUS.LOADING, sales_base_1.ORDER_STATUS.DONE]
|
|
46
|
+
})
|
|
47
|
+
.andWhere('ws.type = :type', { type: constants_1.WORKSHEET_TYPE.SORTING })
|
|
48
|
+
.getRawOne();
|
|
49
|
+
if (!result)
|
|
50
|
+
return null;
|
|
51
|
+
if (result.releaseGoodStatus === 'LOADING' || result.releaseGoodStatus === 'DONE') {
|
|
52
|
+
throw new Error(`Release Good already sorted`);
|
|
53
|
+
}
|
|
54
|
+
return {
|
|
55
|
+
taskNo: result.taskNo,
|
|
56
|
+
selectedReleaseGood: result.releaseGoodName,
|
|
57
|
+
status: result.wsStatus
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Find worksheet by taskNo directly - optimized to only load needed relations
|
|
62
|
+
*/
|
|
63
|
+
async function findWorksheetByTaskNo(tx, domain, taskNo, loadWorksheetDetails = false) {
|
|
64
|
+
const relations = loadWorksheetDetails ? ['bizplace', 'bizplace.domain', 'worksheetDetails'] : ['bizplace', 'bizplace.domain'];
|
|
65
|
+
return tx.getRepository(entities_1.Worksheet).findOne({
|
|
66
|
+
where: { taskNo, type: constants_1.WORKSHEET_TYPE.SORTING, domain },
|
|
67
|
+
relations
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Find worksheet by bin location - combines location lookup and worksheet query
|
|
72
|
+
* Returns both taskNo and worksheet status in a single optimized query
|
|
73
|
+
*/
|
|
74
|
+
async function findWorksheetByBinLocation(tx, domain, binName) {
|
|
75
|
+
// Combined query: location -> order inventory -> worksheet in one go
|
|
76
|
+
const result = await tx
|
|
77
|
+
.getRepository(sales_base_1.OrderInventory)
|
|
78
|
+
.createQueryBuilder('oi')
|
|
79
|
+
.select('ws2.task_no', 'taskNo')
|
|
80
|
+
.addSelect('ws2.id', 'worksheetId')
|
|
81
|
+
.addSelect('ws2.status', 'status')
|
|
82
|
+
.innerJoin('locations', 'loc', 'oi.bin_location_id = loc.id')
|
|
83
|
+
.innerJoin('worksheets', 'ws', `oi.ref_worksheet_id = ws.id AND ws.type = 'BATCH_PICKING'`)
|
|
84
|
+
.innerJoin('worksheets', 'ws2', `ws2.task_no = ws.task_no AND ws2.type = 'SORTING'`)
|
|
85
|
+
.innerJoin('release_goods', 'rg', 'rg.id = oi.release_good_id')
|
|
86
|
+
.where('oi.domain_id = :domainId', { domainId: domain.id })
|
|
87
|
+
.andWhere('loc.domain_id = :domainId', { domainId: domain.id })
|
|
88
|
+
.andWhere('loc.name = :binName', { binName })
|
|
89
|
+
.andWhere('oi.status IN (:...orderInventoryStatus)', {
|
|
90
|
+
orderInventoryStatus: [sales_base_1.ORDER_INVENTORY_STATUS.READY_TO_SORT, sales_base_1.ORDER_INVENTORY_STATUS.SORTING]
|
|
91
|
+
})
|
|
92
|
+
.andWhere('rg.status IN (:...statuses)', {
|
|
93
|
+
statuses: [sales_base_1.ORDER_STATUS.READY_TO_SORT, sales_base_1.ORDER_STATUS.SORTING]
|
|
94
|
+
})
|
|
95
|
+
.andWhere('ws2.status IN (:...worksheetStatuses)', {
|
|
96
|
+
worksheetStatuses: [constants_1.WORKSHEET_STATUS.DEACTIVATED, constants_1.WORKSHEET_STATUS.EXECUTING]
|
|
97
|
+
})
|
|
98
|
+
.getRawOne();
|
|
99
|
+
if (!result) {
|
|
100
|
+
throw new Error(`Bin do not have any batch picking order.`);
|
|
101
|
+
}
|
|
102
|
+
return {
|
|
103
|
+
taskNo: result.taskNo,
|
|
104
|
+
worksheetId: result.worksheetId,
|
|
105
|
+
status: result.status
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Handle worksheet activation if needed
|
|
110
|
+
*/
|
|
111
|
+
async function handleWorksheetActivation(tx, domain, user, task) {
|
|
112
|
+
var _a, _b, _c;
|
|
113
|
+
if (task.status !== 'DEACTIVATED')
|
|
114
|
+
return;
|
|
115
|
+
const sortingWSCtrl = new controllers_1.SortingWorksheetController(tx, domain, user);
|
|
116
|
+
// Use cached settings
|
|
117
|
+
const directActivateSetting = await getCachedSetting(tx, domain, 'id-rule', 'enable-direct-activate-sorting-worksheet');
|
|
118
|
+
if (!directActivateSetting || ((_a = directActivateSetting.value) === null || _a === void 0 ? void 0 : _a.toLowerCase()) !== 'true') {
|
|
119
|
+
throw new Error('Kindly go to sorting worksheet page to activate the sorting worksheet');
|
|
120
|
+
}
|
|
121
|
+
// Only fetch partner setting if main setting is enabled
|
|
122
|
+
const partnerSetting = await tx.getRepository(setting_base_1.PartnerSetting).findOne({
|
|
123
|
+
where: {
|
|
124
|
+
setting: directActivateSetting,
|
|
125
|
+
domain: domain,
|
|
126
|
+
partnerDomain: (_b = task.bizplace) === null || _b === void 0 ? void 0 : _b.domain
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
// If partner setting exists and is false, don't activate
|
|
130
|
+
if (partnerSetting && ((_c = partnerSetting.value) === null || _c === void 0 ? void 0 : _c.toLowerCase()) !== 'true') {
|
|
131
|
+
throw new Error('Kindly go to sorting worksheet page to activate the sorting worksheet');
|
|
132
|
+
}
|
|
133
|
+
// Load worksheet details only when needed for activation
|
|
134
|
+
if (!task.worksheetDetails) {
|
|
135
|
+
const taskWithDetails = await tx.getRepository(entities_1.Worksheet).findOne({
|
|
136
|
+
where: { id: task.id },
|
|
137
|
+
relations: ['worksheetDetails']
|
|
138
|
+
});
|
|
139
|
+
task.worksheetDetails = (taskWithDetails === null || taskWithDetails === void 0 ? void 0 : taskWithDetails.worksheetDetails) || [];
|
|
140
|
+
}
|
|
141
|
+
await sortingWSCtrl.activateSorting(task.name, task.worksheetDetails);
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Build and execute release goods query with item counts in a SINGLE query
|
|
145
|
+
* Optimizations:
|
|
146
|
+
* - Removed redundant Domain join (filter directly on ws.domain_id)
|
|
147
|
+
* - Combined release goods + counts into one query using aggregate functions
|
|
148
|
+
*/
|
|
149
|
+
async function getReleaseGoodsWithCounts(tx, domain, taskNo) {
|
|
150
|
+
// Single query that gets release goods with their counts using aggregation
|
|
151
|
+
const releaseGoods = await tx
|
|
152
|
+
.getRepository(entities_1.Worksheet)
|
|
153
|
+
.createQueryBuilder('ws')
|
|
154
|
+
.select('rg.id', 'id')
|
|
155
|
+
.addSelect('rg.name', 'name')
|
|
156
|
+
.addSelect('rg.refNo', 'refNo')
|
|
157
|
+
.addSelect('rg.refNo2', 'refNo2')
|
|
158
|
+
.addSelect('rg.status', 'status')
|
|
159
|
+
.addSelect('rg.district', 'district')
|
|
160
|
+
.addSelect('rg.attention_company', 'attentionCompany')
|
|
161
|
+
.addSelect('rg.delivery_address_1', 'deliveryAddress1')
|
|
162
|
+
.addSelect('rg.delivery_address_2', 'deliveryAddress2')
|
|
163
|
+
.addSelect('rg.delivery_address_3', 'deliveryAddress3')
|
|
164
|
+
.addSelect('rg.delivery_address_4', 'deliveryAddress4')
|
|
165
|
+
.addSelect('rg.delivery_address_5', 'deliveryAddress5')
|
|
166
|
+
.addSelect('rg.created_at', 'createdAt')
|
|
167
|
+
.addSelect('u.name', 'sortedByUser')
|
|
168
|
+
// Counts computed directly in the same query
|
|
169
|
+
.addSelect('COUNT(oi.id)', 'totalCount')
|
|
170
|
+
.addSelect('SUM(CASE WHEN oi.sorted_qty = oi.release_qty THEN 1 ELSE 0 END)', 'completedCount')
|
|
171
|
+
.innerJoin(entities_1.WorksheetDetail, 'wsd', 'ws.id = wsd.worksheet_id')
|
|
172
|
+
.innerJoin(sales_base_1.OrderInventory, 'oi', 'oi.id = wsd.target_inventory_id')
|
|
173
|
+
.innerJoin(sales_base_1.ReleaseGood, 'rg', 'rg.id = oi.release_good_id')
|
|
174
|
+
.leftJoin(auth_base_1.User, 'u', 'rg.sorted_by_id = u.id')
|
|
175
|
+
// Filter directly on ws.domain_id - no need to join Domain table
|
|
176
|
+
.where('ws.domain_id = :domainId', { domainId: domain.id })
|
|
177
|
+
.andWhere('ws.taskNo = :taskNo', { taskNo })
|
|
178
|
+
.andWhere('ws.type = :worksheetType', { worksheetType: constants_1.WORKSHEET_TYPE.SORTING })
|
|
179
|
+
.andWhere('ws.status = :worksheetStatus', { worksheetStatus: constants_1.WORKSHEET_STATUS.EXECUTING })
|
|
180
|
+
.groupBy('rg.id')
|
|
181
|
+
.addGroupBy('rg.name')
|
|
182
|
+
.addGroupBy('rg.refNo')
|
|
183
|
+
.addGroupBy('rg.refNo2')
|
|
184
|
+
.addGroupBy('rg.status')
|
|
185
|
+
.addGroupBy('rg.district')
|
|
186
|
+
.addGroupBy('rg.attention_company')
|
|
187
|
+
.addGroupBy('rg.delivery_address_1')
|
|
188
|
+
.addGroupBy('rg.delivery_address_2')
|
|
189
|
+
.addGroupBy('rg.delivery_address_3')
|
|
190
|
+
.addGroupBy('rg.delivery_address_4')
|
|
191
|
+
.addGroupBy('rg.delivery_address_5')
|
|
192
|
+
.addGroupBy('rg.created_at')
|
|
193
|
+
.addGroupBy('u.name')
|
|
194
|
+
.orderBy('rg.created_at', 'ASC')
|
|
195
|
+
.getRawMany();
|
|
196
|
+
// Transform results to include itemCounts
|
|
197
|
+
return releaseGoods.map(rg => {
|
|
198
|
+
const total = parseInt(rg.totalCount) || 0;
|
|
199
|
+
const completed = parseInt(rg.completedCount) || 0;
|
|
200
|
+
return {
|
|
201
|
+
id: rg.id,
|
|
202
|
+
name: rg.name,
|
|
203
|
+
refNo: rg.refNo,
|
|
204
|
+
refNo2: rg.refNo2,
|
|
205
|
+
status: rg.status,
|
|
206
|
+
district: rg.district,
|
|
207
|
+
attentionCompany: rg.attentionCompany,
|
|
208
|
+
deliveryAddress1: rg.deliveryAddress1,
|
|
209
|
+
deliveryAddress2: rg.deliveryAddress2,
|
|
210
|
+
deliveryAddress3: rg.deliveryAddress3,
|
|
211
|
+
deliveryAddress4: rg.deliveryAddress4,
|
|
212
|
+
deliveryAddress5: rg.deliveryAddress5,
|
|
213
|
+
sortedByUser: rg.sortedByUser,
|
|
214
|
+
itemCounts: {
|
|
215
|
+
total,
|
|
216
|
+
pending: total - completed
|
|
217
|
+
}
|
|
218
|
+
};
|
|
219
|
+
});
|
|
220
|
+
}
|
|
13
221
|
exports.findSortingReleaseOrdersByTaskNoResolver = {
|
|
14
222
|
async findSortingReleaseOrdersByTaskNo(_, { taskNo }, context) {
|
|
15
|
-
|
|
223
|
+
const startTime = Date.now();
|
|
16
224
|
const { domain, tx, user } = context.state;
|
|
17
225
|
let selectedReleaseGood = null;
|
|
18
|
-
let
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
.
|
|
27
|
-
|
|
28
|
-
})
|
|
29
|
-
.andWhere('ws.type = :type', { type: constants_1.WORKSHEET_TYPE.SORTING })
|
|
30
|
-
.getRawOne();
|
|
31
|
-
if (ws) {
|
|
32
|
-
if (ws.release_good_status == 'LOADING' || ws.release_good_status == 'DONE') {
|
|
33
|
-
throw new Error(`Release Good already sorted`);
|
|
34
|
-
}
|
|
35
|
-
selectedReleaseGood = ws.release_good_name;
|
|
36
|
-
taskNo = ws.ws_task_no;
|
|
226
|
+
let task = null;
|
|
227
|
+
let resolvedTaskNo = taskNo;
|
|
228
|
+
// Step 1: Try to find by release good name first (most common case)
|
|
229
|
+
const releaseGoodResult = await findWorksheetByReleaseGoodName(tx, domain, taskNo);
|
|
230
|
+
if (releaseGoodResult) {
|
|
231
|
+
selectedReleaseGood = releaseGoodResult.selectedReleaseGood;
|
|
232
|
+
resolvedTaskNo = releaseGoodResult.taskNo;
|
|
233
|
+
// Only load worksheetDetails if we need them for activation
|
|
234
|
+
const needsActivation = releaseGoodResult.status === 'DEACTIVATED';
|
|
235
|
+
task = await findWorksheetByTaskNo(tx, domain, resolvedTaskNo, needsActivation);
|
|
37
236
|
}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
}
|
|
42
|
-
//
|
|
237
|
+
// Step 2: Try to find by worksheet taskNo directly
|
|
238
|
+
if (!task) {
|
|
239
|
+
task = await findWorksheetByTaskNo(tx, domain, taskNo, false);
|
|
240
|
+
}
|
|
241
|
+
// Step 3: Try to find by bin location
|
|
43
242
|
if (!task) {
|
|
44
|
-
const
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
.createQueryBuilder('orderInventory');
|
|
51
|
-
qb.innerJoinAndSelect('orderInventory.releaseGood', 'releaseGood')
|
|
52
|
-
.innerJoinAndSelect('worksheets', 'ws', `orderInventory.ref_worksheet_id = ws.id AND ws.type = 'BATCH_PICKING'`)
|
|
53
|
-
.innerJoinAndSelect('worksheets', 'ws2', `ws2.task_no = ws.task_no AND ws2.type = 'SORTING'`)
|
|
54
|
-
.innerJoinAndSelect('releaseGood.bizplace', 'bizplace')
|
|
55
|
-
.innerJoinAndSelect('bizplace.domain', 'domain')
|
|
56
|
-
.where('orderInventory.domain_id = :domainId', { domainId: domain.id })
|
|
57
|
-
.andWhere('orderInventory.status IN (:...orderInventoryStatus)', {
|
|
58
|
-
orderInventoryStatus: [sales_base_1.ORDER_INVENTORY_STATUS.READY_TO_SORT, sales_base_1.ORDER_INVENTORY_STATUS.SORTING]
|
|
59
|
-
})
|
|
60
|
-
.andWhere('orderInventory.bin_location_id = :locationId', { locationId: binLocation.id })
|
|
61
|
-
.andWhere('releaseGood.status IN (:...statuses)', {
|
|
62
|
-
statuses: [sales_base_1.ORDER_STATUS.READY_TO_SORT, sales_base_1.ORDER_STATUS.SORTING]
|
|
63
|
-
});
|
|
64
|
-
const orderInventoryByBin = await qb.getRawOne();
|
|
65
|
-
if (orderInventoryByBin === null || orderInventoryByBin === void 0 ? void 0 : orderInventoryByBin.releaseGood_id) {
|
|
66
|
-
taskNo = orderInventoryByBin.ws_task_no;
|
|
67
|
-
task = await tx.getRepository(entities_1.Worksheet).findOne({
|
|
68
|
-
where: {
|
|
69
|
-
taskNo,
|
|
70
|
-
status: (0, typeorm_1.In)([constants_1.WORKSHEET_STATUS.DEACTIVATED, constants_1.WORKSHEET_STATUS.EXECUTING]),
|
|
71
|
-
type: constants_1.WORKSHEET_TYPE.SORTING,
|
|
72
|
-
domain
|
|
73
|
-
},
|
|
74
|
-
relations: ['worksheetDetails']
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
else {
|
|
78
|
-
throw new Error(`Bin do not have any batch picking order.`);
|
|
79
|
-
}
|
|
243
|
+
const binResult = await findWorksheetByBinLocation(tx, domain, taskNo);
|
|
244
|
+
if (binResult) {
|
|
245
|
+
resolvedTaskNo = binResult.taskNo;
|
|
246
|
+
// Only load worksheetDetails if we need them for activation
|
|
247
|
+
const needsActivation = binResult.status === 'DEACTIVATED';
|
|
248
|
+
task = await findWorksheetByTaskNo(tx, domain, resolvedTaskNo, needsActivation);
|
|
80
249
|
}
|
|
81
250
|
}
|
|
82
|
-
if (!task)
|
|
251
|
+
if (!task) {
|
|
83
252
|
throw new Error('Unable to find task no.');
|
|
84
|
-
if (task.status === 'DEACTIVATED') {
|
|
85
|
-
const sortingWSCtrl = new controllers_1.SortingWorksheetController(tx, domain, user);
|
|
86
|
-
const directActivateSortingWorksheet = await tx.getRepository(setting_base_1.Setting).findOne({
|
|
87
|
-
where: { domain: domain, category: 'id-rule', name: 'enable-direct-activate-sorting-worksheet' }
|
|
88
|
-
});
|
|
89
|
-
const partnerDirectActivateSortingWorksheetSetting = await tx
|
|
90
|
-
.getRepository(setting_base_1.PartnerSetting)
|
|
91
|
-
.findOne({
|
|
92
|
-
where: {
|
|
93
|
-
setting: directActivateSortingWorksheet,
|
|
94
|
-
domain: domain,
|
|
95
|
-
partnerDomain: (_a = task.bizplace) === null || _a === void 0 ? void 0 : _a.domain
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
if (directActivateSortingWorksheet != undefined && directActivateSortingWorksheet.value.toLowerCase() == 'true') {
|
|
99
|
-
if (partnerDirectActivateSortingWorksheetSetting != undefined) {
|
|
100
|
-
if (partnerDirectActivateSortingWorksheetSetting.value.toLowerCase() == 'true')
|
|
101
|
-
await sortingWSCtrl.activateSorting(task.name, task.worksheetDetails);
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
await sortingWSCtrl.activateSorting(task.name, task.worksheetDetails);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
else {
|
|
108
|
-
throw new Error('Kindly go to sorting worksheet page to activate the sorting worksheet');
|
|
109
|
-
}
|
|
110
253
|
}
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
.
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
.addSelect('rg.delivery_address_1 as "deliveryAddress1"')
|
|
122
|
-
.addSelect('rg.delivery_address_2 as "deliveryAddress2"')
|
|
123
|
-
.addSelect('rg.delivery_address_3 as "deliveryAddress3"')
|
|
124
|
-
.addSelect('rg.delivery_address_4 as "deliveryAddress4"')
|
|
125
|
-
.addSelect('rg.delivery_address_5 as "deliveryAddress5"')
|
|
126
|
-
.addSelect('user.name as "sortedByUser"')
|
|
127
|
-
.innerJoin(shell_1.Domain, 'domain', 'ws.domain_id = domain.id')
|
|
128
|
-
.innerJoin(entities_1.WorksheetDetail, 'wsd', 'ws.id = wsd.worksheet_id')
|
|
129
|
-
.innerJoin(sales_base_1.OrderInventory, 'oi', 'oi.id = wsd.target_inventory_id')
|
|
130
|
-
.innerJoin(sales_base_1.ReleaseGood, 'rg', 'rg.id = oi.release_good_id')
|
|
131
|
-
.leftJoin(auth_base_1.User, 'user', 'rg.sorted_by_id = user.id')
|
|
132
|
-
.where('domain.id = :domainId', { domainId: domain.id })
|
|
133
|
-
.andWhere('ws.taskNo = :taskNo', { taskNo: taskNo })
|
|
134
|
-
.andWhere('ws.type = :worksheetType', { worksheetType: constants_1.WORKSHEET_TYPE.SORTING })
|
|
135
|
-
.andWhere('ws.status = :worksheetStatus', { worksheetStatus: constants_1.WORKSHEET_STATUS.EXECUTING })
|
|
136
|
-
.groupBy('rg.id')
|
|
137
|
-
.addGroupBy('rg.name')
|
|
138
|
-
.addGroupBy('rg.status')
|
|
139
|
-
.addGroupBy('user.name')
|
|
140
|
-
.orderBy('rg.createdAt', 'ASC');
|
|
141
|
-
const releaseGoods = await qb.getRawMany();
|
|
142
|
-
return { releaseGoods, taskNo, selectedReleaseGood };
|
|
254
|
+
// Step 4: Handle activation if needed
|
|
255
|
+
await handleWorksheetActivation(tx, domain, user, task);
|
|
256
|
+
// Step 5: Get release goods with counts
|
|
257
|
+
const releaseGoods = await getReleaseGoodsWithCounts(tx, domain, resolvedTaskNo);
|
|
258
|
+
// Performance logging (only in development/debug mode)
|
|
259
|
+
const elapsed = Date.now() - startTime;
|
|
260
|
+
if (elapsed > 1000) {
|
|
261
|
+
console.warn(`[PERF] findSortingReleaseOrdersByTaskNo took ${elapsed}ms for taskNo: ${taskNo}`);
|
|
262
|
+
}
|
|
263
|
+
return { releaseGoods, taskNo: resolvedTaskNo, selectedReleaseGood };
|
|
143
264
|
}
|
|
144
265
|
};
|
|
145
266
|
//# sourceMappingURL=find-sorting-release-orders-by-task-no.js.map
|
package/dist-server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"find-sorting-release-orders-by-task-no.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"find-sorting-release-orders-by-task-no.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.ts"],"names":[],"mappings":"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"}
|
|
@@ -70,6 +70,6 @@ const worksheet_1 = require("./worksheet");
|
|
|
70
70
|
const worksheet_by_order_no_1 = require("./worksheet-by-order-no");
|
|
71
71
|
const worksheet_with_pagination_1 = require("./worksheet-with-pagination");
|
|
72
72
|
const worksheets_1 = require("./worksheets");
|
|
73
|
-
exports.Query = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, refresh_active_worksheet_picking_views_1.refreshActiveWorksheetPickingViews), worksheets_1.worksheetsResolver), worksheet_1.worksheetResolver), unloading_worksheet_1.unloadingWorksheetResolver), unloading_return_worksheet_1.unloadingReturnWorksheetResolver), delivery_order_by_worksheet_1.deliveryOrderByWorksheetResolver), packing_worksheet_1.packingWorksheetResolver), get_packing_list_1.packingListResolver), putaway_worksheet_1.putawayWorksheetResolver), putaway_returning_worksheet_1.putawayReturningWorksheetResolver), return_worksheet_1.returnWorksheetResolver), picking_worksheet_1.pickingWorksheetResolver), cycle_count_worksheet_for_pallet_1.cycleCountWorksheetForPalletResolver), cycle_count_worksheet_for_carton_1.cycleCountWorksheetForCartonResolver), vas_worksheet_1.vasWorksheetResolver), loading_worksheet_1.loadingWorksheetResolver), unloaded_inventories_1.unloadedInventories), unloaded_inventories_by_reusable_pallet_1.unloadedInventoriesByReusablePallet), loaded_inventories_1.loadedInventories), vas_candidates_1.vasCandidatesResolver), inventories_by_pallet_1.inventoriesByPalletResolver), batch_picking_worksheet_1.batchPickingWorksheetResolver), check_stock_take_current_location_1.checkStockTakeCurrentLocationResolver), check_inventory_release_1.checkInventoryReleaseResolver), vas_transactions_1.checkRelabelableResolver), having_vas_1.havingVasResolver), worksheet_by_order_no_1.worksheetByOrderNoResolver), worksheet_with_pagination_1.worksheetWithPaginationResolver), not_tally_target_inventories_1.notTallyTargetInventoriesResolver), vas_inventories_1.vasInventories), picking_assignment_status_by_user_1.pickingAssignmentStatusByUsersResolver), my_picking_assignment_status_1.myPickingAssignmentStatusResolver), recommend_putaway_location_1.recommendPutawayLocationResolver), sorting_worksheet_1.sortingWorksheetResolver), find_sorting_release_orders_by_task_no_1.findSortingReleaseOrdersByTaskNoResolver), find_release_orders_by_task_no_1.findReleaseOrdersByTaskNoResolver), fetch_delivery_order_ro_1.fetchDeliveryOrderROResolver), putaway_replenishment_worksheet_1.putawayReplenishmentWorksheetResolver);
|
|
73
|
+
exports.Query = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, refresh_active_worksheet_picking_views_1.refreshActiveWorksheetPickingViews), worksheets_1.worksheetsResolver), worksheet_1.worksheetResolver), unloading_worksheet_1.unloadingWorksheetResolver), unloading_return_worksheet_1.unloadingReturnWorksheetResolver), delivery_order_by_worksheet_1.deliveryOrderByWorksheetResolver), packing_worksheet_1.packingWorksheetResolver), get_packing_list_1.packingListResolver), putaway_worksheet_1.putawayWorksheetResolver), putaway_returning_worksheet_1.putawayReturningWorksheetResolver), return_worksheet_1.returnWorksheetResolver), picking_worksheet_1.pickingWorksheetResolver), cycle_count_worksheet_for_pallet_1.cycleCountWorksheetForPalletResolver), cycle_count_worksheet_for_carton_1.cycleCountWorksheetForCartonResolver), vas_worksheet_1.vasWorksheetResolver), loading_worksheet_1.loadingWorksheetResolver), unloaded_inventories_1.unloadedInventories), unloaded_inventories_by_reusable_pallet_1.unloadedInventoriesByReusablePallet), loaded_inventories_1.loadedInventories), vas_candidates_1.vasCandidatesResolver), inventories_by_pallet_1.inventoriesByPalletResolver), batch_picking_worksheet_1.batchPickingWorksheetResolver), check_stock_take_current_location_1.checkStockTakeCurrentLocationResolver), check_inventory_release_1.checkInventoryReleaseResolver), vas_transactions_1.checkRelabelableResolver), having_vas_1.havingVasResolver), worksheet_by_order_no_1.worksheetByOrderNoResolver), worksheet_with_pagination_1.worksheetWithPaginationResolver), not_tally_target_inventories_1.notTallyTargetInventoriesResolver), vas_inventories_1.vasInventories), picking_assignment_status_by_user_1.pickingAssignmentStatusByUsersResolver), my_picking_assignment_status_1.myPickingAssignmentStatusResolver), recommend_putaway_location_1.recommendPutawayLocationResolver), sorting_worksheet_1.sortingWorksheetResolver), find_sorting_release_orders_by_task_no_1.findSortingReleaseOrdersByTaskNoResolver), find_release_orders_by_task_no_1.findReleaseOrdersByTaskNoResolver), fetch_delivery_order_ro_1.fetchDeliveryOrderROResolver), putaway_replenishment_worksheet_1.putawayReplenishmentWorksheetResolver), loading_1.Query);
|
|
74
74
|
exports.Mutation = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, generate_worksheet_1.Mutations), unloading_1.Mutations), sorting_1.Mutations), putaway_1.Mutations), putaway_return_1.Mutations), vas_1.Mutations), picking_1.Mutations), packing_1.Mutations), loading_1.Mutations), returning_1.Mutations), unloading_return_1.Mutations), inspecting_1.Mutations), update_worksheet_1.updateWorksheet), create_worksheet_1.createWorksheet), cycle_count_adjustment_1.cycleCountAdjustmentResolver), delete_worksheet_1.deleteWorksheet), transfer_1.transfer), proceed_extra_products_1.proceedExtraProductsResolver), replace_picking_pallets_1.replacePickingPalletsResolver), pending_cancellation_release_order_1.pendingCancellationReleaseOrder), confirm_cancellation_release_order_1.confirmCancellationReleaseOrder), reject_cancellation_release_order_1.rejectCancellationReleaseOrder), vas_transactions_1.repalletizingResolver), vas_transactions_1.undoRepalletizingResolver), vas_transactions_1.repackagingResolver), vas_transactions_1.undoRepackagingResolver), vas_transactions_1.relabelingResolver), vas_transactions_1.undoRelabelingResolver), cross_dock_picking_1.crossDockPickingResolver), vas_transactions_1.unpackingResolver), palletizing_pallets_1.palletizingPallets), fetch_sellercraft_document_1.fetchSellercraftDocumentResolver), fetch_powrup_document_1.fetchPowrupDocumentResolver), fetch_webspert_document_1.fetchWebspertDocumentResolver), cancel_draft_release_order_1.cancelDraftReleaseOrder), cancel_replenishment_1.cancelReplenishment), replenishment_1.Mutations), cancel_arrival_notice_1.cancelArrivalNoticeResolver);
|
|
75
75
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/worksheet/index.ts"],"names":[],"mappings":";;;AAAA,uEAAyE;AACzE,mEAAqE;AACrE,6EAAsE;AACtE,iEAA4D;AAC5D,uEAAyE;AACzE,2FAA2F;AAC3F,6FAAsF;AACtF,yDAAoD;AACpD,6DAA+D;AAC/D,qEAAuE;AACvE,yFAAyF;AACzF,yFAAyF;AACzF,yDAAoD;AACpD,+EAAgF;AAChF,uEAAwE;AACxE,mEAAqE;AACrE,6EAA+E;AAC/E,uEAAyE;AACzE,qFAAoF;AACpF,qGAAmG;AACnG,6DAA8E;AAC9E,yDAAwD;AACxD,6CAAgD;AAChD,6CAA4D;AAC5D,mEAAqE;AACrE,6DAAwD;AACxD,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/worksheet/index.ts"],"names":[],"mappings":";;;AAAA,uEAAyE;AACzE,mEAAqE;AACrE,6EAAsE;AACtE,iEAA4D;AAC5D,uEAAyE;AACzE,2FAA2F;AAC3F,6FAAsF;AACtF,yDAAoD;AACpD,6DAA+D;AAC/D,qEAAuE;AACvE,yFAAyF;AACzF,yFAAyF;AACzF,yDAAoD;AACpD,+EAAgF;AAChF,uEAAwE;AACxE,mEAAqE;AACrE,6EAA+E;AAC/E,uEAAyE;AACzE,qFAAoF;AACpF,qGAAmG;AACnG,6DAA8E;AAC9E,yDAAwD;AACxD,6CAAgD;AAChD,6CAA4D;AAC5D,mEAAqE;AACrE,6DAAwD;AACxD,uCAAgF;AAChF,2DAA8D;AAC9D,iFAAkF;AAClF,uCAAyD;AACzD,2DAA8D;AAC9D,+DAA0D;AAC1D,6FAAsF;AACtF,uCAAyD;AACzD,2DAA8D;AAC9D,yFAA0F;AAC1F,mGAAoG;AACpG,qEAAuE;AACvE,uCAAyD;AACzD,uFAAyF;AACzF,qDAAsE;AACtE,+EAAiF;AACjF,2DAA8D;AAC9D,6EAA+E;AAC/E,qGAA6F;AAC7F,2FAAoF;AACpF,uEAAyE;AACzE,mDAAqE;AACrE,yDAA4D;AAC5D,2CAA6D;AAC7D,uCAAyD;AACzD,2DAA8D;AAC9D,yCAAqC;AACrC,iEAA4D;AAC5D,uGAA+F;AAC/F,2CAA6D;AAC7D,yDAA0E;AAC1E,6EAA+E;AAC/E,+DAAkE;AAClE,yDAAoD;AACpD,+BAAiD;AACjD,qDAAwD;AACxD,uDAAkD;AAClD,yDAS2B;AAC3B,mDAAsD;AACtD,2CAA+C;AAC/C,mEAAoE;AACpE,2EAA6E;AAC7E,6CAAiD;AAEpC,QAAA,KAAK,yiBACb,2EAAkC,GAClC,+BAAkB,GAClB,6BAAiB,GACjB,gDAA0B,GAC1B,6DAAgC,GAChC,8DAAgC,GAChC,4CAAwB,GACxB,sCAAmB,GACnB,4CAAwB,GACxB,+DAAiC,GACjC,0CAAuB,GACvB,4CAAwB,GACxB,uEAAoC,GACpC,uEAAoC,GACpC,oCAAoB,GACpB,4CAAwB,GACxB,0CAAmB,GACnB,6EAAmC,GACnC,sCAAiB,GACjB,sCAAqB,GACrB,mDAA2B,GAC3B,uDAA6B,GAC7B,yEAAqC,GACrC,uDAA6B,GAC7B,2CAAwB,GACxB,8BAAiB,GACjB,kDAA0B,GAC1B,2DAA+B,GAC/B,gEAAiC,GACjC,gCAAc,GACd,0EAAsC,GACtC,gEAAiC,GACjC,6DAAgC,GAChC,4CAAwB,GACxB,iFAAwC,GACxC,kEAAiC,GACjC,sDAA4B,GAC5B,uEAAqC,GACrC,eAAY,EAChB;AAEY,QAAA,QAAQ,2hBAChB,8BAA0B,GAC1B,qBAAkB,GAClB,mBAAgB,GAChB,mBAAgB,GAChB,0BAAsB,GACtB,eAAY,GACZ,mBAAgB,GAChB,mBAAgB,GAChB,mBAAgB,GAChB,qBAAkB,GAClB,4BAAwB,GACxB,sBAAgB,GAChB,kCAAe,GACf,kCAAe,GACf,qDAA4B,GAC5B,kCAAe,GACf,mBAAQ,GACR,qDAA4B,GAC5B,uDAA6B,GAC7B,oEAA+B,GAC/B,oEAA+B,GAC/B,kEAA8B,GAC9B,wCAAqB,GACrB,4CAAyB,GACzB,sCAAmB,GACnB,0CAAuB,GACvB,qCAAkB,GAClB,yCAAsB,GACtB,6CAAwB,GACxB,oCAAiB,GACjB,wCAAkB,GAClB,6DAAgC,GAChC,mDAA2B,GAC3B,uDAA6B,GAC7B,oDAAuB,GACvB,0CAAmB,GACnB,yBAAsB,GACtB,mDAA2B,EAC/B"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Mutations = void 0;
|
|
3
|
+
exports.Query = exports.Mutations = void 0;
|
|
4
4
|
const activate_loading_1 = require("./activate-loading");
|
|
5
5
|
const loading_1 = require("./loading");
|
|
6
6
|
const undo_loading_1 = require("./undo-loading");
|
|
7
7
|
const complete_loading_1 = require("./complete-loading");
|
|
8
|
+
const validate_qc_seals_1 = require("./validate-qc-seals");
|
|
8
9
|
exports.Mutations = Object.assign(Object.assign(Object.assign(Object.assign({}, activate_loading_1.activateLoadingResolver), loading_1.loadingResolver), undo_loading_1.undoLoadingResolver), complete_loading_1.completeLoadingResolver);
|
|
10
|
+
exports.Query = Object.assign({}, validate_qc_seals_1.validateQcSealsResolver);
|
|
9
11
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/loading/index.ts"],"names":[],"mappings":";;;AAAA,yDAA4D;AAC5D,uCAA2C;AAC3C,iDAAoD;AACpD,yDAA4D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/loading/index.ts"],"names":[],"mappings":";;;AAAA,yDAA4D;AAC5D,uCAA2C;AAC3C,iDAAoD;AACpD,yDAA4D;AAC5D,2DAA6D;AAEhD,QAAA,SAAS,+DACjB,0CAAuB,GACvB,yBAAe,GACf,kCAAmB,GACnB,0CAAuB,EAC3B;AAEY,QAAA,KAAK,qBACb,2CAAuB,EAC3B"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateQcSealsResolver = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
const sales_base_1 = require("@things-factory/sales-base");
|
|
6
|
+
const setting_base_1 = require("@things-factory/setting-base");
|
|
7
|
+
exports.validateQcSealsResolver = {
|
|
8
|
+
async validateQcSeals(_, { releaseGoodNo }, context) {
|
|
9
|
+
var _a;
|
|
10
|
+
const { tx, domain, user } = context.state;
|
|
11
|
+
try {
|
|
12
|
+
const releaseGood = await tx.getRepository(sales_base_1.ReleaseGood).findOne({
|
|
13
|
+
where: { domain, name: releaseGoodNo },
|
|
14
|
+
relations: ['bizplace', 'bizplace.domain']
|
|
15
|
+
});
|
|
16
|
+
if (!releaseGood) {
|
|
17
|
+
return { valid: false, error: 'Release good not found', minimumSealNumber: 0 };
|
|
18
|
+
}
|
|
19
|
+
// Check enable-tote-scanning setting
|
|
20
|
+
let enableToteScanningSetting = await tx.getRepository(setting_base_1.Setting).findOne({
|
|
21
|
+
where: {
|
|
22
|
+
domain: domain,
|
|
23
|
+
category: 'id-rule',
|
|
24
|
+
name: 'enable-tote-scanning'
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
// Check minimum-seal-number setting (needed for banner display)
|
|
28
|
+
let minimumSealNumberSetting = await tx.getRepository(setting_base_1.Setting).findOne({
|
|
29
|
+
where: {
|
|
30
|
+
domain: domain,
|
|
31
|
+
category: 'id-rule',
|
|
32
|
+
name: 'minimum-seal-number'
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
const minimumSealNumber = parseInt((minimumSealNumberSetting === null || minimumSealNumberSetting === void 0 ? void 0 : minimumSealNumberSetting.value) || '0', 10);
|
|
36
|
+
if (enableToteScanningSetting) {
|
|
37
|
+
// enable-tote-scanning is numeric: 0 = disabled, >= 1 = enabled
|
|
38
|
+
const enableToteScanningValue = parseInt(enableToteScanningSetting.value || '0', 10);
|
|
39
|
+
if (enableToteScanningValue >= 1) {
|
|
40
|
+
// Check if there are unsealed totes (closedDate is null)
|
|
41
|
+
const foundNotSealedOrderTote = await tx
|
|
42
|
+
.getRepository(sales_base_1.OrderTote)
|
|
43
|
+
.findOne({ where: { releaseGood, closedDate: (0, typeorm_1.IsNull)() } });
|
|
44
|
+
if (foundNotSealedOrderTote) {
|
|
45
|
+
return {
|
|
46
|
+
valid: false,
|
|
47
|
+
error: `Please seal the tote(s) before proceeding. Minimum ${minimumSealNumber} seal(s) required.`,
|
|
48
|
+
minimumSealNumber
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
// If minimum-seal-number > 0, validate seal counts per tote
|
|
52
|
+
if (minimumSealNumber > 0) {
|
|
53
|
+
// Get all order totes for this release good
|
|
54
|
+
const orderTotes = await tx.getRepository(sales_base_1.OrderTote).find({
|
|
55
|
+
where: { releaseGood },
|
|
56
|
+
relations: ['orderToteSeals']
|
|
57
|
+
});
|
|
58
|
+
// Validate each tote has at least minimum-seal-number seals
|
|
59
|
+
for (const orderTote of orderTotes) {
|
|
60
|
+
const sealCount = ((_a = orderTote.orderToteSeals) === null || _a === void 0 ? void 0 : _a.length) || 0;
|
|
61
|
+
if (sealCount < minimumSealNumber) {
|
|
62
|
+
return {
|
|
63
|
+
valid: false,
|
|
64
|
+
error: `Tote ${orderTote.name} has ${sealCount} seal(s), but minimum ${minimumSealNumber} seal(s) required`,
|
|
65
|
+
minimumSealNumber
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return { valid: true, minimumSealNumber };
|
|
73
|
+
}
|
|
74
|
+
catch (error) {
|
|
75
|
+
return { valid: false, error: error.message || 'Validation failed', minimumSealNumber: 0 };
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=validate-qc-seals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-qc-seals.js","sourceRoot":"","sources":["../../../../../server/graphql/resolvers/worksheet/loading/validate-qc-seals.ts"],"names":[],"mappings":"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"}
|
|
@@ -25,6 +25,7 @@ const product_approval_1 = require("./product-approval");
|
|
|
25
25
|
const release_good_worksheet_1 = require("./release-good-worksheet");
|
|
26
26
|
const return_order_worksheet_1 = require("./return-order-worksheet");
|
|
27
27
|
const sellercraft_document_1 = require("./sellercraft-document");
|
|
28
|
+
const validate_qc_seals_result_1 = require("./validate-qc-seals-result");
|
|
28
29
|
const vas_order_worksheet_1 = require("./vas-order-worksheet");
|
|
29
30
|
const webspert_document_1 = require("./webspert-document");
|
|
30
31
|
const worksheet_1 = require("./worksheet");
|
|
@@ -865,6 +866,8 @@ exports.Query = `
|
|
|
865
866
|
findSortingReleaseOrdersByTaskNo(taskNo: String!): FindReleaseOrdersByTaskNo @privilege(category: "worksheet", privilege: "query") @transaction
|
|
866
867
|
|
|
867
868
|
findReleaseOrdersByTaskNo(taskNo: String!): FindReleaseOrdersByTaskNo @privilege(category: "worksheet", privilege: "query") @transaction
|
|
869
|
+
|
|
870
|
+
validateQcSeals(releaseGoodNo: String!): ValidateQcSealsResult @privilege(category: "worksheet", privilege: "query") @transaction
|
|
868
871
|
`;
|
|
869
872
|
exports.Types = [
|
|
870
873
|
worksheet_1.Worksheet,
|
|
@@ -898,6 +901,7 @@ exports.Types = [
|
|
|
898
901
|
delivery_order_ro_1.DeliveryOrderRO,
|
|
899
902
|
batch_pick_worksheet_info_1.GenerateBatchPickInfo,
|
|
900
903
|
multiple_release_good_worksheet_1.MultipleReleaseGoodWorksheet,
|
|
901
|
-
location_filter_1.LocationFilter
|
|
904
|
+
location_filter_1.LocationFilter,
|
|
905
|
+
validate_qc_seals_result_1.ValidateQcSealsResult
|
|
902
906
|
];
|
|
903
907
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/types/worksheet/index.ts"],"names":[],"mappings":";;;AAAA,yEAAmE;AACnE,2EAAmE;AACnE,6DAAuD;AACvD,mEAA6D;AAC7D,mDAA8C;AAC9C,+DAAyD;AACzD,2DAAqD;AACrD,6DAAwD;AACxD,+DAA0D;AAC1D,qFAA4E;AAC5E,+DAAyD;AACzD,2EAAqE;AACrE,uEAAiE;AACjE,uDAAkD;AAClD,uFAAgF;AAChF,iFAA0E;AAC1E,mDAA8C;AAC9C,iDAA4C;AAC5C,2EAAqE;AACrE,uDAAkD;AAClD,yDAAoD;AACpD,qEAA+D;AAC/D,qEAA+D;AAC/D,iEAA4D;AAC5D,+DAAyD;AACzD,2DAAsD;AACtD,2CAAuC;AACvC,mEAA6D;AAC7D,qDAAgD;AAChD,qDAAgD;AAChD,uDAAkD;AAClD,2EAAqE;AAExD,QAAA,QAAQ,GAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAupBnC,CAAA;AAEU,QAAA,KAAK,GAAiB
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/types/worksheet/index.ts"],"names":[],"mappings":";;;AAAA,yEAAmE;AACnE,2EAAmE;AACnE,6DAAuD;AACvD,mEAA6D;AAC7D,mDAA8C;AAC9C,+DAAyD;AACzD,2DAAqD;AACrD,6DAAwD;AACxD,+DAA0D;AAC1D,qFAA4E;AAC5E,+DAAyD;AACzD,2EAAqE;AACrE,uEAAiE;AACjE,uDAAkD;AAClD,uFAAgF;AAChF,iFAA0E;AAC1E,mDAA8C;AAC9C,iDAA4C;AAC5C,2EAAqE;AACrE,uDAAkD;AAClD,yDAAoD;AACpD,qEAA+D;AAC/D,qEAA+D;AAC/D,iEAA4D;AAC5D,yEAAkE;AAClE,+DAAyD;AACzD,2DAAsD;AACtD,2CAAuC;AACvC,mEAA6D;AAC7D,qDAAgD;AAChD,qDAAgD;AAChD,uDAAkD;AAClD,2EAAqE;AAExD,QAAA,QAAQ,GAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAupBnC,CAAA;AAEU,QAAA,KAAK,GAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0KlC,CAAA;AAEY,QAAA,KAAK,GAAiB;IACjC,qBAAS;IACT,0CAAmB;IACnB,gCAAc;IACd,oCAAgB;IAChB,4BAAY;IACZ,gCAAc;IACd,8BAAa;IACb,iDAAsB;IACtB,6CAAoB;IACpB,2CAAmB;IACnB,6CAAoB;IACpB,mDAAuB;IACvB,uCAAiB;IACjB,uCAAiB;IACjB,qCAAgB;IAChB,uCAAiB;IACjB,8BAAa;IACb,4BAAY;IACZ,sCAAiB;IACjB,2CAAmB;IACnB,0BAAW;IACX,wCAAkB;IAClB,+CAAqB;IACrB,kCAAe;IACf,mDAAuB;IACvB,mDAAuB;IACvB,wDAAyB;IACzB,0DAAyB;IACzB,mCAAe;IACf,iDAAqB;IACrB,8DAA4B;IAC5B,gCAAc;IACd,gDAAqB;CACtB,CAAA"}
|