StationTaskCommodityService.php 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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 Illuminate\Support\Collection;
  10. use Illuminate\Support\Facades\Cache;
  11. use App\Traits\ServiceAppAop;
  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. public function __construct(){
  25. $this->stationService=null;
  26. $this->stationTypeService=null;
  27. $this->stationTaskService=null;
  28. $this->materialBoxService=null;
  29. }
  30. function get(array $kvPairs){
  31. ksort($kvPairs);
  32. return Cache::remember('stationTaskChild_'.md5(json_encode($kvPairs)), config('cache.expirations.oftenChange'), function ()use($kvPairs) {
  33. $query = StationTaskCommodity::query();
  34. foreach ($kvPairs as $column => $value){
  35. if (is_array($value))$query->whereIn($column,$value);
  36. else $query->where($column,$value);
  37. }
  38. return $query->get();
  39. });
  40. }
  41. function createByBatches(Collection $batches,Collection $stationTasks_toAttach): Collection
  42. {
  43. $this->instant($this->stationTaskService,'StationTaskService');
  44. $stationTaskCommodities_listByBatch=new Collection();
  45. $stationTaskCommodities=new Collection();
  46. foreach ($batches as $batch){
  47. $taskCommodities = $this->createByBatch($batch);
  48. $stationTaskCommodities= $stationTaskCommodities->merge($taskCommodities);
  49. $stationTaskCommodities_listByBatch->push($taskCommodities);
  50. }
  51. // $stationTaskCommodities=$this->getAndAttachIds($stationTaskCommodities);
  52. $this->stationTaskService->registerSubTasks(
  53. $stationTasks_toAttach,
  54. $stationTaskCommodities_listByBatch);
  55. return $stationTaskCommodities;
  56. }
  57. // function getAndAttachIds($taskCommodities): Collection
  58. // {
  59. // $md5=is_array($taskCommodities)
  60. // ?$md5=md5(json_encode($taskCommodities)):null;
  61. //
  62. // return Cache::remember(
  63. // 'StationTaskCommodity_'.$md5??md5(json_encode($taskCommodities->toArray()))
  64. // ,config('cache.expirations.rarelyChange')
  65. // ,function()use($taskCommodities){
  66. // $a=data_get($taskCommodities,'*.status');
  67. // $a2=data_get($taskCommodities,'*.station_task_batch_id');
  68. // $a3=data_get($taskCommodities,'*.commodity_id');
  69. // $a4=StationTaskCommodity::query()
  70. // ->whereIn('status',data_get($taskCommodities,'*.status'))
  71. // ->whereIn('station_task_batch_id',data_get($taskCommodities,'*.station_task_batch_id'))
  72. // ->whereIn('commodity_id',data_get($taskCommodities,'*.commodity_id'))
  73. // ->get();
  74. // $a5=1;
  75. // return StationTaskCommodity::query()
  76. // ->whereIn('status',data_get($taskCommodities,'*.status'))
  77. // ->whereIn('station_task_batch_id',data_get($taskCommodities,'*.station_task_batch_id'))
  78. // ->whereIn('commodity_id',data_get($taskCommodities,'*.commodity_id'))
  79. // ->get();
  80. // });
  81. // }
  82. function createByBatch(Batch $batch): Collection
  83. {
  84. $this->instant($this->stationTypeService,'StationTypeService');
  85. $this->instant($this->stationService,'StationService');
  86. $this->instant($this->materialBoxService,'MaterialBoxService');
  87. $stationTaskCommodities_toCreate=new Collection();
  88. $order_ids=data_get($batch['orders'],'*.id');
  89. $orderCommodities=OrderCommodity::query()->with('orderBin')->whereIn('order_id',$order_ids)->get();
  90. foreach ($orderCommodities as $orderCommodity){
  91. $stationType=$this->stationTypeService->getForCommodity();
  92. $station=$this->stationService->getStation_byType($stationType['name']);
  93. $materialBox=$this->materialBoxService->firstOrCreate(['code' => $orderCommodity['location']]);
  94. $stationTaskMaterialBoxId=StationTaskMaterialBox::query()->where('station_task_batch_id',$batch['id'])->where('material_box_id',$materialBox['id'])->get('id');
  95. $stationTaskCommodities_toCreate->push(
  96. new StationTaskCommodity([
  97. 'station_id'=>$station['id'],
  98. 'material_box_id'=>$materialBox['id'],
  99. 'commodity_id'=>$orderCommodity['commodity_id'],
  100. 'amount'=>$orderCommodity['amount'],
  101. 'bin_number'=>$orderCommodity['orderBin']['number']??'',
  102. 'order_id'=>$orderCommodity['order_id'],
  103. 'station_task_batch_id'=>$batch['id'],
  104. 'station_task_material_box_id'=>$stationTaskMaterialBoxId,
  105. 'status'=>'待处理',
  106. ])
  107. );
  108. }
  109. return $this->insert($stationTaskCommodities_toCreate->toArray(),true);
  110. }
  111. function markProcessing($stationTaskCommodity_orCollection)
  112. {
  113. $stationTaskCommodities =
  114. (function()use($stationTaskCommodity_orCollection){
  115. if (get_class($stationTaskCommodity_orCollection)==StationTaskCommodity::class){
  116. return collect([$stationTaskCommodity_orCollection]);
  117. }
  118. return collect($stationTaskCommodity_orCollection);
  119. })();
  120. $stationTaskCommodities_grouped=
  121. ($按时间从前往后排出顺序=function ()use(&$stationTaskCommodities){
  122. return $stationTaskCommodities
  123. ->sortBy('id')
  124. ->groupBy('station_task_batch_id');
  125. })();
  126. $stationTaskCommodities_grouped->each(function(&$groupByBatch){
  127. ($标记本波次内是处理中或处理队列=function()use(&$groupByBatch){
  128. $taskBatchId=$groupByBatch[0]['station_task_batch_id'];
  129. $processing=$this->getProcessing_byTaskBatch($taskBatchId);
  130. if(!$processing
  131. || $processing['station_task_batch_id']==$taskBatchId ){
  132. $status='处理中';
  133. }else{
  134. $status='处理队列';
  135. }
  136. $groupByBatch->each(function(&$stationTaskCommodity)use($status){
  137. $stationTaskCommodity['status']=$status;
  138. });
  139. })();
  140. });
  141. ($持久化处理队列的记录=function()use(&$stationTaskCommodities_grouped){
  142. $toArray = $stationTaskCommodities_grouped->collapse();
  143. $toQueue=$toArray->where('status','处理队列');
  144. $toProcess=$toArray->where('status','处理中');
  145. $ids_toQueue_toUpdate = data_get($toQueue, '*.id');
  146. if(count($ids_toQueue_toUpdate))
  147. StationTaskCommodity::query()->where('id',$ids_toQueue_toUpdate)->update(['status'=>'处理队列']);
  148. $ids_toProcess_toUpdate = data_get($toProcess, '*.id');
  149. if(count($ids_toProcess_toUpdate))
  150. StationTaskCommodity::query()->where('id',$ids_toProcess_toUpdate)->update(['status'=>'处理中']);
  151. })();
  152. }
  153. function getProcessing_byTaskBatch($stationTaskBatch_id)
  154. {
  155. //这里不能用缓存,因为更新会非常快
  156. return StationTaskCommodity::query()
  157. ->where('station_task_batch_id',$stationTaskBatch_id)
  158. ->where('status','处理中')
  159. ->first();
  160. }
  161. function markProcessed(Collection $stationTaskCommodities){
  162. StationTaskCommodity::query()
  163. ->whereIn('id',data_get($stationTaskCommodities,'*.id'))
  164. ->update(['status'=>'完成']);
  165. }
  166. }