Server IP : 66.29.132.124 / Your IP : 18.118.138.113 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/book24.ng/modules/User/Admin/ |
Upload File : |
<?php namespace Modules\User\Admin; use App\User; use function Clue\StreamFilter\fun; use Illuminate\Http\Request; use Modules\AdminController; use Modules\User\Exports\SubscriberExport; use Modules\User\Models\Subscriber; class SubscriberController extends AdminController { public function __construct() { parent::__construct(); } public function index(Request $request) { $this->checkPermission('newsletter_manage'); $listCategory = new Subscriber; if (!empty($search = $request->query('s'))) { $listCategory = $listCategory->where(function ($query) use ($request) { $query->where('first_name', 'LIKE', '%' . $request->s . '%'); $query->orWhere('last_name', 'LIKE', '%' . $request->s . '%'); $query->orWhere('email', 'LIKE', '%' . $request->s . '%'); }); } $listCategory = $listCategory->orderBy('created_at', 'asc'); $data = [ 'rows' => $listCategory->paginate(20), 'row' => new Subscriber(), 'breadcrumbs' => [ [ 'name' => __('User'), 'url' => route('user.admin.index') ], [ 'name' => __('Subscribers'), 'class' => 'active' ], ] ]; return view('User::newsletter.subscriber.index', $data); } public function edit(Request $request, $id) { $this->checkPermission('newsletter_manage'); $row = Subscriber::find($id); if (empty($row)) { return redirect()->back(); } $data = [ 'row' => $row, 'breadcrumbs' => [ [ 'name' => __('User'), 'url' => route('user.admin.index') ], [ 'name' => __('Subscribers'), 'url' => route('user.admin.subscriber.index') ], [ 'name' => __('Edit: :email', ['email' => $row->email]), 'class' => 'active' ], ] ]; return view('User::newsletter.subscriber.detail', $data); } public function store(Request $request) { $this->checkPermission('newsletter_manage'); $request->validate([ 'email' => 'required|email|max:255', 'first_name' => 'max:255', 'last_name' => 'max:255', ]); if ($request->input('id')) { $row = Subscriber::find($request->input('id')); } else { $row = new Subscriber(); } $check = Subscriber::where('email', $request->input('email'))->first(); if ($check and $check->id != $request->input('id')) { return redirect()->back()->with('error', __('Email exists')); } $row->fill($request->input()); if ($row->save()) { return redirect()->back()->with('success', __('Subscriber updated')); } } public function bulkEdit(Request $request) { $this->checkPermission("newsletter_manage"); $ids = $request->input('ids'); $action = $request->input('action'); if (empty($ids) or !is_array($ids)) { return redirect()->back()->with('error', __('Select at least 1 item!')); } if (empty($action)) { return redirect()->back()->with('error', __('Select an Action!')); } switch ($action) { case "delete": foreach ($ids as $id) { $query = Subscriber::where("id", $id); $query->first(); if(!empty($query)){ $query->delete(); } } break; default: foreach ($ids as $id) { $query = Subscriber::where("id", $id); $query->update(['status' => $action]); } break; } return redirect()->back()->with('success', __('Updated successfully!')); } public function export() { return (new SubscriberExport())->download('subscribers-' . date('M-d-Y') . '.xlsx'); } }