[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: MyPurchaseController.php
<?php namespace App\Http\Controllers\Panel\Store; use App\Http\Controllers\Controller; use App\Models\Gift; use App\Models\ProductOrder; use App\Models\Sale; use App\User; use Illuminate\Http\Request; use Illuminate\Support\Facades\DB; class MyPurchaseController extends Controller { public function index(Request $request) { $this->authorize("panel_products_purchases"); $user = auth()->user(); $giftsIds = Gift::query() ->where(function ($query) use ($user) { $query->where('email', $user->email); $query->orWhere('user_id', $user->id); }) ->where('status', 'active') ->whereNotNull('product_id') ->where(function ($query) { $query->whereNull('date'); $query->orWhere('date', '<', time()); }) ->whereHas('sale') ->pluck('id') ->toArray(); $query = ProductOrder::query() ->where(function ($query) use ($user, $giftsIds) { $query->where('product_orders.buyer_id', $user->id); $query->orWhereIn('product_orders.gift_id', $giftsIds); }) ->where('product_orders.status', '!=', 'pending') ->whereHas('sale', function ($query) { $query->whereIn('type', ['product', 'gift']); $query->where('access_to_purchased_item', true); $query->whereNull('refund_at'); }); $totalOrders = deepClone($query)->count(); $pendingOrders = deepClone($query)->where(function ($query) { $query->where('status', ProductOrder::$waitingDelivery) ->orWhere('status', ProductOrder::$shipped); })->count(); $canceledOrders = deepClone($query)->where('status', ProductOrder::$canceled)->count(); $totalPurchase = deepClone($query) ->join('sales', 'sales.product_order_id', 'product_orders.id') ->select(DB::raw("sum(total_amount) as totalAmount")) ->first(); $sellerIds = deepClone($query)->pluck('seller_id')->toArray(); $sellers = User::select('id', 'full_name') ->whereIn('id', array_unique($sellerIds)) ->get(); $query = $this->filters($query, $request); $orders = $query->orderBy('created_at', 'desc') ->with([ 'product', 'sale', 'seller' => function ($query) { $query->select('id', 'full_name', 'email', 'mobile', 'avatar'); } ]) ->paginate(10); $data = [ 'pageTitle' => trans('update.product_purchases_lists_page_title'), 'totalOrders' => $totalOrders, 'pendingOrders' => $pendingOrders, 'canceledOrders' => $canceledOrders, 'totalPurchase' => $totalPurchase ? $totalPurchase->totalAmount : 0, 'sellers' => $sellers, 'orders' => $orders, ]; return view('web.default.panel.store.my-purchases', $data); } private function filters($query, $request) { $from = $request->input('from'); $to = $request->input('to'); $seller_id = $request->input('seller_id'); $type = $request->input('type'); $status = $request->input('status'); $query = fromAndToDateFilter($from, $to, $query, 'created_at'); if (!empty($seller_id) and $seller_id != 'all') { $query->where('seller_id', $seller_id); } if (isset($type) and $type !== 'all') { $query->whereHas('product', function ($query) use ($type) { $query->where('type', $type); }); } if (isset($status) and $status !== 'all') { $query->where('status', $status); } return $query; } public function getProductOrder($saleId, $orderId) { $user = auth()->user(); $order = ProductOrder::where('buyer_id', $user->id) ->where('id', $orderId) ->where('sale_id', $saleId) ->first(); if (!empty($order)) { $shippingTrackingUrl = getStoreSettings('shipping_tracking_url'); $order->address = $order->buyer->getAddress(true); return response()->json([ 'order' => $order, 'shipping_tracking_url' => $shippingTrackingUrl ]); } abort(403); } public function setGotTheParcel($saleId, $orderId) { $user = auth()->user(); $order = ProductOrder::where('buyer_id', $user->id) ->where('id', $orderId) ->where('sale_id', $saleId) ->first(); if (!empty($order)) { $order->update([ 'status' => ProductOrder::$success ]); $product = $order->product; $buyer = $order->buyer; $notifyOptions = [ '[p.title]' => $product->title, '[u.name]' => $buyer->full_name ]; sendNotification('product_receive_shipment', $notifyOptions, $order->seller_id); return response()->json([ 'code' => 200 ]); } return response()->json([ 'code' => 422 ]); } public function invoice($saleId, $orderId) { $user = auth()->user(); $giftsIds = Gift::query() ->where(function ($query) use ($user) { $query->where('email', $user->email); $query->orWhere('user_id', $user->id); }) ->where('status', 'active') ->whereNotNull('product_id') ->where(function ($query) { $query->whereNull('date'); $query->orWhere('date', '<', time()); }) ->whereHas('sale') ->pluck('id') ->toArray(); $productOrder = ProductOrder::query() ->where(function ($query) use ($user, $giftsIds) { $query->where('buyer_id', $user->id); $query->orWhereIn('gift_id', $giftsIds); }) ->where('id', $orderId) ->where('sale_id', $saleId) ->first(); if (!empty($productOrder)) { if (!empty($productOrder->gift_id)) { $gift = $productOrder->gift; $productOrder->buyer = $gift->user; } $data = [ 'pageTitle' => trans('webinars.invoice_page_title'), 'order' => $productOrder, 'product' => $productOrder->product, 'sale' => $productOrder->sale, 'seller' => $productOrder->seller, 'buyer' => $productOrder->buyer, ]; return view('web.default.panel.store.invoice', $data); } abort(404); } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: premium320.web-hosting.com
Server IP: 66.29.153.54
PHP Version: 8.2.29
Server Software: LiteSpeed
System: Linux premium320.web-hosting.com 4.18.0-553.50.1.lve.el8.x86_64 #1 SMP Thu Apr 17 19:10:24 UTC 2025 x86_64
HDD Total: 97.87 GB
HDD Free: 76.85 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
No
git:
Yes
User Info
Username: aoneqssk
User ID (UID): 1285
Group ID (GID): 1290
Script Owner UID: 1285
Current Dir Owner: 1285