PartnerController.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\PartnerDiscount;
  5. use App\Models\User;
  6. use App\Settings\LocaleSettings;
  7. use App\Settings\ReferralSettings;
  8. use Illuminate\Http\Request;
  9. class PartnerController extends Controller
  10. {
  11. const READ_PERMISSION = "admin.partners.read";
  12. const WRITE_PERMISSION = "admin.partners.write";
  13. public function index(LocaleSettings $locale_settings)
  14. {
  15. $this->checkPermission(self::READ_PERMISSION);
  16. return view('admin.partners.index', [
  17. 'locale_datatables' => $locale_settings->datatables
  18. ]);
  19. }
  20. /**
  21. * Show the form for creating a new resource.
  22. *
  23. * @return Application|Factory|View
  24. */
  25. public function create()
  26. {
  27. $this->checkPermission(self::WRITE_PERMISSION);
  28. return view('admin.partners.create', [
  29. 'partners' => PartnerDiscount::get(),
  30. 'users' => User::orderBy('name')->get(),
  31. ]);
  32. }
  33. /**
  34. * Store a newly created resource in storage.
  35. *
  36. * @param Request $request
  37. * @return RedirectResponse
  38. */
  39. public function store(Request $request)
  40. {
  41. $request->validate([
  42. 'user_id' => 'required|integer|min:0',
  43. 'partner_discount' => 'required|integer|max:100|min:0',
  44. 'registered_user_discount' => 'required|integer|max:100|min:0',
  45. ]);
  46. if(PartnerDiscount::where("user_id",$request->user_id)->exists()){
  47. return redirect()->route('admin.partners.index')->with('error', __('Partner already exists'));
  48. }
  49. PartnerDiscount::create($request->all());
  50. return redirect()->route('admin.partners.index')->with('success', __('partner has been created!'));
  51. }
  52. /**
  53. * Show the form for editing the specified resource.
  54. *
  55. * @param Partner $partner
  56. * @return Application|Factory|View
  57. */
  58. public function edit(PartnerDiscount $partner)
  59. {
  60. $this->checkPermission(self::WRITE_PERMISSION);
  61. return view('admin.partners.edit', [
  62. 'partners' => PartnerDiscount::get(),
  63. 'partner' => $partner,
  64. 'users' => User::orderBy('name')->get(),
  65. ]);
  66. }
  67. /**
  68. * Update the specified resource in storage.
  69. *
  70. * @param Request $request
  71. * @param Partner $partner
  72. * @return RedirectResponse
  73. */
  74. public function update(Request $request, PartnerDiscount $partner)
  75. {
  76. //dd($request);
  77. $request->validate([
  78. 'user_id' => 'required|integer|min:0',
  79. 'partner_discount' => 'required|integer|max:100|min:0',
  80. 'registered_user_discount' => 'required|integer|max:100|min:0',
  81. ]);
  82. $partner->update($request->all());
  83. return redirect()->route('admin.partners.index')->with('success', __('partner has been updated!'));
  84. }
  85. /**
  86. * Remove the specified resource from storage.
  87. *
  88. * @param Partner $partner
  89. * @return RedirectResponse
  90. */
  91. public function destroy(PartnerDiscount $partner)
  92. {
  93. $this->checkPermission(self::WRITE_PERMISSION);
  94. $partner->delete();
  95. return redirect()->back()->with('success', __('partner has been removed!'));
  96. }
  97. public function dataTable()
  98. {
  99. $query = PartnerDiscount::query();
  100. return datatables($query)
  101. ->addColumn('actions', function (PartnerDiscount $partner) {
  102. return '
  103. <a data-content="'.__('Edit').'" data-toggle="popover" data-trigger="hover" data-placement="top" href="'.route('admin.partners.edit', $partner->id).'" class="btn btn-sm btn-info mr-1"><i class="fas fa-pen"></i></a>
  104. <form class="d-inline" onsubmit="return submitResult();" method="post" action="'.route('admin.partners.destroy', $partner->id).'">
  105. '.csrf_field().'
  106. '.method_field('DELETE').'
  107. <button data-content="'.__('Delete').'" data-toggle="popover" data-trigger="hover" data-placement="top" class="btn btn-sm btn-danger mr-1"><i class="fas fa-trash"></i></button>
  108. </form>
  109. ';
  110. })
  111. ->addColumn('user', function (PartnerDiscount $partner) {
  112. return ($user = User::where('id', $partner->user_id)->first()) ? '<a href="'.route('admin.users.show', $partner->user_id) . '">' . $user->name . '</a>' : __('Unknown user');
  113. })
  114. ->editColumn('created_at', function (PartnerDiscount $partner) {
  115. return $partner->created_at ? $partner->created_at->diffForHumans() : '';
  116. })
  117. ->editColumn('partner_discount', function (PartnerDiscount $partner) {
  118. return $partner->partner_discount ? $partner->partner_discount . '%' : '0%';
  119. })
  120. ->editColumn('registered_user_discount', function (PartnerDiscount $partner) {
  121. return $partner->registered_user_discount ? $partner->registered_user_discount . '%' : '0%';
  122. })
  123. ->editColumn('referral_system_commission', function (PartnerDiscount $partner, ReferralSettings $referral_settings) {
  124. return $partner->referral_system_commission >= 0 ? $partner->referral_system_commission . '%' : __('Default') . ' ('.$referral_settings->percentage . '%)';
  125. })
  126. ->rawColumns(['user', 'actions'])
  127. ->make();
  128. }
  129. }