var pageCurr;
var wrkNo;
var wmsWrkNo;
var ioTime;
layui.config({
base: baseUrl + "/static/wms/layui/lay/modules/"
}).extend({
dropdown: 'dropdown/dropdown',
}).use(['table', 'laydate', 'form', 'dropdown'], function () {
var table = layui.table;
var $ = layui.jquery;
var layer = layui.layer;
var layDate = layui.laydate;
var form = layui.form;
$('#wrkNo').val(parent.wrkNo);
$('#wmsWrkNo').val(parent.wmsWrkNo);
// 数据渲染
tableIns = table.render({
elem: '#wrkMast',
headers: {token: localStorage.getItem('token')},
url: baseUrl + '/wrkMast/list/auth',
where: {wrk_no: parent.wrkNo, wms_wrk_no: parent.wmsWrkNo},
page: true,
limit: 16,
limits: [16, 30, 50, 100, 200, 500],
even: true,
toolbar: '#toolbar',
cellMinWidth: 50,
cols: [[
{type: 'checkbox'}
, {field: 'wmsWrkNo', align: 'center', title: 'WMS任务号', sort: true, width: 120}
, {field: 'wrkNo', align: 'center', title: '任务号', sort: true, width: 120}
, {field: 'ioTime$', align: 'center', title: '任务时间', sort: true, width: 160}
, {field: 'durationTime', align: 'center', title: '持续时长', width: 160}
, {field: 'wrkSts$', align: 'center', title: '任务状态'}
, {field: 'ioType$', align: 'center', title: '任务类型'}
, {field: 'ioPri', align: 'center', title: '优先级'}
, {field: 'crnNo$', align: 'center', title: '堆垛机'}
, {field: 'sourceStaNo$', align: 'center', title: '源站'}
, {field: 'staNo$', align: 'center', title: '目标站'}
, {field: 'sourceLocNo$', align: 'center', title: '起始点'}
, {field: 'locNo$', align: 'center', title: '目标点'}
, {field: 'barcode', align: 'center', title: '条码'}
, {field: 'preHave', align: 'center', title: '先入品', hide: true}
, {field: 'takeNone', align: 'center', title: '空操作', hide: true}
// ,{field: 'picking', align: 'center',title: '拣料', templet:function(row){
// var html = "";
// return html;
// }}
// ,{field: 'exitMk', align: 'center',title: '退出', templet:function(row){
// var html = "";
// return html;
// }}
// ,{field: 'emptyMk', align: 'center',title: '空板', templet:function(row){
// var html = "";
// return html;
// }}
//
// ,{field: 'crnStrTime$', align: 'center',title: '堆垛机启动时间'}
// ,{field: 'crnEndTime$', align: 'center',title: '堆垛机停止时间'}
// ,{field: 'refIotime$', align: 'center',title: '拣料时间'}
, {field: 'modiUser$', align: 'center', title: '修改人员', hide: true}
, {field: 'modiTime$', align: 'center', title: '修改时间', hide: true, width: 160}
// ,{field: 'memo', align: 'center',title: '备注'}
//
// ,{field: 'fullPlt', align: 'center',title: '满板', templet:function(row){
// var html = "";
// return html;
// }}
, {fixed: 'right', title: '操作', align: 'center', toolbar: '#operate', width: 110}
]],
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 + "/";
}
$(".layui-table-body, .layui-table-box, .layui-table-cell").css('overflow', 'visible');//解决layui数据表格中嵌套下拉框显示问题
pageCurr = curr;
limit();
form.on('checkbox(tableCheckbox)', function (data) {
var _index = $(data.elem).attr('table-index') || 0;
if (data.elem.checked) {
res.data[_index][data.value] = 'Y';
} else {
res.data[_index][data.value] = 'N';
}
});
}
});
// 监听排序事件
table.on('sort(wrkMast)', 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(wrkMast)', function (obj) {
var checkStatus = table.checkStatus(obj.config.id);
switch (obj.event) {
// 增加优先级
case 'priAdd':
var list = [];
checkStatus.data.map(function (track) {
list.push({
wrkNo: track.wrkNo,
ioTime: track.ioTime,
ioPri: track.ioPri
});
});
$.ajax({
url: baseUrl + "/wrkMast/add/pri/auth",
headers: {'token': localStorage.getItem('token')},
contentType: 'application/json;charset=UTF-8',
data: JSON.stringify(list),
method: 'POST',
traditional: true,
success: function (res) {
layer.closeAll();
if (res.code === 200) {
$(".layui-laypage-btn")[0].click();
layer.msg(res.msg);
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
}
})
break;
// 降低优先级
case 'priRed':
var list = [];
checkStatus.data.map(function (track) {
list.push({
wrkNo: track.wrkNo,
ioTime: track.ioTime,
ioPri: track.ioPri
});
});
$.ajax({
url: baseUrl + "/wrkMast/red/pri/auth",
headers: {'token': localStorage.getItem('token')},
contentType: 'application/json;charset=UTF-8',
data: JSON.stringify(list),
method: 'POST',
traditional: true,
success: function (res) {
layer.closeAll();
if (res.code === 200) {
$(".layui-laypage-btn")[0].click();
layer.msg(res.msg);
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
}
})
break;
case 'addData':
layer.open({
type: 2,
title: '新增',
maxmin: true,
area: [top.detailWidth, top.detailHeight],
shadeClose: false,
content: 'wrkMast_detail.html',
success: function (layero, index) {
layer.getChildFrame('#data-detail-submit-edit', index).hide();
clearFormVal(layer.getChildFrame('#detail', index));
layer.getChildFrame('##dealDownLine', index).hide();
layer.iframeAuto(index);
layer.style(index, {top: (($(window).height() - layer.getChildFrame('#data-detail', index).height()) / 3) + "px"});
}
});
break;
case 'deleteData':
var data = checkStatus.data;
if (data.length === 0) {
layer.msg('请选择数据');
} else {
layer.confirm('确定删除' + (data.length === 1 ? '此' : data.length) + '条数据吗', function () {
$.ajax({
url: baseUrl + "/wrkMast/delete/auth",
headers: {'token': localStorage.getItem('token')},
data: {param: JSON.stringify(data)},
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 = {
'wrkMast': exportData,
'fields': fields
};
$.ajax({
url: baseUrl + "/wrkMast/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(wrkMast)', function (obj) {
let data = obj.data;
switch (obj.event) {
// 明细展示
case 'detlShow':
wrkNo = data.wrkNo;
ioTime = data.ioTime;
// 表格下方显示
// locDetl(data.wrkNo);
// 弹层显示
layer.open({
type: 2,
title: '任务档明细',
maxmin: true,
area: [top.detailWidth, top.detailHeight],
shadeClose: true,
content: 'wrkDetl.html',
success: function (layero, index) {
}
});
break;
// 完成
case 'complete':
layer.confirm('确认完成该笔任务档?', {title: '任务号:' + data.wrkNo, shadeClose: true}, function () {
http.post(baseUrl + "/hand/control/wrkMast", {workNo: data.wrkNo, type: 1}, function (res) {
$(".layui-laypage-btn")[0].click();
layer.msg(data.wrkNo + res.msg);
})
layer.closeAll();
});
break;
// 取消
case 'cancel':
if (data.pdcType === "Y") {
layer.confirm('当前任务关联ERP销售单,取消将重新生成出库作业,是否继续?', {
title: '任务号:' + data.wrkNo,
shadeClose: true
}, function () {
http.post(baseUrl + "/hand/control/wrkMast", {workNo: data.wrkNo, type: 2}, function (res) {
$(".layui-laypage-btn")[0].click();
layer.msg(data.wrkNo + res.msg);
})
layer.closeAll();
});
} else {
layer.confirm('确认取消该笔任务档?', {
title: '任务号:' + data.wrkNo,
shadeClose: true
}, function () {
http.post(baseUrl + "/hand/control/wrkMast", {workNo: data.wrkNo, type: 2}, function (res) {
$(".layui-laypage-btn")[0].click();
layer.msg(data.wrkNo + res.msg);
})
layer.closeAll();
});
}
break;
// 拣料入库
case 'pick':
layer.confirm('拣料入库该笔任务档?', {title: '任务号:' + data.wrkNo, shadeClose: true}, function () {
http.post(baseUrl + "/hand/control/wrkMast", {workNo: data.wrkNo, type: 3}, function (res) {
$(".layui-laypage-btn")[0].click();
layer.msg(data.wrkNo + res.msg);
})
layer.closeAll();
});
break;
// 先入品
case 'preHave':
layer.confirm('任务发生先入品异常。如需重新入库,请确保货物已放至堆垛机出库站!', {
title: '任务号:' + data.wrkNo,
shadeClose: true
}, function () {
http.post(baseUrl + "/deal/preHave/start", {wrkNo: data.wrkNo}, function (res) {
$(".layui-laypage-btn")[0].click();
layer.msg(data.wrkNo + res.msg, {icon: 1});
})
layer.closeAll();
});
break;
// 空操作
case 'takeNone':
layer.confirm('任务发送空操作异常!是否。。。。。。。。?', {
title: '任务号:' + data.wrkNo,
shadeClose: true
}, function () {
});
break;
case 'more':
//更多下拉菜单
dropdown.render({
elem: '#operate'
, show: true //外部事件触发即显示
, data: [{
title: 'item 1'
, id: 'aaa'
}, {
title: 'item 2'
, id: 'bbb'
}, {
title: '删除'
, id: 'del'
}]
, click: function (data, othis) {
//根据 id 做出不同操作
if (data.id === 'del') {
layer.confirm('真的删除行么', function (index) {
obj.del();
layer.close(index);
});
} else {
layer.msg('得到表格下拉菜单 id:' + data.id);
}
}
, align: 'right' //右对齐弹出(v2.6.8 新增)
, style: 'box-shadow: 1px 1px 10px rgb(0 0 0 / 12%);' //设置额外样式
});
break;
case 'commandShow'://查看指令
wrkNo = data.wrkNo;
wmsWrkNo = data.wmsWrkNo;
layer.open({
type: 2,
title: 'WMS任务指令',
maxmin: true,
area: [top.detailWidth, top.detailHeight],
shadeClose: true,
content: '../commandManage/commandManage.html',
success: function (layero, index) {
}
});
break;
}
});
// 数据保存动作
form.on('submit(save)', function () {
if (banMsg != null) {
layer.msg(banMsg);
return;
}
method("add");
});
// 数据修改动作
form.on('submit(edit)', function () {
method("update")
});
function method(name) {
var index = layer.load(1, {
shade: [0.5, '#000'] //0.1透明度的背景
});
var data = {
wrkNo: $('#wrkNo').val(),
invWh: $('#invWh').val(),
ymd: top.strToDate($('#ymd\\$').val()),
mk: $('#mk').val(),
whsType: $('#whsType').val(),
wrkSts: $('#wrkSts').val(),
ioType: $('#ioType').val(),
crnNo: $('#crnNo').val(),
sheetNo: $('#sheetNo').val(),
ioPri: $('#ioPri').val(),
wrkDate: top.strToDate($('#wrkDate\\$').val()),
locNo: $('#locNo').val(),
staNo: $('#staNo').val(),
sourceStaNo: $('#sourceStaNo').val(),
sourceLocNo: $('#sourceLocNo').val(),
locSts: $('#locSts').val(),
picking: $('#picking').val(),
linkMis: $('#linkMis').val(),
onlineYn: $('#onlineYn').val(),
updMk: $('#updMk').val(),
exitMk: $('#exitMk').val(),
pltType: $('#pltType').val(),
emptyMk: $('#emptyMk').val(),
ioTime: top.strToDate($('#ioTime\\$').val()),
ctnType: $('#ctnType').val(),
packed: $('#packed').val(),
oveMk: $('#oveMk').val(),
mtnType: $('#mtnType').val(),
userNo: $('#userNo').val(),
crnStrTime: top.strToDate($('#crnStrTime\\$').val()),
crnEndTime: top.strToDate($('#crnEndTime\\$').val()),
plcStrTime: top.strToDate($('#plcStrTime\\$').val()),
crnPosTime: top.strToDate($('#crnPosTime\\$').val()),
loadTime: $('#loadTime').val(),
expTime: $('#expTime').val(),
refWrkno: $('#refWrkno').val(),
refIotime: top.strToDate($('#refIotime\\$').val()),
modiUser: $('#modiUser').val(),
modiTime: top.strToDate($('#modiTime\\$').val()),
appeUser: $('#appeUser').val(),
appeTime: top.strToDate($('#appeTime\\$').val()),
pauseMk: $('#pauseMk').val(),
errorTime: top.strToDate($('#errorTime\\$').val()),
errorMemo: $('#errorMemo').val(),
ctnKind: $('#ctnKind').val(),
manuType: $('#manuType').val(),
memo: $('#memo').val(),
scWeight: $('#scWeight').val(),
logMk: $('#logMk').val(),
logErrTime: top.strToDate($('#logErrTime\\$').val()),
logErrMemo: $('#logErrMemo').val(),
barcode: $('#barcode').val(),
PdcType: $('#PdcType').val(),
ctnNo: $('#ctnNo').val(),
fullPlt: $('#fullPlt').val(),
};
$.ajax({
url: baseUrl + "/wrkMast/" + name + "/auth",
headers: {'token': localStorage.getItem('token')},
data: top.reObject(data),
method: 'POST',
success: function (res) {
if (res.code === 200) {
parent.layer.closeAll();
parent.$(".layui-laypage-btn")[0].click();
$("#data-detail :input").each(function () {
$(this).val("");
});
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
layer.close(index);
}
})
}
// 复选框事件
form.on('checkbox(detailCheckbox)', function (data) {
var el = data.elem;
if (el.checked) {
$(el).val('Y');
} else {
$(el).val('N');
}
});
// 搜索栏搜索事件
form.on('submit(search)', function (data) {
pageCurr = 1;
$('#detlTable').css("display", 'none');
tableReload(false);
});
// 搜索栏重置事件
form.on('submit(reset)', function (data) {
pageCurr = 1;
clearFormVal($('#search-box'));
$('#detlTable').css("display", 'none');
tableReload(false);
});
// 时间选择器
layDate.render({
elem: '#ymd\\$',
type: 'datetime'
});
layDate.render({
elem: '#wrkDate\\$',
type: 'datetime'
});
layDate.render({
elem: '#ioTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#crnStrTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#crnEndTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#plcStrTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#crnPosTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#refIotime\\$',
type: 'datetime'
});
layDate.render({
elem: '#modiTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#appeTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#errorTime\\$',
type: 'datetime'
});
layDate.render({
elem: '#logErrTime\\$',
type: 'datetime'
});
layDate.render({
elem: '.layui-laydate-range'
, type: 'datetime'
, range: true
});
var pageCur;
function locDetl(param) {
$('#detlTable').css("display", 'block');
// 数据渲染
$('#wrkNo').val(param);
// 数据渲染
tableIns1 = table.render({
elem: '#wrkDetlByMap',
headers: {token: localStorage.getItem('token')},
url: baseUrl + '/wrkDetl/list/auth',
where: {wrk_no: param},
page: true,
limit: 16,
limits: [16, 30, 50, 100, 200, 500],
even: true,
toolbar: '#toolbar',
cellMinWidth: 50,
cols: [[
{type: 'checkbox'}
, {field: 'wrkNo', align: 'center', title: '任务号'}
, {field: 'ioTime$', align: 'center', title: '任务时间'}
, {field: 'matnr', align: 'center', title: '物料'}
, {field: 'lgnum', align: 'center', title: '仓库号'}
, {field: 'tbnum', align: 'center', title: '转储请求编号'}
, {field: 'tbpos', align: 'center', title: '行项目'}
, {field: 'zmatid', align: 'center', title: '物料标签ID'}
, {field: 'maktx', align: 'center', title: '物料描述'}
, {field: 'werks', align: 'center', title: '工厂'}
, {field: 'anfme', align: 'center', title: '数量'}
, {field: 'altme', align: 'center', title: '单位'}
, {field: 'zpallet', align: 'center', title: '托盘条码'}
, {field: 'bname', align: 'center', title: '用户ID'}
, {field: 'memo', align: 'center', title: '备注'}
, {fixed: 'right', title: '操作', align: 'center', toolbar: '#operate', width: 50}
]],
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 + "/";
}
pageCur = curr;
form.on('checkbox(tableCheckbox)', function (data) {
var _index = $(data.elem).attr('table-index') || 0;
if (data.elem.checked) {
res.data[_index][data.value] = 'Y';
} else {
res.data[_index][data.value] = 'N';
}
});
}
});
}
});
// 关闭动作
$(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 + "']");
if (find[0]!=null){
if (find[0].type === 'checkbox'){
if (data[val]==='Y'){
find.attr("checked","checked");
find.val('Y');
} else {
find.remove("checked");
find.val('N');
}
continue;
}
}
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.8);
}
layer.style(index, {
// top: (($(window).height()-height)/3)+"px",
height: height+'px'
});
}
$('body').keydown(function () {
if (event.keyCode === 13) {
$("#search").click();
}
});