sale_order.html 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>出库管理</title>
  6. <meta name="renderer" content="webkit">
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  8. <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
  9. <link rel="stylesheet" href="../../layuiadmin/layui/css/layui.css" media="all">
  10. <link rel="stylesheet" href="../../layuiadmin/style/admin.css" media="all">
  11. </head>
  12. <style type="text/css">
  13. .LAY-btns .layui-nav {padding-left:0;padding-right:10px;top:-4px;margin: 0 10px;border: 0;background-color: #009688;}
  14. .LAY-btns .layui-nav .layui-nav-item{line-height: 30px;}
  15. .LAY-btns .layui-nav .layui-nav-child{top:34px;}
  16. .LAY-btns .layui-nav .layui-nav-bar{display: none;}
  17. .LAY-btns .layui-nav .layui-nav-child dd.layui-this a{color:#333;background-color:#fff;}
  18. .LAY-btns .layui-nav .layui-nav-child dd.layui-this a:hover {background-color: #f2f2f2;color: #000;}
  19. </style>
  20. <body>
  21. <div class="layui-fluid">
  22. <div class="layui-card">
  23. <div class="layui-card-body" pad15>
  24. <div class="layui-row layui-col-space15">
  25. <div class="layui-col-md12">
  26. <div class="LAY-btns" style="margin-bottom: 10px;">
  27. <button class="layui-btn layui-btn-sm" id="btn_add" data-permission="order.add_sale_order"><i class="layui-icon layui-icon-add-circle" ></i>添加</button>
  28. <button class="layui-btn layui-btn-sm" id="btn_deliver" data-permission="order.add_goods_deliver"><i class="layui-icon layui-icon-add-circle" ></i>转出库</button>
  29. <button class="layui-btn layui-btn-sm" id="btn_loss" data-permission="order.loss_sale_order"><i class="layui-icon layui-icon-layer" ></i>扣减</button>
  30. <button class="layui-btn layui-btn-sm" id="btn_receive"><i class="layui-icon layui-icon-ok-circle" ></i>完善发货</button>
  31. <button class="layui-btn layui-btn-sm" id="btn_ship" data-permission="order.pay_sale_order"><i class="layui-icon layui-icon-dollar" ></i>装运</button>
  32. <button class="layui-btn layui-btn-sm" id="btn_pay" data-permission="order.pay_sale_order"><i class="layui-icon layui-icon-dollar" ></i>结算</button>
  33. <button class="layui-btn layui-btn-sm" id="btn_clear" data-permission="order.pay_sale_order"><i class="layui-icon layui-icon-dollar" ></i>结清</button>
  34. <button class="layui-nav" data-permission="order.export_sale_order">
  35. <div class="layui-nav-item">
  36. <a href="javascript:;" style="color:#fff;">导出</a>
  37. <dl class="layui-nav-child"> <!-- 二级菜单 -->
  38. <dd><a href="#" id="btn_download">导出列表</a></dd>
  39. <dd><a href="#" id="btn_download_detail">导出明细</a></dd>
  40. </dl>
  41. </div>
  42. </button>
  43. <button class="layui-btn layui-btn-sm" id="btn_print" data-permission="order.print_sale_order"><i class="layui-icon layui-icon-form"></i>打印</button>
  44. <button class="layui-btn layui-btn-sm" id="btn_query"><i class="layui-icon layui-icon-search"></i>查询</button>
  45. </div>
  46. <table class="layui-hide" id="datagrid" lay-filter="datagrid-operate"></table>
  47. <script type="text/html" id="datagrid-operate-bar">
  48. <div class="layui-btn-group">
  49. <a class="layui-btn layui-btn-xs" lay-event="detail" data-permission="order.view_sale_order">查看</a>
  50. {{# if(d.status ==0){ }}
  51. <a class="layui-btn layui-btn-xs" lay-event="edit" data-permission="order.add_sale_order">修改</a>
  52. <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del" data-permission="order.delete_sale_order">删除</a>
  53. <a class="layui-btn layui-btn-xs" lay-event="check_pass" data-permission="order.check_sale_order">审核</a>
  54. {{# } }}
  55. {{# if(d.status ==1){ }}
  56. <a class="layui-btn layui-btn-xs" lay-event="check_revoke" data-permission="order.check_sale_order">撤销审核</a>
  57. {{# } }}
  58. </div>
  59. </script>
  60. </div>
  61. </div>
  62. </div>
  63. </div>
  64. </div>
  65. <div id="dlg_query" style="display: none">
  66. <form class="layui-form" lay-filter="query-form-element">
  67. <div class="layui-card-body" pad15>
  68. <div class="layui-row layui-col-space10 layui-form-item">
  69. <div class="layui-col-xs12 layui-col-sm12">
  70. <label class="layui-form-label">下单时间</label>
  71. <div class="layui-input-inline">
  72. <input type="text" class="layui-input" autocomplete="off" name="create_time" id="create_time" placeholder=" - ">
  73. </div>
  74. </div>
  75. <div class="layui-col-xs12 layui-col-sm12">
  76. <label class="layui-form-label">下单人:</label>
  77. <div class="layui-input-block">
  78. <input type="text" autocomplete="off" name="create_user" class="layui-input">
  79. </div>
  80. </div>
  81. <div class="layui-col-xs12 layui-col-sm12">
  82. <label class="layui-form-label">状态:</label>
  83. <div class="layui-input-block">
  84. <select id="id_check_status" name="status">
  85. <option value="" selected></option>
  86. <option value="0">待审核</option>
  87. <option value="1">已审核</option>
  88. </select>
  89. </div>
  90. </div>
  91. <div class="layui-col-xs12 layui-col-sm12">
  92. <label class="layui-form-label">订单号:</label>
  93. <div class="layui-input-block">
  94. <input type="text" autocomplete="off" name="no" class="layui-input">
  95. </div>
  96. </div>
  97. <div class="layui-col-xs12 layui-col-sm12">
  98. <label class="layui-form-label">客户姓名:</label>
  99. <div class="layui-input-block">
  100. <input type="text" autocomplete="off" name="customer_name" class="layui-input">
  101. </div>
  102. </div>
  103. <div class="layui-col-xs12 layui-col-sm12">
  104. <label class="layui-form-label">客户电话:</label>
  105. <div class="layui-input-block">
  106. <input type="text" autocomplete="off" name="customer_tel" class="layui-input">
  107. </div>
  108. </div>
  109. <div class="layui-col-xs12 layui-col-sm12">
  110. <label class="layui-form-label">结清:</label>
  111. <div class="layui-input-block">
  112. <select name="cleared">
  113. <option value="" selected>全部</option>
  114. <option value="0">未结清</option>
  115. <option value="1">已结清</option>
  116. </select>
  117. </div>
  118. </div>
  119. </div>
  120. <div class="layui-form-item" style="display: none">
  121. <button id="query_search" class="layui-btn" lay-submit lay-filter="query-form-element">查询</button>
  122. </div>
  123. </div>
  124. </form>
  125. </div>
  126. <script src="../../layuiadmin/layui/layui.js?t=1"></script>
  127. <script>
  128. var _params = '';
  129. layui.config({
  130. base: '../../../layuiadmin/' //静态资源所在路径
  131. }).extend({
  132. index: 'lib/index' //主入口模块
  133. }).use(['index', 'table', 'laydate', 'form', 'element', 'utils'], function(){
  134. var $ = layui.$;
  135. var table = layui.table
  136. ,laydate = layui.laydate
  137. ,form = layui.form
  138. ,utils = layui.utils
  139. ,admin = layui.admin;
  140. table.render({
  141. elem: '#datagrid'
  142. ,url: '/order/sale_order/data/'
  143. ,cols: [[
  144. {type:'radio',width:50}
  145. ,{field:'no', title:'单号', width:150}
  146. ,{field:'customer_name', title:'客户', width:120}
  147. ,{field:'customer_tel', title:'客户电话', width: 150}
  148. ,{field:'products', title:'产品', width:120}
  149. ,{field:'count', title:'合计数量', width:100, align:'right'}
  150. ,{field:'amount', title:'合计金额', width:100, align:'right'}
  151. ,{field:'receive_count', title:'收货数量', width:100, align:'right'}
  152. ,{field:'receive_amount', title:'收货金额', width:100, align:'right'}
  153. ,{field:'loss_amount', title:'扣减金额', width:100, align:'right'}
  154. ,{field:'total_amount', title:'应付金额', width:100, align:'right'}
  155. ,{field:'pay_amount', title:'结算金额', width:100, align:'right'}
  156. ,{field:'put_amount', title:'装车费用', width:100, align:'right'}
  157. ,{field:'fare_amount', title:'运输费用', width:100, align:'right'}
  158. ,{field:'clear_text', title:'结清', width:60}
  159. ,{field:'loss_notes', title:'扣减备注', width:100, align:'right'}
  160. ,{field:'create_time', title:'创建时间', width:150}
  161. ,{field:'create_user_text', title:'创建人', width:150}
  162. ,{field:'check_status_text', title:'审核状态', width:120}
  163. ,{field:'check_time', title:'审核时间', width:150}
  164. ,{field:'check_user_text', title:'审核人', width:120}
  165. ,{field:'notes', title:'备注', minWidth:200}
  166. ,{width:200, align:'left', fixed: 'right', toolbar: '#datagrid-operate-bar'}
  167. ]]
  168. ,page: true
  169. ,totalRow: true
  170. ,height: 'full-104'
  171. ,parseData:function(res) {
  172. var cols = this.cols[0];
  173. for (var i in cols) {
  174. if (cols[i].field == 'count') {
  175. cols[i].totalRowText = res.more.sum_count;
  176. }
  177. if (cols[i].field == 'amount') {
  178. cols[i].totalRowText = res.more.sum_amount;
  179. }
  180. if (cols[i].field == 'receive_count') {
  181. cols[i].totalRowText = res.more.sum_receive_count;
  182. }
  183. if (cols[i].field == 'receive_amount') {
  184. cols[i].totalRowText = res.more.sum_receive_amount;
  185. }
  186. if (cols[i].field == 'loss_amount') {
  187. cols[i].totalRowText = res.more.sum_loss_amount;
  188. }
  189. if (cols[i].field == 'total_amount') {
  190. cols[i].totalRowText = res.more.sum_total_amount;
  191. }
  192. if (cols[i].field == 'pay_amount') {
  193. cols[i].totalRowText = res.more.sum_pay_amount;
  194. }
  195. if (cols[i].field == 'put_amount') {
  196. cols[i].totalRowText = res.more.sum_put_amount;
  197. }
  198. if (cols[i].field == 'fare_amount') {
  199. cols[i].totalRowText = res.more.sum_fare_amount;
  200. }
  201. }
  202. return {
  203. "code": res.code, //解析接口状态
  204. "count": res.count, //解析数据长度
  205. "data": res.data //解析数据列表
  206. };
  207. }
  208. ,done: function () {
  209. layui.index.removeNoPermButtons();
  210. }
  211. });
  212. //监听工具条
  213. table.on('tool(datagrid-operate)', function(obj){
  214. var data = obj.data;
  215. table.editdata = data;
  216. if(obj.event === 'detail'){
  217. layer.open({
  218. type: 2,
  219. title: '查看',
  220. shadeClose: true,
  221. area: ['90%', '90%'],
  222. content: 'sale_order_detail.html?id='+data.id
  223. });
  224. } else if(obj.event === 'del'){
  225. if (data.status != 0){
  226. layer.msg('该订单已审核,不允许删除');
  227. return;
  228. }
  229. layer.confirm('确定要删除吗?', function(index){
  230. layer.close(index);
  231. layui.admin.req({
  232. url: '/order/sale_order/delete/?id='+data.id
  233. ,done: function(res){
  234. table.reload('datagrid',{});
  235. }
  236. });
  237. });
  238. } else if(obj.event === 'edit'){
  239. if (data.status != 0){
  240. layer.msg('该订单已审核,不允许修改');
  241. return;
  242. }
  243. table.editdata = data;
  244. layer.open({
  245. type: 2,
  246. title: '修改订单['+data.no+']',
  247. area: ['90%', '90%'],
  248. btn: ['保存', '取消'],
  249. yes: function(index, dom){
  250. layui.onSubmitChild = function (data) {
  251. layer.close(index);
  252. table.reload('datagrid',{});
  253. };
  254. layui.submitChild();
  255. },
  256. btn2: function(index, layero){
  257. layer.close(index);//关闭当前按钮
  258. },
  259. content: 'sale_order_edit.html?id='+data.id
  260. });
  261. } else if(obj.event === 'check_pass'){
  262. if (data.status != 0){
  263. layer.msg('该出订单已审核, 禁止重复操作');
  264. return;
  265. }
  266. layer.confirm('确定要通过审核吗?', function(index){
  267. layer.close(index);
  268. layui.admin.req({
  269. url: '/order/sale_order/check/?id='+data.id + '&status=1'
  270. ,done: function(res){
  271. table.reload('datagrid',{});
  272. }
  273. });
  274. });
  275. }else if(obj.event === 'check_revoke'){
  276. if (data.status == 0){
  277. layer.msg('该出订单尚未审核');
  278. return;
  279. }
  280. layer.confirm('确定要撤销审核吗?', function(index){
  281. layer.close(index);
  282. layui.admin.req({
  283. url: '/order/sale_order/check/?id='+data.id + '&status=0'
  284. ,done: function(res){
  285. table.reload('datagrid',{});
  286. }
  287. });
  288. });
  289. }
  290. });
  291. $('#btn_add').on('click', function(){
  292. layer.open({
  293. type: 2,
  294. title: '下单',
  295. area: ['90%', '90%'],
  296. btn: ['保存', '取消'],
  297. yes: function(index, dom){
  298. layui.onSubmitChild = function (data) {
  299. layer.close(index);
  300. table.reload('datagrid',{});
  301. };
  302. layui.submitChild();
  303. },
  304. btn2: function(index, layero){
  305. layer.close(index);//关闭当前按钮
  306. },
  307. content: 'sale_order_edit.html'
  308. });
  309. });
  310. $('#btn_download').on('click', function(){
  311. layui.admin.req({
  312. url: '/order/sale_order/export/',
  313. data:_params,
  314. done: function (res) {
  315. layui.view.download(res.data.filename);
  316. }
  317. });
  318. });
  319. $('#btn_download_detail').on('click', function(){
  320. var data = utils.getSelectedRow('datagrid');
  321. if(data == false){
  322. return;
  323. }
  324. layui.admin.req({
  325. url: '/order/sale_order/export_detail/?id=' + data.id,
  326. done: function (res) {
  327. layui.view.download(res.data.filename);
  328. }
  329. });
  330. });
  331. $('#btn_print').on('click', function(){
  332. var data = utils.getSelectedRow('datagrid');
  333. if(data == false){
  334. return;
  335. }
  336. table.editdata = data;
  337. layer.open({
  338. type: 2,
  339. title: '打印',
  340. shadeClose: true,
  341. area: ['90%', '90%'],
  342. btn: ['打印', '取消'],
  343. yes: function(index, dom){
  344. layui.onSubmitChild = function (data) {
  345. layer.close(index);
  346. };
  347. layui.submitChild();
  348. },
  349. btn2: function(index, layero){
  350. layer.close(index);//关闭当前按钮
  351. },
  352. content: 'sale_order_print.html?id='+data.id
  353. });
  354. });
  355. $('#btn_deliver').on('click', function(){
  356. var data = utils.getSelectedRow('datagrid');
  357. if(data == false){
  358. return;
  359. }
  360. if (data.status == 0) {
  361. layer.msg('该订单未审核,不允许出库');
  362. return;
  363. }
  364. table.editdata = data;
  365. layer.open({
  366. type: 2,
  367. title: '转出库',
  368. shadeClose: false,
  369. area: ['90%', '90%'],
  370. btn: ['保存', '取消'],
  371. yes: function(index, dom){
  372. layui.onSubmitChild = function (data) {
  373. layer.close(index);
  374. };
  375. layui.submitChild();
  376. },
  377. btn2: function(index, layero){
  378. layer.close(index);//关闭当前按钮
  379. },
  380. content: 'goods_deliver_edit.html?order_id='+data.id
  381. });
  382. });
  383. $('#btn_loss').on('click', function(){
  384. var data = utils.getSelectedRow('datagrid');
  385. if(data == false){
  386. return;
  387. }
  388. if (data.status == 0) {
  389. layer.msg('该订单未审核,不允许扣减');
  390. return;
  391. }
  392. table.editdata = data;
  393. layer.open({
  394. type: 2,
  395. title: '扣减[' + data.no + ']',
  396. shadeClose: false,
  397. area: ['90%', '90%'],
  398. btn: ['保存', '取消'],
  399. yes: function(index, dom){
  400. layui.onSubmitChild = function (data) {
  401. layer.close(index);
  402. table.reload('datagrid',{});
  403. };
  404. layui.submitChild();
  405. },
  406. btn2: function(index, layero){
  407. layer.close(index);//关闭当前按钮
  408. },
  409. content: 'sale_order_loss.html?order_id='+data.id
  410. });
  411. });
  412. $('#btn_pay').on('click', function(){
  413. var data = utils.getSelectedRow('datagrid');
  414. if(data == false){
  415. return;
  416. }
  417. if (data.status == 0) {
  418. layer.msg('该订单未审核,不允许收银');
  419. return;
  420. }
  421. table.editdata = data;
  422. layer.open({
  423. type: 2,
  424. title: '付款['+ data.no +']',
  425. shadeClose: false,
  426. area: ['40%', '80%'],
  427. btn: ['保存', '取消'],
  428. yes: function(index, dom){
  429. layui.onSubmitChild = function (data) {
  430. layer.close(index);
  431. table.reload('datagrid',{});
  432. };
  433. layui.submitChild();
  434. },
  435. btn2: function(index, layero){
  436. layer.close(index);//关闭当前按钮
  437. },
  438. content: 'sale_order_pay.html?order_id='+data.id
  439. });
  440. });
  441. $('#btn_ship').on('click', function(){
  442. var data = utils.getSelectedRow('datagrid');
  443. if(data == false){
  444. return;
  445. }
  446. table.editdata = data;
  447. layer.open({
  448. type: 2,
  449. title: '添加装运费[' + data.no + ']',
  450. shadeClose: false,
  451. area: ['80%', '70%'],
  452. btn: ['保存', '取消'],
  453. yes: function(index, dom){
  454. layui.onSubmitChild = function (data) {
  455. layer.close(index);
  456. table.reload('datagrid',{});
  457. };
  458. layui.submitChild();
  459. },
  460. btn2: function(index, layero){
  461. layer.close(index);//关闭当前按钮
  462. },
  463. content: 'sale_order_fare.html?order_id='+data.id
  464. });
  465. });
  466. $('#btn_clear').on('click', function(){
  467. var data = utils.getSelectedRow('datagrid');
  468. if(data == false){
  469. return;
  470. }
  471. if (data.status === 0){
  472. layer.msg('该订单未审核');
  473. return;
  474. }
  475. if (data.cleared){
  476. layer.msg('该订单已结清');
  477. return;
  478. }
  479. layer.confirm('确定要结清吗?', function(index){
  480. layer.close(index);
  481. layui.admin.req({
  482. url: '/order/sale_order/clear/?id='+data.id
  483. ,done: function(res){
  484. table.reload('datagrid',{});
  485. }
  486. });
  487. });
  488. });
  489. $('#btn_query').on('click', function(){
  490. layer.open({
  491. type: 1,
  492. shadeClose: true,
  493. area: ['500px', '450px'],
  494. title: '查询',
  495. btn: ['查询'],
  496. yes: function(index, dom){
  497. $('#query_search').click();
  498. },
  499. content: $('#dlg_query')
  500. });
  501. });
  502. form.on('submit(query-form-element)', function(data){
  503. //layer.msg(JSON.stringify(data.field));
  504. _params = data.field;
  505. table.reload('datagrid', {
  506. where: data.field,
  507. page:{curr:1}
  508. });
  509. layer.closeAll();
  510. return false
  511. });
  512. laydate.render({
  513. elem: '#create_time'
  514. ,range: true
  515. });
  516. });
  517. </script>
  518. </body>
  519. </html>