You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

89 lines
3.1 KiB

<?php
namespace App\Http\Controllers\Admin;
use App\CentralLogics\CustomerLogic;
use App\CentralLogics\Helpers;
use App\Http\Controllers\Controller;
use App\Models\BusinessSetting;
use App\Models\WalletTransaction;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Validator;
use Brian2694\Toastr\Facades\Toastr;
use Illuminate\Support\Facades\Mail;
class CustomerWalletController extends Controller
{
public function add_fund_view()
{
if(BusinessSetting::where('key','wallet_status')->first()->value != 1)
{
Toastr::error(translate('messages.customer_wallet_disable_warning_admin'));
return back();
}
return view('admin-views.customer.wallet.add_fund');
}
public function add_fund(Request $request)
{
$validator = Validator::make($request->all(), [
'customer_id'=>'exists:users,id',
'amount'=>'numeric|min:.01',
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)]);
}
$wallet_transaction = CustomerLogic::create_wallet_transaction($request->customer_id, $request->amount, 'add_fund_by_admin',$request->referance);
if($wallet_transaction)
{
try{
if(config('mail.status')) {
Mail::to($wallet_transaction->user->email)->send(new \App\Mail\AddFundToWallet($wallet_transaction));
}
}catch(\Exception $ex)
{
info($ex);
}
return response()->json([], 200);
}
return response()->json(['errors'=>[
'message'=>translate('messages.failed_to_create_transaction')
]], 200);
}
public function report(Request $request)
{
$data = WalletTransaction::selectRaw('sum(credit) as total_credit, sum(debit) as total_debit')
->when(($request->from && $request->to),function($query)use($request){
$query->whereBetween('created_at', [$request->from.' 00:00:00', $request->to.' 23:59:59']);
})
->when($request->transaction_type, function($query)use($request){
$query->where('transaction_type',$request->transaction_type);
})
->when($request->customer_id, function($query)use($request){
$query->where('user_id',$request->customer_id);
})
->get();
$transactions = WalletTransaction::
when(($request->from && $request->to),function($query)use($request){
$query->whereBetween('created_at', [$request->from.' 00:00:00', $request->to.' 23:59:59']);
})
->when($request->transaction_type, function($query)use($request){
$query->where('transaction_type',$request->transaction_type);
})
->when($request->customer_id, function($query)use($request){
$query->where('user_id',$request->customer_id);
})
->whereNull('delivery_man_id')
->latest()
->paginate(config('default_pagination'));
return view('admin-views.customer.wallet.report', compact('data','transactions'));
}
}