|  |  | 
 |  |  | var treeCond; | 
 |  |  | var admin; | 
 |  |  | var planNeedXmlSelData; | 
 |  |  | let nowUserId2 = 0; | 
 |  |  | fPlan(); | 
 |  |  | function fPlan() { | 
 |  |  |     layui.jquery.ajax({ | 
 |  |  |         url: baseUrl + "/dashboard/user/id/popup/auth", | 
 |  |  |         data:{token : localStorage.getItem('token')}, | 
 |  |  |         method: 'GET', | 
 |  |  |         success: function (res) { | 
 |  |  |             if (res.code === 200) { | 
 |  |  |                 nowUserId2 = res.data; | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |     }) | 
 |  |  | } | 
 |  |  |  | 
 |  |  | layui.config({ | 
 |  |  |     base: baseUrl + "/static/layui/lay/modules/" | 
 |  |  | }).extend({ | 
 |  |  | 
 |  |  |         skin: 'line', | 
 |  |  |         cols: [[ | 
 |  |  |             {type: 'checkbox'} | 
 |  |  |             // ,{field: 'id', align: 'center',title: 'ID'} | 
 |  |  |             ,{field: 'id', align: 'center',title: 'ID'} | 
 |  |  |             // ,{field: 'hostId$', align: 'center',title: '所属商户'} | 
 |  |  |             ,{field: 'userId$', align: 'left',title: '业务员',hide: false, width: 100} | 
 |  |  |             ,{field: 'planType$', align: 'left',title: '业务类型', width: 150,hide: false} | 
 |  |  |             ,{field: 'userId$', align: 'left',title: '业务员',hide: false, width: 100, sort:true} | 
 |  |  |             ,{field: 'cstmrId', align: 'left',title: 'cstmrId',hide: true} | 
 |  |  |             , { | 
 |  |  |                 field: 'cstmrId$', | 
 |  |  |                 align: 'center', | 
 |  |  |                 title: '客户名称', | 
 |  |  |                 style: 'color: #1890ff;cursor:pointer', | 
 |  |  |                 event: 'moreCstmr', | 
 |  |  |                 width: 350, | 
 |  |  |                 hide: false, sort:true | 
 |  |  |             } | 
 |  |  |             ,{field: 'planType$', align: 'left',title: '业务类型', width: 130,hide: false, sort:true} | 
 |  |  |             ,{ | 
 |  |  |                 field: 'name', | 
 |  |  |                 align: 'left', | 
 |  |  | 
 |  |  |                 width: 220, | 
 |  |  |                 style: 'color: #1890ff;cursor:pointer', | 
 |  |  |                 event: 'more', | 
 |  |  |                 hide: false | 
 |  |  |                 hide: false, | 
 |  |  |                 sort:true | 
 |  |  |             } | 
 |  |  |             ,{field: 'uuid', align: 'left',title: '规划单号', width: 100,hide: false} | 
 |  |  |             ,{field: 'uuid', align: 'left',title: '规划单号', width: 100,hide: false, sort:true} | 
 |  |  |             ,{ | 
 |  |  |                 field: 'planNeed$', | 
 |  |  |                 align: 'left', | 
 |  |  | 
 |  |  |                 templet:function(d){ | 
 |  |  |                     return emptyShow(d.planNeed$) | 
 |  |  |                 }, | 
 |  |  |                 hide: false | 
 |  |  |                 hide: false, | 
 |  |  |                 width: 200 | 
 |  |  |             } | 
 |  |  |             , {field: 'settleSize', align: 'center', title: '流程长度', hide: true} | 
 |  |  |             ,{field: 'deptId$', align: 'left',title: '所属部门',hide: true} | 
 |  |  |             ,{field: 'planner$', align: 'left',title: '规划员',hide: false, width: 100} | 
 |  |  |             ,{field: 'planner$', align: 'left',title: '规划员',hide: false, width: 100, sort:true} | 
 |  |  |             // ,{field: 'nowHeadman$', align: 'left',title: '规划组长',hide: true} | 
 |  |  |             ,{ | 
 |  |  |                 field: 'orderId$', | 
 |  |  |                 align: 'left', | 
 |  |  |                 title: '跟踪项目', | 
 |  |  |                 width: 220, | 
 |  |  |                 width: 120, | 
 |  |  |                 style: 'color: #1890ff;cursor:pointer', | 
 |  |  |                 event: 'orderMore',hide: false | 
 |  |  |                 event: 'orderMore', | 
 |  |  |                 hide: false, | 
 |  |  |                 sort:true | 
 |  |  |             } | 
 |  |  |             // ,{ | 
 |  |  |             //     field: 'cstmrId$', | 
 |  |  |             //     align: 'left', | 
 |  |  |             //     title: '甲方单位', | 
 |  |  |             //     width: 220, | 
 |  |  |             //     style: 'color: #1890ff;cursor:pointer', | 
 |  |  |             //     event: 'cstmrMore', | 
 |  |  |             //     hide: true | 
 |  |  |             // } | 
 |  |  |             ,{field: 'appleTime$', align: 'left',title: '申请日期', hide: false} | 
 |  |  |             // ,{field: 'beItem$', align: 'center',title: '立项'} | 
 |  |  |             // ,{field: 'planner', align: 'left',title: '规划员', templet:function(d){return emptyShow(d.planner)}} | 
 |  |  |             // ,{field: 'finishTime$', align: 'center',title: '完成时间'} | 
 |  |  | 
 |  |  |             // ,{field: 'planBonus', align: 'center',title: '规格奖金'} | 
 |  |  |             // ,{field: 'planLeaderBonus', align: 'center',title: '规格组长奖金'} | 
 |  |  |             // ,{field: 'files', align: 'center',title: '附件'} | 
 |  |  |             ,{field: 'settle$', align: 'center',title: '进度', width: 150} | 
 |  |  |             ,{field: 'settle$', align: 'center',title: '进度', width: 150, sort:true} | 
 |  |  |             // ,{field: 'settleMsg', align: 'center',title: '审核进度'} | 
 |  |  |             // ,{field: 'comment', align: 'center',title: '评论'} | 
 |  |  |             ,{field: 'status$', align: 'center',title: '状态'} | 
 |  |  |             ,{field: 'createTime$', align: 'left',title: '添加日期', width: 160, hide: true} | 
 |  |  |             ,{field: 'updateBy$', align: 'left',title: '修改人', width: 100} | 
 |  |  |             ,{field: 'updateTime$', align: 'left',title: '修改时间', hide: true} | 
 |  |  |             ,{field: 'memo', align: 'left',title: '注释', hide: true} | 
 |  |  |  | 
 |  |  |             ,{field: 'statusAll$', align: 'center',title: '状态', hide:true, sort:true,width: 100} | 
 |  |  |             ,{field: 'createTime$', align: 'left',title: '添加日期', hide: true, sort:true,width: 120} | 
 |  |  |             ,{field: 'updateBy$', align: 'left',title: '修改人', width: 100, sort:true} | 
 |  |  |             ,{field: 'updateTime$', align: 'left',title: '更新时间', hide: false, sort:true,width: 120} | 
 |  |  |             ,{field: 'memo', align: 'left',title: '注释', hide: true, sort:true} | 
 |  |  |             ,{field: 'center', align: 'left',title: '关联流程', toolbar: '#tbLook', minWidth: 160, hide: false} | 
 |  |  |             ,{field: 'assistantHostSign$', align: 'left',title: '主副标记', hide: false,width: 80} | 
 |  |  |             ,{field: 'assistantHostSign', align: 'left',title: '主副标记', hide: true} | 
 |  |  |             ,{field: 'hostPlanId', align: 'left',title: '主ID', hide: true} | 
 |  |  |             ,{field: 'assistantPlanId', align: 'left',title: '副ID', hide: true} | 
 |  |  |             ,{field: 'appleTime$', align: 'left',title: '申请日期', hide: false, sort:true,width: 120} | 
 |  |  |             ,{field: 'nowUserId', title: 'nowUserId', hide: true, templet:function(){return nowUserId2}} | 
 |  |  |             ,{field: 'userId',title: 'userId', hide: true} | 
 |  |  |             ,{field: 'director',title: 'director', hide: true} | 
 |  |  |             // ,{field: 'assistantPlanIdSignType', align: 'left',title: '集成货架标志', hide: true} | 
 |  |  |             ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width: 340} | 
 |  |  |         ]], | 
 |  |  |         request: { | 
 |  |  | 
 |  |  |             pageSize: 'limit' | 
 |  |  |         }, | 
 |  |  |         parseData: function (res) { | 
 |  |  |             res.data.records.forEach((item,index) => { | 
 |  |  |                 item.nowUserId = nowUserId2 | 
 |  |  |             }) | 
 |  |  |             return { | 
 |  |  |                 'code': res.code, | 
 |  |  |                 'msg': res.msg, | 
 |  |  | 
 |  |  |         } | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     //多文件列表 | 
 |  |  |     var uploadListIns = upload.render({ | 
 |  |  |         elem: '#data-btn-file2' | 
 |  |  |         ,elemList: $('#data-btn-file3') //列表元素对象 | 
 |  |  |         ,url: '/plan/insert/file/auth' | 
 |  |  |         ,accept: 'file' | 
 |  |  |         ,multiple: true | 
 |  |  |         ,number: 10 | 
 |  |  |         ,auto: false | 
 |  |  |         ,bindAction: '#testListAction' | 
 |  |  |         ,choose: function(obj){ | 
 |  |  |             // 赋值 | 
 |  |  |             this.data.planId=$('.layui-layer-title').text() | 
 |  |  |             var that = this; | 
 |  |  |             var files = this.files = obj.pushFile(); //将每次选择的文件追加到文件队列 | 
 |  |  |             //读取本地文件 | 
 |  |  |             obj.preview(function(index, file, result){ | 
 |  |  |                 var tr = $(['<tr id="upload-'+ index +'">' | 
 |  |  |                     ,'<td>'+ file.name +'</td>' | 
 |  |  |                     ,'<td>'+ (file.size/1014).toFixed(1) +'kb</td>' | 
 |  |  |                     ,'<td><div class="layui-progress" id="progress-id-'+ index +'" lay-filter="progress-demo-'+ index +'"><div class="layui-progress-bar" lay-percent=""></div></div></td>' | 
 |  |  |                     ,'<td>' | 
 |  |  |                     ,'<button class="layui-btn layui-btn-xs demo-reload layui-hide">重传</button>' | 
 |  |  |                     ,'<button class="layui-btn layui-btn-xs layui-btn-danger demo-delete">删除</button>' | 
 |  |  |                     ,'<button id="file-download" class="layui-btn layui-btn-xs demo-reload layui-hide">下载</button>' | 
 |  |  |                     ,'</td>' | 
 |  |  |                     ,'</tr>'].join('')); | 
 |  |  |     $("#data-btn-file2").on("click", (e) => { | 
 |  |  |         $("#data-btn-upload").click() | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |                 //单个重传 | 
 |  |  |                 tr.find('.demo-reload').on('click', function(){ | 
 |  |  |                     obj.upload(index, file); | 
 |  |  |                 }); | 
 |  |  |  | 
 |  |  |                 //删除 | 
 |  |  |                 tr.find('.demo-delete').on('click', function(){ | 
 |  |  |                     delete files[index]; //删除对应的文件 | 
 |  |  |                     tr.remove(); | 
 |  |  |                     uploadListIns.config.elem.next()[0].value = ''; //清空 input file 值,以免删除后出现同名文件不可选 | 
 |  |  |                 }); | 
 |  |  |  | 
 |  |  |                 that.elemList.append(tr); | 
 |  |  |                 element.render('progress'); //渲染新加的进度条组件 | 
 |  |  |             }); | 
 |  |  |     var _uploadFile = null | 
 |  |  |     //响应上传 | 
 |  |  |     $("#data-btn-upload").on("change",(evt) => { | 
 |  |  |         var files = evt.target.files; | 
 |  |  |         if(files==null || files.length==0){ | 
 |  |  |             alert("No files wait for import"); | 
 |  |  |             return; | 
 |  |  |         } | 
 |  |  |         ,done: function(res, index, upload){ //成功的回调 | 
 |  |  |             element.progress('progress-demo-'+ index, '100%'); //执行进度条。n 即为返回的进度百分比 | 
 |  |  |  | 
 |  |  |         var file = files[0] | 
 |  |  |  | 
 |  |  |         var tr = $(['<tr id="upload-">' | 
 |  |  |             ,'<td id="upload-filename-id-'+ file.lastModified + '">' + file.name +'</td>' | 
 |  |  |             ,'<td>'+ (file.size/1014).toFixed(1) +'kb</td>' | 
 |  |  |             ,'<td id="upload-filename-userName-'+ '">' +'</td>' | 
 |  |  |             ,'<td id="upload-file-id-' + file.lastModified + '"><div class="layui-progress layui-progress-big" lay-showPercent="true" lay-filter="progress-demo-'+ file.lastModified +'"><div class="layui-progress-bar" lay-percent=""></div></div></td>' | 
 |  |  |             ,'<td>' | 
 |  |  |             ,'<button class="layui-btn layui-btn-xs demo-reload layui-hide">重传</button>' | 
 |  |  |             ,'<button class="layui-btn layui-btn-xs layui-btn-danger demo-delete">删除</button>' | 
 |  |  |             ,'<button id="file-download" class="layui-btn layui-btn-xs demo-reload layui-hide">下载</button>' | 
 |  |  |             ,'</td>' | 
 |  |  |             ,'</tr>'].join('')); | 
 |  |  |  | 
 |  |  |         //删除 | 
 |  |  |         tr.find('.demo-delete').on('click', function(){ | 
 |  |  |             tr.remove(); | 
 |  |  |             $("#data-btn-upload").val("") | 
 |  |  |             _uploadFile = null | 
 |  |  |         }); | 
 |  |  |  | 
 |  |  |         $('#data-btn-file3').append(tr) | 
 |  |  |  | 
 |  |  |         element.progress('progress-demo-'+ file.lastModified, '0%'); //执行进度条。 | 
 |  |  |         element.init(); | 
 |  |  |  | 
 |  |  |         _uploadFile = file | 
 |  |  |     }) | 
 |  |  |  | 
 |  |  |     //开始上传 | 
 |  |  |     $("#testListAction").on("click", async (e) => { | 
 |  |  |         if (_uploadFile == null) { | 
 |  |  |             return false; | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         var index = layer.load(1, { | 
 |  |  |             shadeClose: false, | 
 |  |  |             title: '上传中..', | 
 |  |  |             shade: [0.5,'#000'] | 
 |  |  |         }); | 
 |  |  |  | 
 |  |  |         var file = _uploadFile | 
 |  |  |  | 
 |  |  |         putObject(file,(p) => { | 
 |  |  |             element.progress('progress-demo-'+ file.lastModified, (Math.round(p * 100)) + "%"); //执行进度条。 | 
 |  |  |         }).then((result) => { | 
 |  |  |             var filename = result.name | 
 |  |  |             layer.msg('上传成功', {icon: 1}); | 
 |  |  |             $("#progress-id-" + index).html("已完成") | 
 |  |  |             var that = this; | 
 |  |  |             //if(res.code == 0){ //上传成功 | 
 |  |  |             var tr = that.elemList.find('tr#upload-'+ index) | 
 |  |  |                 ,tds = tr.children(); | 
 |  |  |             tds.eq(3).html(''); //清空操作 | 
 |  |  |             delete this.files[index]; //删除文件队列已经上传成功的文件 | 
 |  |  |             // return; | 
 |  |  |             //} | 
 |  |  |             // this.error(index, upload); | 
 |  |  |         } | 
 |  |  |         ,allDone: function(obj){ //多文件上传完毕后的状态回调 | 
 |  |  |             console.log(obj) | 
 |  |  |         } | 
 |  |  |         ,error: function(index, upload){ //错误回调 | 
 |  |  |             var that = this; | 
 |  |  |             var tr = that.elemList.find('tr#upload-'+ index) | 
 |  |  |                 ,tds = tr.children(); | 
 |  |  |             tds.eq(3).find('.demo-reload').removeClass('layui-hide'); //显示重传 | 
 |  |  |         } | 
 |  |  |         ,progress: function(n, elem, e, index){ | 
 |  |  |             element.progress('progress-demo-'+ index, '90%'); //执行进度条。n 即为返回的进度百分比 | 
 |  |  |         } | 
 |  |  |             $("#upload-file-id-" + file.lastModified).html("上传成功") | 
 |  |  |             $("#upload-filename-id-" + file.lastModified).html(filename) | 
 |  |  |             let token = localStorage.getItem("token"); | 
 |  |  |             $.ajax({ | 
 |  |  |                 url: baseUrl+"/plan/url/insert/file/auth", | 
 |  |  |                 headers: {'token': localStorage.getItem('token')}, | 
 |  |  |                 data: { | 
 |  |  |                     'planId': $('.layui-layer-title').text(), | 
 |  |  |                     'filename': filename, | 
 |  |  |                     'filesize': file.size | 
 |  |  |                 }, | 
 |  |  |                 method: 'POST', | 
 |  |  |                 success: function (res) { | 
 |  |  |                     if (res.code === 200){ | 
 |  |  |                         layer.close(index) | 
 |  |  |                         // console.log(res) | 
 |  |  |                     } else if (res.code === 403){ | 
 |  |  |                         top.location.href = baseUrl+"/"; | 
 |  |  |                     } else { | 
 |  |  |                         layer.msg(res.msg) | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |             }); | 
 |  |  |         }).catch((e) => { | 
 |  |  |             // console.log(e) | 
 |  |  |             layer.msg('上传失败', {icon: 2}); | 
 |  |  |             $("#upload-file-id-" + file.lastModified).html("上传失败") | 
 |  |  |         }) | 
 |  |  |  | 
 |  |  |         //清空file | 
 |  |  |         $("#data-btn-upload").val("") | 
 |  |  |         _uploadFile = null | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 添加 | 
 |  |  | 
 |  |  |                                     method: 'GET', | 
 |  |  |                                     success: function (res0) { | 
 |  |  |                                         let planType = res0.data.planType; | 
 |  |  |                                         console.log(planType.html) | 
 |  |  |                                         // console.log(planType.html) | 
 |  |  |                                         if (res0.code === 200) { | 
 |  |  |                                             admin.open({ | 
 |  |  |                                                 type: 1, | 
 |  |  | 
 |  |  |                                                     }); | 
 |  |  |                                                     layDateRender(); | 
 |  |  |                                                     form.on('submit(editSubmit)', function (data) { | 
 |  |  |                                                         console.log(data) | 
 |  |  |                                                         // console.log(data) | 
 |  |  |                                                         data.field.planType = planType.id; | 
 |  |  |                                                         data.field.orderId = orderSel.getValue()[0] ? orderSel.getValue()[0].value : null; | 
 |  |  |                                                         data.field.cstmrId = cstmrSel.getValue()[0] ? cstmrSel.getValue()[0].value : null; | 
 |  |  | 
 |  |  |                     } | 
 |  |  |                 }) | 
 |  |  |                 break; | 
 |  |  |             case 'moreCstmr': | 
 |  |  |                 top.cstmrByMore = data.cstmrId; | 
 |  |  |                 admin.popupRight({ | 
 |  |  |                     type: 1, | 
 |  |  |                     window: "top", | 
 |  |  |                     area: "1250px", | 
 |  |  |                     url: "../cstmr/cstmr_more.html", | 
 |  |  |                     end: function () { | 
 |  |  |                         // $(".layui-laypage-btn")[0].click(); | 
 |  |  |                     } | 
 |  |  |                 }) | 
 |  |  |                 break; | 
 |  |  |             case 'approval': | 
 |  |  |                 layer.confirm('审批通过?', { | 
 |  |  |                     skin: 'layui-layer-admin', | 
 |  |  | 
 |  |  |                 }, function (i) { | 
 |  |  |                     layer.close(i); | 
 |  |  |                     // 指定规划员 | 
 |  |  |                     if (data.settle === 1) { | 
 |  |  |                     if (data.settle === 1 && data.settleSize === 4) { | 
 |  |  |                         admin.open({ | 
 |  |  |                             type: 1, | 
 |  |  |                             area: '300px', | 
 |  |  | 
 |  |  |                     approvalEnd(data.id); | 
 |  |  |                 }); | 
 |  |  |                 break; | 
 |  |  |             case 'assistantPlan': | 
 |  |  |                 assistantPlan(data); | 
 |  |  |                 break; | 
 |  |  |             case 'edit': | 
 |  |  |                 showEditModel(data); | 
 |  |  |                 break; | 
 |  |  | 
 |  |  |                 del([data.id]); | 
 |  |  |                 break; | 
 |  |  |             case "uploadLink": | 
 |  |  |                 var planIdSign = data.id; | 
 |  |  |                 if (data.assistantHostSign==1){ | 
 |  |  |                     planIdSign = data.hostPlanId; | 
 |  |  |                 } | 
 |  |  |                 // 打开弹窗 | 
 |  |  |                 // 构建带参数的内容 | 
 |  |  |                 layer.open({ | 
 |  |  |                     type: 1, | 
 |  |  |                     title: '上传文件-'+data.id, | 
 |  |  |                     title: '上传文件-'+planIdSign+'-'+data.id, | 
 |  |  |                     content: $('#myModal') | 
 |  |  |                 }); | 
 |  |  |                 // 获取路径下的文件列表,使用 jQuery 的 ajax 方法 | 
 |  |  |                 $.ajax({ | 
 |  |  |                     url: '/plan/view/file/auth', | 
 |  |  |                     url: '/plan/url/view/file/auth', | 
 |  |  |                     headers: {'token': localStorage.getItem('token')}, | 
 |  |  |                     data:{ | 
 |  |  |                         planId:data.id | 
 |  |  |                         planId:planIdSign, | 
 |  |  |                         planIdI:data.id, | 
 |  |  |                     }, | 
 |  |  |                     success: function(response) { | 
 |  |  |                         if (response.code==200){ | 
 |  |  | 
 |  |  |                                 tr.id = "upload-"+index; | 
 |  |  |                                 tr.innerHTML = '<td>' + file.name + '</td>' | 
 |  |  |                                     + '<td>' + (file.size / 1024).toFixed(1) + 'kb</td>' | 
 |  |  |                                     + '<td>' + file.userName + '</td>' | 
 |  |  |                                     // + '<td><div class="layui-progress" lay-filter="progress-demo-' + index ,100 + '%'+ '"><div class="layui-progress-bar" lay-percent=""></div></div></td>' | 
 |  |  |                                     + '<td>'+'已完成'+'</td>' | 
 |  |  |                                     + '<td>' | 
 |  |  | 
 |  |  |                     } | 
 |  |  |                 }); | 
 |  |  |                 break; | 
 |  |  |             case "look": | 
 |  |  |                 var $a = $(obj.tr).find('a[lay-event="look"]'); | 
 |  |  |                 var offset = $a.offset(); | 
 |  |  |                 var top2 = offset.top; | 
 |  |  |                 var left = offset.left; | 
 |  |  |                 layer.open({ | 
 |  |  |                     type: 1, | 
 |  |  |                     title: false, | 
 |  |  |                     area: '2100px', | 
 |  |  |                     offset: [top2 + 'px', (left - 1430 + $a.outerWidth()) + 'px'], | 
 |  |  |                     shade: .01, | 
 |  |  |                     shadeClose: true, | 
 |  |  |                     fixed: false, | 
 |  |  |                     content: '<table id="lookSSXMTable" lay-filter="lookSSXMTable"></table>', | 
 |  |  |                     success: function (layero) { | 
 |  |  |                         table.render({ | 
 |  |  |                             elem: '#lookSSXMTable', | 
 |  |  |                             headers: {token: localStorage.getItem('token')}, | 
 |  |  |                             url: baseUrl+'/plan/assistantPlan/view/auth', | 
 |  |  |                             where: { | 
 |  |  |                                 hostPlanId: data.id | 
 |  |  |                             }, | 
 |  |  |                             page: true, | 
 |  |  |                             cellMinWidth: 100, | 
 |  |  |                             cols: [[ | 
 |  |  |                                 {field: 'id', align: 'center',title: 'ID'} | 
 |  |  |                                 ,{field: 'userId$', align: 'left',title: '业务员',hide: false, width: 100} | 
 |  |  |                                 ,{field: 'planType$', align: 'left',title: '业务类型', width: 150,hide: false} | 
 |  |  |                                 ,{ | 
 |  |  |                                     field: 'name', | 
 |  |  |                                     align: 'left', | 
 |  |  |                                     title: '售前规划申请单名称', | 
 |  |  |                                     width: 220, | 
 |  |  |                                     style: 'cursor:pointer', | 
 |  |  |                                     event: 'more', | 
 |  |  |                                     hide: false | 
 |  |  |                                 } | 
 |  |  |                                 ,{field: 'uuid', align: 'left',title: '规划单号', width: 100,hide: false} | 
 |  |  |                                 ,{ | 
 |  |  |                                     field: 'planNeed$', | 
 |  |  |                                     align: 'left', | 
 |  |  |                                     title: '所需', | 
 |  |  |                                     templet:function(d){ | 
 |  |  |                                         return emptyShow(d.planNeed$) | 
 |  |  |                                     }, | 
 |  |  |                                     hide: false | 
 |  |  |                                 } | 
 |  |  |                                 ,{field: 'deptId$', align: 'left',title: '所属部门',hide: true} | 
 |  |  |                                 ,{field: 'planner$', align: 'left',title: '规划员',hide: false, width: 100} | 
 |  |  |                                 ,{ | 
 |  |  |                                     field: 'orderId$', | 
 |  |  |                                     align: 'left', | 
 |  |  |                                     title: '跟踪项目', | 
 |  |  |                                     width: 220, | 
 |  |  |                                     style: 'cursor:pointer', | 
 |  |  |                                     event: 'orderMore',hide: false | 
 |  |  |                                 } | 
 |  |  |                                 ,{field: 'appleTime$', align: 'left',title: '申请日期', hide: false} | 
 |  |  |                                 ,{field: 'settle$', align: 'center',title: '进度', width: 150} | 
 |  |  |                                 ,{field: 'statusAll$', align: 'center',title: '状态'} | 
 |  |  |                                 ,{field: 'createTime$', align: 'left',title: '添加日期', width: 160, hide: true} | 
 |  |  |                                 ,{field: 'updateBy$', align: 'left',title: '修改人', width: 100} | 
 |  |  |                                 ,{field: 'updateTime$', align: 'left',title: '修改时间', hide: true} | 
 |  |  |                                 ,{field: 'memo', align: 'left',title: '注释', hide: true} | 
 |  |  |                                 ,{field: 'assistantHostSign', align: 'left',title: '主副标记', hide: true} | 
 |  |  |                                 ,{field: 'hostPlanId', align: 'left',title: '主ID', hide: true} | 
 |  |  |                                 ,{field: 'assistantPlanId', align: 'left',title: '副ID', hide: true} | 
 |  |  |                                 // ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width: 340} | 
 |  |  |                             ]], | 
 |  |  |                             request: { | 
 |  |  |                                 pageName: 'curr', | 
 |  |  |                                 pageSize: 'limit' | 
 |  |  |                             }, | 
 |  |  |                             parseData: function (res) { | 
 |  |  |                                 // console.log(res) | 
 |  |  |                                 return { | 
 |  |  |                                     'code': res.code, | 
 |  |  |                                     'msg': res.msg, | 
 |  |  |                                     'count': res.data.total, | 
 |  |  |                                     'data': res.data.records | 
 |  |  |                                 } | 
 |  |  |                             }, | 
 |  |  |                             response: { | 
 |  |  |                                 statusCode: 200 | 
 |  |  |                             }, | 
 |  |  |                             done: function () { | 
 |  |  |                                 $(layero).find('.layui-table-view').css('margin', '0'); | 
 |  |  |                             }, | 
 |  |  |                             size: '' | 
 |  |  |                         }); | 
 |  |  |                     } | 
 |  |  |                 }); | 
 |  |  |                 break; | 
 |  |  |         } | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  |     // 点击下载按钮时触发文件下载 | 
 |  |  |     $('#data-btn-file3').on('click', 'a', function() { | 
 |  |  |         var downloadUrl = $(this).attr('href'); | 
 |  |  |         // console.log(downloadUrl) | 
 |  |  |         // console.log(baseUrl) | 
 |  |  |         // window.open("/\//"+downloadUrl); | 
 |  |  |         // return false; | 
 |  |  |         // var downloadUrl = $(this).attr('href'); | 
 |  |  |         // console.log(downloadUrl) | 
 |  |  |         // // 发起 AJAX 请求,获取文件 | 
 |  |  |         $.ajax({ | 
 |  |  |             url: '/plan/download/file/auth', | 
 |  |  |             type: 'POST', | 
 |  |  |             data: { downloadUrl: downloadUrl },  // 传递下载链接作为参数 | 
 |  |  |             success: function(response) { | 
 |  |  |                 console.log(response) | 
 |  |  |                 // layer.msg(response.msg+',已下载至默认路径!详细下载路径:'+response.data, {icon: 1}); | 
 |  |  |                 layer.msg(response.msg, {icon: 1}); | 
 |  |  |                 location.href = response.data | 
 |  |  |         //         // window.open(baseUrl+response.msg) | 
 |  |  |         //         // 创建一个Blob对象 | 
 |  |  |         //         var blob = new Blob([response]); | 
 |  |  |         //         // 使用FileSaver保存文件 | 
 |  |  |         //         var fileName = downloadUrl.substring(downloadUrl.lastIndexOf('\\') + 1); | 
 |  |  |         //         console.log(fileName) | 
 |  |  |         //         saveAs(blob, fileName); | 
 |  |  |         //         return false; | 
 |  |  |             }, | 
 |  |  |             error: function() { | 
 |  |  |                 layer.msg('请求文件下载失败'); | 
 |  |  |             } | 
 |  |  |         }); | 
 |  |  |         // var downloadUrl = $(this).attr('href'); | 
 |  |  |         // console.log(downloadUrl) | 
 |  |  |         // if (downloadUrl == "" || downloadUrl == null) { | 
 |  |  |         //     layer.msg('请先上传app文件',{time:1000},() => { | 
 |  |  |         //         parent.location.reload() | 
 |  |  |         //     }) | 
 |  |  |         // }else{ | 
 |  |  |         //     window.open(downloadUrl); | 
 |  |  |         // } | 
 |  |  |         let url = getObjectUrl(downloadUrl) | 
 |  |  |         layer.msg("准备下载中", {icon: 1}); | 
 |  |  |         // location.href = url | 
 |  |  |         window.open(url) | 
 |  |  |         return false;  // 阻止默认的链接跳转行为 | 
 |  |  |     }); | 
 |  |  |  | 
 |  |  | 
 |  |  |         }); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /* 新建 */ | 
 |  |  |     function assistantPlan(data) { | 
 |  |  |         layer.confirm('确定要新建货架规划审批吗?', { | 
 |  |  |             skin: 'layui-layer-admin', | 
 |  |  |             shade: .1 | 
 |  |  |         }, function (i) { | 
 |  |  |             layer.close(i); | 
 |  |  |             var loadIndex = layer.load(2); | 
 |  |  |             $.ajax({ | 
 |  |  |                 url: baseUrl+"/plan/assistantPlan/add/auth", | 
 |  |  |                 headers: {'token': localStorage.getItem('token')}, | 
 |  |  |                 data: { | 
 |  |  |                     hostPlanId: data.id | 
 |  |  |                 }, | 
 |  |  |                 method: 'POST', | 
 |  |  |                 success: function (res) { | 
 |  |  |                     layer.close(loadIndex); | 
 |  |  |                     if (res.code === 200){ | 
 |  |  |                         layer.msg(res.msg, {icon: 1}); | 
 |  |  |                         tableReload(); | 
 |  |  |                     } else if (res.code === 403){ | 
 |  |  |                         top.location.href = baseUrl+"/"; | 
 |  |  |                     } else { | 
 |  |  |                         layer.msg(res.msg, {icon: 2}); | 
 |  |  |                     } | 
 |  |  |                 } | 
 |  |  |             }) | 
 |  |  |         }); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /* 删除 */ | 
 |  |  |     function del(ids) { | 
 |  |  |         layer.confirm('确定要删除选中数据吗?', { |