308 lines
16 KiB
Dart
308 lines
16 KiB
Dart
import 'package:date_time_picker/date_time_picker.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/src/widgets/framework.dart';
|
|
import 'package:flutter/src/widgets/placeholder.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:flutter_form_builder/flutter_form_builder.dart';
|
|
import 'package:intl/intl.dart';
|
|
import 'package:unit2/bloc/profile/profile_bloc.dart';
|
|
import 'package:unit2/bloc/user/user_bloc.dart';
|
|
import 'package:unit2/model/profile/eligibility.dart';
|
|
import 'package:unit2/model/utils/eligibilities_choices.dart';
|
|
import '../../../../model/location/country.dart' as c;
|
|
import '../../../../model/location/region.dart' as r;
|
|
import '../../../../model/location/provinces.dart' as p;
|
|
import '../../../../theme-data.dart/btn-style.dart';
|
|
import '../../../../theme-data.dart/colors.dart';
|
|
import '../../../../theme-data.dart/form-style.dart';
|
|
import '../../../../utils/global.dart';
|
|
import '../../../../utils/text_container.dart';
|
|
|
|
class EditEligibilityScreen extends StatefulWidget {
|
|
final EligibityCert eligibityCert;
|
|
const EditEligibilityScreen({super.key, required this.eligibityCert});
|
|
|
|
@override
|
|
State<EditEligibilityScreen> createState() => _EditEligibilityScreenState();
|
|
}
|
|
|
|
class _EditEligibilityScreenState extends State<EditEligibilityScreen> {
|
|
final formKey = GlobalKey<FormBuilderState>();
|
|
bool overseas = false;
|
|
DateFormat dteFormat2 = DateFormat.yMMMMd('en_US');
|
|
c.Country? selectedCountry;
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
//USERBLOC
|
|
return BlocBuilder<UserBloc, UserState>(
|
|
builder: (context, state) {
|
|
//LOGGED IN USER STATE
|
|
if (state is UserLoggedIn) {
|
|
//PROFIILE BLOC
|
|
return BlocBuilder<ProfileBloc, ProfileState>(
|
|
builder: (context, state) {
|
|
//EDIT ELIGIBILITY STATE
|
|
if (state is EditEligibilityState) {
|
|
String? region = state.eligibityCert.examAddress!
|
|
.cityMunicipality!.province!.region!.description;
|
|
String? eligibiltyTitle =
|
|
state.eligibityCert.eligibility!.title!;
|
|
String? province = state.eligibityCert.examAddress!
|
|
.cityMunicipality!.province!.description!;
|
|
return Center(
|
|
child: Padding(
|
|
padding: const EdgeInsets.symmetric(
|
|
vertical: 25, horizontal: 18),
|
|
child: FormBuilder(
|
|
key: formKey,
|
|
child: Column(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
children: [
|
|
//ELIGIBILITIES DROPDOWN
|
|
FormBuilderDropdown<dynamic>(
|
|
initialValue: state.eligibityCert.eligibility,
|
|
items: state.eligibilities
|
|
.map<DropdownMenuItem<EligibilityList>>(
|
|
(EligibilityList eligibility) {
|
|
return DropdownMenuItem<EligibilityList>(
|
|
value: eligibility,
|
|
child: Text(eligibility.title));
|
|
}).toList(),
|
|
name: "eligibility",
|
|
decoration: normalTextFieldStyle(
|
|
"Eligibility", eligibiltyTitle)
|
|
.copyWith(
|
|
hintStyle: const TextStyle(
|
|
color: Colors.black,
|
|
),
|
|
labelStyle:
|
|
const TextStyle(color: Colors.black)),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
|
|
SizedBox(
|
|
width: screenWidth,
|
|
child: Row(
|
|
children: [
|
|
//LICENSE NUMBER
|
|
Flexible(
|
|
flex: 1,
|
|
child: FormBuilderTextField(
|
|
name: 'license number',
|
|
initialValue:
|
|
widget.eligibityCert.licenseNumber,
|
|
decoration: normalTextFieldStyle(
|
|
"license number", "license number"),
|
|
),
|
|
),
|
|
const SizedBox(
|
|
width: 12,
|
|
),
|
|
//RATING
|
|
Flexible(
|
|
flex: 1,
|
|
child: FormBuilderTextField(
|
|
name: 'rating',
|
|
initialValue: widget.eligibityCert.rating
|
|
.toString(),
|
|
decoration: normalTextFieldStyle(
|
|
'rating', 'rating'),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
SizedBox(
|
|
width: screenWidth,
|
|
child: Row(
|
|
children: [
|
|
//EXAM DATE
|
|
Flexible(
|
|
flex: 1,
|
|
child: DateTimePicker(
|
|
firstDate: DateTime(2000),
|
|
lastDate: DateTime(2100),
|
|
decoration: normalTextFieldStyle(
|
|
"Exam date", "Exam date"),
|
|
initialValue: widget
|
|
.eligibityCert.examDate ==
|
|
null
|
|
? ''
|
|
: dteFormat2.format(
|
|
widget.eligibityCert.examDate!),
|
|
)),
|
|
const SizedBox(
|
|
width: 12,
|
|
),
|
|
//VALIDITY DATE
|
|
Flexible(
|
|
flex: 1,
|
|
child: DateTimePicker(
|
|
firstDate: DateTime(2000),
|
|
lastDate: DateTime(2100),
|
|
decoration: normalTextFieldStyle(
|
|
"Validity date", "Validity date"),
|
|
initialValue:
|
|
widget.eligibityCert.validityDate ==
|
|
null
|
|
? ''
|
|
: dteFormat2.format(widget
|
|
.eligibityCert.validityDate!),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
Text(
|
|
"Placement of Examination/Confinement",
|
|
style: Theme.of(context)
|
|
.textTheme
|
|
.displaySmall!
|
|
.copyWith(fontSize: blockSizeVertical * 2),
|
|
),
|
|
const SizedBox(
|
|
height: 12,
|
|
),
|
|
//OVERSEAS ADDRESS SWITCH
|
|
FormBuilderSwitch(
|
|
initialValue: overseas,
|
|
activeColor: second,
|
|
onChanged: (value) {
|
|
setState(() {
|
|
overseas = value!;
|
|
});
|
|
},
|
|
decoration: normalTextFieldStyle("", ''),
|
|
name: 'overseas',
|
|
title: const Text("Overseas Address?"),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
//COUNTRY DROPDOWN
|
|
|
|
SizedBox(
|
|
child: overseas == true
|
|
? FormBuilderDropdown<dynamic>(
|
|
items: state.countries
|
|
.map<DropdownMenuItem<c.Country>>(
|
|
(c.Country country) {
|
|
return DropdownMenuItem<c.Country>(
|
|
value: country,
|
|
child: Text(country.name!));
|
|
}).toList(),
|
|
name: 'country',
|
|
decoration: normalTextFieldStyle(
|
|
"Country", "Country"),
|
|
onChanged: (value) {
|
|
setState(() {
|
|
selectedCountry = value;
|
|
});
|
|
},
|
|
)
|
|
: Column(
|
|
children: [
|
|
//REGION DROPDOWN
|
|
FormBuilderDropdown<dynamic>(
|
|
// initialValue:state.eligibityCert.examAddress!.cityMunicipality!.province!.description!,
|
|
decoration: normalTextFieldStyle(
|
|
"Region", region ??
|
|
"Region*")
|
|
.copyWith(
|
|
hintStyle: const TextStyle(
|
|
color: Colors.black,
|
|
),
|
|
labelStyle: const TextStyle(
|
|
color: Colors.black)),
|
|
name: 'region',
|
|
items: state.regions.map<
|
|
DropdownMenuItem<r.Region>>(
|
|
(r.Region region) {
|
|
return DropdownMenuItem<r.Region>(
|
|
value: region,
|
|
child: Text(
|
|
region.description!));
|
|
}).toList(),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
//PROVINCE DROPDOWN
|
|
FormBuilderDropdown(
|
|
name: 'province',
|
|
items: state.provinces.map<
|
|
DropdownMenuItem<
|
|
p.Province>>(
|
|
(p.Province province) {
|
|
return DropdownMenuItem(
|
|
value: province,
|
|
child: Text(
|
|
province.description!));
|
|
}).toList(),
|
|
decoration: normalTextFieldStyle(
|
|
"Province", province)
|
|
.copyWith(
|
|
hintStyle: const TextStyle(
|
|
color: Colors.black,
|
|
),
|
|
labelStyle: const TextStyle(
|
|
color: Colors.black),
|
|
)),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
FormBuilderDropdown(
|
|
decoration: normalTextFieldStyle(
|
|
"Municipality", "Municipality"),
|
|
name: 'municipality',
|
|
items: [],
|
|
initialValue: widget
|
|
.eligibityCert
|
|
.examAddress
|
|
?.cityMunicipality
|
|
?.description ==
|
|
null
|
|
? 'region'
|
|
: 'municipality',
|
|
),
|
|
],
|
|
)),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
SizedBox(
|
|
width: screenWidth,
|
|
height: 60,
|
|
child: ElevatedButton(
|
|
style: mainBtnStyle(
|
|
primary, Colors.transparent, second),
|
|
onPressed: () {},
|
|
child: const Text(submit)),
|
|
),
|
|
const SizedBox(
|
|
height: 20,
|
|
),
|
|
]),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
return Container();
|
|
},
|
|
);
|
|
}
|
|
return Container();
|
|
},
|
|
);
|
|
}
|
|
}
|