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.
		
		
		
		
		
			
		
			
				
					
					
						
							590 lines
						
					
					
						
							24 KiB
						
					
					
				
			
		
		
	
	
							590 lines
						
					
					
						
							24 KiB
						
					
					
				<?php
 | 
						|
 | 
						|
namespace App\Http\Controllers\Admin;
 | 
						|
 | 
						|
use App\Models\Zone;
 | 
						|
use App\Models\Message;
 | 
						|
use App\Models\DMReview;
 | 
						|
use App\Models\UserInfo;
 | 
						|
use App\Models\DeliveryMan;
 | 
						|
use App\Models\Conversation;
 | 
						|
use App\Models\IncentiveLog;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use App\CentralLogics\Helpers;
 | 
						|
use App\Models\DeliveryManWallet;
 | 
						|
use App\Models\WalletTransaction;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
use App\Http\Controllers\Controller;
 | 
						|
use Brian2694\Toastr\Facades\Toastr;
 | 
						|
use Illuminate\Support\Facades\Mail;
 | 
						|
use Rap2hpoutre\FastExcel\FastExcel;
 | 
						|
use Illuminate\Support\Facades\Storage;
 | 
						|
use Illuminate\Support\Facades\Validator;
 | 
						|
 | 
						|
 | 
						|
class DeliveryManController extends Controller
 | 
						|
{
 | 
						|
    public function index()
 | 
						|
    {
 | 
						|
 | 
						|
        return view('admin-views.delivery-man.index');
 | 
						|
    }
 | 
						|
 | 
						|
    public function list(Request $request)
 | 
						|
    {
 | 
						|
        $zone_id = $request->query('zone_id', 'all');
 | 
						|
        $delivery_men = DeliveryMan::when(is_numeric($zone_id), function($query) use($zone_id){
 | 
						|
            return $query->where('zone_id', $zone_id);
 | 
						|
        })->with('zone')->where('type','zone_wise')->latest()->where('application_status','approved')->paginate(config('default_pagination'));
 | 
						|
        $zone = is_numeric($zone_id)?Zone::findOrFail($zone_id):null;
 | 
						|
        return view('admin-views.delivery-man.list', compact('delivery_men', 'zone'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function search(Request $request){
 | 
						|
        $key = explode(' ', $request['search']);
 | 
						|
        $delivery_men=DeliveryMan::where(function ($q) use ($key) {
 | 
						|
            foreach ($key as $value) {
 | 
						|
                $q->orWhere('f_name', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('l_name', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('email', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('phone', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('identity_number', 'like', "%{$value}%");
 | 
						|
            }
 | 
						|
        })->where('type','zone_wise')->where('application_status','approved')->get();
 | 
						|
        return response()->json([
 | 
						|
            'view'=>view('admin-views.delivery-man.partials._table',compact('delivery_men'))->render(),
 | 
						|
            'count'=>$delivery_men->count()
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    public function reviews_list(){
 | 
						|
        $reviews=DMReview::with(['delivery_man','customer'])->whereHas('delivery_man',function($query){
 | 
						|
            $query->where('type','zone_wise');
 | 
						|
        })->latest()->paginate(config('default_pagination'));
 | 
						|
        return view('admin-views.delivery-man.reviews-list',compact('reviews'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function preview(Request $request, $id, $tab='info')
 | 
						|
    {
 | 
						|
        $dm = DeliveryMan::with(['reviews'])->where('type','zone_wise')->where(['id' => $id])->first();
 | 
						|
        if($tab == 'info')
 | 
						|
        {
 | 
						|
            $reviews=DMReview::where(['delivery_man_id'=>$id])->latest()->paginate(config('default_pagination'));
 | 
						|
            return view('admin-views.delivery-man.view.info', compact('dm', 'reviews'));
 | 
						|
        }
 | 
						|
        else if($tab == 'transaction')
 | 
						|
        {
 | 
						|
            $date = $request->query('date');
 | 
						|
            return view('admin-views.delivery-man.view.transaction', compact('dm', 'date'));
 | 
						|
        }
 | 
						|
        else if($tab == 'timelog')
 | 
						|
        {
 | 
						|
            $from = $request->query('from', null);
 | 
						|
            $to = $request->query('to', null);
 | 
						|
            $timelogs = $dm->time_logs()->when($from && $to, function($query)use($from, $to){
 | 
						|
                $query->whereBetween('date', [$from, $to]);
 | 
						|
            })->paginate(config('default_pagination'));
 | 
						|
            return view('admin-views.delivery-man.view.timelog', compact('dm', 'timelogs'));
 | 
						|
        }
 | 
						|
        else if($tab == 'conversation')
 | 
						|
        {
 | 
						|
            $user = UserInfo::where(['deliveryman_id' => $id])->first();
 | 
						|
            if($user){
 | 
						|
                $conversations = Conversation::with(['sender', 'receiver', 'last_message'])->WhereUser($user->id)->paginate(8);
 | 
						|
            }else{
 | 
						|
                $conversations = [];
 | 
						|
            }
 | 
						|
 | 
						|
            return view('admin-views.delivery-man.view.conversations', compact('conversations','dm'));
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function store(Request $request)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'f_name' => 'required|max:100',
 | 
						|
            'l_name' => 'nullable|max:100',
 | 
						|
            'identity_number' => 'required|max:30',
 | 
						|
            'email' => 'required|unique:delivery_men',
 | 
						|
            'phone' => 'required|regex:/^([0-9\s\-\+\(\)]*)$/|min:10|max:20|unique:delivery_men',
 | 
						|
            'zone_id' => 'required',
 | 
						|
            'earning' => 'required',
 | 
						|
            'password'=>'required|min:6',
 | 
						|
            'vehicle_id' => 'required',
 | 
						|
            'image' => 'nullable|max:2048',
 | 
						|
            'identity_image.*' => 'nullable|max:2048',
 | 
						|
 | 
						|
        ], [
 | 
						|
            'f_name.required' => translate('messages.first_name_is_required'),
 | 
						|
            'zone_id.required' => translate('messages.select_a_zone'),
 | 
						|
            'vehicle_id.required' => translate('messages.select_a_vehicle'),
 | 
						|
            'earning.required' => translate('messages.select_dm_type')
 | 
						|
        ]);
 | 
						|
 | 
						|
        if ($request->has('image')) {
 | 
						|
            $image_name = Helpers::upload('delivery-man/', 'png', $request->file('image'));
 | 
						|
        } else {
 | 
						|
            $image_name = 'def.png';
 | 
						|
        }
 | 
						|
 | 
						|
        $id_img_names = [];
 | 
						|
        if (!empty($request->file('identity_image'))) {
 | 
						|
            foreach ($request->identity_image as $img) {
 | 
						|
                $identity_image = Helpers::upload('delivery-man/', 'png', $img);
 | 
						|
                array_push($id_img_names, $identity_image);
 | 
						|
            }
 | 
						|
            $identity_image = json_encode($id_img_names);
 | 
						|
        } else {
 | 
						|
            $identity_image = json_encode([]);
 | 
						|
        }
 | 
						|
 | 
						|
        $dm = New DeliveryMan();
 | 
						|
        $dm->f_name = $request->f_name;
 | 
						|
        $dm->l_name = $request->l_name;
 | 
						|
        $dm->email = $request->email;
 | 
						|
        $dm->phone = $request->phone;
 | 
						|
        $dm->identity_number = $request->identity_number;
 | 
						|
        $dm->identity_type = $request->identity_type;
 | 
						|
        $dm->zone_id = $request->zone_id;
 | 
						|
        $dm->vehicle_id = $request->vehicle_id;
 | 
						|
        $dm->identity_image = $identity_image;
 | 
						|
        $dm->image = $image_name;
 | 
						|
        $dm->active = 0;
 | 
						|
        $dm->earning = $request->earning;
 | 
						|
        $dm->password = bcrypt($request->password);
 | 
						|
        $dm->save();
 | 
						|
 | 
						|
        Toastr::success(translate('messages.deliveryman_added_successfully'));
 | 
						|
        return redirect('admin/delivery-man/list');
 | 
						|
    }
 | 
						|
 | 
						|
    public function edit($id)
 | 
						|
    {
 | 
						|
        $delivery_man = DeliveryMan::find($id);
 | 
						|
        return view('admin-views.delivery-man.edit', compact('delivery_man'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function status(Request $request)
 | 
						|
    {
 | 
						|
        $delivery_man = DeliveryMan::find($request->id);
 | 
						|
        $delivery_man->status = $request->status;
 | 
						|
 | 
						|
        try
 | 
						|
        {
 | 
						|
            if($request->status == 0)
 | 
						|
            {   $delivery_man->auth_token = null;
 | 
						|
                if(isset($delivery_man->fcm_token))
 | 
						|
                {
 | 
						|
                    $data = [
 | 
						|
                        'title' => translate('messages.suspended'),
 | 
						|
                        'description' => translate('messages.your_account_has_been_suspended'),
 | 
						|
                        'order_id' => '',
 | 
						|
                        'image' => '',
 | 
						|
                        'type'=> 'block'
 | 
						|
                    ];
 | 
						|
                    Helpers::send_push_notif_to_device($delivery_man->fcm_token, $data);
 | 
						|
 | 
						|
                    DB::table('user_notifications')->insert([
 | 
						|
                        'data'=> json_encode($data),
 | 
						|
                        'delivery_man_id'=>$delivery_man->id,
 | 
						|
                        'created_at'=>now(),
 | 
						|
                        'updated_at'=>now()
 | 
						|
                    ]);
 | 
						|
                }
 | 
						|
 | 
						|
            }
 | 
						|
 | 
						|
        }
 | 
						|
        catch (\Exception $e) {
 | 
						|
            Toastr::warning(translate('messages.push_notification_faild'));
 | 
						|
        }
 | 
						|
 | 
						|
        $delivery_man->save();
 | 
						|
 | 
						|
        Toastr::success(translate('messages.deliveryman_status_updated'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function reviews_status(Request $request)
 | 
						|
    {
 | 
						|
        $review = DMReview::find($request->id);
 | 
						|
        $review->status = $request->status;
 | 
						|
        $review->save();
 | 
						|
        Toastr::success(translate('messages.review_visibility_updated'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function earning(Request $request)
 | 
						|
    {
 | 
						|
        $delivery_man = DeliveryMan::find($request->id);
 | 
						|
        $delivery_man->earning = $request->status;
 | 
						|
 | 
						|
        $delivery_man->save();
 | 
						|
 | 
						|
        Toastr::success(translate('messages.deliveryman_type_updated'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function update_application(Request $request)
 | 
						|
    {
 | 
						|
        $delivery_man = DeliveryMan::findOrFail($request->id);
 | 
						|
        $delivery_man->application_status = $request->status;
 | 
						|
        if($request->status == 'approved') $delivery_man->status = 1;
 | 
						|
        $delivery_man->save();
 | 
						|
 | 
						|
        try{
 | 
						|
            if( config('mail.status')) {
 | 
						|
                Mail::to($request['email'])->send(new \App\Mail\SelfRegistration($request->status, $delivery_man->f_name.' '.$delivery_man->l_name));
 | 
						|
            }
 | 
						|
 | 
						|
        }catch(\Exception $ex){
 | 
						|
            info($ex);
 | 
						|
        }
 | 
						|
 | 
						|
 | 
						|
        Toastr::success(translate('messages.application_status_updated_successfully'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function update(Request $request, $id)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'f_name' => 'required|max:100',
 | 
						|
            'l_name' => 'nullable|max:100',
 | 
						|
            'identity_number' => 'required|max:30',
 | 
						|
            'email' => 'required|unique:delivery_men,email,'.$id,
 | 
						|
            'phone' => 'required|regex:/^([0-9\s\-\+\(\)]*)$/|min:10|unique:delivery_men,phone,'.$id,
 | 
						|
            'vehicle_id' => 'required',
 | 
						|
            'earning' => 'required',
 | 
						|
            'password' => 'nullable|min:6',
 | 
						|
            'image' => 'nullable|max:2048',
 | 
						|
            'identity_image.*' => 'nullable|max:2048',
 | 
						|
        ], [
 | 
						|
            'f_name.required' => translate('messages.first_name_is_required'),
 | 
						|
            'earning.required' => translate('messages.select_dm_type'),
 | 
						|
            'vehicle_id.required' => translate('messages.select_a_vehicle'),
 | 
						|
 | 
						|
        ]);
 | 
						|
 | 
						|
        $delivery_man = DeliveryMan::find($id);
 | 
						|
 | 
						|
        if ($request->has('image')) {
 | 
						|
            $image_name = Helpers::update('delivery-man/', $delivery_man->image, 'png', $request->file('image'));
 | 
						|
        } else {
 | 
						|
            $image_name = $delivery_man['image'];
 | 
						|
        }
 | 
						|
 | 
						|
        if ($request->has('identity_image')){
 | 
						|
            foreach (json_decode($delivery_man['identity_image'], true) as $img) {
 | 
						|
                if (Storage::disk('public')->exists('delivery-man/' . $img)) {
 | 
						|
                    Storage::disk('public')->delete('delivery-man/' . $img);
 | 
						|
                }
 | 
						|
            }
 | 
						|
            $img_keeper = [];
 | 
						|
            foreach ($request->identity_image as $img) {
 | 
						|
                $identity_image = Helpers::upload('delivery-man/', 'png', $img);
 | 
						|
                array_push($img_keeper, $identity_image);
 | 
						|
            }
 | 
						|
            $identity_image = json_encode($img_keeper);
 | 
						|
        } else {
 | 
						|
            $identity_image = $delivery_man['identity_image'];
 | 
						|
        }
 | 
						|
 | 
						|
        $delivery_man->vehicle_id = $request->vehicle_id;
 | 
						|
 | 
						|
        $delivery_man->f_name = $request->f_name;
 | 
						|
        $delivery_man->l_name = $request->l_name;
 | 
						|
        $delivery_man->email = $request->email;
 | 
						|
        $delivery_man->phone = $request->phone;
 | 
						|
        $delivery_man->identity_number = $request->identity_number;
 | 
						|
        $delivery_man->identity_type = $request->identity_type;
 | 
						|
        $delivery_man->zone_id = $request->zone_id;
 | 
						|
        $delivery_man->identity_image = $identity_image;
 | 
						|
        $delivery_man->image = $image_name;
 | 
						|
        $delivery_man->earning = $request->earning;
 | 
						|
        $delivery_man->password = strlen($request->password)>1?bcrypt($request->password):$delivery_man['password'];
 | 
						|
        $delivery_man->save();
 | 
						|
        Toastr::success(translate('messages.deliveryman_updated_successfully'));
 | 
						|
        return redirect('admin/delivery-man/list');
 | 
						|
    }
 | 
						|
 | 
						|
    public function delete(Request $request)
 | 
						|
    {
 | 
						|
        $delivery_man = DeliveryMan::find($request->id);
 | 
						|
        if (Storage::disk('public')->exists('delivery-man/' . $delivery_man['image'])) {
 | 
						|
            Storage::disk('public')->delete('delivery-man/' . $delivery_man['image']);
 | 
						|
        }
 | 
						|
 | 
						|
        foreach (json_decode($delivery_man['identity_image'], true) as $img) {
 | 
						|
            if (Storage::disk('public')->exists('delivery-man/' . $img)) {
 | 
						|
                Storage::disk('public')->delete('delivery-man/' . $img);
 | 
						|
            }
 | 
						|
        }
 | 
						|
        if($delivery_man->userinfo){
 | 
						|
 | 
						|
            $delivery_man->userinfo->delete();
 | 
						|
        }
 | 
						|
        $delivery_man->delete();
 | 
						|
        Toastr::success(translate('messages.deliveryman_deleted_successfully'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function get_deliverymen(Request $request){
 | 
						|
        $key = explode(' ', $request->q);
 | 
						|
        $zone_ids = isset($request->zone_ids)?(count($request->zone_ids)>0?$request->zone_ids:[]):0;
 | 
						|
        $data=DeliveryMan::when($zone_ids, function($query) use($zone_ids){
 | 
						|
            return $query->whereIn('zone_id', $zone_ids);
 | 
						|
        })
 | 
						|
        ->when($request->earning, function($query){
 | 
						|
            return $query->earning();
 | 
						|
        })
 | 
						|
        ->where(function ($q) use ($key) {
 | 
						|
            foreach ($key as $value) {
 | 
						|
                $q->orWhere('f_name', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('l_name', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('email', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('phone', 'like', "%{$value}%")
 | 
						|
                    ->orWhere('identity_number', 'like', "%{$value}%");
 | 
						|
            }
 | 
						|
        })->active()->limit(8)->get(['id',DB::raw('CONCAT(f_name, " ", l_name) as text')]);
 | 
						|
        return response()->json($data);
 | 
						|
    }
 | 
						|
 | 
						|
    public function get_account_data(DeliveryMan $deliveryman)
 | 
						|
    {
 | 
						|
        $wallet = $deliveryman->wallet;
 | 
						|
        $cash_in_hand = 0;
 | 
						|
        $balance = 0;
 | 
						|
 | 
						|
        if($wallet)
 | 
						|
        {
 | 
						|
            $cash_in_hand = $wallet->collected_cash;
 | 
						|
            $balance = round($wallet->total_earning - $wallet->total_withdrawn - $wallet->pending_withdraw, config('round_up_to_digit'));
 | 
						|
        }
 | 
						|
        return response()->json(['cash_in_hand'=>$cash_in_hand, 'earning_balance'=>$balance], 200);
 | 
						|
 | 
						|
    }
 | 
						|
 | 
						|
    public function get_conversation_list(Request $request)
 | 
						|
    {
 | 
						|
        $user = UserInfo::where(['deliveryman_id' => $request->user_id])->first();
 | 
						|
        $dm = DeliveryMan::find($request->user_id);
 | 
						|
        if($user){
 | 
						|
            $conversations = Conversation::with(['sender', 'receiver', 'last_message'])->WhereUser($user->id);
 | 
						|
            if($request->query('key')) {
 | 
						|
                $key = explode(' ', $request->get('key'));
 | 
						|
                $conversations = $conversations->where(function($qu)use($key){
 | 
						|
                    $qu->where(function($q)use($key){
 | 
						|
                        $q->where('sender_type','!=', 'delivery_man')->whereHas('sender',function($query)use($key){
 | 
						|
                            foreach ($key as $value) {
 | 
						|
                                $query->where('f_name', 'like', "%{$value}%")->orWhere('l_name', 'like', "%{$value}%")->orWhere('phone', 'like', "%{$value}%");
 | 
						|
                            }
 | 
						|
                        });
 | 
						|
                    })->orWhere(function($q)use($key){
 | 
						|
                        $q->where('receiver_type','!=', 'delivery_man')->whereHas('receiver',function($query)use($key){
 | 
						|
                            foreach ($key as $value) {
 | 
						|
                                $query->where('f_name', 'like', "%{$value}%")->orWhere('l_name', 'like', "%{$value}%")->orWhere('phone', 'like', "%{$value}%");
 | 
						|
                            }
 | 
						|
                        });
 | 
						|
                    });
 | 
						|
                });
 | 
						|
            }
 | 
						|
            $conversations = $conversations->WhereUserType('delivery_man')->paginate(8);
 | 
						|
        }else{
 | 
						|
            $conversations = [];
 | 
						|
        }
 | 
						|
 | 
						|
        $view = view('admin-views.delivery-man.partials._conversation_list',compact('conversations','dm'))->render();
 | 
						|
        return response()->json(['html'=>$view]);
 | 
						|
 | 
						|
    }
 | 
						|
 | 
						|
    public function conversation_view($conversation_id,$user_id)
 | 
						|
    {
 | 
						|
        $convs = Message::where(['conversation_id' => $conversation_id])->get();
 | 
						|
        $conversation = Conversation::find($conversation_id);
 | 
						|
        $receiver = UserInfo::find($conversation->receiver_id);
 | 
						|
        $sender = UserInfo::find($conversation->sender_id);
 | 
						|
        $user = UserInfo::find($user_id);
 | 
						|
        return response()->json([
 | 
						|
            'view' => view('admin-views.delivery-man.partials._conversations', compact('convs', 'user', 'receiver'))->render()
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
    public function dm_list_export(Request $request){
 | 
						|
 | 
						|
        $withdraw_request = DeliveryMan::where('type','zone_wise')->orderBy('id','desc')->get();
 | 
						|
        if ($request->type == 'excel') {
 | 
						|
            return (new FastExcel(Helpers::export_d_man($withdraw_request)))->download('deliveryman_list.xlsx');
 | 
						|
        } elseif ($request->type == 'csv') {
 | 
						|
            return (new FastExcel(Helpers::export_d_man($withdraw_request)))->download('deliveryman_list.csv');
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    public function pending(Request $request)
 | 
						|
    {
 | 
						|
        $key = explode(' ', $request['search']);
 | 
						|
        $zone_id = $request->query('zone_id', 'all');
 | 
						|
        $delivery_men = DeliveryMan::when(is_numeric($zone_id), function($query) use($zone_id){
 | 
						|
            return $query->where('zone_id', $zone_id);
 | 
						|
        })
 | 
						|
        ->when(isset($key),function($query)use($key){
 | 
						|
            $query->where(function($q)use($key){
 | 
						|
                foreach ($key as $value) {
 | 
						|
                    $q->orWhere('f_name', 'like', "%{$value}%")
 | 
						|
                ->orWhere('l_name', 'like', "%{$value}%")
 | 
						|
                ->orWhere('email', 'like', "%{$value}%")
 | 
						|
                ->orWhere('phone', 'like', "%{$value}%")
 | 
						|
                ->orWhere('identity_number', 'like', "%{$value}%");
 | 
						|
                }
 | 
						|
            });
 | 
						|
        })
 | 
						|
        ->with('zone')->where('type','zone_wise')->where('application_status', 'pending')->latest()->paginate(config('default_pagination'));
 | 
						|
        $zone = is_numeric($zone_id)?Zone::findOrFail($zone_id):null;
 | 
						|
        return view('admin-views.delivery-man.pending_list', compact('delivery_men', 'zone'));
 | 
						|
 | 
						|
 | 
						|
    }
 | 
						|
    public function denied(Request $request)
 | 
						|
    {
 | 
						|
        $key = explode(' ', $request['search']);
 | 
						|
        $zone_id = $request->query('zone_id', 'all');
 | 
						|
        $delivery_men = DeliveryMan::when(is_numeric($zone_id), function($query) use($zone_id){
 | 
						|
            return $query->where('zone_id', $zone_id);
 | 
						|
        })
 | 
						|
        ->when(isset($key),function($query)use($key){
 | 
						|
            $query->where(function($q)use($key){
 | 
						|
                foreach ($key as $value) {
 | 
						|
                    $q->orWhere('f_name', 'like', "%{$value}%")
 | 
						|
                ->orWhere('l_name', 'like', "%{$value}%")
 | 
						|
                ->orWhere('email', 'like', "%{$value}%")
 | 
						|
                ->orWhere('phone', 'like', "%{$value}%")
 | 
						|
                ->orWhere('identity_number', 'like', "%{$value}%");
 | 
						|
                }
 | 
						|
            });
 | 
						|
        })
 | 
						|
        ->with('zone')->where('type','zone_wise')->where('application_status', 'denied')->latest()->paginate(config('default_pagination'));
 | 
						|
        $zone = is_numeric($zone_id)?Zone::findOrFail($zone_id):null;
 | 
						|
        return view('admin-views.delivery-man.denied', compact('delivery_men', 'zone'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function get_incentives(Request $request)
 | 
						|
    {
 | 
						|
        $incentives = IncentiveLog::when($request->search, function ($query) use ($request) {
 | 
						|
            $key = explode(' ', $request->search);
 | 
						|
            $query->whereHas('deliveryman', function ($query) use ($key) {
 | 
						|
                $query->where(function ($q) use ($key) {
 | 
						|
                    foreach ($key as $value) {
 | 
						|
                        $q->orWhere('f_name', 'like', "%{$value}%");
 | 
						|
                        $q->orWhere('l_name', 'like', "%{$value}%");
 | 
						|
                        $q->orWhere('phone', 'like', "%{$value}%");
 | 
						|
                        $q->orWhere('email', 'like', "%{$value}%");
 | 
						|
                    }
 | 
						|
                });
 | 
						|
            });
 | 
						|
        })
 | 
						|
            ->where('status', '!=', 'pending')
 | 
						|
            ->latest()->paginate(config('default_pagination'));
 | 
						|
        return view('admin-views.delivery-man.incentive', compact('incentives'));
 | 
						|
    }
 | 
						|
    public function pending_incentives(Request $request)
 | 
						|
    {
 | 
						|
        $incentives = IncentiveLog::
 | 
						|
        when($request->search, function ($query) use ($request) {
 | 
						|
            $key = explode(' ', $request->search);
 | 
						|
            $query->whereHas('deliveryman', function ($query) use ($key) {
 | 
						|
                $query->where(function ($q) use ($key) {
 | 
						|
                    foreach ($key as $value) {
 | 
						|
                        $q->orWhere('f_name', 'like', "%{$value}%");
 | 
						|
                        $q->orWhere('l_name', 'like', "%{$value}%");
 | 
						|
                        $q->orWhere('phone', 'like', "%{$value}%");
 | 
						|
                        $q->orWhere('email', 'like', "%{$value}%");
 | 
						|
                    }
 | 
						|
                });
 | 
						|
            });
 | 
						|
        })
 | 
						|
            ->whereStatus('pending')
 | 
						|
            ->latest()->paginate(config('default_pagination'));
 | 
						|
        return view('admin-views.delivery-man.incentive', compact('incentives'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function update_incentive_status(Request $request)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'status' => 'required|in:denied',
 | 
						|
            'id' => 'required'
 | 
						|
        ]);
 | 
						|
 | 
						|
        $incentive = IncentiveLog::findOrFail($request->id);
 | 
						|
 | 
						|
        if ($incentive->status == "pending") {
 | 
						|
            $incentive->status = $request->status;
 | 
						|
            $incentive->save();
 | 
						|
            Toastr::success(translate('messages.incentive_denied'));
 | 
						|
            return back();
 | 
						|
        }
 | 
						|
 | 
						|
    }
 | 
						|
 | 
						|
    public function update_all_incentive_status(Request $request)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            'incentive_id' => 'required'
 | 
						|
        ]);
 | 
						|
        $incentives = IncentiveLog::whereIn('id', $request->incentive_id)->get();
 | 
						|
        foreach ($incentives as $incentive) {
 | 
						|
            Helpers::dm_wallet_transaction($incentive->delivery_man_id, $incentive->incentive, null, 'incentive');
 | 
						|
            $incentive->status = "approved";
 | 
						|
            // $incentive->subsidy = $request->incentive[$incentive->id];
 | 
						|
            $incentive->save();
 | 
						|
        }
 | 
						|
        Toastr::success(translate('messages.succesfully_approved_incentive'));
 | 
						|
        return back();
 | 
						|
    }
 | 
						|
 | 
						|
    public function get_bonus(Request $request)
 | 
						|
    {
 | 
						|
        $data = WalletTransaction::where('transaction_type', 'dm_admin_bonus')
 | 
						|
        ->when($request->search, function ($query) use ($request) {
 | 
						|
                $query->where(function($query) use ($request) {
 | 
						|
                    $key = explode(' ', $request->search);
 | 
						|
                    $query->where(function ($q) use ($key) {
 | 
						|
                        foreach ($key as $value) {
 | 
						|
                            $q->Where('transaction_id', 'like', "%{$value}%");
 | 
						|
                        }
 | 
						|
                    })
 | 
						|
                    ->orWhereHas('delivery_man', function ($query) use ($key) {
 | 
						|
                        $query->where(function ($q) use ($key) {
 | 
						|
                            foreach ($key as $value) {
 | 
						|
                                $q->orWhere('f_name', 'like', "%{$value}%");
 | 
						|
                                $q->orWhere('l_name', 'like', "%{$value}%");
 | 
						|
                                $q->orWhere('phone', 'like', "%{$value}%");
 | 
						|
                                $q->orWhere('email', 'like', "%{$value}%");
 | 
						|
                            }
 | 
						|
                        });
 | 
						|
                    });
 | 
						|
                });
 | 
						|
        })
 | 
						|
 | 
						|
        ->paginate(config('default_pagination'));
 | 
						|
        return view('admin-views.delivery-man.bonus', compact('data'));
 | 
						|
    }
 | 
						|
 | 
						|
    public function add_bonus(Request $request)
 | 
						|
    {
 | 
						|
        $validator = Validator::make($request->all(), [
 | 
						|
            'delivery_man_id'=>'exists:delivery_men,id',
 | 
						|
            'amount'=>'numeric|min:.01',
 | 
						|
        ]);
 | 
						|
 | 
						|
        if ($validator->fails()) {
 | 
						|
            return response()->json(['errors' => Helpers::error_processor($validator)]);
 | 
						|
        }
 | 
						|
 | 
						|
        if(Helpers::dm_wallet_transaction($request->delivery_man_id, $request->amount, $request->referance)){
 | 
						|
            return response()->json(['message'=>trans('messages.bonus_added_successfully')], 200);
 | 
						|
        }
 | 
						|
        return response()->json(['errors' => [['code'=>'transaction-failed', 'message'=>translate('messages.faield_to_create_transaction')]]]);
 | 
						|
    }
 | 
						|
 | 
						|
}
 | 
						|
 |