FyyOrderService.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Orders;
  4. use App\Model\SaleOrdersProduct;
  5. use App\Model\SaleOrdersProductStockDetail;
  6. use Illuminate\Support\Facades\DB;
  7. class FyyOrderService extends Service
  8. {
  9. public function edit($data){
  10. return [true,'保存成功!'];
  11. }
  12. public function setOrderNo(){
  13. date_default_timezone_set('PRC');
  14. $order_no = date('Ymd') . time() . rand(1000, 9999);
  15. return $order_no;
  16. }
  17. public function add($data,$user){
  18. //获取数据
  19. $sqlServerModel = new FyySqlServerService();
  20. list($status,$return,$return_stock_detail) = $sqlServerModel->getDataFromSqlServer($data);
  21. if(! $status) return [false, $return];
  22. //数据校验以及填充
  23. list($status,$msg) = $this->orderRule($return);
  24. if(!$status) return [$status,$msg];
  25. try{
  26. DB::beginTransaction();
  27. $keys = array_unique(array_column($return,'out_order_no'));
  28. $map = array_fill_keys($keys, 0);
  29. $orders = $return_stock_detail_map = [];
  30. foreach ($return as $key => $value){
  31. if(! empty($map[$value['out_order_no']])){
  32. $order_no = $map[$value['out_order_no']];
  33. }else{
  34. $order_no = $this->setOrderNo();
  35. $map[$value['out_order_no']] = $order_no;
  36. $orders[] = [
  37. 'order_no' => $order_no,
  38. 'out_order_no' => $value['out_order_no'],
  39. 'crt_time' => time()
  40. ];
  41. }
  42. $return[$key]['order_no'] = $order_no;
  43. $return[$key]['crt_id'] = $user['id'];
  44. $return[$key]['crt_time'] = time();
  45. $keys = ($value['technology_name'] ?? '' ) . ($value['wood_name'] ?? '' ) . $value['product_no'];
  46. $return_stock_detail_map[$keys] = $order_no;
  47. }
  48. foreach ($return_stock_detail as $key => $value){
  49. $keys = ($value['technology_name'] ?? '' ) . ($value['wood_name'] ?? '' ) . $value['product_no'];
  50. $return_stock_detail[$key]['order_no'] = $return_stock_detail_map[$keys] ?? '';
  51. }
  52. Orders::insert($orders);
  53. SaleOrdersProduct::insert($return);
  54. SaleOrdersProductStockDetail::insert($return_stock_detail);
  55. DB::commit();
  56. }catch (\Exception $e){
  57. DB::rollBack();
  58. return [false,$e->getLine().':'.$e->getMessage()];
  59. }
  60. return [true,'保存成功!'];
  61. }
  62. public function del($data){
  63. if($this->isEmpty($data,'id')) return [false,'ID不能为空!'];
  64. Orders::whereIn('id',$data['id'])->update([
  65. 'del_time' => time()
  66. ]);
  67. SaleOrdersProduct::where('id',$data['id'])->update([
  68. 'del_time'=>time()
  69. ]);
  70. return [true,'删除成功'];
  71. }
  72. public function orderDetail($data){
  73. return [200,''];
  74. }
  75. public function orderList($data){
  76. $model = SaleOrdersProduct::where('del_time',0)
  77. ->select('id','order_no','out_order_no','out_order_no_time','customer_no','customer_name','table_header_mark','product_no','product_title','product_size','product_unit','product_quantity','technology_material','technology_name','wood_name','process_mark','table_body_mark','out_crt_man','out_checker_man','out_checker_time')
  78. ->orderBy('id','desc');
  79. if(! empty($data['order_no'])) $model->where('order_no', 'LIKE', '%'.$data['order_no'].'%');
  80. if(! empty($data['out_order_no'])) $model->where('out_order_no', 'LIKE', '%'.$data['out_order_no'].'%');
  81. if(! empty($data['customer_name'])) $model->where('customer_name', 'LIKE', '%'.$data['customer_name'].'%');
  82. if(! empty($data['product_title'])) $model->where('product_title', 'LIKE', '%'.$data['product_title'].'%');
  83. if(! empty($data['product_size'])) $model->where('product_size', 'LIKE', '%'.$data['product_size'].'%');
  84. if(! empty($data['technology_material'])) $model->where('technology_material', 'LIKE', '%'.$data['technology_material'].'%');
  85. if(! empty($data['technology_name'])) $model->where('technology_name', 'LIKE', '%'.$data['technology_name'].'%');
  86. if(! empty($data['wood_name'])) $model->where('wood_name', 'LIKE', '%'.$data['wood_name'].'%');
  87. if(! empty($data['process_mark'])) $model->where('process_mark', 'LIKE', '%'.$data['process_mark'].'%');
  88. if(! empty($data['table_header_mark'])) $model->where('table_header_mark', 'LIKE', '%'.$data['table_header_mark'].'%');
  89. if(! empty($data['table_body_mark'])) $model->where('table_body_mark', 'LIKE', '%'.$data['table_body_mark'].'%');
  90. if(! empty($data['out_checker_man'])) $model->where('out_checker_man', 'LIKE', '%'.$data['out_checker_man'].'%');
  91. if(! empty($data['out_crt_man'])) $model->where('out_crt_man', 'LIKE', '%'.$data['out_crt_man'].'%');
  92. if(! empty($data['out_checker_time'][0]) && ! empty($data['out_checker_time'][1])) $model->whereBetween('out_checker_time',[$data['out_checker_time'][0],$data['out_checker_time'][1]]);
  93. if(! empty($data['out_order_no_time'][0]) && ! empty($data['out_order_no_time'][1])) $model->whereBetween('out_order_no_time',[$data['out_order_no_time'][0],$data['out_order_no_time'][1]]);
  94. if(isset($data['status'])) $model->where('status',$data['status']);
  95. $list = $this->limit($model,'',$data);
  96. $list = $this->fillData($list);
  97. return [true, $list];
  98. }
  99. public function fillData($data){
  100. if(empty($data['data'])) return $data;
  101. $order_no = array_filter(array_column($data['data'],'order_no'));
  102. $detail = SaleOrdersProductStockDetail::where('del_time',0)
  103. ->whereIn('order_no',$order_no)
  104. ->select('order_no','product_no','product_quantity_on_hand','technology_name','wood_name','warehouse_name')
  105. ->get()->toArray();
  106. $detail_map = [];
  107. foreach ($detail as $value){
  108. $keys = $value['order_no'] . $value['product_no'];
  109. $detail_map[$keys][] = [
  110. 'warehouse_name' => $value['warehouse_name'],
  111. 'product_quantity_on_hand' => $value['product_quantity_on_hand']
  112. ];
  113. }
  114. foreach ($data['data'] as $key => $value){
  115. $keys = $value['order_no'] . $value['product_no'];
  116. $data['data'][$key]['sub'] = $detail_map[$keys] ?? [];
  117. }
  118. return $data;
  119. }
  120. public function orderRule($data){
  121. $result = Orders::where('del_time',0)
  122. ->whereIn('out_order_no',array_column($data,'out_order_no'))
  123. ->select('out_order_no')
  124. ->get()->toArray();
  125. if(! empty($result)) return [false,'查询区间内销售订单号已存在'];
  126. return [true,''];
  127. }
  128. public function fyyRefreshOnHandQuantity($data){
  129. return [true,''];
  130. }
  131. }