|
|
|
@ -25,6 +25,14 @@ import 'package:mohem_flutter_app/widgets/app_bar_widget.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/widgets/button/default_button.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/widgets/dynamic_forms/dynamic_textfield_widget.dart';
|
|
|
|
|
|
|
|
|
|
class FamilyMemberScreenParams {
|
|
|
|
|
String? actionType;
|
|
|
|
|
int relationID;
|
|
|
|
|
int? flag;
|
|
|
|
|
|
|
|
|
|
FamilyMemberScreenParams(this.relationID, {this.actionType, this.flag});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class AddUpdateFamilyMember extends StatefulWidget {
|
|
|
|
|
const AddUpdateFamilyMember({Key? key}) : super(key: key);
|
|
|
|
|
|
|
|
|
@ -38,7 +46,8 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
List<GetContactDffStructureList?> getContactDffStructureList = [];
|
|
|
|
|
List<GetContactDetailsList?> getContactDetailsList = [];
|
|
|
|
|
SubmitContactTransactionList? submitContactTransactionList;
|
|
|
|
|
dynamic args;
|
|
|
|
|
//dynamic args;
|
|
|
|
|
FamilyMemberScreenParams? params;
|
|
|
|
|
String? date = "MM/DD/YYYY";
|
|
|
|
|
Duration dateTime = DateTime.now().timeZoneOffset;
|
|
|
|
|
String dateTime1 = DateTime.now().timeZoneName;
|
|
|
|
@ -54,9 +63,9 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
try {
|
|
|
|
|
Utils.showLoading(context);
|
|
|
|
|
getBasicDetDffStructureList = await ProfileApiClient().getBasicDetDffStructure();
|
|
|
|
|
getContactColsStructureList = await ProfileApiClient().getContactColsStructureList(args['actionType']);
|
|
|
|
|
getContactColsStructureList = await ProfileApiClient().getContactColsStructureList(params!.actionType.toString());
|
|
|
|
|
getContactDffStructureList = await ProfileApiClient().getContactDffStructureList();
|
|
|
|
|
if (args['actionType'] == "ADD") {
|
|
|
|
|
if (params!.actionType == "ADD") {
|
|
|
|
|
getBasicDetDffStructureList?.forEach((element) {
|
|
|
|
|
element?.getContactDetailsList = new GetContactDetailsList();
|
|
|
|
|
});
|
|
|
|
@ -66,8 +75,8 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
getContactDffStructureList?.forEach((element) {
|
|
|
|
|
element?.getContactDetailsList = new GetContactDetailsList();
|
|
|
|
|
});
|
|
|
|
|
} else if (args['actionType'] == "UPDATE") {
|
|
|
|
|
getContactDetailsList = await ProfileApiClient().getContactDetailsList(args['relationID']);
|
|
|
|
|
} else if (params!.actionType == "UPDATE") {
|
|
|
|
|
getContactDetailsList = await ProfileApiClient().getContactDetailsList(params!.relationID);
|
|
|
|
|
|
|
|
|
|
getBasicDetDffStructureList?.forEach((element) {
|
|
|
|
|
element?.getContactDetailsList = getContactDetailsList?.singleWhere((userDetail) => userDetail?.aPPLICATIONCOLUMNNAME == element?.aPPLICATIONCOLUMNNAME);
|
|
|
|
@ -90,8 +99,8 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
if (args == null) {
|
|
|
|
|
args = ModalRoute.of(context)!.settings.arguments;
|
|
|
|
|
if (params == null) {
|
|
|
|
|
params = ModalRoute.of(context)!.settings.arguments as FamilyMemberScreenParams;
|
|
|
|
|
callAddAndUpdateFamilyMember();
|
|
|
|
|
}
|
|
|
|
|
return Scaffold(
|
|
|
|
@ -100,7 +109,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
title: LocaleKeys.profile_familyDetails.tr(),
|
|
|
|
|
),
|
|
|
|
|
backgroundColor: MyColors.backgroundColor,
|
|
|
|
|
body: args['flag'] == 1
|
|
|
|
|
body: params!.flag == 1
|
|
|
|
|
? Column(
|
|
|
|
|
children: [
|
|
|
|
|
ListView(physics: const BouncingScrollPhysics(), padding: const EdgeInsets.all(21), children: [
|
|
|
|
@ -110,7 +119,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeCols(getContactColsStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getContactColsStructureList!.length),
|
|
|
|
|
12.height,
|
|
|
|
|
ListView.separated(
|
|
|
|
@ -119,7 +128,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeBasicDetDff(getBasicDetDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getBasicDetDffStructureList!.length),
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
@ -127,18 +136,17 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeContactDff(getContactDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getContactDffStructureList!.length),
|
|
|
|
|
]).expanded,
|
|
|
|
|
],).expanded,
|
|
|
|
|
DefaultButton(LocaleKeys.next.tr(), () async {
|
|
|
|
|
submitUpdateForm();
|
|
|
|
|
}).insideContainer,
|
|
|
|
|
],
|
|
|
|
|
)
|
|
|
|
|
: args['flag'] == 2
|
|
|
|
|
: params!.flag == 2
|
|
|
|
|
? Column(
|
|
|
|
|
children: [
|
|
|
|
|
// getContactDetailsList!.isEmpty
|
|
|
|
|
ListView(physics: const BouncingScrollPhysics(), padding: const EdgeInsets.all(21), children: [
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
@ -146,7 +154,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeCols(getContactColsStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getContactColsStructureList!.length),
|
|
|
|
|
12.height,
|
|
|
|
|
ListView.separated(
|
|
|
|
@ -155,7 +163,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeBasicDetDff(getBasicDetDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getBasicDetDffStructureList!.length),
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
@ -163,7 +171,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeContactDff(getContactDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getContactDffStructureList!.length),
|
|
|
|
|
]).expanded,
|
|
|
|
|
DefaultButton(LocaleKeys.next.tr(), () async {
|
|
|
|
@ -197,13 +205,12 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = getContactColsStructureList[index]!.objectValuesList![popupIndex].mEANING.toString();
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getContactColsStructureList[index]!.objectValuesList![popupIndex].cODE.toString();
|
|
|
|
|
setState(() {});
|
|
|
|
|
});
|
|
|
|
|
},);
|
|
|
|
|
} else {
|
|
|
|
|
return DynamicTextFieldWidget(
|
|
|
|
|
(model!.sEGMENTPROMPT ?? "") + (model!.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
(model!.getContactDetailsList!.sEGMENTVALUEDSP ?? ""),
|
|
|
|
|
//isInputTypeNum: true,
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -213,7 +220,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
(model!.sEGMENTPROMPT ?? "") + (model!.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
(model!.getContactDetailsList!.sEGMENTVALUEDSP ?? ""),
|
|
|
|
|
isInputTypeNum: true,
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -257,13 +264,12 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getBasicDetDffStructureList[index]!.eSERVICESVS![popupIndex].iDCOLUMNNAME.toString();
|
|
|
|
|
|
|
|
|
|
setState(() {});
|
|
|
|
|
});
|
|
|
|
|
},);
|
|
|
|
|
} else {
|
|
|
|
|
return DynamicTextFieldWidget(
|
|
|
|
|
(model.sEGMENTPROMPT ?? "") + (model.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
// isInputTypeNum: true,
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -273,7 +279,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
(model.sEGMENTPROMPT ?? "") + (model.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isInputTypeNum: true,
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -316,12 +322,12 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = getContactDffStructureList[index]!.eSERVICESVS![popupIndex].vALUECOLUMNNAME.toString();
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getContactDffStructureList[index]!.eSERVICESVS![popupIndex].iDCOLUMNNAME.toString();
|
|
|
|
|
setState(() {});
|
|
|
|
|
});
|
|
|
|
|
},);
|
|
|
|
|
} else {
|
|
|
|
|
return DynamicTextFieldWidget(
|
|
|
|
|
(model.sEGMENTPROMPT ?? "") + (model.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -331,7 +337,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
(model.sEGMENTPROMPT ?? "") + (model.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isInputTypeNum: true,
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -359,13 +365,13 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
if (!Platform.isIOS) {
|
|
|
|
|
await showCupertinoModalPopup(
|
|
|
|
|
context: context,
|
|
|
|
|
builder: (cxt) => Container(
|
|
|
|
|
builder: (BuildContext cxt) => Container(
|
|
|
|
|
height: 250,
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
child: CupertinoDatePicker(
|
|
|
|
|
backgroundColor: Colors.white,
|
|
|
|
|
mode: CupertinoDatePickerMode.date,
|
|
|
|
|
onDateTimeChanged: (value) {
|
|
|
|
|
onDateTimeChanged: (DateTime value) {
|
|
|
|
|
if (value != null && value != selectedDate) {
|
|
|
|
|
time = value;
|
|
|
|
|
}
|
|
|
|
@ -470,7 +476,6 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
Utils.hideLoading(context);
|
|
|
|
|
setState(() {});
|
|
|
|
|
} catch (ex) {
|
|
|
|
|
print(ex);
|
|
|
|
|
Utils.hideLoading(context);
|
|
|
|
|
Utils.handleException(ex, context, null);
|
|
|
|
|
}
|
|
|
|
|