feeding.js 62 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823
  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. };
  61. }
  62. // 为表格绑定事件
  63. Table.api.bindevent(table);
  64. },
  65. add: function () {
  66. // document.documentElement.webkitRequestFullScreen();// 进入页面全屏
  67. $('#c-bach').focus();//光标自动跳到(批次号输入框)
  68. var num=0;
  69. $('#c-bach').keydown((e)=>{
  70. let key = e.which;
  71. if(key == 13){
  72. $("#wuliao").focus();
  73. if(num === 0){
  74. var bach = $("#c-bach").val();
  75. // console.log("输入框的批次号:↓↓↓↓");
  76. // console.log(bach);
  77. if (bach == ''){
  78. layer.confirm('批次号不能为空',{
  79. title:'操作提示',
  80. btn:[],
  81. // icon:2,
  82. closeBtn:0,
  83. time:2000
  84. });
  85. return false;
  86. }
  87. $.ajax({
  88. method:"POST",
  89. data:{bach:bach},//批次号
  90. url:"feeding/get_task",
  91. success(res){
  92. // $("#table").append("<input id='name' type='hidden' value='"+res.data.name+"'>");
  93. $("#table").append("<input id='name' type='hidden' value='"+res.data[0].name+"'>");
  94. //批次号重复/做下拉选择
  95. if(res.data.length>1){
  96. // let str = '';
  97. // str+='<select class="selectpicker form-control" id="bach"><option>请选择对应的生产量</option>';
  98. // for(var i=0;i<res.data.length;i++){
  99. // str+='<option value="'+i+'">'+res.data[i].create+'&nbsp;&nbsp;&nbsp;&nbsp;生产量:'+res.data[i].number+'</option>';
  100. // }
  101. // str+='</select><a href="javascript:;" id="btn" class="btn btn-success">确认</a>';
  102. // $('#c-bach').parent('#c_bach').append(str);
  103. // $("#bach").change(()=>{
  104. // $("#c-name").val(res.data[$("#bach").val()].name);
  105. // $("#c-specifications").val(res.data[$("#bach").val()].drawer_name);
  106. // $("#c-unit").val(res.data[$("#bach").val()].examine_name);
  107. // });
  108. // $("#btn").click(()=>{
  109. // //只读->已扫描过批次号
  110. // if($("#c-bach").attr('readonly')==='readonly'){
  111. // return false;
  112. // }
  113. // $("#bach").css('cssText','display:none! important');//隐藏按钮,下拉菜单
  114. // $("#btn").css('display','none');
  115. //
  116. // $.ajax({
  117. // method:"POST",
  118. // url:"feeding/get_formula",
  119. // data:{
  120. // bach:$("#c-bach").val(),
  121. // num:res.data[$("#bach").val()].number// 选定批次号的生产量,精确查找
  122. // },
  123. // success(result){
  124. // var str = '';//页面table
  125. // var html = '';// html:需打印的表格
  126. // for(var i=0;i<result.data.length;i++){
  127. // str += "<tr class='tablestr"+i+" tablestr'><td><input class='form-control material' type='text' name='row[material][]' readonly value='"+result.data[i].material+"'></td>";
  128. // str += "<td><input class='form-control' type='text' name='row[nweight][]' readonly value='"+result.data[i].nweight+"'></td>";
  129. // str += "<td><input class='form-control' type='number' name='row[weight][]' value='";
  130. // if (result.data[i].weight) {
  131. // //已操作的工序变为只读,附带实加重量
  132. // str += parseFloat(result.data[i].weight) + "' readonly ";
  133. // }
  134. // str += "'></td>";
  135. // str += "<input class='form-control' type='hidden' name='row[gy_num][]' value='"+result.data[i].gy_num+"'>";
  136. // str += "<td><input class='form-control' type='text' name='row[gy_name][]' readonly value='"+result.data[i].gy_name+"'></td>";
  137. // str += "</tr>";
  138. // html += `<tr class="print${i} print"><td>${result.data[i].material}</td>
  139. // <td>${result.data[i].nweight}</td><td>`;
  140. // if (result.data[i].weight) {
  141. // html += parseFloat(result.data[i].weight);
  142. // }
  143. // html += `</td><td style="text-align: left">${result.data[i].gy_name}</td></tr>`;
  144. //
  145. // }
  146. // html+= `<tr>
  147. // <td style="width: 100px;text-align: center">总计</td>
  148. // <td class="total" style="width: 100px;text-align: center"></td>
  149. // <td id="total"></td>
  150. // <td></td>
  151. // </tr>`;//${res.data.number}
  152. // $("#print_gy").append(html);
  153. // $("#table").append(str);
  154. // $("#c-bach").attr('readonly','readonly');//批次号输入框变为只读
  155. //
  156. // $("#wuliao").keydown((e)=>{
  157. // let key = e.which;
  158. // var error = 0;
  159. // if(key === 13){
  160. // var wuliao = $("#wuliao").val();
  161. // for(var i=0;i<result.data.length;i++) {
  162. // //扫描的物料=table中的物料,,,变红,否则语音提示
  163. // if(result.data[i].material===wuliao && result.data[i].gy_num == result.process){
  164. // $(".material")[i].setAttribute('style','color:red');
  165. // error++;
  166. // }else if(result.data[i].material===wuliao){
  167. // Layer.confirm("此物料不在当前工序,请确认!");
  168. // //语音播报
  169. // var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  170. // window.speechSynthesis.speak(msg);
  171. // error++;
  172. // }
  173. // //替代料变扫描的物料
  174. // if(result.data[i].material.indexOf('/')!==-1){
  175. // var arr = result.data[i].material.split('/');
  176. // if(arr.indexOf($("#wuliao").val()) !== -1 && result.data[i].gy_num == result.process){
  177. // $(".material")[i].value = wuliao;
  178. // $(".material")[i].setAttribute('style','color:red');
  179. // error++;
  180. // }else if(arr.indexOf($("#wuliao").val()) !== -1 ){
  181. // Layer.confirm("此物料不在当前工序,请确认!");
  182. // //语音播报
  183. // var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  184. // window.speechSynthesis.speak(msg);
  185. // error++;
  186. // }
  187. // }
  188. // }
  189. // if(error===0){
  190. // Layer.confirm("此物料不在配方中,请确认!");
  191. // //语音播报
  192. // var msg = new SpeechSynthesisUtterance("此物料不在配方中,请确认!");
  193. // window.speechSynthesis.speak(msg);
  194. // }
  195. // //清空物料扫描后的值,下次直接重新扫描即可
  196. // $("#wuliao").val('');
  197. // }
  198. // });
  199. // }
  200. // });
  201. // });
  202. }else{//批次号不重复直接赋值
  203. $("#btn").css('display','none');
  204. $("#c-name").val(res.data[0].name);
  205. $("#c-specifications").val(res.data[0].drawer_name);
  206. $("#c-unit").val(res.data[0].examine_name);
  207. // $("#c-name").val(res.data.name);
  208. // $("#c-specifications").val(res.data.drawer_name);
  209. // $("#c-unit").val(res.data.examine_name);
  210. // alert(res.operator)
  211. if (res.operator != '' && res.inspector != ''){
  212. $("#c-operator").val(res.operator);
  213. $("#c-inspector").val(res.inspector);
  214. }
  215. $.ajax({
  216. method: "POST",
  217. url: "feeding/get_formula",
  218. data: {
  219. bach: $("#c-bach").val(),
  220. },
  221. success(result) {
  222. var str = '';//页面table
  223. var html = '';//打印的table
  224. for(var i=0;i<result.data.length;i++){
  225. str += "<tr class='tablestr"+i+" tablestr'><td><input class='form-control material' type='text' name='row[material][]' readonly value='"+result.data[i].material+"'></td>";
  226. str += "<td><input class='form-control nweight' type='text' name='row[nweight][]' readonly value='"+result.data[i].nweight+"'></td>";
  227. str += "<td style='display: none'><input class='form-control gy_num' type='hidden' name='row[gy_num][]' value='"+result.data[i].gy_num+"'></td>";
  228. //投料重量
  229. str += "<td><input class='form-control number' type='number' name='row[weight][]' value='";
  230. if (result.data[i].weight) {
  231. //已操作的工序变为只读,附带实加重量
  232. str += result.data[i].weight + "' readonly ";
  233. }
  234. str += "'></td>";
  235. if(result.data[i].weight == 0){
  236. str += "<td><button type=\"button\" class=\"btn btn-primary btn-embossed submit \">保存</button></td>";
  237. str += "<td><input class='form-control bach' type='text' name='row[bach][]' value=''></td>";
  238. }else{
  239. str += "<td><button type=\"button\" class=\"btn btn-primary btn-embossed submit \" disabled>已保存</button></td>";
  240. str += "<td><input class='form-control bach' type='text' name='row[bach][]' disabled readonly value='"+result.data[i].material_bach+"'></td>";
  241. }
  242. // if(result.data[i].material_bach){
  243. // str += "<td><input class='form-control bach' type='text' name='row[bach][]' readonly value='"+result.data[i].material_bach+"'></td>";
  244. // }else{
  245. // str += "<td><input class='form-control bach' type='text' name='row[bach][]' value=''></td>";
  246. // }
  247. str += "<td><input class='form-control' type='text' name='row[gy_name][]' value='"+result.data[i].gy_name+"'></td>";
  248. str += "</tr>";
  249. html += `<tr class="print${i} print"><td>${result.data[i].material}</td>
  250. <td>${result.data[i].nweight}</td><td>`;
  251. if (result.data[i].weight) {
  252. html += parseFloat(result.data[i].weight);
  253. }
  254. html += `</td><td style="text-align: left">${result.data[i].gy_name}</td></tr>`;
  255. }
  256. html+= `<tr>
  257. <td style="width: 100px;text-align: center">总计</td>
  258. <td class="total" id="stotal" style="width: 100px;text-align: center"></td>
  259. <td id="total"></td>
  260. <td></td>
  261. </tr>`;
  262. $("#print_gy").append(html);
  263. $("#table").append(str);
  264. $("#c-bach").attr('readonly','readonly');//批次号输入框变为只读
  265. $("#wuliao").keydown((e)=>{
  266. let key = e.which;
  267. var error = 0;
  268. if(key === 13){
  269. var string = $("#wuliao").val();//获取扫描物料的值
  270. $(document).ready(function() {
  271. console.log('开始获取');
  272. var intervalId; // 用于存储定时器ID
  273. function fetchDataAndUpdateInput() {
  274. $.ajax({
  275. url: 'Feeding/cheng',
  276. method: 'GET',
  277. success: function(data) {
  278. var val = data.slice(0,-2);
  279. console.log(data);
  280. console.log(val);
  281. var focusedInput = $("#table").find('.number:focus');
  282. focusedInput.val(val);
  283. // 遍历返回的数据对象,更新对应的输入框
  284. // for (var port in data) {
  285. // var value = data[port];
  286. // // var inputToUpdate = $('#table').find('.' + port); // 假设每个输入框有对应的类名(例如 COM3、COM4)
  287. // var focusedInput = $("#table").find('.number:focus');
  288. // // 只有当值大于 0 时才更新输入框
  289. // if (value > 0 && focusedInput.length > 0) {
  290. // focusedInput.val(value);
  291. // }
  292. // }
  293. },
  294. error: function(jqXHR, textStatus, errorThrown) {
  295. console.log('数据错误:', errorThrown);
  296. }
  297. });
  298. }
  299. function startTimer() {
  300. // 如果定时器已经存在,则不重复创建
  301. if (intervalId) {
  302. return;
  303. }
  304. // 创建定时器,每2秒获取一次数据
  305. intervalId = setInterval(fetchDataAndUpdateInput, 2000);
  306. }
  307. function stopTimer() {
  308. if (intervalId) {
  309. clearInterval(intervalId); // 停止定时器
  310. intervalId = null; // 清除定时器ID
  311. }
  312. console.log('停止获取电子秤数据。');
  313. }
  314. // 当任何一个class为number的输入框获得焦点时,启动定时器
  315. $('.number').focus(startTimer);
  316. // 当任何一个class为number的输入框失去焦点时,停止定时器
  317. $('.number').blur(stopTimer);
  318. });
  319. //选择获取电子秤数据
  320. // $(document).ready(function() {
  321. // var intervalId; // 用于存储定时器ID
  322. // // 当任何一个class为number的输入框获得焦点时,启动定时器
  323. // $('.number').focus(function() {
  324. // // 如果定时器已经存在,则不重复创建
  325. // if (intervalId) {
  326. // return;
  327. // }
  328. // // 创建定时器,每3秒获取一次数据
  329. // intervalId = setInterval(function() {
  330. // $.ajax({
  331. // url: 'Feeding/cheng',
  332. // method: 'GET',
  333. // success: function(data) {
  334. // console.log(data);
  335. // var focusedInput = $("#table").find('.number:focus');
  336. // if (focusedInput.length > 0 && data > 0) {
  337. // focusedInput.val(data);
  338. // } else {
  339. // console.log("未获取到电子秤数据或输入框失去焦点");
  340. // clearInterval(intervalId); // 停止定时器
  341. // intervalId = null; // 清除定时器ID
  342. // }
  343. // },
  344. // error: function() {
  345. // console.log('数据错误');
  346. // }
  347. // });
  348. // }, 2000);
  349. // });
  350. // // 当任何一个class为number的输入框失去焦点时,停止定时器
  351. // $('.number').blur(function() {
  352. // if (intervalId) {
  353. // clearInterval(intervalId); // 停止定时器
  354. // intervalId = null; // 清除定时器ID
  355. // }
  356. // console.log('未选择输入框,停止获取电子秤数据。');
  357. // });
  358. // });
  359. // //获取电子秤数据
  360. // $(document).ready(function() {
  361. // var intervalId; // 用于存储定时器ID
  362. // // 当任何一个class为number的输入框获得焦点时,启动定时器
  363. // $('.number').focus(function() {
  364. // // 如果定时器已经存在,则不重复创建
  365. // if (intervalId) {
  366. // return;
  367. // }
  368. // // 创建定时器,每3秒获取一次数据
  369. // intervalId = setInterval(function() {
  370. // // var dzc = $("#dzc").val(); // 获取选择的电子秤值
  371. // var dzc = '开始获取'; // 自动获取
  372. // // console.log(dzc);
  373. // if (!dzc) {
  374. // console.log('未获取电子秤');
  375. // return; // 如果没有选择电子秤,则不执行后续操作
  376. // }
  377. // // 发送AJAX请求获取电子秤数据
  378. // $.ajax({
  379. // url: 'Feeding/cheng',
  380. // method: 'GET',
  381. // data: { dzc: dzc },
  382. // success: function(data) {
  383. // // console.log('开始获取电子秤数据↓↓↓↓↓↓');
  384. // // console.log("电子秤:" + '(' + dzc + ')' + "--数据:" + '(' + data + ')');
  385. // var focusedInput = $("#table").find('.number:focus');
  386. // if (focusedInput.length > 0 && data > 0) {
  387. // focusedInput.val(data);
  388. // } else {
  389. // console.log("未获取到电子秤数据或输入框失去焦点");
  390. // clearInterval(intervalId); // 停止定时器
  391. // intervalId = null; // 清除定时器ID
  392. // }
  393. // },
  394. // error: function() {
  395. // console.log('数据错误');
  396. // }
  397. // });
  398. // }, 2000);
  399. // });
  400. // // 当任何一个class为number的输入框失去焦点时,停止定时器
  401. // $('.number').blur(function() {
  402. // if (intervalId) {
  403. // clearInterval(intervalId); // 停止定时器
  404. // intervalId = null; // 清除定时器ID
  405. // }
  406. // console.log('未选择输入框,停止获取电子秤数据。');
  407. // });
  408. // });
  409. if(string.substr(0,string.indexOf('_'))){
  410. var wuliao = string.substr(0,string.indexOf('_')); //原材料
  411. var bach = string.substr(string.indexOf('_')+1); //原材料批次号
  412. }else{
  413. var wuliao = string;
  414. var bach = '';
  415. }
  416. $('#input').html();
  417. $.ajax({
  418. method: "POST",
  419. url: "feeding/get_material",
  420. data: {
  421. bach: $("#c-bach").val(),
  422. material:wuliao
  423. },
  424. success(data) {
  425. if (data.total > 0){
  426. wuliao = data.string;
  427. $('#input').html(wuliao);
  428. for (var i=0;i<result.data.length;i++){
  429. for (var j=0;j<data.data.length;j++){
  430. //扫描的物料=table中的物料,,,变红,否则语音提示
  431. if(result.data[i].material===data.data[j].m_name){
  432. if (result.data[i].gy_num <= result.process){
  433. //投料重量为空时 扫描物料文字为红
  434. if (result.data[i].weight == 0) {
  435. $(".material")[i].setAttribute('style','color:red');
  436. $(".nweight")[i].setAttribute('style','color:red');
  437. }
  438. var the_bach = document.getElementsByClassName('bach')[i];
  439. if(the_bach.readOnly == false){
  440. the_bach.value = bach;
  441. $(".number")[i].focus();
  442. //语音播报
  443. var msg = new SpeechSynthesisUtterance("应投入物料"+result.data[i].material+"应投入重量"+result.data[i].nweight+"千克");
  444. window.speechSynthesis.speak(msg);
  445. }
  446. error++;
  447. }else if (result.data[i].gy_num > result.process){
  448. Layer.confirm("此物料不在当前工序,请确认!",{
  449. area: ['60%', '60%'],
  450. });
  451. //语音播报
  452. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  453. window.speechSynthesis.speak(msg);
  454. error++;
  455. // }else{
  456. // Layer.confirm("此物料已经投料,请确认此工序是否有此物料!",{
  457. // area: ['60%', '60%'],
  458. // });
  459. // //语音播报
  460. // var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  461. // window.speechSynthesis.speak(msg);
  462. // error++;
  463. }
  464. }
  465. //替代料变扫描的物料
  466. if(result.data[i].material.indexOf('/')!==-1) {
  467. var arr = result.data[i].material.split('/');
  468. if (arr.indexOf($("#wuliao").val()) !== -1 && result.data[i].gy_num == result.process) {
  469. $(".material")[i].value = wuliao;
  470. if (result.data[i].weight == 0) {
  471. $(".material")[i].setAttribute('style','color:red');
  472. $(".nweight")[i].setAttribute('style','color:red');
  473. }
  474. var the_bach = document.getElementsByClassName('bach')[i];
  475. the_bach.value = bach;
  476. $(".number")[i].focus();
  477. error++;
  478. } else if (arr.indexOf($("#wuliao").val()) !== -1) {
  479. Layer.confirm("此物料不在当前工序,请确认!", {
  480. area: ['60%', '60%'],
  481. });
  482. //语音播报
  483. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  484. window.speechSynthesis.speak(msg);
  485. error++;
  486. }
  487. }
  488. }
  489. }
  490. if(error===0){
  491. layer.confirm("此物料不在配方中,且没有替代料,请确认!", {//物料不存在提示错误信息
  492. title: ['信息'],
  493. btn: ['确认'],
  494. area: ['60%', '60%'],
  495. });
  496. var synth = window.speechSynthesis;
  497. var msg = new window.SpeechSynthesisUtterance('此物料不在配方中,且没有替代料,请确认!');
  498. window.speechSynthesis.cancel();
  499. synth.speak(msg);
  500. }
  501. }else{
  502. //没有在数据库查到,直接去比较物料与配方
  503. $('#input').html(wuliao);
  504. for (var i=0;i<result.data.length;i++){
  505. //扫描的物料=table中的物料,,,变红,否则语音提示
  506. if(result.data[i].material===wuliao){
  507. if (result.data[i].gy_num <= result.process){
  508. if (result.data[i].weight == 0) {
  509. $(".material")[i].setAttribute('style','color:red');
  510. $(".nweight")[i].setAttribute('style','color:red');
  511. }
  512. var the_bach = document.getElementsByClassName('bach')[i];
  513. if(the_bach.readOnly == false){
  514. the_bach.value = bach;
  515. $(".number")[i].focus();
  516. //语音播报
  517. var msg = new SpeechSynthesisUtterance("应投入物料"+result.data[i].material+"应投入重量"+result.data[i].nweight+"千克");
  518. window.speechSynthesis.speak(msg);
  519. }
  520. error++;
  521. }else if (result.data[i].gy_num > result.process){
  522. Layer.confirm("此物料不在当前工序,请确认!",{
  523. area: ['60%', '60%'],
  524. });
  525. //语音播报
  526. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  527. window.speechSynthesis.speak(msg);
  528. error++;
  529. }
  530. // else {
  531. // Layer.confirm("此物料已经投料,请确认此工序是否有此物料!",{
  532. // area: ['60%', '60%'],
  533. // });
  534. // //语音播报
  535. // var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  536. // window.speechSynthesis.speak(msg);
  537. // error++;
  538. // }
  539. }
  540. //替代料变扫描的物料
  541. if(result.data[i].material.indexOf('/')!==-1) {
  542. var arr = result.data[i].material.split('/');
  543. var spanValue = document.getElementById("input").innerHTML;
  544. if (arr.indexOf(spanValue) !== -1 && result.data[i].gy_num == result.process) {
  545. $(".material")[i].value = wuliao;
  546. if (result.data[i].weight == 0) {
  547. $(".material")[i].setAttribute('style','color:red');
  548. $(".nweight")[i].setAttribute('style','color:red');
  549. }
  550. var the_bach = document.getElementsByClassName('bach')[i];
  551. if(the_bach.readOnly == false){
  552. the_bach.value = bach;
  553. $(".number")[i].focus();
  554. var msg = new SpeechSynthesisUtterance("应投入物料"+result.data[i].material+"应投入重量"+result.data[i].nweight+"千克");
  555. window.speechSynthesis.speak(msg);
  556. }
  557. error++;
  558. } else if (arr.indexOf($("#wuliao").val()) !== -1) {
  559. Layer.confirm("此物料不在当前工序,请确认!", {
  560. area: ['60%', '60%'],
  561. });
  562. //语音播报
  563. var msg = new SpeechSynthesisUtterance("此物料不在当前工序,请确认!");
  564. window.speechSynthesis.speak(msg);
  565. error++;
  566. }
  567. }
  568. }
  569. if(error===0){
  570. layer.confirm("此物料不在配方中,且没有替代料,请确认!", {//物料不存在提示错误信息
  571. title: ['信息'],
  572. btn: ['确认'],
  573. area: ['60%', '60%'],
  574. });
  575. var synth = window.speechSynthesis;
  576. var msg = new window.SpeechSynthesisUtterance('此物料不在配方中,且没有替代料,请确认!');
  577. window.speechSynthesis.cancel();
  578. synth.speak(msg);
  579. }
  580. }
  581. }
  582. });
  583. //清空物料扫描后的值,下次直接重新扫描即可
  584. $("#wuliao").val('');
  585. }
  586. });
  587. }
  588. });
  589. }
  590. }
  591. });
  592. num++;
  593. }else{
  594. // return false;
  595. }
  596. }
  597. });
  598. $(document).on('click','.submit',function () {
  599. if($("#c-operator").val() == "" || $("#c-inspector").val() == ""){
  600. layer.confirm('请选择 操作人员 或 检验人员',{
  601. title:'操作提示',
  602. btn:[],
  603. area: ['60%','60%'],
  604. closeBtn:0,
  605. time:3000
  606. });
  607. //语音播报
  608. var msg = new SpeechSynthesisUtterance("请选择 操作人员 或 检验人员");
  609. window.speechSynthesis.speak(msg);
  610. }else{
  611. // console.log("批次号"+$("#c-bach").val());
  612. // console.log("日期"+$("#c-date").val());
  613. // console.log("操作人员"+$("#c-operator").val());
  614. // console.log("检验人员"+$("#c-inspector").val());
  615. // console.log("原材料"+$(this).parent().siblings().eq(0).children('input').val());
  616. // console.log("应投重量"+$(this).parent().siblings().eq(1).children('input').val());
  617. // console.log("工艺序号:"+$(this).parent().siblings().eq(2).children('input').val());
  618. // console.log("投料重量"+$(this).parent().siblings().eq(3).children('input').val());
  619. // console.log("原材料_批次号"+$(this).parent().siblings().eq(4).children('input').val());
  620. // console.log("操作记录"+$(this).parent().siblings().eq(5).children('input').val());
  621. // if($(this).parent().siblings().eq(2).children('input').attr('readonly') == true){
  622. // layer.confirm('此原材料已经保存',{
  623. // title:'操作提示',
  624. // btn:[],
  625. // closeBtn:0,
  626. // time:2000
  627. // });
  628. // return false;
  629. // }
  630. //批次号
  631. var bach = $("#c-bach").val();
  632. //日期
  633. var date = $("#c-date").val();
  634. //操作人员
  635. var operator = $("#c-operator").val();
  636. //检验人员
  637. var inspector = $("#c-inspector").val();
  638. //原材料
  639. var material = $(this).parent().siblings().eq(0).children('input').val();
  640. //应投重量
  641. var nweight = $(this).parent().siblings().eq(1).children('input').val();
  642. //工艺序号
  643. var gy_num = $(this).parent().siblings().eq(2).children('input').val();
  644. //投料重量
  645. var weight = $(this).parent().siblings().eq(3).children('input').val();
  646. //原材料批次号
  647. var material_bach = $(this).parent().siblings().eq(4).children('input').val();
  648. //操作记录
  649. var gy_name = $(this).parent().siblings().eq(5).children('input').val();
  650. if(weight == ""){
  651. layer.confirm('请输入投料重量',{
  652. title:'操作提示',
  653. btn:[],
  654. area: ['60%','60%'],
  655. closeBtn:0,
  656. time:2000
  657. });
  658. //语音播报
  659. var msg = new SpeechSynthesisUtterance("请输入投料重量");
  660. window.speechSynthesis.speak(msg);
  661. }else{
  662. $(this).text('已保存');
  663. // $(this).text('修改');
  664. //禁用投料重量
  665. $(this).parent().siblings().eq(3).children('input').attr('disabled',true);
  666. // 禁用原材料批次号
  667. $(this).parent().siblings().eq(4).children('input').attr('disabled',true);
  668. $(this).attr('disabled',true);
  669. }
  670. // console.log(bach);
  671. // console.log(date);
  672. // console.log(operator);
  673. // console.log(inspector);
  674. // console.log(material);
  675. // console.log(nweight);
  676. // console.log(gy_num);
  677. // console.log(weight);
  678. // console.log(material_bach);
  679. // console.log(gy_name);return false;
  680. $.ajax({
  681. type: "POST",
  682. url: "feeding/add",
  683. data: {
  684. bach: bach,
  685. date: date,
  686. operator: operator,
  687. inspector: inspector,
  688. material: material,
  689. nweight: nweight,
  690. gy_num: gy_num,
  691. weight: weight,
  692. material_bach: material_bach,
  693. gy_name: gy_name,
  694. },
  695. success:function(data) {
  696. // console.log("ajax"+data);
  697. }
  698. });
  699. }
  700. });
  701. //投料重量 修改
  702. // $(document).on('click','.submits',function () {
  703. // // $(this).text('保存');
  704. // var bach = $("#c-bach").val();
  705. // var weight = $(this).parent().siblings().eq(3).children('input').val();
  706. // $(this).parent().siblings().eq(3).children('input').removeAttr("readonly");
  707. // $.ajax({
  708. // type: "POST",
  709. // url: "feeding/submits",
  710. // data: {
  711. // weight: weight,
  712. // bach: bach,
  713. // },
  714. // success:function(data) {
  715. // console.log("ajax"+data);
  716. // if(data == '修改失败'){
  717. // console.log(111);
  718. // $(this).text('修改');
  719. // $(this).parent().siblings().eq(3).children('input').attr('disabled',true);
  720. // $(this).attr('disabled',true);
  721. // }
  722. // }
  723. // });
  724. //
  725. // })
  726. $('input').keydown( function (e) {
  727. let key = e.which;
  728. if (key == 13) {
  729. return false;
  730. }
  731. });
  732. $(document).ready(function($) { 'use strict';
  733. $(".print-link").on('click', function() {
  734. var status = 1;
  735. var total = 0;
  736. var stotal = 0;
  737. //开票人
  738. $("#specifications").html($('#c-specifications').val());
  739. //审核
  740. $("#unit").html($('#c-unit').val());
  741. //批次号
  742. var bach = $('#c-bach').val();
  743. //写入到add页面
  744. $("#bach").html(bach);
  745. $("#formula").val($("#name").val());
  746. //添加重量,包装规格,机组到表格内
  747. for(var i=0;i<$(".tablestr").length;i++){
  748. var weight = parseFloat($(".tablestr:eq("+i+")").children("tr td:eq(3)").children().val());
  749. if(weight){
  750. $(".print:eq("+i+")").children("tr td:eq(2)").html(weight);
  751. total += weight;
  752. }
  753. var weight2 = parseFloat($(".tablestr:eq("+i+")").children("tr td:eq(1)").children().val());
  754. if(weight2){
  755. $(".print:eq("+i+")").children("tr td:eq(1)").html(weight2);
  756. stotal += weight2;
  757. }
  758. }
  759. $("#stotal").html(stotal.toFixed(2));
  760. if(total>0){
  761. $("#total").html(total.toFixed(2));
  762. }
  763. if(!$("#c-pickor").val()){
  764. status = 2;
  765. }
  766. if(!$("#c-warehouseor").val()){
  767. status = 2;
  768. }
  769. /*if (status == 2){
  770. layer.confirm('领料人或仓管人为空,请检查!');return false;
  771. }*/
  772. createQrcode(bach,80,80);
  773. var img = document.getElementById("myImage"); /// get image element
  774. var canvas = document.getElementsByTagName('canvas')[0];
  775. img.src = canvas.toDataURL(); /// update image
  776. $.print('#print_area');
  777. return false;
  778. });
  779. function createQrcode(txt,width,height) {
  780. $(".qrcode").qrcode({
  781. render: "canvas",//canvas和table两种渲染方式
  782. width: width,
  783. height: height,
  784. correctLevel:3,//二维码纠错级别
  785. background:"#ffffff",//背景颜色
  786. foreground:"#000000", //二维码颜色
  787. text:txt
  788. });
  789. }
  790. });
  791. Controller.api.bindevent();
  792. },
  793. edit: function () {
  794. Controller.api.bindevent();
  795. },
  796. api: {
  797. bindevent: function () {
  798. Form.api.bindevent($("form[role=form]"));
  799. }
  800. }
  801. };
  802. return Controller;
  803. });