Files
elcaribe/app/Http/Controllers/Seller/OrderController.php
2023-08-07 15:52:04 -04:00

193 lines
6.4 KiB
PHP

<?php
namespace App\Http\Controllers\Seller;
use App\Models\Order;
use App\Models\ProductStock;
use App\Models\SmsTemplate;
use App\Models\User;
use App\Utility\NotificationUtility;
use App\Utility\SmsUtility;
use Illuminate\Http\Request;
use Auth;
use DB;
class OrderController extends Controller
{
/**
* Display a listing of the resource to seller.
*
* @return \Illuminate\Http\Response
*/
public function index(Request $request)
{
$payment_status = null;
$delivery_status = null;
$sort_search = null;
$orders = DB::table('orders')
->orderBy('id', 'desc')
->where('seller_id', Auth::user()->id)
->select('orders.id')
->distinct();
if ($request->payment_status != null) {
$orders = $orders->where('payment_status', $request->payment_status);
$payment_status = $request->payment_status;
}
if ($request->delivery_status != null) {
$orders = $orders->where('delivery_status', $request->delivery_status);
$delivery_status = $request->delivery_status;
}
if ($request->has('search')) {
$sort_search = $request->search;
$orders = $orders->where('code', 'like', '%' . $sort_search . '%');
}
$orders = $orders->paginate(15);
foreach ($orders as $key => $value) {
$order = Order::find($value->id);
$order->viewed = 1;
$order->save();
}
return view('seller.orders.index', compact('orders', 'payment_status', 'delivery_status', 'sort_search'));
}
public function show($id)
{
$order = Order::findOrFail(decrypt($id));
$order_shipping_address = json_decode($order->shipping_address);
$delivery_boys = User::where('city', $order_shipping_address->city)
->where('user_type', 'delivery_boy')
->get();
$order->viewed = 1;
$order->save();
return view('seller.orders.show', compact('order', 'delivery_boys'));
}
// Update Delivery Status
public function update_delivery_status(Request $request)
{
$order = Order::findOrFail($request->order_id);
$order->delivery_viewed = '0';
$order->delivery_status = $request->status;
$order->save();
if ($request->status == 'cancelled' && $order->payment_type == 'wallet') {
$user = User::where('id', $order->user_id)->first();
$user->balance += $order->grand_total;
$user->save();
}
foreach ($order->orderDetails->where('seller_id', Auth::user()->id) as $key => $orderDetail) {
$orderDetail->delivery_status = $request->status;
$orderDetail->save();
if ($request->status == 'cancelled') {
$variant = $orderDetail->variation;
if ($orderDetail->variation == null) {
$variant = '';
}
$product_stock = ProductStock::where('product_id', $orderDetail->product_id)
->where('variant', $variant)
->first();
if ($product_stock != null) {
$product_stock->qty += $orderDetail->quantity;
$product_stock->save();
}
}
}
if (addon_is_activated('otp_system') && SmsTemplate::where('identifier', 'delivery_status_change')->first()->status == 1) {
try {
SmsUtility::delivery_status_change(json_decode($order->shipping_address)->phone, $order);
} catch (\Exception $e) {
}
}
//sends Notifications to user
NotificationUtility::sendNotification($order, $request->status);
if (get_setting('google_firebase') == 1 && $order->user->device_token != null) {
$request->device_token = $order->user->device_token;
$request->title = "Order updated !";
$status = str_replace("_", "", $order->delivery_status);
$request->text = " Your order {$order->code} has been {$status}";
$request->type = "order";
$request->id = $order->id;
$request->user_id = $order->user->id;
NotificationUtility::sendFirebaseNotification($request);
}
if (addon_is_activated('delivery_boy')) {
if (Auth::user()->user_type == 'delivery_boy') {
$deliveryBoyController = new DeliveryBoyController;
$deliveryBoyController->store_delivery_history($order);
}
}
return 1;
}
// Update Payment Status
public function update_payment_status(Request $request)
{
$order = Order::findOrFail($request->order_id);
$order->payment_status_viewed = '0';
$order->save();
foreach ($order->orderDetails->where('seller_id', Auth::user()->id) as $key => $orderDetail) {
$orderDetail->payment_status = $request->status;
$orderDetail->save();
}
$status = 'paid';
foreach ($order->orderDetails as $key => $orderDetail) {
if ($orderDetail->payment_status != 'paid') {
$status = 'unpaid';
}
}
$order->payment_status = $status;
$order->save();
if ($order->payment_status == 'paid' && $order->commission_calculated == 0) {
calculateCommissionAffilationClubPoint($order);
}
//sends Notifications to user
NotificationUtility::sendNotification($order, $request->status);
if (get_setting('google_firebase') == 1 && $order->user->device_token != null) {
$request->device_token = $order->user->device_token;
$request->title = "Order updated !";
$status = str_replace("_", "", $order->payment_status);
$request->text = " Your order {$order->code} has been {$status}";
$request->type = "order";
$request->id = $order->id;
$request->user_id = $order->user->id;
NotificationUtility::sendFirebaseNotification($request);
}
if (addon_is_activated('otp_system') && SmsTemplate::where('identifier', 'payment_status_change')->first()->status == 1) {
try {
SmsUtility::payment_status_change(json_decode($order->shipping_address)->phone, $order);
} catch (\Exception $e) {
}
}
return 1;
}
}