yuyou_x
2024-03-26 5b4f00ff3ea04a3246a8f6f86bdefe749fcfd0c4
HTML/views/ASNSetting/LabelBox.html
@@ -3,7 +3,7 @@
<head>
   <meta charset="utf-8">
   <title>物料信息录入</title>
   <title>物料标签</title>
   <meta name="renderer" content="webkit">
   <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
   <meta name="viewport"
@@ -36,14 +36,14 @@
   </style>
   <script>
      // 这里是需要在页面渲染之前执行的代码
      document.addEventListener("DOMContentLoaded", function() {
      document.addEventListener("DOMContentLoaded", function () {
         //获取table默认显示数
         pageCntFirst();
         //判断是否开启table列表列宽调整功能。
         GetIsSetColW();
      });
     </script>
   </script>
</head>
@@ -53,6 +53,13 @@
      <div class="layui-card">
         <div class="layui-form layui-card-header layuiadmin-card-header-auto">
            <div class="layui-form-item">
               <div class="layui-inline" style="margin-right: 0;">
                  <label class="layui-form-label" style="width: 60px;">入库单号</label>
                  <div class="layui-input-inline" style="margin-right: 0;">
                     <input type="text" id="ASNNo" name="ASNNo" placeholder="入库单号" autocomplete="off"
                        class="layui-input">
                  </div>
               </div>
               <div class="layui-inline" style="margin-right: 0;">
                  <label class="layui-form-label" style="width: 60px;">箱 号</label>
                  <div class="layui-input-inline" style="margin-right: 0;">
@@ -77,11 +84,26 @@
                  </div>
               </div>
               <div class="layui-inline" style="margin-right: 0;">
                  <label class="layui-form-label" style="width: 60px;">批次描述</label>
                  <label class="layui-form-label" style="width: 60px;">供货批次</label>
                  <div class="layui-input-inline" style="margin-right: 0;">
                     <div class="layui-input-inline" style="margin-right: 0;">
                        <input type="text" id="LotText" name="LotText" placeholder="批次描述" autocomplete="off"
                           class="layui-input">
                        <input type="text" id="SupplierLot" name="SupplierLot" placeholder="供货批次"
                           autocomplete="off" class="layui-input">
                     </div>
                  </div>
               </div>
               <div class="layui-inline" style="margin-right: 0;">
                  <label class="layui-form-label">标签状态</label>
                  <div class="layui-input-inline" style="margin-right: 0;">
                     <div class="layui-input-inline" style="margin-right: 0;">
                        <select name="Status" id="Status" lay-filter="Status" lay-search>
                           <option value=""></option>
                           <option value="0">未组托</option>
                           <option value="1">已组托</option>
                           <option value="2">已入库</option>
                        </select>
                     </div>
                  </div>
               </div>
@@ -99,22 +121,44 @@
                     lay-filter="LAY-app-contlist-search">
                     <i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>搜索
                  </button>
                  <button class="layui-btn layui-btn-sm layuiadmin-btn-list layui-btn-normal buDaLabelClass" style="margin-left: 5px;" lay-event="BuDaLabel" id="BuDaLabel">
                     <i class="layui-icon layui-icon-print layuiadmin-button-btn"></i>补打标签
                  </button>
                  <button class="layui-btn layui-btn-sm layuiadmin-btn-list layui-btn-danger delLabelClass" style="margin-left: 5px;" lay-event="delLabel" id="delLabel">
                     <i class="layui-icon layui-icon-delete layuiadmin-button-btn"></i>删除标签
                  </button>
               </div>
               <!-- 确认出库口弹窗 -->
               <div class="layui-inline" id="divDelLotNo" style="display: none; padding-top: 10px;">
                  <div class="layui-inline">
                     <label class="layui-form-label">入库单据</label>
                     <div class="layui-input-inline" style="width: 220px;">
                        <input type="text" id="AsnNoSelect" name="AsnNoSelect" placeholder="入库单据" autocomplete="off" class="layui-input">
                     </div>
                  </div>
                  <div class="layui-inline DivLoadingArea" style="margin-top: 10px;">
                     <label class="layui-form-label">批次号</label>
                     <div class="layui-input-inline" style="width: 220px;">
                        <select name="LotNoSelect" id="LotNoSelect" lay-search>
                           <option value=""></option>
                        </select>
                     </div>
                  </div>
               </div>
            </div>
         </div>
         <div class="layui-card-body">
            <!-- <button type="button" class="layui-btn layui-btn-sm" id="daoru1">
               导入
            </button> -->
         <div class="layui-card-body">
            <div class="position-relative">
               <table id="Box-list" lay-filter="Box-list"></table>
               <div class="headerSetIcon">
                  <button class="layui-btn layui-btn-primary layui-btn-sm" data-type="customCols">
                     <i class="layui-icon">&#xe610;</i>
                  </button>
               </div>
               <script type="text/html" id="templetProductionTime">
                  {{# function GetBtn3(d){
                        return formatDate2(d.ProductionTime);
@@ -130,15 +174,15 @@
                  }}
                  {{ GetBtn4(d) }}
               </script>
               <script type="text/html" id="templetInspectTime">
               <script type="text/html" id="templetStoreTimeTime">
                  {{# function GetBtn5(d){
                        return formatDate2(d.InspectTime);
                        return formatDate2(d.StoreTimeTime);
                     }   
                  }}
                  {{ GetBtn5(d) }}
               </script>
               <script type="text/html" id="templetCompleteTime">
                  {{# function GetBtn6(d){
                        return formatDate(d.CompleteTime);
@@ -147,19 +191,42 @@
                  {{ GetBtn6(d) }}
               </script>
               <script type="text/html" id="templetIsUse">
               <script type="text/html" id="templetStatus">
                  {{# function GetBtn7(d){
                        switch (d.IsUse) {
                           case "0": return '<button class="layui-btn layui-btn-radius layui-btn-xs">否</button>';
                           case "1": return '<button class="layui-btn layui-btn-radius layui-btn-xs layui-btn-danger ">是</button>';
                        switch (d.Status) {
                           case "0": return '<button class="layui-btn layui-btn-radius layui-btn-xs">未组托</button>';
                           case "1": return '<button class="layui-btn layui-btn-radius layui-btn-xs layui-btn-danger ">已组托</button>';
                           case "2": return '<button class="layui-btn layui-btn-radius layui-btn-xs layui-btn-normal ">已入库</button>';
                           default: return "";
                        }   
                     }   
                  }}
                  {{ GetBtn7(d) }}
               </script>
               <script type="text/html" id="templetInspectMark">
                  {{# function GetBtn9(d){
                        switch (d.InspectMark) {
                           case "0": return '<button class="layui-btn layui-btn-radius layui-btn-xs">否</button>';
                           case "1": return '<button class="layui-btn layui-btn-radius layui-btn-xs layui-btn-danger ">是</button>';
                           default: return "";
                        }
                     }
                  }}
                  {{ GetBtn9(d) }}
               </script>
               <script type="text/html" id="templetBitBoxMark">
                  {{# function GetBtn10(d){
                        switch (d.BitBoxMark) {
                           case "0": return '<button class="layui-btn layui-btn-radius layui-btn-xs">否</button>';
                           case "1": return '<button class="layui-btn layui-btn-radius layui-btn-xs layui-btn-danger ">是</button>';
                           default: return "";
                        }
                     }
                  }}
                  {{ GetBtn10(d) }}
               </script>
               <script type="text/html" id="templetCreateTime">
                  {{# function GetBtn8(d){
@@ -168,9 +235,9 @@
                  }}
                  {{ GetBtn8(d) }}
               </script>
            </div>
            </div>
            <script type="text/html" id="toolbarDemo">
            <!-- <script type="text/html" id="toolbarDemo">
               <button style="margin-right: 5px;" class="layui-btn layui-btn-sm layuiadmin-btn-list addClass" lay-event="add" >
                  <i class="layui-icon">&#xe654;</i>添加
               </button>
@@ -178,12 +245,12 @@
               <button style="margin-right: 5px;" id="daoru" class="layui-btn layui-btn-sm layuiadmin-btn-list DaoRuClass" lay-event="import" >
                  <i class="layui-icon">&#xe654;</i>导入
               </button>
            </script>
            </script> -->
            <script type="text/html" id="toolbarDemoList">
               {{# function GetBtn2(d){
                     var html = '';
                     if(d.Origin == "录入" || d.Origin == "导入"){
                     if(d.Origin == "WMS生成" || d.Status == "0"){
                        html = `<a class="layui-btn layui-btn-danger layui-btn-xs delClass" lay-event="del"> 
                           <i class="layui-icon layui-icon-delete"></i>删除</a>`; 
                        
@@ -226,134 +293,203 @@
         // 搜索方法
         form.on('submit(LAY-app-contlist-search)', function (data) {
            bindTable();
         });
            bindTable();
         });
         // 页面加载绑定Table
         bindTable();
         // 添加导入按钮单机事件
         table.on('toolbar(Box-list)', function (obj) {
            switch (obj.event) {
               case 'add':   // 添加箱支关系
                        // layer.open({
                        //     type: 2,
                        //     title: '自定义列',
                        //     content: '../SystemSettings/HeaderSetting.html',
                        //     maxmin: false,
                        //     resize: false,
                        //     area: ['970px', '650px']
                        // });
                        layer.open({
                            type: 2,
                            title: '打印',
                            content: 'LabelPrint.html?',
                            maxmin: true,
                            area: ['600px', '670px'],
                            btn: ['取消']
                        });
                  break;
               default: break;
         //生成
         $('#BuDaLabel').on('click', function () {
                layer.open({
               type: 2,
               title: '打印',
               content: 'LabelBoxBuDa.html',
               maxmin: true,
               area: ['430px', '390px'],
               // btn: ['取消']
            });
            });
         $("#AsnNoSelect").on('input', function () {
            if ($("#AsnNoSelect").val() == "" || $("#AsnNoSelect").val().length < 16) {
               return
            }
         });
            if ($("#AsnNoSelect").val().length >= 16) {
               $("#AsnNoSelect").val($("#AsnNoSelect").val().substr(-16))
            }
            GetLotNoByAsnNo()
         })
         function GetLotNoByAsnNo() {
         // 删除箱支信息
         table.on('tool(Box-list)', function (obj) {
            var data = obj.data;
            switch (obj.event) {
               case "del":
                  layer.confirm('确定删除箱支明细吗?', function (index) {
                     // 代码区域
                     var param = {
                        Id: data.Id,
                        Status: "0",
                     };
                     console.log(param);
                     sendData(IP + "/BllAsn/DelBllBoxInfo", param, 'post', function (res) {
                        if (res.code == 0) { //成功
                           layer.msg(res.msg, {
                              icon: 1,
                              time: 2000 //2秒关闭(如果不配置,默认是3秒)
                           }, function () {
                              bindTable();
                              doing = true
                           });
                        } else { //不成功
                           layer.msg(res.msg, {
                              icon: 2,
                              time: 2000 //2秒关闭(如果不配置,默认是3秒)
                           }, function () { doing = true });
                        }
                     });
            $("#LotNoSelect").empty()
                $("#LotNoSelect").append('<option value =>' + '</option>');
            form.render('select');
            var param = {
               asnNo: $("#AsnNoSelect").val(),
            };
            sendData(IP + "/BllAsn/GetLotNoListByAsn", param, 'get', function(res) {
               if (res.code == 0) { //成功
                  for (var i = 0; i < res.data.length; i++) {
                     $("#LotNoSelect").append('<option value =' + res.data[i] + '>' + res.data[i] + '</option>');
                  }
                  form.render('select');
               } else { //不成功
                  layer.msg(res.msg, {
                     icon: 2,
                     time: 3000 //2秒关闭(如果不配置,默认是3秒)
                  }, function() {
                  });
               }
            });
         }
                  break;
               default: break;
            }
         });
            //删除标签
         $('#delLabel').on('click', function () {
            layer.open({
               type: 1,
               title: '删除标签',
               content: $('#divDelLotNo'),
               maxmin: false,
               area: ['350px','340px'],
               btn: ['确定', '取消'],
               yes: function(index, layero) {
                  var param = {
                     AsnNo: $('#AsnNoSelect').val(),
                     LotNo: $('#LotNoSelect').val(),
                  };
                  sendData(IP + "/BllAsn/DelLabelByAsnNo", param, 'post', function(res) {
                     if (res.code == 0) { //成功
                        bindTable();
                        layer.msg(res.msg, {
                           icon: 1,
                           time: 1500 //1秒关闭(如果不配置,默认是3秒)
                        }, function() {
                           $('#AsnNoSelect').val("");
                           $("#LotNoSelect").empty()
                           $("#LotNoSelect").append('<option value =>' + '</option>');
                           form.render('select');
                        });
                     } else { //不成功
                        layer.msg(res.msg, {
                           icon: 2,
                           time: 3000 //2秒关闭(如果不配置,默认是3秒)
                        }, function() {
                           bindTable();
                           $('#AsnNoSelect').val("");
                           $("#LotNoSelect").empty()
                           $("#LotNoSelect").append('<option value =>' + '</option>');
                           form.render('select');
                        });
                     }
                     layer.close(index);
                  });
               }
            });
            });
         // // 删除箱支信息
         // table.on('tool(Box-list)', function (obj) {
         //    var data = obj.data;
         //    switch (obj.event) {
         //       case "del":
         //          layer.confirm('确定删除箱支明细吗?', function (index) {
         //             // 代码区域
         //             var param = {
         //                Id: data.Id,
         //                Status: "0",
         //             };
         //             console.log(param);
         //             sendData(IP + "/BllAsn/DelBllBoxInfo", param, 'post', function (res) {
         //                if (res.code == 0) { //成功
         //                   layer.msg(res.msg, {
         //                      icon: 1,
         //                      time: 2000 //2秒关闭(如果不配置,默认是3秒)
         //                   }, function () {
         //                      bindTable();
         //                      doing = true
         //                   });
         //                } else { //不成功
         //                   layer.msg(res.msg, {
         //                      icon: 2,
         //                      time: 2000 //2秒关闭(如果不配置,默认是3秒)
         //                   }, function () { doing = true });
         //                }
         //             });
         //          });
         //          break;
         //       default: break;
         //    }
         // });
         //#region 事件方法
         // 查询录入的箱支关系
         //#region 自定义表头
         var TotalColsArr = [[
            {field: 'BoxNo',title: '箱号',align: 'center',fixed: 'left',width: 220, "disabled": true},
            {field: 'ParentBoxNo',title: '父级箱号',align: 'center',fixed: 'left',width: 220, "disabled": true},
            {field: 'SkuNo',title: '物料编码',align: 'center',fixed: 'left',width: 140, "disabled": true },
            {field: 'SkuName',title: '物料名称',align: 'center',width: 240,  },
                {field: 'Qty',title: '数量',align: 'center',width: 100,},
            {field: 'LotNo',title: '批次号',align: 'center',width: 155,},
            {field: 'LotText',title: '批次描述',align: 'center',width: 165},
                {field: 'AsnNo',title: '单据号',align: 'center',width: 155,},
                {field: 'IsUse',title: '是否使用',align: 'center',templet: '#templetIsUse',width: 90},
            {field: 'Level',title: '级别',align: 'center',width: 90},
            {field: 'ProductionTime',title: '生产日期',align: 'center',width: 160,templet: '#templetProductionTime'},
            {field: 'ExpirationTime',title: '过期日期',align: 'center',width: 160,templet: '#templetExpirationTime'},
            {field: 'InspectTime',title: '复验日期',align: 'center',width: 160,templet: '#templetInspectTime'},
            {field: 'CompleteTime',title: '完成日期',align: 'center',width: 160,templet: '#templetCompleteTime'},
            {field: 'SupplierName',title: '供应商',align: 'center',width: 155},
            {field: 'SupplierLot',title: '供货批次',align: 'center',width: 155},
            { field: 'ASNNo', title: '入库单号', align: 'center',fixed: 'left', width: 180, "disabled": true },
            { field: 'BoxNo', title: '箱号', align: 'center', fixed: 'left', width: 220, "disabled": true },
            { field: 'BoxNo2', title: '盒号', align: 'center', fixed: 'left', width: 220,  },
            { field: 'BoxNo3', title: '支号', align: 'center', fixed: 'left', width: 220, "disabled": true },
            { field: 'SkuNo', title: '物料编码', align: 'center', fixed: 'left', width: 140, "disabled": true },
            { field: 'SkuName', title: '物料名称', align: 'center', width: 240, },
            { field: 'Qty', title: '数量', align: 'center', width: 100, },
            { field: 'FullQty', title: '整箱数量', align: 'center', width: 100, },
            { field: 'LotNo', title: '批次号', align: 'center', width: 155, },
            { field: 'LotText', title: '批次描述', align: 'center', width: 165 },
            { field: 'SupplierLot', title: '供货批次', align: 'center', width: 155 },
            { field: 'Status', title: '状态', align: 'center', templet: '#templetStatus', width: 90 },
             
                {field: 'CreateUserName',title: '创建人',align: 'center',width: 100},
                {field: 'CreateTime',title: '创建时间',align: 'center',width: 160,templet: '#templetCreateTime'},
                {field: 'caozuo',title: '操作',fixed: 'right',width: 100,align: 'center',toolbar: '#toolbarDemoList', "disabled": true}
            ]];
            //url编码
         var TotalColsSysArr=encodeURIComponent(encodeURIComponent(JSON.stringify(TotalColsArr)))//将表头数据进行url编码
            { field: 'Standard', title: '规格/型号', align: 'center', width: 165 },
            { field: 'PackageStandard', title: '包装规格', align: 'center', width: 165 },
            { field: 'ProductionTime', title: '生产日期', align: 'center', width: 160, templet: '#templetProductionTime' },
            { field: 'ExpirationTime', title: '过期日期', align: 'center', width: 160, templet: '#templetExpirationTime' },
            { field: 'StoreTime', title: '储存期至', align: 'center', width: 160, templet: '#templetStoreTime' },
            { field: 'CompleteTime', title: '完成日期', align: 'center', width: 160, templet: '#templetCompleteTime' },
            {field: 'InspectMark',title: '抽检标记',align: 'center',templet: '#templetInspectMark',width: 90},
            {field: 'BitBoxMark',title: '零箱标记',align: 'center',templet: '#templetBitBoxMark',width: 90},
            {field: 'Origin',title: '来源',align: 'center',width: 90},
            { field: 'CreateUserName', title: '创建人', align: 'center', width: 100 },
            { field: 'CreateTime', title: '创建时间', align: 'center', width: 160, templet: '#templetCreateTime' },
            //{ field: 'caozuo', title: '操作', fixed: 'right', width: 100, align: 'center', toolbar: '#toolbarDemoList', "disabled": true }
         ]];
         //url编码
         var TotalColsSysArr = encodeURIComponent(encodeURIComponent(JSON.stringify(TotalColsArr)))//将表头数据进行url编码
         //#endregion
         function bindTable() {
            //#region 自定义表头
            var colsJson
            var param1={
               Href:'BllAsn/GetLabelBoxList'
            var param1 = {
               Href: 'BllAsn/GetLabelBoxList'
            };
            sendData(IP + "/Sys/GetTableColsByUserId", param1, 'post', function(res) {
               if (res.code == 0){
                  if(res.data=='' || res.data==undefined || res.data==null){
                     colsJson=TotalColsArr
                  }else{
                     colsJson= eval(res.data);
            sendData(IP + "/Sys/GetTableColsByUserId", param1, 'post', function (res) {
               if (res.code == 0) {
                  if (res.data == '' || res.data == undefined || res.data == null) {
                     colsJson = TotalColsArr
                  } else {
                     colsJson = eval(res.data);
                  }
               }else{
                  colsJson=TotalColsArr
               } else {
                  colsJson = TotalColsArr
               }
               var param = {
                  AsnNo:$("#ASNNo").val(),
                  BoxNo: $("#BoxNo").val(),
                  // BoxNo2: $("#BoxNo2").val(),
                  BoxNo3: $("#BoxNo3").val(),
                  Status: $("#Status").val(),
                  SkuNo: $("#SkuNo").val(),
                  LotNo: $("#LotNo").val(),
                  LotText: $("#LotText").val(),
                  LotNo: $("#LotNo").val(),
                  ProductionTime: $("#ProductionTime").val(),
                  InspectMark: $("#InspectMark").val(),
                  BitBoxMark: $("#BitBoxMark").val(),
                  // Origin: "录入",
                  SupplierLot: $("#SupplierLot").val(),
               };
               table.render({
                  elem: '#Box-list',
@@ -363,7 +499,6 @@
                  id: 'Box-list',
                  where: param,
                  contentType: 'application/json',
                  toolbar: '#toolbarDemo',
                  defaultToolbar: [], //'filter','print', 'exports'
                  headers: { ToKen: $.cookie('token') },
                  page: true,
@@ -374,42 +509,9 @@
                  done: function (res) {
                     setRight();
                     //自定义列宽
                     SetTableColW('Box-list','BllAsn/GetLabelBoxList',TotalColsSysArr);
                     SetTableColW('Box-list', 'BllAsn/GetLabelBoxList', TotalColsSysArr);
                  },
                  cols: colsJson
               });
               //绑定导入
               upload.render({
                  elem: '#daoru' //绑定元素
                  , url: '' //上传接口
                  , auto: false  //是否选完文件后自动上传。如果设定 false,那么需要设置 bindAction 参数来指向一个其它按钮提交上传
                  , exts: 'slx|excel|xlsx'  //允许上传的文件后缀
                  , accept: 'file' //指定允许上传时校验的文件类型
                  //, bindAction: '#daoru' //指向一个按钮触发上传
                  , choose: function (obj) {// 选择文件回调
                     console.log(obj);
                     var files = obj.pushFile(); //将每次选择的文件追加到文件队列
                     var fileArr = Object.values(files);// 注意这里的数据需要是数组,所以需要转换一下
                     console.log(fileArr)
                     // 用完就清理掉,避免多次选中相同文件时出现问题
                     for (var index in files) {
                        console.log(index);
                        if (files.hasOwnProperty(index)) {
                           delete files[index];
                        }
                     }
                     console.log("abs");
                     uploadExcel(fileArr); // 如果只需要最新选择的文件,可以这样写: uploadExcel([files.pop()])
                  }
                  , done: function (res) {
                     console.log(res);
                     //上传完毕回调
                  }
                  , error: function (res) {
                     console.log(res);
                     //请求异常回调
                  }
               });
            });
            //#endregion
@@ -418,28 +520,22 @@
         // 权限设置
         function setRight() {
            $(function () {
               $(".addClass").hide();
               $(".DaoRuClass").hide();
               $(".delClass").hide();
               $(".buDaLabelClass").hide();
               $(".delLabelClass").hide();
            });
            sendData(IP + "/Basis/GetRoleRightList", {}, 'get', function (res) {
               if (res.code == 0) { //成功 
                  for (var k = 0; k < res.data.length; k++) {
                     if (res.data[k].MenuName == "添加箱支录入") {
                     if (res.data[k].MenuName == "补打标签") {
                        $(function () {
                           $(".addClass").show();
                           $(".buDaLabelClass").show();
                        });
                     }
                     if (res.data[k].MenuName == "导入箱支录入") {
                     }
                     if (res.data[k].MenuName == "删除标签") {
                        $(function () {
                           $(".DaoRuClass").show();
                           $(".delLabelClass").show();
                        });
                     }
                     if (res.data[k].MenuName == "删除箱支录入") {
                        $(function () {
                           $(".delClass").show();
                        });
                     }
                     }
                  }
               } else { //不成功
                  layer.msg('获取权限信息失败', {
@@ -450,178 +546,22 @@
            });
         }
         // 获取箱支信息
         function getBoxInforVlues() {
            var msg = "";
            if ($("#BoxNo").val() == "") {
               layer.msg("请输入箱码!", {
                  icon: 2,
                  time: 2000 //2秒关闭(如果不配置,默认是3秒)
               });
               return msg;
            }
            // if ($("#BoxNo2").val() == "") {
            //    layer.msg("请输入盒码!", {
            //       icon: 2,
            //       time: 2000 //2秒关闭(如果不配置,默认是3秒)
            //    });
            //    return msg;
            // }
            if ($("#BoxNo3").val() == "") {
               layer.msg("请输入支码!", {
                  icon: 2,
                  time: 2000 //2秒关闭(如果不配置,默认是3秒)
               });
               return msg;
            }
            if ($("#SkuNo").val() == "") {
               layer.msg("请输入物料编码!", {
                  icon: 2,
                  time: 2000 //2秒关闭(如果不配置,默认是3秒)
               });
               return msg;
            }
            if ($("#LotNo").val() == "") {
               layer.msg("请输入批次号!", {
                  icon: 2,
                  time: 2000 //2秒关闭(如果不配置,默认是3秒)
               });
               return msg;
            }
            if ($("#Qty").val() == "") {
               layer.msg("请输入实际数量!", {
                  icon: 2,
                  time: 2000 //2秒关闭(如果不配置,默认是3秒)
               });
               return msg;
            }
            var param = {
               BoxNo: $("#BoxNo").val(),
               // BoxNo2: $("#BoxNo2").val(),
               BoxNo3: $("#BoxNo3").val(),
               SkuNo: $("#SkuNo").val(),
               LotNo: $("#LotNo").val(),
               LotText: $("#LotText").val(),
               Qty: parseInt($("#Qty").val()),
               ProductionTime: $("#ProductionTime").val(),
               InspectMark: $("#InspectMark").val(),
               BitBoxMark: $("#BitBoxMark").val(),
               Origin: "录入",
            };
            return param;
         }
         // 导入箱支关系
         function uploadExcel(files) {
            console.log("123");
            var list = [];
            try {
               var excel = layui.excel;
               excel.importExcel(files, {
                  // 读取数据的同时梳理数据
                  fields: {
                     'BoxNo': 'A', //箱号
                     'BoxNo2': 'B', //盒号
                     'BoxNo3': 'C', //支号
                     'Qty': 'D', //数量
                     'SkuNo': 'E', //物料号
                     'LotNo': 'F', //批次
                     'LotText': 'G', //批次描述
                     'ProductionTime': 'H', //生产日期
                     'InspectMark': 'I',  //检验标记
                     'BitBoxMark': 'J', //零箱标记
                  }
               },
                  function (data) {
                     console.log(data);
                     // var arr = new Array();
                     //excel第一行不读取、设置为标题
                     for (i = 1; i < data[0].Sheet1.length; i++) {
                        var Qty = 0;
                        if (isIntNum(data[0].Sheet1[i].Qty)) {
                           Qty = parseInt(data[0].Sheet1[i].Qty);
                        }
                        var InspectMark = "0";
                        var BitBoxMark = "0";
                        if (data[0].Sheet1[i].InspectMark == "是") {
                           InspectMark = "1";
                        }
                        if (data[0].Sheet1[i].BitBoxMark == "是") {
                           BitBoxMark = "1";
                        }
                        var tt = {
                           BoxNo: data[0].Sheet1[i].BoxNo,
                           BoxNo2: data[0].Sheet1[i].BoxNo2,
                           BoxNo3: data[0].Sheet1[i].BoxNo3,
                           Qty: Qty,
                           SkuNo: data[0].Sheet1[i].SkuNo,
                           LotNo: data[0].Sheet1[i].LotNo,
                           LotText: data[0].Sheet1[i].LotText,
                           ProductionTime: data[0].Sheet1[i].ProductionTime,
                           InspectMark: InspectMark,
                           BitBoxMark: BitBoxMark,
                        };
                        list.push(tt);
                        console.log(data[0].Sheet1[i].ProductionTime);
                     }
                     console.log(list);
                     var param = {
                        "OperType": "Add",
                        "ListBoxInfo": list,
                     }
                     console.log(param)
                     layer.load();//打开loading
                     sendData(IP + "/BllAsn/ImportBllBoxInfo", param, 'post', function (res) {
                        layer.closeAll(); //关闭loading
                        if (res.code == 0) { //成功
                           layer.msg(res.msg, {
                              icon: 1,
                              time: 2000 //2秒关闭(如果不配置,默认是3秒)
                           }, function () {
                              bindTable();
                              doing = true
                           });
                        } else { //不成功
                           if(res.msg==undefined){
                              layer.msg("后台正在导入中,请稍后查看结果", {
                                 icon: 2,
                                 time: 3000 //2秒关闭(如果不配置,默认是3秒)
                              }, function () { bindTable();doing = true });
                           }else{
                              layer.msg(res.msg, {
                                 icon: 2,
                                 time: 2000 //2秒关闭(如果不配置,默认是3秒)
                              }, function () { bindTable();doing = true });
                           }
                        }
                     });
                  });
            } catch (e) {
               layer.alert(e.message);
            }
         }
         //#endregion
         //#region 自定义表头
         //自定义表头         
         active = {
            customCols: function(){
            customCols: function () {
               layer.open({
                  type: 2,
                  title: '自定义列',
                  content: '../SystemSettings/HeaderSetting.html?Href=BllAsn/GetLabelBoxList&ColsSysArr='+TotalColsSysArr,
                  content: '../SystemSettings/HeaderSetting.html?Href=BllAsn/GetLabelBoxList&ColsSysArr=' + TotalColsSysArr,
                  maxmin: false,
                  resize: false,
                  area: ['970px', '650px']
               });
            },
         };
         $('.layui-btn').on('click', function() {
         $('.layui-btn').on('click', function () {
            var type = $(this).data('type');
            active[type] ? active[type].call(this) : '';
         });