sale_order.html 18 KB

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