¨4.0.1¨
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
namespace Modules\Checkout\Http\Controllers;
|
||||
|
||||
use Exception;
|
||||
use Illuminate\Http\Response;
|
||||
use Modules\Order\Entities\Order;
|
||||
use Modules\Payment\Facades\Gateway;
|
||||
use Modules\Checkout\Events\OrderPlaced;
|
||||
@@ -14,8 +15,9 @@ class CheckoutCompleteController
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param int $orderId
|
||||
* @param \Modules\Checkout\Services\OrderService $orderService
|
||||
* @return \Illuminate\Http\Response
|
||||
* @param OrderService $orderService
|
||||
*
|
||||
* @return Response
|
||||
*/
|
||||
public function store($orderId, OrderService $orderService)
|
||||
{
|
||||
@@ -37,16 +39,18 @@ class CheckoutCompleteController
|
||||
|
||||
event(new OrderPlaced($order));
|
||||
|
||||
if (! request()->ajax()) {
|
||||
if (!request()->ajax()) {
|
||||
return redirect()->route('checkout.complete.show');
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*
|
||||
* @return Response
|
||||
*/
|
||||
public function show()
|
||||
{
|
||||
|
||||
@@ -6,18 +6,51 @@ use Exception;
|
||||
use Modules\Support\Country;
|
||||
use Modules\Cart\Facades\Cart;
|
||||
use Modules\Page\Entities\Page;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Pipeline\Pipeline;
|
||||
use Illuminate\Routing\Controller;
|
||||
use Illuminate\Support\Collection;
|
||||
use Modules\Coupon\Entities\Coupon;
|
||||
use Illuminate\Contracts\View\View;
|
||||
use Modules\Payment\Facades\Gateway;
|
||||
use Illuminate\Contracts\View\Factory;
|
||||
use Modules\Coupon\Checkers\ValidCoupon;
|
||||
use Modules\Coupon\Checkers\CouponExists;
|
||||
use Modules\Coupon\Checkers\MinimumSpend;
|
||||
use Modules\Coupon\Checkers\MaximumSpend;
|
||||
use Modules\User\Services\CustomerService;
|
||||
use Modules\Checkout\Services\OrderService;
|
||||
use Modules\Coupon\Checkers\AlreadyApplied;
|
||||
use Modules\Address\Entities\DefaultAddress;
|
||||
use Modules\Cart\Http\Middleware\CheckCartStock;
|
||||
use Modules\Shipping\Facades\ShippingMethod;
|
||||
use Modules\Coupon\Checkers\ExcludedProducts;
|
||||
use Modules\Coupon\Checkers\ApplicableProducts;
|
||||
use Modules\Coupon\Checkers\ExcludedCategories;
|
||||
use Illuminate\Contracts\Foundation\Application;
|
||||
use Modules\Coupon\Checkers\UsageLimitPerCoupon;
|
||||
use Modules\Coupon\Checkers\ApplicableCategories;
|
||||
use Modules\Order\Http\Requests\StoreOrderRequest;
|
||||
use Modules\Cart\Http\Middleware\CheckCouponUsageLimit;
|
||||
use Modules\Coupon\Checkers\UsageLimitPerCustomer;
|
||||
use Modules\Cart\Http\Middleware\CheckCartItemsStock;
|
||||
use Modules\Cart\Http\Middleware\RedirectIfCartIsEmpty;
|
||||
|
||||
class CheckoutController extends Controller
|
||||
{
|
||||
private array $checkers = [
|
||||
CouponExists::class,
|
||||
AlreadyApplied::class,
|
||||
ValidCoupon::class,
|
||||
MinimumSpend::class,
|
||||
MaximumSpend::class,
|
||||
ApplicableProducts::class,
|
||||
ExcludedProducts::class,
|
||||
ApplicableCategories::class,
|
||||
ExcludedCategories::class,
|
||||
UsageLimitPerCoupon::class,
|
||||
UsageLimitPerCustomer::class,
|
||||
];
|
||||
|
||||
|
||||
/**
|
||||
* Create a new controller instance.
|
||||
*
|
||||
@@ -27,50 +60,22 @@ class CheckoutController extends Controller
|
||||
{
|
||||
$this->middleware([
|
||||
RedirectIfCartIsEmpty::class,
|
||||
CheckCartStock::class,
|
||||
CheckCouponUsageLimit::class,
|
||||
]);
|
||||
|
||||
$this->middleware([
|
||||
CheckCartItemsStock::class,
|
||||
])->only('store');
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
Gateway::all();
|
||||
return view('public.checkout.create', [
|
||||
'cart' => Cart::instance(),
|
||||
'countries' => Country::supported(),
|
||||
'gateways' => Gateway::all(),
|
||||
'defaultAddress' => auth()->user()->defaultAddress ?? new DefaultAddress,
|
||||
'addresses' => $this->getAddresses(),
|
||||
'termsPageURL' => Page::urlForPage(setting('storefront_terms_page')),
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get addresses for the logged in user.
|
||||
*
|
||||
* @return \Illuminate\Support\Collection
|
||||
*/
|
||||
private function getAddresses()
|
||||
{
|
||||
if (auth()->guest()) {
|
||||
return collect();
|
||||
}
|
||||
|
||||
return auth()->user()->addresses->keyBy('id');
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Modules\Order\Http\Requests\StoreOrderRequest $request
|
||||
* @param \Modules\User\Services\CustomerService $customerService
|
||||
* @param \Modules\Checkout\Services\OrderService $orderService
|
||||
* @return \Illuminate\Http\Response
|
||||
* @param StoreOrderRequest $request
|
||||
* @param CustomerService $customerService
|
||||
* @param OrderService $orderService
|
||||
*
|
||||
* @return JsonResponse
|
||||
*/
|
||||
public function store(StoreOrderRequest $request, CustomerService $customerService, OrderService $orderService)
|
||||
{
|
||||
@@ -78,6 +83,24 @@ class CheckoutController extends Controller
|
||||
$customerService->register($request)->login();
|
||||
}
|
||||
|
||||
|
||||
$cartWithCoupon = null;
|
||||
$couponCode = request()->query('coupon_code');
|
||||
if ($couponCode) {
|
||||
$coupon = Coupon::findByCode($couponCode);
|
||||
try {
|
||||
resolve(Pipeline::class)
|
||||
->send($coupon)
|
||||
->through($this->checkers)
|
||||
->then(function ($coupon) use (&$cartWithCoupon) {
|
||||
Cart::applyCoupon($coupon);
|
||||
});
|
||||
} catch (Exception) {
|
||||
//Just suppressing the exception
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
$order = $orderService->create($request);
|
||||
|
||||
$gateway = Gateway::get($request->payment_method);
|
||||
@@ -90,8 +113,47 @@ class CheckoutController extends Controller
|
||||
return response()->json([
|
||||
'message' => $e->getMessage(),
|
||||
], 403);
|
||||
} finally {
|
||||
if (Cart::hasCoupon()) {
|
||||
Cart::removeCoupon();
|
||||
}
|
||||
}
|
||||
|
||||
return response()->json($response);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return Application|Factory|View
|
||||
*/
|
||||
public function create(): View|Factory|Application
|
||||
{
|
||||
Gateway::all();
|
||||
|
||||
return view('public.checkout.create', [
|
||||
'cart' => Cart::instance(),
|
||||
'countries' => Country::supported(),
|
||||
'gateways' => Gateway::all(),
|
||||
'defaultAddress' => auth()->user()->defaultAddress ?? new DefaultAddress,
|
||||
'addresses' => $this->getAddresses(),
|
||||
'termsPageURL' => Page::urlForPage(setting('storefront_terms_page')),
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get addresses for the logged in user.
|
||||
*
|
||||
* @return Collection
|
||||
*/
|
||||
private function getAddresses()
|
||||
{
|
||||
if (auth()->guest()) {
|
||||
return collect();
|
||||
}
|
||||
|
||||
return auth()->user()->addresses->keyBy('id');
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,6 +5,7 @@ namespace Modules\Checkout\Http\Controllers;
|
||||
use Illuminate\Http\Request;
|
||||
use Modules\Cart\Facades\Cart;
|
||||
use Modules\Order\Entities\Order;
|
||||
use Modules\Checkout\Services\OrderService;
|
||||
|
||||
class PaymentCanceledController
|
||||
{
|
||||
@@ -13,8 +14,7 @@ class PaymentCanceledController
|
||||
*
|
||||
* @param int $orderId
|
||||
* @param string $paymentMethod
|
||||
* @param \Modules\Checkout\Services\OrderService $orderService
|
||||
* @return \Illuminate\Http\Response
|
||||
* @param OrderService $orderService
|
||||
*/
|
||||
public function store(Request $request, $orderId)
|
||||
{
|
||||
@@ -27,8 +27,7 @@ class PaymentCanceledController
|
||||
[
|
||||
'success' => true,
|
||||
'message' => trans('payment::messages.payment_cancelled'),
|
||||
],
|
||||
200,
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user