get signed in user on home screen

This commit is contained in:
2024-07-26 13:01:15 +02:00
parent e825d73954
commit cae2ca2320

View File

@@ -6,6 +6,7 @@ import 'package:patient_manager/env/env.dart';
import 'package:patient_manager/components/homeTileGrid.dart'; import 'package:patient_manager/components/homeTileGrid.dart';
import 'package:patient_manager/components/myAppBar.dart'; import 'package:patient_manager/components/myAppBar.dart';
import 'package:patient_manager/main.dart'; import 'package:patient_manager/main.dart';
import 'package:patient_manager/objects/appUser.dart';
import 'package:supertokens_flutter/supertokens.dart'; import 'package:supertokens_flutter/supertokens.dart';
import 'package:supertokens_flutter/http.dart' as http; import 'package:supertokens_flutter/http.dart' as http;
@@ -19,6 +20,7 @@ class Home extends StatefulWidget {
} }
class _HomeState extends State<Home> { class _HomeState extends State<Home> {
//late Future<AppUser> signedInUser;
String useremail = ""; String useremail = "";
final baseAPI = AppEnviroment.baseApiUrl; final baseAPI = AppEnviroment.baseApiUrl;
//late Image logo; //late Image logo;
@@ -32,27 +34,45 @@ class _HomeState extends State<Home> {
} }
} }
Future<void> getUserEmail() async { Future<AppUser> getUserDetails() async {
//print("pat man drawer: " + endpointUserData + widget.userEmail);
var uid = await SuperTokens.getUserId(); var uid = await SuperTokens.getUserId();
var response = await http.get(Uri.parse("$baseAPI/user/$uid")); var response = await http.get(Uri.parse("$baseAPI/user/$uid"));
// print(response.statusCode);
// print(response.body);
if (response.statusCode == 200) { if (response.statusCode == 200) {
var user = jsonDecode(response.body); // print("here");
useremail = user["email"]; String body = response.body;
var decodedData = jsonDecode(body);
AppUser u = AppUser.fromJson(decodedData);
// print(u.email);
return u;
} else {
throw Exception("Error: GetUserData status code ${response.statusCode}");
} }
} }
String getEmail() { // Future<void> getUser() async {
return useremail; // var uid = await SuperTokens.getUserId();
} // var response = await http.get(Uri.parse("$baseAPI/user/$uid"));
// if (response.statusCode == 200) {
// var user = jsonDecode(response.body);
// print(user);
// signedInUser = AppUser.fromJson(user as Map<String, dynamic>);
@override // //useremail = user["email"];
void dispose() { // }
// TODO: implement dispose // }
super.dispose();
} // @override
// void dispose() {
// // TODO: implement dispose
// super.dispose();
// }
@override @override
void initState() { void initState() {
//signedInUser = getUserDetails();
super.initState(); super.initState();
} }
@@ -61,54 +81,64 @@ class _HomeState extends State<Home> {
loadImage(); loadImage();
var logo = MzanziInnovationHub.of(context)!.theme.logoImage(); var logo = MzanziInnovationHub.of(context)!.theme.logoImage();
return FutureBuilder( return FutureBuilder(
future: getUserEmail(), future: getUserDetails(),
builder: (contexts, snapshot) { builder: (BuildContext context, AsyncSnapshot<AppUser> snapshot) {
if (snapshot.connectionState == ConnectionState.done) { if (snapshot.connectionState == ConnectionState.done) {
//print("home page: $useremail"); if (snapshot.hasData) {
return Scaffold( return Scaffold(
appBar: const MyAppBar(barTitle: "Mzansi Innovation Hub"), appBar: const MyAppBar(barTitle: "Mzansi Innovation Hub"),
drawer: PatManAppDrawer( drawer: PatManAppDrawer(
userEmail: useremail, signedInUser: snapshot.data!,
logo: logo, logo: logo,
), //HomeAppDrawer(userEmail: useremail), ), //HomeAppDrawer(userEmail: useremail),
body: HomeTileGrid( body: HomeTileGrid(
userEmail: useremail, signedInUser: snapshot.data!,
), ),
// floatingActionButtonLocation: FloatingActionButtonLocation.endTop, // floatingActionButtonLocation: FloatingActionButtonLocation.endTop,
// floatingActionButton: Padding( // floatingActionButton: Padding(
// padding: const EdgeInsets.only(top: 65, right: 5), // padding: const EdgeInsets.only(top: 65, right: 5),
// child: FloatingActionButton.extended( // child: FloatingActionButton.extended(
// label: const Text( // label: const Text(
// "Test Pop Up", // "Test Pop Up",
// style: TextStyle( // style: TextStyle(
// fontWeight: FontWeight.bold, // fontWeight: FontWeight.bold,
// ), // ),
// ), // ),
// //backgroundColor: Colors.blueAccent, // //backgroundColor: Colors.blueAccent,
// onPressed: () { // onPressed: () {
// showDatePicker( // showDatePicker(
// context: context, // context: context,
// initialDate: DateTime.now(), // initialDate: DateTime.now(),
// firstDate: DateTime(2000), // firstDate: DateTime(2000),
// lastDate: DateTime(2100), // lastDate: DateTime(2100),
// ); // );
// // showDialog( // // showDialog(
// // context: context, // // context: context,
// // builder: (context) => // // builder: (context) =>
// // const MyErrorMessage(errorType: "Input Error"), // // const MyErrorMessage(errorType: "Input Error"),
// // ); // // );
// }, // },
// icon: const Icon( // icon: const Icon(
// Icons.warning, // Icons.warning,
// //color: MzanziInnovationHub.of(context)!.theme.primaryColor(), // //color: MzanziInnovationHub.of(context)!.theme.primaryColor(),
// ), // ),
// ), // ),
); );
//); } else {
} else { return Center(
return const Center(child: CircularProgressIndicator()); child: Text(
'${snapshot.error} occurred',
style: TextStyle(fontSize: 18),
),
);
}
} }
return const Center(
child: CircularProgressIndicator(),
);
}, },
); );
//);
} }
} }