U8ServerService.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Record;
  4. use Illuminate\Support\Facades\DB;
  5. class U8ServerService extends Service
  6. {
  7. protected $databaseService;
  8. /**
  9. * @var string|null
  10. */
  11. protected $error;
  12. /**
  13. * U8ServerService constructor.
  14. */
  15. public function __construct($loginUser = [])
  16. {
  17. $service = new U8DatabaseServerService($loginUser);
  18. $this->databaseService = $service->db;
  19. $this->error = $service->error;
  20. }
  21. /**
  22. * 获取错误信息
  23. *
  24. * @return string|null
  25. */
  26. public function getError()
  27. {
  28. return $this->error;
  29. }
  30. public function purchaseRequisition($data, $user){
  31. $qx = $user['qx'];
  32. $order_date = $data['order_date'] ?? [];
  33. $order_date = array_filter($order_date);
  34. $order_number = $data['order_number'] ?? "";
  35. $model = $this->databaseService->table('PU_AppVouch as a')
  36. ->leftJoin('Person as c', 'c.cPersonCode', 'a.cPersonCode')
  37. ->when(empty($qx), function ($query) use($user){
  38. return $query->where('a.cMaker',$user['username']);
  39. })
  40. ->when(! empty($order_number), function ($query) use($order_number){
  41. return $query->where('a.cCode','LIKE', '%'.$order_number.'%');
  42. })
  43. ->when(! empty($order_date), function ($query) use($order_date){
  44. $start = date('Y-m-d H:i:s.000', $order_date[0]);
  45. $end = date('Y-m-d H:i:s.000', $order_date[1]);
  46. return $query->whereBetween('a.dDate', [$start, $end]);
  47. })
  48. ->where(function ($query) {
  49. $query->where('a.iverifystateex', 0)
  50. ->OrwhereNull('a.iverifystateex');
  51. })
  52. ->select('a.cMaker as crt_name', DB::raw("COALESCE(c.cPersonName, '') as purchase_name"),'a.cBusType as business_type','a.cCode as order_number',DB::raw("CONVERT(varchar(10), a.dDate, 120) as order_date"))
  53. ->orderBy('a.ID','desc');
  54. $list = $this->limit($model,'',$data);
  55. $list = $this->fillAll($list, 2);
  56. return [true , $list];
  57. }
  58. public function purchaseRequisitionDetail($data, $user){
  59. if(empty($data['order_number'])) return [false, '采购请购单号不能为空'];
  60. $order = $this->databaseService->table('PU_AppVouch as a')
  61. ->leftJoin('Person as c', 'c.cPersonCode', 'a.cPersonCode')
  62. // ->where('a.cMaker',$user['username'])
  63. // ->where('a.iverifystateex',0)
  64. ->where('cCode', $data['order_number'])
  65. ->select('a.cMaker as crt_name', DB::raw("COALESCE(c.cPersonName, '') as purchase_name"),'a.cBusType as business_type','a.cCode as order_number',DB::raw("CONVERT(varchar(10), a.dDate, 120) as order_date"),'a.ID as id')
  66. ->first();
  67. if(empty($order)) return [false, '采购请购单不存在'];
  68. $order = (array) $order;
  69. $detail = $this->databaseService->table('PU_AppVouchs as a')
  70. ->leftJoin('Inventory as b', 'b.cInvCode', 'a.cInvCode')
  71. ->leftJoin('ComputationUnit as c', 'c.cComunitCode', 'b.cComUnitCode')
  72. ->where('a.ID', $order['id'])
  73. ->select('b.cInvName as product_title','b.cInvStd as product_size','b.cInvCode as product_code','b.cCurrencyName as product_ty','c.cComUnitName as unit_title',DB::raw("CONVERT(varchar(10), a.dRequirDate, 120) as need_arrived_date"),DB::raw("LTRIM(STR(a.fQuantity, 20, 2)) as quantity"))
  74. ->get();
  75. // 转为数组的数组
  76. $detail = array_map(function ($item) {
  77. return (array) $item;
  78. }, $detail->toArray());
  79. foreach ($detail as $key => $value){
  80. if($user['zt'] == 1){
  81. if(! empty($value['product_ty'])) $detail[$key]['product_title'] = $value['product_title'] . '|' . $value['product_ty'];
  82. }else{
  83. if(! empty($value['product_size'])) $detail[$key]['product_title'] = $value['product_title'] . '|' . $value['product_size'];
  84. }
  85. }
  86. $order['detail'] = $detail;
  87. return [true, $order];
  88. }
  89. public function purchaseOrder($data, $user){
  90. $qx = $user['qx'];
  91. $order_date = $data['order_date'] ?? [];
  92. $order_date = array_filter($order_date);
  93. $order_number = $data['order_number'] ?? "";
  94. $model = $this->databaseService->table('PO_Pomain as a')
  95. ->leftJoin('Vendor as c', 'c.cVenCode', 'a.cVenCode')
  96. ->when(empty($qx), function ($query) use($user){
  97. return $query->where('a.cMaker',$user['username']);
  98. })
  99. ->when(! empty($order_number), function ($query) use($order_number){
  100. return $query->where('a.cPOID','LIKE', '%'.$order_number.'%');
  101. })
  102. ->when(! empty($order_date), function ($query) use($order_date){
  103. $start = date('Y-m-d H:i:s.000', $order_date[0]);
  104. $end = date('Y-m-d H:i:s.000', $order_date[1]);
  105. return $query->whereBetween('a.dPODate', [$start, $end]);
  106. })
  107. ->where(function ($query) {
  108. $query->where('a.iverifystateex', 0)
  109. ->OrwhereNull('a.iverifystateex');
  110. })
  111. ->select('a.cMaker as crt_name', 'a.cBusType as business_type','a.cPOID as order_number',DB::raw("CONVERT(varchar(10), a.dPODate, 120) as order_date"),'c.cVenName as supplier_title')
  112. ->orderBy('a.POID','desc');
  113. $list = $this->limit($model,'',$data);
  114. $list = $this->fillAll($list, 1);
  115. return [true , $list];
  116. }
  117. public function purchaseOrderDetail($data, $user){
  118. if(empty($data['order_number'])) return [false, '采购单号不能为空'];
  119. $order = $this->databaseService->table('PO_Pomain as a')
  120. ->leftJoin('Vendor as c', 'c.cVenCode', 'a.cVenCode')
  121. ->where('cPOID', $data['order_number'])
  122. // ->where('a.cMaker',$user['username'])
  123. // ->where('a.iverifystateex',0)
  124. ->select('a.cMaker as crt_name', 'a.cBusType as business_type','a.cPOID as order_number',DB::raw("CONVERT(varchar(10), a.dPODate, 120) as order_date"),'c.cVenName as supplier_title','a.POID as id')
  125. ->first();
  126. if(empty($order)) return [false, '采购单不存在'];
  127. $order = (array) $order;
  128. $detail = $this->databaseService->table('PO_Podetails as a')
  129. ->leftJoin('Inventory as b', 'b.cInvCode', 'a.cInvCode')
  130. ->leftJoin('ComputationUnit as c', 'c.cComunitCode', 'b.cComUnitCode')
  131. ->where('a.POID', $order['id'])
  132. ->select('b.cInvName as product_title','b.cInvStd as product_size','b.cInvCode as product_code','b.cCurrencyName as product_ty','c.cComUnitName as unit_title',DB::raw("LTRIM(STR(a.iQuantity, 20, 2)) as quantity"),DB::raw("LTRIM(STR(a.iSum, 20, 2)) as amount"))
  133. ->get();
  134. // 转为数组的数组
  135. $detail = array_map(function ($item) {
  136. return (array) $item;
  137. }, $detail->toArray());
  138. foreach ($detail as $key => $value){
  139. if($user['zt'] == 1){
  140. if(! empty($value['product_ty'])) $detail[$key]['product_title'] = $value['product_title'] . '|' . $value['product_ty'];
  141. }else{
  142. if(! empty($value['product_size'])) $detail[$key]['product_title'] = $value['product_title'] . '|' . $value['product_size'];
  143. }
  144. }
  145. $order['detail'] = $detail;
  146. return [true, $order];
  147. }
  148. public function paymentOrder($data, $user){
  149. $qx = $user['qx'];
  150. $order_date = $data['order_date'] ?? [];
  151. $order_date = array_filter($order_date);
  152. $order_number = $data['order_number'] ?? "";
  153. $model = $this->databaseService->table('AP_ApplyPayVouch as a')
  154. ->leftJoin('Vendor as c', 'c.cVenCode', 'a.cDwCode')
  155. ->when(empty($qx), function ($query) use($user){
  156. return $query->where('a.cOperator',$user['username']);
  157. })
  158. ->when(! empty($order_number), function ($query) use($order_number){
  159. return $query->where('a.cVouchID','LIKE', '%'.$order_number.'%');
  160. })
  161. ->when(! empty($order_date), function ($query) use($order_date){
  162. $start = date('Y-m-d H:i:s.000', $order_date[0]);
  163. $end = date('Y-m-d H:i:s.000', $order_date[1]);
  164. return $query->whereBetween('a.dVouchDate', [$start, $end]);
  165. })
  166. ->whereNull('a.cCheckMan')
  167. ->select('a.cOperator as crt_name', 'c.cVenName as supplier_title','a.cVouchID as order_number',DB::raw("CONVERT(varchar(10), a.dVouchDate, 120) as order_date"))
  168. ->orderBy('a.PID','desc');
  169. $list = $this->limit($model,'',$data);
  170. $list = $this->fillAll($list, 3);
  171. return [true , $list];
  172. }
  173. public function paymentOrderDetail($data, $user){
  174. if(empty($data['order_number'])) return [false, '付款申请单号不能为空'];
  175. $order = $this->databaseService->table('AP_ApplyPayVouch as a')
  176. ->leftJoin('Vendor as c', 'c.cVenCode', 'a.cDwCode')
  177. // ->where('a.cOperator',$user['username'])
  178. // ->whereNull('a.cCheckMan')
  179. ->where('cVouchID', $data['order_number'])
  180. ->select('a.cOperator as crt_name', 'c.cVenName as supplier_title','a.cVouchID as order_number',DB::raw("CONVERT(varchar(10), a.dVouchDate, 120) as order_date"),'a.PID as id')
  181. ->first();
  182. if(empty($order)) return [false, '付款单不存在'];
  183. $order = (array) $order;
  184. $detail = $this->databaseService->table('AP_ApplyPayVouchs as a')
  185. ->leftJoin('Inventory as b', 'b.cInvCode', 'a.cInvCode')
  186. ->leftJoin('ComputationUnit as c', 'c.cComunitCode', 'b.cComUnitCode')
  187. ->where('a.PID', $order['id'])
  188. ->select('a.cSource as source','a.cCoVouchID as source_order_number','b.cInvName as product_title','b.cInvStd as product_size','b.cCurrencyName as product_ty','c.cComUnitName as unit_title',DB::raw("LTRIM(STR(a.iApplyAmt_s, 20, 2)) as number"),
  189. DB::raw("LTRIM(STR(a.iApplyAmt_f, 20, 2)) as amount"))
  190. ->get();
  191. // 转为数组的数组
  192. $detail = array_map(function ($item) {
  193. return (array) $item;
  194. }, $detail->toArray());
  195. foreach ($detail as $key => $value){
  196. if($user['zt'] == 1){
  197. if(! empty($value['product_ty'])) $detail[$key]['product_title'] = $value['product_title'] . '|' . $value['product_ty'];
  198. }else{
  199. if(! empty($value['product_size'])) $detail[$key]['product_title'] = $value['product_title'] . '|' . $value['product_size'];
  200. }
  201. }
  202. // 使用 array_column 提取所有 amount 并求和
  203. $order['total_amount'] = number_format(array_sum(array_column($detail, 'amount')), 2, '.', '');
  204. $order['detail'] = $detail;
  205. return [true, $order];
  206. }
  207. public function getOrderDetails($data,$user){
  208. $type = $data['type'];
  209. if($type == 1){
  210. // 采购单
  211. [$success, $order] = $this->purchaseOrderDetail($data,$user);
  212. }elseif ($type == 2){
  213. // 请购单
  214. [$success, $order] = $this->purchaseRequisitionDetail($data,$user);
  215. }else{
  216. // 付款申请单
  217. [$success, $order] = $this->paymentOrderDetail($data,$user);
  218. }
  219. return [$success, $order];
  220. }
  221. private function fillAll($list, $type){
  222. if(empty($list['data'])) return $list;
  223. $map = Record::where('del_time',0)
  224. ->where('type', $type)
  225. ->whereIn('order_number',array_column($list['data'],'order_number'))
  226. ->pluck('id','order_number')
  227. ->toArray();
  228. foreach ($list['data'] as $key => $value){
  229. $is_create = 0;
  230. if(isset($map[$value->order_number])) $is_create = 1;
  231. $list['data'][$key]->is_create = $is_create;
  232. }
  233. return $list;
  234. }
  235. }