FacilitatorController.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  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 getQrCode(Request $request)
  43. {
  44. /** @var FacilitatorService $service */
  45. $service = app(FacilitatorService::class);
  46. $qrCodeUrl = $service->getQrCode($request->all());
  47. $facilitator = Facilitator::query()->find($request['facilitator_id']);
  48. return view('personnel/discharge/facilitator/Qrcode',compact('qrCodeUrl','facilitator'));
  49. }
  50. public function gainStatementApi(Request $request,DischargeTaskFilters $filters)
  51. {
  52. $this->gate('装卸队-对账单-查询');
  53. $facilitatorStatements = DischargeTask::query()
  54. ->with('facilitator')
  55. ->filter($filters)
  56. ->get();
  57. $this->success($facilitatorStatements);
  58. }
  59. public function storeApi(FacilitatorRequest $request)
  60. {
  61. $this->gate('装卸队-创建');
  62. $facilitator = Facilitator::query()->create($request->all());
  63. $this->success($facilitator);
  64. }
  65. public function updateApi(FacilitatorRequest $request)
  66. {
  67. $this->gate('装卸队-编辑');
  68. $facilitator = Facilitator::query()->where('id', $request['id'])->update($request->only(['name']));
  69. if ($facilitator) $this->success(Facilitator::query()->find($request['id']));
  70. $this->error('更新失败');
  71. }
  72. public function destroyApi(FacilitatorRequest $request)
  73. {
  74. $this->gate('装卸队-删除');
  75. $count = Facilitator::query()->where('id', $request['id'])->delete();
  76. if ($count > 0) $this->success('删除成功');
  77. $this->error('删除失败');
  78. }
  79. // 对账单导出
  80. public function exportStatement(Request $request, DischargeTaskFilters $filters)
  81. {
  82. $this->gate('装卸队-对账单-查询');
  83. /** @var Collection $facilitatorStatements */
  84. $facilitatorStatements = DischargeTask::query()
  85. ->filter($filters)
  86. ->with('facilitator')
  87. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  88. ->whereNotNull('facilitator_id')
  89. ->where('facilitator_id', '!=', '0')
  90. ->orderByDesc('id')->get();
  91. $row = ['日期', '装卸队', '数量', '单位', '单价', '总金额合计'];
  92. $json = app('DischargeTaskService')->getFacilitatorStatementsJson($facilitatorStatements);
  93. return app(ExportService::class)->json($row, $json, "装卸队对账单报表");
  94. }
  95. public function create()
  96. {
  97. }
  98. public function store(Request $request)
  99. {
  100. }
  101. public function show(Facilitator $facilitator)
  102. {
  103. }
  104. public function edit(Facilitator $facilitator)
  105. {
  106. }
  107. public function update(Request $request, Facilitator $facilitator)
  108. {
  109. }
  110. public function destroy(Facilitator $facilitator)
  111. {
  112. }
  113. }