--[[
|
编码: JX-24-19
|
名称: 出库单-完工回报
|
作者:HAN
|
日期:2025-1-29
|
级别:项目
|
|
函数: CompletionReturn
|
|
功能:
|
检查一下【出库单】中出库明细中的出库数量是否等于 计划出库数量,如果全部都已经出库完成
|
需要把出库情况反馈给上游系统,根据出库单的创建方式不同向不同的来源报完工
|
|
更改记录:
|
V2.0 HAN 20241126
|
拣料箱相同只出现一个
|
--]]
|
jx_base= require( "jx_base" )
|
jx_api = require ( "jx_external_api")
|
|
local function set_outbound_detail_pick_box_code( strLuaDEID, oo_no )
|
local nRet, strRetInfo, pick_box_code, n, m, strUpdateSql
|
|
local strCondition = "S_OO_NO = '"..oo_no.."'"
|
local strOrder = "N_ROW_NO"
|
local oo_detail_objs
|
nRet, oo_detail_objs = m3.QueryDataObject(strLuaDEID, "Outbound_Detail", strCondition, strOrder)
|
if (nRet ~= 0) then
|
lua.Error(strLuaDEID, debug.getinfo(1), "获取【Outbound_Detail】信息失败! " .. oo_detail_objs)
|
end
|
local obj_attrs, dc_detail_objs
|
-- 遍历出库单明细
|
for n = 1, #oo_detail_objs do
|
local picking_box_set = {}
|
obj_attrs = m3.KeyValueAttrsToObjAttr(oo_detail_objs[n].attrs)
|
|
-- 从【配盘明细】中获取 拣料箱编码
|
strCondition = "S_BS_NO = '"..oo_no.."' AND S_BS_TYPE = 'Outbound_Order' AND S_ITEM_CODE = '"..obj_attrs.S_ITEM_CODE.."'"
|
nRet, dc_detail_objs = m3.QueryDataObject(strLuaDEID, "Distribution_CNTR_Detail", strCondition, "")
|
if (nRet ~= 0) then
|
lua.Error(strLuaDEID, debug.getinfo(1), "获取【Distribution_CNTR_Detail】信息失败! " .. dc_detail_objs)
|
end
|
pick_box_code = ''
|
for m = 1, #dc_detail_objs do
|
obj_attrs = m3.KeyValueAttrsToObjAttr(dc_detail_objs[m].attrs)
|
-- V2.0 检查一下拣料箱是否已经存在
|
if ( lua.IsInTable( obj_attrs.S_PICK_BOX_CODE, picking_box_set ) == false ) then
|
table.insert( picking_box_set, obj_attrs.S_PICK_BOX_CODE )
|
if ( pick_box_code ~= '' ) then
|
pick_box_code = pick_box_code..","
|
end
|
pick_box_code = pick_box_code..obj_attrs.S_PICK_BOX_CODE
|
end
|
end
|
|
strUpdateSql = "S_PICK_BOX_CODE = '"..pick_box_code.."'"
|
strCondition = "S_ID = '"..oo_detail_objs[n].id.."'"
|
nRet, strRetInfo = mobox.updateDataAttrByCondition( strLuaDEID, "Outbound_Detail", strCondition, strUpdateSql )
|
if ( nRet ~= 0 ) then lua.Error( strLuaDEID, debug.getinfo(1), "更新【预分配容器】信息失败!"..strRetInfo ) end
|
end
|
end
|
|
function CompletionReturn ( strLuaDEID )
|
local nRet, strRetInfo
|
local oo_obj = {}
|
nRet, oo_obj = m3.GetSysCurEditDataObj( strLuaDEID, "Outbound_Order" )
|
if (nRet ~= 0) then lua.Error( strLuaDEID, debug.getinfo(1), "获取【出库单】对象属性失败!"..oo_obj ) end
|
|
-- 如果已经报过完工或报工,不需要报完工,如果没完成也不需要执行后面的报告
|
-- b_state = 4 出库单状态为完成
|
if ( oo_obj.cr_state ~= 0 or oo_obj.b_state ~= 4 ) then return end
|
|
if ( oo_obj.create_method == "JW-WMS" ) then
|
-- 把【配盘明细】中的 pick_box_code 加到 出库单明细中
|
set_outbound_detail_pick_box_code( strLuaDEID, oo_obj.no )
|
nRet, strRetInfo = jx_api.JW_WMS_API_subPickDown( strLuaDEID, oo_obj.no )
|
else
|
nRet = 0
|
end
|
|
-- 更新出库单的完工回报属性
|
local curTime = os.date("%Y-%m-%d %H:%M:%S")
|
strCondition = "S_NO = '"..oo_obj.no.."'"
|
local strSetAttr
|
if ( nRet == 0 ) then
|
strSetAttr = "N_B_STATE = 4, N_CR_STATE = 1, S_CR_ERR = '', T_CR = '"..curTime.."'"
|
else
|
lua.Debug( strLuaDEID, debug.getinfo(1), "JW-WMS subPickDown接口错误", strRetInfo )
|
strSetAttr = "N_B_STATE = 4, N_CR_STATE = 2, S_CR_ERR = 'JW-WMS subPickDown接口错误, 详细信息看日志!', T_CR = '"..curTime.."'"
|
end
|
|
lua.Debug( strLuaDEID, debug.getinfo(1), "strCondition", strCondition )
|
lua.Debug( strLuaDEID, debug.getinfo(1), "strSetAttr", strSetAttr )
|
|
nRet, strRetInfo = mobox.updateDataAttrByCondition( strLuaDEID, "Outbound_Order", strCondition, strSetAttr )
|
if ( nRet ~= 0 ) then lua.Error( strLuaDEID, debug.getinfo(1), "更新【出库单】完工回报信息失败!"..strRetInfo ) end
|
end
|