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

101 lines
3.5 KiB
PHP

<?php
namespace App\Http\Controllers;
use DB;
use Auth;
use App\Models\Order;
use App\Models\Upload;
use App\Models\Product;
use Illuminate\Http\Request;
class PurchaseHistoryController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
$orders = Order::with('orderDetails')->where('user_id', Auth::user()->id)->orderBy('code', 'desc')->paginate(10);
return view('frontend.user.purchase_history', compact('orders'));
}
public function digital_index()
{
$orders = DB::table('orders')
->orderBy('code', 'desc')
->join('order_details', 'orders.id', '=', 'order_details.order_id')
->join('products', 'order_details.product_id', '=', 'products.id')
->where('orders.user_id', Auth::user()->id)
->where('products.digital', '1')
->where('order_details.payment_status', 'paid')
->select('order_details.id')
->paginate(15);
return view('frontend.user.digital_purchase_history', compact('orders'));
}
public function purchase_history_details($id)
{
$order = Order::findOrFail(decrypt($id));
$order->delivery_viewed = 1;
$order->payment_status_viewed = 1;
$order->save();
return view('frontend.user.order_details_customer', compact('order'));
}
public function download(Request $request)
{
$product = Product::findOrFail(decrypt($request->id));
$downloadable = false;
foreach (Auth::user()->orders as $key => $order) {
foreach ($order->orderDetails as $key => $orderDetail) {
if ($orderDetail->product_id == $product->id && $orderDetail->payment_status == 'paid') {
$downloadable = true;
break;
}
}
}
if ($downloadable) {
$upload = Upload::findOrFail($product->file_name);
if (env('FILESYSTEM_DRIVER') == "s3") {
return \Storage::disk('s3')->download($upload->file_name, $upload->file_original_name . "." . $upload->extension);
} else {
if (file_exists(base_path('public/' . $upload->file_name))) {
return response()->download(base_path('public/' . $upload->file_name));
}
}
} else {
flash(translate('You cannot download this product at this product.'))->success();
}
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function order_cancel($id)
{
$order = Order::where('id', $id)->where('user_id', auth()->user()->id)->first();
if($order && ($order->delivery_status == 'pending' && $order->payment_status == 'unpaid')) {
$order->delivery_status = 'cancelled';
$order->save();
foreach ($order->orderDetails as $key => $orderDetail) {
$orderDetail->delivery_status = 'cancelled';
$orderDetail->save();
product_restock($orderDetail);
}
flash(translate('Order has been canceled successfully'))->success();
} else {
flash(translate('Something went wrong'))->error();
}
return back();
}
}