FacilitatorController.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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\FacilitatorRequest;
  8. use App\Services\common\ExportService;
  9. use Illuminate\Database\Eloquent\Collection;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Support\Facades\Gate;
  12. class FacilitatorController extends Controller
  13. {
  14. use AsyncResponse;
  15. // 服务商基础设置
  16. public function index(Request $request)
  17. {
  18. if (!Gate::allows('装卸队-查询')) {
  19. return redirect(url('/'));
  20. }
  21. $facilitators = Facilitator::query()->select(['id', 'name', 'created_at'])->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  22. return view('maintenance.facilitator.index', compact('facilitators'));
  23. }
  24. // 服务商对账单
  25. public function statementIndex(Request $request, DischargeTaskFilters $filters)
  26. {
  27. if (!Gate::allows('装卸队-对账单-查询')) {
  28. return redirect(url('/'));
  29. }
  30. $facilitatorStatements = DischargeTask::query()
  31. ->filter($filters)
  32. ->with('facilitator')
  33. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  34. ->whereNotNull('facilitator_id')
  35. ->where('facilitator_id','!=','0')
  36. ->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  37. $facilitators = Facilitator::query()->get();
  38. return view('personnel.discharge.facilitator.index', compact('facilitatorStatements', 'facilitators'));
  39. }
  40. public function create()
  41. {
  42. }
  43. public function store(Request $request)
  44. {
  45. }
  46. public function storeApi(FacilitatorRequest $request)
  47. {
  48. $this->gate('装卸队-创建');
  49. $facilitator = Facilitator::query()->create($request->all());
  50. $this->success($facilitator);
  51. }
  52. public function show(Facilitator $facilitator)
  53. {
  54. }
  55. public function edit(Facilitator $facilitator)
  56. {
  57. }
  58. public function update(Request $request, Facilitator $facilitator)
  59. {
  60. }
  61. public function updateApi(FacilitatorRequest $request)
  62. {
  63. $this->gate('装卸队-编辑');
  64. $facilitator = Facilitator::query()->where('id', $request['id'])->update($request->only(['name']));
  65. if ($facilitator) $this->success(Facilitator::query()->find($request['id']));
  66. $this->error('更新失败');
  67. }
  68. public function destroy(Facilitator $facilitator)
  69. {
  70. }
  71. public function destroyApi(FacilitatorRequest $request)
  72. {
  73. $this->gate('装卸队-删除');
  74. $count = Facilitator::query()->where('id', $request['id'])->delete();
  75. if ($count > 0) $this->success('删除成功');
  76. $this->error('删除失败');
  77. }
  78. // 对账单导出
  79. public function exportStatement(Request $request, DischargeTaskFilters $filters)
  80. {
  81. $this->gate('装卸队-对账单-查询');
  82. /** @var Collection $facilitatorStatements */
  83. $facilitatorStatements = DischargeTask::query()
  84. ->filter($filters)
  85. ->with('facilitator')
  86. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  87. ->whereNotNull('facilitator_id')
  88. ->where('facilitator_id','!=','0')
  89. ->orderByDesc('id')->get();
  90. $row = ['日期', '装卸队', '数量', '单位', '单价', '总金额合计'];
  91. $json = app('DischargeTaskService')->getFacilitatorStatementsJson($facilitatorStatements);
  92. return app(ExportService::class)->json($row, $json, "装卸队对账单报表");
  93. }
  94. }