DischargeTaskController.php 8.0 KB

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