add notifications api call

This commit is contained in:
2024-10-07 14:30:08 +02:00
parent 7019440cc1
commit a64dae56b4
4 changed files with 76 additions and 4 deletions

View File

@@ -21,11 +21,13 @@ import 'package:patient_manager/mih_objects/app_user.dart';
import 'package:patient_manager/mih_objects/arguments.dart';
import 'package:patient_manager/mih_objects/business.dart';
import 'package:patient_manager/mih_objects/business_user.dart';
import 'package:patient_manager/mih_objects/notification.dart';
class MIHHome extends StatefulWidget {
final AppUser signedInUser;
final BusinessUser? businessUser;
final Business? business;
final List<MIHNotification> notifications;
final ImageProvider<Object>? propicFile;
final bool isUserNew;
final bool isBusinessUser;
@@ -36,6 +38,7 @@ class MIHHome extends StatefulWidget {
required this.signedInUser,
required this.businessUser,
required this.business,
required this.notifications,
required this.propicFile,
required this.isUserNew,
required this.isBusinessUser,
@@ -631,7 +634,7 @@ class _MIHHomeState extends State<MIHHome> {
MIHNotificationDrawer getSecondaryActionDrawer() {
return MIHNotificationDrawer(
signedInUser: widget.signedInUser,
propicFile: widget.propicFile,
notifications: widget.notifications,
);
}

View File

@@ -11,6 +11,7 @@ import 'package:patient_manager/mih_objects/app_user.dart';
import 'package:patient_manager/mih_objects/arguments.dart';
import 'package:patient_manager/mih_objects/business.dart';
import 'package:patient_manager/mih_objects/business_user.dart';
import 'package:patient_manager/mih_objects/notification.dart';
import 'package:patient_manager/mih_packages/mih_home/mih_home.dart';
import 'package:supertokens_flutter/supertokens.dart';
import 'package:supertokens_flutter/http.dart' as http;
@@ -26,6 +27,7 @@ class MIHProfileGetter extends StatefulWidget {
class _MIHProfileGetterState extends State<MIHProfileGetter> {
String useremail = "";
int amount = 10;
final baseAPI = AppEnviroment.baseApiUrl;
late Future<HomeArguments> profile;
@@ -36,6 +38,7 @@ class _MIHProfileGetterState extends State<MIHProfileGetter> {
AppUser userData;
Business? busData;
BusinessUser? bUserData;
List<MIHNotification> notifi;
String userPic;
// Get Userdata
@@ -53,8 +56,9 @@ class _MIHProfileGetterState extends State<MIHProfileGetter> {
}
// Get BusinessUserdata
var responseBUser =
await http.get(Uri.parse("$baseAPI/business-user/$uid"));
var responseBUser = await http.get(
Uri.parse("$baseAPI/business-user/$uid"),
);
if (responseBUser.statusCode == 200) {
String body = responseBUser.body;
var decodedData = jsonDecode(body);
@@ -99,8 +103,26 @@ class _MIHProfileGetterState extends State<MIHProfileGetter> {
// "Error: GetUserData status code ${response.statusCode}");
}
}
//Get Notifications
var responseNotification =
await http.get(Uri.parse("$baseAPI/notifications/$uid?amount=$amount"));
if (responseNotification.statusCode == 200) {
String body = responseNotification.body;
// var decodedData = jsonDecode(body);
// MIHNotification notifications = MIHNotification.fromJson(decodedData);
Iterable l = jsonDecode(body);
//print("Here2");
List<MIHNotification> notifications = List<MIHNotification>.from(
l.map((model) => MIHNotification.fromJson(model)));
notifi = notifications;
} else {
notifi = [];
}
//print(userPic);
return HomeArguments(userData, bUserData, busData, userPic);
return HomeArguments(userData, bUserData, busData, notifi, userPic);
}
ImageProvider<Object>? isPictureAvailable(String url) {
@@ -169,6 +191,7 @@ class _MIHProfileGetterState extends State<MIHProfileGetter> {
signedInUser: snapshot.requireData.signedInUser,
businessUser: snapshot.data!.businessUser,
business: snapshot.data!.business,
notifications: snapshot.data!.notifi,
propicFile: isPictureAvailable(snapshot.data!.profilePicUrl),
isUserNew: isUserNew(snapshot.requireData.signedInUser),
isBusinessUser: isBusinessUser(snapshot.requireData.signedInUser),