OrderService.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Bom;
  4. use App\Model\BomDetail;
  5. use App\Model\BomDetailMeasure;
  6. use App\Model\BomMaterial;
  7. use App\Model\Orders;
  8. use App\Model\OrdersHouse;
  9. use App\Model\OrdersProduct;
  10. use App\Model\OrdersProductBom;
  11. use App\Model\SysMenu;
  12. use Illuminate\Support\Facades\DB;
  13. use App\Service\Order\OrderService as OrderHook;
  14. /**
  15. * bom相关
  16. * @package App\Models
  17. */
  18. class OrderService extends Service
  19. {
  20. public function edit($data){
  21. list($status,$msg) = $this->orderRule($data);
  22. if(!$status) return [$status,$msg];
  23. if($this->isEmpty($data,'id')) return [false,'ID必须!'];
  24. $id = $data['id'];
  25. $first = Bom::where('title',$data['title'])->where('id','<>',$id)->where('del_time',0)->first();
  26. if(!empty($first))return [false,'名称已存在!'];
  27. try{
  28. DB::beginTransaction();
  29. $model = Bom::where('id',$id)->first();
  30. $model->title = $data['title'];
  31. $model->formula = $data['formula'] ?? '';
  32. $model->unit = $data['unit'];
  33. $model->label = $data['label'] ?? 0;
  34. $model->label_type = $data['label_type'] ?? 0;
  35. $model->save();
  36. $material_insert = [];
  37. $detail_insert = [];
  38. $bom_id = $model->id;
  39. BomDetail::where('bom_id',$bom_id)->update([
  40. 'del_time' => time()
  41. ]);
  42. BomMaterial::where('bom_id',$bom_id)->update([
  43. 'del_time' => time()
  44. ]);
  45. if(isset($data['detail'])){
  46. foreach ($data['detail'] as $v){
  47. $bom_detail = new BomDetail();
  48. $bom_detail->bom_id = $bom_id;
  49. $bom_detail->sub_bom_id = $v['sub_bom_id'];
  50. $bom_detail->formula = $v['formula']??'';
  51. $bom_detail->num = $v['num'];
  52. $bom_detail->save();
  53. $bom_detail_id = $bom_detail->id;
  54. $bom_detail_insert = [];
  55. foreach ($v['measure'] as $vv){
  56. $bom_detail_insert[] = [
  57. 'bom_id' => $bom_id,
  58. 'bom_detail_id' => $bom_detail_id,
  59. 'measure_id' => $vv['measure_id'],
  60. 'value' => $vv['value'],
  61. ];
  62. }
  63. BomDetailMeasure::insert($bom_detail_insert);
  64. }
  65. BomDetail::insert($detail_insert);
  66. }
  67. if(isset($data['material'])){
  68. foreach ($data['material'] as $v){
  69. $material_insert[] = [
  70. 'bom_id' => $id,
  71. 'formula' => $v['formula']??'',
  72. 'num' => $v['num'],
  73. 'material_id' => $v['id'],
  74. 'crt_time' => time(),
  75. 'upd_time' => time(),
  76. ];
  77. }
  78. BomMaterial::insert($material_insert);
  79. }
  80. DB::commit();
  81. }catch (\Exception $e){
  82. DB::rollBack();
  83. return [false,$e->getMessage()];
  84. }
  85. return [true,'保存成功!'];
  86. }
  87. public function add($data,$user){
  88. // if($this->isEmpty($data,'title')) return [201,'名称不存在!'];
  89. list($status,$msg) = $this->orderRule($data);
  90. // if($this->isEmpty($data,'id')) return [false,'ID不存在!'];
  91. if(!$status) return [$status,$msg];
  92. // $first = Orders::where('out_order_no',$data['out_order_no'])->where('del_time',0)->first();
  93. // if(!empty($first))return [false,'单号已存在!'];
  94. $orderService = new OrderHook();
  95. try{
  96. DB::beginTransaction();
  97. $bom_list =
  98. list($status,$order_no) = $orderService->orderSave($data);
  99. foreach ($data['house'] as $v){
  100. $v['order_no'] = $order_no;
  101. list($status,$house_id) = $orderService->orderHouseSave($v);
  102. // var_dump($v);
  103. foreach ($v['product'] as $product){
  104. $product['order_no'] = $order_no;
  105. $product['house_id'] = $house_id;
  106. list($status,$order_product_id) = $orderService->orderProductSave($product);
  107. $product['house_id'] = $house_id;
  108. $product['order_no'] = $order_no;
  109. $product['o_p_id'] = $order_product_id;
  110. $orderService->orderProductBomSave($product);
  111. }
  112. }
  113. DB::commit();
  114. }catch (\Exception $e){
  115. DB::rollBack();
  116. return [false,$e->getLine().':'.$e->getMessage()];
  117. }
  118. return [true,'保存成功!'];
  119. }
  120. public function del($data){
  121. if($this->isEmpty($data,'order_no')) return [false,'order_no必须!'];
  122. $id = $data['order_no'];
  123. Orders::where('order_no',$id)->update([
  124. 'del_time'=>time()
  125. ]);
  126. return [true,'删除成功'];
  127. }
  128. public function orderDetail($data){
  129. $order_no = $data['order_no'];
  130. $order = Orders::where('order_no',$order_no)->first()->toArray();
  131. $house_list = OrdersHouse::where('order_no',$order_no)->select('*')->get()->toArray();
  132. $order_product_list = OrdersProduct::where('order_no',$order_no)->select('*','product_title as title')->get()->toArray();
  133. $order_product_bom_list = OrdersProductBom::where('order_no',$order_no)->select('*','bom_title as title')->get()->toArray();
  134. $order_product_key_list = [];
  135. foreach ($order_product_list as $v){
  136. $order_product_key_list[$v['house_id']][] = $v;
  137. }
  138. $order_product_bom_key_list = [];
  139. foreach ($order_product_bom_list as $v){
  140. $order_product_bom_key_list[$v['o_p_id']][] = $v;
  141. }
  142. foreach ($house_list as $v){
  143. if(isset($order_product_key_list[$v['id']])){
  144. foreach ($order_product_key_list[$v['id']] as &$vv){
  145. if(isset($order_product_bom_key_list[$vv['id']])){
  146. $vv['bom'] = $order_product_bom_key_list[$vv['id']];
  147. }
  148. }
  149. $v['product'] = $order_product_key_list[$v['id']];
  150. }
  151. $order['house'][] = $v;
  152. }
  153. // var_dump($order);die;
  154. return [200,$order];
  155. }
  156. public function orderList($data){
  157. // $id = $data['id'];
  158. $return = Orders::where('del_time',0)->select('*');
  159. $return = $this->limit(
  160. $return,'',$data
  161. );
  162. // $return['bom_detail'] = Bom::from('bom_detail as bd')
  163. // ->leftJoin('bom as b','b.id','bd.bom_id')
  164. // ->where('bd.del_time',0)
  165. // ->select('title','bd.*')->get()->toArray();
  166. //
  167. //
  168. // $return['material'] = Bom::from('bom_material as bm')
  169. // ->leftJoin('material as m','m.id','bm.bom_id')
  170. // ->where('bm.del_time',0)
  171. // ->select('m.title','bm.*')->get()->toArray();
  172. return [200,$return];
  173. }
  174. public function orderRule($data){
  175. if($this->isEmpty($data,'out_order_no')) return [false,'订单号不存在!'];
  176. if($this->isEmpty($data,'project_title')) return [false,'项目名称不存在!'];
  177. if($this->isEmpty($data,'address')) return [false,'地址不存在!'];
  178. if($this->isEmpty($data,'mobile')) return [false,'手机号不存在!'];
  179. // if($this->isEmpty($data,'icon')) return [201,'d不存在!'];
  180. // if($this->isEmpty($data,'uri')) return [false,'路由不存在!'];
  181. return [true,''];
  182. }
  183. }