123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656 |
- <?php
- namespace App\Http\Controllers;
- use App\Helpers\CommonMethods;
- use App\OrderActivities;
- use App\OrderNotifications;
- use App\Orders;
- use App\Outlets;
- use App\Restaurants;
- use App\RestoSMSs;
- use Carbon\Carbon;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Artisan;
- use Illuminate\Support\Facades\Auth;
- use Pusher\Pusher;
- use Log;
- use Illuminate\Support\Facades\Http;
- use DB;
- class Order extends Controller
- {
- public function orders(){
- //$recent_till = Carbon::now()->subDays(2);;
- $orders = Orders::where('resto_id',Auth::user()->restaurants->id)->whereIN('status' ,['Placed','Send_to_Kitchen','On_Road','Accepted'])->orderBy('created_at','DESC')->paginate(10);
- // $orders = Auth::user()->restaurants->orders;
- $data = [
- 'orders' => $orders
- ];
- return view('orders.orders',$data);
- }
- public function all_status_count(){
- $orders = Orders::select(DB::raw(' count(status) as status_count'),'status')->where('resto_id',Auth::user()->restaurants->id)->whereIN('status' ,['Placed','Send_to_Kitchen','On_Road','Accepted'])->groupBy('status')->get();
- $order_statuses = ['Placed','Send_to_Kitchen','On_Road','Accepted'];
- $a = [];
- foreach($orders as $order){
- $status[$order->status] = array('status_count'=>$order->status_count,'status'=>$order->status);
- }
- $aa = [];
- foreach($order_statuses as $st){
- if(isset($status[$st]))
- $aa[] = $status[$st];
- else{
- $aa[] = array('status_count'=>0,'status'=>$st);
- }
- }
- return response()->json($aa);
- }
- public function load_live_order($status){
- $exitCode = Artisan::call('cache:clear');
- $exitCode = Artisan::call('route:clear');
- $exitCode = Artisan::call('view:clear');
- // $exitCode = Artisan::call('config:cache');
- // $exitCode = Artisan::call('config:clear');
- $s = ['Placed','Send_to_Kitchen','On_Road','Accepted'];
- if($status=="new")
- $s = ['Placed'];
- if($status=="kitchen")
- $s = ['Accepted','Send_to_Kitchen'];
- if($status=="route")
- $s = ['On_Road'];
- $orders = Orders::where('resto_id',Auth::user()->restaurants->id)->whereIN('status' ,$s)->orderBy('created_at','DESC')->get();
- $liveOrders = NULL;
- if(isset($orders) && $orders->count() > 0){
- foreach($orders as $order){
- $status = "";
- $bg="";
- $box_bg="";
- $remaining_min = 0;
- $order_delivery_time = !empty($order->delivery_preparation_time)?$order->delivery_preparation_time:0;
- $created_at = $order->created_at;
- // dump("Delivery Time : ".$order_delivery_time);
- $till_to = strtotime("+".$order_delivery_time.' minutes',strtotime($order->updated_at));
- // dump("Till To : ".date('H:i',$till_to));
- $updated_at = Carbon::parse(date('Y-m-d H:i',$till_to));
- $now = Carbon::now();
- // dump("Update time: ".$updated_at);
- $diff = $updated_at->diffInMinutes($now);
- $order_placed_diff = Carbon::parse($created_at)->diffInMinutes($now);
- // dump($order_placed_diff);
- // dump("Difference: ".$diff);
- if($diff <=$order_delivery_time )
- $remaining_min = $diff;
- // dump("Remain_min ".$remaining_min);
- if($order->status=="Placed"){
- $status = "New";
- $bg="blu-bg";
- $box_bg="bg-danger";
- $bg_color="#0ED0DF";
- }
- if($order->status=="Accepted" || $order->status=="Send_to_Kitchen"){
- $status = "In Prep";
- $bg="org-bg";
- $bg_color="orange";
- }
- if($order->status=="On_Road"){
- $status = "In Route";
- $bg = "blu-bg";
- $bg_color="#0ED0DF";
- }
- $liveOrders[] = array(
- 'id' => $order->id,
- 'order_ref' => $order->order_ref,
- 'campaign_type' => !empty($order->campaign_type) && $order->order_type!="dining"?ucwords($order->campaign_type):"Direct",
- 'status' => $status,
- 'bg'=>$bg,
- 'box_bg'=>$box_bg,
- 'bg_color'=> $bg_color,
- 'remaining_min'=>$remaining_min,
- 'remaining_min_milliseconds'=>strtotime($order->created_at),
- 'created_at' => Carbon::createFromTimeStamp(strtotime($order->created_at))->diffForHumans(),
- 'current_time'=>Carbon::now()->format('H:i'),
- 'updated_at'=> $updated_at->format('H:i'),
- 'placed_min'=>$order_placed_diff
- );
- }
- }
- if(isset($liveOrders))
- return response()->json(array('type'=>'success','orders'=>$liveOrders));
- else
- echo json_encode(array('type'=>'error','message'=>'No order found'));
- }
- public function get_detail_json($id){
- $order = Orders::find($id);
- $recipes = NULL;
-
- if(empty($order->selected_area_formatted) && $order->order_type=="delivery"){
- // dump($order->selected_area);
- $url = "https://maps.googleapis.com/maps/api/geocode/json?address=".urlencode($order->selected_area)."&key=AIzaSyBFh6fzq8G7dgWLfz8kccvTlmPCSI_uWXQ";
- $curl = curl_init();
- curl_setopt_array($curl, array(
- CURLOPT_URL => $url,
- CURLOPT_RETURNTRANSFER => true,
- CURLOPT_ENCODING => '',
- CURLOPT_MAXREDIRS => 10,
- CURLOPT_TIMEOUT => 0,
- CURLOPT_FOLLOWLOCATION => true,
- CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
- CURLOPT_CUSTOMREQUEST => 'GET',
- ));
- $response = curl_exec($curl);
- curl_close($curl);
- //echo $response;
- $result = (json_decode($response));
- $formatted_address = isset($result->results[0])?$result->results[0]->formatted_address:"";
- $order->selected_area_formatted = $formatted_address;
- $order->save();
- }
-
-
- $country_code = Auth::user()->restaurants->countries->country_code;
-
- $new_phone = $order->customers->users->email;
- if(isset($order->customers)){
- $pos = strpos($order->customers->users->email, (string)$country_code);
-
- if ($pos !== false) {
- $new_phone = substr_replace($order->customers->users->email, '', $pos, strlen(env('COUNTRY_CODE')));
- }
- }
- if(isset($order->orderItems) && $order->orderItems->count() > 0){
- $extra_price = 0;
- $recipes = [];$ex = [];
- foreach($order->orderItems as $item){
- $ex= NULL;
- $recipe = $item->recipes;
- $cate_name = "";
- $categories = isset($recipe->categories)?$recipe->categories->pluck('category_id'):NULL;
- if($categories){
- $categories = \App\Categories::whereIn('id',$categories)->pluck('name')->toArray();
- $cate_name = $categories[0];
- }
- $extra_options = NULL;
- $opt = [];
- if(!empty($item->extra_options)){
- $ss_item = [];
- $extra_options = json_decode($item->extra_options);
- $extra_options_array = (json_decode($item->extra_options,true));
- if(isset($extra_options_array['sub_items']) && count($extra_options_array['sub_items']) > 0){
- $extra_sub_options = $extra_options_array['sub_items'];
- foreach($extra_sub_options as $k=>$s){
- $itm = \App\ExtraOptionItems::find($s['id']);
- $ss_item[$k] = array('id'=>$itm->id,'name'=>$itm->name);
- }
- }
- //$opt = "<ul>";
- if(isset($extra_options)){
- foreach($extra_options as $option){
- //dump($option);
- if(isset($option->id)){
- $itm = \App\ExtraOptionItems::find($option->id);
- if(isset($itm)){
- $ex[] = array('id'=>$option->id,'price'=>$option->price,'name'=>$itm->name,'sub_items'=>isset($ss_item[$option->id])?$ss_item:null);
-
- // dump($ex);
- $opt[] = $itm->name;
- // $opt.="<li>".$itm->name.' <span class="ml-2 badge badge-danger">'.($itm->price).'</span>';
- $extra_price = $extra_price+$option->price;
- if(isset($option->sub_items)){
- foreach($option->sub_items as $sub){
- $itm = \App\ExtraOptionItems::find($sub->sub_item_id);
- $extra_price = $extra_price+$sub->price;
- }
- }
- //$opt.="</li>";
- }
- }
- }
- }
- // $opt.="</ul>";
- }
- if(isset($extra_options->color_size)){
- $ex = array('color'=>$extra_options->color_size->color,'size'=>$extra_options->color_size->size);
- }
- $recipes[] = array(
- 'recipe_name'=>isset($item->recipes)?$item->recipes->name:"",
- 'recipe_image' => isset($item->recipes->main_images)?$item->recipes->main_images->file_name:"",
- 'quantity'=>$item->qty,
- 'item_price'=>$item->price,
- 'total_price'=>($item->qty*$item->price),
- 'extra_options'=>$ex
- );
- }
- }
- $status = "";
- $bg="";
- $next_action="";
- $next_status="";
- $bg_color="";
- if($order->status=="Placed"){
- $status = "New";
- $bg="bg-danger";
- $box_bg="bg-danger";
- $next_action='Accepted';
- $next_status="Accepted";
- }
- if($order->status=="Accepted" || $order->status=="Send_to_Kitchen"){
- $status = "In Prep";
- $bg="org-bg";
- $next_action='On Road';
- $next_status="On_Road";
- $bg_color="orange";
- }
- if($order->status=="On_Road"){
- $status = "In Route";
- $bg = "blu-bg";
- $bg_color="#0ED0DF";
- $next_action='Delivered';
- $next_status="Has_Delivered";
- }
- $address = "";
- $delivery_notes = "";
- if(isset($order->customers) && isset($order->customers->customer_addresses)){
- $address .= isset($order->customers->customer_addresses[0])?ucwords($order->customers->customer_addresses[0]->label):NULL;
- $address.= isset($order->customers->customer_addresses[0])?", ".$order->customers->customer_addresses[0]->area:NULL;
- $address.= isset($order->customers->customer_addresses[0])?",".$order->customers->customer_addresses[0]->address:NULL;
- }
- if(isset($order->customers) && isset($order->customers->customer_addresses)){
- $delivery_notes .= isset($order->customers->customer_addresses[0])?$order->customers->customer_addresses[0]->instructions:NULL;
- }
- $outlet = Outlets::find($order->outlet_id);
- $order = array(
- 'order_ref' => str_pad($order->order_ref,6,0,STR_PAD_LEFT),
- 'brand_name' => Auth::user()->restaurants->name,
- 'outlet_name' => isset($outlet)?$outlet->name:"None",
- 'order_type' => $order->order_type=="dining"?"Dine in":ucwords($order->order_type),
- 'delivery_at' => !empty($order->order_deliver_time)?$order->order_deliver_time:date('d/m/y',strtotime($order->created_at))." - ASAP",
- 'customer' =>$order->customer_name,
- 'delivery_fee' => $order->delivery_fee,
- 'phone' => $new_phone,
- 'channel' => !empty($order->campaign_type) && $order->order_type!="dining"?ucwords($order->campaign_type):"Direct",
- 'order_placed' =>\Carbon\Carbon::createFromTimeStamp(strtotime($order->created_at))->diffForHumans(),
- 'payment' => $order->payment_mode=="COD"?"Cash":"Card",
- 'status'=>$status,
- 'bg'=>$bg,
- 'total_price' => $order->total_price,
- 'recipes'=>$recipes,
- 'next_action'=>$next_action,
- 'next_status' =>$next_status,
- 'address'=>$address,
-
- 'for_table'=>$order->for_table,
- 'formatted_address'=>$order->selected_area_formatted,
- 'order_instructions'=>$order->order_instructions,
- 'delivery_notes' => $order->order_type=="delivery"?$delivery_notes:$order->order_instructions,
- 'bg_color'=> $bg_color,
- 'recipient_name' => isset($order->recipients)?$order->recipients->recipient_name:null,
- 'recipient_phone' => isset($order->recipients)?$order->recipients->recipient_phone:null,
- 'greeting_message' => isset($order->recipients)?$order->recipients->greeting_message:null,
- );
- echo json_encode($order);
- }
- public function show($id){
- $order = Orders::find($id);
- $activities = OrderActivities::where('order_id',$id)->pluck('status')->toArray();
- // dd($activities);
- $data = [
- 'order' => $order,
- 'activities' =>$activities
- ];
- return view('orders.show',$data);
- }
- public function update_status(Request $request){
- $id = $request->id;
- $status = $request->status;
- $order = Orders::find($id);
- if($status=="Accepted"){
- $order->preparation_time = !empty($request->preparation_time)?$request->preparation_time:"";
- $order->delivery_preparation_time = !empty($request->preperation_delivery)?$request->preperation_delivery:"";
- }
- $order->status = $status;
- $order->save();
- if(strtolower($status)=="accepted" || strtolower($status)=="rejected" || strtolower($status)=="rejected_by_user"){
- $url = env('QRCODE_HOST_ORDER')."track/order?order=".$id."&ref=".$order->order_ref;
- if(strtolower($status)=="accepted"){
- $message =env('ORDER_ACCEPTED_MESSAGE').' '.$url;
- $message = "Dear Customer, Your Order #".$order->order_ref." is accepted , kindly track your order at ".$url." ";
- $restuarant = Restaurants::find($order->resto_id);
- if($restuarant->default_lang=="ar"){
- $message = "عزيزي العميل طلبك {{1}} تم {{2}} ، لتتبع طلبك افتح الرابط {{3}}";
- $message = str_replace(["{{1}}",'{{2}}','{{3}}'],["#".$order->order_ref,'قبوله',$url],$message);
- // echo $message;
- }
- }
- else{
- $message = env('ORDER_CANCELLED_MESSAGE');
- $message = "Dear Customer, Your Order #".$order->order_ref." is rejected , kindly track your order at ".$url." ";
- $restuarant = Restaurants::find($order->resto_id);
- if($restuarant->default_lang=="ar"){
- $message = "عزيزي العميل طلبك {{1}} تم {{2}} ، لتتبع طلبك افتح الرابط {{3}}";
- $message = str_replace(["{{1}}",'{{2}}','{{3}}'],["#".$order->order_ref,'رفضه',$url],$message);
- // echo $message;
- }
- }
- $mobile_number = isset($order->customers)?$order->customers->users->email:NULL;
- //$mobile_number = "923459635387";
- if(isset($mobile_number)){
- $sms = new RestoSMSs();
- $sms->resto_id = $order->resto_id;
- $sms->msg = $message;
- $sms->msg_purpose = "TRACK_ORDER_SMS";
- $sms->msisdn = $mobile_number;
- $sms->status = 1;
- $sms->save();
- $sms_id = $sms->id;
- $usrname = 'meem_food_order';
- if(env('OTP_TEST_IN_DEV')=="1"){//ALWAYS ZERO IN PROD
- $usrname = 'meem_food_order1';
- }
- $data = [
- 'usrname'=>$usrname,
- 'pwd'=>'meem@kkew#9',
- 'msisdn' => $mobile_number,
- 'smstxt' => $message,
- 'pricepoint'=>1,
- 'jsonstr'=>'Future'
- ];
- Log::info('TRACK_ORDER_SMS Data: '.json_encode($data));
- if(env('OTP_DONT_SEND_REQ')=="0"){//IN PROD THIS SHOULD BE 0 IN PROD
- $wsdlurl = env('WHATSAPP_OPT_API');
- $response = Http::acceptJson()->post($wsdlurl,$data);
- $response = $response->json();
- $response = json_encode($response);
- Log::info('TRACK_ORDER_SMS Response: '.$response);
- $sms = RestoSMSs::find($sms_id);
- $sms->otp_req = json_encode($data);
- $resp = json_decode($response);
- $sms->otp_req_status = strtoupper($resp->status)=="ACCEPTED"?"SUCCESS":"FAIL";
- $sms->otp_res = $response;
-
- $sms->save();
-
- }
- }
-
- }
- OrderActivities::add_order_activity($id,$status);
- $options = array(
- 'cluster' => env('PUSHER_APP_CLUSTER'),
- 'encrypted' => true
- );
- $pusher = new Pusher(
- env('PUSHER_APP_KEY'),
- env('PUSHER_APP_SECRET'),
- env('PUSHER_APP_ID'),
- $options
- );
- $data['order_id'] = $id;
- $data['order_ref'] = $order->order_ref;
- $data['customer_id'] = $order->customer_id;
- $data['status'] = $status;
- $data['order_resto_id'] = $order->resto_id;
- $data['notification_for'] ="update-order-status";
- $pusher->trigger(env('PUHER_APP_CHANNEL'), 'App\\Events\\OrderNotification', $data);
-
- }
- public function update_instruction(Request $request){
- $id = $request->id;
- $txt = $request->text;
- $order = Orders::find($id);
- $order->order_instructions = $txt;
- $order->save();
- }
- public function ajax_order(){
- $offset = request()->get('start');
- $limit = request()->get('length');
- $draw = request()->get('draw');
- // $offset = ($offset-1) * $limit;
- $orders = Orders::where('resto_id',Auth::user()->restaurants->id)->orderBy('created_at','DESC')->offset($offset)->limit($limit)->get();
- $custom_status['Placed'] = ['Accepted'=>'Accepted','Rejected'=>'Rejected', 'Rejected_by_User'=>'Rejected by User'];
- $custom_status['Send_to_Kitchen'] = ['On_Road'=>'On the Way','Rejected'=>'Rejected', 'Rejected_by_User'=>'Rejected by User'];
- $custom_status['On_Road'] = ['Has_Delivered'=>'Delivered','Rejected'=>'Rejected', 'Rejected_by_User'=>'Rejected by User'];
- $custom_statuses = ['Rejected_by_User'=>'Rejected by User','Accepted'=>'Accepted','Rejected'=>'Rejected','Placed'=>'Placed','Send_to_Kitchen'=>'Send to Kitchen','On_Road'=>'On the Way', 'Has_Delivered'=>'Delivered','Served'=>"Served","Cancelled_by_Customer"=>"Cancelled"];
- $custom_status['Accepted'] = ['On_Road'=>'On the Way','Rejected'=>'Rejected', 'Rejected_by_User'=>'Rejected by User'];
- $data = NULL;
- foreach($orders as $order){
- $data[] = [
- $order->order_ref,
- CommonMethods::formatDateTime($order->created_at),
- $order->customer_name,
- isset($order->customers)?(str_replace(env('COUNTRY_CODE'),'',$order->customers->users->email)):"",
- isset($order->customers) && isset($order->customers->customer_addresses[0])?$order->customers->customer_addresses[0]->address:"",
- number_format($order->total_price+$order->delivery_fee),
- isset($custom_statuses[$order->status])?$custom_statuses[$order->status]:"",
- NULL
- ];
- }
- return response()->json(array('data'=>$data));
- }
- public function print_order($id){
- $order = Orders::find($id);
- $data = [
- 'order' => $order
- ];
- return view('orders.print-order',$data);
- }
- public function order_history(){
- //$recent_till = Carbon::now()->subDays(2);;
- $orders = Orders::where('resto_id',Auth::user()->restaurants->id)->whereIN('status' ,['Rejected_by_User','Rejected','Has_Delivered','Close'])->orderBy('created_at','DESC')->paginate(50);
- // $orders = Auth::user()->restaurants->orders;
- $data = [
- 'orders' => $orders
- ];
- return view('orders.orders-history',$data);
- }
- function send_message($mobile_number,$message,$sms_id){
- dd('ETST');
- // $mobile_number = '9647834000012';
- $usrname = 'meem_food_order';
- //OTP_TEST_IN_DEV0,DISABLE_OTP=0,CONSIDER_OTP_ALWAYS_TRUE=0 in prod to make it live
- if(env('OTP_TEST_IN_DEV')=="1"){//ALWAYS ZERO IN PROD
- $usrname = 'meem_food_order1';
- }
- $data = [
- 'usrname'=>$usrname,
- 'pwd'=>'meem@kkew#9',
- 'msisdn' => $mobile_number,
- 'smstxt' => $message,
- 'pricepoint'=>1,
- 'jsonstr'=>'Future'
- ];
- dd($data);
- // $wsdlurl = 'https://taiftec.com/blkdlr/bulk/sendmt';
- $wsdlurl="";//Uncomment in prod
-
- Log::info('SMS Data: '.json_encode($data));
- if(env('OTP_DONT_SEND_REQ')=="0"){//IN PROD THIS SHOULD BE 0 IN PROD
- $wsdlurl = env('SMS_OPT_API');
- $response = Http::acceptJson()->post($wsdlurl,$data);
- $response = $response->json();
- $response = json_encode($response);
- Log::info('SMS Response: '.$response);
- $sms = RestoSMSs::find($sms_id);
- $sms->otp_req = json_encode($data);
- $sms->otp_res = $response;
- $sms->save();
-
- }
- if(env('OTP_CONSIDER_ALWAYS_TRUE')=="1"){//IN PROD THIS SHOULD BE 0 IN PROD
- $a = [
- "reqid" => "20210611025322000469",
- "mtid" => "18",
- "errcode" => 1,
- "status" => "ACCEPTED"];
- $response = json_encode($a);
- $access_token = Session::get('access_token');
- $sms_url = env('RESTO_API_URL').'update/sms';
- Http::post($sms_url,['sms_id'=>$sms_id,'req'=>json_encode($data),'resp'=>$response]);
- return $response;
- }
- // dd($response->json());
- }
- }
|