yangle
2023-08-15 a52df0c1a9ceca0df214701b9990b66726fd4600
产线组装追溯单
1个文件已修改
2个文件已添加
1617 ■■■■■ 已修改文件
WebTM/views/index.html 9 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
WebTM/views/车间管理/产线组装追溯/Cj_AssemblyTraceability.html 844 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
WebTM/views/车间管理/产线组装追溯/Cj_AssemblyTraceabilityList.html 764 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
WebTM/views/index.html
@@ -366,7 +366,7 @@
                                            <a>报表</a>
                                            <dl class="layui-nav-child">
                                                <dd><a lay-href="生产管理/日计划报表/ReportPODemandPlanBillList.html" style="margin: 0 0 0 13px;">提料计划报表(采购订单维度)</a></dd>
                                                <!--<dd><a lay-href="生产管理/日计划报表/ReportPODemandPlanBillList_S.html" style="margin: 0 0 0 13px;">提料计划报表</a></dd>-->
                                                <dd><a lay-href="生产管理/日计划报表/ReportPODemandPlanBillList_S.html" style="margin: 0 0 0 13px;">提料计划报表</a></dd>
                                                <dd><a lay-href="生产管理/日计划报表/ReportWorkDemandPlanBillList.html" style="margin: 0 0 0 13px;">要料计划报表</a></dd>
                                                <dd><a lay-href="生产管理/日计划报表/ReportMOMaterReadysBillList.html" style="margin: 0 0 0 13px;">齐套报表</a></dd>
                                                <dd><a lay-href="生产管理/日计划报表/MaterialShorAnalysisReport.html" style="margin: 0 0 0 13px;">缺料分析报表</a></dd>
@@ -555,6 +555,13 @@
                                        <dd><a lay-href="车间管理/叫料管理/生产日计划单/Sc_WorkBillAutoSortBillMain.html">生产日计划单列表</a></dd>
                                    </dl>
                                </dd>
                                <dd>
                                    <a>产线组装追溯</a>
                                    <dl class="layui-nav-child append" id="append">
                                        <dd><a lay-href="车间管理/产线组装追溯/Cj_AssemblyTraceability.html">产线组装追溯单</a></dd>
                                        <dd><a lay-href="车间管理/产线组装追溯/Cj_AssemblyTraceabilityList.html">产线组装追溯列表</a></dd>
                                    </dl>
                                </dd>
                            </dl>
                        </li>
                        <!-- è´¨é‡ç®¡ç† -->
WebTM/views/³µ¼ä¹ÜÀí/²úÏß×é×°×·ËÝ/Cj_AssemblyTraceability.html
New file
@@ -0,0 +1,844 @@
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>产线组装追溯单</title>
    <link rel="stylesheet" href="../../../layuiadmin/layui/css/layui.css" media="all">
    <link rel="stylesheet" href="../../../layuiadmin/style/admin.css" media="all">
    <script src="../../../layuiadmin/zgqCustom/zgqCustom.js"></script>
    <script src="../../../layuiadmin/layui/layui.js"></script>
    <script src="../../../layuiadmin/Scripts/json2.js"></script>
    <script src="../../../layuiadmin/Scripts/jquery-1.4.1.js"></script>
    <script src="../../../layuiadmin/Scripts/webConfig.js"></script>
    <script src="../../../layuiadmin/PubCustom.js"></script>
    <style>
        .main-btn { /*头部主按钮*/
            padding: 0 2px; /*调整按钮左右空隙大小*/
            height: 30px;
            line-height: 30px;
        }
        .btn-title {
            font-size: 16px;
        }
    </style>
</head>
<body>
    <div class="layui-fluid" style="padding: 0;">
        <div class="layui-card" style="padding: 2px;background-color: #efefef;">
            <div class="layui-card-body" style="padding: 1px;">
                <form class="layui-form" action="" lay-filter="formData" style="background-color:white;">
                    <div style="padding: 10px;">
                        <button class="layui-btn layui-btn-normal" style="margin-left: 0px" type="button" lay-submit="" lay-filter="btnSave" id="btnSave">保存</button>
                        <button class="layui-btn layui-btn-normal" style="margin-left: 0px" type="button" lay-submit="" lay-filter="btnSave" id="btnSave">退出</button>
                    </div>
                    <div class="layui-tab" lay-filter="tab-POStockInBill">
                        <ul class="layui-tab-title" lay-filter="tab-all">
                            <li lay-id="1" style="padding:1px;" class="layui-this">采集信息</li>
                        </ul>
                        <div class="layui-tab-content">
                            <!--基本信息-->
                            <div class="layui-tab-item layui-show">
                                <div class="layui-form-item" style="padding-top: 10px;">
                                    <div class="layui-row">
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">条形码:</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" name="HBarCode" lay-verify="HBarCode" placeholder="请键入后回车" id="HBarCode" style="width: 500px;">
                                            </div>
                                        </div>
                                    </div>
                                    <div class="layui-row">
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">单据号</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" name="HBillNo" lay-verify="HBillNo" id="HBillNo" style="background-color:#efefef4d;" readonly>
                                                <input type="hidden" name="HInterID" id="HInterID" lay-verify="HInterID">
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">创建人</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" name="HMaker" lay-verify="HMaker" id="HMaker" style="background-color:#efefef4d;" readonly>
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 68px;">生产订单</label>
                                            <div class="layui-input-block" style="margin-left: 100px;">
                                                <input type="text" class="layui-input" name="HICMOBillNo" lay-verify="HICMOBillNo" id="HICMOBillNo" value="" style="background-color: #efefef4d; display: inline-block;" readonly>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="layui-row">
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">产品MAC</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" lay-verify="HMateMAC" name="HMateMAC" id="HMateMAC" style="background-color:#efefef4d;" readonly>
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">产品SN</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" name="HMateSN" lay-verify="HMateSN" id="HMateSN" style="background-color:#efefef4d;display: inline-block;" readonly>
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 65px;">产品编码</label>
                                            <div class="layui-input-block" style="margin-left: 100px;">
                                                <input type="text" class="layui-input" lay-verify="HMaterNumber" name="HMaterNumber" id="HMaterNumber" style="background-color:#efefef4d;" readonly>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="layui-row">
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">产品名称</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" lay-verify="HMaterName" name="HMaterName" id="HMaterName" style="background-color:#efefef4d;" readonly>
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">规格型号</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" lay-verify="HMaterModel" name="HMaterModel" id="HMaterModel" style="background-color:#efefef4d;" readonly>
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 70px;">状态</label>
                                            <div class="layui-input-block" style="margin-left: 100px; width: 184px;">
                                                <select name="HAssemblyStatus" id="HAssemblyStatus" lay-verify="HAssemblyStatus">
                                                    <option value="生产中" selected>生产中</option>
                                                    <option value="汇报">汇报</option>
                                                    <option value="检验">检验</option>
                                                    <option value="包装">包装</option>
                                                    <option value="入库">入库</option>
                                                </select>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="layui-row">
                                        <div class="layui-inline" style="width: 56%;">
                                            <label class="layui-form-label" style="width: 85px;">备注</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" name="HRemark" id="HRemark" lay-verify="HRemark" placeholder="请输入内容" onmouseover="this.title=this.value" style="width: 50%;">
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                    <div class="layui-tab layui-tab-card" style="width: 49%; float: left;">
                        <ul class="layui-tab-title">
                            <li class="layui-this">关键件清单</li>
                        </ul>
                        <div class="layui-tab-content">
                            <div class="layui-tab-item layui-show">
                                <!--关键件清单-->
                                <table class="layui-hide" id="mainTable2" lay-filter="mainTable2"></table>
                            </div>
                        </div>
                    </div>
                    <div class="layui-tab layui-tab-card" style="width: 49%; float: left; margin-left: 1%; ">
                        <ul class="layui-tab-title">
                            <li class="layui-this">采集记录</li>
                        </ul>
                        <div class="layui-tab-content">
                            <div class="layui-tab-item layui-show">
                                <!--采集记录-->
                                <table class="layui-hide" id="mainTable" lay-filter="mainTable"></table>
                            </div>
                        </div>
                    </div>
                    <script type="text/html" id="toolbarDemo">
                        <div class="layui-btn-container">
                            <button type="button" class="layui-btn layui-btn-sm" lay-event="btn-AddLine"><i class="layui-icon layui-icon-form"></i>增加一行</button>
                            <button type="button" class="layui-btn layui-btn-sm" lay-event="btn-CopyLine"><i class="layui-icon layui-icon-form"></i>复制一行</button>
                        </div>
                    </script>
                    <script type="text/html" id="toolbarDemo2">
                        <div class="layui-btn-container">
                            <button type="button" class="layui-btn layui-btn-sm" lay-event="btn-AddLine2"><i class="layui-icon layui-icon-form"></i>增加一行</button>
                            <button type="button" class="layui-btn layui-btn-sm" lay-event="btn-CopyLine2"><i class="layui-icon layui-icon-form"></i>复制一行</button>
                        </div>
                    </script>
                </form>
            </div>
            <input type="hidden" id="HPRDORGID" value="0"/>
        </div>
    </div>
    <script type="text/html" id="barDemo">
        <!--<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>-->
        <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
    </script>
    <script type="text/html" id="barDemo2">
        <!--<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>-->
        <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
    </script>
    <script>
        layui.config({
            base: '../../../layuiadmin/' //静态资源所在路径
        }).extend({
            index: 'lib/index' //主入口模块
        }).use(['index', 'form', 'laydate', 'table', 'element'], function () {
            //#region å…¬å…±å˜é‡
            var $ = layui.$
                , admin = layui.admin
                , layer = layui.layer
                , table = layui.table
                , form = layui.form
                , element = layui.element;
            var option = [];
            var option2 = [];
            //#endregion
            //#region è¿›å…¥é¡µé¢å³åŠ è½½
            var params = getUrlVars();
            var OperationType = params[params[0]]; //从参数中获取 æ•°æ®ç±»åž‹  æ·»åŠ  ä¿å­˜
            var linterid = params[params[1]]; //从参数中获取 å•据内码
            //判断是否新增
            if (linterid == null || linterid == 0) {
                OperationType = 1;
                $.ajax({
                    url: GetWEBURL() + "/Web/GetMAXNum",
                    type: "GET",
                    data: { "HBillType": '3727' },
                    success: function (d) {
                        //赋值
                        $("#HInterID").val(d.data[0].HInterID);
                        $("#HBillNo").val(d.data[0].HBillNo);
                    }
                });
            }
            else {//如果修改则走下面 new
                RoadBillMain(linterid);
            }
            //初始化界面
            set_ClearBill();
            //#endregion
            //#region  è§¦å‘事件:包括form.on(){}格式的所有点击事件、选择事件等
            //条形码回车方法
            $('#HBarCode').on('keydown', function (event) {
                var HBarCode = $('#HBarCode').val();
                if (event.keyCode == 13) {
                    if (!HBarCode) {
                        layer.msg("条形码不能为空!")
                        return;
                    }
                    txtHBarCode_KeyDown(HBarCode);
                }
            });
            //头工具栏事件
            table.on('toolbar(mainTable)', function (obj) {
                var checkStatus = table.checkStatus('mainTable')
                    , data = checkStatus.data;
                //新增行表格数据
                var NewRow = {
                    "HDate": "", "HMaterName": "", "HMaterID": 0, "HBarCode": "", "HBarCode_P": "",
                    "HICMOBillNo": ""
                };
                switch (obj.event) {
                    case 'btn-AddLine':
                        table.cache["mainTable"].push(NewRow);
                        option.data = table.cache["mainTable"];
                        table.render(option);
                        break;
                    case 'btn-CopyLine':
                        var copydata = JSON.stringify(data);
                        if (data.length <= 0) {
                            layer.msg("请选择需要复制的一行!");
                        }
                        else if (data.length > 1) {
                            layer.msg("只能选择复制一行!");
                        }
                        else {
                            var copydata2 = copydata.substring(1, copydata.length);//去除首行字符'['
                            var copyrow = copydata2.substring(0, copydata2.length - 1);//去除末尾字符']'
                            table.cache["mainTable"].push(JSON.parse(copyrow));//将复制的行强转成json追加到表格上
                            option.data = table.cache["mainTable"];//将数据绑定到data上
                            table.render(option);//将数据渲染到表格上
                            //layer.alert(copyrow);
                        }
                        break;
                }
            });
            table.on('toolbar(mainTable2)', function (obj) {
                var checkStatus = table.checkStatus('mainTable2')
                    , data = checkStatus.data;
                //新增行表格数据
                var NewRow = {
                    "HDate": "", "HMaterName": "", "HMaterID": 0, "HMaterModel": "", "HQty": 0,
                    "HBardQty": 0
                };
                switch (obj.event) {
                    case 'btn-AddLine2':
                        table.cache["mainTable2"].push(NewRow);
                        option2.data = table.cache["mainTable2"];
                        table.render(option2);
                        break;
                    case 'btn-CopyLine2':
                        var copydata = JSON.stringify(data);
                        if (data.length <= 0) {
                            layer.msg("请选择需要复制的一行!");
                        }
                        else if (data.length > 1) {
                            layer.msg("只能选择复制一行!");
                        }
                        else {
                            var copydata2 = copydata.substring(1, copydata.length);//去除首行字符'['
                            var copyrow = copydata2.substring(0, copydata2.length - 1);//去除末尾字符']'
                            table.cache["mainTable2"].push(JSON.parse(copyrow));//将复制的行强转成json追加到表格上
                            option2.data = table.cache["mainTable2"];//将数据绑定到data上
                            table.render(option2);//将数据渲染到表格上
                            //layer.alert(copyrow);
                        }
                        break;
                }
            });
            //行内事件
            table.on('tool(mainTable)', function (obj) {
                set_GridDelete(obj);   //行内删除
                set_GridCellCheck(obj); //行内快捷键筛选
            });
            //行内事件
            table.on('tool(mainTable2)', function (obj) {
                set_GridDelete2(obj);   //行内删除
                //set_GridCellCheck2(obj); //行内快捷键筛选
            });
            //保存提交
            form.on('submit(btnSave)', function (data) {//提交
                //为空验证
                if (AllowLoadData(data)) {
                    set_AddNew(data,3);
                }
            });
            //#endregion
            //#region æ­¤é¡µé¢æ‰€æœ‰çš„æ–¹æ³•
            // åˆå§‹åŒ–界面
            function set_ClearBill() {
                //判断是否登录 æœªç™»å½•则跳到登录页
                if (sessionStorage.login != "login") {
                    layer.confirm("登录失效,请重新登录!", {
                        icon: 4, skin: 'layui-layer-lan', title: "温馨提示", closeBtn: 0, btn: ['重新登录']
                    }, function () { window.location.href = "../../user/login.html"; });
                }
                set_InitGrid();
                set_InitGrid2();
                //制单人
                $("#HMaker").val(sessionStorage["HUserName"]);
                $("#HPRDORGID").val(sessionStorage["OrganizationID"]);//组织
                //初始化日期
                $("#HPlanBeginDate").val(Format(new Date(), "yyyy-MM-dd"));
                $("#HPlanEndDate").val(Format(new Date(), "yyyy-MM-dd"));
                $("#HDate").val(Format(new Date(), "yyyy-MM-dd"));
            }
            function set_InitGrid() {
                //子表  åˆå§‹åŒ–表格数据
                option = {
                    elem: '#mainTable'
                    //, toolbar: '#toolbarDemo'
                    , limit: 500 //每页默认显示的数量
                    , cellMinWidth: 120
                    , height: 400
                    , cols: [[ //表头
                        { type: 'checkbox', totalRowText: '合计行' }
                        , { type: 'numbers', title: '序号', totalRow: true }
                        , { field: 'HDate', title: '日期', edit: 'text' }
                        , { field: 'HMaterName', title: '产品名称', edit: 'text', event: "hprocid" }//f7
                        , { field: 'HMaterID', title: 'HMaterID ', hide: true }//f7
                        , { field: 'HBarCode', title: 'SN码', edit: 'text' }
                        , { field: 'HBarCode_P', title: '配件SN码', edit: 'text' }
                        , { field: 'HICMOBillNo', title: '订单号', edit: 'text' }
                        , { field: 'HPRDORGID', title: 'HPRDORGID', hide: true }
                        , { fixed: 'right', title: '操作', toolbar: '#barDemo' }
                    ]]
                };
                //var rowdata = [{
                //    "HDate": "", "HMaterName": "", "HMaterID": 0, "HBarCode": "", "HBarCode_P": "",
                //    "HICMOBillNo": ""
                //}];
                option.data = [];
                table.render(option);
            }
            function set_InitGrid2() {
                //子表  åˆå§‹åŒ–表格数据
                option2 = {
                    elem: '#mainTable2'
                    //, toolbar: '#toolbarDemo2'
                    , limit: 500 //每页默认显示的数量
                    , cellMinWidth: 120
                    , height: 400
                    , cols: [[ //表头
                        { type: 'checkbox', totalRowText: '合计行' }
                        , { type: 'numbers', title: '序号', totalRow: true }
                        , { field: 'HDate', title: '日期', edit: 'text' }
                        , { field: 'HMaterName', title: '配件名称', edit: 'text', event: "hprocid" }//f7
                        , { field: 'HMaterID', title: 'HMaterID ', hide: true}//f7
                        , { field: 'HMaterModel', title: '配件规格', edit: 'text' }
                        , { field: 'HQty', title: '配件数量', edit: 'text' }
                        , { field: 'HBardQty', title: '已扫数量', edit: 'text' }
                        , { field: 'HPRDORGID', title: 'HPRDORGID', hide: true }
                        , { fixed: 'right', title: '操作', toolbar: '#barDemo2' }
                    ]]
                };
                var rowdata = [{
                    "HDate": "", "HMaterName": "", "HMaterID": 0, "HMaterModel": "", "HQty": 0,
                    "HBardQty": 0, "HPRDORGID": $("#HPRDORGID").val()
                }];
                option2.data = rowdata;
                table.render(option2);
            }
            function txtHBarCode_KeyDown(HBarCode) {
                var index = layer.load();
                $.ajax({
                    type: "GET",
                    url: GetWEBURL() + "/Sc_AssemblyBill/HBardCodeList",
                    async: true,
                    data: { "HBarCode": HBarCode, "user": sessionStorage["HUserName"], "HICMOBillNo": $("#HICMOBillNo").val()},
                    dataType: "json",
                    success: function (data) {
                        if (data.count == 1) {
                            if ($("#HICMOBillNo").val() == "") {
                                $("#HICMOBillNo").val(data.data[0]["FMOBILLNO"]);
                                $("#HMateSN").val($("#HBarCode").val());
                                $("#HMaterNumber").val(data.data[0]["HMaterNumber"]);
                                $("#HMaterName").val(data.data[0]["HMaterName"]);
                                $("#HMaterModel").val(data.data[0]["HMaterModel"]);
                                var num = [];
                                for (var i = 0; i < data.data.length; i++) {
                                    num.push({
                                        "HDate": Format(new Date().getTime(), 'yyyy-MM-dd hh:mm:ss'), "HMaterName": data.data[i]["HMaterName_z"], "HMaterID": data.data[i]["HMaterID"], "HMaterModel": data.data[i]["HMaterModel_z"], "HQty": data.data[i]["FMUSTQTY"],
                                        "HBardQty": 0, "HPRDORGID": $("#HPRDORGID").val()
                                    });
                                }
                                option2.data = num;
                                table.render(option2);
                                set_AddNew([], 1);
                            } else {
                                var num = option.data;
                                for (var i = 0; i < data.data.length; i++) {
                                    num.push({
                                        "HDate": Format(new Date().getTime(), 'yyyy-MM-dd hh:mm:ss'), "HMaterName": data.data[i]["HMaterName"], "HMaterID": data.data[i]["HMaterID"], "HBarCode": $("#HMateSN").val(), "HBarCode_P": $("#HBarCode").val(),
                                        "HICMOBillNo": data.data[i]["HSourceBillNo"], "HPRDORGID": $("#HPRDORGID").val()
                                    });
                                }
                                for (var i = 0; i < option2.data.length; i++) {
                                    if (option2.data[i]["HMaterID"] == data.data[0]["HMaterID"]) {
                                        option2.data[i]["HBardQty"] += data.data[0]["HQty"];
                                    }
                                }
                                option.data = num;
                                table.render(option);
                                table.render(option2);
                            }
                            layer.close(index);
                            layer.msg("提交成功");
                            $("#HBarCode").val("");
                        }
                        else {
                            layer.close(index);
                            layer.msg(data.Message, { icon: 5, btn: ['确认'], time: 100000, offset: 't', skin: 'layui-layer-lan', title: "温馨提示" });
                        }
                    },
                    error: function (err) {
                        layer.close(index);
                        layer.msg("错误:" + err, { icon: 5, btn: ['确认'], time: 100000, offset: 't', skin: 'layui-layer-lan', title: "温馨提示" });
                    }
                });
            }
            //行内删除
            function set_GridDelete(obj) {
                var data = obj.data;
                var rowIndex = $(obj.tr).attr("data-index");
                if (obj.event === 'del') {
                    layer.confirm('真的删除行吗?', function (index) {
                        if (rowIndex === '0') {
                            layer.msg('首行无法删除!!!');
                        } else {
                            var oldData = table.cache["mainTable"];
                            oldData.splice(obj.tr.data('index'), 1)
                            option.data = oldData;//将数据绑定到data上
                            table.render(option);
                            layer.close(index);
                        }
                    });
                }
            }
            //行内删除
            function set_GridDelete2(obj) {
                var data = obj.data;
                var rowIndex = $(obj.tr).attr("data-index");
                if (obj.event === 'del') {
                    layer.confirm('真的删除行吗?', function (index) {
                        if (rowIndex === '0') {
                            layer.msg('首行无法删除!!!');
                        } else {
                            var oldData = table.cache["mainTable2"];
                            oldData.splice(obj.tr.data('index'), 1)
                            option2.data = oldData;//将数据绑定到data上
                            table.render(option2);
                            layer.close(index);
                        }
                    });
                }
            }
            //行内快捷键
            function set_GridCellCheck(obj) {
                $(document).off('keydown', ".layui-table-edit").on('keydown', ".layui-table-edit", function (e) {
                    if (event.key == "F7") {
                        //工序
                        if (obj.event == "hprocid") {
                            layer.open({
                                type: 2 //弹窗类型
                                , skin: "layui-layer-rim" //加上边框
                                , title: "工序列表" //标题
                                , closeBtn: 1  //窗体右上角 å…³é—­çš„æ ·å¼
                                , shift: 2 //弹出动画
                                , area: ["90%", "90%"] //窗体大小
                                , maxmin: true //设置窗体最大最小按钮是否显示
                                , content: ["../../Baseset/基础资料/Gy_ProcList.html", "yes"]
                                , btn: ["确定", "取消"]
                                , btn1: function (index) {//按钮一 å›žè°ƒ
                                    var iframeWindow = window["layui-layer-iframe" + index]; //获取弹窗页面
                                    var checkStatus = iframeWindow.layui.table.checkStatus("mainTable"); //获取选中行数据
                                    if (checkStatus.data.length != 1) {
                                        return layer.msg("请选中一条数据!");
                                    }
                                    //获取数据/绑定数据
                                    obj.update({
                                        "工序代码": checkStatus.data[0].工序代码
                                        , "工序": checkStatus.data[0].工序
                                        , "hprocid": checkStatus.data[0].HItemID
                                    })
                                    //关闭页面
                                    layer.close(index);
                                }
                            })
                        }
                        //工作中心
                        if (obj.event == "HCenterID") {
                            layer.open({
                                type: 2 //弹窗类型
                                , skin: "layui-layer-rim" //加上边框
                                , title: "工作中心表" //标题
                                , closeBtn: 1  //窗体右上角 å…³é—­çš„æ ·å¼
                                , shift: 2 //弹出动画
                                , area: ["90%", "90%"] //窗体大小
                                , maxmin: true //设置窗体最大最小按钮是否显示
                                , content: ["../../Baseset/基础资料/Gy_WorkCenterList.html", "yes"]
                                , btn: ["确定", "取消"]
                                , btn1: function (index) {//按钮一 å›žè°ƒ
                                    var iframeWindow = window["layui-layer-iframe" + index]; //获取弹窗页面
                                    var checkStatus = iframeWindow.layui.table.checkStatus("mainTable"); //获取选中行数据
                                    if (checkStatus.data.length != 1) {
                                        return layer.msg("请选中一条数据!");
                                    }
                                    //获取数据/绑定数据
                                    obj.update({
                                        "工作中心": checkStatus.data[0].工作中心
                                        , "HCenterID": checkStatus.data[0].HItemID
                                    })
                                    //关闭页面
                                    layer.close(index);
                                }
                            })
                        }
                        //加工车间
                        if (obj.event == "HDeptID") {
                            layer.open({
                                type: 2 //弹窗类型
                                , skin: "layui-layer-rim" //加上边框
                                , title: "部门表" //标题
                                , closeBtn: 1  //窗体右上角 å…³é—­çš„æ ·å¼
                                , shift: 2 //弹出动画
                                , area: ["90%", "90%"] //窗体大小
                                , maxmin: true //设置窗体最大最小按钮是否显示
                                , content: ["../../Baseset/基础资料/Gy_DepartmentList.html", "yes"]
                                , btn: ["确定", "取消"]
                                , btn1: function (index) {//按钮一 å›žè°ƒ
                                    var iframeWindow = window["layui-layer-iframe" + index]; //获取弹窗页面
                                    var checkStatus = iframeWindow.layui.table.checkStatus("mainTable"); //获取选中行数据
                                    if (checkStatus.data.length != 1) {
                                        return layer.msg("请选中一条数据!");
                                    }
                                    //获取数据/绑定数据
                                    obj.update({
                                        "加工车间代码": checkStatus.data[0].HNumber
                                        , "加工车间": checkStatus.data[0].HName
                                        , "HDeptID": checkStatus.data[0].HItemID
                                    })
                                    //关闭页面
                                    layer.close(index);
                                }
                            })
                        }
                        //班组
                        if (obj.event == "HGroupID") {
                            layer.open({
                                type: 2 //弹窗类型
                                , skin: "layui-layer-rim" //加上边框
                                , title: "班组表" //标题
                                , closeBtn: 1  //窗体右上角 å…³é—­çš„æ ·å¼
                                , shift: 2 //弹出动画
                                , area: ["90%", "90%"] //窗体大小
                                , maxmin: true //设置窗体最大最小按钮是否显示
                                , content: ["../../基础资料/工资基础资料/Gy_Group.html", "yes"]
                                , btn: ["确定", "取消"]
                                , btn1: function (index) {//按钮一 å›žè°ƒ
                                    var iframeWindow = window["layui-layer-iframe" + index]; //获取弹窗页面
                                    var checkStatus = iframeWindow.layui.table.checkStatus("mainTable"); //获取选中行数据
                                    if (checkStatus.data.length != 1) {
                                        return layer.msg("请选中一条数据!");
                                    }
                                    //获取数据/绑定数据
                                    obj.update({
                                        "班组代码": checkStatus.data[0].班组代码
                                        , "班组": checkStatus.data[0].班组名称
                                        , "HGroupID": checkStatus.data[0].HItemID
                                    })
                                    //关闭页面
                                    layer.close(index);
                                }
                            })
                        }
                        //操作工
                        if (obj.event == "HWorkerID") {
                            layer.open({
                                type: 2 //弹窗类型
                                , skin: "layui-layer-rim" //加上边框
                                , title: "人员表" //标题
                                , closeBtn: 1  //窗体右上角 å…³é—­çš„æ ·å¼
                                , shift: 2 //弹出动画
                                , area: ["90%", "90%"] //窗体大小
                                , maxmin: true //设置窗体最大最小按钮是否显示
                                , content: ["../../Baseset/基础资料/Gy_EmployeeList.html", "yes"]
                                , btn: ["确定", "取消"]
                                , btn1: function (index) {//按钮一 å›žè°ƒ
                                    var iframeWindow = window["layui-layer-iframe" + index]; //获取弹窗页面
                                    var checkStatus = iframeWindow.layui.table.checkStatus("mainTable"); //获取选中行数据
                                    if (checkStatus.data.length != 1) {
                                        return layer.msg("请选中一条数据!");
                                    }
                                    //获取数据/绑定数据
                                    obj.update({
                                        "操作员": checkStatus.data[0].HName
                                        , "操作员代码": checkStatus.data[0].HNumber
                                        , "HWorkerID": checkStatus.data[0].HItemID
                                    })
                                    //关闭页面
                                    layer.close(index);
                                }
                            })
                        }
                        //生产资源
                        if (obj.event == "HSourceID") {
                            layer.open({
                                type: 2 //弹窗类型
                                , skin: "layui-layer-rim" //加上边框
                                , title: "生产资源表" //标题
                                , closeBtn: 1  //窗体右上角 å…³é—­çš„æ ·å¼
                                , shift: 2 //弹出动画
                                , area: ["90%", "90%"] //窗体大小
                                , maxmin: true //设置窗体最大最小按钮是否显示
                                , content: ["../../基础资料/生产基础资料/Gy_Source.html", "yes"]
                                , btn: ["确定", "取消"]
                                , btn1: function (index) {//按钮一 å›žè°ƒ
                                    var iframeWindow = window["layui-layer-iframe" + index]; //获取弹窗页面
                                    var checkStatus = iframeWindow.layui.table.checkStatus("mainTable"); //获取选中行数据
                                    if (checkStatus.data.length != 1) {
                                        return layer.msg("请选中一条数据!");
                                    }
                                    //获取数据/绑定数据
                                    obj.update({
                                        "生产资源": checkStatus.data[0].生产资源名称
                                        , "HSourceID": checkStatus.data[0].HItemID
                                    })
                                    //关闭页面
                                    layer.close(index);
                                }
                            })
                        }
                    }
                })
            }
            //保存数据
            function set_AddNew(data,num) {
                //过滤子表删除之后留下的空数据
                var num = [];
                for (var i = 0; i < table.cache['mainTable'].length; i++) {
                    //给不能为空的数据 èµ‹å€¼(子)
                    if (table.cache['mainTable'][i] != "") {
                        num.push(table.cache['mainTable'][i]);
                    }
                }
                var num2 = [];
                for (var i = 0; i < table.cache['mainTable2'].length; i++) {
                    //给不能为空的数据 èµ‹å€¼(子)
                    if (table.cache['mainTable2'][i] != "") {
                        num2.push(table.cache['mainTable2'][i]);
                    }
                }
                var sMainStr = JSON.stringify(data.field);
                var sSubStr = "";
                if (num==1) {
                    sSubStr = JSON.stringify(num);
                } else {
                    sSubStr = JSON.stringify(num2);
                }
                var sMainSub = sMainStr + ';' + sSubStr  + ';' + OperationType + ";" + sessionStorage["HUserName"];
                var index = layer.load();
                $.ajax({
                    type: "POST",
                    url: GetWEBURL() + "/Sc_ProcessMangement/AddBill",
                    async: true,
                    data: { "sMainSub": sMainSub },
                    dataType: "json",
                    success: function (data) {
                        if (data.count == 1) {
                            layer.close(index);
                            layer.msg("提交成功");
                        }
                        else {
                            layer.close(index);
                            layer.msg(data.Message, { icon: 5, btn: ['确认'], time: 100000, offset: 't', skin: 'layui-layer-lan', title: "温馨提示" });
                        }
                    },
                    error: function (err) {
                        layer.close(index);
                        layer.msg("错误:" + err, { icon: 5, btn: ['确认'], time: 100000, offset: 't', skin: 'layui-layer-lan', title: "温馨提示" });
                    }
                });
            }
            //编辑
            function RoadBillMain(linterid) {
                var sWhere = " and hmainid ='" + linterid + "' ";
                $.ajax({
                    url: GetWEBURL() + '/Sc_ProcessMangement/MES_Sc_ProcessPlanMain_Json',
                    type: "GET",
                    data: { "sWhere": sWhere },
                    success: function (d) {
                        //主表
                        form.val("formData", { //formTest å³ class="layui-form" æ‰€åœ¨å…ƒç´ å±žæ€§ lay-filter="" å¯¹åº”的值
                            "HBillNo": d.data[0].单据号
                            , "HInterID": d.data[0].hmainid
                            , "HDate": Format(new Date(d.data[0].日期), "yyyy-MM-dd")
                            , "HICMOBillNo": d.data[0].任务单号
                            , "HMaterNumber": d.data[0].物料代码
                            , "HMaterIDName": d.data[0].物料名称
                            , "HMaterID": d.data[0].HMaterID
                            , "HMaterIDNum": d.data[0].规格型号
                            , "HUnitNumber": d.data[0].计量单位代码
                            , "HUnitIDName": d.data[0].计量单位
                            , "HUnitID": d.data[0].hunitid
                            , "HInnerBillNo": d.data[0].内部单据号
                            , "HPlanBeginDate": Format(new Date(d.data[0].计划开工日期), "yyyy-MM-dd")
                            , "HPlanEndDate": Format(new Date(d.data[0].计划完工日期), "yyyy-MM-dd")
                            , "HPlanQty": d.data[0].生产数量
                            , "HExplanation": d.data[0].摘要
                            , "HRemark": d.data[0].表头备注
                        });
                        //子表
                        var rowdata = [{
                            "HProcNo": d.data[0].工序号, "工序代码": d.data[0].工序代码, "工序": d.data[0].工序, "hprocid": d.data[0].hprocid, "HWorkRemark": d.data[0].加工说明,
                            "工作中心": d.data[0].工作中心, "HCenterID": d.data[0].HCenterID, "加工车间代码": d.data[0].加工车间代码, "加工车间": d.data[0].加工车间, "HDeptID": d.data[0].HDeptID,
                            "班组代码": d.data[0].班组代码, "班组": d.data[0].班组名称, "HGroupID": d.data[0].HGroupID, "操作员代码": d.data[0].操作员代码, "操作员": d.data[0].操作员,
                            "HWorkerID": d.data[0].HWorkerID, "生产资源": d.data[0].生产资源, "HSourceID": d.data[0].HSourceID, "HQty": d.data[0].计划数量, "HWorkingQty": d.data[0].在制品数量,
                            "HTimeUnit": d.data[0].时间单位, "HPlanWorkTimes": d.data[0].计划加工时间, "hplanbegindate": (Format(new Date(d.data[0].工序计划开工日期), "yyyyMMdd") == "19000101" ? null : Format(new Date(d.data[0].工序计划开工日期), "yyyy-MM-dd")), "hplanenddate": (Format(new Date(d.data[0].工序计划完工日期), "yyyyMMdd") == "19000101" ? null : Format(new Date(d.data[0].工序计划完工日期), "yyyy-MM-dd")), "HICMOInterID": d.data[0].任务单号id,
                            "HICMOBillNo": d.data[0].子任务单号, "HBeginDayQty": d.data[0].开工固天, "HBeginFixQty": d.data[0].开工固数, "HFixWorkDays": d.data[0].上道固定天数, "HTrunWorkDays": d.data[0].上道循环周期,
                            "HReadyTimes": d.data[0].本道准备时间, "HReadyTime": d.data[0].准备时间, "HQueueTime": d.data[0].排队时间, "HMoveTime": d.data[0].转移时间, "HSeOrderInterID": d.data[0].销售订单主ID,
                            "HSeOrderEntryID": d.data[0].销售订单子ID, "HSeOrderBillNo": d.data[0].销售订单号
                        }];
                        option.data = rowdata;
                        table.render(option);
                    }
                })
            }
            //数据验证
            function AllowLoadData(data) {
                var HMaterIDName = data.field.HMaterIDName;//产品
                var HUnitIDName = data.field.HUnitIDName;//单位
                if (HMaterIDName == "") {
                    layer.msg("请选择产品!");
                    return false;
                }
                if (HUnitIDName == "") {
                    layer.msg("请选择单位!");
                    return false;
                }
                return true;
            }
            //获取参数
            function getUrlVars() {
                var vars = [], hash;
                var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
                for (var i = 0; i < hashes.length; i++) {
                    hash = hashes[i].split('=');
                    vars.push(hash[0]);
                    vars[hash[0]] = hash[1];
                }
                return vars;
            }
            //#endregion
        });
    </script>
</body>
</html>
WebTM/views/³µ¼ä¹ÜÀí/²úÏß×é×°×·ËÝ/Cj_AssemblyTraceabilityList.html
New file
@@ -0,0 +1,764 @@
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>产线组装追溯列表</title>
    <link rel="stylesheet" href="../../../layuiadmin/layui/css/layui.css" media="all">
    <link rel="stylesheet" href="../../../layuiadmin/style/admin.css" media="all">
    <script src="../../../layuiadmin/layui/layui.js"></script>
    <script src="../../../layuiadmin/scripts/jquery-1.4.1.js"></script>
    <script src="../../../layuiadmin/scripts/jquery-1.4.1.min.js"></script>
    <script src="../../../layuiadmin/pubcustom.js"></script>
    <script src="../../../layuiadmin/Scripts/webConfig.js"></script>
</head>
<body>
    <div class="layui-fluid">
        <div class="layui-col-md12">
            <div class="layui-card" style="padding: 1px">
                <div class="layui-card-body" style="padding: 1px;">
                    <form class="layui-form" action="" lay-filter="component-form-group">
                        <div class="layui-collapse">
                            <div class="layui-colla-item">
                                <div class="layui-colla-title layui-inline">
                                    <div class="layui-inline">
                                        <span>更多</span>
                                    </div>
                                </div>
                                <div class="layui-inline">
                                    <label class="layui-form-label">单据号</label>
                                    <div class="layui-input-block">
                                        <input type="text" class="layui-input" name="WorkCenter" id="WorkCenter">
                                    </div>
                                </div>
                                <div class="layui-inline">
                                    <label class="layui-form-label" style="width: 85px;padding: 9px 18px;">物料代码</label>
                                    <div class="layui-input-block" style="margin-left: 77px;">
                                        <input type="hidden" class="layui-input" lay-verify="HMaterID" name="HMaterID" id="HMaterID" value="0" style="background-color:#efefef4d;width: 60%;display: inline-block;" readonly>
                                        <input type="text" class="layui-input" lay-verify="HMaterNumber" name="HMaterNumber" id="HMaterNumber" value="" style="background-color:#efefef4d;width: 60%;display: inline-block;" readonly>
                                        <button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btnHMaterID" id="btnHMaterID" style="padding: 0 10px;float: right;margin-right: 3px;">
                                            <i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>
                                        </button>
                                    </div>
                                </div>
                                <div class="layui-inline">
                                    <label class="layui-form-label" style="width: 85px;">生产订单组织</label>
                                    <div class="layui-input-block" style="margin-left: 120px; width: 185px;">
                                        <select name="HProdOrgID" id="HProdOrgID" lay-verify="HProdOrgID">
                                            <!--动态渲染组织-->
                                        </select>
                                    </div>
                                </div>
                                <button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btnSearch" id="btnSearch">
                                    <i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>
                                </button>
                                <button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btnReSearch" id="btnReSearch" style="padding:0 5px">重置</button>
                                <div class="layui-colla-content" style="padding: 0px; margin-left: 6%;">
                                    <div class="layui-row" style="margin-top:10px;margin-left:5%;">
                                        <!--其他条件-->
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 76px;">物料名称</label>
                                            <div class="layui-input-block" style="margin-left: 107px;">
                                                <input type="text" class="layui-input" name="HMaterName" id="HMaterName">
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <label class="layui-form-label" style="width: 85px;">规格型号</label>
                                            <div class="layui-input-block" style="margin-left: 120px;">
                                                <input type="text" class="layui-input" name="HModel" id="HModel">
                                            </div>
                                        </div>
                                    </div>
                                    <div class="layui-row" style="margin-top: 10px; margin-bottom: 10px ">
                                        <div class="layui-inline">
                                            <label class="layui-form-label">过滤</label>
                                            <div class="layui-input-block">
                                                <select name="ColName" id="ColName" lay-filter="ColName" style="width:190px;">
                                                </select>
                                            </div>
                                        </div>
                                        <div class="layui-inline">
                                            <select name="Comparator" id="Comparator" lay-filter="Comparator" style="width:190px;">
                                                <option value="0" selected="selected"></option>
                                                <option value="=">=</option>
                                                <option value=">=">>=</option>
                                                <option value=">">></option>
                                                <option value="<="><=</option>
                                                <option value="<"><</option>
                                                <option value="<>"><></option>
                                                <option value="7">包含</option>
                                                <option value="8">左包含</option>
                                                <option value="9">右包含</option>
                                                <option value="10">不包含</option>
                                            </select>
                                        </div>
                                        <div class="layui-inline">
                                            <input type="text" class="layui-input" value="" name="ColContent" id="ColContent">
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <table class="" id="mainTable" lay-filter="mainTable"></table>
                        <script type="text/html" id="toolbarDemo">
                            <div class="layui-btn-container">
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_AddNew"><i class="layui-icon layui-icon-file-b"></i>新增</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_ShowBill"><i class="layui-icon layui-icon-form"></i>编辑</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_DeleteBill"><i class="layui-icon layui-icon-delete"></i>删除</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="get_Refresh"><i class="layui-icon layui-icon-refresh-3"></i>刷新</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="get_Exit"><i class="layui-icon layui-icon-logout"></i>退出</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_CheckBill" id="CheckBill"><i class="layui-icon layui-icon-form"></i>审核</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_AbandonCheck" id="AbandonCheck"><i class="layui-icon layui-icon-form"></i>反审核</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_CloseBill" id="set_CloseBill"><i class="layui-icon layui-icon-form"></i>关闭</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_CancelCloseBill" id="set_CancelCloseBill"><i class="layui-icon layui-icon-form"></i>反关闭</button>
                                <button type="button" class="layui-btn layui-btn-sm" lay-event="set_HideColumn"><i class="layui-icon layui-icon-form"></i>列设置</button>
                            </div>
                        </script>
                    </form>
                </div>
            </div>
        </div>
    </div>
</body>
</html>
<script>
    layui.config({
        base: '../../../layuiadmin/' //静态资源所在路径
    }).extend({
        index: 'lib/index', //主入口模块
    }).use(['index', 'form', 'table', 'element', 'laypage', 'laydate'], function () {
        //#region å…¬å…±å˜é‡
        var $ = layui.$
            , admin = layui.admin
            , layer = layui.layer
            , table = layui.table
            , form = layui.form
            , element = layui.element
            , laypage = layui.laypage
            , laydate = layui.laydate
        //var sWhere = " äº§å“ä»£ç  = 'BX0002'";
        var sWhere = "";
        var option = [];
        var ins;                        //用于导出excel
        var HModName = "Cj_AssemblyTraceabilityList";
        var titleData = [];//不需要显示的字段 å¯æ‰©å±•
        //#endregion
        //#region è¿›å…¥é¡µé¢å³åŠ è½½
        //初始化表格
        DisPlay_HideColumn();
        //初始化界面
        set_ClearBill();
        //#endregion
        //#region è§¦å‘事件:包括form.on(){}格式的所有点击事件、选择事件等
        //#region å¤´å·¥å…·æ äº‹ä»¶
        table.on('toolbar(mainTable)', function (obj) {
            switch (obj.event) {
                //新增
                case 'set_AddNew': set_AddNew();
                    break;
                //编辑
                case 'set_ShowBill': set_ShowBill();
                    break;
                //删除
                case 'set_DeleteBill': set_DeleteBill();
                    break;
                //复制
                case 'set_Copy': set_Copy();
                    break;
                //浏览
                case 'get_PrintReport': get_PrintReport();
                    break;
                //刷新
                case 'get_Refresh': get_Refresh();
                    break;
                //审核
                case 'set_CheckBill': set_CheckBill(1);
                    break;
                //反审核
                case 'set_AbandonCheck': set_CheckBill(2);
                    break;
                //关闭
                case 'set_CloseBill': set_CloseBill(1);
                    break;
                //反关闭
                case 'set_CancelCloseBill': set_CloseBill(2);
                    break;
                //退出按钮
                case 'get_Exit': Pub_Close(2);
                    break;
                //列设置
                case 'set_HideColumn': get_HideColumn();
                    break;
            };
        });
        //#endregion
        //#region æŸ¥è¯¢æŒ‰é’®
        form.on('submit(btnSearch)', function (data) {//选择仓位
            get_FastQuery(2);
        });
        //#endregion
        //物料
        form.on('submit(btnHMaterID)', function (data) {//选择仓位
            get_btnHMaterID();
        });
        //重置按钮
        form.on('submit(btnReSearch)', function (data) {
            set_ClearQuery();
        });
        //#endregion
        //#region æ­¤é¡µé¢æ‰€æœ‰çš„æ–¹æ³•
        //获取组织
        function Organ() {
            //获取登录页组织列
            $.ajax({
                type: "get",
                url: GetWEBURL() + "/Web/GetOrganizations",
                success: function (result) {
                    var Organization = "";
                    if (result.count == 1) { // è¯´æ˜ŽéªŒè¯æˆåŠŸäº†ï¼Œ
                        var data = result.data;
                        for (var i = 0; i < data.length; i++) {
                            Organization += '<option  style="color:blue;" value="' + data[i].ID + '">' + data[i].Name + '</option>';
                        }
                        $("#HProdOrgID").append(Organization);
                        $("#HProdOrgID").val(sessionStorage["OrganizationID"])
                        form.render('select');
                    }
                    layer.closeAll("loading");
                }
            })
        }
        //#region åˆå§‹åŒ–界面
        function set_ClearBill() {
            Organ();
            //查询
            get_FastQuery(1);
        }
        //#endregion
        //#region é‡ç½®è¿‡æ»¤æ¡ä»¶æ–¹æ³•
        function set_ClearQuery() {
            $("#WorkCenter").val("");//单据号
            $("#HMaterID").val(0);//物料
            $("#HMaterName").val("");//物料
            $("#HMaterNumber").val("");//物料
            $("#HModel").val("");//物料
            $("#HOrderProcNO").val("");//单据类型
            $("#ColContent").val("");
            $("#ColName").val("0");
            $("#Comparator").val("0");
            $("#HProdOrgID").val(sessionStorage["OrganizationID"]);
            form.render('select');
            $("#btnSearch").click();
            sWhere = "";
        }
        //#endregion
        //物料
        function get_btnHMaterID() {
            layer.open({
                type: 2
                , area: ['80%', '80%']
                , title: '物料'
                , shade: 0.6 //遮罩透明度
                //, maxmin: true //允许全屏最小化
                , anim: 0 //0-6的动画形式,-1不开启
                , content: ['../../Baseset/基础资料/Gy_MaterialList.html', 'yes']
                , btn: ['确定', '取消']
                , btn1: function (index, layero) {
                    //按钮【按钮一】的回调
                    var iframeWindow = window['layui-layer-iframe' + index]  //获取弹框页面
                    var checkStatus = iframeWindow.layui.table.checkStatus('mainTable');//获取table的elem:"#test"
                    if (checkStatus.data.length === 0) {
                        return layer.msg('请选择数据');
                    }
                    $("#HMaterID").val(checkStatus.data[0].HItemID);
                    $("#HMaterName").val(checkStatus.data[0].HName);
                    $("#HMaterNumber").val(checkStatus.data[0].HNumber);
                    layer.close(layer.index); //它获取的始终是最新弹出的某个层,值是由layer内部动态递增计算的
                }
            })
        }
        //#region æŸ¥è¯¢
        function get_Display(sWhere) {
            //sWhere += " and HPRDORGID=" + sessionStorage["OrganizationID"] + " ";
            var ajaxLoad = layer.load();
            $.ajax({
                url: GetWEBURL() + '/Sc_AssemblyBill/list1',
                type: "GET",
                data: { "sWhere": sWhere, "user": sessionStorage["HUserName"] },
                success: function (data1) {
                    if (data1.count == 1) {
                        var data = [];
                        var col = [];
                        //给空的数组赋值
                        for (var key in data1.list) {
                            data.push({ "id": data1.list[key].ColmCols, "name": data1.list[key].ColmCols, "Type": data1.list[key].ColmType });
                        }
                        //在列表左边添加勾选框
                        col.push({ type: 'checkbox', fixed: 'left', totalRowText: '合计' });
                        for (var i = 0; i < data.length; i++) {
                            if ($.inArray(data[i].name, titleData) > -1) {
                                col.push({ field: data[i].id, title: data[i].name, align: 'center', hide: true }); //隐藏id列
                            }
                            else {
                                switch (data[i].Type) {
                                    //int
                                    case 'DateTime':
                                        col.push({ field: data[i].id, title: data[i].name, align: 'center', sort: true, templet: "<div>{{d." + data[i].name + " ==null ?'':layui.util.toDateString(d." + data[i].name + ", 'yyyy-MM-dd')}}</div>", width: 200 });
                                        break;
                                    default:
                                        if (data[i].name == '生产数量' || data[i].name == '流转卡数量' || data[i].name == '入库数量') {
                                            col.push({ field: data[i].id, title: data[i].name, align: 'center', sort: true, width: 200, totalRow: true });
                                        } else {
                                            col.push({ field: data[i].id, title: data[i].name, align: 'center', sort: true, width: 200 });
                                        }
                                }
                            }
                        }
                        //动态显示列名
                        option = {
                            elem: '#mainTable'
                            , toolbar: '#toolbarDemo'
                            , cols: [col]
                            , data: data1.data
                            , height: 800
                            , page: true
                            , totalRow: true
                            , cellMinWidth: 90
                            , limit: 50
                            , limits: [50, 500, 5000, 20000]
                        }
                        table.render(option);
                        //刷新表格数据
                        DisPlay_HideColumn();
                        if ($("#Comparator").val() == 0 && $("#ColContent").val() == "") {
                            ColFilter();
                        }
                        layer.close(ajaxLoad);
                    } else {
                        layer.close(ajaxLoad);
                        layer.alert(data1.code + data1.Message, { icon: 5 });
                    }
                }, error: function () {
                    layer.close(ajaxLoad);
                    layer.alert("接口请求失败!", { icon: 5 });
                }
            });
        }
        //#endregion
        //#region å¿«é€Ÿè¿‡æ»¤
        function get_FastQuery(number) {
            var HProdOrgID = "";
            var HOrderProcNO = $("#HOrderProcNO").val();//单据类型
            //var HMaterID = $("#HMaterID").val();
            var HMaterName = $("#HMaterName").val();
            var HMaterNumber = $("#HMaterNumber").val();
            var HModel = $("#HModel").val();
            var WorkCenter = $("#WorkCenter").val();//单据号
            var ColName = $("#ColName").val();//复选框
            var Comparator = $("#Comparator").val()
            var ColContent = $("#ColContent").val();
            if (ColName != 0 && Comparator != 0) {
                var com = "";
                switch (Comparator) {
                    case "7":
                        com = "like'%" + ColContent + "%'";
                        break;
                    case "8":
                        com = "like'%" + ColContent + "'";
                        break;
                    case "9":
                        com = "like'" + ColContent + "%'";
                        break;
                    case "10":
                        com = "not like'%" + ColContent + "%'";
                        break;
                    default:
                        com = "" + Comparator + "'" + ColContent + "'";
                        break;
                }
                sWhere += " and " + ColName + " " + com;
            }
            if (number == 1) {
                HProdOrgID = sessionStorage["OrganizationID"];
            }
            else {
                HProdOrgID = $("#HProdOrgID").val();//组织
            }
            if (HOrderProcNO) {
                sWhere += " and å•据类型 like '%" + HOrderProcNO + "%'";
            }
            if (HMaterName) {
                sWhere += "and ç‰©æ–™åç§° like '%" + HMaterName + "%'";
            }
            if (HMaterNumber) {
                sWhere += "and  ç‰©æ–™ä»£ç  like '%" + HMaterNumber + "%'";
            }
            if (HModel) {
                sWhere += "and  è§„格型号 like '%" + HModel + "%'";
            }
            if (WorkCenter) {
                sWhere += " and å•据号 like '%" + WorkCenter + "%'";
            }
            if (HProdOrgID) {
                sWhere += " and HProdOrgID = '" + HProdOrgID + "'";
            }
            get_Display(sWhere);
            sWhere = "";//调用接口后清空sWhere缓存
        }
        //#endregion
        //#region æ–°å¢ž
        function set_AddNew() {
            layer.open({
                type: 2
                , skin: 'layui-layer-rim' //加上边框
                , area: ['100%', '100%']
                , title: '工艺路线-新增'
                , shift: 0//弹出动画
                , content: '../工艺路线/Gy_RoutingBill.html?OperationType=1&linterid=&HSouceBillType=&linteridSub=-1'
                , end: function () {
                    //刷新页面,
                    location.reload();
                }
            })
        }
        //#endregion
        //#region ç¼–辑
        function set_ShowBill() {
            var checkStatus = table.checkStatus('mainTable')
                , data = checkStatus.data;
            if (checkStatus.data.length === 1) {
                var linterid = data[0].HItemID;
                //var linteridSub = data[0].hsubid;
                //if (AllowLoadData(sSubStr) != false) {//非空验证
                layer.open({
                    type: 2
                    , area: ['100%', '100%']
                    , title: '工艺路线-编辑'
                    , shift: 0//弹出动画
                    , content: '../工艺路线/Gy_RoutingBill.html?OperationType=3&linterid=' + linterid + '&HSouceBillType='
                    , end: function () {
                        //刷新页面,
                        location.reload();
                    }
                })
            } else {
                layer.msg('请选择一行数据编辑!');
            }
        }
        //#endregion
        //#region åˆ é™¤
        function set_DeleteBill() {
            var checkStatus = table.checkStatus('mainTable')
                , data = checkStatus.data;
            if (checkStatus.data.length === 1) {
                var hmainid = data[0].hmainid;
                layer.confirm("确认要删除吗,删除后不能恢复", { title: "删除确认" }, function (index) {
                    var wait = layer.load();
                    //逻辑删除方法
                    $.ajax({
                        url: GetWEBURL() + '/LEMS/DeltetGy_RoutingBillSub',
                        type: "GET",
                        data: { "lngBillKey": hmainid, "user": sessionStorage["HUserName"] },
                        success: function (result) {
                            console.log('gouba' + result);
                            if (result.count == 1) {
                                layer.msg(result.Message, { icon: 1 }, function () {
                                    // å¾—到frame索引
                                    var index = layer.getFrameIndex(window.name);
                                    //关闭当前frame
                                    layer.close(wait);
                                    //修改为功后刷新界面
                                    window.location.reload();
                                });
                            } else {
                                layer.alert(result.code + result.Message, { icon: 5 });
                                layer.close(wait);
                            }
                        }, error: function () {
                            layer.alert("接口请求失败!", { icon: 5 });
                            layer.close(wait);
                        }
                    });
                })
            }
            else {
                layer.msg('请选择一行数据删除!');
            }
        }
        //#endregion
        //复制
        function set_Copy() {
            var checkStatus = table.checkStatus('mainTable')
                , data = checkStatus.data;
            if (checkStatus.data.length === 1) {
                var linterid = data[0].HItemID;
                layer.open({
                    type: 2
                    , area: ['100%', '100%']
                    , title: '工艺路线-编辑'
                    , shift: 0//弹出动画
                    , content: '../工艺路线/Gy_RoutingBill.html?OperationType=2&linterid=' + linterid + '&HSouceBillType='
                    , end: function () {
                        //刷新页面,
                        location.reload();
                    }
                })
            } else {
                layer.msg('请选择一行数据编辑!');
            }
        }
        //#region åˆ·æ–°
        function get_Refresh() {
            set_ClearQuery();
            get_Display(sWhere);
        }
        //审核   [1 å®¡æ ¸ã€2 åå®¡æ ¸]
        function set_CheckBill(num) {
            var checkStatus = table.checkStatus('mainTable')
                , data = checkStatus.data;
            if (data.length == 1) {
                layer.confirm("确认要审核吗?", function (index) {
                    var wait = layer.load();
                    var HInterID = data[0].hmainid;
                    $.ajax({
                        url: GetWEBURL() + '/Gy_RoutingBill/CheckGy_RoutingBill',
                        type: "GET",
                        data: { "HInterID": HInterID, "Type": num, "user": sessionStorage["HUserName"] },
                        success: function (result) {
                            if (result.count == 1) {
                                get_FastQuery();
                                layer.msg(result.Message, { icon: 1 });
                                layer.close(wait);
                            } else {
                                layer.alert(result.code + result.Message, { icon: 5 });
                                layer.close(wait);
                            }
                        }, error: function () {
                            layer.alert("接口请求失败!", { icon: 5 });
                            layer.close(wait);
                        }
                    });
                })
            } else {
                layer.msg("请选择一条数据!");
            }
        }
        //关闭  [1 å…³é—­ã€2 åå…³é—­]
        function set_CloseBill(num) {
            var checkStatus = table.checkStatus('mainTable')
                , data = checkStatus.data;
            if (data.length == 1) {
                layer.confirm("确认要关闭吗?", function (index) {
                    var wait = layer.load();
                    var HInterID = data[0].hmainid;
                    $.ajax({
                        url: GetWEBURL() + '/Gy_RoutingBill/CloseGy_RoutingBill_1',
                        type: "GET",
                        data: { "HInterID": HInterID, "Type": num, "user": sessionStorage["HUserName"] },
                        success: function (result) {
                            if (result.count == 1) {
                                layer.msg(result.Message, { icon: 1 });
                                layer.close(wait);
                            } else {
                                layer.alert(result.code + result.Message, { icon: 5 });
                                layer.close(wait);
                            }
                        }, error: function () {
                            layer.alert("接口请求失败!", { icon: 5 });
                            layer.close(wait);
                        }
                    });
                })
            }
            else {
                layer.msg("请选择一条数据!");
            }
        }
        //#endregion
        //隐藏列设置
        function get_HideColumn() {
            var colName = "";
            var contentUrl = "";
            for (var i = 1; i < option.cols[0].length - 1; i++) {
                colName += option.cols[0][i]["title"] + ",";
            }
            var urlStr = window.document.location.pathname;//获取文件路径
            var urlLen = urlStr.split('/');
            for (var i = 0; i < urlLen.length - 4; i++) {
                contentUrl += "../";
            }
            colName = encodeURI(colName.substring(0, colName.length - 1));//对 URI è¿›è¡Œç¼–码
            contentUrl += '基础资料/隐藏列设置/Gy_GridView_Hide.html?HModName=' + HModName + '&colName=' + colName;
            layer.open({
                type: 2
                , skin: "layui-layer-rim" //加上边框
                , title: "隐藏列设置"  //标题
                , closeBtn: 1  //窗体右上角关闭 çš„ æ ·å¼
                , shift: 2 //弹出动画
                , area: ["50%", "90%"] //窗体大小
                , maxmin: true //设置最大最小按钮是否显示
                , content: [contentUrl, "yes"]
                , btn: ["确定", "取消"]
                , btn1: function (index, laero) {
                    //刷新表格数据
                    DisPlay_HideColumn();
                    //更新表格缓存的数据
                    layer.close(index);//关闭弹窗
                }
            })
        }
        //显示列数据
        function DisPlay_HideColumn() {
            $.ajax({
                url: GetWEBURL() + '/Xt_grdAlignment_WMES/grdAlignmentWMESList',
                type: "GET",
                data: { "HModName": HModName, "user": sessionStorage["HUserName"] },
                success: function (data1) {
                    if (data1.data.length != 0) {
                        var dataCol = [];//数据库查询出的列数据
                        dataCol = data1.data[0].HGridString.split(',');
                        for (var i = 0; i < option.cols[0].length - 2; i++) {
                            var dataCols = dataCol[i].split('|');
                            //隐藏列
                            if (dataCols[1] == 1) {
                                option.cols[0][i + 1]["hide"] = true;
                            }
                            //设置列宽
                            if (dataCols[3] > 0) {
                                option.cols[0][i + 1]["width"] = dataCols[3];
                            }
                            //设置内容字体大小
                            if (data1.data[0].HFontSize != 0) {
                                option.cols[0][i + 1]["style"] = "font-size:" + data1.data[0].HFontSize + "px;";
                            } else {
                                option.cols[0][i + 1]["style"] = "font-size:100%";
                            }
                            //设置列宽
                            //if (data1.data[0].HColumnWidth != 0) {
                            //    option.cols[0][i + 1]["width"] = data1.data[0].HColumnWidth + "px;";
                            //} else {
                            //    option.cols[0][i + 1]["width"] = "";
                            //}
                            //显示列
                            if (dataCols[1] == 0 && $.inArray(option.cols[0][i + 1]["title"], titleData) == -1) {
                                option.cols[0][i + 1]["hide"] = false;
                            }
                            //字体所在位置(å·¦ å±…中 å³)
                            switch (dataCols[2]) {
                                case "L":
                                    option.cols[0][i + 1]["align"] = "left";
                                    break;
                                case "M":
                                    option.cols[0][i + 1]["align"] = "center";
                                    break;
                                case "R":
                                    option.cols[0][i + 1]["align"] = "right";
                                    break;
                            }
                        }
                        //取消冻结列
                        for (var i = 1; i < option.cols[0].length - 1; i++) {
                            if (option.cols[0][i]["fixed"] != null) {
                                option.cols[0][i]["fixed"] = null;
                            }
                            else {
                                break;
                            }
                        }
                        //冻结列
                        if (data1.data[0].HFixCols != 0) {
                            for (var i = 0; i < data1.data[0].HFixCols; i++) {
                                if ($.inArray(option.cols[0][i + 1]["title"], titleData) != -1) {
                                    data1.data[0].HFixCols += 1;
                                }
                                option.cols[0][i + 1]["fixed"] = "left";
                            }
                        }
                        table.render(option);
                    } else {
                        table.render(option);
                    }
                }, error: function () {
                    layer.alert("接口请求失败!", { icon: 5 });
                }
            })
        }
        //#region åˆ—明显示下拉框
        function ColFilter() {
            var Organization = '<option  value="0" selected="selected" ></option>';
            for (var i = 1; i < option.cols[0].length; i++) {
                if (option.cols[0][i].hide != true) {
                    Organization += '<option  style="color:blue;" value="' + option.cols[0][i].field + '">' + option.cols[0][i].field + '</option>';
                }
            }
            $("#ColName").empty();
            $("#ColName").append(Organization);
            form.render('select');
        }
        //#endregion
        //#endregion
        //以上是layui模块
    });
</script>