fy36
2025-07-01 350eb5ec9163d3ea21416b1525bb80191e958071
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
--[[
    编码: WMS-18-01
    名称: 收货单明细-创建前
    作者:HAN  
    日期:2025-1-29
 
    级别:固定 (说明本段代码在项目中不太会变化)
    
    函数: BeforeDataObjCreate
 
    功能:
        1) 如何没有行号或行号 =0 则系统自动生成行号
    更改记录:
        V6.0 HAN 2023/9/6  -- lua.Error/lua.Debug 函数变化  
--]]
json  = require ("json")
mobox = require ("OILua_JavelinExt")
m3 = require("oi_base_mobox")
 
function BeforeDataObjCreate ( strLuaDEID ) 
    local   nRet, strRetInfo
 
    -- 获取 S_RECEIPT_NO,N_ROW_NO
    nRet, strRetInfo = mobox.getCurEditDataObjAttr( strLuaDEID, "S_RECEIPT_NO","N_ROW_NO" ) 
    if ( nRet ~= 0 )  then lua.Error( strLuaDEID, debug.getinfo(1), "获取当前编辑属性失败! "..strRetInfo ) end 
 
    local obj_attrs = json.decode( strRetInfo ) 
    local receipt_no = obj_attrs[1].value                 -- 收货单号
    local row_no = lua.StrToNumber( obj_attrs[2].value )      -- 行号
    if ( receipt_no == '' )  then lua.Error( strLuaDEID, debug.getinfo(1), "S_RECEIPT_NO 不能为空! " ) end 
 
    -- 如果行号=0 获取当前最大行号
    if ( row_no == 0 ) then
        nRet,strRetInfo = mobox.getSerialMaxNumber( "行号", receipt_no ) 
        if ( nRet ~= 0 )  then lua.Error( strLuaDEID, debug.getinfo(1), "getSerialMaxNumber() 失败! "..strRetInfo ) end  
        row_no = lua.StrToNumber( strRetInfo ) 
        -- 设置行号
        local   attr_value = {}
        attr_value[1] = lua.KeyValueObj( "N_ROW_NO", row_no )
        nRet, strRetInfo = mobox.setCurEditDataObjAttr( strLuaDEID, lua.table2str(attr_value) ) 
        if ( nRet ~= 0 ) then lua.Error( strLuaDEID, debug.getinfo(1), "设置【收货单明细】信息失败!  "..strRetInfo ) end   
    end
end