pat man used signedinUser as paremeter and required user to search for patient by id or medaid no

This commit is contained in:
2024-08-08 16:07:03 +02:00
parent 04f1255083
commit e418c8118b

View File

@@ -2,8 +2,10 @@ import 'dart:async';
import 'dart:convert'; import 'dart:convert';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:patient_manager/components/buildPatientList.dart'; import 'package:patient_manager/components/buildPatientList.dart';
import 'package:patient_manager/components/mihAppBar.dart'; import 'package:patient_manager/components/mihAppBar.dart';
import 'package:patient_manager/objects/appUser.dart';
import 'package:supertokens_flutter/http.dart' as http; import 'package:supertokens_flutter/http.dart' as http;
import 'package:patient_manager/components/mySearchInput.dart'; import 'package:patient_manager/components/mySearchInput.dart';
import 'package:patient_manager/env/env.dart'; import 'package:patient_manager/env/env.dart';
@@ -11,11 +13,11 @@ import 'package:patient_manager/main.dart';
import 'package:patient_manager/objects/patients.dart'; import 'package:patient_manager/objects/patients.dart';
class PatientManager extends StatefulWidget { class PatientManager extends StatefulWidget {
final String userEmail; final AppUser signedInUser;
const PatientManager({ const PatientManager({
super.key, super.key,
required this.userEmail, required this.signedInUser,
}); });
@override @override
@@ -25,16 +27,20 @@ class PatientManager extends StatefulWidget {
// //
class _PatientManagerState extends State<PatientManager> { class _PatientManagerState extends State<PatientManager> {
TextEditingController searchController = TextEditingController(); TextEditingController searchController = TextEditingController();
String endpoint = "${AppEnviroment.baseApiUrl}/patients/user/"; String baseUrl = AppEnviroment.baseApiUrl;
late Future<List<Patient>> futurePatients;
final FocusNode _focusNode = FocusNode();
String errorCode = ""; String errorCode = "";
String errorBody = ""; String errorBody = "";
String searchString = ""; String searchString = "";
Future<List<Patient>> fetchPatients(String endpoint) async { late Future<List<Patient>> patientSearchResults;
Future<List<Patient>> fetchPatients(String search) async {
//print("Patien manager page: $endpoint"); //print("Patien manager page: $endpoint");
final response = await http.get(Uri.parse(endpoint)); final response =
await http.get(Uri.parse("$baseUrl/patients/search/$search"));
// print("Here"); // print("Here");
// print("Body: ${response.body}"); // print("Body: ${response.body}");
// print("Code: ${response.statusCode}"); // print("Code: ${response.statusCode}");
@@ -68,15 +74,16 @@ class _PatientManagerState extends State<PatientManager> {
return templist; return templist;
} }
void submitForm() {
setState(() {
searchString = searchController.text;
patientSearchResults = fetchPatients(searchString);
});
}
Widget displayList(List<Patient> patientsList, String searchString) { Widget displayList(List<Patient> patientsList, String searchString) {
if (searchString.isNotEmpty && searchString != "") { if (searchString.isNotEmpty && searchString != "") {
return Padding( return Container(
padding: const EdgeInsets.only(
left: 25,
right: 25,
bottom: 25,
),
child: Container(
height: 500, height: 500,
decoration: BoxDecoration( decoration: BoxDecoration(
color: MzanziInnovationHub.of(context)!.theme.primaryColor(), color: MzanziInnovationHub.of(context)!.theme.primaryColor(),
@@ -88,18 +95,11 @@ class _PatientManagerState extends State<PatientManager> {
), ),
child: BuildPatientsList( child: BuildPatientsList(
patients: patientsList, patients: patientsList,
//searchString: searchString, signedInUser: widget.signedInUser,
),
), ),
); );
} }
return Padding( return Container(
padding: const EdgeInsets.only(
left: 25,
right: 25,
bottom: 25,
),
child: Container(
height: 500, height: 500,
decoration: BoxDecoration( decoration: BoxDecoration(
color: MzanziInnovationHub.of(context)!.theme.primaryColor(), color: MzanziInnovationHub.of(context)!.theme.primaryColor(),
@@ -113,17 +113,30 @@ class _PatientManagerState extends State<PatientManager> {
"Enter ID or Medical Aid No. of Patient", "Enter ID or Medical Aid No. of Patient",
style: TextStyle( style: TextStyle(
fontSize: 25, fontSize: 25,
color: color: MzanziInnovationHub.of(context)!.theme.messageTextColor()),
MzanziInnovationHub.of(context)!.theme.messageTextColor()),
textAlign: TextAlign.center, textAlign: TextAlign.center,
), ),
), ),
),
); );
} }
Widget patientSearch(double w, double h) { Widget patientSearch(double w, double h) {
return SizedBox( return KeyboardListener(
focusNode: _focusNode,
autofocus: true,
onKeyEvent: (event) async {
if (event is KeyDownEvent &&
event.logicalKey == LogicalKeyboardKey.enter) {
submitForm();
}
},
child: Padding(
padding: const EdgeInsets.only(
left: 25,
right: 25,
bottom: 25,
),
child: SizedBox(
width: w, width: w,
height: h, height: h,
child: Column(mainAxisSize: MainAxisSize.max, children: [ child: Column(mainAxisSize: MainAxisSize.max, children: [
@@ -134,27 +147,19 @@ class _PatientManagerState extends State<PatientManager> {
hintText: "ID or Medical Aid No. Search", hintText: "ID or Medical Aid No. Search",
required: false, required: false,
editable: true, editable: true,
onTap: () {}, onTap: () {
onChanged: (value) { submitForm();
setState(() {
searchString = value;
});
}, },
onChanged: (value) {},
), ),
//spacer //spacer
const SizedBox(height: 10), const SizedBox(height: 10),
FutureBuilder( FutureBuilder(
future: futurePatients, future: patientSearchResults,
builder: (context, snapshot) { builder: (context, snapshot) {
//print("patient Liust ${snapshot.data}"); //print("patient Liust ${snapshot.data}");
if (snapshot.connectionState == ConnectionState.waiting) { if (snapshot.connectionState == ConnectionState.waiting) {
return Padding( return Container(
padding: const EdgeInsets.only(
left: 25,
right: 25,
bottom: 25,
),
child: Container(
height: 500, height: 500,
decoration: BoxDecoration( decoration: BoxDecoration(
color: color:
@@ -169,7 +174,6 @@ class _PatientManagerState extends State<PatientManager> {
child: const Center( child: const Center(
child: CircularProgressIndicator(), child: CircularProgressIndicator(),
), ),
),
); );
} else if (snapshot.hasData) { } else if (snapshot.hasData) {
List<Patient> patientsList; List<Patient> patientsList;
@@ -185,13 +189,7 @@ class _PatientManagerState extends State<PatientManager> {
child: displayList(patientsList, searchString), child: displayList(patientsList, searchString),
); );
} else { } else {
return Padding( return Container(
padding: const EdgeInsets.only(
left: 25,
right: 25,
bottom: 25,
),
child: Container(
height: 500, height: 500,
decoration: BoxDecoration( decoration: BoxDecoration(
color: color:
@@ -205,7 +203,7 @@ class _PatientManagerState extends State<PatientManager> {
), ),
child: Center( child: Center(
child: Text( child: Text(
"$errorCode: Error pulling Patients Data\n$endpoint${widget.userEmail}\n$errorBody", "$errorCode: Error pulling Patients Data\n$baseUrl${widget.signedInUser.email}\n$errorBody",
style: TextStyle( style: TextStyle(
fontSize: 25, fontSize: 25,
color: MzanziInnovationHub.of(context)! color: MzanziInnovationHub.of(context)!
@@ -214,12 +212,13 @@ class _PatientManagerState extends State<PatientManager> {
textAlign: TextAlign.center, textAlign: TextAlign.center,
), ),
), ),
),
); );
} }
}, },
), ),
]), ]),
),
),
); );
} }
@@ -228,7 +227,7 @@ class _PatientManagerState extends State<PatientManager> {
// errorCode = ""; // errorCode = "";
// errorBody = ""; // errorBody = "";
//print("patient manager page: ${widget.userEmail}"); //print("patient manager page: ${widget.userEmail}");
futurePatients = fetchPatients(endpoint + widget.userEmail); patientSearchResults = fetchPatients("abc");
super.initState(); super.initState();
} }
@@ -243,24 +242,24 @@ class _PatientManagerState extends State<PatientManager> {
// logo: MzanziInnovationHub.of(context)!.theme.logoImage(), // logo: MzanziInnovationHub.of(context)!.theme.logoImage(),
// ), // ),
//floatingActionButtonLocation: FloatingActionButtonLocation., //floatingActionButtonLocation: FloatingActionButtonLocation.,
floatingActionButton: FloatingActionButton.extended( // floatingActionButton: FloatingActionButton.extended(
label: Text( // label: Text(
"Add Patient", // "Add Patient",
style: TextStyle( // style: TextStyle(
fontWeight: FontWeight.bold, // fontWeight: FontWeight.bold,
color: MzanziInnovationHub.of(context)!.theme.primaryColor(), // color: MzanziInnovationHub.of(context)!.theme.primaryColor(),
), // ),
), // ),
//backgroundColor: Colors.blueAccent, // //backgroundColor: Colors.blueAccent,
onPressed: () { // onPressed: () {
Navigator.of(context) // Navigator.of(context).pushNamed('/patient-manager/add',
.pushNamed('/patient-manager/add', arguments: widget.userEmail); // arguments: widget.signedInUser.email);
}, // },
icon: Icon( // icon: Icon(
Icons.add, // Icons.add,
color: MzanziInnovationHub.of(context)!.theme.primaryColor(), // color: MzanziInnovationHub.of(context)!.theme.primaryColor(),
), // ),
), // ),
body: patientSearch(screenWidth, screenHeight), body: patientSearch(screenWidth, screenHeight),
); );
} }