FacilitatorController.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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\Http\Request;
  10. use Illuminate\Support\Facades\Gate;
  11. class FacilitatorController extends Controller
  12. {
  13. use AsyncResponse;
  14. // 服务商基础设置
  15. public function index(Request $request)
  16. {
  17. if (!Gate::allows('服务商-查询')) {
  18. return redirect(url('/'));
  19. }
  20. $facilitators = Facilitator::query()->select(['id', 'name', 'created_at'])->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  21. return view('maintenance.facilitator.index', compact('facilitators'));
  22. }
  23. // 服务商对账单
  24. public function statementIndex(Request $request, DischargeTaskFilters $filters)
  25. {
  26. if (!Gate::allows('服务商-对账单-查询')) {
  27. return redirect(url('/'));
  28. }
  29. $facilitatorStatements = DischargeTask::query()->with('facilitator')
  30. ->whereNotNull('facilitator_id')
  31. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  32. ->filter($filters)->orderByDesc('id')->paginate($request['paginate'] ?? 50);
  33. $facilitators = Facilitator::query()->get();
  34. return view('transport.discharge.facilitator.index', compact('facilitatorStatements', 'facilitators'));
  35. }
  36. public function create()
  37. {
  38. //
  39. }
  40. public function store(Request $request)
  41. {
  42. //
  43. }
  44. public function storeApi(FacilitatorRequest $request)
  45. {
  46. $this->gate('服务商-创建');
  47. $facilitator = Facilitator::query()->create($request->all());
  48. $this->success($facilitator);
  49. }
  50. public function show(Facilitator $facilitator)
  51. {
  52. //
  53. }
  54. public function edit(Facilitator $facilitator)
  55. {
  56. //
  57. }
  58. public function update(Request $request, Facilitator $facilitator)
  59. {
  60. //
  61. }
  62. public function updateApi(FacilitatorRequest $request)
  63. {
  64. $this->gate('服务商-编辑');
  65. $facilitator = Facilitator::query()->where('id', $request['id'])->update($request->only(['name']));
  66. if ($facilitator) $this->success(Facilitator::query()->find($request['id']));
  67. $this->error('更新失败');
  68. }
  69. public function destroy(Facilitator $facilitator)
  70. {
  71. //
  72. }
  73. public function destroyApi(FacilitatorRequest $request)
  74. {
  75. $this->gate('服务商-删除');
  76. $count = Facilitator::query()->where('id', $request['id'])->delete();
  77. if ($count > 0) $this->success('删除成功');
  78. $this->error('删除失败');
  79. }
  80. // 对账单导出
  81. public function exportStatement(Request $request, DischargeTaskFilters $filters)
  82. {
  83. // 权限 ***
  84. $this->gate('服务商-对账单-查询');
  85. $dischargeTasks = DischargeTask::query()->with('facilitator')
  86. ->whereNotNull('facilitator_id')
  87. ->select(['id', 'facilitator_id', 'expenditure_amount', 'expenditure_unit', 'expenditure_unit_price', 'expenditure_total_cost', 'expenditure_remark', 'created_at'])
  88. ->filter($filters)->orderByDesc('id')->get();
  89. $row = ['日期', '服务商', '数量', '单位', '单价', '总金额合计'];
  90. $json = app('DischargeTaskService')->getStatementsJson($dischargeTasks);
  91. return app(ExportService::class)->json($row, $json, "服务商对账单报表");
  92. }
  93. }