var baseUrl = "/tzhnewms"; // 详情窗口-高度 var detailHeight = '80%'; // 详情窗口-宽度 var detailWidth = '90%'; function checkPassword(password) { //密码必须包含字符和数字长度不能少于8位 let pattern = /(?=.*[0-9])(?=.*[a-zA-Z!@#$]).{8,}/ //不能包含连续数字 let pattern2 = /(0(?=1)|1(?=2)|2(?=3)|3(?=4)|4(?=5)|5(?=6)|6(?=7)|7(?=8)|8(?=9)){3}\d/ //重复数字不能超过四位 let pattern3 = /(\d)\1{3}/ if (pattern.test(password) && pattern2.test(password) === false && pattern3.test(password) === false) { //匹配放行 return true } //不匹配要求修改密码1 return false; } // 非空判断 function isEmpty(obj){ return typeof obj == "undefined" || obj == null || obj === ""; } // let loadIndex = layer.msg('请求中...', {icon: 16, shade: 0.01, time: false}); // layer.close(loadIndex); // 时间 ==>> 字符串 function dateToStr(date, millisecond) { var time = new Date(date); var y = time.getFullYear(); var M = time.getMonth() + 1; M = M < 10 ? ("0" + M) : M; var d = time.getDate(); d = d < 10 ? ("0" + d) : d; var h = time.getHours(); h = h < 10 ? ("0" + h) : h; var m = time.getMinutes(); m = m < 10 ? ("0" + m) : m; var s = time.getSeconds(); s = s < 10 ? ("0" + s) : s; if (!millisecond) { return y + "-" + M + "-" + d + " " + h + ":" + m + ":" + s; } else { var p = time.getMilliseconds(); if (p < 10) { p = "00" + p; } if (p < 100) { p = "0" + p; } return y + "-" + M + "-" + d + " " + h + ":" + m + ":" + s + "," + p; } } // 字符串 ===>> 时间 function strToDate(str) { var t = Date.parse(str); if (!isNaN(t)) { return new Date(Date.parse(str.replace(/-/g, "/"))); } else { return null; } } // 清理对象null值 function reObject(data) { for (var obj in data) { if (data[obj]===null){ delete data[obj]; } } return data; } /** * disabled 属性转换 */ function convertDisabled(el, param) { el.each(function () { $(this).attr("disabled", param); }); } // 权限 function limit(child){ if (child == null){ child = false; } var param = (child?parent.window:window).location.href.split("?")[1]; if (null != param) { var resourceId = param.split("=")[1]; $.ajax({ url: baseUrl+"/power/menu/"+resourceId+"/auth", headers: {'token': localStorage.getItem('token')}, method: 'GET', async: false, success: function (res) { if (res.code === 200){ for(var i = 0, len = res.data.length; i < len; i++) { (child?parent:window).$('#'+res.data[i].code).css("display", "inline-block"); (child?parent:window).$('.'+res.data[i].code).css("display", "inline-block"); } } else if (res.code === 403){ top.location.href = baseUrl+"/"; } else { layer.msg(res.msg) } } }); } } // http请求 !function (n) { "use strict"; var http = { toAjax: function (params) { $.ajax(params); }, get: function (url, data, callback) { http.toAjax({ method: 'GET', url: url, data: data, dataType: 'json', header: {'token': localStorage.getItem('token')}, timeout: 10000, cache: false, success: function (res) { if (res.code === 200){ callback(res); } else if (res.code === 403){ top.location.href = baseUrl+"/"; } else { layer.msg(res.msg); } }, error: function (res, type) { } }) }, // 默认表单 post: function (url, param, callback, type) { var headerType; if (type === 'json') { headerType = {'Content-Type': 'application/json'} } else { headerType = {'Content-Type': 'application/x-www-form-urlencoded'} } headerType['token'] = localStorage.getItem('token'); http.toAjax({ method: 'POST', url: url, data: param, dataType: 'json', headers: headerType, timeout: 10000, cache: false, success: function (res) { if (res.code === 200){ callback(res); } else if (res.code === 403){ top.location.href = baseUrl+"/"; } else { layer.msg(res.msg); } }, error: function (res, type) { } }) }, }; "function" == typeof define && define.amd ? define(function () { return http }) : "object" == typeof module && module.exports ? module.exports = http : n.http = http }(this); /*************************************************************************************************************/ /********************************************** 物料业务抽象 ***************************************************/ /*************************************************************************************************************/ function arrRemove(arr, key, val) { for(var i=arr.length-1; i>=0; i--){ if(arr[i][key] === val){ arr.splice(i,1); } } } var matCols = [ {field: 'matnr', align: 'center',title: '商品编号', width: 180} // {field: 'id', align: 'center',title: 'ID'} // ,{field: 'uuid', align: 'center',title: '编号'} // ,{field: 'tagId$', align: 'center',title: '所属归类'} ,{field: 'maktx', align: 'center',title: '商品名称'} // ,{field: 'name', align: 'center',title: '别名'} ,{field: 'specs', align: 'center',title: '规格'} ,{field: 'origin', align: 'center',title: '产地'} ,{field: 'model', align: 'center',title: '代码', hide: true} ,{field: 'color', align: 'center',title: '颜色', hide: true} ,{field: 'brand', align: 'center',title: '品牌', hide: true} ,{field: 'unit', align: 'center',title: '单位', hide: true} ,{field: 'price', align: 'center',title: '单价', hide: true} ,{field: 'sku', align: 'center',title: 'sku', hide: true} ,{field: 'units', align: 'center',title: '单位量', hide: true} ,{field: 'barcode', align: 'center',title: '条码', hide: true} ,{field: 'origin', align: 'center',title: '产地', hide: true} ,{field: 'manu', align: 'center',title: '厂家', hide: true} ,{field: 'manuDate', align: 'center',title: '生产日期', hide: true} ,{field: 'itemNum', align: 'center',title: '品项数', hide: true} ,{field: 'safeQty', align: 'center',title: '安全库存量', hide: true} ,{field: 'weight', align: 'center',title: '单箱净重', hide: true} ,{field: 'length', align: 'center',title: '单箱毛重', hide: true} ,{field: 'volume', align: 'center',title: '单箱体积', hide: true} ,{field: 'threeCode', align: 'center',title: '箱子尺寸', hide: true} ,{field: 'supp', align: 'center',title: '供应商', hide: true} ,{field: 'suppCode', align: 'center',title: '供应商编码', hide: true} ,{field: 'beBatch$', align: 'center',title: '是否批次', hide: true} ,{field: 'deadTime', align: 'center',title: '保质期', hide: true} ,{field: 'deadWarn', align: 'center',title: '预警天数', hide: true} ,{field: 'source$', align: 'center',title: '制购', hide: true} ,{field: 'check$', align: 'center',title: '要求检验', hide: true} ,{field: 'danger$', align: 'center',title: '危险品', hide: true} // ,{field: 'status$', align: 'center',title: '状态'} // ,{field: 'createBy$', align: 'center',title: '添加人员'} // ,{field: 'createTime$', align: 'center',title: '添加时间'} ,{field: 'updateBy$', align: 'center',title: '修改人员', hide: true} ,{field: 'updateTime$', align: 'center',title: '修改时间', hide: true} ,{field: 'memo', align: 'center',title: '备注', hide: true} ,{field: 'inventoryMax', align: 'center',title: '库存上限', hide: false} ,{field: 'inventoryMin', align: 'center',title: '库存下限', hide: false} ,{field: 'inventoryAgeMax', align: 'center',title: '库龄上限', hide: false} ] var detlCols = [ {field: 'matnr', align: 'center',title: '商品编号', sort:true} ,{field: 'maktx', align: 'center',title: '商品名称', sort:true} ,{field: 'orderNo', align: 'center',title: '单据编号', hide: true} ,{field: 'batch', align: 'center',title: '批号', sort:true} ,{field: 'anfme', align: 'center',title: '数量(件)',hide: false} ,{field: 'zpallet', align: 'center',title: '托盘条码',hide: false} ,{field: 'specs', align: 'center',title: '规格',hide: true} ,{field: 'model', align: 'center',title: '代码', hide: false} ,{field: 'color', align: 'center',title: '颜色', hide: true} ,{field: 'brand', align: 'center',title: '品牌', hide: true} ,{field: 'unit', align: 'center',title: '单位', hide: true} ,{field: 'price', align: 'center',title: '单价', hide: true} ,{field: 'sku', align: 'center',title: 'sku', hide: true} ,{field: 'units', align: 'center',title: '单位量', hide: true} ,{field: 'barcode', align: 'center',title: '条码', hide: true} ,{field: 'origin', align: 'center',title: '产地', hide: true} ,{field: 'manu', align: 'center',title: '厂家', hide: true} ,{field: 'manuDate', align: 'center',title: '生产日期', hide: true} ,{field: 'itemNum', align: 'center',title: '品项数', hide: true} ,{field: 'safeQty', align: 'center',title: '安全库存量', hide: true} ,{field: 'weight', align: 'center',title: '重量', hide: false} ,{field: 'length', align: 'center',title: '单箱毛重', hide: true} ,{field: 'volume', align: 'center',title: '单箱体积', hide: true} ,{field: 'threeCode', align: 'center',title: '箱子尺寸', hide: true} ,{field: 'supp', align: 'center',title: '供应商', hide: true} ,{field: 'suppCode', align: 'center',title: '供应商编码', hide: true} ,{field: 'beBatch$', align: 'center',title: '是否批次', hide: true} ,{field: 'deadTime', align: 'center',title: '保质期', hide: true} ,{field: 'deadWarn', align: 'center',title: '预警天数', hide: true} ,{field: 'source$', align: 'center',title: '制购', hide: true} ,{field: 'check$', align: 'center',title: '要求检验', hide: true} ,{field: 'danger$', align: 'center',title: '危险品', hide: true} ,{field: 'owner$', align: 'center',title: '货主', hide: false} ] var plaCols = [ {field: 'id', title: 'id', align: 'center',hide:true} ,{type: 'checkbox',totalRow:true} ,{field:'id', width:80, title: '', sort: true, totalRowText: '合计:',hide: true} ,{field: 'pakinTime$', title: '入库时间', align: 'center' , sort:true} ,{field: 'matnr', align: 'center',title: '存货编码',hide:true,edit:true} ,{field: 'brand', align: 'center',title: '牌号',edit:true} ,{field: 'batch', align: 'center',title: '批号',edit:true, width: 150, sort:true} ,{field: 'packageNo', align: 'center',title: '包装号',edit:true, sort:true} ,{field: 'proDate', align: 'center',title: '生产日期',edit:true, width: 100} ,{field: 'weight', align: 'center',title: '重量KG',edit:true,totalRow:true} ,{field: 'packageType', align: 'center',title: '包装类型',edit:true} ,{field: 'zpalletType', align: 'center',title: '托盘类型',edit:true} ,{field: 'filmWrap', align: 'center',title: '缠膜',edit:true,hide:true} ,{field: 'fingerMelting', align: 'center',title: '熔指,g/10min',edit:true} ,{field: 'water', align: 'center',title: '水分,ppm', hide:true,edit:true} ,{field: 'fusingPoint', align: 'center',title: '熔点,℃',edit:true} ,{field: 'vadf1', align: 'center',title: '挥发段,%', hide:true,edit:true} ,{field: 'vadf2', align: 'center',title: '分解段,%', hide:true,edit:true} ,{field: 'yellowness', align: 'center',title: '黄度',edit:true} ,{field: 'opacity', align: 'center',title: '不透明度,%',edit:true} ,{field: 'l', align: 'center',title: 'L*', hide:true,edit:true} ,{field: 'a', align: 'center',title: 'a*', hide:true,edit:true} ,{field: 'b', align: 'center',title: 'b*', hide:true,edit:true} ,{field: 'fillIn', align: 'center',title: '填充,%',hide:true,edit:true} ,{field: 'str1', align: 'center',title: '拉伸强度,MPa',hide:true,edit:true} ,{field: 'str2', align: 'center',title: '断裂伸长率,%',hide:true,edit:true} ,{field: 'str3', align: 'center',title: '缺口冲击,KJ/m2',hide:true,edit:true} ,{field: 'str4', align: 'center',title: '维卡,℃',hide:true,edit:true} ,{field: 'str5', align: 'center',title: '半结晶时间,min',hide:true,edit:true} ,{field: 'str6', align: 'center',title: '结晶度,%',hide:true,edit:true} ,{field: 'massState', align: 'center',title: '质量状态',edit:true} ,{field: 'problem', align: 'center',title: '备注',edit:true,hide:true} ,{field: 'direction', align: 'center',title: '应用方向',edit:true,hide:true} ,{field: 'position', align: 'center',title: '存放位置',edit:true,hide:true} ,{field: 'stash', align: 'center',title: '仓库',edit:true,hide:true} ,{field: 'locNo', align: 'center',title: '库位',edit:true} ,{field: 'owner', align: 'center',title: '主体',edit:true} ,{field: 'type', align: 'center',title: '物资类别',hide:true,edit:true} ,{field: 'proOrderNo', align: 'center',title: '生产订单编号',hide:true,edit:true} ,{field: 'workshop', align: 'center',title: '生产车间',hide:true,edit:true} ,{field: 'line', align: 'center',title: '生产线',hide:true,edit:true} ,{field: 'weightAnfme', align: 'center',title: '剩余重量(KG)',edit:true,totalRow:true} ,{field: 'qtyAnfme', align: 'center',title: '待出库重量(KG)',hide:true} ,{field: 'status', align: 'center',title: '状态', templet: setState ,edit:true} ,{field: 'stockFreeze', align: 'center',title: '库存冻结', templet: '#stockFreezeTpl'} ,{field: 'stockFreezeBy', align: 'center',title: '操作人员',hide:true} ,{field: 'stockFreezeDate$', align: 'center',title: '操作日期',hide:true} ,{align: 'center', title: '流转明细', toolbar: '#tbLook'} ,{field: 'createTime$', title: '创建时间', align: 'center' , sort:true} ] function setState(data){ if(data.status === "待入库"){ return "待入库" }else if(data.status === "已入库"){ return "已入库" }else if(data.status === "待出库"){ return "待出库" }else if(data.status === "部分出库"){ return "部分出库" }else if(data.status === "全部出库"){ return "全部出库" }else if(data.status === "暂入库"){ return "暂入库" } } function getQueryVariable(variable) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i=0;i