2020-07-27 14:49:59 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
2024-08-10 10:14:47 +10:00
|
|
|
use Illuminate\Http\RedirectResponse;
|
2020-07-27 14:49:59 +10:00
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
2022-07-29 16:06:19 +10:00
|
|
|
use App\Http\Requests\CheckoutAddEdit;
|
|
|
|
use App\Models\{Checkout,Invoice};
|
2020-07-27 14:49:59 +10:00
|
|
|
|
|
|
|
class CheckoutController extends Controller
|
|
|
|
{
|
2022-07-29 16:06:19 +10:00
|
|
|
/**
|
2024-08-10 10:14:47 +10:00
|
|
|
* Update a checkout details
|
2022-07-29 16:06:19 +10:00
|
|
|
*
|
|
|
|
* @param CheckoutAddEdit $request
|
|
|
|
* @param Checkout $o
|
2024-08-10 10:14:47 +10:00
|
|
|
* @return RedirectResponse
|
2022-07-29 16:06:19 +10:00
|
|
|
*/
|
2024-08-10 10:14:47 +10:00
|
|
|
public function addedit(CheckoutAddEdit $request,Checkout $o): RedirectResponse
|
2022-07-29 16:06:19 +10:00
|
|
|
{
|
2024-08-10 10:14:47 +10:00
|
|
|
foreach ($request->validated() as $key => $item)
|
2022-07-29 16:06:19 +10:00
|
|
|
$o->{$key} = $item;
|
|
|
|
|
2024-08-10 10:14:47 +10:00
|
|
|
$o->active = (bool)$request->validated('active',FALSE);
|
2022-07-29 16:06:19 +10:00
|
|
|
|
|
|
|
try {
|
|
|
|
$o->save();
|
|
|
|
|
|
|
|
} catch (\Exception $e) {
|
2024-08-10 10:14:47 +10:00
|
|
|
return redirect()
|
|
|
|
->back()
|
|
|
|
->withErrors($e->getMessage())->withInput();
|
2022-07-29 16:06:19 +10:00
|
|
|
}
|
|
|
|
|
2024-08-10 10:14:47 +10:00
|
|
|
return $o->wasRecentlyCreated
|
|
|
|
? redirect()
|
|
|
|
->to('a/checkout/'.$o->id)
|
|
|
|
->with('success','Checkout added')
|
|
|
|
: redirect()
|
|
|
|
->back()
|
|
|
|
->with('success','Checkout saved');
|
2022-07-29 16:06:19 +10:00
|
|
|
}
|
|
|
|
|
2024-08-10 22:17:21 +10:00
|
|
|
/**
|
|
|
|
* Add an invoice to the cart
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @param Invoice $o
|
|
|
|
* @return \Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View|\Illuminate\Foundation\Application
|
|
|
|
* @note The route validates that the user can see the invoice
|
|
|
|
*/
|
|
|
|
public function cart_invoice(Request $request,Invoice $o)
|
2020-07-27 14:49:59 +10:00
|
|
|
{
|
2024-08-10 22:17:21 +10:00
|
|
|
$request->session()->put('invoice.cart.'.$o->id,$o->id);
|
2020-07-27 14:49:59 +10:00
|
|
|
|
2024-08-10 22:17:21 +10:00
|
|
|
return view('theme.backend.adminlte.checkout.cart');
|
|
|
|
}
|
2020-07-27 14:49:59 +10:00
|
|
|
|
2024-08-10 22:17:21 +10:00
|
|
|
/**
|
|
|
|
* Remove an item from the cart
|
|
|
|
*
|
|
|
|
* @param Request $request
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function cart_remove(Request $request): string
|
|
|
|
{
|
|
|
|
if ($id=$request->post('id')) {
|
|
|
|
$cart = $request->session()->pull('invoice.cart');
|
|
|
|
unset($cart[$id]);
|
|
|
|
|
|
|
|
$request->session()->put('invoice.cart',$cart);
|
|
|
|
}
|
|
|
|
|
|
|
|
return '';
|
2020-07-27 14:49:59 +10:00
|
|
|
}
|
|
|
|
|
2024-08-10 22:17:21 +10:00
|
|
|
public function fee(Request $request): float
|
2020-07-27 14:49:59 +10:00
|
|
|
{
|
2024-08-10 22:17:21 +10:00
|
|
|
if ((! $request->post('checkout_id') || (! $request->post('total'))))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
$co = Checkout::findOrFail($request->post('checkout_id'));
|
|
|
|
|
|
|
|
return $co->fee($request->post('total'));
|
2020-07-27 14:49:59 +10:00
|
|
|
}
|
|
|
|
|
2024-08-10 22:17:21 +10:00
|
|
|
public function pay()
|
2020-07-27 14:49:59 +10:00
|
|
|
{
|
2024-08-10 22:17:21 +10:00
|
|
|
// @todo Currently sending all payments to paypal
|
|
|
|
return redirect()
|
|
|
|
->action([PaypalController::class,'authorise']);
|
2020-07-27 14:49:59 +10:00
|
|
|
}
|
|
|
|
}
|