passo_mobile_app/lib/screens/profile/components/eligibility_screen.dart

258 lines
13 KiB
Dart
Raw Normal View History

2023-02-15 05:23:06 +00:00
import 'package:app_popup_menu/app_popup_menu.dart';
2023-02-09 08:48:19 +00:00
import 'package:flutter/material.dart';
2023-02-15 05:23:06 +00:00
import 'package:flutter_bloc/flutter_bloc.dart';
2023-02-16 07:10:54 +00:00
import 'package:flutter_progress_hud/flutter_progress_hud.dart';
2023-02-15 05:23:06 +00:00
import 'package:fluttericon/font_awesome_icons.dart';
import 'package:unit2/bloc/profile/profile_bloc.dart';
import 'package:unit2/bloc/user/user_bloc.dart';
2023-02-09 08:48:19 +00:00
import 'package:unit2/model/profile/eligibility.dart';
2023-02-23 00:53:14 +00:00
import 'package:unit2/screens/profile/components/eligibility/add_modal.dart';
2023-02-15 05:23:06 +00:00
import 'package:unit2/screens/profile/components/eligibility/edit_modal.dart';
2023-02-09 08:48:19 +00:00
import 'package:unit2/theme-data.dart/box_shadow.dart';
import 'package:unit2/theme-data.dart/colors.dart';
import 'package:unit2/utils/global.dart';
import 'package:unit2/utils/text_container.dart';
import 'package:unit2/widgets/add_leading.dart';
2023-02-09 08:48:19 +00:00
2023-02-15 05:23:06 +00:00
import '../../../utils/alerts.dart';
2023-02-09 08:48:19 +00:00
2023-02-15 05:23:06 +00:00
class EligibiltyScreen extends StatelessWidget {
const EligibiltyScreen({super.key});
2023-02-09 08:48:19 +00:00
@override
Widget build(BuildContext context) {
2023-02-23 00:53:14 +00:00
String? token;
String? profileId;
2023-02-09 08:48:19 +00:00
return Scaffold(
2023-02-15 05:23:06 +00:00
appBar: AppBar(
title: const Text(elibilityScreenTitle),
centerTitle: true,
backgroundColor: primary,
2023-02-23 00:53:14 +00:00
actions: [AddLeading(onPressed: () {
2023-02-23 05:51:53 +00:00
context.read<ProfileBloc>().add( AddEligibility());
2023-02-23 00:53:14 +00:00
})],
2023-02-15 05:23:06 +00:00
),
body: BlocBuilder<UserBloc, UserState>(
builder: (context, state) {
if (state is UserLoggedIn) {
2023-02-23 00:53:14 +00:00
token = state.userData!.user!.login!.token;
profileId =
state.userData!.user!.login!.user!.profileId.toString();
2023-02-16 07:10:54 +00:00
return ProgressHUD(
child: BlocConsumer<ProfileBloc, ProfileState>(
listener: (context, state) {
2023-02-23 00:53:14 +00:00
if (state is EditEligibilityState) {
2023-02-20 07:48:24 +00:00
final progress = ProgressHUD.of(context);
progress!.dismiss();
2023-02-23 00:53:14 +00:00
}
if (state is ProfileLoading) {
final progress = ProgressHUD.of(context);
progress!.showWithText("Loading");
}
if (state is EligibilityLoaded) {
2023-02-16 07:10:54 +00:00
final progress = ProgressHUD.of(context);
progress!.dismiss();
2023-02-23 00:53:14 +00:00
}if(state is AddEligibilityState){
final progress = ProgressHUD.of(context);
2023-02-20 07:48:24 +00:00
progress!.dismiss();
2023-02-16 07:10:54 +00:00
}
2023-02-23 00:53:14 +00:00
if (state is DeletedState) {
if (state.success) {
successAlert(context, "Deletion Successfull",
"Eligibility has been deleted successfully", () {
context.read<ProfileBloc>().add(LoadEligibility(
eligibilities: state.eligibilities));
});
} else {
errorAlert(context, "Deletion Failed",
"Error deleting eligibility", () {
context.read<ProfileBloc>().add(LoadEligibility(
eligibilities: state.eligibilities));
});
}
}
2023-02-16 07:10:54 +00:00
// TODO: implement listener
},
builder: (context, state) {
return BlocBuilder<ProfileBloc, ProfileState>(
builder: (context, state) {
if (state is EligibilityLoaded) {
return ListView.builder(
padding: const EdgeInsets.symmetric(
vertical: 8, horizontal: 10),
itemCount: state.eligibilities.length,
itemBuilder: (BuildContext context, int index) {
String title = state
2023-02-23 00:53:14 +00:00
.eligibilities[index].eligibility!.title;
2023-02-16 07:10:54 +00:00
return Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
2023-02-15 05:23:06 +00:00
children: [
2023-02-16 07:10:54 +00:00
Container(
width: screenWidth,
padding: const EdgeInsets.symmetric(
horizontal: 12, vertical: 8),
decoration: box1(),
child: Row(
children: [
Expanded(
child: Column(
mainAxisAlignment:
MainAxisAlignment.start,
crossAxisAlignment:
CrossAxisAlignment.start,
children: [
Text(
title,
style: Theme.of(context)
.textTheme
.titleMedium!
.copyWith(
fontWeight:
FontWeight
.w500),
),
const Divider(),
const SizedBox(
height: 5,
),
Text(
"$licenseNumber: ${state.eligibilities[index].licenseNumber == null ? 'N/A' : state.eligibilities[index].licenseNumber.toString()}",
style: Theme.of(context)
.textTheme
.titleSmall),
const SizedBox(
height: 3,
),
Text(
2023-02-23 00:53:14 +00:00
"Rating : ${state.eligibilities[index].rating ?? 'N/A'}.",
2023-02-16 07:10:54 +00:00
style: Theme.of(context)
.textTheme
.titleSmall)
]),
),
AppPopupMenu<int>(
offset: const Offset(-10, -10),
elevation: 3,
onSelected: (value) {
if (value == 2) {
2023-02-23 00:53:14 +00:00
confirmAlert(context, () {
BlocProvider.of<
ProfileBloc>(context)
.add(DeleteEligibility(
eligibilities: state
.eligibilities,
eligibilityId: state
.eligibilities[
index]
.id!,
profileId: profileId!,
token: token!));
}, "Delete?",
2023-02-16 07:10:54 +00:00
"Confirm Delete?");
}
if (value == 1) {
2023-02-20 07:48:24 +00:00
EligibityCert eligibityCert =
state.eligibilities[index];
bool overseas = eligibityCert
.examAddress!
.country!
.id
.toString() ==
'175'
? false
: true;
eligibityCert.overseas =
overseas;
2023-02-16 07:10:54 +00:00
final progress =
ProgressHUD.of(context);
2023-02-20 07:48:24 +00:00
eligibityCert.overseas =
overseas;
2023-02-16 07:10:54 +00:00
progress!
.showWithText("Loading...");
2023-02-23 00:53:14 +00:00
context.read<ProfileBloc>().add(
EditEligibility(
2023-02-23 05:51:53 +00:00
2023-02-23 00:53:14 +00:00
eligibityCert:
eligibityCert));
2023-02-16 07:10:54 +00:00
}
},
menuItems: [
popMenuItem(
text: "Edit",
value: 1,
icon: Icons.edit),
popMenuItem(
text: "Delete",
value: 2,
icon: Icons.delete),
popMenuItem(
text: "Attachment",
value: 3,
icon: FontAwesome.attach)
],
icon: const Icon(
Icons.more_vert,
color: Colors.grey,
2023-02-15 05:23:06 +00:00
),
2023-02-16 07:10:54 +00:00
tooltip: "Options",
)
],
2023-02-15 05:23:06 +00:00
),
2023-02-16 07:10:54 +00:00
),
const SizedBox(
height: 5,
2023-02-15 05:23:06 +00:00
)
],
2023-02-16 07:10:54 +00:00
);
});
}
2023-02-23 00:53:14 +00:00
if (state is EditEligibilityState) {
2023-02-16 07:10:54 +00:00
return EditEligibilityScreen(
eligibityCert: state.eligibityCert);
2023-02-23 00:53:14 +00:00
}if(state is AddEligibilityState){
return const AddEligibilityScreen();
}
if (state is DeletedState) {
return Center(
child: Container(
child: Text(state.success.toString())),
);
}
if (state is ProfileErrorState) {
return Center(
child: Text(state.mesage),
);
2023-02-16 07:10:54 +00:00
}
return Container();
},
);
},
),
2023-02-15 05:23:06 +00:00
);
}
return Container();
},
));
}
PopupMenuItem<int> popMenuItem({String? text, int? value, IconData? icon}) {
return PopupMenuItem(
value: value,
child: Row(
children: [
Icon(
icon,
),
const SizedBox(
width: 10,
),
Text(
text!,
),
],
),
2023-02-09 08:48:19 +00:00
);
}
}