|
|
|
@ -1,11 +1,16 @@
|
|
|
|
|
import 'dart:io';
|
|
|
|
|
|
|
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
|
import 'package:easy_localization/src/public_ext.dart';
|
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/api/leave_balance_api_client.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/api/profile_api_client.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/app_state/app_state.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/classes/colors.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/classes/utils.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/config/routes.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/extensions/int_extensions.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/extensions/string_extensions.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/extensions/widget_extensions.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/generated/locale_keys.g.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/models/dyanmic_forms/validate_eit_transaction_model.dart';
|
|
|
|
@ -17,11 +22,16 @@ import 'package:mohem_flutter_app/models/profile/get_contact_details_list.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/models/profile/submit_contact_transaction_list_model.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/ui/misc/request_submit_screen.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/widgets/app_bar_widget.dart';
|
|
|
|
|
import 'dart:io';
|
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/widgets/button/default_button.dart';
|
|
|
|
|
import 'package:mohem_flutter_app/widgets/dynamic_forms/dynamic_textfield_widget.dart';
|
|
|
|
|
import 'package:easy_localization/src/public_ext.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);
|
|
|
|
@ -36,10 +46,12 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
List<GetContactDffStructureList?> getContactDffStructureList = [];
|
|
|
|
|
List<GetContactDetailsList?> getContactDetailsList = [];
|
|
|
|
|
SubmitContactTransactionList? submitContactTransactionList;
|
|
|
|
|
dynamic args;
|
|
|
|
|
|
|
|
|
|
//dynamic args;
|
|
|
|
|
FamilyMemberScreenParams? params;
|
|
|
|
|
String? date = "MM/DD/YYYY";
|
|
|
|
|
var dateTime = DateTime.now().timeZoneOffset;
|
|
|
|
|
var dateTime1 = DateTime.now().timeZoneName;
|
|
|
|
|
Duration dateTime = DateTime.now().timeZoneOffset;
|
|
|
|
|
String dateTime1 = DateTime.now().timeZoneName;
|
|
|
|
|
|
|
|
|
|
GetApprovesList? getApprovesList;
|
|
|
|
|
|
|
|
|
@ -52,9 +64,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();
|
|
|
|
|
});
|
|
|
|
@ -64,8 +76,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);
|
|
|
|
@ -88,8 +100,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(
|
|
|
|
@ -98,45 +110,48 @@ 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: [
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeCols(getContactColsStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
itemCount: getContactColsStructureList!.length),
|
|
|
|
|
12.height,
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeBasicDetDff(getBasicDetDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
itemCount: getBasicDetDffStructureList!.length),
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeContactDff(getContactDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (cxt, index) => 0.height,
|
|
|
|
|
itemCount: getContactDffStructureList!.length),
|
|
|
|
|
]).expanded,
|
|
|
|
|
ListView(
|
|
|
|
|
physics: const BouncingScrollPhysics(),
|
|
|
|
|
padding: const EdgeInsets.all(21),
|
|
|
|
|
children: [
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeCols(getContactColsStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getContactColsStructureList!.length),
|
|
|
|
|
12.height,
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeBasicDetDff(getBasicDetDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getBasicDetDffStructureList!.length),
|
|
|
|
|
ListView.separated(
|
|
|
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
itemBuilder: (BuildContext cxt, int parentIndex) {
|
|
|
|
|
return parseDynamicFormatTypeContactDff(getContactDffStructureList![parentIndex], parentIndex);
|
|
|
|
|
},
|
|
|
|
|
separatorBuilder: (BuildContext cxt, int index) => 0.height,
|
|
|
|
|
itemCount: getContactDffStructureList!.length),
|
|
|
|
|
],
|
|
|
|
|
).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(),
|
|
|
|
@ -144,7 +159,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(
|
|
|
|
@ -153,7 +168,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(),
|
|
|
|
@ -161,7 +176,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 {
|
|
|
|
@ -181,27 +196,27 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
if (model.dATATYPE == "VARCHAR2") {
|
|
|
|
|
if (model!.objectValuesList?.isNotEmpty ?? false) {
|
|
|
|
|
return PopupMenuButton(
|
|
|
|
|
child: DynamicTextFieldWidget(
|
|
|
|
|
(model!.sEGMENTPROMPT ?? "") + (model!.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isEnable: false,
|
|
|
|
|
isPopup: true,
|
|
|
|
|
).paddingOnly(bottom: 12),
|
|
|
|
|
itemBuilder: (_) => <PopupMenuItem<int>>[
|
|
|
|
|
for (int i = 0; i < getContactColsStructureList[index]!.objectValuesList!.length; i++)
|
|
|
|
|
PopupMenuItem<int>(child: Text(getContactColsStructureList[index]!.objectValuesList![i].mEANING.toString()), value: i),
|
|
|
|
|
],
|
|
|
|
|
onSelected: (int popupIndex) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = getContactColsStructureList[index]!.objectValuesList![popupIndex].mEANING.toString();
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getContactColsStructureList[index]!.objectValuesList![popupIndex].cODE.toString();
|
|
|
|
|
setState(() {});
|
|
|
|
|
});
|
|
|
|
|
child: DynamicTextFieldWidget(
|
|
|
|
|
(model!.sEGMENTPROMPT ?? "") + (model!.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isEnable: false,
|
|
|
|
|
isPopup: true,
|
|
|
|
|
).paddingOnly(bottom: 12),
|
|
|
|
|
itemBuilder: (_) => <PopupMenuItem<int>>[
|
|
|
|
|
for (int i = 0; i < getContactColsStructureList[index]!.objectValuesList!.length; i++)
|
|
|
|
|
PopupMenuItem<int>(child: Text(getContactColsStructureList[index]!.objectValuesList![i].mEANING.toString()), value: i),
|
|
|
|
|
],
|
|
|
|
|
onSelected: (int popupIndex) {
|
|
|
|
|
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);
|
|
|
|
@ -211,7 +226,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);
|
|
|
|
@ -223,13 +238,8 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
isEnable: false,
|
|
|
|
|
onTap: () async {
|
|
|
|
|
DateTime dateValue = await _selectDate(context);
|
|
|
|
|
//date = DateFormat('yyyy/MM/dd').format(dateValue);
|
|
|
|
|
//date = "2022-10-23T09:17:38.653+03:00";
|
|
|
|
|
date = (DateFormat('yyyy-MM-dd').format(dateValue));
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP = date;
|
|
|
|
|
print(dateTime);
|
|
|
|
|
print(dateTime1);
|
|
|
|
|
print(date);
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -245,28 +255,28 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
if (model!.fORMATTYPE == "C") {
|
|
|
|
|
if (model!.eSERVICESVS?.isNotEmpty ?? false) {
|
|
|
|
|
return PopupMenuButton(
|
|
|
|
|
child: DynamicTextFieldWidget(
|
|
|
|
|
(model.sEGMENTPROMPT ?? "") + (model.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isEnable: false,
|
|
|
|
|
isPopup: true,
|
|
|
|
|
).paddingOnly(bottom: 12),
|
|
|
|
|
itemBuilder: (_) => <PopupMenuItem<int>>[
|
|
|
|
|
for (int i = 0; i < getBasicDetDffStructureList[index]!.eSERVICESVS!.length; i++)
|
|
|
|
|
PopupMenuItem<int>(child: Text(getBasicDetDffStructureList[index]!.eSERVICESVS![i].vALUECOLUMNNAME.toString()), value: i),
|
|
|
|
|
],
|
|
|
|
|
onSelected: (int popupIndex) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = getBasicDetDffStructureList[index]!.eSERVICESVS![popupIndex].vALUECOLUMNNAME.toString();
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getBasicDetDffStructureList[index]!.eSERVICESVS![popupIndex].iDCOLUMNNAME.toString();
|
|
|
|
|
child: DynamicTextFieldWidget(
|
|
|
|
|
(model.sEGMENTPROMPT ?? "") + (model.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isEnable: false,
|
|
|
|
|
isPopup: true,
|
|
|
|
|
).paddingOnly(bottom: 12),
|
|
|
|
|
itemBuilder: (_) => <PopupMenuItem<int>>[
|
|
|
|
|
for (int i = 0; i < getBasicDetDffStructureList[index]!.eSERVICESVS!.length; i++)
|
|
|
|
|
PopupMenuItem<int>(child: Text(getBasicDetDffStructureList[index]!.eSERVICESVS![i].vALUECOLUMNNAME.toString()), value: i),
|
|
|
|
|
],
|
|
|
|
|
onSelected: (int popupIndex) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = getBasicDetDffStructureList[index]!.eSERVICESVS![popupIndex].vALUECOLUMNNAME.toString();
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getBasicDetDffStructureList[index]!.eSERVICESVS![popupIndex].iDCOLUMNNAME.toString();
|
|
|
|
|
|
|
|
|
|
setState(() {});
|
|
|
|
|
});
|
|
|
|
|
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);
|
|
|
|
@ -276,7 +286,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);
|
|
|
|
@ -289,8 +299,6 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
onTap: () async {
|
|
|
|
|
DateTime dateValue = await _selectDate(context);
|
|
|
|
|
date = (DateFormat('yyyy-MM-dd').format(dateValue));
|
|
|
|
|
// date = (DateFormat('yyyy-MM-dd').format(dateValue) +"T"+ dateTime.toString() + dateTime1.toString());
|
|
|
|
|
// date = DateFormat('yyyy/MM/dd').format(dateValue);
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP = date;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
@ -307,27 +315,27 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
if (model!.fORMATTYPE == "C") {
|
|
|
|
|
if (model.eSERVICESVS?.isNotEmpty ?? false) {
|
|
|
|
|
return PopupMenuButton(
|
|
|
|
|
child: DynamicTextFieldWidget(
|
|
|
|
|
(model!.sEGMENTPROMPT ?? "") + (model!.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isEnable: false,
|
|
|
|
|
isPopup: true,
|
|
|
|
|
).paddingOnly(bottom: 12),
|
|
|
|
|
itemBuilder: (_) => <PopupMenuItem<int>>[
|
|
|
|
|
for (int i = 0; i < getContactDffStructureList[index]!.eSERVICESVS!.length; i++)
|
|
|
|
|
PopupMenuItem<int>(child: Text(getContactDffStructureList[index]!.eSERVICESVS![i].vALUECOLUMNNAME.toString()), value: i),
|
|
|
|
|
],
|
|
|
|
|
onSelected: (int popupIndex) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = getContactDffStructureList[index]!.eSERVICESVS![popupIndex].vALUECOLUMNNAME.toString();
|
|
|
|
|
model.getContactDetailsList!.vARCHAR2VALUE = getContactDffStructureList[index]!.eSERVICESVS![popupIndex].iDCOLUMNNAME.toString();
|
|
|
|
|
setState(() {});
|
|
|
|
|
});
|
|
|
|
|
child: DynamicTextFieldWidget(
|
|
|
|
|
(model!.sEGMENTPROMPT ?? "") + (model!.rEQUIREDFLAG == "Y" ? "*" : ""),
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP ?? "",
|
|
|
|
|
isEnable: false,
|
|
|
|
|
isPopup: true,
|
|
|
|
|
).paddingOnly(bottom: 12),
|
|
|
|
|
itemBuilder: (_) => <PopupMenuItem<int>>[
|
|
|
|
|
for (int i = 0; i < getContactDffStructureList[index]!.eSERVICESVS!.length; i++)
|
|
|
|
|
PopupMenuItem<int>(child: Text(getContactDffStructureList[index]!.eSERVICESVS![i].vALUECOLUMNNAME.toString()), value: i),
|
|
|
|
|
],
|
|
|
|
|
onSelected: (int popupIndex) {
|
|
|
|
|
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 ?? "",
|
|
|
|
|
// isInputTypeNum: true,
|
|
|
|
|
onChange: (text) {
|
|
|
|
|
onChange: (String text) {
|
|
|
|
|
model.getContactDetailsList!.sEGMENTVALUEDSP = text;
|
|
|
|
|
},
|
|
|
|
|
).paddingOnly(bottom: 12);
|
|
|
|
@ -337,7 +345,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);
|
|
|
|
@ -349,9 +357,7 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
isEnable: false,
|
|
|
|
|
onTap: () async {
|
|
|
|
|
DateTime dateValue = await _selectDate(context);
|
|
|
|
|
// date = "2022-10-23T09:17:38.653+03:00";
|
|
|
|
|
date = (DateFormat('yyyy-MM-dd').format(dateValue));
|
|
|
|
|
// date = DateFormat('yyyy/MM/dd').format(dateValue);
|
|
|
|
|
model!.getContactDetailsList!.sEGMENTVALUEDSP = date;
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
@ -367,13 +373,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;
|
|
|
|
|
}
|
|
|
|
@ -392,7 +398,6 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void submitUpdateForm() async {
|
|
|
|
|
print("submit");
|
|
|
|
|
try {
|
|
|
|
|
List<Map<String, dynamic>> values1 = getBasicDetDffStructureList!.map((e) {
|
|
|
|
|
String? dateVal = '';
|
|
|
|
@ -441,12 +446,10 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
return ValidateEitTransactionModel(dATEVALUE: dateVal, nAME: e.aPPLICATIONCOLUMNNAME, nUMBERVALUE: numberVal, tRANSACTIONNUMBER: 1, vARCHAR2VALUE: varChar).toJson();
|
|
|
|
|
}).toList();
|
|
|
|
|
List<Map<String, dynamic>> values3 = getContactColsStructureList!.map((e) {
|
|
|
|
|
// String tempVar = e!.getContactDetailsList!.sEGMENTVALUEDSP ?? "";
|
|
|
|
|
String? dateVal = '';
|
|
|
|
|
dynamic? varChar1 = '';
|
|
|
|
|
String? varChar1 = '';
|
|
|
|
|
int? numberVal;
|
|
|
|
|
|
|
|
|
|
print("e.dATATYPE:${e?.dATATYPE}");
|
|
|
|
|
if (e!.dATATYPE == 'VARCHAR2') {
|
|
|
|
|
dateVal = null;
|
|
|
|
|
numberVal = null;
|
|
|
|
@ -468,15 +471,18 @@ class _AddUpdateFamilyMemberState extends State<AddUpdateFamilyMember> {
|
|
|
|
|
}).toList();
|
|
|
|
|
List<Map<String, dynamic>> valuesFinal = [...values1, ...values2, ...values3];
|
|
|
|
|
Utils.showLoading(context);
|
|
|
|
|
submitContactTransactionList = await ProfileApiClient().submitContactTransactionAddAndUpdate(args['actionType'], args['relationID'] ?? null, valuesFinal);
|
|
|
|
|
var transactionId = submitContactTransactionList!.pTRANSACTIONID;
|
|
|
|
|
var itemKey = submitContactTransactionList!.pITEMKEY;
|
|
|
|
|
submitContactTransactionList = await ProfileApiClient().submitContactTransactionAddAndUpdate(params!.actionType!, params!.relationID, valuesFinal);
|
|
|
|
|
Utils.hideLoading(context);
|
|
|
|
|
await Navigator.pushNamed(context, AppRoutes.requestSubmitScreen,
|
|
|
|
|
arguments: RequestSubmitScreenParams(LocaleKeys.profile_familyDetails.tr(), submitContactTransactionList!.pTRANSACTIONID!, submitContactTransactionList!.pITEMKEY!, 'family_member'));
|
|
|
|
|
if (!AppState().cancelRequestTrancsection) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
Utils.showLoading(context);
|
|
|
|
|
await LeaveBalanceApiClient().cancelHrTransaction(submitContactTransactionList!.pTRANSACTIONID!);
|
|
|
|
|
Utils.hideLoading(context);
|
|
|
|
|
Navigator.pushNamed(context, AppRoutes.requestSubmitScreen,
|
|
|
|
|
arguments: RequestSubmitScreenParams(LocaleKeys.profile_familyDetails.tr(), transactionId!.toInt(), itemKey.toString(), 'family_member'));
|
|
|
|
|
setState(() {});
|
|
|
|
|
} catch (ex) {
|
|
|
|
|
print(ex);
|
|
|
|
|
Utils.hideLoading(context);
|
|
|
|
|
Utils.handleException(ex, context, null);
|
|
|
|
|
}
|
|
|
|
|