|  |  |  | 
|---|
|  |  |  | var pageCount = 0; | 
|---|
|  |  |  | var treeCond; | 
|---|
|  |  |  | var admin; | 
|---|
|  |  |  | var planNeedXmlSelData; | 
|---|
|  |  |  | layui.config({ | 
|---|
|  |  |  | base: baseUrl + "/static/layui/lay/modules/" | 
|---|
|  |  |  | }).extend({ | 
|---|
|  |  |  | steps: 'steps/steps', | 
|---|
|  |  |  | cascader: 'cascader/cascader', | 
|---|
|  |  |  | }).use(['table','laydate', 'form', 'admin', 'xmSelect', 'steps', 'element', 'cascader', 'tree', 'dropdown'], function(){ | 
|---|
|  |  |  | }).use(['table','laydate','layer','upload', 'form', 'admin', 'xmSelect', 'steps', 'element', 'cascader', 'tree', 'dropdown'], function(){ | 
|---|
|  |  |  | var table = layui.table; | 
|---|
|  |  |  | var $ = layui.jquery; | 
|---|
|  |  |  | var layer = layui.layer; | 
|---|
|  |  |  | var layDate = layui.laydate; | 
|---|
|  |  |  | var form = layui.form; | 
|---|
|  |  |  | admin = layui.admin; | 
|---|
|  |  |  | var upload = layui.upload; | 
|---|
|  |  |  | var xmSelect = layui.xmSelect; | 
|---|
|  |  |  | var steps = layui.steps; | 
|---|
|  |  |  | var cascader = layui.cascader; | 
|---|
|  |  |  | 
|---|
|  |  |  | {type: 'checkbox'} | 
|---|
|  |  |  | // ,{field: 'id', align: 'center',title: 'ID'} | 
|---|
|  |  |  | // ,{field: 'hostId$', align: 'center',title: '所属商户'} | 
|---|
|  |  |  | ,{field: 'userId$', align: 'left',title: '业务员'} | 
|---|
|  |  |  | ,{field: 'planType$', align: 'left',title: '业务类型', width: 150} | 
|---|
|  |  |  | ,{field: 'name', align: 'left',title: '售前规划申请单名称', width: 220, style: 'color: #1890ff;cursor:pointer', event: 'more'} | 
|---|
|  |  |  | ,{field: 'uuid', align: 'left',title: '规划单号', width: 100} | 
|---|
|  |  |  | ,{field: 'planNeed$', align: 'left',title: '所需', templet:function(d){return emptyShow(d.planNeed$)}} | 
|---|
|  |  |  | ,{field: 'deptId$', align: 'left',title: '所属部门'} | 
|---|
|  |  |  | ,{field: 'orderId$', align: 'left',title: '跟踪项目', width: 220, style: 'color: #1890ff;cursor:pointer', event: 'orderMore'} | 
|---|
|  |  |  | // ,{field: 'cstmrId$', align: 'left',title: '甲方单位', width: 220, style: 'color: #1890ff;cursor:pointer', event: 'cstmrMore'} | 
|---|
|  |  |  | ,{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: 'color: #1890ff;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: 'nowHeadman$', align: 'left',title: '规划组长',hide: true} | 
|---|
|  |  |  | ,{field: 'orderId$', align: 'left',title: '跟踪项目', width: 220, style: 'color: #1890ff;cursor:pointer', event: 'orderMore',hide: false} | 
|---|
|  |  |  | // ,{field: 'cstmrId$', align: 'left',title: '甲方单位', width: 220, style: 'color: #1890ff;cursor:pointer', event: 'cstmrMore',hide: true} | 
|---|
|  |  |  | ,{field: 'appleTime$', align: 'left',title: '申请日期', hide: true} | 
|---|
|  |  |  | // ,{field: 'beItem$', align: 'center',title: '立项'} | 
|---|
|  |  |  | // ,{field: 'planner', align: 'left',title: '规划员', templet:function(d){return emptyShow(d.planner)}} | 
|---|
|  |  |  | 
|---|
|  |  |  | // ,{field: 'planBonus', align: 'center',title: '规格奖金'} | 
|---|
|  |  |  | // ,{field: 'planLeaderBonus', align: 'center',title: '规格组长奖金'} | 
|---|
|  |  |  | // ,{field: 'files', align: 'center',title: '附件'} | 
|---|
|  |  |  | // ,{field: 'settle$', align: 'center',title: '进度'} | 
|---|
|  |  |  | ,{field: 'settle$', align: 'center',title: '进度', width: 150} | 
|---|
|  |  |  | // ,{field: 'settleMsg', align: 'center',title: '审核进度'} | 
|---|
|  |  |  | // ,{field: 'comment', align: 'center',title: '评论'} | 
|---|
|  |  |  | // ,{field: 'status$', align: 'center',title: '状态'} | 
|---|
|  |  |  | ,{field: 'createTime$', align: 'left',title: '添加日期', width: 160, hide: false} | 
|---|
|  |  |  | ,{field: 'updateBy$', align: 'left',title: '修改人'} | 
|---|
|  |  |  | ,{field: 'updateBy$', align: 'left',title: '修改人', width: 100} | 
|---|
|  |  |  | ,{field: 'updateTime$', align: 'left',title: '修改时间', hide: true} | 
|---|
|  |  |  | ,{field: 'memo', align: 'left',title: '注释', hide: true} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width: 180} | 
|---|
|  |  |  | ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width: 280} | 
|---|
|  |  |  | ]], | 
|---|
|  |  |  | request: { | 
|---|
|  |  |  | pageName: 'curr', | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pageCurr=curr;pageCount=count; | 
|---|
|  |  |  | limit(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //多文件列表 | 
|---|
|  |  |  | 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" 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('')); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //单个重传 | 
|---|
|  |  |  | 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'); //渲染新加的进度条组件 | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,done: function(res, index, upload){ //成功的回调 | 
|---|
|  |  |  | 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, n + '%'); //执行进度条。n 即为返回的进度百分比 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | case "del": | 
|---|
|  |  |  | del([data.id]); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case "uploadLink": | 
|---|
|  |  |  | // 打开弹窗 | 
|---|
|  |  |  | // 构建带参数的内容 | 
|---|
|  |  |  | layer.open({ | 
|---|
|  |  |  | type: 1, | 
|---|
|  |  |  | title: '上传文件-'+data.id, | 
|---|
|  |  |  | content: $('#myModal') | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // 获取路径下的文件列表,使用 jQuery 的 ajax 方法 | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: '/plan/view/file/auth', | 
|---|
|  |  |  | data:{ | 
|---|
|  |  |  | planId:data.id | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | success: function(response) { | 
|---|
|  |  |  | if (response.code==200){ | 
|---|
|  |  |  | var targetTable = document.getElementById("data-btn-file3"); | 
|---|
|  |  |  | // var targetTable1 = document.getElementById("layui-layer2"); | 
|---|
|  |  |  | // // 获取文本内容 | 
|---|
|  |  |  | // var text = targetTable1.textContent.trim(); | 
|---|
|  |  |  | // console.log(text); // 输出 '上传文件-20' | 
|---|
|  |  |  | targetTable.innerHTML = ''; | 
|---|
|  |  |  | // 将获取到的文件列表添加到文件队列中进行显示 | 
|---|
|  |  |  | response.data.forEach(function(file,index) { | 
|---|
|  |  |  | // 创建tr元素 | 
|---|
|  |  |  | var tr = document.createElement("tr"); | 
|---|
|  |  |  | tr.id = "upload-"+index; | 
|---|
|  |  |  | tr.innerHTML = '<td>' + file.name + '</td>' | 
|---|
|  |  |  | + '<td>' + (file.size / 1024).toFixed(1) + 'kb</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>' | 
|---|
|  |  |  | + '<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>' | 
|---|
|  |  |  | + '<a href="' + file.path + '" download class="layui-btn layui-btn-xs layui-btn-primary">下载</a>' | 
|---|
|  |  |  | + '</td>'; | 
|---|
|  |  |  | // 将tr元素添加到目标table中 | 
|---|
|  |  |  | targetTable.appendChild(tr); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | console.log('Failed to get file list error.'); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | error: function() { | 
|---|
|  |  |  | console.log('Failed to get file list.'); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | 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) | 
|---|
|  |  |  | // 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); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | error: function() { | 
|---|
|  |  |  | layer.msg('请求文件下载失败'); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return false;  // 阻止默认的链接跳转行为 | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function approval(planId, plannerId, dIdx) { | 
|---|
|  |  |  | 
|---|
|  |  |  | if (plan.orderId) { orderSel.setValue([{name: plan.orderId$, value: plan.orderId}]); } | 
|---|
|  |  |  | if (plan.cstmrId) { cstmrSel.setValue([{name: plan.cstmrId$, value: plan.cstmrId}]); } | 
|---|
|  |  |  | if (plan.userId) { userSel.setValue([{name: plan.userId$, value: plan.userId}]); } | 
|---|
|  |  |  | // console.log(plan); | 
|---|
|  |  |  | // console.log(plan.planNeed); | 
|---|
|  |  |  | // console.log(plan.planNeed.split("-")); | 
|---|
|  |  |  | // console.log(plan.planNeed.split("-").length); | 
|---|
|  |  |  | let split = plan.planNeed.split("-"); | 
|---|
|  |  |  | // console.log(split); | 
|---|
|  |  |  | // console.log(split.length); | 
|---|
|  |  |  | if (plan.planNeed) { | 
|---|
|  |  |  | var planNeedValue1=split[0]; | 
|---|
|  |  |  | for (var i=1;i<split.length;i++){ | 
|---|
|  |  |  | planNeedValue1 = planNeedSel+"-" +split[i]; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | planNeedSel.setValue([{name: plan.planNeed$, value: planNeedValue1}]); | 
|---|
|  |  |  | var data = [] | 
|---|
|  |  |  | split.forEach((item,idx) => { | 
|---|
|  |  |  | data.push(parseInt(item)) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | planNeedXmlSelData = data | 
|---|
|  |  |  | } | 
|---|
|  |  |  | layDateRender(plan); | 
|---|
|  |  |  | plan['planTypeName'] = plan.planType$; | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | window.loadPlanNeedSel = function () { | 
|---|
|  |  |  | return xmSelect.render({ | 
|---|
|  |  |  | var planNeedXmlSel = xmSelect.render({ | 
|---|
|  |  |  | el: '#planNeedXmlSel', | 
|---|
|  |  |  | autoRow: true, | 
|---|
|  |  |  | filterable: true, | 
|---|
|  |  |  | remoteSearch: true, | 
|---|
|  |  |  | remoteMethod: function (val, cb, show) { | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: baseUrl + "/planNeed/all/get/kv", | 
|---|
|  |  |  | headers: {'token': localStorage.getItem('token')}, | 
|---|
|  |  |  | data: { | 
|---|
|  |  |  | condition: val | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | method: 'POST', | 
|---|
|  |  |  | success: function (res) { | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | cb(res.data) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | cb([]); | 
|---|
|  |  |  | layer.msg(res.msg, {icon: 2}); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | data: [] | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: baseUrl + "/planNeed/all/get/kv", | 
|---|
|  |  |  | headers: {'token': localStorage.getItem('token')}, | 
|---|
|  |  |  | data: { | 
|---|
|  |  |  | condition: "" | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | method: 'POST', | 
|---|
|  |  |  | success: function (res) { | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | console.log(planNeedXmlSelData) | 
|---|
|  |  |  | planNeedXmlSel.update({ | 
|---|
|  |  |  | initValue: planNeedXmlSelData, | 
|---|
|  |  |  | data: res.data | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | cb([]); | 
|---|
|  |  |  | layer.msg(res.msg, {icon: 2}); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return planNeedXmlSel; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | window.loadUserSel = function () { | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 关闭动作 | 
|---|
|  |  |  | // 点击事件 | 
|---|
|  |  |  | $(document).on('click','#data-detail-close', function () { | 
|---|
|  |  |  | parent.layer.closeAll(); | 
|---|
|  |  |  | }); | 
|---|