@things-factory/worksheet-base 4.3.184 → 4.3.186
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/ecommerce/ecommerce-controller.js +4 -1
- package/dist-server/controllers/ecommerce/ecommerce-controller.js.map +1 -1
- package/dist-server/controllers/ecommerce/sellercraft-controller.js +10 -1
- package/dist-server/controllers/ecommerce/sellercraft-controller.js.map +1 -1
- package/dist-server/controllers/outbound/picking-worksheet-controller.js +13 -2
- package/dist-server/controllers/outbound/picking-worksheet-controller.js.map +1 -1
- package/dist-server/controllers/pos/xilnex-controller.js +5 -1
- package/dist-server/controllers/pos/xilnex-controller.js.map +1 -1
- package/dist-server/controllers/render-ro-do.js +7 -3
- package/dist-server/controllers/render-ro-do.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/confirm-cancellation-release-order.js +23 -1
- package/dist-server/graphql/resolvers/worksheet/confirm-cancellation-release-order.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/inventories-by-pallet.js +36 -27
- package/dist-server/graphql/resolvers/worksheet/inventories-by-pallet.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-batch-picking.js +16 -2
- package/dist-server/graphql/resolvers/worksheet/picking/complete-batch-picking.js.map +1 -1
- package/dist-server/graphql/resolvers/worksheet/picking/complete-picking.js +15 -3
- package/dist-server/graphql/resolvers/worksheet/picking/complete-picking.js.map +1 -1
- package/dist-server/index.js +1 -0
- package/dist-server/index.js.map +1 -1
- package/dist-server/utils/index.js +1 -0
- package/dist-server/utils/index.js.map +1 -1
- package/dist-server/utils/lmd-util.js +76 -0
- package/dist-server/utils/lmd-util.js.map +1 -0
- package/package.json +13 -13
- package/server/controllers/ecommerce/ecommerce-controller.ts +4 -1
- package/server/controllers/ecommerce/sellercraft-controller.ts +15 -1
- package/server/controllers/outbound/picking-worksheet-controller.ts +18 -7
- package/server/controllers/pos/xilnex-controller.ts +6 -1
- package/server/controllers/render-ro-do.ts +4 -0
- package/server/graphql/resolvers/worksheet/confirm-cancellation-release-order.ts +22 -1
- package/server/graphql/resolvers/worksheet/inventories-by-pallet.ts +80 -42
- package/server/graphql/resolvers/worksheet/picking/complete-batch-picking.ts +16 -2
- package/server/graphql/resolvers/worksheet/picking/complete-picking.ts +16 -2
- package/server/index.ts +1 -0
- package/server/utils/index.ts +1 -0
- package/server/utils/lmd-util.ts +86 -0
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { LastMileAPI, LastMileDelivery } from '@things-factory/integration-lmd'
|
|
2
|
+
import { logger } from '@things-factory/env'
|
|
3
|
+
import { GeoArea } from '@things-factory/geography'
|
|
4
|
+
import { Bizplace } from '@things-factory/biz-base'
|
|
5
|
+
import { ReleaseGood, OrderPackage } from '@things-factory/sales-base'
|
|
6
|
+
|
|
7
|
+
export async function createLmdParcel(releaseGoods, tx) {
|
|
8
|
+
try {
|
|
9
|
+
let parcelsRequest = []
|
|
10
|
+
for (let releaseGood of releaseGoods) {
|
|
11
|
+
|
|
12
|
+
const lmd: LastMileDelivery = releaseGood.lastMileDelivery
|
|
13
|
+
|
|
14
|
+
const bizplace: Bizplace = await tx.getRepository(Bizplace).findOne({
|
|
15
|
+
where: { domain: releaseGood.domain },
|
|
16
|
+
relations: ['domain']
|
|
17
|
+
})
|
|
18
|
+
|
|
19
|
+
const senderGeoArea: GeoArea = await tx
|
|
20
|
+
.getRepository(GeoArea)
|
|
21
|
+
.findOne({ where: { postalCode: bizplace.postalCode } })
|
|
22
|
+
|
|
23
|
+
let data = {
|
|
24
|
+
courier: lmd.platform,
|
|
25
|
+
clientId: lmd?.clientId,
|
|
26
|
+
clientPass: lmd?.secretKey,
|
|
27
|
+
pickupAccountId: lmd?.pickupAccountId,
|
|
28
|
+
soldToAccountId: lmd?.soldToAccountId,
|
|
29
|
+
token: lmd?.accessToken,
|
|
30
|
+
|
|
31
|
+
recipient: releaseGood.attentionTo,
|
|
32
|
+
phone: releaseGood.phone1,
|
|
33
|
+
email: releaseGood.email,
|
|
34
|
+
address: releaseGood.deliveryAddress1,
|
|
35
|
+
address2: releaseGood.deliveryAddress2,
|
|
36
|
+
city: releaseGood.city,
|
|
37
|
+
postcode: releaseGood.postalCode,
|
|
38
|
+
district: releaseGood.city,
|
|
39
|
+
state: releaseGood.state,
|
|
40
|
+
country: releaseGood.country,
|
|
41
|
+
|
|
42
|
+
pAddress: bizplace.address,
|
|
43
|
+
pAddress2: bizplace.address2,
|
|
44
|
+
pCity: senderGeoArea.cityName,
|
|
45
|
+
pPostcode: senderGeoArea.postalCode,
|
|
46
|
+
pDistrict: senderGeoArea.cityName,
|
|
47
|
+
pState: senderGeoArea.stateName,
|
|
48
|
+
pCountry: senderGeoArea.countryCode,
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
let unprocessedOrderPackages: OrderPackage[] = releaseGood.orderPackages.filter(op => !op.parcelId)
|
|
52
|
+
|
|
53
|
+
let packagesData = unprocessedOrderPackages.map(op => {
|
|
54
|
+
return {
|
|
55
|
+
...data,
|
|
56
|
+
refNo: op.id,
|
|
57
|
+
items: op.orderPackageItems.map(opi => {
|
|
58
|
+
return {
|
|
59
|
+
quantity: opi?.releaseQty?.toString() || ' ',
|
|
60
|
+
item: opi.orderProduct.product.name.slice(0, 49).trim() || ' ',
|
|
61
|
+
sku: opi.orderProduct.product.sku || ' ',
|
|
62
|
+
price: opi?.orderProduct.productDetail?.costPrice?.toString() || ' ',
|
|
63
|
+
weight: opi?.orderProduct.productDetail?.grossWeight?.toString() || ' ',
|
|
64
|
+
width: opi?.orderProduct.productDetail?.width?.toString() || ' ',
|
|
65
|
+
length: opi?.orderProduct.productDetail?.depth?.toString() || ' ',
|
|
66
|
+
height: opi?.orderProduct.productDetail?.height?.toString() || ' '
|
|
67
|
+
}
|
|
68
|
+
})
|
|
69
|
+
}
|
|
70
|
+
})
|
|
71
|
+
parcelsRequest.push(...packagesData)
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
if (parcelsRequest && parcelsRequest.length > 0) {
|
|
75
|
+
let res = await LastMileAPI.createParcel(
|
|
76
|
+
{ ...releaseGoods[0].lastMileDelivery, platform: 'lmdMiddleware' },
|
|
77
|
+
parcelsRequest
|
|
78
|
+
)
|
|
79
|
+
for (let parcel of res) {
|
|
80
|
+
await tx.getRepository(OrderPackage).update({ id: parcel.refNo }, { parcelId: parcel.parcelId })
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
} catch (e) {
|
|
84
|
+
logger.error(`[lmd-create-parcel]: ${e}`)
|
|
85
|
+
}
|
|
86
|
+
}
|