FacilitatorController.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  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. use Oursdreams\Export\Export;
  15. class FacilitatorController extends Controller
  16. {
  17. use AsyncResponse;
  18. public function index(Request $request)
  19. {
  20. if (!Gate::allows('装卸队-查询')) {
  21. return redirect(url('/'));
  22. }
  23. $facilitators = Facilitator::query()->select(['id', 'name', 'created_at'])->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  24. return view('maintenance.facilitator.index', compact('facilitators'));
  25. }
  26. // 装卸队对账单
  27. public function statementIndex(Request $request, DischargeTaskFilters $filters)
  28. {
  29. if (!Gate::allows('装卸队-对账单-查询')) {
  30. return redirect(url('/'));
  31. }
  32. $facilitatorStatements = DischargeTask::query()
  33. ->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 ")
  34. ->leftJoin('facilitators', 'discharge_tasks.facilitator_id', '=', 'facilitators.id')
  35. ->filter($filters)
  36. ->groupBy('months', 'facilitator_id')
  37. ->orderByDesc('months')
  38. ->paginate($request['paginate'] ?? 50);
  39. $facilitators = Facilitator::query()->get();
  40. return view('personnel.discharge.facilitator.index', compact('facilitatorStatements', 'facilitators'));
  41. }
  42. // 卸货队扫描二维码
  43. public function getQrCode(Request $request)
  44. {
  45. /** @var FacilitatorService $service */
  46. $service = app(FacilitatorService::class);
  47. $qrCodeUrl = $service->getQrCodeUrl($request->all());
  48. $facilitator = Facilitator::query()->where('id',$request['facilitator_id'])->first();
  49. return view('personnel/discharge/facilitator/external/Qrcode',compact('qrCodeUrl','facilitator'));
  50. }
  51. public function gainStatementApi(Request $request,DischargeTaskFilters $filters)
  52. {
  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, FacilitatorExternalFilters $filters)
  81. {
  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 Export::make($row, $json, "装卸队对账单报表");
  93. }
  94. public function create()
  95. {
  96. }
  97. public function store(Request $request)
  98. {
  99. }
  100. public function show(Facilitator $facilitator)
  101. {
  102. }
  103. public function edit(Facilitator $facilitator)
  104. {
  105. }
  106. public function update(Request $request, Facilitator $facilitator)
  107. {
  108. }
  109. public function destroy(Facilitator $facilitator)
  110. {
  111. }
  112. }