Patien View page added to display selected patient.

This commit is contained in:
2024-04-07 15:28:52 +02:00
parent 9c8406367e
commit d9e2afd571
5 changed files with 77 additions and 29 deletions

View File

@@ -14,10 +14,15 @@ class BuildPatientsList extends StatefulWidget {
State<BuildPatientsList> createState() => _BuildPatientsListState(); State<BuildPatientsList> createState() => _BuildPatientsListState();
} }
int indexOn = 0;
class _BuildPatientsListState extends State<BuildPatientsList> { class _BuildPatientsListState extends State<BuildPatientsList> {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return ListView.builder( return ListView.separated(
separatorBuilder: (BuildContext context, int index) {
return Divider();
},
itemCount: widget.patients.length, itemCount: widget.patients.length,
itemBuilder: (context, index) { itemBuilder: (context, index) {
//final patient = widget.patients[index].id_no.contains(widget.searchString); //final patient = widget.patients[index].id_no.contains(widget.searchString);
@@ -27,6 +32,13 @@ class _BuildPatientsListState extends State<BuildPatientsList> {
" " + " " +
widget.patients[index].last_name), widget.patients[index].last_name),
subtitle: Text(widget.patients[index].id_no), subtitle: Text(widget.patients[index].id_no),
onTap: () {
setState(() {
Navigator.of(context).pushNamed('/patient-manager/patient',
arguments: widget.patients[index]);
});
},
trailing: Icon(Icons.arrow_forward),
) )
: Container(); : Container();
}, },

View File

@@ -56,4 +56,8 @@ class Patient {
_ => throw const FormatException('Failed to load album.'), _ => throw const FormatException('Failed to load album.'),
}; };
} }
String getIDNum() {
return id_no;
}
} }

View File

@@ -48,14 +48,6 @@ class _PatientManagerState extends State<PatientManager> {
super.initState(); super.initState();
} }
// void filterSearchResults(String query) {
// setState(() {
// futurePatients = futurePatientsList
// .where((item) => item.toLowerCase().contains(query.toLowerCase()))
// .toList();
// });
// }
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
@@ -69,27 +61,33 @@ class _PatientManagerState extends State<PatientManager> {
} else if (snapshot.hasData) { } else if (snapshot.hasData) {
final patientsList = snapshot.data!; final patientsList = snapshot.data!;
return Column(children: [ return Row(
//spacer children: [
const SizedBox(height: 10), Expanded(
MySearchField( child: Column(children: [
controller: searchController, //spacer
hintText: "ID Search", const SizedBox(height: 10),
onChanged: (value) { MySearchField(
setState(() { controller: searchController,
searchString = value; hintText: "ID Search",
}); onChanged: (value) {
}, setState(() {
), searchString = value;
//spacer });
const SizedBox(height: 10), },
Expanded( ),
child: BuildPatientsList( //spacer
patients: patientsList, const SizedBox(height: 10),
searchString: searchString, Expanded(
child: BuildPatientsList(
patients: patientsList,
searchString: searchString,
),
),
]),
), ),
), ],
]); );
} else { } else {
return const MyAppDrawer(drawerTitle: "Error pulling email"); return const MyAppDrawer(drawerTitle: "Error pulling email");
} }

View File

@@ -0,0 +1,23 @@
import 'package:flutter/material.dart';
import 'package:patient_manager/components/myAppBar.dart';
import 'package:patient_manager/objects/patients.dart';
class PatientView extends StatefulWidget {
final Patient selectedPatient;
const PatientView({super.key, required this.selectedPatient});
@override
State<PatientView> createState() => _PatientViewState();
}
class _PatientViewState extends State<PatientView> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: const MyAppBar(barTitle: "Patient View"),
body: Center(
child: Text(widget.selectedPatient.first_name),
),
);
}
}

View File

@@ -3,8 +3,10 @@ import 'package:flutter/material.dart';
import 'package:patient_manager/Authentication/authCheck.dart'; import 'package:patient_manager/Authentication/authCheck.dart';
import 'package:patient_manager/components/myAppBar.dart'; import 'package:patient_manager/components/myAppBar.dart';
import 'package:patient_manager/components/signInOrRegister.dart'; import 'package:patient_manager/components/signInOrRegister.dart';
import 'package:patient_manager/objects/patients.dart';
import 'package:patient_manager/pages/home.dart'; import 'package:patient_manager/pages/home.dart';
import 'package:patient_manager/pages/patientManager.dart'; import 'package:patient_manager/pages/patientManager.dart';
import 'package:patient_manager/pages/patientView.dart';
class RouteGenerator { class RouteGenerator {
static Route<dynamic> generateRoute(RouteSettings settings) { static Route<dynamic> generateRoute(RouteSettings settings) {
@@ -24,6 +26,15 @@ class RouteGenerator {
); );
} }
return _errorRoute(); return _errorRoute();
case '/patient-manager/patient':
if (args is Patient) {
return MaterialPageRoute(
builder: (_) => PatientView(
selectedPatient: args,
),
);
}
return _errorRoute();
case '/signin': case '/signin':
return MaterialPageRoute(builder: (_) => const SignInOrRegister()); return MaterialPageRoute(builder: (_) => const SignInOrRegister());
// //case '/signIn': // //case '/signIn':