<?php
namespace App\Http\Controllers\Api\V2;
use App\Http\Resources\V2\PurchasedResource;
use App\Http\Resources\V2\PurchaseHistoryCollection;
use App\Http\Resources\V2\PurchaseHistoryItemsCollection;
use App\Http\Resources\V2\PurchaseHistoryMiniCollection;
use App\Models\Cart;
use App\Models\Order;
use App\Models\OrderDetail;
use App\Models\Product;
use App\Utility\CartUtility;
use Illuminate\Http\Request;
class PurchaseHistoryController extends Controller {
public function index(Request $request) {
$order_query = Order::query();
if ($request->payment_status != "" || $request->payment_status != null) {
$order_query->where('payment_status', $request->payment_status);
}
if ($request->delivery_status != "" || $request->delivery_status != null) {
$delivery_status = $request->delivery_status;
$order_query->whereIn("id", function ($query) use ($delivery_status) {
$query->select('order_id')
->from('order_details')
->where('delivery_status', $delivery_status);
});
}
return new PurchaseHistoryMiniCollection($order_query->where('user_id', auth()->user()->id)->latest()->paginate(5));
}
public function details($id) {
$order_detail = Order::where('id', $id)->get();
return new PurchaseHistoryCollection($order_detail);
}
public function items($id) {
$order_id = Order::select('id')->where('id', $id)->where('user_id', auth()->user()->id)->first();
$order_query = OrderDetail::where('order_id', $order_id->id);
return new PurchaseHistoryItemsCollection($order_query->get());
}
public function digital_purchased_list() {
$order_detail_products = Product::query()
->where('digital', 1)
->whereHas('orderDetails', function ($query) {
$query->whereHas('order', function ($q) {
$q->where('payment_status', 'paid');
$q->where('user_id', auth()->id());
});
})->paginate(15);
// $order_detail_products = OrderDetail::whereHas('order', function ($q) {
// $q->where('payment_status', 'paid');
// $q->where('user_id', auth()->id());
// })->with(['product' => function ($query) {
// $query->where('digital', 1);
// }])
// ->paginate(1);
// $products = Product::with(['orderDetails', 'orderDetails.order' => function($q) {
// $q->where('payment_status', 'paid');
// $q->where('user_id', auth()->id());
// }])
// ->where('digital', 1)
// ->paginate(15);
// dd($order_detail_products);
return PurchasedResource::collection($order_detail_products);
}
public function re_order($id) {
$user_id = auth()->user()->id;
$success_msgs = [];
$failed_msgs = [];
$carts = Cart::where('user_id', auth()->user()->id)->get();
$check_auction_in_cart = CartUtility::check_auction_in_cart($carts);
if ($check_auction_in_cart) {
array_push($failed_msgs, translate('Remove auction product from cart to add products.'));
return response()->json([
'success_msgs' => $success_msgs,
'failed_msgs' => $failed_msgs
]);
}
$order = Order::findOrFail($id);
$data['user_id'] = $user_id;
foreach ($order->orderDetails as $key => $orderDetail) {
$product = $orderDetail->product;
if (
!$product || $product->published == 0 ||
$product->approved == 0 || ($product->wholesale_product && !addon_is_activated("wholesale"))
) {
array_push($failed_msgs, translate('An item from this order is not available now.'));
continue;
}
if ($product->auction_product == 1) {
array_push($failed_msgs, translate('You can not re order an auction product.'));
break;
}
// If product min qty is greater then the ordered qty, then update the order qty
$order_qty = $orderDetail->quantity;
if ($product->digital == 0 && $order_qty < $product->min_qty) {
$order_qty = $product->min_qty;
}
$cart = Cart::firstOrNew([
'variation' => $orderDetail->variation,
'user_id' => $user_id,
'product_id' => $product->id
]);
$product_stock = $product->stocks->where('variant', $orderDetail->variation)->first();
if ($product_stock) {
$quantity = 1;
if ($product->digital != 1) {
$quantity = $product_stock->qty;
if ($quantity > 0) {
if ($cart->exists) {
$order_qty = $cart->quantity + $order_qty;
}
//If order qty is greater then the product stock, set order qty = current product stock qty
$quantity = ($quantity >= $order_qty) ? $order_qty : $quantity;
} else {
array_push($failed_msgs, $product->getTranslation('name') . ' ' . translate('is stock out.'));
continue;
}
}
$price = CartUtility::get_price($product, $product_stock, $quantity);
$tax = CartUtility::tax_calculation($product, $price);
CartUtility::save_cart_data($cart, $product, $price, $tax, $quantity);
array_push($success_msgs, $product->getTranslation('name') . ' ' . translate('added to cart.'));
} else {
array_push($failed_msgs, $product->getTranslation('name') . ' ' . translate(' is stock out.'));
}
}
return response()->json([
'success_msgs' => $success_msgs,
'failed_msgs' => $failed_msgs
]);
}
}
|