FacilitatorController.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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\Filters\FacilitatorExternalFilters;
  8. use App\Http\Requests\DischargeTask\FacilitatorRequest;
  9. use App\Services\common\ExportService;
  10. use App\Services\FacilitatorService;
  11. use Illuminate\Database\Eloquent\Collection;
  12. use Illuminate\Http\Request;
  13. use Illuminate\Support\Facades\Gate;
  14. class FacilitatorController extends Controller
  15. {
  16. use AsyncResponse;
  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->getQrCodeUrl($request->all());
  47. $facilitator = Facilitator::query()->where('id',$request['facilitator_id'])->first();
  48. return view('personnel/discharge/facilitator/external/Qrcode',compact('qrCodeUrl','facilitator'));
  49. }
  50. public function gainStatementApi(Request $request,DischargeTaskFilters $filters)
  51. {
  52. $facilitatorStatements = DischargeTask::query()
  53. ->with('facilitator')
  54. ->filter($filters)
  55. ->get();
  56. $this->success($facilitatorStatements);
  57. }
  58. public function storeApi(FacilitatorRequest $request)
  59. {
  60. $this->gate('装卸队-创建');
  61. $facilitator = Facilitator::query()->create($request->all());
  62. $this->success($facilitator);
  63. }
  64. public function updateApi(FacilitatorRequest $request)
  65. {
  66. $this->gate('装卸队-编辑');
  67. $facilitator = Facilitator::query()->where('id', $request['id'])->update($request->only(['name']));
  68. if ($facilitator) $this->success(Facilitator::query()->find($request['id']));
  69. $this->error('更新失败');
  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, FacilitatorExternalFilters $filters)
  80. {
  81. /** @var Collection $facilitatorStatements */
  82. $facilitatorStatements = DischargeTask::query()
  83. ->filter($filters)
  84. ->with('facilitator')
  85. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  86. ->whereNotNull('facilitator_id')
  87. ->where('facilitator_id', '!=', '0')
  88. ->orderByDesc('id')->get();
  89. $row = ['日期', '装卸队', '数量', '单位', '单价', '总金额合计'];
  90. $json = app('DischargeTaskService')->getFacilitatorStatementsJson($facilitatorStatements);
  91. return app(ExportService::class)->json($row, $json, "装卸队对账单报表");
  92. }
  93. public function create()
  94. {
  95. }
  96. public function store(Request $request)
  97. {
  98. }
  99. public function show(Facilitator $facilitator)
  100. {
  101. }
  102. public function edit(Facilitator $facilitator)
  103. {
  104. }
  105. public function update(Request $request, Facilitator $facilitator)
  106. {
  107. }
  108. public function destroy(Facilitator $facilitator)
  109. {
  110. }
  111. }