| | |
| | | <script type="text/javascript" src="../../static/js/handlebars/handlebars-v4.5.3.js"></script> |
| | | </head> |
| | | <style> |
| | | .form-box span { |
| | | font-size: 16px; |
| | | display: inline-block; |
| | | text-align: right; |
| | | } |
| | | .form-box input { |
| | | width: 165px; |
| | | padding-left: 5px; |
| | | height: 30px; |
| | | border: 1px solid #777777; |
| | | overflow:hidden; |
| | | white-space:nowrap; |
| | | text-overflow:ellipsis; |
| | | } |
| | | .number-tool { |
| | | margin-left: 10px; |
| | | padding: 1px 0 1px 5px; |
| | | display: inline-block; |
| | | width: 120px; |
| | | } |
| | | |
| | | .number-tool:after { |
| | | clear: both; |
| | | content: ""; |
| | | display: table; |
| | | } |
| | | |
| | | .number-tool button { |
| | | background-color: #fff; |
| | | margin-top: 3px; |
| | |
| | | width: 25px; |
| | | border: 1px solid #777777; |
| | | } |
| | | |
| | | .number-tool input { |
| | | text-align: center; |
| | | height: 30px; |
| | |
| | | </style> |
| | | <body> |
| | | |
| | | <header> |
| | | <div> |
| | | <header class="layui-form"> |
| | | <div class="layui-input-inline"> |
| | | <label class="layui-form-label" style="margin-left: 32px">单号</label> |
| | | <div class="layui-input-inline"> |
| | | <label class="layui-form-label" style="margin-left: 32px">库区</label> |
| | | <input class="layui-input" id="uuid" onkeyup="findCode(this, 'uuid')" placeholder="扫码 / 输入" |
| | | autocomplete="off"> |
| | | </div> |
| | | <div class="layui-input-inline"> |
| | | <label class="layui-form-label">物料编码</label> |
| | | <input class="layui-input" id="matnr" onkeyup="findCode(this, 'matnr')" placeholder="扫码 / 输入" style="width: 65%" |
| | | autocomplete="off"> |
| | | <input id="billNo" class="layui-input" autocomplete="off" oninput="findCode(this, 'billNo')" |
| | | style="width: 175px"> |
| | | </div> |
| | | </div> |
| | | |
| | | <div class="layui-input-inline"> |
| | | <label class="layui-form-label">物料编码</label> |
| | | <input class="layui-input" id="matnr" onkeyup="findCode(this, 'matnr')" placeholder="扫码 / 输入" |
| | | style="width: 175px" |
| | | autocomplete="off"> |
| | | </div> |
| | | <div class="layui-input-inline"> |
| | | <label class="layui-form-label" style="margin-left: 28px;">库区</label> |
| | | <div class="layui-input-inline" style="margin-left: 5px;width: 175px"> |
| | | <select id="uuid" lay-filter="uuid"> |
| | | <option value="">请选择</option> |
| | | </select> |
| | | </div> |
| | | </div> |
| | | </header> |
| | | |
| | | <main> |
| | |
| | | </footer> |
| | | |
| | | <!-- 修改数量弹窗 --> |
| | | <div id="modify" style="display: none; text-align: center;padding-top: 10px"> |
| | | <div class="form-item"> |
| | | <span>编码</span> |
| | | <input id="matnr2" type="text" disabled="disabled" style="width: 70%"> |
| | | </div> |
| | | <div class="form-item"> |
| | | <span>名称</span> |
| | | <input id="maktx2" type="text" disabled="disabled" style="width: 70%"> |
| | | <div id="modify" style="display: none; padding-top: 10px; text-align: center;"> |
| | | <div class="form-box"> |
| | | <div class="form-item"> |
| | | <table style="display: inline"> |
| | | <tr> |
| | | <td> |
| | | <span style="width: 35px; margin-right: 5px">编码</span> |
| | | </td> |
| | | <td style="text-align: left"> |
| | | <input id="matnr2" type="text" disabled="disabled"> |
| | | </td> |
| | | </tr> |
| | | </table> |
| | | </div> |
| | | <div class="form-item"> |
| | | <table style="display: inline"> |
| | | <tr> |
| | | <td style="vertical-align: top"> |
| | | <span style="width: 35px; margin-right: 5px">名称</span> |
| | | </td> |
| | | <td style="text-align: left"> |
| | | <textarea rows="3" style="resize: none; width: 165px" id="maktx2" type="text" disabled="disabled" |
| | | readonly="readonly"></textarea> |
| | | </td> |
| | | </tr> |
| | | </table> |
| | | </div> |
| | | </div> |
| | | <input id="index" type="text" disabled="disabled" style="display: none;"> |
| | | <div class="form-item" style="margin-top: 5px; margin-bottom: 8px"> |
| | | <div class="form-item" style="margin-top: 5px; margin-bottom: 8px;"> |
| | | <span style="vertical-align: middle">数量</span> |
| | | <div class="number-tool" style="vertical-align: middle"> |
| | | <button onclick="reduce()">-</button><input id="anfme2" type="number" onchange="fix(this)"><button onclick="add()">+</button> |
| | | <button onclick="reduce()">-</button> |
| | | <input id="anfme2" type="number" onchange="fix(this)"> |
| | | <button onclick="add()">+</button> |
| | | </div> |
| | | </div> |
| | | <button id="remove" onclick="remove()">移除</button> |
| | |
| | | // 表格数据 |
| | | var normalOutList = []; |
| | | window.onload = function () { |
| | | document.getElementById("uuid").focus(); |
| | | document.getElementById("billNo").focus(); |
| | | } |
| | | |
| | | /** |
| | |
| | | * @param warn true:红色字体 |
| | | */ |
| | | function tips(msg, warn) { |
| | | layer.msg(msg, {icon: warn?2:1}) |
| | | layer.msg(msg, {icon: warn ? 2 : 1}) |
| | | } |
| | | |
| | | function back() { |
| | |
| | | } |
| | | |
| | | var tableIns; |
| | | layui.use(['table','laydate', 'form'], function() { |
| | | layui.use(['table', 'laydate', 'form'], function () { |
| | | var table = layui.table; |
| | | var $ = layui.jquery; |
| | | var layer = layui.layer; |
| | |
| | | limit: 500, |
| | | cellMinWidth: 50, |
| | | cols: [[ |
| | | {type: 'checkbox', fixed: 'left', width:30}, |
| | | {field: 'anfmeOut', align: 'center', title: '数量', event: 'detail', style:'color: blue', event: 'modify', style:'cursor: pointer;color: blue', width:50}, |
| | | {field: 'matnr', align: 'center', title: '编码', event: 'detail', width:80}, |
| | | {field: 'matnr', align: 'center', title: '编码', event: 'detail', width: 80}, |
| | | {field: 'maktx', align: 'center', title: '名称', event: 'detail'}, |
| | | {field: 'warehouse', align: 'center', title: '库区', event: 'detail', width:50} |
| | | {field: 'warehouse', align: 'center', title: '库区', event: 'detail', width: 50}, |
| | | { |
| | | field: 'anfmeOut', |
| | | align: 'center', |
| | | title: '数量', |
| | | event: 'detail', |
| | | style: 'color: blue', |
| | | event: 'modify', |
| | | style: 'cursor: pointer;color: blue', |
| | | width: 50 |
| | | }, |
| | | {type: 'checkbox', fixed: 'right', width: 30}, |
| | | ]], |
| | | done: function (res, curr, count) { |
| | | } |
| | |
| | | |
| | | |
| | | // 监听行工具事件 |
| | | table.on('tool(locNormalOut)', function(obj) { |
| | | table.on('tool(locNormalOut)', function (obj) { |
| | | var data = obj.data; |
| | | switch (obj.event) { |
| | | case 'modify': |
| | |
| | | offset: '20px', |
| | | title: '修改数量', |
| | | shadeClose: true, |
| | | area: ['80%', '200px'], |
| | | area: ['80%', '240px'], |
| | | content: $("#modify"), |
| | | success: function (layero, index) { |
| | | $('#matnr2').val(data.matnr); |
| | |
| | | break; |
| | | } |
| | | }); |
| | | |
| | | form.on('select(uuid)', function (data) { |
| | | var val = data.value; |
| | | findCode(this, 'uuid'); |
| | | }); |
| | | |
| | | var areaType = getQueryVariable('areaType'); |
| | | // 获取仓库下拉 |
| | | $.ajax({ |
| | | url: baseUrl + "/locArea/queryAll/auth?areaType=" + (areaType ? areaType : ""), |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | method: 'POST', |
| | | success: function (res) { |
| | | if (res.code === 200) { |
| | | var html = ""; |
| | | if (res.data && res.data.length > 0) { |
| | | html += res.data.map(function (item) { |
| | | return "<Option value=" + item.uuid + ">" + item.name + "</Option>"; |
| | | }); |
| | | } |
| | | $('#uuid').append(html); |
| | | layui.form.render('select'); |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/pda"; |
| | | } else { |
| | | layer.msg(res.msg) |
| | | } |
| | | } |
| | | }); |
| | | }); |
| | | |
| | | var warehouseBar; |
| | | var matnrBar; |
| | | var billNo; |
| | | |
| | | /* 扫码、输入库区和物料编码 */ |
| | | function findCode(el, type) { |
| | | warehouseBar = $('#uuid').val(); |
| | | billNo = $("#billNo").val(); |
| | | if (billNo && billNo != '' && billNo.indexOf('=') > -1) { |
| | | billNo = billNo.split(",")[0].split("=")[1]; |
| | | } |
| | | switch (type) { |
| | | case 'uuid': |
| | | warehouseBar = el.value; |
| | | exist('uuid', 'locArea'); |
| | | // exist('uuid', 'locArea'); |
| | | break; |
| | | case 'matnr': |
| | | matnrBar = el.value; |
| | | matnrBar = el.value; |
| | | break; |
| | | default: |
| | | break; |
| | | } |
| | | |
| | | // 判断库区或者物料编码都不为空 |
| | | if (!warehouseBar || !matnrBar) { |
| | | return; |
| | | } |
| | | // if (!warehouseBar || !matnrBar) { |
| | | // return; |
| | | // } |
| | | |
| | | $.ajax({ |
| | | url: baseUrl + "/locNormal/pda/out/query?matnr="+matnrBar+"&warehouse="+warehouseBar, |
| | | url: baseUrl + "/locNormal/pda/out/query?matnr=" + (matnrBar ? matnrBar : "") + "&warehouse=" + (warehouseBar ? warehouseBar : "") + "&billNo=" + (billNo ? billNo : ""), |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | // contentType: 'application/json;charset=UTF-8', |
| | | method: 'GET', |
| | |
| | | if (res.data && res.data.length > 0) { |
| | | res.data.map(function (item) { |
| | | // 默认赋值0开始 |
| | | item.anfmeOut = 0; |
| | | item.anfmeOut = 0; |
| | | }); |
| | | } |
| | | tableIns.reload({ |
| | |
| | | |
| | | /* 修改数量 */ |
| | | var countDom = $('#anfme2'); |
| | | |
| | | function add() { |
| | | if (countDom.val() >= maxCount) { |
| | | return; |
| | | } |
| | | countDom.val(Number(countDom.val()) + 1); |
| | | } |
| | | |
| | | function reduce() { |
| | | if (countDom.val() <= 0) { |
| | | return; |
| | | } |
| | | countDom.val(Number(countDom.val()) - 1); |
| | | } |
| | | |
| | | function fix(e) { |
| | | if (Number(e.value) > maxCount) { |
| | | countDom.val(maxCount); |
| | | } |
| | | } |
| | | |
| | | function remove() { |
| | | var matnr = $('#matnr2').val(); |
| | | var index = $('#index').val(); |
| | | for (var j=0;j<normalOutList.length;j++){ |
| | | for (var j = 0; j < normalOutList.length; j++) { |
| | | if (matnr === normalOutList[j].matnr && index == normalOutList[j].id) { |
| | | normalOutList.splice(j, 1); |
| | | } |
| | |
| | | layer.close(countLayer); |
| | | tips("移除成功"); |
| | | } |
| | | |
| | | // 修改数量 |
| | | function confirm(){ |
| | | function confirm() { |
| | | var matnr = $('#matnr2').val(); |
| | | var count = $('#anfme2').val(); |
| | | var index = $('#index').val(); |
| | | for (var j=0;j<normalOutList.length;j++){ |
| | | for (var j = 0; j < normalOutList.length; j++) { |
| | | if (matnr === normalOutList[j].matnr && index == normalOutList[j].id) { |
| | | if (count > maxCount || count < 0) { |
| | | tips("数量不能超过范围", true); |
| | |
| | | // 库区赋值 |
| | | var warehouse = $('#uuid').val(); |
| | | data.map(function (item) { |
| | | item.warehouse = warehouse; |
| | | item.warehouse = warehouse; |
| | | }); |
| | | // 出库接口 |
| | | $.ajax({ |
| | |
| | | if (res.code === 200) { |
| | | layer.msg("出库成功"); |
| | | $("#matnr").val(null); |
| | | $("#uuid").val(null); |
| | | $("#billNo").val(null); |
| | | warehouseBar = null; |
| | | matnrBar = null; |
| | | normalOutList = []; |
| | |
| | | function reset() { |
| | | $("#uuid").val(null); |
| | | $("#matnr").val(null); |
| | | $("#billNo").val(null); |
| | | layui.form.render('select'); |
| | | normalOutList = []; |
| | | tableIns.reload({data: normalOutList}); |
| | | layer.closeAll(); |