DischargeTaskController.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Components\AsyncResponse;
  4. use App\Facilitator;
  5. use App\DischargeTask;
  6. use App\Filters\DischargeTaskFilters;
  7. use App\Http\Requests\DischargeTask\DischargeTaskRequest;
  8. use App\Imports\CommodityImport;
  9. use App\Imports\DischargeTaskImport;
  10. use App\Services\common\ExportService;
  11. use App\Services\OwnerService;
  12. use App\Warehouse;
  13. use Carbon\Carbon;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Support\Facades\Cache;
  16. use Illuminate\Support\Facades\Gate;
  17. use Maatwebsite\Excel\Facades\Excel;
  18. use function Sodium\compare;
  19. class DischargeTaskController extends Controller
  20. {
  21. use AsyncResponse;
  22. public function index(Request $request, DischargeTaskFilters $filters)
  23. {
  24. if (!Gate::allows('人事管理-卸货-查询')) {
  25. return redirect(url('/'));
  26. }
  27. $dischargeTasks = DischargeTask::query()->with(['facilitator', 'owner','warehouse'])->filter($filters)->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  28. $owners = app(OwnerService::class)->getAuthorizedOwners();
  29. $warehouses = Warehouse::query()->select('id','name')->get();
  30. $facilitators = Facilitator::query()->select('name', 'id')->get();
  31. return view('personnel.discharge.task.index', compact('dischargeTasks', 'owners', 'facilitators','warehouses'));
  32. }
  33. // 结算报表
  34. public function statementIndex(Request $request, DischargeTaskFilters $filters)
  35. {
  36. if (!Gate::allows('人事管理-卸货-结算报表-查询')) {
  37. return redirect(url('/'));
  38. }
  39. $dischargeStatements = DischargeTask::query()->with('facilitator')->filter($filters)->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  40. $owners = app(OwnerService::class)->getAuthorizedOwners();
  41. $facilitators = Facilitator::query()->select('name', 'id')->get();
  42. return view('personnel.discharge.statement.index', compact('dischargeStatements', 'owners', 'facilitators'));
  43. }
  44. // async 创建
  45. public function storeApi(DischargeTaskRequest $request)
  46. {
  47. $this->gate('人事管理-卸货-创建');
  48. $result = app('DischargeTaskService')->createTask($request->all());
  49. if ($result['success']) $this->success($result['data']);
  50. $this->error('任务创建异常,刷新当前页面重试');
  51. }
  52. // async 编辑
  53. public function updateApi(DischargeTaskRequest $request)
  54. {
  55. $this->gate('人事管理-卸货-编辑');
  56. $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
  57. $result = app('DischargeTaskService')->updateDischargeTask($dischargeTask, $request->all());
  58. if ($result['success']) $this->success($result['data']);
  59. else $this->error($result['message'] ?? '操作异常,请刷新页面重试');
  60. }
  61. // 修改任务服务商
  62. public function updateTaskFacilitatorApi(DischargeTaskRequest $request)
  63. {
  64. $this->gate('人事管理-卸货-编辑');
  65. /** @var DischargeTask $dischargeTask */
  66. $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
  67. if (!$dischargeTask) $this->error('没有找对应的卸货任务');
  68. $result = app('DischargeTaskService')->updateTaskFacilitator($dischargeTask, $request->all());
  69. if ($result['success']) $this->success($result['data']);
  70. else $this->error($result['message'] ?? '操作异常,请刷新页面重试');
  71. }
  72. // async 删除
  73. public function destroyApi(DischargeTaskRequest $request)
  74. {
  75. $this->gate('人事管理-卸货-删除');
  76. /** @var DischargeTask $dischargeTask */
  77. $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
  78. $result = app('DischargeTaskService')->deleteDischargeTask($dischargeTask);
  79. if ($result['success']) $this->success();
  80. else $this->error($result['message']);
  81. }
  82. // 执行任务
  83. public function executingTaskApi(DischargeTaskRequest $request)
  84. {
  85. $this->gate('人事管理-卸货-编辑');
  86. $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
  87. $result = app('DischargeTaskService')->updateTaskProvider($dischargeTask, $request->all());
  88. if ($result['success']) $this->success($result['data']);
  89. $this->error($result['message'] ?? '操作异常,请刷新页面重试');
  90. }
  91. // 卸货任务下载
  92. public function export(Request $request, DischargeTaskFilters $filters)
  93. {
  94. $this->gate('人事管理-卸货-查询');
  95. $dischargeTasks = DischargeTask::query()->with(['Facilitator', 'owner'])->filter($filters)->orderByDesc('id')->get();
  96. $row = ['日期', '客户名称', '作业名称', '入库单号', '数量', '单位', '单价', '收费', '状态', '备注'];
  97. $json = app('DischargeTaskService')->getJson($dischargeTasks);
  98. return app(ExportService::class)->json($row, $json, "卸货任务");
  99. }
  100. // 结算报表下载
  101. public function exportStatements(Request $request, DischargeTaskFilters $filters)
  102. {
  103. $this->gate('人事管理-卸货-结算报表-查询');
  104. $dischargeTasks = DischargeTask::query()->with(['facilitator', 'owner','warehouse'])->filter($filters)->orderByDesc('id')->get();
  105. $row = ['日期', '客户名称','仓库', '作业名称', '入库单号', '数量', '单位', '收入单价', '收入合计', '装卸队', '数量', '单位', '支出单价', '支出合计', '状态', '收入备注', '支出备注'];
  106. $json = app('DischargeTaskService')->getStatementsJson($dischargeTasks);
  107. return app(ExportService::class)->json($row, $json, "卸货结算报表");
  108. }
  109. // 回执单
  110. public function receipt(Request $request)
  111. {
  112. $task = DischargeTask::query()->with(['facilitator', 'owner','warehouse'])->where('id' , $request['id'])->first();
  113. $task->type = DischargeTask::types[$task->type];
  114. return view('personnel.discharge.task.receipt',compact('task'));
  115. }
  116. public function importApi(Request $request): array
  117. {
  118. $extension=$request->file()['file']->getClientOriginalExtension();
  119. $extension[0] = strtoupper($extension[0]);
  120. try {
  121. Excel::import(new DischargeTaskImport(), $request->file()['file']->path(), null, $extension);
  122. } catch (\Exception $e) {
  123. dd($e->getMessage());
  124. return ['success'=>false,'message' => ['请检查导入文件是否符合要求']];
  125. }
  126. if(Cache::has('exception')){
  127. return ['success' => false,'errors' => Cache::get('exception')];
  128. }
  129. return ['success' => true];
  130. }
  131. public function show(DischargeTask $dischargeTask)
  132. {
  133. }
  134. public function edit(DischargeTask $dischargeTask)
  135. {
  136. }
  137. public function update(Request $request, DischargeTask $dischargeTask)
  138. {
  139. }
  140. public function store(Request $request)
  141. {
  142. }
  143. public function create()
  144. {
  145. }
  146. public function destroy(DischargeTask $dischargeTask)
  147. {
  148. }
  149. }