import 'dart:convert'; import 'package:flutter/material.dart'; import 'package:patient_manager/mih_components/mih_layout/mih_action.dart'; import 'package:patient_manager/mih_components/mih_layout/mih_body.dart'; import 'package:patient_manager/mih_components/mih_layout/mih_header.dart'; import 'package:patient_manager/mih_components/mih_layout/mih_layout_builder.dart'; import 'package:patient_manager/mih_packages/access_review/builder/build_access_request_list.dart'; import 'package:patient_manager/mih_components/mih_inputs_and_buttons/mih_dropdown_input.dart'; import 'package:patient_manager/mih_components/mih_pop_up_messages/mih_loading_circle.dart'; import 'package:patient_manager/mih_env/env.dart'; import 'package:patient_manager/main.dart'; import 'package:patient_manager/mih_objects/access_request.dart'; import 'package:patient_manager/mih_objects/app_user.dart'; import 'package:supertokens_flutter/http.dart' as http; class Appointments extends StatefulWidget { final AppUser signedInUser; const Appointments({ super.key, required this.signedInUser, }); @override State createState() => _PatientAccessRequestState(); } class _PatientAccessRequestState extends State { TextEditingController filterController = TextEditingController(); String baseUrl = AppEnviroment.baseApiUrl; String errorCode = ""; String errorBody = ""; String datefilter = ""; String accessFilter = ""; bool forceRefresh = false; late String selectedDropdown; late Future> accessRequestResults; Future> fetchAccessRequests() async { //print("Patien manager page: $endpoint"); final response = await http.get( Uri.parse("$baseUrl/access-requests/${widget.signedInUser.app_id}")); // print("Here"); // print("Body: ${response.body}"); // print("Code: ${response.statusCode}"); errorCode = response.statusCode.toString(); errorBody = response.body; if (response.statusCode == 200) { //print("Here1"); Iterable l = jsonDecode(response.body); //print("Here2"); List patientQueue = List.from( l.map((model) => AccessRequest.fromJson(model))); //print("Here3"); //print(patientQueue); return patientQueue; } else { throw Exception('failed to load patients'); } } List filterSearchResults(List accessList) { List templist = []; for (var item in accessList) { if (filterController.text == "All") { if (item.date_time.contains(datefilter)) { templist.add(item); } } else { if (item.date_time.contains(datefilter) && item.access.contains(filterController.text.toLowerCase())) { templist.add(item); } } } return templist; } Widget displayAccessRequestList(List accessRequestList) { if (accessRequestList.isNotEmpty) { return BuildAccessRequestList( signedInUser: widget.signedInUser, accessRequests: accessRequestList, // BuildPatientQueueList( // patientQueue: patientQueueList, // signedInUser: widget.signedInUser, // ), ); } else { return Center( child: Text( "No Request have been made.", style: TextStyle( fontSize: 25, color: MzanziInnovationHub.of(context)!.theme.messageTextColor()), textAlign: TextAlign.center, ), ); } } Widget viewAccessRequest(double w, double h) { return Padding( padding: const EdgeInsets.all(15.0), child: SizedBox( width: w, height: h, child: Column(mainAxisSize: MainAxisSize.max, children: [ //const SizedBox(height: 15), const Text( "Access Request", style: TextStyle( fontSize: 25, fontWeight: FontWeight.bold, ), ), const SizedBox(height: 25), SizedBox( width: 500, child: MIHDropdownField( controller: filterController, hintText: "Access Types", dropdownOptions: const ["All", "Approved", "Pending", "Declined"], required: true, editable: true, ), ), const SizedBox(height: 10), FutureBuilder( future: accessRequestResults, builder: (context, snapshot) { //print("patient Queue List ${snapshot.hasData}"); if (snapshot.connectionState == ConnectionState.waiting) { return Expanded( child: Container( //height: 500, decoration: BoxDecoration( color: MzanziInnovationHub.of(context)!.theme.primaryColor(), borderRadius: BorderRadius.circular(25.0), border: Border.all( color: MzanziInnovationHub.of(context)! .theme .secondaryColor(), width: 3.0), ), child: const Mihloadingcircle(), ), ); } else if (snapshot.connectionState == ConnectionState.done) { List accessRequestList; accessRequestList = filterSearchResults(snapshot.requireData); if (accessRequestList.isNotEmpty) { return BuildAccessRequestList( signedInUser: widget.signedInUser, accessRequests: accessRequestList, ); } else { return Center( child: Text( "No Request have been made.", style: TextStyle( fontSize: 25, color: MzanziInnovationHub.of(context)! .theme .messageTextColor()), textAlign: TextAlign.center, ), ); } // return Expanded( // child: displayAccessRequestList(accessRequestList), // ); } else { return Center( child: Text( "$errorCode: Error pulling Patients Data\n$baseUrl/queue/patients/\n$errorBody", style: TextStyle( fontSize: 25, color: MzanziInnovationHub.of(context)! .theme .errorColor()), textAlign: TextAlign.center, ), ); } }, ), ]), ), ); } void refreshList() { if (forceRefresh == true) { setState(() { accessRequestResults = fetchAccessRequests(); forceRefresh = false; }); } else if (selectedDropdown != filterController.text) { setState(() { accessRequestResults = fetchAccessRequests(); selectedDropdown = filterController.text; }); } // setState(() { // accessRequestResults = fetchAccessRequests(); // }); } MIHAction getActionButton() { return MIHAction( icon: const Icon(Icons.arrow_back), iconSize: 35, onTap: () { Navigator.of(context).pop(); Navigator.of(context).popAndPushNamed( '/', ); }, ); } MIHHeader getHeader() { return const MIHHeader( headerAlignment: MainAxisAlignment.center, headerItems: [ Text( "Appointments", style: TextStyle( fontWeight: FontWeight.bold, fontSize: 25, ), ), ], ); } MIHBody getBody() { return MIHBody( borderOn: true, bodyItems: [ const SizedBox(height: 10), Row( mainAxisAlignment: MainAxisAlignment.center, mainAxisSize: MainAxisSize.max, children: [ Flexible( child: MIHDropdownField( controller: filterController, hintText: "Access Types", dropdownOptions: const [ "All", "Approved", "Pending", "Declined", "Cancelled" ], required: true, editable: true, ), ), IconButton( onPressed: () { setState(() { forceRefresh = true; }); refreshList(); }, icon: const Icon( Icons.refresh, ), ), ], ), const SizedBox(height: 10), FutureBuilder( future: accessRequestResults, builder: (context, snapshot) { //print("patient Queue List ${snapshot.hasData}"); if (snapshot.connectionState == ConnectionState.waiting) { return const Mihloadingcircle(); } else if (snapshot.connectionState == ConnectionState.done) { List accessRequestList; accessRequestList = filterSearchResults(snapshot.requireData); if (accessRequestList.isNotEmpty) { return BuildAccessRequestList( signedInUser: widget.signedInUser, accessRequests: accessRequestList, ); } else { return Center( child: Text( "No Request have been made.", style: TextStyle( fontSize: 25, color: MzanziInnovationHub.of(context)! .theme .messageTextColor()), textAlign: TextAlign.center, ), ); } // return Expanded( // child: displayAccessRequestList(accessRequestList), // ); } else { return Center( child: Text( "$errorCode: Error pulling Patients Data\n$baseUrl/queue/patients/\n$errorBody", style: TextStyle( fontSize: 25, color: MzanziInnovationHub.of(context)!.theme.errorColor()), textAlign: TextAlign.center, ), ); } }, ), ], ); } @override void dispose() { filterController.dispose(); super.dispose(); } @override void initState() { selectedDropdown = "All"; filterController.text = "All"; filterController.addListener(refreshList); setState(() { accessRequestResults = fetchAccessRequests(); }); super.initState(); } @override Widget build(BuildContext context) { return MIHLayoutBuilder( actionButton: getActionButton(), header: getHeader(), secondaryActionButton: null, body: getBody(), actionDrawer: null, secondaryActionDrawer: null, bottomNavBar: null, pullDownToRefresh: false, onPullDown: () async {}, ); // return Scaffold( // // appBar: const MIHAppBar( // // barTitle: "Access Reviews", // // propicFile: null, // // ), // //drawer: MIHAppDrawer(signedInUser: widget.signedInUser), // body: SafeArea( // child: Stack( // children: [ // viewAccessRequest(screenWidth, screenHeight), // Positioned( // top: 10, // left: 5, // width: 50, // height: 50, // child: IconButton( // onPressed: () { // Navigator.of(context).pop(); // }, // icon: const Icon(Icons.arrow_back), // ), // ), // Positioned( // top: 10, // right: 5, // width: 50, // height: 50, // child: IconButton( // onPressed: () { // setState(() { // forceRefresh = true; // }); // refreshList(); // }, // icon: const Icon( // Icons.refresh, // ), // ), // ) // ], // ), // ), // ); } }