fy36
2025-05-14 a37aca60ff9914b0abb710f04118b22420f4f398
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
--[[
    编码: 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