| | |
| | | <head> |
| | | <meta charset="UTF-8"> |
| | | <meta name="viewport" content="width=device-width, target-densitydpi=high-dpi, initial-scale=1.0, user-scalable=no"/> |
| | | <title>中扬物流</title> |
| | | <title>浙江中扬立库技术有限公司</title> |
| | | <script type="text/javascript" src="../../static/js/common.js" charset="utf-8"></script> |
| | | <style> |
| | | * { |
| | | font-size: 12px; |
| | | } |
| | | html { |
| | | background-color: #fff; |
| | | } |
| | | |
| | | .mat-msg { |
| | | overflow-y: scroll; |
| | | margin-top: 10px; |
| | | height: 115px; |
| | | background-color: #fff; |
| | | border-radius: 5px; |
| | | border: 1px solid #c2c2c2; |
| | | } |
| | | #mat-msg-table { |
| | | font-size: 12px; |
| | | border-collapse: collapse; |
| | | margin: 0 auto; |
| | | text-align: center; |
| | | } |
| | | #tthead { |
| | | padding-top: 4px; |
| | | background-color: #ececec; |
| | | height: 18px; |
| | | } |
| | | #tthead span { |
| | | border-right: 1px solid #b3b3b3; |
| | | float: left; |
| | | width: 24%; |
| | | } |
| | | #ttbody { |
| | | padding-top: 4px; |
| | | } |
| | | #ttbody div { |
| | | content: ""; |
| | | clear: both; |
| | | display: table; |
| | | } |
| | | #ttbody span { |
| | | border-right: 1px solid #b3b3b3; |
| | | float: left; |
| | | width: 22%; |
| | | overflow:hidden; |
| | | white-space:nowrap; |
| | | text-overflow:ellipsis; |
| | | } |
| | | |
| | | #btn-con { |
| | | padding-left: 10px; |
| | | position: absolute; |
| | | bottom: 10px; |
| | | width: 100%; |
| | | } |
| | | #btn-con button { |
| | | display: inline-block; |
| | | vertical-align: middle; |
| | | } |
| | | #tips { |
| | | font-size: 12px; |
| | | margin-top: 2px; |
| | | margin-left: 10px; |
| | | display: inline-block; |
| | | vertical-align: middle; |
| | | width: 90px; |
| | | overflow:hidden; |
| | | white-space:nowrap; |
| | | text-overflow:ellipsis; |
| | | } |
| | | |
| | | /* 详情 */ |
| | | .form-box { |
| | | margin-top: 10px; |
| | | padding: 15px 0 10px 0; |
| | | text-align: center; |
| | | border: 1px solid #BBBBBB; |
| | | } |
| | | |
| | | .form-item { |
| | | margin-bottom: 5px; |
| | | } |
| | | .form-box span { |
| | | } |
| | | .form-box input { |
| | | overflow:hidden; |
| | | white-space:nowrap; |
| | | text-overflow:ellipsis; |
| | | } |
| | | .form-count button { |
| | | width: 25px; |
| | | height: 20px; |
| | | } |
| | | .form-count input { |
| | | margin: 0 7px; |
| | | width: 40px; |
| | | } |
| | | .form-btn-con { |
| | | margin-top: 10px; |
| | | } |
| | | .form-btn-con button { |
| | | padding: 4px 0; |
| | | height: 25px; |
| | | margin: 0 15px; |
| | | } |
| | | </style> |
| | | </head> |
| | | <body> |
| | | Hello World |
| | | <!-- <button onclick="her()">页面跳转</button>--> |
| | | <button onclick="help()" style="padding: 0 3px; position: absolute; top: 0%; right: 0%">?</button> |
| | | <div> |
| | | <span>条码</span> |
| | | <input type="text" id="code"> |
| | | </div> |
| | | <div> |
| | | <span>物料</span> |
| | | <input type="text" id="matNo" onkeyup="find(this)" autocomplete="off"> |
| | | <button onclick="find()">查询</button> |
| | | </div> |
| | | |
| | | <div class="mat-msg" id="mat-msg-id"> |
| | | <div id="mat-msg-table"> |
| | | <div id="tthead"> |
| | | <span>编码</span> |
| | | <span>名称</span> |
| | | <span>单位</span> |
| | | <span>数量</span> |
| | | </div> |
| | | <div id="ttbody"> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | |
| | | <div id="btn-con"> |
| | | <button style="margin-right: 20px" onclick="reset()">重置</button> |
| | | <button id="comb" onclick="comb()">组托</button> |
| | | <span id="tips"></span> |
| | | </div> |
| | | |
| | | <!-- 详情 --> |
| | | <div class="form-box" id="mat-detail"> |
| | | <div class="form-item form-count"> |
| | | <span style="margin-right: 10px">数量</span> |
| | | <button onclick="reduce()">-</button><input id="count" type="number" style="text-align: center"><button onclick="add()">+</button> |
| | | </div> |
| | | <div class="form-item"> |
| | | <span>名称</span> |
| | | <input id="matName" type="text" disabled="disabled" style="background-color: #ececec;color: #000"> |
| | | </div> |
| | | <div class="form-item"> |
| | | <span>单位</span> |
| | | <input id="str1" type="text" disabled="disabled" style="background-color: #ececec;color: #000; text-align: center;"> |
| | | </div> |
| | | <div class="form-item form-btn-con"> |
| | | <button id="confirm" onclick="confirm()">提取</button> |
| | | <button id="cancel" onclick="cancel()" style="background-color: #fff">取消</button> |
| | | </div> |
| | | </div> |
| | | |
| | | |
| | | </body> |
| | | <script> |
| | | function her() { |
| | | window.location.href="login.html"; |
| | | |
| | | var matMsgTableBlankRows = 0; // 空白行数 |
| | | var matData = []; // 表格数据 |
| | | var code = document.getElementById("code") |
| | | var matNo = document.getElementById("matNo") |
| | | var matMsg = document.getElementById("mat-msg-id"); |
| | | var matMsgTable = document.getElementById("mat-msg-table"); |
| | | var tthead = document.getElementById("tthead"); |
| | | var ttbody = document.getElementById("ttbody"); |
| | | var btnCon = document.getElementById("btn-con"); |
| | | var tipDom = document.getElementById("tips"); |
| | | var combBtn = document.getElementById("comb"); |
| | | |
| | | var matDetail = document.getElementById("mat-detail"); |
| | | var matName = document.getElementById("matName"); |
| | | var str1 = document.getElementById("str1"); |
| | | var count = document.getElementById("count"); |
| | | var confirmBtn = document.getElementById("confirm"); |
| | | |
| | | matDetail.style.display = 'none'; |
| | | var initMatCount = 1; |
| | | window.onload = function(){matMsg.focus();} |
| | | |
| | | // 查询物流 |
| | | function find(el) { |
| | | httpRequest({ |
| | | httpUrl: baseUrl + "/matCode/auth", |
| | | type: 'post', |
| | | headers: [{token: getCookie('token')}], |
| | | data: { |
| | | id: matNo.value |
| | | }, |
| | | }, function (res) { |
| | | if (res.code === 200) { |
| | | if (res.data != null) { |
| | | // 样式 |
| | | matMsg.style.display = 'none'; |
| | | btnCon.style.display = 'none'; |
| | | matDetail.style.display = 'block'; |
| | | // 填充数据 |
| | | matName.value = res.data.matName; |
| | | str1.value = res.data.str1; |
| | | |
| | | // count.focus(); |
| | | count.value = initMatCount; |
| | | confirmBtn.focus(); |
| | | } else { |
| | | matMsg.style.display = 'block'; |
| | | btnCon.style.display = 'block'; |
| | | matDetail.style.display = 'none'; |
| | | } |
| | | } else if (res.code === 403) { |
| | | window.location.href = baseUrl + "/pda/ce"; |
| | | } else { |
| | | tips(res.msg, true) |
| | | } |
| | | }) |
| | | } |
| | | |
| | | // 组托 |
| | | function comb() { |
| | | var barcode = code.value; |
| | | if (isEmpty(barcode)) { |
| | | tips("请输入托盘条码", true); |
| | | // document.getElementById("code").focus(); |
| | | return; |
| | | } |
| | | if (barcode.length !== 8) { |
| | | tips("条码必须为8位", true); |
| | | // document.getElementById("code").focus(); |
| | | return; |
| | | } |
| | | if (matData.length === 0) { |
| | | tips("请提取物料", true); |
| | | return; |
| | | } |
| | | httpRequest({ |
| | | httpUrl: baseUrl+"/mobile/comb/auth", |
| | | type: 'post', |
| | | headers: [ |
| | | {token: getCookie('token')} |
| | | ,{'Content-type':'application/json;charset=UTF-8',} |
| | | ], |
| | | data: JSON.stringify({ |
| | | barcode: barcode, |
| | | combMats: matData |
| | | }) , |
| | | }, function (res) { |
| | | if (res.code === 200) { |
| | | reset(); |
| | | tips("组托成功") |
| | | } else if (res.code === 403) { |
| | | window.location.href = baseUrl + "/pda/ce"; |
| | | } else { |
| | | tips(res.msg, true) |
| | | } |
| | | }) |
| | | } |
| | | |
| | | // initCrnMsgTable(); |
| | | function initCrnMsgTable(row) { |
| | | var line; |
| | | if (row === undefined){ |
| | | var one = 15; |
| | | var total = matMsg.offsetHeight; |
| | | var count = total / one; |
| | | count = parseInt(count) - 1; |
| | | matMsgTableBlankRows = count; |
| | | line = count; |
| | | } else { |
| | | line = row; |
| | | } |
| | | var html = ""; |
| | | for (var i = 0; i < line; i ++){ |
| | | html += " <div>\n" + |
| | | " <span></span>\n" + |
| | | " <span></span>\n" + |
| | | " <span></span>\n" + |
| | | " <span></span>\n" + |
| | | " </div>\n"; |
| | | } |
| | | ttbody.innerHTML = html; |
| | | } |
| | | |
| | | // 添加表格数据 |
| | | function addTableData(data) { |
| | | if (isEmpty(data.matName)){ |
| | | tips("提取失败"); |
| | | return; |
| | | } |
| | | var toPush = true; |
| | | for (var j=0;j<matData.length;j++){ |
| | | if (data.matNo === matData[j].matNo) { |
| | | matData[j].count = Number(matData[j].count) + Number(data.count); |
| | | toPush = false; |
| | | } |
| | | } |
| | | if (toPush) { |
| | | matData.push(data); |
| | | } |
| | | var html = ""; |
| | | for (var i=0;i<matData.length;i++) { |
| | | html += " <div class='table-data'>\n" + |
| | | " <span>" + matData[i].matNo + "</span>\n" + |
| | | " <span>" + matData[i].matName + "</span>\n" + |
| | | " <span>" + matData[i].str1 + "</span>\n" + |
| | | " <span>" + matData[i].count + "</span>\n" + |
| | | " </div>\n"; |
| | | } |
| | | |
| | | ttbody.innerHTML = html; |
| | | } |
| | | |
| | | // 重置 |
| | | function reset() { |
| | | code.value = ""; |
| | | matNo.value = ""; |
| | | cancel(); |
| | | while(ttbody.hasChildNodes()) { |
| | | ttbody.removeChild(ttbody.firstChild); |
| | | |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 提示信息 |
| | | * @param msg 提示内容 |
| | | * @param warn true:红色字体 |
| | | */ |
| | | function tips(msg, warn) { |
| | | tipDom.innerText = msg; |
| | | if (warn) { |
| | | tipDom.style.color = "red"; |
| | | } else { |
| | | tipDom.style.color = "#000"; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 详情 |
| | | */ |
| | | // 提取 |
| | | function confirm() { |
| | | addTableData({ |
| | | matNo: matNo.value, |
| | | matName: matName.value, |
| | | str1: str1.value, |
| | | count: count.value |
| | | }) |
| | | cancel(); |
| | | tips("提取成功"); |
| | | } |
| | | // 取消 |
| | | function cancel() { |
| | | matNo.value = ""; |
| | | matName.value = ""; |
| | | str1.value = ""; |
| | | count.value = initMatCount; |
| | | matMsg.style.display = 'block'; |
| | | btnCon.style.display = 'block'; |
| | | matDetail.style.display = 'none'; |
| | | tips(""); |
| | | } |
| | | |
| | | function add() { |
| | | count.value = Number(count.value) + 1; |
| | | } |
| | | function reduce() { |
| | | if (count.value <= initMatCount) { |
| | | return; |
| | | } |
| | | count.value = count.value - 1; |
| | | } |
| | | |
| | | //获取 cookie |
| | | function getCookie(objName){//获取指定名称的cookie的值 |
| | | //多个cookie 保存的时候是以 ;空格 分开的 |
| | | var arrStr = document.cookie.split("; "); |
| | | for (var i = 0; i < arrStr.length; i++) { |
| | | var temp = arrStr[i].split("="); |
| | | if (temp[0] === objName){ |
| | | return decodeURIComponent(temp[1]); |
| | | }else{ |
| | | return ""; |
| | | } |
| | | |
| | | } |
| | | } |
| | | |
| | | function httpRequest(paramObj,fun,errFun) { |
| | | var xmlhttp = null; |
| | | /*创建XMLHttpRequest对象, |
| | | *老版本的 Internet Explorer(IE5 和 IE6)使用 ActiveX 对象:new ActiveXObject("Microsoft.XMLHTTP") |
| | | * */ |
| | | if(window.XMLHttpRequest) { |
| | | xmlhttp = new XMLHttpRequest(); |
| | | }else if(window.ActiveXObject) { |
| | | xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); |
| | | } |
| | | /*判断是否支持请求*/ |
| | | if(xmlhttp == null) { |
| | | alert('你的浏览器不支持XMLHttp'); |
| | | return; |
| | | } |
| | | /*请求方式,并且转换为大写*/ |
| | | var httpType = (paramObj.type || 'GET').toUpperCase(); |
| | | /*数据类型*/ |
| | | var dataType = paramObj.dataType || 'json'; |
| | | /*请求接口*/ |
| | | var httpUrl = paramObj.httpUrl || ''; |
| | | /*是否异步请求*/ |
| | | var async = paramObj.async || true; |
| | | /*请求头参数*/ |
| | | var headerData = paramObj.headers || []; |
| | | /*请求参数--post请求参数格式为:foo=bar&lorem=ipsum*/ |
| | | var paramData = paramObj.data || []; |
| | | var requestData = ''; |
| | | for(var name in paramData) { |
| | | requestData += name + '='+ paramData[name] + '&'; |
| | | } |
| | | requestData = requestData === '' ? '' : requestData.substring(0,requestData.length - 1); |
| | | /*请求接收*/ |
| | | xmlhttp.onreadystatechange = function() { |
| | | if(xmlhttp.readyState === 4 && xmlhttp.status === 200) { |
| | | /*成功回调函数*/ |
| | | fun(JSON.parse(xmlhttp.responseText)); |
| | | }else{ |
| | | /*失败回调函数*/ |
| | | errFun; |
| | | } |
| | | } |
| | | |
| | | /*接口连接,先判断连接类型是post还是get*/ |
| | | if(httpType === 'GET') { |
| | | xmlhttp.open("GET",httpUrl,async); |
| | | xmlhttp.send(null); |
| | | }else if(httpType === 'POST'){ |
| | | xmlhttp.open("POST",httpUrl,async); |
| | | //发送合适的请求头信息 |
| | | var defaultContentType = true; |
| | | for (var i=0;i<headerData.length;i++) { |
| | | for(var key in headerData[i]) { |
| | | if (key === "Content-type") { |
| | | defaultContentType = false; |
| | | } |
| | | xmlhttp.setRequestHeader(key, headerData[i][key]); |
| | | } |
| | | } |
| | | if (defaultContentType) { |
| | | xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); |
| | | } |
| | | xmlhttp.send(defaultContentType?requestData:paramData); |
| | | } |
| | | } |
| | | |
| | | document.onkeyup = function (e) { |
| | | if (window.event)//如果window.event对象存在,就以此事件对象为准 |
| | | e = window.event; |
| | | var key = e.charCode || e.keyCode; |
| | | if (key === 112) { |
| | | code.focus(); |
| | | } else if (key === 113) { |
| | | matNo.focus(); |
| | | } else if (key === 114) { |
| | | combBtn.focus(); |
| | | } else if (key === 13) { |
| | | confirmBtn.focus(); |
| | | } |
| | | } |
| | | |
| | | document.onkeydown = function (e) { |
| | | if (window.event)//如果window.event对象存在,就以此事件对象为准 |
| | | e = window.event; |
| | | var key = e.charCode || e.keyCode; |
| | | if (key === 114) { |
| | | comb() |
| | | } |
| | | } |
| | | |
| | | function help() { |
| | | window.alert("① 按F1输入条码\n" + |
| | | "② 按F2输入商品编号,按ENTER查询,选择数量后提取\n" + |
| | | "③ 按F3开始组托\n" + |
| | | "其它:按F5刷新页面"); |
| | | } |
| | | </script> |
| | | </html> |