StationTaskCommodityService.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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 Illuminate\Support\Collection;
  9. use Illuminate\Support\Facades\Cache;
  10. use App\Traits\ServiceAppAop;
  11. class StationTaskCommodityService
  12. {
  13. use ServiceAppAop;
  14. protected $modelClass=StationTaskCommodity::class;
  15. /** @var StationService $stationService */
  16. private $stationService;
  17. /** @var StationTypeService $stationTypeService */
  18. private $stationTypeService;
  19. /** @var StationTaskService $stationTaskService */
  20. private $stationTaskService;
  21. /** @var MaterialBoxService $materialBoxService */
  22. private $materialBoxService;
  23. public function __construct(){
  24. $this->stationService=null;
  25. $this->stationTypeService=null;
  26. $this->stationTaskService=null;
  27. $this->materialBoxService=null;
  28. }
  29. function get(array $kvPairs){
  30. ksort($kvPairs);
  31. return Cache::remember('stationTaskChild_'.md5(json_encode($kvPairs)), config('cache.expirations.oftenChange'), function ()use($kvPairs) {
  32. $query = StationTaskCommodity::query();
  33. foreach ($kvPairs as $column => $value){
  34. if (is_array($value))$query->whereIn($column,$value);
  35. else $query->where($column,$value);
  36. }
  37. return $query->get();
  38. });
  39. }
  40. function createByBatches(Collection $batches,Collection $stationTasks_toAttach): Collection
  41. {
  42. $this->instant($this->stationTaskService,'StationTaskService');
  43. $stationTaskCommodities_listByBatch=new Collection();
  44. $stationTaskCommodities=new Collection();
  45. foreach ($batches as $batch){
  46. $taskCommodities = $this->createByBatch($batch);
  47. $stationTaskCommodities= $stationTaskCommodities->merge($taskCommodities);
  48. $stationTaskCommodities_listByBatch->push($taskCommodities);
  49. }
  50. // $stationTaskCommodities=$this->getAndAttachIds($stationTaskCommodities);
  51. $this->stationTaskService->registerSubTasks(
  52. $stationTasks_toAttach,
  53. $stationTaskCommodities_listByBatch);
  54. return $stationTaskCommodities;
  55. }
  56. // function getAndAttachIds($taskCommodities): Collection
  57. // {
  58. // $md5=is_array($taskCommodities)
  59. // ?$md5=md5(json_encode($taskCommodities)):null;
  60. //
  61. // return Cache::remember(
  62. // 'StationTaskCommodity_'.$md5??md5(json_encode($taskCommodities->toArray()))
  63. // ,config('cache.expirations.rarelyChange')
  64. // ,function()use($taskCommodities){
  65. // $a=data_get($taskCommodities,'*.status');
  66. // $a2=data_get($taskCommodities,'*.station_task_batch_id');
  67. // $a3=data_get($taskCommodities,'*.commodity_id');
  68. // $a4=StationTaskCommodity::query()
  69. // ->whereIn('status',data_get($taskCommodities,'*.status'))
  70. // ->whereIn('station_task_batch_id',data_get($taskCommodities,'*.station_task_batch_id'))
  71. // ->whereIn('commodity_id',data_get($taskCommodities,'*.commodity_id'))
  72. // ->get();
  73. // $a5=1;
  74. // return StationTaskCommodity::query()
  75. // ->whereIn('status',data_get($taskCommodities,'*.status'))
  76. // ->whereIn('station_task_batch_id',data_get($taskCommodities,'*.station_task_batch_id'))
  77. // ->whereIn('commodity_id',data_get($taskCommodities,'*.commodity_id'))
  78. // ->get();
  79. // });
  80. // }
  81. function createByBatch(Batch $batch): Collection
  82. {
  83. $this->instant($this->stationTypeService,'StationTypeService');
  84. $this->instant($this->stationService,'StationService');
  85. $this->instant($this->materialBoxService,'MaterialBoxService');
  86. $stationTaskCommodities_toCreate=new Collection();
  87. $order_ids=data_get($batch['orders'],'*.id');
  88. $orderCommodities=OrderCommodity::query()->with('orderBin')->whereIn('order_id',$order_ids)->get();
  89. foreach ($orderCommodities as $orderCommodity){
  90. $stationType=$this->stationTypeService->getForCommodity();
  91. $station=$this->stationService->getStation_byType($stationType['name']);
  92. $materialBox=$this->materialBoxService->firstOrCreate(['code' => $orderCommodity['location']]);
  93. $stationTaskCommodities_toCreate->push(
  94. new StationTaskCommodity([
  95. 'station_id'=>$station['id'],
  96. 'material_box_id'=>$materialBox['id'],
  97. 'commodity_id'=>$orderCommodity['commodity_id'],
  98. 'amount'=>$orderCommodity['amount'],
  99. 'bin_number'=>$orderCommodity['orderBin']['number']??'',
  100. 'order_id'=>$orderCommodity['order_id'],
  101. 'station_task_batch_id'=>$batch['id'],
  102. 'status'=>'待处理'
  103. ])
  104. );
  105. }
  106. return $this->insert($stationTaskCommodities_toCreate->toArray());
  107. }
  108. public function insert(array $taskCommodities): ?Collection
  109. {
  110. StationTaskCommodity::query()->insert($taskCommodities);
  111. return StationTaskCommodity::query()
  112. ->whereIn('status', data_get($taskCommodities, '*.status'))
  113. ->whereIn('station_task_batch_id', data_get($taskCommodities, '*.station_task_batch_id'))
  114. ->whereIn('commodity_id', data_get($taskCommodities, '*.commodity_id'))
  115. ->get();
  116. }
  117. function markProcessing($stationTaskCommodities)
  118. {
  119. if (get_class($stationTaskCommodities)==StationTaskCommodity::class){
  120. $stationTaskCommodities = collect($stationTaskCommodities);
  121. }
  122. StationTaskCommodity::query()
  123. ->whereIn('id',data_get($stationTaskCommodities,'*.id'))
  124. ->update(['status'=>'处理中']);
  125. $this->stationTaskService
  126. ->markProcessing_byId(
  127. data_get($stationTaskCommodities, '*.station_id')
  128. );
  129. }
  130. }