var pageCurr;
|
var admin;
|
layui.config({
|
base: baseUrl + "/static/layui/lay/modules/"
|
}).extend({
|
steps: 'steps/steps',
|
cascader: 'cascader/cascader',
|
}).use(['table','laydate', 'form', 'admin', 'xmSelect', 'element', 'cascader', 'steps', 'tree', 'dropdown','layer','upload', 'cascader'], function(){
|
var table = layui.table;
|
var $ = layui.jquery;
|
var layer = layui.layer;
|
var layDate = layui.laydate;
|
var form = layui.form;
|
admin = layui.admin;
|
var tree = layui.tree;
|
var steps = layui.steps;
|
var element = layui.element;
|
var upload = layui.upload;
|
var xmSelect = layui.xmSelect;
|
var cascader = layui.cascader;
|
var dropdown = layui.dropdown;
|
|
$('#organization').html(localStorage.getItem('nickname') + ' <i class="layui-icon"></i>');
|
|
// 部门人员 筛选
|
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(){
|
loadTree();
|
}
|
});
|
|
// 树形图
|
var organizationTree;
|
window.loadTree = function(condition){
|
var loadIndex = layer.load(2);
|
$.ajax({
|
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){
|
organizationTree = tree.render({
|
elem: '#organizationTree',
|
id: 'organizationTree',
|
onlyIconControl: true,
|
data: res.data,
|
click: function (obj) {
|
treeCond = {
|
key: obj.data.key,
|
val: obj.data.id
|
}
|
$('#organization').html(obj.data.title + ' <i class="layui-icon"></i>');
|
$('#organizationTree').find('.ew-tree-click').removeClass('ew-tree-click');
|
$(obj.elem).children('.layui-tree-entry').addClass('ew-tree-click');
|
clearFormVal($('#search-box'));
|
tableIns.reload({
|
where: {[obj.data.key]: obj.data.id},
|
page: {curr: 1}
|
});
|
}
|
});
|
treeData = res.data;
|
} else if (res.code === 403){
|
top.location.href = baseUrl+"/";
|
} else {
|
layer.msg(res.msg)
|
}
|
}
|
})
|
}
|
|
// 数据渲染
|
tableIns = table.render({
|
elem: '#priQuote',
|
headers: {token: localStorage.getItem('token')},
|
url: baseUrl+'/priQuote/list/auth',
|
page: true,
|
limit: 16,
|
limits: [16, 30, 50, 100, 200, 500],
|
toolbar: '#toolbar',
|
cellMinWidth: 150,
|
cols: [[
|
{type: 'checkbox', fixed: 'left'}
|
,{field: 'id', title: 'ID', sort: true,align: 'center', fixed: 'left', width: 80,hide : true, sort:true}
|
,{
|
field: 'templateName',
|
align: 'center',
|
title: '客户名称',
|
style: 'color: #1890ff;cursor:pointer',
|
event: 'moreCstmr',
|
width: 350,
|
hide: false, sort:true
|
}
|
,{field: 'cstmrId$', align: 'center',title: '客户id',hide: true}
|
,{field: 'inOrderNum', align: 'center',title: '报价编号',hide: false, sort:true}
|
// ,{field: 'orderNum', align: 'center',title: '报价预算单号',hide: false}
|
,{
|
field: 'planId$',
|
align: 'center',
|
title: '规划单号',
|
style: 'color: #1890ff;cursor:pointer',
|
event: 'morePlan'}
|
,{field: 'itemId', align: 'center',title: '规划单ID', hide: true, sort:true}
|
,{field: 'planName$', align: 'center',title: '规划单名称',hide: false}
|
,{
|
field: 'settle$',
|
align: 'center',
|
title: '进度',
|
style: 'color: #1890ff;cursor:pointer',
|
event: 'more',
|
width: 150,
|
hide: false
|
}
|
,{field: 'createTime$', align: 'center',title: '创建时间',hide: false}
|
,{field: 'updateTime$', align: 'center',title: '更新时间',hide: false}
|
// ,{field: 'memberId$', align: 'center',title: '业务员',hide: false}
|
,{field: 'userId$', align: 'center',title: '业务员',hide: true}
|
,{field: 'updateUserId$', align: 'center',title: '更新人员',hide: false}
|
,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width:280}
|
]],
|
request: {
|
pageName: 'curr',
|
pageSize: 'limit'
|
},
|
parseData: function (res) {
|
return {
|
'code': res.code,
|
'msg': res.msg,
|
'count': res.data.total,
|
'data': res.data.records
|
}
|
},
|
response: {
|
statusCode: 200
|
},
|
done: function(res, curr, count) {
|
if (res.code === 403) {
|
top.location.href = baseUrl+"/";
|
}
|
pageCurr=curr;pageCount=count;
|
limit();
|
}
|
});
|
|
$("#data-btn-file2").on("click", (e) => {
|
$("#data-btn-upload").click()
|
});
|
|
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;
|
}
|
|
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-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});
|
$("#upload-file-id-" + file.lastModified).html("上传成功")
|
$("#upload-filename-id-" + file.lastModified).html(filename)
|
|
$.ajax({
|
url: baseUrl+"/plan/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
|
});
|
|
// 监听排序事件
|
table.on('sort(priQuote)', function (obj) {
|
var searchData = {};
|
$.each($('#search-box [name]').serializeArray(), function() {
|
searchData[this.name] = this.value;
|
});
|
searchData['orderByField'] = obj.field;
|
searchData['orderByType'] = obj.type;
|
tableIns.reload({
|
where: searchData,
|
page: {
|
curr: 1
|
},
|
done: function (res, curr, count) {
|
if (res.code === 403) {
|
top.location.href = baseUrl+"/";
|
}
|
pageCurr=curr;
|
limit();
|
}
|
});
|
});
|
|
// 监听头工具栏事件
|
table.on('toolbar(priQuote)', function (obj) {
|
var checkStatus = table.checkStatus(obj.config.id);
|
console.log(checkStatus)
|
switch(obj.event) {
|
case 'addBlank':
|
showEditModel();
|
break;
|
case 'refreshData':
|
tableIns.reload({
|
page: {
|
curr: pageCurr
|
}
|
});
|
limit();
|
break;
|
case 'deleteData':
|
var data = checkStatus.data;
|
var ids=[];
|
data.map(function (track) {
|
ids.push(track.id);
|
});
|
if (ids.length === 0){
|
layer.msg('请选择数据');
|
} else {
|
layer.confirm('确定删除'+(ids.length===1?'此':ids.length)+'条数据吗', function(){
|
$.ajax({
|
url: baseUrl+"/priQuote/delete/auth",
|
headers: {'token': localStorage.getItem('token')},
|
data: {ids: ids},
|
method: 'POST',
|
traditional:true,
|
success: function (res) {
|
if (res.code === 200){
|
layer.closeAll();
|
tableReload(false);
|
} 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=[];
|
obj.config.cols[0].map(function (col) {
|
if (col.type === 'normal' && col.hide === false && col.toolbar == null) {
|
titles.push(col.title);
|
fields.push(col.field);
|
}
|
});
|
var exportData = {};
|
$.each($('#search-box [name]').serializeArray(), function() {
|
exportData[this.name] = this.value;
|
});
|
var param = {
|
'config': exportData,
|
'fields': fields
|
};
|
$.ajax({
|
url: baseUrl+"/priQuote/export/auth",
|
headers: {'token': localStorage.getItem('token')},
|
data: JSON.stringify(param),
|
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');
|
} else if (res.code === 403) {
|
top.location.href = baseUrl+"/";
|
} else {
|
layer.msg(res.msg)
|
}
|
}
|
});
|
});
|
break;
|
}
|
});
|
|
// 监听行工具事件
|
table.on('tool(priQuote)', function(obj){
|
var data = obj.data;
|
switch (obj.event) {
|
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 'morePlan':
|
top.planByMore = data.itemId;
|
admin.popupRight({
|
type: 1,
|
window: "top",
|
area: "1250px",
|
url: "../plan/plan_more_other.html",
|
end: function () {
|
// $(".layui-laypage-btn")[0].click();
|
}
|
})
|
break;
|
case 'approval':
|
layer.confirm('审批通过?', {
|
skin: 'layui-layer-admin',
|
shade: .1,
|
offset: '200px',
|
title: data.name
|
}, function (i) {
|
layer.close(i);
|
approval(data.id);
|
});
|
break;
|
case 'refuse':
|
layer.confirm('拒绝?', {
|
skin: 'layui-layer-admin',
|
shade: .1,
|
offset: '200px',
|
title: data.name
|
}, function (i) {
|
layer.close(i);
|
refuse(data.id);
|
});
|
break;
|
case 'more':
|
top.priQuoteByMore = data.id;
|
console.log(top.priQuoteByMore)
|
|
admin.popupRight({
|
type: 1,
|
window: "top",
|
area: "1250px",
|
url: "priQuote_more.html",
|
end: function () {
|
// $(".layui-laypage-btn")[0].click();
|
}
|
})
|
break;
|
case "quote":
|
console.log(data)
|
layer.open({
|
type: 2,
|
title: '报价单编辑',
|
maxmin: true,
|
area: [top.detailWidth, top.detailHeight],
|
shadeClose: false,
|
content: 'priQuote_detail.html?id=' + data.id + "&template=" + data.template,
|
success: function(layero, index){
|
// layer.iframeAuto(index);layer.style(index, {top: (($(window).height()-layer.getChildFrame('#data-detail', index).height())/3)+"px"});
|
}
|
});
|
break;
|
// 编辑
|
case 'edit':
|
showEditForm(data)
|
break;
|
case 'del':
|
layer.confirm('确定删除这条数据吗', function(){
|
$.ajax({
|
url: baseUrl+"/priQuote/delete/auth",
|
headers: {'token': localStorage.getItem('token')},
|
data: {ids: data.id},
|
method: 'POST',
|
traditional:true,
|
success: function (res) {
|
if (res.code === 200){
|
layer.closeAll();
|
tableReload(false);
|
} else if (res.code === 403){
|
top.location.href = baseUrl+"/";
|
} else {
|
layer.msg(res.msg)
|
}
|
}
|
})
|
});
|
break;
|
case "uploadLink":
|
// 打开弹窗
|
// 构建带参数的内容
|
console.log(data)
|
layer.open({
|
type: 1,
|
title: '上传文件-'+data.itemId,
|
content: $('#myModal')
|
});
|
// 获取路径下的文件列表,使用 jQuery 的 ajax 方法
|
$.ajax({
|
url: '/plan/view/file/auth',
|
data:{
|
planId:data.itemId
|
},
|
success: function(response) {
|
if (response.code==200){
|
var targetTable = document.getElementById("data-btn-file3");
|
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() {
|
console.log(this)
|
var downloadUrl = $(this).attr('href');
|
let url = getObjectUrl(downloadUrl)
|
layer.msg("准备下载中", {icon: 1});
|
location.href = url
|
return false; // 阻止默认的链接跳转行为
|
});
|
|
// 搜索
|
form.on('submit(search)', function (data) {
|
pageCurr = 1;
|
pageCount = 0;
|
tableReload();
|
});
|
|
/* 弹窗 - 新增、修改 */
|
function showEditModel(mData) {
|
admin.open({
|
type: 1,
|
area: '800px',
|
title: (mData ? '修改' : '添加') + '报价单',
|
content: $('#editDialog').html(),
|
success: function (layero, dIndex) {
|
form.on("#orderNumId",function (data) {
|
console.log(data)
|
})
|
form.val('detail', mData);
|
form.on('submit(editSubmit)', function (data) {
|
var loadIndex = layer.load(2);
|
layer.close(loadIndex);
|
layer.close(dIndex);
|
layer.open({
|
type: 2,
|
title: '新增',
|
maxmin: true,
|
area: [top.detailWidth, top.detailHeight],
|
shadeClose: false,
|
content: 'priQuote_detail.html?priQuoteBudgetId=' + data.field.id + "&template=" + data.field.template,
|
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"});
|
}
|
});
|
return false;
|
});
|
$(layero).children('.layui-layer-content').css('overflow', 'visible');
|
layui.form.render('select');
|
}
|
});
|
}
|
|
function refuse(planId, plannerId, dIdx) {
|
let loadIndex = layer.load(2);
|
$.ajax({
|
url: baseUrl+"/priQuote/refuse/auth",
|
headers: {'token': localStorage.getItem('token')},
|
data: {
|
planId: planId,
|
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(planId, plannerId, dIdx) {
|
let loadIndex = layer.load(2);
|
$.ajax({
|
url: baseUrl+"/priQuote/approval/auth",
|
headers: {'token': localStorage.getItem('token')},
|
data: {
|
planId: planId,
|
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});
|
}
|
}
|
})
|
}
|
|
//更新form
|
function showEditForm(mData) {
|
admin.open({
|
type: 1,
|
area: '800px',
|
title: '报价编辑',
|
content: $('#editForm').html(),
|
success: function (layero, dIndex) {
|
form.val('editFormDetail', mData);
|
form.render('select')
|
form.on('submit(editSubmit)', function (data) {
|
var loadIndex = layer.load(2);
|
$.ajax({
|
url: baseUrl+"/priQuote/updateForm/auth",
|
headers: {'token': localStorage.getItem('token')},
|
data: data.field,
|
method: 'POST',
|
traditional:true,
|
success: function (res) {
|
if (res.code === 200){
|
layer.closeAll();
|
tableReload(false);
|
} else if (res.code === 403){
|
top.location.href = baseUrl+"/";
|
} else {
|
layer.msg(res.msg)
|
}
|
}
|
})
|
layer.close(loadIndex);
|
layer.close(dIndex);
|
return false;
|
});
|
$(layero).children('.layui-layer-content').css('overflow', 'visible');
|
layui.form.render('select');
|
}
|
});
|
}
|
|
});
|
|
// 关闭动作
|
$(document).on('click','#data-detail-close', function () {
|
parent.layer.closeAll();
|
});
|
|
function tableReload(child) {
|
var searchData = {};
|
$.each($('#search-box [name]').serializeArray(), function() {
|
searchData[this.name] = this.value;
|
});
|
(child ? parent.tableIns : tableIns).reload({
|
where: searchData,
|
page: {
|
curr: pageCurr
|
},
|
done: function (res, curr, count) {
|
if (res.code === 403) {
|
top.location.href = baseUrl+"/";
|
}
|
pageCurr=curr;
|
if (res.data.length === 0 && count !== 0) {
|
tableIns.reload({
|
where: searchData,
|
page: {
|
curr: pageCurr-1
|
}
|
});
|
pageCurr -= 1;
|
}
|
limit(child);
|
}
|
});
|
}
|
|
function setFormVal(el, data, showImg) {
|
for (var val in data) {
|
var find = el.find(":input[id='" + val + "']");
|
find.val(data[val]);
|
if (showImg){
|
var next = find.next();
|
if (next.get(0)){
|
if (next.get(0).localName === "img") {
|
find.hide();
|
next.attr("src", data[val]);
|
next.show();
|
}
|
}
|
}
|
}
|
}
|
|
function clearFormVal(el) {
|
$(':input', el)
|
.val('')
|
.removeAttr('checked')
|
.removeAttr('selected');
|
}
|
|
function detailScreen(index) {
|
var detail = layer.getChildFrame('#data-detail', index);
|
var height = detail.height()+60;
|
if (height > ($(window).height()*0.9)) {
|
height = ($(window).height()*0.9);
|
}
|
layer.style(index, {
|
top: (($(window).height()-height)/3)+"px",
|
height: height+'px'
|
});
|
$(".layui-layer-shade").remove();
|
}
|
|
$('body').keydown(function () {
|
if (event.keyCode === 13) {
|
$("#search").click();
|
}
|
});
|
|
function getItemInfo(val) {
|
$.ajax({
|
url: baseUrl+"/priOnline2/" + val + "/auth",
|
headers: {'token': localStorage.getItem('token')},
|
method: 'GET',
|
traditional:true,
|
success: function (res) {
|
if (res.code === 200){
|
$("#planId").val(res.data.planId$)
|
$("#priSalesNum").val(res.data.orderNum)
|
} else if (res.code === 403){
|
top.location.href = baseUrl+"/";
|
} else {
|
layer.msg(res.msg)
|
}
|
}
|
})
|
}
|