Server : nginx/1.18.0 System : Linux localhost 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64 User : www-data ( 33) PHP Version : 8.0.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/ecommerce/app/Http/Controllers/Shop/ |
<?php
namespace App\Http\Controllers\Shop;
use App\Models\Cart;
use App\Models\Coupon;
use Illuminate\Http\Request;
class CouponController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
$coupon = Coupon::orderBy('id', 'DESC')->paginate('10');
return view('backend.coupon.index')->with('coupons', $coupon);
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
return view('backend.coupon.create');
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
*
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
// return $request->all();
$this->validate($request, [
'code' => 'string|required',
'type' => 'required|in:fixed,percent',
'value' => 'required|numeric',
'status' => 'required|in:active,inactive',
]);
$data = $request->all();
$status = Coupon::create($data);
if ($status) {
request()->session()->flash('success', 'Coupon Successfully added');
} else {
request()->session()->flash('error', 'Please try again!!');
}
return redirect()->route('coupon.index');
}
/**
* Display the specified resource.
*
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function show($id)
{
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
$coupon = Coupon::find($id);
if ($coupon) {
return view('backend.coupon.edit')->with('coupon', $coupon);
} else {
return view('backend.coupon.index')->with('error', 'Coupon not found');
}
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
$coupon = Coupon::find($id);
$this->validate($request, [
'code' => 'string|required',
'type' => 'required|in:fixed,percent',
'value' => 'required|numeric',
'status' => 'required|in:active,inactive',
]);
$data = $request->all();
$status = $coupon->fill($data)->save();
if ($status) {
request()->session()->flash('success', 'Coupon Successfully updated');
} else {
request()->session()->flash('error', 'Please try again!!');
}
return redirect()->route('coupon.index');
}
/**
* Remove the specified resource from storage.
*
* @param int $id
*
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
$coupon = Coupon::find($id);
if ($coupon) {
$status = $coupon->delete();
if ($status) {
request()->session()->flash('success', 'Coupon successfully deleted');
} else {
request()->session()->flash('error', 'Error, Please try again');
}
return redirect()->route('coupon.index');
} else {
request()->session()->flash('error', 'Coupon not found');
return redirect()->back();
}
}
public function couponStore(Request $request)
{
// return $request->all();
$coupon = Coupon::where('code', $request->code)->first();
// dd($coupon);
if (!$coupon) {
request()->session()->flash('error', 'Invalid coupon code, Please try again');
return back();
}
if ($coupon) {
$total_price = Cart::where('user_id', auth()->id())->where('order_id', null)->sum('price');
// dd($total_price);
session()->put('coupon', [
'id' => $coupon->id,
'code' => $coupon->code,
'value' => $coupon->discount($total_price),
]);
request()->session()->flash('success', 'Coupon successfully applied');
return redirect()->back();
}
}
}