StationTaskCommodityService.php 10 KB

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