first upload all files
This commit is contained in:
73
Modules/Cart/Http/Middleware/CheckCartStock.php
Normal file
73
Modules/Cart/Http/Middleware/CheckCartStock.php
Normal file
@@ -0,0 +1,73 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Cart\Http\Middleware;
|
||||
|
||||
use Closure;
|
||||
use Exception;
|
||||
use Modules\Cart\CartItem;
|
||||
use Illuminate\Http\Request;
|
||||
use Modules\Cart\Facades\Cart;
|
||||
use Modules\FlashSale\Entities\FlashSale;
|
||||
|
||||
class CheckCartStock
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure $next
|
||||
* @return mixed
|
||||
*/
|
||||
public function handle(Request $request, Closure $next)
|
||||
{
|
||||
try {
|
||||
Cart::items()->each(function (CartItem $cartItem) {
|
||||
$cartItem->refreshStock();
|
||||
|
||||
$this->checkQuantity($cartItem);
|
||||
});
|
||||
} catch (Exception $e) {
|
||||
return redirect()->route('cart.index')->with('error', $e->getMessage());
|
||||
}
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
|
||||
private function checkQuantity(CartItem $cartItem)
|
||||
{
|
||||
if ($cartItem->product->isOutOfStock()) {
|
||||
throw new Exception(trans('cart::messages.one_or_more_product_is_out_of_stock'));
|
||||
}
|
||||
|
||||
if (! $this->hasFlashSaleStock($cartItem)) {
|
||||
throw new Exception(trans('cart::messages.one_or_more_product_doesn\'t_have_enough_stock'));
|
||||
}
|
||||
|
||||
if (! $this->hasStock($cartItem)) {
|
||||
throw new Exception(trans('cart::messages.one_or_more_product_doesn\'t_have_enough_stock'));
|
||||
}
|
||||
}
|
||||
|
||||
private function hasFlashSaleStock(CartItem $cartItem)
|
||||
{
|
||||
if (! FlashSale::contains($cartItem->product)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$remainingQty = FlashSale::remainingQty($cartItem->product);
|
||||
$addedCartQty = Cart::addedQty($cartItem->product->id);
|
||||
|
||||
return ($remainingQty - $addedCartQty) >= 0;
|
||||
}
|
||||
|
||||
private function hasStock(CartItem $cartItem)
|
||||
{
|
||||
if (! $cartItem->product->manage_stock) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$addedCartQty = Cart::addedQty($cartItem->product->id);
|
||||
|
||||
return ($cartItem->product->qty - $addedCartQty) >= 0;
|
||||
}
|
||||
}
|
||||
27
Modules/Cart/Http/Middleware/CheckCouponUsageLimit.php
Normal file
27
Modules/Cart/Http/Middleware/CheckCouponUsageLimit.php
Normal file
@@ -0,0 +1,27 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Cart\Http\Middleware;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Modules\Cart\Facades\Cart;
|
||||
use Modules\Coupon\Exceptions\CouponUsageLimitReachedException;
|
||||
|
||||
class CheckCouponUsageLimit
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure $next
|
||||
* @return mixed
|
||||
*/
|
||||
public function handle(Request $request, Closure $next)
|
||||
{
|
||||
if (Cart::coupon()->usageLimitReached($request->customer_email)) {
|
||||
throw new CouponUsageLimitReachedException;
|
||||
}
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
103
Modules/Cart/Http/Middleware/CheckProductIsInStock.php
Normal file
103
Modules/Cart/Http/Middleware/CheckProductIsInStock.php
Normal file
@@ -0,0 +1,103 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Cart\Http\Middleware;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Modules\Cart\Facades\Cart;
|
||||
use Modules\Product\Entities\Product;
|
||||
use Modules\FlashSale\Entities\FlashSale;
|
||||
|
||||
class CheckProductIsInStock
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure $next
|
||||
* @return mixed
|
||||
*/
|
||||
public function handle(Request $request, Closure $next)
|
||||
{
|
||||
$product = Product::withName()
|
||||
->addSelect('id', 'in_stock', 'manage_stock', 'qty')
|
||||
->where('id', $this->getProductId($request))
|
||||
->firstOrFail();
|
||||
|
||||
if ($product->isOutOfStock()) {
|
||||
abort(400, trans('cart::messages.out_of_stock'));
|
||||
}
|
||||
|
||||
if (! $this->hasFlashSaleStock($product, $request)) {
|
||||
abort(400, trans('cart::messages.not_have_enough_quantity_in_stock', [
|
||||
'stock' => FlashSale::remainingQty($product),
|
||||
]));
|
||||
}
|
||||
|
||||
if (! $this->hasStock($product, $request)) {
|
||||
abort(400, trans('cart::messages.not_have_enough_quantity_in_stock', [
|
||||
'stock' => $product->qty,
|
||||
]));
|
||||
}
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
|
||||
private function getProductId(Request $request)
|
||||
{
|
||||
if ($request->routeIs('cart.items.store')) {
|
||||
return $request->product_id;
|
||||
}
|
||||
|
||||
$cartItem = $this->getCartItemForUpdateRequest($request);
|
||||
|
||||
if (! is_null($cartItem)) {
|
||||
return $cartItem->product->id;
|
||||
}
|
||||
}
|
||||
|
||||
private function getCartItemForUpdateRequest(Request $request)
|
||||
{
|
||||
return Cart::items()->get($request->route()->parameter('cartItemId'));
|
||||
}
|
||||
|
||||
private function hasFlashSaleStock(Product $product, Request $request)
|
||||
{
|
||||
if (! FlashSale::contains($product)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$remainingQty = FlashSale::remainingQty($product);
|
||||
$addedCartQty = Cart::addedQty($product->id);
|
||||
|
||||
// Exclude current cart item quantity from the total added cart quantity
|
||||
// So, that current quantity is not added with the updated quantity.
|
||||
$addedCartQty -= $this->currentCartItemQuantity($request);
|
||||
|
||||
return ($remainingQty - $addedCartQty) >= $request->qty;
|
||||
}
|
||||
|
||||
private function hasStock(Product $product, Request $request)
|
||||
{
|
||||
if (! $product->manage_stock) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$addedCartQty = Cart::addedQty($product->id);
|
||||
|
||||
// Exclude current cart item quantity from the total added cart quantity
|
||||
// So, that current quantity is not added with the updated quantity.
|
||||
$addedCartQty -= $this->currentCartItemQuantity($request);
|
||||
|
||||
return ($product->qty - $addedCartQty) >= $request->qty;
|
||||
}
|
||||
|
||||
private function currentCartItemQuantity(Request $request)
|
||||
{
|
||||
if ($request->routeIs('cart.items.update')) {
|
||||
return $this->getCartItemForUpdateRequest($request)->qty;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
26
Modules/Cart/Http/Middleware/RedirectIfCartIsEmpty.php
Normal file
26
Modules/Cart/Http/Middleware/RedirectIfCartIsEmpty.php
Normal file
@@ -0,0 +1,26 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Cart\Http\Middleware;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Modules\Cart\Facades\Cart;
|
||||
|
||||
class RedirectIfCartIsEmpty
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure $next
|
||||
* @return mixed
|
||||
*/
|
||||
public function handle(Request $request, Closure $next)
|
||||
{
|
||||
if (Cart::isEmpty()) {
|
||||
return redirect()->route('cart.index');
|
||||
}
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user