FacilitatorController.php 3.5 KB

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