|  |  |  | 
|---|
|  |  |  | {type: 'checkbox'} | 
|---|
|  |  |  | ,{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: '业务员',hide: true, width: 100, sort: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: 150,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', | 
|---|
|  |  |  | 
|---|
|  |  |  | hide: false | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ,{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$', | 
|---|
|  |  |  | 
|---|
|  |  |  | title: '跟踪项目', | 
|---|
|  |  |  | width: 220, | 
|---|
|  |  |  | 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: 'appleTime$', align: 'left',title: '申请日期', hide: false, sort:true} | 
|---|
|  |  |  | // ,{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: 'assistantHostSign', align: 'left',title: '主副标记', hide: false} | 
|---|
|  |  |  | ,{field: 'hostPlanId', align: 'left',title: '主ID', hide: false} | 
|---|
|  |  |  | ,{field: 'assistantPlanId', align: 'left',title: '副ID', hide: false} | 
|---|
|  |  |  | ,{field: 'statusAll$', align: 'center',title: '状态', sort:true, sort:true} | 
|---|
|  |  |  | ,{field: 'createTime$', align: 'left',title: '添加日期', width: 160, hide: true, sort:true} | 
|---|
|  |  |  | ,{field: 'updateBy$', align: 'left',title: '修改人', width: 100, sort:true} | 
|---|
|  |  |  | ,{field: 'updateTime$', align: 'left',title: '修改时间', hide: true, sort:true} | 
|---|
|  |  |  | ,{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} | 
|---|
|  |  |  | ,{field: 'assistantHostSign', align: 'left',title: '主副标记', hide: true} | 
|---|
|  |  |  | ,{field: 'hostPlanId', align: 'left',title: '主ID', hide: true} | 
|---|
|  |  |  | ,{field: 'assistantPlanId', align: 'left',title: '副ID', hide: true} | 
|---|
|  |  |  | // ,{field: 'assistantPlanIdSignType', align: 'left',title: '集成货架标志', hide: true} | 
|---|
|  |  |  | ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width: 340} | 
|---|
|  |  |  | ]], | 
|---|
|  |  |  | request: { | 
|---|
|  |  |  | 
|---|
|  |  |  | 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-file-id-' + file.lastModified + '">准备上传</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>' | 
|---|
|  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | $('#data-btn-file3').append(tr) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | element.progress('progress-demo-'+ file.lastModified, '0%'); //执行进度条。 | 
|---|
|  |  |  | element.init(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | _uploadFile = file | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | var file = _uploadFile | 
|---|
|  |  |  | $("#upload-file-id-" + file.lastModified).html("上传中") | 
|---|
|  |  |  |  | 
|---|
|  |  |  | putObject(file).then((result) => { | 
|---|
|  |  |  | putObject(file,(p) => { | 
|---|
|  |  |  | element.progress('progress-demo-'+ file.lastModified, (Math.round(p * 100)) + "%"); //执行进度条。 | 
|---|
|  |  |  | }).then((result) => { | 
|---|
|  |  |  | var filename = result.name | 
|---|
|  |  |  | layer.msg('上传成功', {icon: 1}); | 
|---|
|  |  |  | $("#upload-file-id-" + file.lastModified).html("上传成功") | 
|---|
|  |  |  | $("#upload-filename-id-" + file.lastModified).html(filename) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | let token = localStorage.getItem("token"); | 
|---|
|  |  |  | $.ajax({ | 
|---|
|  |  |  | url: baseUrl+"/plan/insert/file/auth", | 
|---|
|  |  |  | url: baseUrl+"/plan/url/insert/file/auth", | 
|---|
|  |  |  | headers: {'token': localStorage.getItem('token')}, | 
|---|
|  |  |  | data: { | 
|---|
|  |  |  | 'planId': $('.layui-layer-title').text(), | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | 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', | 
|---|
|  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|