| | |
| | | base: baseUrl + "/static/layui/lay/modules/" |
| | | }).extend({ |
| | | cascader: 'cascader/cascader', |
| | | }).use(['table','laydate', 'form', 'admin', 'xmSelect', 'element', 'cascader', 'tree', 'dropdown'], function(){ |
| | | }).use(['table','laydate', 'form', 'admin', 'xmSelect', 'element', 'cascader', 'tree', 'dropdown'], function() { |
| | | var table = layui.table; |
| | | var $ = layui.jquery; |
| | | var layer = layui.layer; |
| | |
| | | // 部门人员 筛选 |
| | | dropdown.render({ |
| | | elem: '#organization' |
| | | ,content: ['<div id="organizationTree" style="height: calc(100vh - 525px);border: none"></div>'].join('') |
| | | ,style: 'width: 370px; height: 350px; padding: 0 15px; box-shadow: 1px 1px 30px rgb(0 0 0 / 12%);' |
| | | ,ready: function(){ |
| | | , content: ['<div id="organizationTree" style="height: calc(100vh - 525px);border: none"></div>'].join('') |
| | | , style: 'width: 370px; height: 350px; padding: 0 15px; box-shadow: 1px 1px 30px rgb(0 0 0 / 12%);' |
| | | , ready: function () { |
| | | loadTree(); |
| | | } |
| | | }); |
| | | |
| | | // 树形图 |
| | | var organizationTree; |
| | | window.loadTree = function(condition){ |
| | | window.loadTree = function (condition) { |
| | | var loadIndex = layer.load(2); |
| | | $.ajax({ |
| | | url: baseUrl+"/dept/user/tree/auth", |
| | | url: baseUrl + "/dept/user/tree/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | 'condition': condition |
| | |
| | | method: 'POST', |
| | | success: function (res) { |
| | | layer.close(loadIndex); |
| | | if (res.code === 200){ |
| | | if (res.code === 200) { |
| | | organizationTree = tree.render({ |
| | | elem: '#organizationTree', |
| | | id: 'organizationTree', |
| | |
| | | } |
| | | }); |
| | | treeData = res.data; |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/"; |
| | | } else { |
| | | layer.msg(res.msg) |
| | | } |
| | |
| | | tableIns = table.render({ |
| | | elem: '#priOnline', |
| | | headers: {token: localStorage.getItem('token')}, |
| | | url: baseUrl+'/priOnline2/list/auth', |
| | | url: baseUrl + '/priOnline2/list/auth', |
| | | page: true, |
| | | limit: 16, |
| | | limits: [16, 30, 50, 100, 200, 500], |
| | |
| | | cellMinWidth: 150, |
| | | cols: [[ |
| | | {type: 'checkbox', fixed: 'left'} |
| | | ,{field: 'id', title: 'ID', sort: true,align: 'center', fixed: 'left', width: 80,hide: true} |
| | | ,{field: 'templateName', align: 'center',title: '客户名称', style: 'color: #1890ff;cursor:pointer', event: 'moreCstmr', width: 350,hide: false} |
| | | ,{field: 'cstmrId$', align: 'center',title: '客户id',hide: true} |
| | | ,{field: 'orderNum', align: 'center',title: '核价单号',hide: false} |
| | | ,{field: 'planId$', align: 'center',title: '规划单号', style: 'color: #1890ff;cursor:pointer', event: 'morePlan',hide: false} |
| | | ,{field: 'itemId', align: 'center',title: '规划单号', hide: true} |
| | | ,{field: 'createTime$', align: 'center',title: '创建时间'} |
| | | ,{field: 'updateTime$', align: 'center',title: '更新时间'} |
| | | ,{field: 'status$', align: 'center',title: '状态'} |
| | | , {field: 'id', title: 'ID', sort: true, align: 'center', fixed: 'left', width: 80, hide: true} |
| | | , { |
| | | field: 'templateName', |
| | | align: 'center', |
| | | title: '客户名称', |
| | | style: 'color: #1890ff;cursor:pointer', |
| | | event: 'moreCstmr', |
| | | width: 350, |
| | | hide: false |
| | | } |
| | | , {field: 'cstmrId$', align: 'center', title: '客户id', hide: true} |
| | | , {field: 'orderNum', align: 'center', title: '核价单号', hide: false} |
| | | , { |
| | | field: 'planId$', |
| | | align: 'center', |
| | | title: '规划单号', |
| | | style: 'color: #1890ff;cursor:pointer', |
| | | event: 'morePlan', |
| | | hide: false |
| | | } |
| | | , {field: 'itemId', align: 'center', title: '规划单号', hide: true} |
| | | , {field: 'createTime$', align: 'center', title: '创建时间'} |
| | | , {field: 'updateTime$', align: 'center', title: '更新时间'} |
| | | , {field: 'status$', align: 'center', title: '状态'} |
| | | // ,{field: 'memberId$', align: 'center',title: ''} |
| | | ,{field: 'settle$', align: 'center',title: '进度', style: 'color: #1890ff;cursor:pointer', event: 'more',hide: false} |
| | | ,{field: 'user$', align: 'center',title: '业务员'} |
| | | ,{field: 'updateUserId$', align: 'center',title: '更新人员'} |
| | | ,{field: 'checkDataStatus$', align: 'center',title: '报价数据'} |
| | | ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width:350} |
| | | , { |
| | | field: 'settle$', |
| | | align: 'center', |
| | | title: '进度', |
| | | style: 'color: #1890ff;cursor:pointer', |
| | | event: 'more', |
| | | hide: false |
| | | } |
| | | , {field: 'user$', align: 'center', title: '业务员'} |
| | | , {field: 'updateUserId$', align: 'center', title: '更新人员'} |
| | | , {field: 'checkDataStatus$', align: 'center', title: '报价数据'} |
| | | , {fixed: 'right', title: '操作', align: 'center', toolbar: '#operate', width: 350} |
| | | ]], |
| | | request: { |
| | | pageName: 'curr', |
| | |
| | | response: { |
| | | statusCode: 200 |
| | | }, |
| | | done: function(res, curr, count) { |
| | | done: function (res, curr, count) { |
| | | if (res.code === 403) { |
| | | top.location.href = baseUrl+"/"; |
| | | top.location.href = baseUrl + "/"; |
| | | } |
| | | pageCurr=curr; |
| | | pageCurr = curr; |
| | | limit(); |
| | | } |
| | | }); |
| | |
| | | // 监听排序事件 |
| | | table.on('sort(priOnline)', function (obj) { |
| | | var searchData = {}; |
| | | $.each($('#search-box [name]').serializeArray(), function() { |
| | | $.each($('#search-box [name]').serializeArray(), function () { |
| | | searchData[this.name] = this.value; |
| | | }); |
| | | searchData['orderByField'] = obj.field; |
| | |
| | | }, |
| | | done: function (res, curr, count) { |
| | | if (res.code === 403) { |
| | | top.location.href = baseUrl+"/"; |
| | | top.location.href = baseUrl + "/"; |
| | | } |
| | | pageCurr=curr; |
| | | pageCurr = curr; |
| | | limit(); |
| | | } |
| | | }); |
| | |
| | | // 监听头工具栏事件 |
| | | table.on('toolbar(priOnline)', function (obj) { |
| | | var checkStatus = table.checkStatus(obj.config.id); |
| | | switch(obj.event) { |
| | | switch (obj.event) { |
| | | case 'addBlank': |
| | | showEditModel(); |
| | | break; |
| | |
| | | break; |
| | | case 'deleteData': |
| | | var data = checkStatus.data; |
| | | var ids=[]; |
| | | var ids = []; |
| | | data.map(function (track) { |
| | | ids.push(track.id); |
| | | }); |
| | | if (ids.length === 0){ |
| | | if (ids.length === 0) { |
| | | layer.msg('请选择数据'); |
| | | } else { |
| | | layer.confirm('确定删除'+(ids.length===1?'此':ids.length)+'条数据吗', function(){ |
| | | layer.confirm('确定删除' + (ids.length === 1 ? '此' : ids.length) + '条数据吗', function () { |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/delete/auth", |
| | | url: baseUrl + "/priOnline2/delete/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: {ids: ids}, |
| | | method: 'POST', |
| | | traditional:true, |
| | | traditional: true, |
| | | success: function (res) { |
| | | if (res.code === 200){ |
| | | if (res.code === 200) { |
| | | layer.closeAll(); |
| | | tableReload(false); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/"; |
| | | } else { |
| | | layer.msg(res.msg) |
| | | } |
| | |
| | | } |
| | | break; |
| | | case 'exportData': |
| | | layer.confirm('确定导出Excel吗', {shadeClose: true}, function(){ |
| | | var titles=[]; |
| | | var fields=[]; |
| | | layer.confirm('确定导出Excel吗', {shadeClose: true}, function () { |
| | | var titles = []; |
| | | var fields = []; |
| | | obj.config.cols[0].map(function (col) { |
| | | if (col.type === 'normal' && col.hide === false && col.toolbar == null) { |
| | | titles.push(col.title); |
| | |
| | | } |
| | | }); |
| | | var exportData = {}; |
| | | $.each($('#search-box [name]').serializeArray(), function() { |
| | | $.each($('#search-box [name]').serializeArray(), function () { |
| | | exportData[this.name] = this.value; |
| | | }); |
| | | var param = { |
| | |
| | | 'fields': fields |
| | | }; |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/export/auth", |
| | | url: baseUrl + "/priOnline2/export/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: JSON.stringify(param), |
| | | dataType:'json', |
| | | contentType:'application/json;charset=UTF-8', |
| | | dataType: 'json', |
| | | contentType: 'application/json;charset=UTF-8', |
| | | method: 'POST', |
| | | success: function (res) { |
| | | layer.closeAll(); |
| | | if (res.code === 200) { |
| | | table.exportFile(titles,res.data,'xls'); |
| | | table.exportFile(titles, res.data, 'xls'); |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl+"/"; |
| | | top.location.href = baseUrl + "/"; |
| | | } else { |
| | | layer.msg(res.msg) |
| | | } |
| | |
| | | }); |
| | | |
| | | // 监听行工具事件 |
| | | table.on('tool(priOnline)', function(obj){ |
| | | table.on('tool(priOnline)', function (obj) { |
| | | var data = obj.data; |
| | | switch (obj.event) { |
| | | case 'approvalEnd': |
| | | layer.confirm('审批拒绝?', { |
| | | skin: 'layui-layer-admin', |
| | | shade: .1, |
| | | offset: '200px', |
| | | title: data.name |
| | | }, function (i) { |
| | | layer.close(i); |
| | | approvalEnd(data.id); |
| | | }); |
| | | break; |
| | | case 'approval': |
| | | layer.confirm('审批通过?', { |
| | | skin: 'layui-layer-admin', |
| | |
| | | remoteMethod: function (val, cb, show) { |
| | | let loadIndex = layer.load(2); |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/priQuoteAdd/list/auth", |
| | | url: baseUrl + "/priOnline2/priQuoteAdd/list/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | planId: data.id |
| | |
| | | area: [top.detailWidth, top.detailHeight], |
| | | shadeClose: false, |
| | | content: 'priOnline_detail.html?id=' + data.id, |
| | | success: function(layero, index){ |
| | | success: function (layero, index) { |
| | | // layer.iframeAuto(index);layer.style(index, {top: (($(window).height()-layer.getChildFrame('#data-detail', index).height())/3)+"px"}); |
| | | } |
| | | }); |
| | | break; |
| | | case 'del': |
| | | layer.confirm('确定删除这条数据吗', function(){ |
| | | layer.confirm('确定删除这条数据吗', function () { |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/delete/auth", |
| | | url: baseUrl + "/priOnline2/delete/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: {ids: data.id}, |
| | | method: 'POST', |
| | | traditional:true, |
| | | traditional: true, |
| | | success: function (res) { |
| | | if (res.code === 200){ |
| | | if (res.code === 200) { |
| | | layer.closeAll(); |
| | | tableReload(false); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/"; |
| | | } else { |
| | | layer.msg(res.msg) |
| | | } |
| | |
| | | break; |
| | | case "upload": |
| | | $.ajax({ |
| | | type:"get", |
| | | url: baseUrl+"/priOnline2/viewCheck/" + data.id + "/auth", |
| | | dataType:"json", |
| | | type: "get", |
| | | url: baseUrl + "/priOnline2/viewCheck/" + data.id + "/auth", |
| | | dataType: "json", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | success:function(res) { |
| | | success: function (res) { |
| | | if (res.code == 200) { |
| | | layer.confirm('当前已存在数据,继续上传将会覆盖旧数据,是否上传?', function(){ |
| | | layer.confirm('当前已存在数据,继续上传将会覆盖旧数据,是否上传?', function () { |
| | | $("#uploadQuote").click() |
| | | }); |
| | | }else{ |
| | | } else { |
| | | $("#uploadQuote").click() |
| | | } |
| | | } |
| | | }); |
| | | |
| | | $("#uploadQuote").on("change",(evt) => { |
| | | $("#uploadQuote").on("change", (evt) => { |
| | | var files = evt.target.files; |
| | | if(files==null || files.length==0){ |
| | | if (files == null || files.length == 0) { |
| | | alert("No files wait for import"); |
| | | return; |
| | | } |
| | | |
| | | let name = files[0].name; |
| | | let suffixArr = name.split("."), suffix = suffixArr[suffixArr.length-1]; |
| | | if(suffix!="xlsx"){ |
| | | let suffixArr = name.split("."), suffix = suffixArr[suffixArr.length - 1]; |
| | | if (suffix != "xlsx") { |
| | | alert("Currently only supports the import of xlsx files"); |
| | | return; |
| | | } |
| | | LuckyExcel.transformExcelToLucky(files[0], function(exportJson, luckysheetfile){ |
| | | if(exportJson.sheets==null || exportJson.sheets.length==0){ |
| | | LuckyExcel.transformExcelToLucky(files[0], function (exportJson, luckysheetfile) { |
| | | if (exportJson.sheets == null || exportJson.sheets.length == 0) { |
| | | alert("Failed to read the content of the excel file, currently does not support xls files!"); |
| | | return; |
| | | } |
| | |
| | | formData.append("id", data.id); |
| | | formData.append("checkData", zip(exportJson.sheets)); |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/uploadCheck/auth", |
| | | url: baseUrl + "/priOnline2/uploadCheck/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: formData, |
| | | // data: JSON.stringify({ |
| | |
| | | // contentType:'application/json;charset=UTF-8', |
| | | success: function (res) { |
| | | if (res.code == 200) { |
| | | layer.msg('上传成功',{time:1000},() => { |
| | | layer.msg('上传成功', {time: 1000}, () => { |
| | | parent.location.reload() |
| | | }) |
| | | }else{ |
| | | layer.msg(res.msg,{time:1000},() => { |
| | | } else { |
| | | layer.msg(res.msg, {time: 1000}, () => { |
| | | parent.location.reload() |
| | | }) |
| | | } |
| | |
| | | case "viewCheck": |
| | | //查看询价 |
| | | $.ajax({ |
| | | type:"get", |
| | | url: baseUrl+"/priOnline2/viewCheck/" + data.id + "/auth", |
| | | dataType:"json", |
| | | type: "get", |
| | | url: baseUrl + "/priOnline2/viewCheck/" + data.id + "/auth", |
| | | dataType: "json", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | success:function(res) { |
| | | success: function (res) { |
| | | if (res.code == 200) { |
| | | layer.open({ |
| | | type: 2, |
| | |
| | | area: [top.detailWidth, top.detailHeight], |
| | | shadeClose: false, |
| | | content: 'priOnline_check.html?id=' + data.id, |
| | | success: function(layero, index){ |
| | | success: function (layero, index) { |
| | | // layer.iframeAuto(index);layer.style(index, {top: (($(window).height()-layer.getChildFrame('#data-detail', index).height())/3)+"px"}); |
| | | } |
| | | }); |
| | | }else{ |
| | | layer.msg(res.msg,{time:1000}) |
| | | } else { |
| | | layer.msg(res.msg, {time: 1000}) |
| | | } |
| | | } |
| | | }); |
| | |
| | | area: [top.detailWidth, top.detailHeight], |
| | | shadeClose: false, |
| | | content: 'priOnline_detail.html?item_id=' + data.field.planId + "&template=" + data.field.template + "&name=" + data.field.name, |
| | | success: function(layero, index){ |
| | | success: function (layero, index) { |
| | | clearFormVal(layer.getChildFrame('#detail', index)); |
| | | // layer.iframeAuto(index);layer.style(index, {top: (($(window).height()-layer.getChildFrame('#data-detail', index).height())/3)+"px"}); |
| | | } |
| | |
| | | form.on('submit(editSubmit)', function (data) { |
| | | var loadIndex = layer.load(2); |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/updateForm/auth", |
| | | url: baseUrl + "/priOnline2/updateForm/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: data.field, |
| | | method: 'POST', |
| | | traditional:true, |
| | | traditional: true, |
| | | success: function (res) { |
| | | if (res.code === 200){ |
| | | if (res.code === 200) { |
| | | layer.closeAll(); |
| | | tableReload(false); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/"; |
| | | } else { |
| | | layer.msg(res.msg) |
| | | } |
| | |
| | | } |
| | | }); |
| | | } |
| | | |
| | | function approvalEnd(planId, plannerId, dIdx) { |
| | | let loadIndex = layer.load(2); |
| | | $.ajax({ |
| | | url: baseUrl+"/priOnline2/approvalEnd/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | priOnlineId: priOnlineId, |
| | | plannerId: plannerId |
| | | }, |
| | | method: 'POST', |
| | | success: function (res) { |
| | | if (dIdx) { |
| | | layer.close(dIdx); |
| | | } |
| | | 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 approval(priOnlineId, plannerId, dIdx) { |
| | | let loadIndex = layer.load(2); |