StationTaskCommodityService.php 4.8 KB

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