StationTaskCommodityService.php 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <?php
  2. namespace App\Services;
  3. use App\Batch;
  4. use App\MaterialBoxCommodity;
  5. use App\OrderCommodity;
  6. use App\StationTaskCommodity;
  7. use App\StationTaskMaterialBox;
  8. use Illuminate\Support\Collection;
  9. use Illuminate\Support\Facades\Cache;
  10. use App\Traits\ServiceAppAop;
  11. use Illuminate\Support\Facades\DB;
  12. class StationTaskCommodityService
  13. {
  14. use ServiceAppAop;
  15. protected $modelClass=StationTaskCommodity::class;
  16. /** @var StationService $stationService */
  17. private $stationService;
  18. /** @var StationTypeService $stationTypeService */
  19. private $stationTypeService;
  20. /** @var StationTaskService $stationTaskService */
  21. private $stationTaskService;
  22. /** @var MaterialBoxService $materialBoxService */
  23. private $materialBoxService;
  24. /** @var StationTaskBatchService $stationTaskBatchService */
  25. private $stationTaskBatchService;
  26. public function __construct(){
  27. $this->stationService=null;
  28. $this->stationTypeService=null;
  29. $this->stationTaskService=null;
  30. $this->materialBoxService=null;
  31. }
  32. function get(array $kvPairs){
  33. ksort($kvPairs);
  34. return Cache::remember('stationTaskChild_'.md5(json_encode($kvPairs)), config('cache.expirations.oftenChange'), function ()use($kvPairs) {
  35. $query = StationTaskCommodity::query();
  36. foreach ($kvPairs as $column => $value){
  37. if (is_array($value))$query->whereIn($column,$value);
  38. else $query->where($column,$value);
  39. }
  40. return $query->get();
  41. });
  42. }
  43. function createByBatches(Collection $batches,Collection $stationTasks_toAttach): Collection
  44. {
  45. $this->instant($this->stationTaskService,'StationTaskService');
  46. $stationTaskCommodities_lists_ByBatch=new Collection();
  47. $stationTaskCommodities=new Collection();
  48. foreach ($batches as $batch){
  49. $taskCommodities = $this->createByBatch($batch);
  50. $stationTaskCommodities= $stationTaskCommodities->merge($taskCommodities);
  51. $stationTaskCommodities_lists_ByBatch->push($taskCommodities);
  52. }
  53. // $stationTaskCommodities=$this->getAndAttachIds($stationTaskCommodities);
  54. $this->stationTaskService->registerSubTasks(
  55. $stationTasks_toAttach,
  56. $stationTaskCommodities_lists_ByBatch);
  57. return $stationTaskCommodities;
  58. }
  59. // function getAndAttachIds($taskCommodities): Collection
  60. // {
  61. // $md5=is_array($taskCommodities)
  62. // ?$md5=md5(json_encode($taskCommodities)):null;
  63. //
  64. // return Cache::remember(
  65. // 'StationTaskCommodity_'.$md5??md5(json_encode($taskCommodities->toArray()))
  66. // ,config('cache.expirations.rarelyChange')
  67. // ,function()use($taskCommodities){
  68. // $a=data_get($taskCommodities,'*.status');
  69. // $a2=data_get($taskCommodities,'*.station_task_batch_id');
  70. // $a3=data_get($taskCommodities,'*.commodity_id');
  71. // $a4=StationTaskCommodity::query()
  72. // ->whereIn('status',data_get($taskCommodities,'*.status'))
  73. // ->whereIn('station_task_batch_id',data_get($taskCommodities,'*.station_task_batch_id'))
  74. // ->whereIn('commodity_id',data_get($taskCommodities,'*.commodity_id'))
  75. // ->get();
  76. // $a5=1;
  77. // return StationTaskCommodity::query()
  78. // ->whereIn('status',data_get($taskCommodities,'*.status'))
  79. // ->whereIn('station_task_batch_id',data_get($taskCommodities,'*.station_task_batch_id'))
  80. // ->whereIn('commodity_id',data_get($taskCommodities,'*.commodity_id'))
  81. // ->get();
  82. // });
  83. // }
  84. function createByBatch(Batch $batch): Collection
  85. {
  86. $this->instant($this->stationTypeService,'StationTypeService');
  87. $this->instant($this->stationService,'StationService');
  88. $this->instant($this->materialBoxService,'MaterialBoxService');
  89. $this->instant($this->stationTaskBatchService,'StationTaskBatchService');
  90. $stationTaskCommodities_toCreate=new Collection();
  91. $order_ids=data_get($batch['orders'],'*.id');
  92. $orderCommodities=OrderCommodity::query()->with('orderBin')->whereIn('order_id',$order_ids)->get();
  93. $stationTaskBatch=$this->stationTaskBatchService->get(['batch_id'=>$batch['id']])->first();
  94. foreach ($orderCommodities as $orderCommodity){
  95. $stationType=$this->stationTypeService->getForCommodity();
  96. $station=$this->stationService->getStation_byType($stationType['name']);
  97. $materialBox=$this->materialBoxService->firstOrCreate(['code' => $orderCommodity['location']]);
  98. $stationTaskMaterialBoxId=StationTaskMaterialBox::query()->where('station_task_batch_id',$stationTaskBatch['id'])->where('material_box_id',$materialBox['id'])->get('id')->first()['id']??null;
  99. $stationTaskCommodities_toCreate->push(
  100. new StationTaskCommodity([
  101. 'station_id'=>$station['id'],
  102. // 'material_box_id'=>$materialBox['id'],
  103. 'material_box_position'=>$orderCommodity['material_box_position'],
  104. 'commodity_id'=>$orderCommodity['commodity_id'],
  105. 'amount'=>$orderCommodity['amount'],
  106. 'bin_number'=>$orderCommodity['orderBin']['number']??'',
  107. 'order_id'=>$orderCommodity['order_id'],
  108. 'station_task_batch_id'=>$stationTaskBatch['id'],
  109. 'station_task_material_box_id'=>$stationTaskMaterialBoxId,
  110. 'status'=>'待处理',
  111. ])
  112. );
  113. }
  114. return $this->insert($stationTaskCommodities_toCreate->toArray(),true);
  115. }
  116. function markProcessing($stationTaskCommodity_orCollection)
  117. {
  118. $stationTaskCommodities =
  119. (function()use($stationTaskCommodity_orCollection){
  120. if (get_class($stationTaskCommodity_orCollection)==StationTaskCommodity::class){
  121. return collect([$stationTaskCommodity_orCollection]);
  122. }
  123. return collect($stationTaskCommodity_orCollection);
  124. })();
  125. $stationTaskCommodities_grouped=
  126. ($按时间从前往后排出顺序=function ()use(&$stationTaskCommodities){
  127. return $stationTaskCommodities
  128. ->sortBy('id')
  129. ->groupBy('station_task_batch_id');
  130. })();
  131. $stationTaskCommodities_grouped->each(function(&$groupByBatch){
  132. ($标记本波次内是处理中或处理队列=function()use(&$groupByBatch){
  133. $stationId=$groupByBatch[0]['station_id'];
  134. $processingIds=data_get($this->getProcessings_byStationId($stationId),'*.id')??[];
  135. $groupByBatch->each(function(&$stationTaskCommodity)use($processingIds){
  136. if(in_array($stationTaskCommodity['id'],$processingIds))
  137. $stationTaskCommodity['status']='处理中';
  138. else
  139. $stationTaskCommodity['status']='处理队列';
  140. });
  141. if(count($processingIds)==0){
  142. foreach($groupByBatch as &$stationTaskCommodity){
  143. if($stationTaskCommodity['station_task_material_box_id']==$groupByBatch[0]['station_task_material_box_id']){
  144. $stationTaskCommodity['status']='处理中';
  145. }
  146. }
  147. }
  148. })();
  149. });
  150. ($持久化处理队列的记录=function()use(&$stationTaskCommodities_grouped){
  151. $toArray = $stationTaskCommodities_grouped->collapse();
  152. $toQueue=$toArray->where('status','处理队列');
  153. $toProcess=$toArray->where('status','处理中');
  154. $ids_toQueue_toUpdate = data_get($toQueue, '*.id');
  155. if(count($ids_toQueue_toUpdate))
  156. StationTaskCommodity::query()->whereIn('id',$ids_toQueue_toUpdate)->update(['status'=>'处理队列']);
  157. $ids_toProcess_toUpdate = data_get($toProcess, '*.id');
  158. if(count($ids_toProcess_toUpdate))
  159. StationTaskCommodity::query()->whereIn('id',$ids_toProcess_toUpdate)->update(['status'=>'处理中']);
  160. })();
  161. }
  162. function getProcessings_byStationId($stationTaskBatch_id)
  163. {
  164. //这里不好用缓存,因为更新会非常快
  165. return StationTaskCommodity::query()
  166. ->where('station_id',$stationTaskBatch_id)
  167. ->where('status','处理中')
  168. ->get();
  169. }
  170. function markProcessed(Collection $stationTaskCommodities){
  171. StationTaskCommodity::query()
  172. ->whereIn('id',data_get($stationTaskCommodities,'*.id')??[])
  173. ->update(['status'=>'完成']);
  174. $stationTaskMaterialBoxes=StationTaskMaterialBox::query()
  175. ->whereIn('id', data_get($stationTaskCommodities, '*.station_task_material_box_id') ?? [])
  176. ->get('material_box_id');
  177. $boxes = data_get($stationTaskMaterialBoxes,'*.material_box_id')??[];
  178. $commodities = data_get($stationTaskCommodities,'*.commodity_id')??[];
  179. $map = [];
  180. foreach ($stationTaskCommodities as $commodity){
  181. $map[$commodity->material_box_id."-".$commodity->commodity_id] = $commodity->amount;
  182. }
  183. MaterialBoxCommodity::query()->whereIn('commodity_id',$commodities)
  184. ->whereIn('material_box_id',$boxes)->lockForUpdate()
  185. ->get()->each(function ($boxC)use($map){
  186. $key = $boxC->material_box_id."-".$boxC->commodity_id;
  187. if (!isset($map[$key]))return false;
  188. if ($boxC->amount>$map[$key])$boxC->update(["amount"=>DB::raw("amount-{$map[$key]}")]);
  189. if ($boxC->amount==$map[$key])$boxC->delete();
  190. return true;
  191. });
  192. }
  193. }