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.

795 lines
35 KiB

2 years ago
<?php
namespace App\Http\Controllers\Api\V1;
use App\CentralLogics\Helpers;
use App\Http\Controllers\Controller;
use App\Models\Conversation;
use App\Models\DeliveryMan;
use App\Models\UserInfo;
use App\Models\Message;
use App\Models\Order;
use App\Models\Vendor;
use App\Models\User;
use Carbon\Carbon;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\Validator;
class ConversationController extends Controller
{
public function messages_store(Request $request)
{
// info(['New message request',$request->all()]);
if ($request->has('image')) {
$validator = Validator::make($request->all(), [
'image.*' => 'max:2048',
]);
if ($validator->fails()) {
$validator->getMessageBag()->add('image', 'Max Image Upload limit is 2mb');
return response()->json(['errors' => Helpers::error_processor($validator)],403);
}
$image_name=[];
foreach($request->file('image') as $key=>$img)
{
$name = Helpers::upload('conversation/', 'png', $img);
array_push($image_name,$name);
}
} else {
$image_name = null;
}
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$fcm_token_web = null;
$sender = UserInfo::where('user_id', $request->user()->id)->first();
if(!$sender){
$sender = new UserInfo();
$sender->user_id = $request->user()->id;
$sender->f_name = $request->user()->f_name;
$sender->l_name = $request->user()->l_name;
$sender->phone = $request->user()->phone;
$sender->email = $request->user()->email;
$sender->image = $request->user()->image;
$sender->save();
}
if($request->conversation_id){
$conversation = Conversation::find($request->conversation_id);
if($conversation->sender_id == $sender->id){
$receiver_id = $conversation->receiver_id;
$receiver = UserInfo::find($receiver_id);
if($receiver->vendor_id){
$vendor = Vendor::find($receiver->vendor_id);
$fcm_token=$vendor->firebase_token;
$fcm_token_web=$vendor->fcm_token_web;
}elseif($receiver->deliveryman_id){
$delivery_man = DeliveryMan::find($receiver->deliveryman_id);
$fcm_token=$delivery_man->fcm_token;
}elseif($receiver->admin_id){
$receiver_id = 0;
}
}else{
$receiver_id =$conversation->sender_id;
$receiver = UserInfo::find($receiver_id);
if($receiver->vendor_id){
$vendor = Vendor::find($receiver->vendor_id);
$fcm_token=$vendor->firebase_token;
$fcm_token_web=$vendor->fcm_token_web;
}elseif($receiver->deliveryman_id){
$delivery_man = DeliveryMan::find($receiver->deliveryman_id);
$fcm_token=$delivery_man->fcm_token;
}elseif($receiver->admin_id){
$receiver_id = 0;
}
}
}else{
if($request->receiver_type == 'admin'){
$receiver_id = 0;
}else if($request->receiver_type == 'vendor'){
$receiver = UserInfo::where('vendor_id',$request->receiver_id)->first();
$vendor = Vendor::find($request->receiver_id);
if(!$receiver){
$receiver = new UserInfo();
$receiver->vendor_id = $vendor->id;
$receiver->f_name = $vendor->restaurants[0]->name;
$receiver->l_name = '';
$receiver->phone = $vendor->phone;
$receiver->email = $vendor->email;
$receiver->image = $vendor->restaurants[0]->logo;
$receiver->save();
}
$receiver_id = $receiver->id;
$fcm_token=$vendor->firebase_token;
$fcm_token_web=$vendor->fcm_token_web;
}else if($request->receiver_type == 'delivery_man'){
$receiver = UserInfo::where('deliveryman_id',$request->receiver_id)->first();
$delivery_man = DeliveryMan::find($request->receiver_id);
if(!$receiver){
$receiver = new UserInfo();
$receiver->deliveryman_id = $delivery_man->id;
$receiver->f_name = $delivery_man->f_name;
$receiver->l_name = $delivery_man->l_name;
$receiver->phone = $delivery_man->phone;
$receiver->email = $delivery_man->email;
$receiver->image = $delivery_man->image;
$receiver->save();
}
$receiver_id = $receiver->id;
$fcm_token=$delivery_man->fcm_token;
}
$conversation = Conversation::WhereConversation($sender->id,$receiver_id)->first();
}
if(!$conversation){
$conversation = new Conversation;
$conversation->sender_id = $sender->id;
$conversation->sender_type = 'customer';
$conversation->receiver_id = $receiver_id;
$conversation->receiver_type = $request->receiver_type;
$conversation->unread_message_count = 0;
$conversation->last_message_time = Carbon::now()->toDateTimeString();
$conversation->save();
$conversation= Conversation::find($conversation->id);
}
$message = new Message();
$message->conversation_id = $conversation->id;
$message->sender_id = $sender->id;
$message->message = $request->message;
$message->file = $image_name?json_encode($image_name, JSON_UNESCAPED_SLASHES):null;
try {
if($message->save())
$conversation->unread_message_count = $conversation->unread_message_count? $conversation->unread_message_count+1:1;
$conversation->last_message_id=$message->id;
$conversation->last_message_time = Carbon::now()->toDateTimeString();
$conversation->save();
{
if($request->receiver_type == 'admin' || $receiver_id == 0){
$data = [
'title' =>translate('messages.message'),
'description' =>translate('messages.message_description'),
'order_id' => '',
'image' => '',
'message' => json_encode($message) ,
'type'=> 'message'
];
Helpers::send_push_notif_to_topic($data,'admin_message','message');
}else if($request->receiver_type == 'vendor' || $request->receiver_type == 'delivery_man'){
$data = [
'title' =>translate('messages.message'),
'description' =>translate('messages.message_description'),
'order_id' => '',
'image' => '',
'message' => json_encode($message) ,
'type'=> 'message',
'conversation_id'=> $conversation->id,
'sender_type'=> 'user'
];
Helpers::send_push_notif_to_device($fcm_token, $data);
if($fcm_token_web){
Helpers::send_push_notif_to_device($fcm_token_web, $data);
}
}
}
} catch (\Exception $e) {
info($e);
}
$messages = Message::where(['conversation_id' => $conversation->id])->latest()->paginate($limit, ['*'], 'page', $offset);
$conv = Conversation::with('sender','receiver','last_message')->find($conversation->id);
if($conv->sender_type == 'vendor' && $conversation->sender){
$vd = Vendor::find($conv->sender->vendor_id);
$order = Order::where('user_id',$request->user()->id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conv->receiver_type == 'vendor' && $conversation->receiver){
$vd = Vendor::find($conv->receiver->vendor_id);
$order = Order::where('user_id',$request->user()->id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conv->sender_type == 'delivery_man' && $conversation->sender){
$user2 = DeliveryMan::find($conv->sender->deliveryman_id);
$order = Order::where('user_id',$request->user()->id)->where('delivery_man_id', $user2->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conv->receiver_type == 'delivery_man' && $conversation->receiver){
$user2 = DeliveryMan::find($conv->receiver->deliveryman_id);
$order = Order::where('user_id',$request->user()->id)->where('delivery_man_id', $user2->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}
else{
$order=1;
}
$data = [
'total_size' => intval($messages->total()),
'limit' => intval($limit),
'offset' => intval($offset),
'status' => ($order>0)?true:false,
'message' => 'successfully sent!',
'messages' => $messages->items(),
'conversation' => $conv,
];
return response()->json($data, 200);
}
public function chat_image(Request $request)
{
$validator = Validator::make($request->all(), [
'image' => 'required|max:2048'
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)], 403);
}
if ($request->has('image')) {
$image_name = Helpers::upload('conversation/', 'png', $request->file('image'));
} else {
$image_name = 'def.png';
}
$url = asset('storage/app/public/conversation') . '/' . $image_name;
return response()->json(['image_url' => $url], 200);
}
public function conversations(Request $request)
{
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$sender = UserInfo::where('user_id', $request->user()->id)->first();
if(!$sender){
$sender = new UserInfo();
$sender->user_id = $request->user()->id;
$sender->f_name = $request->user()->f_name;
$sender->l_name = $request->user()->l_name;
$sender->phone = $request->user()->phone;
$sender->email = $request->user()->email;
$sender->image = $request->user()->image;
$sender->save();
}
$conversations = Conversation::with('sender','receiver','last_message')->where(['sender_id' => $sender->id])->orWhere(['receiver_id' => $sender->id])->orderBy('last_message_time', 'DESC')->paginate($limit, ['*'], 'page', $offset);
$data = [
'total_size' => intval($conversations->total()),
'limit' => intval($limit),
'offset' => intval($offset),
'conversations' => $conversations->items()
];
return response()->json($data, 200);
}
public function get_searched_conversations(Request $request)
{
$validator = Validator::make($request->all(), [
'name' => 'required'
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)], 403);
}
$key = explode(' ', $request['name']);
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$sender = UserInfo::where('user_id', $request->user()->id)->first();
if(!$sender){
$sender = new UserInfo();
$sender->user_id = $request->user()->id;
$sender->f_name = $request->user()->f_name;
$sender->l_name = $request->user()->l_name;
$sender->phone = $request->user()->phone;
$sender->email = $request->user()->email;
$sender->image = $request->user()->image;
$sender->save();
}
$conversations = Conversation::with('sender','receiver','last_message')->WhereUser($sender->id)->where(function($qu)use($key){
$qu->whereHas('sender',function($query)use($key){
foreach ($key as $value) {
$query->where('f_name', 'like', "%{$value}%")->orWhere('l_name', 'like', "%{$value}%");
}
})
->orWhereHas('receiver',function($query1)use($key){
foreach ($key as $value) {
$query1->where('f_name', 'like', "%{$value}%")->orWhere('l_name', 'like', "%{$value}%");
}
});
});
$conversations = $conversations->orderBy('last_message_time', 'DESC')->paginate($limit, ['*'], 'page', $offset);
$data = [
'total_size' => intval($conversations->total()),
'limit' => intval($limit),
'offset' => intval($offset),
'conversations' => $conversations->items()
];
return response()->json($data, 200);
}
public function messages(Request $request)
{
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$user = UserInfo::where('user_id', $request->user()->id)->first();
if(!$user){
$user = new UserInfo();
$user->user_id = $request->user()->id;
$user->f_name = $request->user()->f_name;
$user->l_name = $request->user()->l_name;
$user->phone = $request->user()->phone;
$user->email = $request->user()->email;
$user->image = $request->user()->image;
$user->save();
}
$conversation = null;
if($request->conversation_id){
$conversation = Conversation::with(['sender','receiver','last_message'])->find($request->conversation_id);
}else if($request->has('admin_id')){
$conversation = Conversation::with(['sender','receiver','last_message'])->WhereConversation($user->id,0)->first();
$order=0;
}else if($request->vendor_id){
$vendor = UserInfo::where('vendor_id', $request->vendor_id)->first();
if(!$vendor){
$vd = Vendor::find($request->vendor_id);
$vendor = new UserInfo();
$vendor->vendor_id = $vd->id;
$vendor->f_name = $vd->restaurants[0]->name;
$vendor->l_name = '';
$vendor->phone = $vd->phone;
$vendor->email = $vd->email;
$vendor->image = $vd->restaurants[0]->logo;
$vendor->save();
}
$conversation = Conversation::with(['sender','receiver','last_message'])->WhereConversation($user->id,$vendor->id)->first();
}else if($request->delivery_man_id){
$dm = UserInfo::where('deliveryman_id', $request->delivery_man_id)->first();
if(!$dm){
$user2 = DeliveryMan::find($request->delivery_man_id);
$dm = new UserInfo();
$dm->deliveryman_id = $user2->id;
$dm->f_name = $user2->f_name;
$dm->l_name = $user2->l_name;
$dm->phone = $user2->phone;
$dm->email = $user2->email;
$dm->image = $user2->image;
$dm->save();
}
$conversation = Conversation::with(['sender','receiver','last_message'])->WhereConversation($user->id,$dm->id)->first();
}
if(isset($conversation)){
if($conversation->sender_type == 'vendor' && $conversation->sender){
$vd = Vendor::find($conversation->sender->vendor_id);
$order = Order::where('user_id',$user->user_id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conversation->receiver_type == 'vendor' && $conversation->receiver){
$vd = Vendor::find($conversation->receiver->vendor_id);
$order = Order::where('user_id',$user->user_id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conversation->sender_type == 'delivery_man' && $conversation->sender){
$user2 = DeliveryMan::find($conversation->sender->deliveryman_id);
$order = Order::where('user_id',$user->user_id)->where('delivery_man_id', $user2->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conversation->receiver_type == 'delivery_man' && $conversation->receiver){
$user2 = DeliveryMan::find($conversation->receiver->deliveryman_id);
$order = Order::where('user_id',$user->user_id)->where('delivery_man_id', $user2->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}
else{
$order=1;
}
$lastmessage = $conversation->last_message;
if($lastmessage && $lastmessage->sender_id != $user->id ) {
$conversation->unread_message_count = 0;
$conversation->save();
}
Message::where(['conversation_id' => $conversation->id])->where('sender_id','!=',$user->id)->update(['is_seen' => 1]);
$messages = Message::where(['conversation_id' => $conversation->id])->latest()->paginate($limit, ['*'], 'page', $offset);
}else{
$messages =[];
$order=0;
}
$data = [
'total_size' => $messages? intval($messages->total()):0,
'limit' => intval($limit),
'offset' => intval($offset),
'status' => ($order > 0)?true:false,
'messages' => $messages? $messages->items():[],
'conversation' => $conversation
];
return response()->json($data, 200);
}
public function dm_messages_store(Request $request)
{
if ($request->has('image')) {
$validator = Validator::make($request->all(), [
'image.*' => 'max:2048',
]);
if ($validator->fails()) {
$validator->getMessageBag()->add('image', 'Max Image Upload limit is 2mb');
return response()->json(['errors' => Helpers::error_processor($validator)],403);
}
$image_name=[];
foreach($request->file('image') as $key=>$img)
{
$name = Helpers::upload('conversation/', 'png', $img);
array_push($image_name,$name);
}
} else {
$image_name = null;
}
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$fcm_token_web = null;
$dm = DeliveryMan::where(['auth_token' => $request['token']])->first();
$sender = UserInfo::where('deliveryman_id', $dm->id)->first();
if(!$sender){
$sender = new UserInfo();
$sender->deliveryman_id = $dm->id;
$sender->f_name = $dm->f_name;
$sender->l_name = $dm->l_name;
$sender->phone = $dm->phone;
$sender->email = $dm->email;
$sender->image = $dm->image;
$sender->save();
}
if($request->conversation_id){
$conversation = Conversation::find($request->conversation_id);
if($conversation->sender_id == $sender->id){
$receiver_id = $conversation->receiver_id;
$receiver = UserInfo::find($receiver_id);
if($receiver->vendor_id){
$vendor = Vendor::find($receiver->vendor_id);
$fcm_token=$vendor->firebase_token;
$fcm_token_web = "restaurant_panel_{$vendor->restaurants[0]->id}_message";
}elseif($receiver->user_id){
$user = User::find($receiver->user_id);
$fcm_token=$user->cm_firebase_token;
}
}else{
$receiver_id =$conversation->sender_id;
$receiver = UserInfo::find($receiver_id);
if($receiver->vendor_id){
$vendor = Vendor::find($receiver->vendor_id);
$fcm_token=$vendor->firebase_token;
$fcm_token_web="restaurant_panel_{$vendor->restaurants[0]->id}_message";
}elseif($receiver->user_id){
$user = User::find($receiver->user_id);
$fcm_token=$user->cm_firebase_token;
}
}
}else{
if($request->receiver_type == 'vendor'){
$receiver = UserInfo::where('vendor_id',$request->receiver_id)->first();
$vendor = Vendor::find($request->receiver_id);
if(!$receiver){
$receiver = new UserInfo();
$receiver->vendor_id = $vendor->id;
$receiver->f_name = $vendor->restaurants[0]->name;
$receiver->l_name = '';
$receiver->phone = $vendor->phone;
$receiver->email = $vendor->email;
$receiver->image = $vendor->restaurants[0]->logo;
$receiver->save();
}
$receiver_id = $receiver->id;
$fcm_token=$vendor->firebase_token;
$fcm_token_web="restaurant_panel_{$vendor->restaurants[0]->id}_message";
}else if($request->receiver_type == 'customer'){
$receiver = UserInfo::where('user_id',$request->receiver_id)->first();
$user = User::find($request->receiver_id);
// dd($user);
if(!$receiver){
$receiver = new UserInfo();
$receiver->user_id = $user->id;
$receiver->f_name = $user->f_name;
$receiver->l_name = $user->l_name;
$receiver->phone = $user->phone;
$receiver->email = $user->email;
$receiver->image = $user->image;
$receiver->save();
}
$receiver_id = $receiver->id;
$fcm_token=$user->cm_firebase_token;
}
}
$conversation = Conversation::WhereConversation($sender->id,$receiver_id)->first();
if(!$conversation){
$conversation = new Conversation;
$conversation->sender_id = $sender->id;
$conversation->sender_type = 'delivery_man';
$conversation->receiver_id = $receiver->id;
$conversation->receiver_type = $request->receiver_type;
$conversation->unread_message_count = 0;
$conversation->last_message_time = Carbon::now()->toDateTimeString();
$conversation->save();
$conversation= Conversation::find($conversation->id);
}
$message = new Message();
$message->conversation_id = $conversation->id;
$message->sender_id = $sender->id;
$message->message = $request->message;
$message->file = $image_name?json_encode($image_name, JSON_UNESCAPED_SLASHES):null;
try {
if($message->save())
$conversation->unread_message_count = $conversation->unread_message_count? $conversation->unread_message_count+1:1;
$conversation->last_message_id=$message->id;
$conversation->last_message_time = Carbon::now()->toDateTimeString();
$conversation->save();
{
$data = [
'title' =>translate('messages.message'),
'description' =>translate('messages.message_description'),
'order_id' => '',
'image' => '',
'message' => json_encode($message) ,
'type'=> 'message',
'conversation_id'=> $conversation->id,
'sender_type'=> 'delivery_man'
];
Helpers::send_push_notif_to_device($fcm_token, $data);
if($fcm_token_web){
Helpers::send_push_notif_to_topic($data, $fcm_token_web, 'message');
}
}
} catch (\Exception $e) {
info($e);
}
$messages = Message::where(['conversation_id' => $conversation->id])->latest()->paginate($limit, ['*'], 'page', $offset);
$conv = Conversation::with('sender','receiver','last_message')->find($conversation->id);
if($conv->sender_type == 'vendor' && $conversation->sender){
$vd = Vendor::find($conv->sender->vendor_id);
$order = Order::where('delivery_man_id',$dm->id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conv->receiver_type == 'vendor' && $conversation->receiver){
$vd = Vendor::find($conv->receiver->vendor_id);
$order = Order::where('delivery_man_id',$dm->id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conv->sender_type == 'customer' && $conversation->sender){
$user = User::find($conv->sender->user_id);
$order = Order::where('delivery_man_id',$dm->id)->where('user_id', $user->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conv->receiver_type == 'customer' && $conversation->receiver){
$user = User::find($conv->receiver->user_id);
$order = Order::where('delivery_man_id',$dm->id)->where('user_id', $user->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}
else{
$order=0;
}
$data = [
'total_size' => intval($messages->total()),
'limit' => intval($limit),
'offset' => intval($offset),
'status' => ($order>0)?true:false,
'message' => 'successfully sent!',
'messages' => $messages->items(),
'conversation' => $conv,
];
return response()->json($data, 200);
}
public function dm_conversations(Request $request)
{
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$delivery_man = DeliveryMan::where(['auth_token' => $request['token']])->first();
$sender = UserInfo::where('deliveryman_id', $delivery_man->id)->first();
if(!$sender){
$sender = new UserInfo();
$sender->deliveryman_id = $delivery_man->id;
$sender->f_name = $delivery_man->f_name;
$sender->l_name = $delivery_man->l_name;
$sender->phone = $delivery_man->phone;
$sender->email = $delivery_man->email;
$sender->image = $delivery_man->image;
$sender->save();
}
$conversations = Conversation::with('sender','receiver','last_message')->where(['sender_id' => $sender->id])->orWhere(['receiver_id' => $sender->id])->orderBy('last_message_time', 'DESC')->paginate($limit, ['*'], 'page', $offset);
$data = [
'total_size' => intval($conversations->total()),
'limit' => intval($limit),
'offset' => intval($offset),
'conversation' => $conversations->items()
];
return response()->json($data, 200);
}
public function dm_search_conversations(Request $request)
{
$validator = Validator::make($request->all(), [
'name' => 'required'
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)], 403);
}
$key = explode(' ', $request['name']);
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$delivery_man = DeliveryMan::where(['auth_token' => $request['token']])->first();
$sender = UserInfo::where('deliveryman_id', $delivery_man->id)->first();
if(!$sender){
$sender = new UserInfo();
$sender->deliveryman_id = $delivery_man->id;
$sender->f_name = $delivery_man->f_name;
$sender->l_name = $delivery_man->l_name;
$sender->phone = $delivery_man->phone;
$sender->email = $delivery_man->email;
$sender->image = $delivery_man->image;
$sender->save();
}
$conversations = Conversation::with('sender','receiver','last_message')->WhereUser($sender->id)->where(function($qu)use($key){
$qu->whereHas('sender',function($query)use($key){
foreach ($key as $value) {
$query->where('f_name', 'like', "%{$value}%")->orWhere('l_name', 'like', "%{$value}%");
}
})
->orWhereHas('receiver',function($query1)use($key){
foreach ($key as $value) {
$query1->where('f_name', 'like', "%{$value}%")->orWhere('l_name', 'like', "%{$value}%");
}
});
});
$conversations = $conversations->orderBy('last_message_time', 'DESC')->paginate($limit, ['*'], 'page', $offset);
$data = [
'total_size' => intval($conversations->total()),
'limit' => intval($limit),
'offset' => intval($offset),
'conversation' => $conversations->items()
];
return response()->json($data, 200);
}
public function dm_messages(Request $request)
{
$limit = $request['limit']??10;
$offset = $request['offset']??1;
$dm = DeliveryMan::where(['auth_token' => $request['token']])->first();
$delivery_man = UserInfo::where('deliveryman_id',$dm->id)->first();
if(!$delivery_man){
$delivery_man = new UserInfo();
$delivery_man->deliveryman_id = $dm->id;
$delivery_man->f_name = $dm->f_name;
$delivery_man->l_name = $dm->l_name;
$delivery_man->phone = $dm->phone;
$delivery_man->email = $dm->email;
$delivery_man->image = $dm->image;
$delivery_man->save();
}
if($request->conversation_id){
$conversation = Conversation::with(['sender','receiver','last_message'])->find($request->conversation_id);
}else if($request->vendor_id){
$vendor = UserInfo::where('vendor_id', $request->vendor_id)->first();
if(!$vendor){
$user = Vendor::find($request->vendor_id);
$vendor = new UserInfo();
$vendor->vendor_id = $user->id;
$vendor->f_name = $user->restaurants[0]->name;
$vendor->l_name = '';
$vendor->phone = $user->phone;
$vendor->email = $user->email;
$vendor->image = $user->image;
$vendor->save();
}
$conversation = Conversation::with(['sender','receiver','last_message'])->WhereConversation($delivery_man->id,$vendor->id)->first();
}else if($request->user_id){
$user = UserInfo::where('user_id', $request->user_id)->first();
if(!$user){
$customer = User::find($request->user_id);
$user = new UserInfo();
$user->user_id = $customer->id;
$user->f_name = $customer->f_name;
$user->l_name = $customer->l_name;
$user->phone = $customer->phone;
$user->email = $customer->email;
$user->image = $customer->image;
$user->save();
}
$conversation = Conversation::with(['sender','receiver','last_message'])->WhereConversation($delivery_man->id,$user->id)->first();
}
if($conversation){
if($conversation->sender_type == 'vendor' && $conversation->sender){
$vd = Vendor::find($conversation->sender->vendor_id);
$order = Order::where('delivery_man_id',$dm->id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conversation->receiver_type == 'vendor' && $conversation->receiver){
$vd = Vendor::find($conversation->receiver->vendor_id);
$order = Order::where('delivery_man_id',$dm->id)->where('restaurant_id', $vd->restaurants[0]->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conversation->sender_type == 'customer' && $conversation->sender){
$user = User::find($conversation->sender->user_id);
$order = Order::where('delivery_man_id',$dm->id)->where('user_id', $user->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}else if($conversation->receiver_type == 'customer' && $conversation->receiver){
$user = User::find($conversation->receiver->user_id);
$order = Order::where('delivery_man_id',$dm->id)->where('user_id', $user->id)->whereIn('order_status', ['pending','accepted','confirmed','processing','handover','picked_up'])->count();
}
else{
$order=0;
}
$lastmessage = $conversation->last_message;
if($lastmessage && $lastmessage->sender_id != $delivery_man->id ) {
$conversation->unread_message_count = 0;
$conversation->save();
}
Message::where(['conversation_id' => $conversation->id])->where('sender_id','!=',$delivery_man->id)->update(['is_seen' => 1]);
$messages = Message::where(['conversation_id' => $conversation->id])->latest()->paginate($limit, ['*'], 'page', $offset);
}else{
$messages =[];
$order=0;
}
$data = [
'total_size' => $messages? intval($messages->total()):0,
'limit' => intval($limit),
'offset' => intval($offset),
'status' => ($order>0)?true:false,
'messages' => $messages? $messages->items():[],
'conversation' => $conversation
];
return response()->json($data, 200);
}
}