FacilitatorController.php 4.2 KB

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