diff --git a/app/Http/Controllers/ClientsController.php b/app/Http/Controllers/ClientsController.php index 62b1c0e..dad0a0e 100755 --- a/app/Http/Controllers/ClientsController.php +++ b/app/Http/Controllers/ClientsController.php @@ -854,21 +854,22 @@ class ClientsController extends Controller public function getShortCodes($type){ //$auth_users = Models\SystemUser::pluck('name', 'id'); //todo : separate the short codes into individual pages + // dd(session('current_user.designation')); switch ($type) { case 'sms': - $codes_data = Models\ClientShortCode::with('client_info','client_info', 'update_info')->where('code_type', 'sms')->get(); + $codes_data = Models\ClientShortCode::with('client_info','client_info', 'update_info')->where('code_type', 'sms')->orderBy('id', 'DESC')->get(); break; case 'ussd': - $codes_data = Models\ClientShortCode::with('client_info', 'client_info', 'update_info')->where('code_type', 'ussd')->get(); + $codes_data = Models\ClientShortCode::with('client_info', 'client_info', 'update_info')->where('code_type', 'ussd')->orderBy('id', 'DESC')->get(); break; case 'voice': - $codes_data = Models\ClientShortCode::with('client_info', 'client_info', 'update_info')->where('code_type', 'voice')->get(); + $codes_data = Models\ClientShortCode::with('client_info', 'client_info', 'update_info')->where('code_type', 'voice')->orderBy('id', 'DESC')->get(); break; default: // code... show 404 break; } - $codes = Models\ClientShortCode::with('update_info')->get(); + // $codes = Models\ClientShortCode::with('update_info')->get(); $data = [ 'page_title' => 'Client Short Codes', diff --git a/app/Http/Controllers/ShortCodesController.php b/app/Http/Controllers/ShortCodesController.php new file mode 100644 index 0000000..b4af376 --- /dev/null +++ b/app/Http/Controllers/ShortCodesController.php @@ -0,0 +1,151 @@ + 'Short Codes', + 'type' => 'SMS', + 'current_user' => session('current_user') + ]; + return view('shortcodes.index', $data); + } + + public function smsindex(){ + // $codes_data = Models\ClientShortCode::groupBy('code_type')->get(); + $codes_data = \DB::table('client_short_codes') + ->select('code_type', \DB::raw('count(*) as total')) + ->groupBy('code_type') + ->get(); + $data = [ + 'page_title' => 'Short Codes', + 'type' => 'SMS', + 'codes_data' => $codes_data, + 'current_user' => session('current_user') + ]; + return view('shortcodes.smsindex', $data); + } + public function getShortCodesJson(Request $request){ + #$this->log_query(); + //$codes_data = Models\ClientShortCode::with('client_info', 'update_info')->where('code_type', 'sms')->orderBy('id', 'DESC')->get(); + + $shortcode_arr = \DB::table('client_short_codes') + ->join('auth_users', 'auth_users.id', '=', 'client_short_codes.last_updated_by') + ->join('clients', 'clients.id', '=', 'client_short_codes.client_id') + ->select('client_short_codes.id', 'client_short_codes.name', 'client_short_codes.shortcode', 'clients.name AS clientName', 'client_short_codes.network', 'client_short_codes.toll_free', 'client_short_codes.status', 'client_short_codes.remarks', 'client_short_codes.launch_date', 'client_short_codes.expiry_date', 'client_short_codes.last_updated_by', 'auth_users.name AS modifiedBy') + ->where('client_short_codes.code_type', 'sms') + ->orderBy('client_short_codes.shortcode', 'ASC') + ->paginate(15); + + if($request->has('keyword')){ + $keyword = $request->keyword; + $code_type = 'sms'; + $shortcode_arr = \DB::table('client_short_codes') + ->join('auth_users', 'auth_users.id', '=', 'client_short_codes.last_updated_by') + ->join('clients', 'clients.id', '=', 'client_short_codes.client_id') + ->select('client_short_codes.id', 'client_short_codes.name', 'client_short_codes.shortcode', 'clients.name AS clientName', 'client_short_codes.network', 'client_short_codes.toll_free', 'client_short_codes.status', 'client_short_codes.remarks', 'client_short_codes.launch_date', 'client_short_codes.expiry_date', 'client_short_codes.last_updated_by', 'auth_users.name AS modifiedBy') + ->whereRaw("code_type = '$code_type' AND (client_short_codes.name LIKE '%$keyword%' OR client_short_codes.shortcode LIKE '%$keyword%' OR client_short_codes.status LIKE '%$keyword%' OR client_short_codes.network LIKE '%$keyword%' OR client_short_codes.toll_free LIKE '%$keyword%' OR client_short_codes.launch_date LIKE '%$keyword%' OR client_short_codes.expiry_date LIKE '%$keyword%' OR clients.name LIKE '%$keyword%' OR auth_users.name LIKE '%$keyword%')") + // ->where('code_type', $code_type) + ->orderBy('client_short_codes.shortcode', 'ASC') + ->paginate(15); + } + return response()->json($shortcode_arr); + } + + public function ussdindex(){ + // $codes_data = Models\ClientShortCode::groupBy('code_type')->get(); + $codes_data = \DB::table('client_short_codes') + ->select('code_type', \DB::raw('count(*) as total')) + ->groupBy('code_type') + ->get(); + $data = [ + 'page_title' => 'Short Codes', + 'type' => 'USSD', + 'codes_data' => $codes_data, + 'current_user' => session('current_user') + ]; + return view('shortcodes.ussdindex', $data); + } + public function getUssdShortCodesJson(Request $request){ + #$this->log_query(); + //$codes_data = Models\ClientShortCode::with('client_info', 'update_info')->where('code_type', 'sms')->orderBy('id', 'DESC')->get(); + + $shortcode_arr = \DB::table('client_short_codes') + ->join('auth_users', 'auth_users.id', '=', 'client_short_codes.last_updated_by') + ->join('clients', 'clients.id', '=', 'client_short_codes.client_id') + ->select('client_short_codes.id', 'client_short_codes.name', 'client_short_codes.shortcode', 'clients.name AS clientName', 'client_short_codes.network', 'client_short_codes.toll_free', 'client_short_codes.status', 'client_short_codes.remarks', 'client_short_codes.launch_date', 'client_short_codes.expiry_date', 'client_short_codes.last_updated_by', 'auth_users.name AS modifiedBy') + ->where('client_short_codes.code_type', 'ussd') + ->orderBy('client_short_codes.shortcode', 'ASC') + ->paginate(15); + + if($request->has('keyword')){ + $keyword = $request->keyword; + $code_type = 'ussd'; + $shortcode_arr = \DB::table('client_short_codes') + ->join('auth_users', 'auth_users.id', '=', 'client_short_codes.last_updated_by') + ->join('clients', 'clients.id', '=', 'client_short_codes.client_id') + ->select('client_short_codes.id', 'client_short_codes.name', 'client_short_codes.shortcode', 'clients.name AS clientName', 'client_short_codes.network', 'client_short_codes.toll_free', 'client_short_codes.status', 'client_short_codes.remarks', 'client_short_codes.launch_date', 'client_short_codes.expiry_date', 'client_short_codes.last_updated_by', 'auth_users.name AS modifiedBy') + ->whereRaw("code_type = '$code_type' AND (client_short_codes.name LIKE '%$keyword%' OR client_short_codes.shortcode LIKE '%$keyword%' OR client_short_codes.status LIKE '%$keyword%' OR client_short_codes.network LIKE '%$keyword%' OR client_short_codes.toll_free LIKE '%$keyword%' OR client_short_codes.launch_date LIKE '%$keyword%' OR client_short_codes.expiry_date LIKE '%$keyword%' OR clients.name LIKE '%$keyword%' OR auth_users.name LIKE '%$keyword%')") + // ->where('code_type', $code_type) + ->orderBy('client_short_codes.shortcode', 'ASC') + ->paginate(15); + } + return response()->json($shortcode_arr); + } + + + public function voiceindex(){ + // $codes_data = Models\ClientShortCode::groupBy('code_type')->get(); + $codes_data = \DB::table('client_short_codes') + ->select('code_type', \DB::raw('count(*) as total')) + ->groupBy('code_type') + ->get(); + $data = [ + 'page_title' => 'Short Codes', + 'type' => 'Voice', + 'codes_data' => $codes_data, + 'current_user' => session('current_user') + ]; + return view('shortcodes.voiceindex', $data); + } + public function getVoiceShortCodesJson(Request $request){ + #$this->log_query(); + //$codes_data = Models\ClientShortCode::with('client_info', 'update_info')->where('code_type', 'sms')->orderBy('id', 'DESC')->get(); + + $shortcode_arr = \DB::table('client_short_codes') + ->join('auth_users', 'auth_users.id', '=', 'client_short_codes.last_updated_by') + ->join('clients', 'clients.id', '=', 'client_short_codes.client_id') + ->select('client_short_codes.id', 'client_short_codes.name', 'client_short_codes.shortcode', 'clients.name AS clientName', 'client_short_codes.network', 'client_short_codes.toll_free', 'client_short_codes.status', 'client_short_codes.remarks', 'client_short_codes.launch_date', 'client_short_codes.expiry_date', 'client_short_codes.last_updated_by', 'auth_users.name AS modifiedBy') + ->where('client_short_codes.code_type', 'voice') + ->orderBy('client_short_codes.shortcode', 'ASC') + ->paginate(15); + + if($request->has('keyword')){ + $keyword = $request->keyword; + $code_type = 'voice'; + $shortcode_arr = \DB::table('client_short_codes') + ->join('auth_users', 'auth_users.id', '=', 'client_short_codes.last_updated_by') + ->join('clients', 'clients.id', '=', 'client_short_codes.client_id') + ->select('client_short_codes.id', 'client_short_codes.name', 'client_short_codes.shortcode', 'clients.name AS clientName', 'client_short_codes.network', 'client_short_codes.toll_free', 'client_short_codes.status', 'client_short_codes.remarks', 'client_short_codes.launch_date', 'client_short_codes.expiry_date', 'client_short_codes.last_updated_by', 'auth_users.name AS modifiedBy') + ->whereRaw("code_type = '$code_type' AND (client_short_codes.name LIKE '%$keyword%' OR client_short_codes.shortcode LIKE '%$keyword%' OR client_short_codes.status LIKE '%$keyword%' OR client_short_codes.network LIKE '%$keyword%' OR client_short_codes.toll_free LIKE '%$keyword%' OR client_short_codes.launch_date LIKE '%$keyword%' OR client_short_codes.expiry_date LIKE '%$keyword%' OR clients.name LIKE '%$keyword%' OR auth_users.name LIKE '%$keyword%')") + // ->where('code_type', $code_type) + ->orderBy('client_short_codes.shortcode', 'ASC') + ->paginate(15); + } + return response()->json($shortcode_arr); + } + + + + + +} diff --git a/resources/views/client/partials/shortcode-index.blade.php b/resources/views/client/partials/shortcode-index.blade.php index 91c0f1d..e0f30b0 100644 --- a/resources/views/client/partials/shortcode-index.blade.php +++ b/resources/views/client/partials/shortcode-index.blade.php @@ -1,6 +1,6 @@