feeding.js 84 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form', 'jQuery.print', 'jquery.qrcode.min'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. // 初始化表格参数配置
  5. Table.api.init({
  6. extend: {
  7. index_url: 'feeding/index' + location.search,
  8. add_url: 'feeding/add',
  9. edit_url: 'feeding/edit',
  10. del_url: 'feeding/del',
  11. multi_url: 'feeding/multi',
  12. import_url: 'feeding/import',
  13. table: 'feeding',
  14. }
  15. });
  16. var table = $("#table");
  17. // 初始化表格
  18. table.bootstrapTable({
  19. url: $.fn.bootstrapTable.defaults.extend.index_url,
  20. pk: 'id',
  21. sortName: 'id',
  22. fixedColumns: true,
  23. fixedRightNumber: 1,
  24. columns: [
  25. [
  26. { checkbox: true },
  27. // { field: 'id', title: __('Id') },
  28. { field: 'bach', title: __('Bach'), operate: 'LIKE' },
  29. { field: 'material', title: __('Material'), operate: 'LIKE' },
  30. { field: 'no', title: __('No'), operate: 'LIKE' },
  31. { field: 'nweight', title: __('Nweight'), operate: 'LIKE' },
  32. { field: 'weight', title: __('Weight'), operate: 'LIKE' },
  33. { field: 'gy_num', title: __('Gy_num') },
  34. { field: 'date', title: __('Date'), operate: 'LIKE' },
  35. { field: 'operator', title: __('Operator'), operate: 'LIKE' },
  36. // {field: 'tid', title: __('Tid')},
  37. { field: 'inspector', title: __('Inspector'), operate: 'LIKE' },
  38. { field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate }
  39. ]
  40. ]
  41. });
  42. table.on('post-body.bs.table', function () {
  43. $(".btn-add").data("area", ["100%", "100%"]);
  44. });
  45. // 进入页面全屏
  46. // if (document.documentElement) {
  47. // document.documentElement.webkitRequestFullScreen();
  48. // document.body.onkeyup = function (e) {
  49. // e = e || window.event;
  50. // console.log(e.keyCode);
  51. // if (e.keyCode == 27) {//Esc全屏或退出全屏
  52. // document.documentElement.webkitRequestFullScreen();
  53. // }
  54. // if (e.keyCode == 116) {//F5
  55. // document.documentElement.webkitRequestFullScreen();
  56. // }
  57. // if (e.keyCode == 82 && e.ctrlKey) {//Ctrl+R
  58. // document.documentElement.webkitRequestFullScreen();
  59. // }
  60. // if (e.keyCode === 13) {
  61. // document.querySelector('.btn-refresh').click();
  62. // document.querySelector('.btn-add').click();
  63. // }
  64. //
  65. // };
  66. // }
  67. // $(document).ready(function() {
  68. // // 尝试进入全屏模式
  69. // // function enterFullScreen() {
  70. // // if (document.documentElement.requestFullscreen) {
  71. // // document.documentElement.requestFullscreen();
  72. // // } else if (document.documentElement.webkitRequestFullScreen) {
  73. // // document.documentElement.webkitRequestFullScreen();
  74. // // }
  75. // // }
  76. //
  77. // // 页面加载时尝试进入全屏
  78. // enterFullScreen();
  79. //
  80. // // 监听键盘事件
  81. // document.body.addEventListener('keyup', function(e) {
  82. // e = e || window.event;
  83. // console.log(e.keyCode);
  84. // if (e.keyCode === 27) { // Esc键退出全屏后,不需要再次请求全屏
  85. // // 一般情况下,浏览器会自动处理 Esc 键退出全屏
  86. // }
  87. // if (e.keyCode === 116) { // F5刷新页面,通常不需要特别处理
  88. // // 浏览器默认行为会刷新页面
  89. // }
  90. // if (e.keyCode === 82 && e.ctrlKey) { // Ctrl+R,通常不需要特别处理
  91. // // 浏览器默认行为会刷新页面
  92. // }
  93. // if (e.keyCode === 13) { // 回车键
  94. // document.querySelector('.btn-refresh').click(); // 模拟点击刷新按钮
  95. // document.querySelector('.btn-add').click(); // 模拟点击添加按钮
  96. // }
  97. // });
  98. // });
  99. $(".form-control").focus();
  100. // 为表格绑定事件
  101. Table.api.bindevent(table);
  102. },
  103. //添加
  104. add: function () {
  105. $(document).ready(function(){
  106. // 设置边框颜色并清除其他输入框的边框颜色
  107. function setBorderColor(input) {
  108. $('input').not(input).css('border-color', ''); // 清除其他输入框的边框颜色
  109. input.css('border-color', 'red'); // 设置当前点击输入框的边框颜色
  110. }
  111. function setBorderColors(input) {
  112. $('input').not(input).css('border-color', '');
  113. input.css('border-color', 'red');
  114. $('#c-inspector').css('border-color', '');
  115. $('#c-operator').css('border-color', '');
  116. }
  117. $('#c-bach').focus(function(){
  118. setBorderColors($(this));
  119. });
  120. $('#wuliao').focus(function(){
  121. setBorderColors($(this));
  122. });
  123. $('#dzcshuju').focus(function(){
  124. setBorderColors($(this));
  125. });
  126. $('#c-operator').focus(function(){
  127. setBorderColor($(this));
  128. $('#c-inspector').css('border-color', '');
  129. });
  130. $('#c-inspector').focus(function(){
  131. setBorderColor($(this));
  132. $('#c-operator').css('border-color', '');
  133. });
  134. });
  135. const BAUD_RATE = 9600;
  136. const READ_TIMEOUT = 50;
  137. let serialPort;
  138. let reader;
  139. let readFlag = true;
  140. let conectFlag = false;
  141. let serialData = [];
  142. let asciidecoder = new TextDecoder();
  143. let serialTimer = null;
  144. let input = null;
  145. let oldVal = 0;
  146. // 连接串口设备
  147. const connectSerial = async () => {
  148. try {
  149. const ports = await navigator.serial.getPorts();
  150. if (ports.length > 0) {
  151. // 关闭已连接的串口
  152. if (serialPort) {
  153. await serialPort.close();
  154. serialPort = null;
  155. }
  156. // 选择第一个串口进行连接
  157. serialPort = ports[0];
  158. await serialPort.open({ baudRate: BAUD_RATE });
  159. if (serialPort.readable) {
  160. console.log("已连接设备");
  161. conectFlag = true;
  162. readData(); // 开始读取数据
  163. } else {
  164. console.log("未能连接到设备");
  165. }
  166. } else {
  167. var duankou_msg = new SpeechSynthesisUtterance("请选择 U S B 串口并点击连接");
  168. window.speechSynthesis.speak(duankou_msg);
  169. const port = await navigator.serial.requestPort();
  170. serialPort = port;
  171. await serialPort.open({ baudRate: BAUD_RATE });
  172. if (serialPort.readable) {
  173. var duankou_msg = new SpeechSynthesisUtterance("已连接设备");
  174. window.speechSynthesis.speak(duankou_msg);
  175. conectFlag = true;
  176. readData(); // 开始读取数据
  177. }
  178. }
  179. } catch (error) {
  180. // 处理连接错误
  181. }
  182. };
  183. // 读取串口数据
  184. const readData = async () => {
  185. try {
  186. while (readFlag && conectFlag && serialPort.readable) {
  187. reader = serialPort.readable.getReader();
  188. while (true) {
  189. const { value, done } = await reader.read();
  190. if (done) break;
  191. dataReceived(value);
  192. }
  193. }
  194. } catch (error) {
  195. // 处理读取数据错误
  196. } finally {
  197. reader.releaseLock();
  198. }
  199. };
  200. // 处理接收到的数据
  201. const dataReceived = (data) => {
  202. serialData.push(...data);
  203. clearTimeout(serialTimer);
  204. serialTimer = setTimeout(() => {
  205. // const dataNum = parseFloat(asciidecoder.decode(Uint8Array.from(data)));
  206. const dataNum = parseFloat(asciidecoder.decode(Uint8Array.from(serialData)));
  207. console.log('电子秤获取的数据是'+ dataNum);
  208. if (!isNaN(parseFloat(dataNum))) {
  209. if (dataNum === 0) {
  210. // 如果数据是0,设置显示为空
  211. $('#dzcshuju').text('');
  212. } else {
  213. // 数据不是0,正常显示数据
  214. $('#dzcshuju').text(dataNum);
  215. }
  216. } else {
  217. // 字符串不是数字的处理逻辑
  218. console.log("串口接触异常,未获取到数据");
  219. }
  220. serialData = [];
  221. }, READ_TIMEOUT);
  222. };
  223. // const BAUD_RATE = 9600;
  224. // const READ_TIMEOUT = 20;
  225. // let serialPort;
  226. // let reader;
  227. // let readFlag = true;
  228. // let conectFlag = false;
  229. // let serialData = [];
  230. // let asciidecoder = new TextDecoder();
  231. // let serialTimer = null;
  232. // let input = null;
  233. // let oldVal = 0;
  234. //
  235. // // 连接串口设备
  236. // const connectSerial = async () => {
  237. // try {
  238. // const ports = await navigator.serial.getPorts();
  239. // console.log(ports);
  240. //
  241. // if (ports.length > 0) {
  242. // // 关闭已连接的串口
  243. // if (serialPort) {
  244. // await serialPort.close();
  245. // serialPort = null;
  246. // }
  247. // // 选择第一个串口进行连接
  248. // serialPort = ports[0];
  249. // await serialPort.open({ baudRate: BAUD_RATE });
  250. // if (serialPort.readable) {
  251. // console.log("已连接设备");
  252. // conectFlag = true;
  253. // readData(); // 开始读取数据
  254. // } else {
  255. // console.log("未能连接到设备");
  256. // }
  257. // } else {
  258. // var duankou_msg = new SpeechSynthesisUtterance("请选择 U S B 串口并点击连接");
  259. // window.speechSynthesis.speak(duankou_msg);
  260. // const port = await navigator.serial.requestPort();
  261. // serialPort = port;
  262. // await serialPort.open({ baudRate: BAUD_RATE });
  263. // if (serialPort.readable) {
  264. // var duankou_msg = new SpeechSynthesisUtterance("已连接设备");
  265. // window.speechSynthesis.speak(duankou_msg);
  266. // conectFlag = true;
  267. // readData(); // 开始读取数据
  268. // }
  269. // }
  270. // } catch (error) {
  271. // // 处理连接错误
  272. // }
  273. // };
  274. //
  275. // // 读取串口数据
  276. // const readData = async () => {
  277. // try {
  278. // while (readFlag && conectFlag && serialPort.readable) {
  279. // reader = serialPort.readable.getReader();
  280. // while (true) {
  281. // const { value, done } = await reader.read();
  282. // if (done) break;
  283. // dataReceived(value);
  284. // }
  285. // }
  286. // } catch (error) {
  287. // // 处理读取数据错误
  288. // } finally {
  289. // reader.releaseLock();
  290. // }
  291. // };
  292. //
  293. // // 处理接收到的数据
  294. // const dataReceived = (data) => {
  295. // serialData.push(...data);
  296. // clearTimeout(serialTimer);
  297. // serialTimer = setTimeout(() => {
  298. // const dataNums = asciidecoder.decode(Uint8Array.from(serialData));
  299. // const dataNum = parseFloat(dataNums.split('').reverse().join('').split('=')[0]);
  300. // console.log('电子秤获取的数据是'+ dataNum);
  301. // if (!isNaN(parseFloat(dataNum))) {
  302. // $('#dzcshuju').text(dataNum);
  303. // } else {
  304. // // 字符串不是数字的处理逻辑
  305. // console.log("串口接触异常,未获取到数据");
  306. // }
  307. // serialData = [];
  308. // }, READ_TIMEOUT);
  309. // };
  310. //进入投料添加页面 光标自动跳到批次号输入框
  311. $('#c-bach').focus();
  312. var num = 0;
  313. $('#c-bach').keydown((e) => {
  314. let key = e.which;
  315. if (key == 13) {
  316. $('#dzcshuju').text('');
  317. $.ajax({
  318. method: "get",
  319. url: "feeding/cheng",
  320. success(data) {
  321. if(data.admin.username === '333' || data.admin.username === 'admin'){
  322. console.log('登录了带有电子秤的账号');
  323. connectSerial();
  324. }else{
  325. console.log('登录了没有电子秤的账号');
  326. }
  327. }
  328. });
  329. $("#wuliao").focus();
  330. if (num === 0) {
  331. var bach = $("#c-bach").val();//批次号
  332. if (bach == '') {
  333. layer.confirm('批次号不能为空', { title: '操作提示',btn: [],closeBtn: 0,time: 2000});
  334. return false;
  335. }
  336. //批次号语音播报
  337. var bach_msg = new SpeechSynthesisUtterance("当前批次号是" + bach);
  338. window.speechSynthesis.speak(bach_msg);
  339. $.ajax({
  340. method: "POST",
  341. data: { bach: bach },
  342. url: "feeding/get_task",
  343. success(res) {
  344. $("#table").append("<input id='name' type='hidden' value='" + res.data[0].name + "'>");
  345. //批次号重复/做下拉选择
  346. if (res.data.length > 1) {
  347. // let str = '';
  348. // str+='<select class="selectpicker form-control" id="bach"><option>请选择对应的生产量</option>';
  349. // for(var i=0;i<res.data.length;i++){
  350. // str+='<option value="'+i+'">'+res.data[i].create+'&nbsp;&nbsp;&nbsp;&nbsp;生产量:'+res.data[i].number+'</option>';
  351. // }
  352. // str+='</select><a href="javascript:;" id="btn" class="btn btn-success">确认</a>';
  353. // $('#c-bach').parent('#c_bach').append(str);
  354. // $("#bach").change(()=>{
  355. // $("#c-name").val(res.data[$("#bach").val()].name);
  356. // $("#c-specifications").val(res.data[$("#bach").val()].drawer_name);
  357. // $("#c-unit").val(res.data[$("#bach").val()].examine_name);
  358. // });
  359. // $("#btn").click(()=>{
  360. // //只读->已扫描过批次号
  361. // if($("#c-bach").attr('readonly')==='readonly'){
  362. // return false;
  363. // }
  364. // $("#bach").css('cssText','display:none! important');//隐藏按钮,下拉菜单
  365. // $("#btn").css('display','none');
  366. //
  367. // $.ajax({
  368. // method:"POST",
  369. // url:"feeding/get_formula",
  370. // data:{
  371. // bach:$("#c-bach").val(),
  372. // num:res.data[$("#bach").val()].number// 选定批次号的生产量,精确查找
  373. // },
  374. // success(result){
  375. // var str = '';//页面table
  376. // var html = '';// html:需打印的表格
  377. // for(var i=0;i<result.data.length;i++){
  378. // str += "<tr class='tablestr"+i+" tablestr'><td><input class='form-control material' type='text' name='row[material][]' readonly value='"+result.data[i].material+"'></td>";
  379. // str += "<td><input class='form-control' type='text' name='row[nweight][]' readonly value='"+result.data[i].nweight+"'></td>";
  380. // str += "<td><input class='form-control' type='number' name='row[weight][]' value='";
  381. // if (result.data[i].weight) {
  382. // //已操作的工序变为只读,附带实加重量
  383. // str += parseFloat(result.data[i].weight) + "' readonly ";
  384. // }
  385. // str += "'></td>";
  386. // str += "<input class='form-control' type='hidden' name='row[gy_num][]' value='"+result.data[i].gy_num+"'>";
  387. // str += "<td><input class='form-control' type='text' name='row[gy_name][]' readonly value='"+result.data[i].gy_name+"'></td>";
  388. // str += "</tr>";
  389. // html += `<tr class="print${i} print"><td>${result.data[i].material}</td>
  390. // <td>${result.data[i].nweight}</td><td>`;
  391. // if (result.data[i].weight) {
  392. // html += parseFloat(result.data[i].weight);
  393. // }
  394. // html += `</td><td style="text-align: left">${result.data[i].gy_name}</td></tr>`;
  395. //
  396. // }
  397. // html+= `<tr>
  398. // <td style="width: 100px;text-align: center">总计</td>
  399. // <td class="total" style="width: 100px;text-align: center"></td>
  400. // <td id="total"></td>
  401. // <td></td>
  402. // </tr>`;//${res.data.number}
  403. // $("#print_gy").append(html);
  404. // $("#table").append(str);
  405. // $("#c-bach").attr('readonly','readonly');//批次号输入框变为只读
  406. //
  407. // $("#wuliao").keydown((e)=>{
  408. // let key = e.which;
  409. // var error = 0;
  410. // if(key === 13){
  411. // var wuliao = $("#wuliao").val();
  412. // for(var i=0;i<result.data.length;i++) {
  413. // //扫描的物料=table中的物料,,,变红,否则语音提示
  414. // if(result.data[i].material===wuliao && result.data[i].gy_num == result.process){
  415. // $(".material")[i].setAttribute('style','color:red');
  416. // error++;
  417. // }else if(result.data[i].material===wuliao){
  418. // Layer.confirm("此物料不在当前工序,请确认!");
  419. // //语音播报
  420. // var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  421. // window.speechSynthesis.speak(msg);
  422. // error++;
  423. // }
  424. // //替代料变扫描的物料
  425. // if(result.data[i].material.indexOf('/')!==-1){
  426. // var arr = result.data[i].material.split('/');
  427. // if(arr.indexOf($("#wuliao").val()) !== -1 && result.data[i].gy_num == result.process){
  428. // $(".material")[i].value = wuliao;
  429. // $(".material")[i].setAttribute('style','color:red');
  430. // error++;
  431. // }else if(arr.indexOf($("#wuliao").val()) !== -1 ){
  432. // Layer.confirm("此物料不在当前工序,请确认!");
  433. // //语音播报
  434. // var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  435. // window.speechSynthesis.speak(msg);
  436. // error++;
  437. // }
  438. // }
  439. // }
  440. // if(error===0){
  441. // Layer.confirm("此物料不在配方中,请确认!");
  442. // //语音播报
  443. // var msg = new SpeechSynthesisUtterance("此物料不在配方中,请确认!");
  444. // window.speechSynthesis.speak(msg);
  445. // }
  446. // //清空物料扫描后的值,下次直接重新扫描即可
  447. // $("#wuliao").val('');
  448. // }
  449. // });
  450. // }
  451. // });
  452. // });
  453. } else {//批次号不重复直接赋值
  454. $("#btn").css('display', 'none');
  455. $("#c-name").val(res.data[0].name);
  456. $("#c-specifications").val(res.data[0].drawer_name);
  457. $("#c-unit").val(res.data[0].examine_name);
  458. if (res.operator != '' && res.inspector != '') {
  459. $("#c-operator").val(res.operator);
  460. $("#c-inspector").val(res.inspector);
  461. }
  462. $.ajax({
  463. method: "POST",
  464. url: "feeding/get_formula",
  465. data: {
  466. bach: $("#c-bach").val(),
  467. },
  468. success(result) {
  469. let pattern = /\*/;
  470. var str = '';//页面table
  471. var html = '';//打印的table
  472. for (var i = 0; i < result.data.length; i++) {
  473. str += "<tr class='tablestr" + i + " tablestr'><td style='padding: 0px 0px 0px 10px;'><input class='form-control material' type='text' name='row[material][]' readonly value='" + result.data[i].material + "'></td>";
  474. str += "<td style='padding: 0px 0px 0px 0px;'><input class='form-control nweight' type='text' name='row[nweight][]' readonly value='" + result.data[i].nweight + "'></td>";
  475. // str += "<td><input class='form-control nweight' type='text' name='row[nweight][]' readonly value='" + result.data[i].nweight + "' style='color: " + (result.data[i].weight ? "##000000" : "") + ";'></td>";
  476. str += "<td style='display: none'><input class='form-control gy_num' type='hidden' name='row[gy_num][]' value='" + result.data[i].gy_num + "'></td>";
  477. //投料重量
  478. str += "<td style='padding: 0px 0px 0px 0px;'><input class='form-control number' type='number' name='row[weight][]' value='";
  479. // if (result.data[i].weight || result.data[i].material === '*****') {
  480. if (result.data[i].weight || pattern.test(result.data[i].material) || result.data[i].material === null || result.data[i].material === ' ') {
  481. //已操作的工序变为只读,附带实加重量
  482. str += result.data[i].weight + "' readonly ";
  483. // str += `${result.data[i].weight}' style="color: ##000000;`;
  484. }
  485. str += "'></td>";
  486. if (result.data[i].weight == 0) {
  487. str += "<td style='display:none'><button type=\"button\" class=\"btn btn-primary btn-embossed submit \">保存</button></td>";
  488. str += "<td style='padding: 0px 0px 0px 0px;'><input class='form-control bach' readonly type='text' name='row[bach][]' value=''></td>";
  489. } else {
  490. str += "<td style='display:none' ><button type=\"button\" class=\"btn btn-primary btn-embossed submit \" disabled>已保存</button></td>";
  491. str += "<td style='padding: 0px 0px 0px 0px;'><input class='form-control bach' type='text' name='row[bach][]' readonly value='" + result.data[i].material_bach + "'></td>";
  492. }
  493. str += "<td style='padding: 0px 0px 0px 0px;'><input class='form-control' readonly type='text' name='row[gy_name][]' value='" + result.data[i].gy_name + "'></td>";
  494. str += "</tr>";
  495. html += `<tr class="print${i} print"><td>${result.data[i].material}</td>
  496. <td>${result.data[i].nweight}</td><td>`;
  497. if (result.data[i].weight) {
  498. html += parseFloat(result.data[i].weight);
  499. }
  500. html += `</td><td style="text-align: left">${result.data[i].gy_name}</td></tr>`;
  501. }
  502. html += `<tr>
  503. <td style="width: 100px;text-align: center">总计</td>
  504. <td class="total" id="stotal" style="width: 100px;text-align: center"></td>
  505. <td id="total"></td>
  506. <td></td>
  507. </tr>`;
  508. $("#print_gy").append(html);
  509. $("#table").append(str);
  510. $("#c-bach").attr('readonly', 'readonly');//批次号输入框变为只读
  511. //判断是否链接电子秤串口conectFlag === true 连接正常
  512. if(conectFlag === true){
  513. $("#dzcshuju").on({
  514. focus: function () {
  515. readFlag = true;
  516. input = $(this);
  517. readData();
  518. },
  519. blur: function () {
  520. readFlag = false;
  521. reader.releaseLock();
  522. input = null;
  523. },
  524. });
  525. $(".number").on({
  526. focus: function () {
  527. readFlag = true;
  528. input = $(this);
  529. readData();
  530. },
  531. blur: function () {
  532. readFlag = false;
  533. reader.releaseLock();
  534. input = null;
  535. },
  536. keydown:function(e){
  537. //通过回车自动保存数据
  538. if(e.keyCode == 13){
  539. $(this).parent().next().children().click();
  540. }
  541. }
  542. });
  543. }else{
  544. //连接电子秤异常,可手动在表格回车保存
  545. $(".number").on({
  546. keydown:function(e){
  547. //通过回车自动保存数据
  548. if(e.keyCode == 13){
  549. $(this).parent().next().children().click();
  550. }
  551. }
  552. });
  553. }
  554. //扫描物料回车
  555. $("#wuliao").keydown((e) => {
  556. let key = e.which;
  557. var error = 0;
  558. if (key === 13) {
  559. var string = $("#wuliao").val().trim();//获取扫描物料的值
  560. // if ($("#wuliao").val() === '') {
  561. // // layer.confirm('扫描物料不能为空', { title: '操作提示',btn: [],closeBtn: 0,time: 2000});
  562. // return false;
  563. // }
  564. var ytzl = $("#ytzl").text().trim();
  565. var trzl = $("#dzcshuju").text().trim();
  566. var input = $("#input").text().trim();
  567. if (string === '') {
  568. for (let i = 0; i < $('.tablestr').length; i++) {
  569. const dom = $('.tablestr').eq(i); // 使用 jQuery 对象
  570. const val = dom.find('td:eq(0) input').val(); // 获取第一个单元格中的input的值
  571. const table_tlzl = dom.find('td:eq(1) input').val(); // 获取第二个单元格中的input的值
  572. const table_ytzl = dom.find('td:eq(3) input').val(); // 获取第二个单元格中的input的值
  573. const status_button = dom.find('td:eq(4) button').text(); // 获取第五个单元格中的button的文本
  574. if (ytzl !== '' && trzl !== '') {
  575. if (status_button === '保存' && trzl === table_ytzl && val === input) {
  576. dom.find('td:eq(4) button').click(); // 触发按钮点击事件
  577. $("#dzcshuju").text(''); // 清空对应的文本
  578. $("#ytzl").text('');
  579. $("#wuliao").val('');
  580. $("#wuliao").focus(); // 让物料输入框获得焦点
  581. // 扫描物料语音播报
  582. var wuliao_msg = new SpeechSynthesisUtterance("已保存");
  583. window.speechSynthesis.speak(wuliao_msg);
  584. }
  585. }
  586. }
  587. return false;
  588. }
  589. console.log("扫描物料"+string);
  590. //扫描批次号关闭 判断扫描物料 是否纯数字五位数
  591. var regex = /^[0-9]{5}$/;
  592. if (regex.test(string)) {
  593. Fast.api.close();//关闭窗口
  594. return false;
  595. }
  596. // 扫描重量
  597. var regexs = /^\d+(\.\d+)?$/;
  598. if (regexs.test(string)) {
  599. var zhongliang = string + 'kg';
  600. //判断是否扫描公斤码【20GJ\50GJ\60GJ】
  601. if(zhongliang.includes('kg')) {
  602. var numberOnly = zhongliang.replace(/kg$/, ""); // 只替换字符串末尾的'GJ'
  603. $('#dzcshuju').text(numberOnly);
  604. $("#wuliao").val('');
  605. $("#wuliao").focus();
  606. return false;
  607. }
  608. }
  609. //物料码(string):M-501_年月日【M-501_230325】 = 原材料_原材料批次号
  610. if (string.substr(0, string.indexOf('_'))) {
  611. var wuliao = string.substr(0, string.indexOf('_'));//原材料_
  612. var bach = string.substr(string.indexOf('_') + 1);//_原材料批次号
  613. } else {
  614. var wuliao = string;
  615. var bach = '';
  616. }
  617. //定时获取投入重量的值,将值复制到对应物料列表中投料重量
  618. setInterval(() => {
  619. let dzcshuju = $("#dzcshuju").text();
  620. for (let i = 0; i < $('.tablestr').length; i++) {
  621. const dom = $('.tablestr')[i];
  622. const val = $(dom).children().eq(0).children().eq(0).val();
  623. const status = $(dom).children().eq(4).children().eq(0).text();
  624. //按钮状态是未保存(是保存按钮的时候)并且 表格物料 == 扫描的物料
  625. if (status === '保存' && val == wuliao) {
  626. $(dom).children().eq(3).children().eq(0).val(dzcshuju);
  627. break;
  628. }
  629. }
  630. }, 1000); // 每秒检查一次
  631. // $('#input').html();
  632. $.ajax({
  633. method: "POST",
  634. url: "feeding/get_material",
  635. data: {
  636. bach: $("#c-bach").val(),
  637. material: wuliao
  638. },
  639. success(data) {
  640. if (data.total > 0) {
  641. if (wuliao.length < 7) {
  642. $('#input').css('font-size', '60px');
  643. } else {
  644. $('#input').css('font-size', '25px');
  645. }
  646. console.log(11111)
  647. wuliao = data.string;
  648. $('#input').html(wuliao);
  649. for (var i = 0; i < result.data.length; i++) {
  650. for (var j = 0; j < data.data.length; j++) {
  651. //扫描的物料=table中的物料,,,变红,否则语音提示
  652. if (result.data[i].material === data.data[j].m_name && (result.data[i].weight === 0 || result.data[i].weight == '')) {
  653. if (result.data[i].gy_num <= result.process) {
  654. console.log(wuliao+"中文文字变红")
  655. //投料重量为空时 扫描物料文字为红
  656. if (result.data[i].weight == 0 || result.data[i].weight == '') {
  657. $(".material")[i].setAttribute('style', 'color:red');
  658. $(".nweight")[i].setAttribute('style', 'color:red');
  659. }
  660. // 扫描物料保存
  661. let ytzl = $("#ytzl").text().trim(); // 应投重量
  662. let trzl = $("#dzcshuju").text().trim(); // 投入重量
  663. let input = $("#input").text();//扫描的物料
  664. // 遍历表格行
  665. const dom = $('.tablestr')[i];
  666. //原材料
  667. const val = $(dom).find('td:eq(0) input').val();
  668. //应投重量
  669. const table_ytzl = $(dom).find('td:eq(1) input').val();
  670. //投料重量
  671. const table_tlzl = $(dom).find('td:eq(2) input').val();
  672. //按钮
  673. const status_button = $(dom).find('td:eq(4) button').text();
  674. //扫描物料等于表格中物料 并且 未保存
  675. if (status_button === '保存' && (val === wuliao || data.data[j].m_name === wuliao)) {
  676. if (ytzl === '' && trzl === '' || ytzl && trzl === '') {
  677. $("#input").text(wuliao);
  678. $("#ytzl").text(table_ytzl);
  679. $("#wuliao").val('');
  680. $("#wuliao").focus();
  681. var wuliao_msg = new SpeechSynthesisUtterance("当前扫描物料" + wuliao + "应投入重量" + table_ytzl + "千克");
  682. window.speechSynthesis.speak(wuliao_msg);
  683. } else if (table_tlzl !== '' && trzl !== '' && status_button === '保存' && val === wuliao) {
  684. console.log("保存了");
  685. $(dom).find('td:eq(4) button').click();
  686. $("#dzcshuju").text('');
  687. $("#ytzl").text('');
  688. $("#wuliao").val('');
  689. $("#wuliao").focus();
  690. //扫描物料语音播报
  691. var wuliao_msg = new SpeechSynthesisUtterance("已保存");
  692. window.speechSynthesis.speak(wuliao_msg);
  693. }
  694. break; // 退出循环
  695. } else if (status_button === '已保存' && val === wuliao) {
  696. // 扫描的物料保存过了,清空【应投重量,投入重量】
  697. $("#ytzl").text('');
  698. $("#dzcshuju").text('');
  699. var wuliao_msg = new SpeechSynthesisUtterance("当前扫描" + wuliao + "已投料");
  700. window.speechSynthesis.speak(wuliao_msg);
  701. $("#wuliao").val('');
  702. $("#wuliao").focus();
  703. break; // 退出循环
  704. }
  705. // var the_bach = document.getElementsByClassName('bach')[i];
  706. // if (the_bach.readOnly == false) {
  707. // the_bach.value = bach;
  708. // //语音播报
  709. // var msg = new SpeechSynthesisUtterance("应投入物料" + result.data[i].material + "应投入重量" + result.data[i].nweight + "千克");
  710. // window.speechSynthesis.speak(msg);
  711. // }
  712. // error++;
  713. } else if (result.data[i].gy_num > result.process) {
  714. Layer.confirm("此物料不在当前工序,请确认!", {
  715. area: ['60%', '60%'],
  716. });
  717. //语音播报
  718. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  719. window.speechSynthesis.speak(msg);
  720. error++;
  721. }
  722. }
  723. //替代料变扫描的物料
  724. if (result.data[i].material.indexOf('/') !== -1) {
  725. var arr = result.data[i].material.split('/');
  726. if (arr.indexOf($("#wuliao").val()) !== -1 && result.data[i].gy_num == result.process) {
  727. $(".material")[i].value = wuliao;
  728. if (result.data[i].weight == 0) {
  729. $(".material")[i].setAttribute('style', 'color:red');
  730. $(".nweight")[i].setAttribute('style', 'color:red');
  731. }
  732. var the_bach = document.getElementsByClassName('bach')[i];
  733. the_bach.value = bach;
  734. $(".number")[i].focus();
  735. error++;
  736. } else if (arr.indexOf($("#wuliao").val()) !== -1) {
  737. Layer.confirm("此物料不在当前工序,请确认!", {
  738. area: ['60%', '60%'],
  739. });
  740. //语音播报
  741. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  742. window.speechSynthesis.speak(msg);
  743. error++;
  744. }
  745. }
  746. }
  747. }
  748. // if (error === 0) {
  749. // layer.confirm("此物料不在配方中,且没有替代料,请确认!", {//物料不存在提示错误信息
  750. // title: ['信息'],
  751. // btn: ['确认'],
  752. // area: ['60%', '60%'],
  753. // });
  754. // var synth = window.speechSynthesis;
  755. // var msg = new window.SpeechSynthesisUtterance('此物料不在配方中,且没有替代料,请确认!');
  756. // window.speechSynthesis.cancel();
  757. // synth.speak(msg);
  758. // }
  759. } else {
  760. console.log(2)
  761. //没有在数据库查到,直接去比较物料与配方
  762. if (wuliao.length < 7) {
  763. $('#input').css('font-size', '52px');
  764. } else {
  765. $('#input').css('font-size', '25px');
  766. }
  767. $('#input').html(wuliao);
  768. for (var i = 0; i < result.data.length; i++) {
  769. //扫描的物料=table中的物料,,,变红,否则语音提示
  770. if (result.data[i].material === wuliao && (result.data[i].weight === 0 || result.data[i].weight == '')) {
  771. if (result.data[i].gy_num <= result.process) {
  772. if (result.data[i].weight == 0 || result.data[i].weight == '') {
  773. console.log('扫描的物料 : '+wuliao+ '红色')
  774. //原材料、应投重量文字颜色
  775. $(".material")[i].setAttribute('style', 'color:red');
  776. $(".nweight")[i].setAttribute('style', 'color:red');
  777. }
  778. var the_bach = document.getElementsByClassName('bach')[i];
  779. the_bach.value = bach;
  780. let ytzl = $("#ytzl").text().trim(); // 应投重量
  781. let trzl = $("#dzcshuju").text().trim(); // 投入重量
  782. // 遍历表格行
  783. const dom = $('.tablestr')[i];
  784. //原材料
  785. const val = $(dom).find('td:eq(0) input').val();
  786. //应投重量
  787. const table_ytzl = $(dom).find('td:eq(1) input').val();
  788. //投料重量
  789. const table_tlzl = $(dom).find('td:eq(2) input').val();
  790. //按钮
  791. const status_button = $(dom).find('td:eq(4) button').text();
  792. //扫描物料等于表格中物料 并且 未保存
  793. if (status_button === '保存' && val === wuliao) {
  794. if (ytzl === '' && trzl === '' || ytzl && trzl === '') {
  795. $("#input").text(wuliao);
  796. $("#ytzl").text(table_ytzl);
  797. $("#wuliao").val('');
  798. $("#wuliao").focus();
  799. var wuliao_msg = new SpeechSynthesisUtterance("当前扫描物料" + wuliao + "应投入重量" + table_ytzl + "千克");
  800. window.speechSynthesis.speak(wuliao_msg);
  801. } else if (table_tlzl !== '' && trzl !== '' && status_button === '保存' && val === wuliao) {
  802. console.log("保存了");
  803. $(dom).find('td:eq(4) button').click();
  804. $("#dzcshuju").text('');
  805. $("#ytzl").text('');
  806. $("#wuliao").val('');
  807. $("#wuliao").focus();
  808. //扫描物料语音播报
  809. var wuliao_msg = new SpeechSynthesisUtterance("已保存");
  810. window.speechSynthesis.speak(wuliao_msg);
  811. }
  812. break; // 退出循环
  813. } else if (status_button === '已保存' && val === wuliao) {
  814. // 扫描的物料保存过了,清空【应投重量,投入重量】
  815. $("#ytzl").text('');
  816. $("#dzcshuju").text('');
  817. var wuliao_msg = new SpeechSynthesisUtterance("当前扫描" + wuliao + "已投料");
  818. window.speechSynthesis.speak(wuliao_msg);
  819. $("#wuliao").val('');
  820. $("#wuliao").focus();
  821. break; // 退出循环
  822. }
  823. // //语音播报
  824. // if($("#ytzl").text() !== ''){
  825. // var ytzl_msg = new SpeechSynthesisUtterance("应投入重量" + result.data[i].nweight + "千克");
  826. // window.speechSynthesis.speak(ytzl_msg);
  827. // }
  828. error++;
  829. break;
  830. } else if (result.data[i].gy_num > result.process) {
  831. Layer.confirm( wuliao + "此物料不在当前工序,请确认!", {
  832. area: ['70%', '60%'],
  833. });
  834. $("#ytzl").text('');
  835. $("#wuliao").val('');
  836. $("#wuliao").focus();
  837. //语音播报
  838. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  839. window.speechSynthesis.speak(msg);
  840. error++;
  841. break;
  842. }
  843. }
  844. //替代料变扫描的物料
  845. if (result.data[i].material.indexOf('/') !== -1) {
  846. var arr = result.data[i].material.split('/');
  847. var spanValue = document.getElementById("input").innerHTML;
  848. if (arr.indexOf(spanValue) !== -1 && result.data[i].gy_num <= result.process) {
  849. $(".material")[i].value = wuliao;
  850. if (result.data[i].weight == 0) {
  851. $(".material")[i].setAttribute('style', 'color:red');
  852. $(".nweight")[i].setAttribute('style', 'color:red');
  853. }
  854. // 扫描物料保存
  855. let ytzl = $("#ytzl").text().trim(); // 应投重量
  856. let trzl = $("#dzcshuju").text().trim(); // 投入重量
  857. // 遍历表格行
  858. // for (let i = 0; i < $('.tablestr').length; i++) {
  859. const dom = $('.tablestr')[i];
  860. //原材料
  861. const val = $(dom).find('td:eq(0) input').val();
  862. //应投重量
  863. const table_ytzl = $(dom).find('td:eq(1) input').val();
  864. //投料重量
  865. const table_tlzl = $(dom).find('td:eq(2) input').val();
  866. //按钮
  867. const status_button = $(dom).find('td:eq(4) button').text();
  868. //扫描物料等于表格中物料 并且 未保存
  869. if (status_button === '保存' && val === wuliao) {
  870. if (ytzl === '' && trzl === '' || ytzl && trzl === '') {
  871. $("#input").text(wuliao);
  872. $("#ytzl").text(table_ytzl);
  873. $("#wuliao").val('');
  874. $("#wuliao").focus();
  875. var wuliao_msg = new SpeechSynthesisUtterance("当前扫描物料" + wuliao + "应投入重量" + table_ytzl + "千克");
  876. window.speechSynthesis.speak(wuliao_msg);
  877. } else if (table_tlzl !== '' && trzl !== '' && status_button === '保存' && val === wuliao) {
  878. console.log("保存了");
  879. $(dom).find('td:eq(4) button').click();
  880. $("#dzcshuju").text('');
  881. $("#ytzl").text('');
  882. $("#wuliao").val('');
  883. $("#wuliao").focus();
  884. //扫描物料语音播报
  885. var wuliao_msg = new SpeechSynthesisUtterance("已保存");
  886. window.speechSynthesis.speak(wuliao_msg);
  887. }
  888. break; // 退出循环
  889. } else if (status_button === '已保存' && val === wuliao) {
  890. // 扫描的物料保存过了,清空【应投重量,投入重量】
  891. $("#ytzl").text('');
  892. $("#dzcshuju").text('');
  893. var wuliao_msg = new SpeechSynthesisUtterance("当前扫描" + wuliao + "已投料");
  894. window.speechSynthesis.speak(wuliao_msg);
  895. $("#wuliao").val('');
  896. $("#wuliao").focus();
  897. break; // 退出循环
  898. }
  899. // }
  900. // var the_bach = document.getElementsByClassName('bach')[i];
  901. // if (the_bach.readOnly == false) {
  902. // the_bach.value = bach;
  903. // // $(".number")[i].focus();
  904. // console.log("替代料")
  905. // var msg = new SpeechSynthesisUtterance("应投入物料" + result.data[i].material + "应投入重量" + result.data[i].nweight + "千克");
  906. // window.speechSynthesis.speak(msg);
  907. // }
  908. // error++;
  909. // break;
  910. } else if (arr.indexOf($("#wuliao").val()) !== -1) {
  911. Layer.confirm("此物料不在当前工序,请确认!", {
  912. area: ['60%', '60%'],
  913. });
  914. //语音播报
  915. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  916. window.speechSynthesis.speak(msg);
  917. error++;
  918. break;
  919. }
  920. }
  921. }
  922. // if (error === 0) {
  923. // layer.confirm("此物料不在配方中,且没有替代料,请确认!", {//物料不存在提示错误信息
  924. // title: ['信息'],
  925. // btn: ['确认'],
  926. // area: ['60%', '60%'],
  927. // });
  928. // var synth = window.speechSynthesis;
  929. // //没有物料,清空应投重量
  930. // $("#ytzl").text('');
  931. // var msg = new window.SpeechSynthesisUtterance('此物料不在配方中,且没有替代料,请确认!');
  932. // window.speechSynthesis.cancel();
  933. // synth.speak(msg);
  934. // }
  935. }
  936. }
  937. });
  938. //清空物料扫描后的值,下次直接重新扫描即可
  939. $("#wuliao").val('');
  940. }
  941. });
  942. }
  943. });
  944. }
  945. }
  946. });
  947. num++;
  948. } else {
  949. // return false;
  950. }
  951. }
  952. });
  953. $(document).on('click', '.submit', function () {
  954. if ($("#c-operator").val() == "" || $("#c-inspector").val() == "") {
  955. layer.confirm('请选择 操作人员 或 检验人员', {title: '操作提示',btn: [],area: ['60%', '60%'],closeBtn: 0,time: 2000});
  956. //语音播报
  957. var msg = new SpeechSynthesisUtterance("请选择 操作人员 或 检验人员");
  958. window.speechSynthesis.speak(msg);
  959. } else {
  960. //批次号
  961. var bach = $("#c-bach").val();
  962. //日期
  963. var date = $("#c-date").val();
  964. //操作人员
  965. var operator = $("#c-operator").val();
  966. //检验人员
  967. var inspector = $("#c-inspector").val();
  968. //原材料
  969. var material = $(this).parent().siblings().eq(0).children('input').val();
  970. //应投重量
  971. var nweight = $(this).parent().siblings().eq(1).children('input').val();
  972. //工艺序号
  973. var gy_num = $(this).parent().siblings().eq(2).children('input').val();
  974. //投料重量
  975. var weight = $(this).parent().siblings().eq(3).children('input').val();
  976. //原材料批次号
  977. var material_bach = $(this).parent().siblings().eq(4).children('input').val();
  978. //操作记录
  979. var gy_name = $(this).parent().siblings().eq(5).children('input').val();
  980. // if(nweight != weight){
  981. // var num_weight = parseFloat((nweight - weight).toFixed(3));
  982. // console.log(num_weight)
  983. // var num_weight_msg = new SpeechSynthesisUtterance("投料重量与应投入重量相差" + num_weight + "请确认" );
  984. // window.speechSynthesis.speak(num_weight_msg);
  985. // return false;
  986. // }
  987. // if (weight == "") {
  988. // layer.confirm('投料重量不能为空', {
  989. // title: '操作提示',
  990. // btn: [],
  991. // area: ['60%', '60%'],
  992. // closeBtn: 0,
  993. // time: 2000
  994. // });
  995. // //语音播报
  996. // var msg = new SpeechSynthesisUtterance("投料重量不能为空");
  997. // window.speechSynthesis.speak(msg);
  998. // } else {
  999. $(this).text('已保存');
  1000. $("#wuliao").focus();
  1001. // $(this).text('修改');
  1002. //禁用投料重量
  1003. $(this).parent().siblings().eq(3).children('input').attr('readonly', true);
  1004. // 禁用原材料批次号
  1005. $(this).parent().siblings().eq(4).children('input').attr('readonly', true);
  1006. $(this).attr('disabled', true);
  1007. // }
  1008. // console.log(bach);
  1009. // console.log(date);
  1010. // console.log(operator);
  1011. // console.log(inspector);
  1012. // console.log(material);
  1013. // console.log(nweight);
  1014. // console.log(gy_num);
  1015. // console.log(weight);
  1016. // console.log(material_bach);
  1017. // console.log(gy_name);return false;
  1018. $.ajax({
  1019. type: "POST",
  1020. url: "feeding/add",
  1021. data: {
  1022. bach: bach,
  1023. date: date,
  1024. operator: operator,
  1025. inspector: inspector,
  1026. material: material,
  1027. nweight: nweight,
  1028. gy_num: gy_num,
  1029. weight: weight,
  1030. material_bach: material_bach,
  1031. gy_name: gy_name,
  1032. },
  1033. success: function (data) {
  1034. console.log(data)
  1035. }
  1036. });
  1037. }
  1038. });
  1039. document.addEventListener('keydown', function(event) {
  1040. // console.log(event.key);
  1041. // 检查按下的键是否是回车键
  1042. if (event.key === 'Escape') {
  1043. //关闭弹窗
  1044. Fast.api.close();
  1045. }
  1046. });
  1047. $('input').keydown(function (e) {
  1048. let key = e.which;
  1049. if (key == 13) {
  1050. return false;
  1051. }
  1052. });
  1053. //打印预览
  1054. $(document).ready(function ($) {
  1055. 'use strict';
  1056. $(".print-link").on('click', function () {
  1057. var status = 1;
  1058. var total = 0;
  1059. var stotal = 0;
  1060. //开票人
  1061. $("#specifications").html($('#c-specifications').val());
  1062. //审核
  1063. $("#unit").html($('#c-unit').val());
  1064. //批次号
  1065. var bach = $('#c-bach').val();
  1066. //写入到add页面
  1067. $("#bach").html(bach);
  1068. $("#formula").val($("#name").val());
  1069. //添加重量,包装规格,机组到表格内
  1070. for (var i = 0; i < $(".tablestr").length; i++) {
  1071. var weight = parseFloat($(".tablestr:eq(" + i + ")").children("tr td:eq(3)").children().val());
  1072. if (weight) {
  1073. $(".print:eq(" + i + ")").children("tr td:eq(2)").html(weight);
  1074. total += weight;
  1075. }
  1076. var weight2 = parseFloat($(".tablestr:eq(" + i + ")").children("tr td:eq(1)").children().val());
  1077. if (weight2) {
  1078. $(".print:eq(" + i + ")").children("tr td:eq(1)").html(weight2);
  1079. stotal += weight2;
  1080. }
  1081. }
  1082. $("#stotal").html(stotal.toFixed(2));
  1083. if (total > 0) {
  1084. $("#total").html(total.toFixed(2));
  1085. }
  1086. if (!$("#c-pickor").val()) {
  1087. status = 2;
  1088. }
  1089. if (!$("#c-warehouseor").val()) {
  1090. status = 2;
  1091. }
  1092. /*if (status == 2){
  1093. layer.confirm('领料人或仓管人为空,请检查!');return false;
  1094. }*/
  1095. createQrcode(bach, 80, 80);
  1096. var img = document.getElementById("myImage"); /// get image element
  1097. var canvas = document.getElementsByTagName('canvas')[0];
  1098. img.src = canvas.toDataURL(); /// update image
  1099. $.print('#print_area');
  1100. return false;
  1101. });
  1102. function createQrcode(txt, width, height) {
  1103. $(".qrcode").qrcode({
  1104. render: "canvas",//canvas和table两种渲染方式
  1105. width: width,
  1106. height: height,
  1107. correctLevel: 3,//二维码纠错级别
  1108. background: "#ffffff",//背景颜色
  1109. foreground: "#000000", //二维码颜色
  1110. text: txt
  1111. });
  1112. }
  1113. });
  1114. Controller.api.bindevent();
  1115. },
  1116. edit: function () {
  1117. Controller.api.bindevent();
  1118. },
  1119. api: {
  1120. bindevent: function () {
  1121. Form.api.bindevent($("form[role=form]"));
  1122. }
  1123. }
  1124. };
  1125. return Controller;
  1126. });