diff --git a/.github/workflows/Test deployment.yml b/.github/workflows/Test deployment.yml index 10a6bbe..2b7b414 100644 --- a/.github/workflows/Test deployment.yml +++ b/.github/workflows/Test deployment.yml @@ -30,8 +30,8 @@ jobs: cp /apps/configs/ushauri-dashboard/php.dockerfile /apps/github-workflows/mhealth-apps/ushauri_dashboard/ cp -r /apps/configs/ushauri-dashboard/nginx /apps/github-workflows/mhealth-apps/ushauri_dashboard/ docker-compose down - docker-compose rm -f - docker-compose --env-file .env up -d --build site + docker-compose rm -fv + docker-compose --env-file .env up -d --build # execute normal laravel commands docker-compose exec -T php composer install --ignore-platform-reqs --no-dev docker-compose exec -T php php artisan config:cache diff --git a/app/Http/Controllers/DirectoryController.php b/app/Http/Controllers/DirectoryController.php index b1a2390..c5269ff 100644 --- a/app/Http/Controllers/DirectoryController.php +++ b/app/Http/Controllers/DirectoryController.php @@ -39,4 +39,31 @@ public function directoryLog(Request $request) return response()->json(['status' => 'success']); } + + public function directoryRating(Request $request) + { + $mflcode = $request['FacilityCode']; + $rating = $request['Rating']; + $comment = $request['Comment']; + + //send this rating value to the facility directory + try { + $apiUrl = "https://artrefferal.kenyahmis.org/api/facility/directory/rating"; + + $httpresponse = Http:: + withoutVerifying() + ->post("$apiUrl", [ + 'mflcode' => $mflcode, + 'rating' => $rating, + 'comment' => $comment, + ]); + + $body = json_decode($httpresponse->getBody(), true); + // return response()->json(['body'=>$body]); + } catch (\Exception $e) { + return response()->json(['status' => 'fail','error'=>$e]); + } + + return response()->json(['status' => 'success','mfl_code'=>$mflcode,'rating'=>$rating,'comment'=>$comment]); + } } diff --git a/app/Http/Controllers/FacilityController.php b/app/Http/Controllers/FacilityController.php index 46b9832..5e3e564 100644 --- a/app/Http/Controllers/FacilityController.php +++ b/app/Http/Controllers/FacilityController.php @@ -3,6 +3,7 @@ namespace App\Http\Controllers; use Illuminate\Http\Request; +use Illuminate\Support\Facades\Http; use App\Models\Facility; use App\Models\County; use App\Models\Partner; @@ -368,4 +369,45 @@ public function edit_facility(Request $request) return back(); } } + + public function update_contact(Request $request) + { + $validated = $request->validate([ + 'ccc_phone' => ['required', "regex:/^[0-9][0-9]{9,14}$/", 'max:12'], + 'pmtct_phone' => ['required', "regex:/^[0-9][0-9]{9,14}$/", 'max:12'], + ]); + + //get the facility details + $mflcode = $request->mflcode; + // $partner_name = $request->partner_name; + $ccc_phone = $request->ccc_phone; + $pmtct_phone = $request->pmtct_phone; + + //update the facility contact on ART directory + $apiUrl = env('ART_URL')."facility/directory/edit"; + $httpresponse = Http:: + withoutVerifying() + ->post("$apiUrl", [ + 'mflcode' => $mflcode, + 'ccc_phone' => $ccc_phone, + 'pmtct_phone' => $pmtct_phone, + ]); + + $body = json_decode( $httpresponse->getBody(), true); + + if (is_array($body) && array_key_exists('status', $body)) { + if ($body['status']) { + Alert::success('Success', 'Facility updated successfully!'); + return redirect('/admin/dashboard'); + } else { + Alert::error('Failed', 'An error has occurred please try again later.'); + return back(); + } + }else{ + Alert::error('Failed', 'An error has occurred please try again later.'); + return back(); + } + + + } } diff --git a/app/Http/Controllers/NewDashboardController.php b/app/Http/Controllers/NewDashboardController.php index 08f5836..bd715f8 100644 --- a/app/Http/Controllers/NewDashboardController.php +++ b/app/Http/Controllers/NewDashboardController.php @@ -4,7 +4,7 @@ use Illuminate\Support\Facades\Cache; use Illuminate\Http\Request; - +use Illuminate\Support\Facades\Http; use App\Models\Client; use App\Models\Appointments; @@ -98,6 +98,29 @@ public function dashboard() // showing all the active clients, all appointments, missed appointments if (Auth::user()->access_level == 'Facility') { + + try { + //check if the facility has maintained a contact in the facility directory + $apiUrl = env('ART_URL')."facility/directory"; + + $httpresponse = Http:: + withoutVerifying() + ->get("$apiUrl", [ + 'code' => Auth::user()->facility_id, + ]); + + $body = json_decode($httpresponse->getBody(), true); + + if($body['message'] !== []) + { + $mflcode = Auth::user()->facility_id; + return view('facilities.facility_contact')->with('mflcode',$mflcode); + } + } catch (\Exception $e) { + // dd($e); + } + + $all_partners = Partner::where('status', '=', 'Active') ->remember($this->remember_period) ->pluck('name', 'id'); diff --git a/app/View/Components/Rating.php b/app/View/Components/Rating.php new file mode 100644 index 0000000..0a6ec84 --- /dev/null +++ b/app/View/Components/Rating.php @@ -0,0 +1,71 @@ +mflCode = $mflCode; + $this->searchRating = $searchRating; + $this->searchCounter = $searchRating > 0 ? $searchRating : 5; + // dd($mflCode); + } + + public function isSelected($option) + { + return $option == $this->searchRating; + } + + /** + * Get the view / contents that represent the component. + * + * @return \Illuminate\Contracts\View\View|\Closure|string + */ + public function render() + { + return view('components.rating'); + } +} diff --git a/resources/views/components/rating.blade.php b/resources/views/components/rating.blade.php new file mode 100644 index 0000000..855cf7f --- /dev/null +++ b/resources/views/components/rating.blade.php @@ -0,0 +1,13 @@ +