QOL: Mzansi profile Personal get data on package open
This commit is contained in:
@@ -2,10 +2,12 @@ import 'package:go_router/go_router.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_action.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_package_components/mih_package_tools.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_pop_up_messages/mih_loading_circle.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_packages/mzansi_profile/personal_profile/package_tools/mih_personal_profile.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_packages/mzansi_profile/personal_profile/package_tools/mih_personal_settings.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_data_helper_services.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class MzansiProfile extends StatefulWidget {
|
||||
@@ -18,16 +20,50 @@ class MzansiProfile extends StatefulWidget {
|
||||
}
|
||||
|
||||
class _MzansiProfileState extends State<MzansiProfile> {
|
||||
bool _isLoadingInitialData = true;
|
||||
|
||||
Future<void> _loadInitialData() async {
|
||||
setState(() {
|
||||
_isLoadingInitialData = true;
|
||||
});
|
||||
MzansiProfileProvider mzansiProfileProvider =
|
||||
context.read<MzansiProfileProvider>();
|
||||
await MihDataHelperServices().loadUserDataOnly(
|
||||
mzansiProfileProvider,
|
||||
);
|
||||
setState(() {
|
||||
_isLoadingInitialData = false;
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
_loadInitialData();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return MihPackage(
|
||||
appActionButton: getAction(),
|
||||
appTools: getTools(),
|
||||
appBody: getToolBody(),
|
||||
appToolTitles: getToolTitle(),
|
||||
selectedbodyIndex: context.watch<MzansiProfileProvider>().personalIndex,
|
||||
onIndexChange: (newIndex) {
|
||||
context.read<MzansiProfileProvider>().setPersonalIndex(newIndex);
|
||||
return Consumer<MzansiProfileProvider>(
|
||||
builder: (BuildContext context, MzansiProfileProvider profileProvider,
|
||||
Widget? child) {
|
||||
if (_isLoadingInitialData) {
|
||||
return Scaffold(
|
||||
body: Center(
|
||||
child: Mihloadingcircle(),
|
||||
),
|
||||
);
|
||||
}
|
||||
return MihPackage(
|
||||
appActionButton: getAction(),
|
||||
appTools: getTools(),
|
||||
appBody: getToolBody(),
|
||||
appToolTitles: getToolTitle(),
|
||||
selectedbodyIndex: profileProvider.personalIndex,
|
||||
onIndexChange: (newIndex) {
|
||||
profileProvider.setPersonalIndex(newIndex);
|
||||
},
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
@@ -8,7 +8,6 @@ import 'package:flutter/material.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_config/mih_env.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_file_services.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:supertokens_flutter/supertokens.dart';
|
||||
import '../mih_components/mih_pop_up_messages/mih_error_message.dart';
|
||||
import 'package:supertokens_flutter/http.dart' as http;
|
||||
@@ -80,7 +79,7 @@ class MihBusinessDetailsServices {
|
||||
}
|
||||
|
||||
Future<Business?> getBusinessDetailsByUser(
|
||||
BuildContext context,
|
||||
MzansiProfileProvider profileProvider,
|
||||
) async {
|
||||
String app_id = await SuperTokens.getUserId();
|
||||
var response = await http.get(
|
||||
@@ -93,7 +92,7 @@ class MihBusinessDetailsServices {
|
||||
String body = response.body;
|
||||
var jsonBody = jsonDecode(body);
|
||||
Business? business = Business.fromJson(jsonBody);
|
||||
context.read<MzansiProfileProvider>().setBusiness(newBusiness: business);
|
||||
profileProvider.setBusiness(newBusiness: business);
|
||||
return business;
|
||||
} else {
|
||||
return null;
|
||||
|
||||
67
Frontend/lib/mih_services/mih_data_helper_services.dart
Normal file
67
Frontend/lib/mih_services/mih_data_helper_services.dart
Normal file
@@ -0,0 +1,67 @@
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/app_user.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/business.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_business_details_services.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_file_services.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_my_business_user_services.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_user_consent_services.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_user_services.dart';
|
||||
|
||||
class MihDataHelperServices {
|
||||
Future<void> getUserData(MzansiProfileProvider profileProvider) async {
|
||||
String url;
|
||||
await MihUserServices().getMyUserDetails(profileProvider);
|
||||
url = await MihFileApi.getMinioFileUrl(
|
||||
profileProvider.user!.pro_pic_path,
|
||||
);
|
||||
profileProvider.setUserProfilePicUrl(url);
|
||||
}
|
||||
|
||||
Future<void> getUserConsentStatus(
|
||||
MzansiProfileProvider profileProvider) async {
|
||||
await MihUserConsentServices().getUserConsentStatus(profileProvider);
|
||||
}
|
||||
|
||||
Future<void> getBusinessData(MzansiProfileProvider profileProvider) async {
|
||||
AppUser? user = profileProvider.user;
|
||||
String logoUrl;
|
||||
String signatureUrl;
|
||||
Business? responseBusiness = await MihBusinessDetailsServices()
|
||||
.getBusinessDetailsByUser(profileProvider);
|
||||
if (responseBusiness != null && user!.type == "business") {
|
||||
logoUrl = await MihFileApi.getMinioFileUrl(
|
||||
profileProvider.business!.logo_path,
|
||||
);
|
||||
profileProvider.setBusinessProfilePicUrl(logoUrl);
|
||||
await MihMyBusinessUserServices().getBusinessUser(profileProvider);
|
||||
signatureUrl = await MihFileApi.getMinioFileUrl(
|
||||
profileProvider.businessUser!.sig_path,
|
||||
);
|
||||
profileProvider.setBusinessUserSignatureUrl(signatureUrl);
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> loadUserDataOnly(MzansiProfileProvider profileProvider) async {
|
||||
if (profileProvider.user == null) {
|
||||
await getUserData(profileProvider);
|
||||
}
|
||||
if (profileProvider.userConsent == null) {
|
||||
await getUserConsentStatus(profileProvider);
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> loadUserDataWithBusinessesData(
|
||||
MzansiProfileProvider profileProvider) async {
|
||||
if (profileProvider.user == null) {
|
||||
await getUserData(profileProvider);
|
||||
}
|
||||
if (profileProvider.userConsent == null) {
|
||||
await getUserConsentStatus(profileProvider);
|
||||
}
|
||||
if (profileProvider.user != null &&
|
||||
profileProvider.user!.type == "business" &&
|
||||
profileProvider.business == null) {
|
||||
await getBusinessData(profileProvider);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -6,14 +6,13 @@ import 'package:flutter/material.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_config/mih_env.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_services/mih_file_services.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:supertokens_flutter/supertokens.dart';
|
||||
import '../mih_components/mih_pop_up_messages/mih_error_message.dart';
|
||||
import 'package:supertokens_flutter/http.dart' as http;
|
||||
|
||||
class MihMyBusinessUserServices {
|
||||
Future<BusinessUser?> getBusinessUser(
|
||||
BuildContext context,
|
||||
MzansiProfileProvider profileProvider,
|
||||
) async {
|
||||
String app_id = await SuperTokens.getUserId();
|
||||
var response = await http.get(
|
||||
@@ -26,9 +25,7 @@ class MihMyBusinessUserServices {
|
||||
// KenLogger.success(response.body);
|
||||
BusinessUser? businessUser =
|
||||
BusinessUser.fromJson(jsonDecode(response.body));
|
||||
context
|
||||
.read<MzansiProfileProvider>()
|
||||
.setBusinessUser(newBusinessUser: businessUser);
|
||||
profileProvider.setBusinessUser(newBusinessUser: businessUser);
|
||||
return businessUser;
|
||||
} else {
|
||||
return null;
|
||||
|
||||
@@ -4,13 +4,12 @@ import 'package:flutter/material.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_objects/user_consent.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_components/mih_providers/mzansi_profile_provider.dart';
|
||||
import 'package:mzansi_innovation_hub/mih_config/mih_env.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:supertokens_flutter/http.dart' as http;
|
||||
import 'package:supertokens_flutter/supertokens.dart';
|
||||
|
||||
class MihUserConsentServices {
|
||||
Future<void> getUserConsentStatus(
|
||||
BuildContext context,
|
||||
MzansiProfileProvider profileProvider,
|
||||
) async {
|
||||
var app_id = await SuperTokens.getUserId();
|
||||
final response = await http.get(
|
||||
@@ -18,12 +17,8 @@ class MihUserConsentServices {
|
||||
if (response.statusCode == 200) {
|
||||
Map<String, dynamic> userMap = jsonDecode(response.body);
|
||||
UserConsent userConsent = UserConsent.fromJson(userMap);
|
||||
context.read<MzansiProfileProvider>().setUserConsent(userConsent);
|
||||
// return userConsent;
|
||||
profileProvider.setUserConsent(userConsent);
|
||||
}
|
||||
// else {
|
||||
// return null;
|
||||
// }
|
||||
}
|
||||
|
||||
Future<int> insertUserConsentStatus(
|
||||
|
||||
Reference in New Issue
Block a user