FacilitatorController.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  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 App\Services\FacilitatorService;
  10. use Illuminate\Database\Eloquent\Collection;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Support\Facades\Gate;
  13. class FacilitatorController extends Controller
  14. {
  15. use AsyncResponse;
  16. // 服务商基础设置
  17. public function index(Request $request)
  18. {
  19. if (!Gate::allows('装卸队-查询')) {
  20. return redirect(url('/'));
  21. }
  22. $facilitators = Facilitator::query()->select(['id', 'name', 'created_at'])->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  23. return view('maintenance.facilitator.index', compact('facilitators'));
  24. }
  25. // 装卸队对账单
  26. public function statementIndex(Request $request, DischargeTaskFilters $filters)
  27. {
  28. if (!Gate::allows('装卸队-对账单-查询')) {
  29. return redirect(url('/'));
  30. }
  31. $facilitatorStatements = DischargeTask::query()
  32. ->selectRaw('sum( discharge_tasks.expenditure_total_cost ) total_cost,' . ' count( 1 ) sum , ' . ' facilitators.name facilitators_name,' . ' facilitators.id id,' . " DATE_FORMAT( discharge_tasks.created_at, '%Y-%m' ) months ")
  33. ->leftJoin('facilitators', 'discharge_tasks.facilitator_id', '=', 'facilitators.id')
  34. ->filter($filters)
  35. ->groupBy('months', 'facilitator_id')
  36. ->orderByDesc('months')
  37. ->paginate($request['paginate'] ?? 50);
  38. $facilitators = Facilitator::query()->get();
  39. return view('personnel.discharge.facilitator.index', compact('facilitatorStatements', 'facilitators'));
  40. }
  41. // 装卸队查询页面
  42. public function facilitatorSearch(Request $request)
  43. {
  44. // $request['facilitator_id'] = $request['facilitator_id'];
  45. $filter = new DischargeTaskFilters($request);
  46. /** @var FacilitatorService $service */
  47. $service = app(FacilitatorService::class);
  48. $facilitatorStatements = $service->facilitatorStatement($filter);
  49. return view('personnel.discharge.facilitator.search', compact('facilitatorStatements'));
  50. }
  51. // 二维码
  52. public function getQrCode(Request $request)
  53. {
  54. /** @var FacilitatorService $service */
  55. $service = app(FacilitatorService::class);
  56. $qrCodeUrl = $service->getQrCode($request->all());
  57. $facilitator = Facilitator::query()->find($request['facilitator_id']);
  58. return view('personnel/discharge/facilitator/Qrcode',compact('qrCodeUrl','facilitator'));
  59. }
  60. public function gainStatementApi(Request $request,DischargeTaskFilters $filters)
  61. {
  62. $this->gate('装卸队-对账单-查询');
  63. $facilitatorStatements = DischargeTask::query()
  64. ->with('facilitator')
  65. ->filter($filters)
  66. ->get();
  67. $this->success($facilitatorStatements);
  68. }
  69. public function storeApi(FacilitatorRequest $request)
  70. {
  71. $this->gate('装卸队-创建');
  72. $facilitator = Facilitator::query()->create($request->all());
  73. $this->success($facilitator);
  74. }
  75. public function updateApi(FacilitatorRequest $request)
  76. {
  77. $this->gate('装卸队-编辑');
  78. $facilitator = Facilitator::query()->where('id', $request['id'])->update($request->only(['name']));
  79. if ($facilitator) $this->success(Facilitator::query()->find($request['id']));
  80. $this->error('更新失败');
  81. }
  82. public function destroyApi(FacilitatorRequest $request)
  83. {
  84. $this->gate('装卸队-删除');
  85. $count = Facilitator::query()->where('id', $request['id'])->delete();
  86. if ($count > 0) $this->success('删除成功');
  87. $this->error('删除失败');
  88. }
  89. // 对账单导出
  90. public function exportStatement(Request $request, DischargeTaskFilters $filters)
  91. {
  92. $this->gate('装卸队-对账单-查询');
  93. /** @var Collection $facilitatorStatements */
  94. $facilitatorStatements = DischargeTask::query()
  95. ->filter($filters)
  96. ->with('facilitator')
  97. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  98. ->whereNotNull('facilitator_id')
  99. ->where('facilitator_id', '!=', '0')
  100. ->orderByDesc('id')->get();
  101. $row = ['日期', '装卸队', '数量', '单位', '单价', '总金额合计'];
  102. $json = app('DischargeTaskService')->getFacilitatorStatementsJson($facilitatorStatements);
  103. return app(ExportService::class)->json($row, $json, "装卸队对账单报表");
  104. }
  105. public function create()
  106. {
  107. }
  108. public function store(Request $request)
  109. {
  110. }
  111. public function show(Facilitator $facilitator)
  112. {
  113. }
  114. public function edit(Facilitator $facilitator)
  115. {
  116. }
  117. public function update(Request $request, Facilitator $facilitator)
  118. {
  119. }
  120. public function destroy(Facilitator $facilitator)
  121. {
  122. }
  123. }