1
Jianw
2025-07-09 f6f5e6b632d6649386a380558d84003f3de7ec6c
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
--[[
    编码: GK-56-10
    名称: 预分配容器明细-3055顶部窗口初始化
    作者:HAN  
    日期:2025-6-25
 
    级别:固定 (说明本段代码在项目中不太会变化)
    
    函数: InitialTopViewDlg
 
    功能:
        -- 获取当前登录人的账号和姓名
        -- 获取本机登录的 MAC 地址,这个在网页版是实现不了的,需要在MBC运行
 
 
    更改记录:
 
--]]
 
wms_base = require( "wms_base" )
 
function InitialTopViewDlg ( strLuaDEID ) 
    local nRet, strRetInfo
 
    -- 获取当前登录人员账号名称及PC绑定的站台
    local login_info
    nRet, login_info = wms_base.Get_CurLoginUserInfo( strLuaDEID )
    if ( nRet ~= 0 ) then lua.Error( strLuaDEID, debug.getinfo(1), login_info ) end
    
    local strCondition = ""
    local nCount = 0            -- 未执行任务数量
    local station_list = {}
    local cur_station = ''
    if ( login_info.station ~= '') then
        -- 获取当前站台的作业类型
        table.insert( station_list, login_info.station )
        cur_station = login_info.station
        station_enable = false                  -- 不能选站台
    else
        -- 获取所有可用的站台,类型是 WS(TP/SW)类型
        local station_objs, obj_attrs
 
        strCondition = "C_ENABLE = 'Y' AND S_TYPE = 'WS(TP/SW)'"
        nRet, station_objs = m3.QueryDataObject( strLuaDEID, "Machine_Station", strCondition, "S_CODE" )
        if nRet ~= 0 then 
            lua.Stop( strLuaDEID, "获取【Machine_Station】信息失败! " .. station_objs ) 
            return
        end
    
         for _, obj in ipairs( station_objs ) do
            obj_attrs = m3.KeyValueAttrsToObjAttr(obj.attrs)  
            table.insert( station_list, obj_attrs.S_CODE )  
         end  
         station_enable = true              
    end
 
    local action =  {
        {
            action_type = "set_dlg_attr",
            value = {
                { attr = "Operator", value = login_info.user_name, enable = false },
                { attr = "S_STATION_NO", value = cur_station, choice_list = station_list, enable = station_enable }
            }
        }
    }
 
    if ( login_info.station ~= '') then
        -- 查询到站台了可以进行入库的预分配料箱明细
        strCondition = "S_STATION_NO = '"..cur_station.."' AND N_B_STATE = "..PAC_DETAIL_STATE.Palletizing   
        action[2] = {
            action_type = "set_query_condition",
            value = {
                condition = strCondition,
                order = "S_SET_CODE",
                page_name = "当前任务"
            }            
        }
        mobox.removeCacheGroup( "Station:"..login_info.station )
    end
 
    nRet, strRetInfo = mobox.setAction( strLuaDEID, lua.table2str(action)  )
    if ( nRet ~= 0 ) then 
        lua.Stop( strLuaDEID, "setAction失败! "..strRetInfo )
        return
    end 
 
end