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')); } }