@things-factory/worksheet-base 4.3.113-alpha.0 → 4.3.114
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/inbound/unloading-worksheet-controller.js +73 -58
- package/dist-server/controllers/inbound/unloading-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/inspect/cycle-count-worksheet-controller.js +4 -2
- package/dist-server/controllers/inspect/cycle-count-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/loading-worksheet-controller.js +4 -10
- package/dist-server/controllers/outbound/loading-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/packing-worksheet-controller.js +24 -33
- package/dist-server/controllers/outbound/packing-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/picking-worksheet-controller.js +48 -78
- package/dist-server/controllers/outbound/picking-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/outbound/sorting-worksheet-controller.js +14 -12
- package/dist-server/controllers/outbound/sorting-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/render-orientage-do.js +1 -1
- package/dist-server/controllers/render-orientage-do.js.map +1 -1
- package/dist-server/controllers/render-orientage-grn.js +1 -1
- package/dist-server/controllers/render-orientage-grn.js.map +1 -1
- package/dist-server/controllers/vas/vas-worksheet-controller.js +2 -1
- package/dist-server/controllers/vas/vas-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/worksheet-controller.js +9 -7
- package/dist-server/controllers/worksheet-controller.js.map +1 -1
- package/dist-server/entities/index.js +2 -3
- package/dist-server/entities/index.js.map +1 -1
- package/dist-server/entities/warehouse-bizplace-onhand-inventory.js +62 -29
- package/dist-server/entities/warehouse-bizplace-onhand-inventory.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/batch-picking-worksheet.js +0 -6
- package/dist-server/graphql/resolvers/worksheet/batch-picking-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/confirm-cancellation-release-order.js +39 -1
- package/dist-server/graphql/resolvers/worksheet/confirm-cancellation-release-order.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/cycle-count-adjustment.js +6 -6
- package/dist-server/graphql/resolvers/worksheet/cycle-count-adjustment.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/cycle-count-worksheet.js +2 -1
- package/dist-server/graphql/resolvers/worksheet/cycle-count-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inventories-by-pallet.js +1 -2
- package/dist-server/graphql/resolvers/worksheet/inventories-by-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/packing-worksheet.js +1 -4
- package/dist-server/graphql/resolvers/worksheet/packing-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-batch-picking.js +3 -3
- package/dist-server/graphql/resolvers/worksheet/picking/complete-batch-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-picking.js +51 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking-worksheet.js +2 -3
- package/dist-server/graphql/resolvers/worksheet/picking-worksheet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/transfer.js +9 -9
- package/dist-server/graphql/resolvers/worksheet/transfer.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloaded-inventories.js +1 -1
- package/dist-server/graphql/resolvers/worksheet/unloaded-inventories.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/common-utils.js +17 -17
- package/dist-server/graphql/resolvers/worksheet/vas-transactions/common-utils.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.js +4 -4
- package/dist-server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.js.map +1 -1
- package/dist-server/graphql/types/worksheet/index.js +1 -1
- package/dist-server/graphql/types/worksheet/index.js.map +1 -1
- package/dist-server/graphql/types/worksheet-detail/index.js +0 -1
- package/dist-server/graphql/types/worksheet-detail/index.js.map +1 -1
- package/dist-server/utils/inventory-util.js +98 -1
- package/dist-server/utils/inventory-util.js.map +1 -1
- package/package.json +18 -17
- package/server/controllers/inbound/unloading-worksheet-controller.ts +86 -72
- package/server/controllers/inspect/cycle-count-worksheet-controller.ts +4 -2
- package/server/controllers/outbound/loading-worksheet-controller.ts +3 -9
- package/server/controllers/outbound/packing-worksheet-controller.ts +36 -41
- package/server/controllers/outbound/picking-worksheet-controller.ts +66 -98
- package/server/controllers/outbound/sorting-worksheet-controller.ts +12 -12
- package/server/controllers/render-orientage-do.ts +1 -1
- package/server/controllers/render-orientage-grn.ts +12 -12
- package/server/controllers/vas/vas-worksheet-controller.ts +2 -2
- package/server/controllers/worksheet-controller.ts +12 -15
- package/server/entities/index.ts +2 -2
- package/server/entities/warehouse-bizplace-onhand-inventory.ts +63 -29
- package/server/graphql/resolvers/worksheet/batch-picking-worksheet.ts +0 -6
- package/server/graphql/resolvers/worksheet/confirm-cancellation-release-order.ts +43 -1
- package/server/graphql/resolvers/worksheet/cycle-count-adjustment.ts +2 -2
- package/server/graphql/resolvers/worksheet/cycle-count-worksheet.ts +1 -0
- package/server/graphql/resolvers/worksheet/find-sorting-release-orders-by-task-no.ts +62 -62
- package/server/graphql/resolvers/worksheet/inventories-by-pallet.ts +1 -3
- package/server/graphql/resolvers/worksheet/packing-worksheet.ts +2 -4
- package/server/graphql/resolvers/worksheet/picking/complete-batch-picking.ts +3 -3
- package/server/graphql/resolvers/worksheet/picking/complete-picking.ts +57 -1
- package/server/graphql/resolvers/worksheet/picking-worksheet.ts +2 -3
- package/server/graphql/resolvers/worksheet/transfer.ts +16 -18
- package/server/graphql/resolvers/worksheet/unloaded-inventories.ts +1 -1
- package/server/graphql/resolvers/worksheet/vas-transactions/common-utils.ts +2 -3
- package/server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.ts +1 -4
- package/server/graphql/types/worksheet/index.ts +2 -2
- package/server/graphql/types/worksheet-detail/index.ts +0 -1
- package/server/utils/inventory-util.ts +126 -1
|
@@ -76,7 +76,6 @@ export async function pickingWorksheet(
|
|
|
76
76
|
.leftJoinAndSelect('T_INV.binLocation', 'BIN_LOC')
|
|
77
77
|
.leftJoinAndSelect('T_INV.inventory', 'INV')
|
|
78
78
|
.leftJoinAndSelect('T_INV.product', 'PROD')
|
|
79
|
-
.leftJoinAndSelect('T_INV.productDetail', 'PROD_DET')
|
|
80
79
|
.leftJoinAndSelect('INV.location', 'LOC')
|
|
81
80
|
|
|
82
81
|
if (locationSortingRules?.length > 0) {
|
|
@@ -115,8 +114,8 @@ export async function pickingWorksheet(
|
|
|
115
114
|
const inventoryChangesCount: number = await tx.getRepository(InventoryChange).count({
|
|
116
115
|
where: {
|
|
117
116
|
inventory: inventory.id,
|
|
118
|
-
status:
|
|
119
|
-
transactionType:
|
|
117
|
+
status: "PENDING",
|
|
118
|
+
transactionType: "MISSING"
|
|
120
119
|
},
|
|
121
120
|
relations: ['inventory', 'product']
|
|
122
121
|
})
|
|
@@ -1,36 +1,38 @@
|
|
|
1
|
-
import { EntityManager } from 'typeorm'
|
|
2
|
-
|
|
3
1
|
import { User } from '@things-factory/auth-base'
|
|
4
2
|
import { Bizplace } from '@things-factory/biz-base'
|
|
5
|
-
import { ORDER_PRODUCT_STATUS, OrderInventory } from '@things-factory/sales-base'
|
|
6
3
|
import { Domain } from '@things-factory/shell'
|
|
4
|
+
import { OrderInventory, ORDER_PRODUCT_STATUS } from '@things-factory/sales-base'
|
|
7
5
|
import {
|
|
8
6
|
Inventory,
|
|
9
|
-
INVENTORY_STATUS,
|
|
10
|
-
INVENTORY_TRANSACTION_TYPE,
|
|
11
7
|
InventoryHistory,
|
|
12
|
-
InventoryNoGenerator
|
|
8
|
+
InventoryNoGenerator,
|
|
9
|
+
INVENTORY_STATUS,
|
|
10
|
+
INVENTORY_TRANSACTION_TYPE
|
|
13
11
|
} from '@things-factory/warehouse-base'
|
|
14
|
-
|
|
12
|
+
import { EntityManager } from 'typeorm'
|
|
15
13
|
import { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../constants'
|
|
16
14
|
import { Worksheet, WorksheetDetail } from '../../../entities'
|
|
17
15
|
|
|
18
16
|
export const transfer = {
|
|
19
17
|
async transfer(_: any, { palletId, toPalletId, qty }, context: any) {
|
|
20
|
-
const {
|
|
21
|
-
|
|
18
|
+
const {
|
|
19
|
+
tx,
|
|
20
|
+
domain,
|
|
21
|
+
bizplace,
|
|
22
|
+
user
|
|
23
|
+
}: { tx: EntityManager; domain: Domain; bizplace: Bizplace; user: User } = context.state
|
|
22
24
|
|
|
23
25
|
// 1. get to inventory
|
|
24
26
|
let toInventory: Inventory = await tx.getRepository(Inventory).findOne({
|
|
25
27
|
where: { domain: domain, palletId: toPalletId },
|
|
26
|
-
relations: ['bizplace', 'product', '
|
|
28
|
+
relations: ['bizplace', 'product', 'warehouse', 'location']
|
|
27
29
|
})
|
|
28
30
|
if (!toInventory) throw new Error(`to pallet doesn't exists`)
|
|
29
31
|
|
|
30
32
|
// 2. get from inventory
|
|
31
33
|
let fromInventory: Inventory = await tx.getRepository(Inventory).findOne({
|
|
32
34
|
where: { domain: domain, palletId },
|
|
33
|
-
relations: ['bizplace', 'product', '
|
|
35
|
+
relations: ['bizplace', 'product', 'warehouse', 'location']
|
|
34
36
|
})
|
|
35
37
|
if (!fromInventory) throw new Error(`from pallet doesn't exists`)
|
|
36
38
|
if (toInventory.batchId !== fromInventory.batchId) throw new Error(`Can't transfer to different batch`)
|
|
@@ -72,7 +74,6 @@ export const transfer = {
|
|
|
72
74
|
domain: domain,
|
|
73
75
|
name: InventoryNoGenerator.inventoryHistoryName(),
|
|
74
76
|
product: toInventory.product,
|
|
75
|
-
productDetail: toInventory.productDetail,
|
|
76
77
|
warehouse: toInventory.warehouse,
|
|
77
78
|
location: toInventory.location,
|
|
78
79
|
seq: toInventory.lastSeq,
|
|
@@ -96,7 +97,7 @@ export const transfer = {
|
|
|
96
97
|
|
|
97
98
|
fromInventory = await tx.getRepository(Inventory).findOne({
|
|
98
99
|
where: { id: fromInventory.id },
|
|
99
|
-
relations: ['bizplace', 'product', '
|
|
100
|
+
relations: ['bizplace', 'product', 'warehouse', 'location']
|
|
100
101
|
})
|
|
101
102
|
|
|
102
103
|
// - add inventory history
|
|
@@ -104,7 +105,6 @@ export const transfer = {
|
|
|
104
105
|
...fromInventory,
|
|
105
106
|
name: InventoryNoGenerator.inventoryHistoryName(),
|
|
106
107
|
product: fromInventory.product,
|
|
107
|
-
productDetail: fromInventory.productDetail,
|
|
108
108
|
warehouse: fromInventory.warehouse,
|
|
109
109
|
location: fromInventory.location,
|
|
110
110
|
seq: fromInventory.lastSeq,
|
|
@@ -131,7 +131,7 @@ export const transfer = {
|
|
|
131
131
|
|
|
132
132
|
toInventory = await tx.getRepository(Inventory).findOne({
|
|
133
133
|
where: { id: toInventory.id },
|
|
134
|
-
relations: ['bizplace', 'product', '
|
|
134
|
+
relations: ['bizplace', 'product', 'warehouse', 'location']
|
|
135
135
|
})
|
|
136
136
|
// - add inventory history
|
|
137
137
|
delete toInventory.id
|
|
@@ -140,7 +140,6 @@ export const transfer = {
|
|
|
140
140
|
domain,
|
|
141
141
|
name: InventoryNoGenerator.inventoryHistoryName(),
|
|
142
142
|
product: toInventory.product,
|
|
143
|
-
productDetail: toInventory.productDetail,
|
|
144
143
|
warehouse: toInventory.warehouse,
|
|
145
144
|
location: toInventory.location,
|
|
146
145
|
seq: toInventory.lastSeq,
|
|
@@ -158,7 +157,7 @@ export const transfer = {
|
|
|
158
157
|
|
|
159
158
|
fromInventory = await tx.getRepository(Inventory).findOne({
|
|
160
159
|
where: { id: fromInventory.id },
|
|
161
|
-
relations: ['bizplace', 'product', '
|
|
160
|
+
relations: ['bizplace', 'product', 'warehouse', 'location']
|
|
162
161
|
})
|
|
163
162
|
|
|
164
163
|
// - add inventory history
|
|
@@ -166,7 +165,6 @@ export const transfer = {
|
|
|
166
165
|
...fromInventory,
|
|
167
166
|
name: InventoryNoGenerator.inventoryHistoryName(),
|
|
168
167
|
product: fromInventory.product,
|
|
169
|
-
productDetail: fromInventory.productDetail,
|
|
170
168
|
warehouse: fromInventory.warehouse,
|
|
171
169
|
location: fromInventory.location,
|
|
172
170
|
seq: fromInventory.lastSeq,
|
|
@@ -44,7 +44,7 @@ export const unloadedInventories = {
|
|
|
44
44
|
orderProductId: In(foundWorksheetDetails.map(wsd => wsd.targetProduct.id)),
|
|
45
45
|
status: In([INVENTORY_STATUS.UNLOADED, INVENTORY_STATUS.CHECKED])
|
|
46
46
|
},
|
|
47
|
-
relations: ['reusablePallet', 'product', 'bizplace'
|
|
47
|
+
relations: ['reusablePallet', 'product', 'bizplace']
|
|
48
48
|
})
|
|
49
49
|
const items = foundInv.map((inv: Inventory) => {
|
|
50
50
|
const expirationDate: Date = inv.expirationDate ? new Date(inv.expirationDate) : null
|
|
@@ -19,13 +19,12 @@ import {
|
|
|
19
19
|
InventoryNoGenerator,
|
|
20
20
|
Location,
|
|
21
21
|
Pallet,
|
|
22
|
-
Warehouse
|
|
23
|
-
generateInventoryHistory
|
|
22
|
+
Warehouse
|
|
24
23
|
} from '@things-factory/warehouse-base'
|
|
25
24
|
|
|
26
25
|
import { WORKSHEET_STATUS, WORKSHEET_TYPE } from '../../../../constants'
|
|
27
26
|
import { Worksheet, WorksheetDetail } from '../../../../entities'
|
|
28
|
-
import { WorksheetNoGenerator } from '../../../../utils'
|
|
27
|
+
import { generateInventoryHistory, WorksheetNoGenerator } from '../../../../utils'
|
|
29
28
|
import {
|
|
30
29
|
OperationGuideInterface,
|
|
31
30
|
PackingUnits,
|
package/server/graphql/resolvers/worksheet-detail/regenerate-release-good-worksheet-details.ts
CHANGED
|
@@ -19,7 +19,7 @@ import { WorksheetNoGenerator } from '../../../utils'
|
|
|
19
19
|
export const regenerateReleaseGoodWorksheetDetailsResolver = {
|
|
20
20
|
async regenerateReleaseGoodWorksheetDetails(
|
|
21
21
|
_: any,
|
|
22
|
-
{ worksheetNo, batchId, productId,
|
|
22
|
+
{ worksheetNo, batchId, productId, packingType, packingSize, orderProductId, worksheetDetails },
|
|
23
23
|
context: any
|
|
24
24
|
): Promise<void> {
|
|
25
25
|
const { tx, domain, user }: { tx: EntityManager; domain: Domain; user: User } = context.state
|
|
@@ -30,7 +30,6 @@ export const regenerateReleaseGoodWorksheetDetailsResolver = {
|
|
|
30
30
|
worksheetNo,
|
|
31
31
|
batchId,
|
|
32
32
|
productId,
|
|
33
|
-
productDetailId,
|
|
34
33
|
packingType,
|
|
35
34
|
packingSize,
|
|
36
35
|
orderProductId,
|
|
@@ -46,7 +45,6 @@ export async function regenerateReleaseGoodWorksheetDetails(
|
|
|
46
45
|
worksheetNo: string,
|
|
47
46
|
batchId: string,
|
|
48
47
|
productId: string,
|
|
49
|
-
productDetailId: string,
|
|
50
48
|
packingType: string,
|
|
51
49
|
packingSize: number,
|
|
52
50
|
orderProductId: string,
|
|
@@ -117,7 +115,6 @@ export async function regenerateReleaseGoodWorksheetDetails(
|
|
|
117
115
|
batchIdRef: inventory.batchIdRef,
|
|
118
116
|
status: ORDER_INVENTORY_STATUS.READY_TO_PICK,
|
|
119
117
|
product: await tx.getRepository(Product).findOne(productId),
|
|
120
|
-
productDetail: productDetailId,
|
|
121
118
|
packingType,
|
|
122
119
|
packingSize,
|
|
123
120
|
orderProduct: targetProduct,
|
|
@@ -346,8 +346,8 @@ export const Mutation = /* GraphQL */ `
|
|
|
346
346
|
): Boolean @privilege(category: "worksheet_execute", privilege: "mutation") @transaction
|
|
347
347
|
|
|
348
348
|
scanProductSorting (
|
|
349
|
-
taskNo: String!
|
|
350
349
|
releaseGoodNo: String!
|
|
350
|
+
taskNo: String!
|
|
351
351
|
productBarcode: String!
|
|
352
352
|
serialNumber: String
|
|
353
353
|
toteNo: String
|
|
@@ -718,7 +718,7 @@ export const Query = /* GraphQL */ `
|
|
|
718
718
|
findReleaseOrdersByTaskNo(taskNo: String!): FindReleaseOrdersByTaskNo @privilege(category: "worksheet", privilege: "query") @transaction
|
|
719
719
|
`
|
|
720
720
|
|
|
721
|
-
export const Types = /* GraphQL */[
|
|
721
|
+
export const Types = /* GraphQL */ [
|
|
722
722
|
Worksheet,
|
|
723
723
|
SellercraftDocument,
|
|
724
724
|
NewWorksheet,
|
|
@@ -4,9 +4,134 @@ import { User } from '@things-factory/auth-base'
|
|
|
4
4
|
import { Bizplace } from '@things-factory/biz-base'
|
|
5
5
|
import { Product } from '@things-factory/product-base'
|
|
6
6
|
import { Domain } from '@things-factory/shell'
|
|
7
|
-
import {
|
|
7
|
+
import {
|
|
8
|
+
Inventory,
|
|
9
|
+
INVENTORY_STATUS,
|
|
10
|
+
InventoryHistory,
|
|
11
|
+
InventoryNoGenerator,
|
|
12
|
+
Location,
|
|
13
|
+
LOCATION_STATUS,
|
|
14
|
+
LOCATION_TYPE
|
|
15
|
+
} from '@things-factory/warehouse-base'
|
|
8
16
|
|
|
9
17
|
/**
|
|
18
|
+
* @description It will insert new record into inventory histories table.
|
|
19
|
+
* seq will be calculated based on number of records for one specific pallet id (provided by inventory object)
|
|
20
|
+
*/
|
|
21
|
+
export async function generateInventoryHistory(
|
|
22
|
+
inventory: Inventory,
|
|
23
|
+
refOrder: any,
|
|
24
|
+
transactionType: string,
|
|
25
|
+
qty: number = 0,
|
|
26
|
+
uomValue: number = 0,
|
|
27
|
+
user: User,
|
|
28
|
+
trxMgr?: EntityManager,
|
|
29
|
+
targetInventory: Inventory = {}
|
|
30
|
+
): Promise<InventoryHistory> {
|
|
31
|
+
const invHistoryRepo: Repository<InventoryHistory> =
|
|
32
|
+
trxMgr?.getRepository(InventoryHistory) || getRepository(InventoryHistory)
|
|
33
|
+
const invRepo: Repository<Inventory> = trxMgr?.getRepository(Inventory) || getRepository(Inventory)
|
|
34
|
+
|
|
35
|
+
if (!inventory?.id) throw new Error(`Can't find out ID of inventory.`)
|
|
36
|
+
if (!refOrder?.id || !refOrder.name) throw new Error(`Can't find out ID or Name of Reference Order`)
|
|
37
|
+
if (
|
|
38
|
+
!inventory?.domain ||
|
|
39
|
+
!inventory?.bizplace ||
|
|
40
|
+
!inventory?.product?.id ||
|
|
41
|
+
!inventory?.warehouse?.id ||
|
|
42
|
+
!inventory?.location?.id
|
|
43
|
+
) {
|
|
44
|
+
inventory = await invRepo.findOne({
|
|
45
|
+
where: { id: inventory.id },
|
|
46
|
+
relations: ['domain', 'bizplace', 'product', 'warehouse', 'location']
|
|
47
|
+
})
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
const domain: Domain = inventory.domain
|
|
51
|
+
const location: Location = inventory.location
|
|
52
|
+
|
|
53
|
+
const seq: number = await invHistoryRepo.count({ domain: inventory.domain, palletId: inventory.palletId })
|
|
54
|
+
let openingQty: number = 0
|
|
55
|
+
let openingUomValue: number = 0
|
|
56
|
+
|
|
57
|
+
if (seq) {
|
|
58
|
+
const lastInvHistory: InventoryHistory = await invHistoryRepo.findOne({
|
|
59
|
+
domain: inventory.domain,
|
|
60
|
+
palletId: inventory.palletId,
|
|
61
|
+
seq: seq - 1
|
|
62
|
+
})
|
|
63
|
+
|
|
64
|
+
openingQty = lastInvHistory.openingQty + lastInvHistory.qty
|
|
65
|
+
openingUomValue = lastInvHistory.openingUomValue + lastInvHistory.uomValue
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
if (transactionType == 'PICKING' || transactionType == 'UNLOADING') {
|
|
69
|
+
const [findSameOrderHistory, total]: InventoryHistory = await invHistoryRepo.findAndCount({
|
|
70
|
+
domain: inventory.domain,
|
|
71
|
+
palletId: inventory.palletId,
|
|
72
|
+
refOrderId: refOrder.id
|
|
73
|
+
})
|
|
74
|
+
|
|
75
|
+
if (findSameOrderHistory) {
|
|
76
|
+
let prevTotalQty = 0
|
|
77
|
+
let prevTotalUomValue = 0
|
|
78
|
+
for (let oh of findSameOrderHistory) {
|
|
79
|
+
prevTotalQty += oh.qty
|
|
80
|
+
prevTotalUomValue += oh.uomValue
|
|
81
|
+
}
|
|
82
|
+
qty -= prevTotalQty
|
|
83
|
+
uomValue -= prevTotalUomValue
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
let inventoryHistory: InventoryHistory = new InventoryHistory()
|
|
88
|
+
inventoryHistory.name = InventoryNoGenerator.inventoryHistoryName()
|
|
89
|
+
inventoryHistory.description = inventory.description
|
|
90
|
+
inventoryHistory.seq = seq
|
|
91
|
+
inventoryHistory.palletId = inventory.palletId
|
|
92
|
+
inventoryHistory.cartonId = inventory.cartonId
|
|
93
|
+
inventoryHistory.batchId = inventory.batchId
|
|
94
|
+
inventoryHistory.batchIdRef = inventory.batchIdRef
|
|
95
|
+
inventoryHistory.status = inventory.status
|
|
96
|
+
inventoryHistory.transactionType = transactionType
|
|
97
|
+
inventoryHistory.refOrderId = refOrder?.id || null
|
|
98
|
+
inventoryHistory.orderNo = refOrder?.name || null
|
|
99
|
+
inventoryHistory.orderRefNo = refOrder?.refNo || null
|
|
100
|
+
inventoryHistory.inventory = inventory
|
|
101
|
+
inventoryHistory.targetInventory = targetInventory
|
|
102
|
+
inventoryHistory.product = inventory.product
|
|
103
|
+
inventoryHistory.reusablePallet = inventory.reusablePallet
|
|
104
|
+
inventoryHistory.zone = inventory.zone
|
|
105
|
+
inventoryHistory.warehouse = inventory.warehouse
|
|
106
|
+
inventoryHistory.location = inventory.location
|
|
107
|
+
inventoryHistory.expirationDate = inventory.expirationDate
|
|
108
|
+
inventoryHistory.packingType = inventory.packingType
|
|
109
|
+
inventoryHistory.packingSize = inventory.packingSize
|
|
110
|
+
inventoryHistory.uom = inventory.uom
|
|
111
|
+
inventoryHistory.qty = qty
|
|
112
|
+
inventoryHistory.openingQty = openingQty
|
|
113
|
+
inventoryHistory.uomValue = uomValue
|
|
114
|
+
inventoryHistory.openingUomValue = openingUomValue
|
|
115
|
+
inventoryHistory.unitCost = inventory.unitCost
|
|
116
|
+
inventoryHistory.domain = inventory.domain
|
|
117
|
+
inventoryHistory.bizplace = inventory.bizplace
|
|
118
|
+
inventoryHistory.creator = user
|
|
119
|
+
inventoryHistory.updater = user
|
|
120
|
+
|
|
121
|
+
inventoryHistory = await invHistoryRepo.save(inventoryHistory)
|
|
122
|
+
|
|
123
|
+
if (inventory.lastSeq !== seq) {
|
|
124
|
+
await invRepo.save({
|
|
125
|
+
id: inventory.id,
|
|
126
|
+
lastSeq: inventoryHistory.seq,
|
|
127
|
+
updater: user
|
|
128
|
+
})
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
await switchLocationStatus(domain, location, user, trxMgr)
|
|
132
|
+
return inventoryHistory
|
|
133
|
+
}
|
|
134
|
+
|
|
10
135
|
/**
|
|
11
136
|
* @description: Check location emptiness and update status of location
|
|
12
137
|
* @param domain
|