deliver.js 56 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. $('#lager').click(function () {
  5. $('#iframe1').contentWindow.location.reload('lager.html');
  6. });
  7. Controller.api.bindevent();
  8. },
  9. lager: function () {
  10. // 初始化表格参数配置
  11. Table.api.init();
  12. this.table.first();
  13. this.table.second();
  14. Controller.api.bindevent();
  15. },
  16. table:{
  17. first:function (){
  18. var table = $("#table");
  19. // 初始化表格
  20. table.bootstrapTable({
  21. url: 'deliver/lager',
  22. pk: 'id',
  23. height:600,
  24. sortName: 'id',
  25. pagination: false, // 关闭分页功能
  26. toolbar:'#toolbar',
  27. searchFormVisible:true,
  28. onClickRow:function(row, $element, field)
  29. {
  30. $("#myTabContent1 .form-commonsearch input[name='large_id']").val(row.id);
  31. $("#myTabContent1 .btn-refresh").trigger("click");
  32. },
  33. search:false,
  34. showToggle:false,
  35. showColumns:false,
  36. showExport:false,
  37. columns: [
  38. [
  39. {checkbox: true},
  40. {field: 'id', title: 'ID', visible:false,operate: false},
  41. {field: 'bach', title: __('批次号'),operate: "LIKE"},
  42. {field: 'l_flow', title: __('托盘号'), operate: false},
  43. {field: 'matter_name', title: __('产品名称'), operate: 'LIKE',searchList: $.getJSON("deliver/matterName")},
  44. {field: 'total_boxes', title: "每托箱数", operate: false},
  45. {field: 'tray_num', title: "每层箱数", operate: false},
  46. {field: 'box_num', title: "每托层数", operate: false},
  47. {field: 'pallet_height', title: "每托高度", operate: false},
  48. {
  49. field: 'pallet_size',
  50. title: '托盘规格',
  51. operate: false,
  52. width: 120,
  53. formatter: function (value, row, index) {
  54. return row.pallet_length + ' * ' + row.pallet_width;
  55. }
  56. },
  57. // {field: 'small_num', title: "托盘数", operate: false},
  58. {field: 'larger_num', title: "总箱数", operate: false},
  59. {field: 'manufacture_date', title: '生产日期', operate: 'RANGE', addclass: 'datetimerange',datetimeFormat:'YYYY-MM-DD', formatter: Table.api.formatter.datetime},
  60. {field: 'code', title: __('大件编码'), operate: false},
  61. // {field: 'small_num', title: __('小件数'),operate: false},
  62. ]
  63. ]
  64. });
  65. // 监听复选框点击事件
  66. $('#table').on('check.bs.table uncheck.bs.table check-all.bs.table uncheck-all.bs.table', function(e, rows) {
  67. var selectedData = table.bootstrapTable('getSelections'); // 获取选中的数据
  68. // 计算选中的大件数量和小件数量
  69. // 大件数量(选中的行数)
  70. var largeItemCount = selectedData.length;
  71. var smallItemCount = selectedData.reduce(function(total, row) {
  72. // 累加每个选中项的 small_num
  73. return total + (row.small_num || 0);
  74. }, 0);
  75. // 更新页面上的提示信息
  76. $('p span').eq(1).text(largeItemCount); // 更新大件数量
  77. $('p span').eq(3).text(smallItemCount); // 更新小件数量
  78. });
  79. //导出发货按钮
  80. $('.btn-print').on('click',function () {
  81. var ids = Table.api.selectedids(table);
  82. if (ids.length === 0){
  83. alert('至少选择一个大件');
  84. }
  85. var lager = ids.toString();
  86. // window.location.href = 'print?lager_id='+lager;
  87. Fast.api.ajax({
  88. url:'deliver/print',
  89. data:{lager_id:lager},
  90. },function (data,res) {
  91. if (res.code == 1){
  92. window.location.href = '/'+res.data;
  93. table.bootstrapTable('refresh');
  94. }
  95. return false;
  96. },function (data,res) {
  97. if (res.code == 0){
  98. layer.confirm(res.msg);
  99. }
  100. return false;
  101. })
  102. })
  103. // 为表格绑定事件
  104. Table.api.bindevent(table);
  105. //去掉时间区间记忆
  106. table.on('post-body.bs.table',function (e,settings,json,xhr) {
  107. $('.datetimerange').each(function () {
  108. $(this).attr('autocomplete','off');
  109. })
  110. });
  111. }, second:function(){
  112. //小件列表
  113. var smallTable = $('#small_table');
  114. smallTable.bootstrapTable({
  115. url:'deliver/smallList',
  116. height: 600,
  117. toolbar: '#toolbar1',
  118. search:false,
  119. // commonSearch:false,
  120. showToggle:false,
  121. showColumns:false,
  122. showExport:false,
  123. columns: [
  124. [
  125. {field: 'large_id',title: __('大件id'),operate: 'LIKE',visible:false},
  126. {field: 'code', title: __('小件标签代码'),operate: false},
  127. {field: 'l_flow', title: __('当前序号'),operate: false},
  128. {field: 'print_num', title: __('打印次数'),operate: false},
  129. {field: 'status', title: __('状态'),searchList: {"0":'正常',"1":'已删除'},operate: false,formatter: Table.api.formatter.status},
  130. ]
  131. ]
  132. });
  133. // 为表格绑定事件
  134. Table.api.bindevent(smallTable);
  135. }
  136. },
  137. apply: function () {
  138. // 初始化表格参数配置
  139. Table.api.init({
  140. extend: {
  141. index_url: 'deliver/apply' + location.search,
  142. goods_url: 'deliver/goods',
  143. del_url:'deliver/apply_del',
  144. table:'deliver'
  145. }
  146. });
  147. var table = $("#table2");
  148. // 初始化表格
  149. table.bootstrapTable({
  150. url: $.fn.bootstrapTable.defaults.extend.index_url,
  151. pk: 'id',
  152. height:400,
  153. sortName: 'id',
  154. searchFormVisible:true,
  155. search:false,
  156. showToggle:false,
  157. showColumns:false,
  158. showExport:false,
  159. fixedColumns: true,
  160. fixedRightNumber: 1,
  161. columns: [
  162. [
  163. {checkbox: true},
  164. {field: 'id', title: __('Id'),visible:false,operate: false},
  165. {field: 'large_num', title: '托盘数量', operate: false},
  166. {field: 'matter_name', title: '产品名称', operate: 'LIKE',searchList: $.getJSON("deliver/matterName")},
  167. {field: 'total_boxes', title: '每箱托数', operate: false},
  168. {field: 'tray_num', title: '每层箱数', operate: false},
  169. {field: 'box_num', title: '每托层数', operate: false},
  170. {field: 'pallet_height', title: '托盘高度', operate: false},
  171. {
  172. field: 'pallet_size',
  173. title: '托盘规格',
  174. operate: false,
  175. width: 120,
  176. formatter: function (value, row, index) {
  177. return row.pallet_length + ' * ' + row.pallet_width;
  178. }
  179. },
  180. {field: 'small_num', title: '总箱数', operate: false},
  181. // {field: 'matter_no', title: '产品编码', operate: false},
  182. {field: 'username', title: '所属用户', operate: 'LIKE'},
  183. // {field: 'large_num', title: '大件数量', operate: false},
  184. // {field: 'small_num', title: '小件数量', operate: false},
  185. {field: 'create_time', title: '创建时间', operate: 'RANGE', addclass: 'datetimerange', formatter: Table.api.formatter.datetime},
  186. {field: 'file_dir', title: '下载路径', operate: false,formatter: function (value,row,index) {
  187. if (row.status == 0){
  188. return "<a href=/"+value+">点击下载</a>";
  189. }else {
  190. return "不支持下载";
  191. }
  192. }},
  193. {field: 'status', title: '状态', operate: 'LIKE',searchList: {"0":'待发货',"1":'已删除'}, formatter: Table.api.formatter.status},
  194. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  195. ]
  196. ],
  197. });
  198. // 为表格绑定事件
  199. Table.api.bindevent(table);
  200. //发货按钮
  201. $('.btn-goods').on('click',function () {
  202. var ids = Table.api.selectedids(table);
  203. if (ids.length === 0){
  204. alert('至少选择一个订单');
  205. }
  206. var id_str = ids.toString();
  207. Fast.api.open('deliver/goods?ids='+id_str,'发货信息',{area:["60%","60%"]})
  208. });
  209. //去掉时间区间输入记忆
  210. table.on('post-body.bs.table',function (e,settings,json,xhr) {
  211. $('.datetimerange').each(function () {
  212. $(this).attr('autocomplete','off');
  213. })
  214. });
  215. Controller.api.bindevent();
  216. },
  217. goods: function () {
  218. $('#apply_btn').click(function () {
  219. var ids = $('#goods_id').val();
  220. var order_number = $('#c-order_number').val();
  221. if (order_number == null || order_number === ''){
  222. layer.confirm('订单号不能为空');
  223. }
  224. var deliveryman = $('#c-deliveryman').val();
  225. if (deliveryman == null || deliveryman === ''){
  226. layer.confirm('司机名称不能为空');
  227. }
  228. var shr_phone = $('#c-shr_phone').val();
  229. if (shr_phone == null || shr_phone === ''){
  230. layer.confirm('手机号不能为空');
  231. }
  232. var plate_number = $('#c-plate_number').val();
  233. if (plate_number == null || plate_number === ''){
  234. layer.confirm('车牌号不能为空');
  235. }
  236. var note = $('c-note').val();
  237. Fast.api.ajax({
  238. url:'deliver/apply_add',
  239. data:{
  240. ids:ids,
  241. order_number:order_number,
  242. deliveryman:deliveryman,
  243. shr_phone:shr_phone,
  244. plate_number:plate_number,
  245. note:note,
  246. }
  247. },function (data,res) {
  248. parent.Toastr.success("成功");
  249. Fast.api.close();
  250. window.parent.location.reload();
  251. return false;
  252. },function (data) {
  253. parent.Toastr.error('失败');
  254. Fast.api.close();
  255. window.parent.location.reload();
  256. return false;
  257. })
  258. });
  259. Controller.api.bindevent();
  260. },
  261. dispatch: function () {
  262. // 初始化表格参数配置
  263. Table.api.init({
  264. extend: {
  265. index_url: 'deliver/dispatch' + location.search,
  266. del_url:'deliver/dispatch_del',
  267. table:'deliver'
  268. }
  269. });
  270. var table = $("#table3");
  271. // 初始化表格
  272. table.bootstrapTable({
  273. url: $.fn.bootstrapTable.defaults.extend.index_url,
  274. pk: 'id',
  275. height:400,
  276. sortName: 'id',
  277. searchFormVisible:true,
  278. showToggle:false,
  279. showColumns:false,
  280. showExport:false,
  281. fixedColumns: true,
  282. fixedRightNumber: 1,
  283. columns: [
  284. [
  285. {checkbox: true},
  286. {field: 'id', title: __('Id'),visible:false,operate: false},
  287. {field: 'shdh', title: '收货单号', operate: false},
  288. {field: 'order_number', title: '订单号', operate: 'LIKE'},
  289. {field: 'deliveryman', title: '司机', operate: false},
  290. {field: 'plate_number', title: '车牌号', operate: false},
  291. {field: 'supplier_name', title: '供应商名称', operate: 'LIKE'},
  292. {field: 'create_time', title: '发货时间', operate: 'RANGE', addclass: 'datetimerange', formatter: Table.api.formatter.datetime},
  293. {field: 'buttons',
  294. width: "120px",
  295. title: __('发货单打印'),
  296. operate: false,
  297. table: table,
  298. events: Table.api.events.operate,
  299. buttons: [
  300. {
  301. name: 'ajax',
  302. text: __('点击打印'),
  303. title: __('点击打印'),
  304. classname: 'btn btn-xs btn-success btn-magic btn-ajax',
  305. icon: 'fa fa-magic',
  306. url: 'deliver/printqrcode/id/{ids}',
  307. // confirm: '确认发送',
  308. // success: function (data,res) {
  309. // if (res.code === 1){
  310. // var arr = res.data.data;
  311. // var note='';
  312. // var html = '<div style="width: 1100px;height: 100px;position: relative;">\n' +
  313. // ' <div style="float: left">\n' +
  314. // ' <div style="width: 1000px;font-weight: 400;font-size: 28px;text-align: center;line-height: 50px;" class="company">'+res.data.supplier_name+'</div>\n' +
  315. // ' <div style="width: 1000px;font-weight: 400;font-size: 24px;text-align: center;line-height: 50px;">送货单</div>\n' +
  316. // ' </div>\n' +
  317. // ' <div id="qrcode" style="display:inline-block;width: 105px;height: 105px;position: absolute;right: 100px;top: -5px;">\n' +
  318. // ' <img src="" style="width: 105px;height: 105px;" id="qrcode_image"/>\n' +
  319. // ' </div>\n' +
  320. // ' </div>\n' +
  321. // ' <table class="tg1" style="margin-top: 3px;border-collapse:collapse;border-spacing:0;font-weight:500;width:1186px">\n' +
  322. // ' <tr class="info">\n' +
  323. // ' <td colspan="6" style="border:none">客户名称:河南中烟工业有限责任公司黄金叶生产制造中心</td>\n' +
  324. // ' <td colspan="4" style="border:none">送货单号:<span style="font-size: 16px;" id="shdh">'+res.data.shdh+'</span></td>\n' +
  325. // ' </tr>\n' +
  326. // ' <tr class="info">\n' +
  327. // ' <td colspan="6" style="border:none">送货地址:河南省郑州市经开区第三大街9号</td>\n' +
  328. // ' <td colspan="4" style="border:none">送货日期:<span style="font-size: 16px;" id="shrq_date">'+res.data.shrq_date+'</span></td>\n' +
  329. // ' </tr>\n' +
  330. // ' </table>\n' +
  331. // ' <br>\n' +
  332. // ' <table class="tg1" style="table-layout:fixed;width: 1070px;border-collapse:collapse;border-spacing:0;font-weight:500; position: relative;" id="table">'+
  333. // ' <tr><th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;;;">托盘序号</th>' +
  334. // ' <tr><th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;;">产品名称</th>' +
  335. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;;">每托箱数</th>' +
  336. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">每层箱数</th>' +
  337. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">每托层数</th>' +
  338. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">每托高度</th>' +
  339. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">托盘规格</th>' +
  340. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">托盘数</th>' +
  341. // ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;font-weight:500;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">总箱数</th>' +
  342. // // ' <th id="explain" rowspan="'+(res.data.count+1)+'" width="7%" style="border: none"><span style="writing-mode: tb-rl;height: 300px;font-size:16px;text-align: center;">' +
  343. // // ' 蓝联(回):业务 黄联(回):运输 '+'<br>'+'白联:存根 红联:财务 绿联:客户</span></th>' +
  344. // '</tr>';
  345. // for (var i=0;i < arr.length;i++){
  346. // html+= '<tr><td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].large_ber+'</td>';
  347. // html+= '<tr><td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].matter_name+'</td>';
  348. // html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].total_boxes+'</td>';
  349. // html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].tray_num+'</td>';
  350. // html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].box_num+'</td>';
  351. // // if(arr[i].mater_type==1){
  352. // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].pallet_height+'</td>';
  353. // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].pallet_length + '*' + arr[i].pallet_width+'</td>';
  354. // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].large_num+'</td>';
  355. // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'</td>';
  356. // // }else if (arr[i].mater_type==2){
  357. // // html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">kg</td>';
  358. // // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].l_weight +'</td>';
  359. // // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'件*'+parseFloat(arr[i].num)/1000+'kg'+'</td>';
  360. // // }else if (arr[i].mater_type==3){
  361. // // html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">万支</td>';
  362. // // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+parseFloat(arr[i].num)*parseFloat(arr[i].small_num)/10000+'</td>';
  363. // // html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'件*'+parseInt(arr[i].num)+'支'+'</td>';
  364. // // }
  365. // }
  366. // // html+= '<tr><td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">送货单备注</td>' +
  367. // // ' <td colspan="6" class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+res.data.note+'</td>' +
  368. // // '</tr>'+
  369. // ' </table>\n' +
  370. // ' <table class="tg2" style="margin-top: 3px;border-collapse:collapse;border-spacing:0;font-weight:500;width:1086px;font-size: 16px;">\n' +
  371. // ' <tr class="footer">\n' +
  372. // ' <td colspan="3">发货单位:<span class="company">'+res.data.supplier_name+'</span></td>\n' +
  373. // ' <td colspan="3">司机/司机电话:<span id="deliveryman">'+res.data.deliveryman+'&nbsp;&nbsp;'+res.data.shr_phone+'</span></td>\n' +
  374. // ' <td colspan="3">车牌号:<span id="carid">'+res.data.plate_number+'</span></td>\n' +
  375. // ' </tr>\n' +
  376. // ' <tr class="footer">\n' +
  377. // ' <td colspan="7">发货单位地址:<span id="address">'+res.data.address+'</span></td>\n' +
  378. // ' <td colspan="3">收货单位(签名、盖章)</td>\n' +
  379. // ' </tr>\n' +
  380. // ' </table>'
  381. // $("#printcode").html(html)
  382. // var ee = $('#qrcode_image').attr('src',res.data.qrcode_add);
  383. // // 将打印的区域赋值,进行打印
  384. // ee.on('load',function () {
  385. // var printHTML = document.querySelector('#printcode').innerHTML;
  386. // window.document.body.innerHTML = printHTML;
  387. // window.print();
  388. // // window.location.reload(); // 打印完成后重新加载页面
  389. // })
  390. // }
  391. // return false;
  392. // },
  393. success: function (data, res) {
  394. console.log(data);
  395. console.log(res);
  396. if (res.code === 1) {
  397. var arr = res.data.data;
  398. let html = `
  399. <div style="width: 1100px;height: 100px;position: relative;">
  400. <div style="float: left">
  401. <!-- <div style="width: 1000px;font-weight: 400;font-size: 28px;text-align: center;line-height: 50px;" class="company">${res.data.supplier_name}</div>-->
  402. <!-- <div style="width: 1000px;font-weight: 400;font-size: 24px;text-align: center;line-height: 50px;">送货单</div>-->
  403. <div style="width: 1000px;font-weight: 400;font-size: 28px;text-align: center;line-height: 50px;" class="company"></div>
  404. <div style="width: 1000px;font-weight: 400;font-size: 24px;text-align: center;line-height: 50px;"></div>
  405. </div>
  406. <div id="qrcode" style="display:inline-block;width: 105px;height: 105px;position: absolute;right: 100px;top: -5px;">
  407. <!-- <img src="${res.data.qrcode_add}" style="width: 105px;height: 105px;" id="qrcode_image"/>-->
  408. </div>
  409. </div>
  410. <table class="tg1" style="margin-top: 3px;border-collapse:collapse;width:1186px;font-weight:500;">
  411. <!-- <tr><td colspan="6" style="border:none">客户名称:河南中烟工业有限责任公司黄金叶生产制造中心</td><td colspan="4" style="border:none">送货单号:<span id="shdh">${res.data.shdh}</span></td></tr>-->
  412. <!-- <tr><td colspan="6" style="border:none">送货地址:河南省郑州市经开区第三大街9号</td><td colspan="4" style="border:none">送货日期:<span id="shrq_date">${res.data.shrq_date}</span></td></tr>-->
  413. </table>
  414. <table class="tg1" style="table-layout:fixed;width: 1070px;border-collapse:collapse;border-spacing:0;font-weight:500; position: relative;" >
  415. <tr>
  416. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">托盘序号</th>
  417. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;width: 360px">产品名称</th>
  418. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">每托箱数</th>
  419. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">每层箱数</th>
  420. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">每托层数</th>
  421. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">每托高度</th>
  422. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">托盘规格</th>
  423. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">托盘数</th>
  424. <th style="font-family:Arial, sans-serif;font-size:20px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">总箱数</th>
  425. </tr>
  426. `;
  427. for (let i = 0; i < arr.length; i++) {
  428. html += `
  429. <tr>
  430. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].large_ber}</td>
  431. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].matter_name}</td>
  432. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].total_boxes}</td>
  433. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].tray_num}</td>
  434. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].box_num}</td>
  435. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].pallet_height}</td>
  436. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].pallet_length} * ${arr[i].pallet_width}</td>
  437. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].large_num}</td>
  438. <td style="font-family:Arial, sans-serif;font-size:16px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">${arr[i].small_num}</td>
  439. </tr>
  440. `;
  441. }
  442. // html += `
  443. // </table>
  444. // <table class="tg2" style="margin-top: 3px;border-collapse:collapse;width:1086px;font-size: 16px;">
  445. // <tr><td colspan="3">发货单位:${res.data.supplier_name}</td><td colspan="3">司机/司机电话:${res.data.deliveryman} &nbsp;&nbsp;${res.data.shr_phone}</td><td colspan="3">车牌号:${res.data.plate_number}</td></tr>
  446. // <tr><td colspan="7">发货单位地址:${res.data.address}</td><td colspan="3">收货单位(签名、盖章)</td></tr>
  447. // </table>
  448. // `;
  449. $("#printcode").html(html);
  450. // 正确绑定 load 事件并打印
  451. // let image = document.getElementById('qrcode_image');
  452. // image.onload = function () {
  453. const printHTML = document.querySelector('#printcode').innerHTML;
  454. document.body.innerHTML = printHTML;
  455. window.print();
  456. window.location.reload(); // 可选:打印完重新加载页面
  457. // };
  458. }
  459. return false;
  460. },
  461. error: function (data, ret) {
  462. return false;
  463. }
  464. },
  465. ],
  466. formatter: Table.api.formatter.buttons
  467. },
  468. {field: 'status', title: '状态', operate: 'LIKE',searchList: {"0":'已发货',"1":'已删除'}, formatter: Table.api.formatter.status},
  469. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  470. ]
  471. ],
  472. });
  473. // 为表格绑定事件
  474. Table.api.bindevent(table);
  475. //去掉时间区间输入记忆
  476. table.on('post-body.bs.table',function (e,settings,json,xhr) {
  477. $('.datetimerange').each(function () {
  478. $(this).attr('autocomplete','off');
  479. })
  480. });
  481. Controller.api.bindevent();
  482. },
  483. receive: function () {
  484. // 初始化表格参数配置
  485. Table.api.init({
  486. extend: {
  487. index_url: 'deliver/receive' + location.search,
  488. del_url:'deliver/receive_del',
  489. table:'deliver'
  490. }
  491. });
  492. var table = $("#table");
  493. // 初始化表格
  494. table.bootstrapTable({
  495. url: $.fn.bootstrapTable.defaults.extend.index_url,
  496. pk: 'id',
  497. height:500,
  498. sortName: 'id',
  499. searchFormVisible:true,
  500. showToggle:false,
  501. showColumns:false,
  502. showExport:false,
  503. fixedColumns: true,
  504. fixedRightNumber: 1,
  505. columns: [
  506. [
  507. {checkbox: true},
  508. {field: 'id', title: __('Id'),visible:false,operate: false},
  509. {field: 'shdh', title: '送货单号', operate: false},
  510. {field: 'order_number', title: '订单号', operate: 'LIKE'},
  511. {field: 'deliveryman', title: '司机', operate: false},
  512. {field: 'plate_number', title: '车牌号', operate: false},
  513. {field: 'supplier_name', title: '供应商名称', operate: 'LIKE'},
  514. {field: 'create_time', title: '发货时间', operate: 'RANGE', addclass: 'datetimerange', formatter: Table.api.formatter.datetime},
  515. {field: 'buttons', operate: false,
  516. width: "120px",
  517. title: __('发货单打印'),
  518. table: table,
  519. events: Table.api.events.operate,
  520. buttons: [
  521. {
  522. name: 'ajax',
  523. text: __('点击打印'),
  524. title: __('点击打印'),
  525. classname: 'btn btn-xs btn-success btn-magic btn-ajax',
  526. icon: 'fa fa-magic',
  527. url: 'deliver/printqrcode/id/{ids}',
  528. // confirm: '确认发送',
  529. success: function (data,res) {
  530. if (res.code === 1){
  531. var arr = res.data.data;
  532. var note='';
  533. var html = '<div style="width: 1100px;height: 100px;position: relative;">\n' +
  534. ' <div style="float: left">\n' +
  535. ' <div style="width: 1000px;font-weight: 400;font-size: 28px;text-align: center;line-height: 50px;" class="company">'+res.data.supplier_name+'</div>\n' +
  536. ' <div style="width: 1000px;font-weight: 400;font-size: 24px;text-align: center;line-height: 50px;">送货单</div>\n' +
  537. ' </div>\n' +
  538. ' <div id="qrcode" style="display:inline-block;width: 105px;height: 105px;position: absolute;right: 100px;top: -5px;">\n' +
  539. ' <img src="" style="width: 105px;height: 105px;" id="qrcode_image"/>\n' +
  540. ' </div>\n' +
  541. ' </div>\n' +
  542. ' <table class="tg1" style="margin-top: 3px;border-collapse:collapse;border-spacing:0;font-weight:500;width:1186px">\n' +
  543. ' <tr class="info">\n' +
  544. ' <td colspan="6" style="border:none">客户名称:河南中烟工业有限责任公司黄金叶生产制造中心</td>\n' +
  545. ' <td colspan="4" style="border:none">送货单号:<span style="font-size: 16px;" id="shdh">'+res.data.shdh+'</span></td>\n' +
  546. ' </tr>\n' +
  547. ' <tr class="info">\n' +
  548. ' <td colspan="6" style="border:none">送货地址:河南省郑州市经开区第三大街9号</td>\n' +
  549. ' <td colspan="4" style="border:none">送货日期:<span style="font-size: 16px;" id="shrq_date">'+res.data.shrq_date+'</span></td>\n' +
  550. ' </tr>\n' +
  551. ' </table>\n' +
  552. ' <br>\n' +
  553. ' <table class="tg1" style="table-layout:fixed;width: 1186px;border-collapse:collapse;border-spacing:0;font-weight:500; position: relative;" id="table">'+
  554. ' <tr><th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">物料名称</th>' +
  555. ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">生产批号</th>' +
  556. ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">大件</th>' +
  557. ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">小件</th>' +
  558. ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">单位</th>' +
  559. ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">实发数量</th>' +
  560. ' <th class="tg-s6z2" style="font-family:Arial, sans-serif;font-size:20px;text-align:center;font-weight:500;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:black;">备注</th>' +
  561. ' <th id="explain" rowspan="'+(res.data.count+1)+'" width="7%" style="border: none"><span style="writing-mode: tb-rl;height: 300px;font-size:16px;text-align: center;">' +
  562. ' 蓝联(回):业务 黄联(回):运输 '+'<br>'+'白联:存根 红联:财务 绿联:客户</span></th></tr>';
  563. for (var i=0;i < arr.length;i++){
  564. html+= '<tr><td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].matter_name+'</td>';
  565. html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+(arr[i].bach_num?arr[i].bach_num:'')+'</td>';
  566. html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].large_num+'</td>';
  567. html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'</td>';
  568. if(arr[i].mater_type==1){
  569. html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">万张</td>';
  570. html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].l_num+'</td>';
  571. html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'件*'+parseInt(arr[i].num)+'张'+'</td>';
  572. }else if (arr[i].mater_type==2){
  573. html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">kg</td>';
  574. html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].l_weight +'</td>';
  575. html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'件*'+parseFloat(arr[i].num)/1000+'kg'+'</td>';
  576. }else if (arr[i].mater_type==3){
  577. html+= '<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">万支</td>';
  578. html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+parseFloat(arr[i].num)*parseFloat(arr[i].small_num)/10000+'</td>';
  579. html+='<td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+arr[i].small_num+'件*'+parseInt(arr[i].num)+'支'+'</td>';
  580. }
  581. }
  582. html+= '<tr><td class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">送货单备注</td>' +
  583. ' <td colspan="6" class="tg-031e" style="font-family:Arial, sans-serif;font-size:18px;text-align:center;border-style:solid;border-width:1px;overflow:hidden;word-break:break-all;border-color:black;">'+res.data.note+'</td></tr>'+
  584. ' </table>\n' +
  585. ' <table class="tg2" style="margin-top: 3px;border-collapse:collapse;border-spacing:0;font-weight:500;width:1086px;font-size: 16px;">\n' +
  586. ' <tr class="footer">\n' +
  587. ' <td colspan="3">发货单位:<span class="company">'+res.data.supplier_name+'</span></td>\n' +
  588. ' <td colspan="3">司机/司机电话:<span id="deliveryman">'+res.data.deliveryman+'&nbsp;&nbsp;'+res.data.shr_phone+'</span></td>\n' +
  589. ' <td colspan="3">车牌号:<span id="carid">'+res.data.plate_number+'</span></td>\n' +
  590. ' </tr>\n' +
  591. ' <tr class="footer">\n' +
  592. ' <td colspan="7">发货单位地址:<span id="address">'+res.data.address+'</span></td>\n' +
  593. ' <td colspan="3">收货单位(签名、盖章)</td>\n' +
  594. ' </tr>\n' +
  595. ' </table>'
  596. $("#printcode").html(html)
  597. var ee = $('#qrcode_image').attr('src',res.data.qrcode_add);
  598. // 将打印的区域赋值,进行打印
  599. ee.on('load',function () {
  600. var printHTML = document.querySelector('#printcode').innerHTML;
  601. window.document.body.innerHTML = printHTML;
  602. window.print();
  603. window.location.reload(); // 打印完成后重新加载页面
  604. })
  605. }
  606. return false;
  607. },
  608. error: function (data, ret) {
  609. return false;
  610. }
  611. },
  612. ],
  613. formatter: Table.api.formatter.buttons
  614. },
  615. {field: 'status', title: '状态', operate: 'LIKE',searchList: {"0":'未收货',"2":'已收货'},defaultValue:'1', formatter: Table.api.formatter.status},
  616. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  617. ]
  618. ],
  619. });
  620. $('#receive').click(function (){
  621. var shdh = $('#shdh').val();
  622. if (shdh!=''){
  623. $.get('deliver/receive_add',{'shdh':shdh},function (res){
  624. if (res.code==1){
  625. //修改成功
  626. //1. 提示
  627. Toastr.success(res.msg)
  628. //2. 刷新页面
  629. table.bootstrapTable('refresh');
  630. }else{
  631. Toastr.error(res.msg)
  632. }
  633. })
  634. }
  635. })
  636. // 为表格绑定事件
  637. Table.api.bindevent(table);
  638. Controller.api.bindevent();
  639. },
  640. api: {
  641. bindevent: function () {
  642. Form.api.bindevent($("form[role=form]"));
  643. }
  644. }
  645. };
  646. return Controller;
  647. });