diff --git a/frontend/mgramseva/lib/model/expenses_details/expenses_details.dart b/frontend/mgramseva/lib/model/expenses_details/expenses_details.dart index 72cbca65f..68c6ae4d1 100644 --- a/frontend/mgramseva/lib/model/expenses_details/expenses_details.dart +++ b/frontend/mgramseva/lib/model/expenses_details/expenses_details.dart @@ -2,7 +2,11 @@ import 'package:flutter/material.dart'; import 'package:json_annotation/json_annotation.dart'; import 'package:mgramseva/model/expenses_details/vendor.dart'; import 'package:mgramseva/model/file/file_store.dart'; +import 'package:mgramseva/providers/expenses_details_provider.dart'; import 'package:mgramseva/utils/date_formats.dart'; +import 'package:provider/provider.dart'; + +import '../../utils/global_variables.dart'; part 'expenses_details.g.dart'; @@ -185,9 +189,6 @@ class ExpensesDetailsModel { paidDateCtrl.text = ''; allowEdit = true; } - if(expenseType=='ELECTRICITY_BILL'){ - allowEdit = false; - } } factory ExpensesDetailsModel.fromJson(Map json) => diff --git a/frontend/mgramseva/lib/providers/expenses_details_provider.dart b/frontend/mgramseva/lib/providers/expenses_details_provider.dart index 646ca3211..4443c3536 100644 --- a/frontend/mgramseva/lib/providers/expenses_details_provider.dart +++ b/frontend/mgramseva/lib/providers/expenses_details_provider.dart @@ -44,6 +44,7 @@ class ExpensesDetailsProvider with ChangeNotifier { var phoneNumberAutoValidation = false; var dateAutoValidation = false; GlobalKey? filePickerKey; + var isPSPCLEnabled = false; dispose() { @@ -56,23 +57,34 @@ class ExpensesDetailsProvider with ChangeNotifier { try { if(expensesDetails != null || id != null) await fetchVendors(); else fetchVendors(); + var commonProvider = + Provider.of(context, listen: false); + if (languageList?.mdmsRes?.expense?.expenseList != null) { + var res = languageList?.mdmsRes?.pspclIntegration?.accountNumberGpMapping?.where((element) => element.departmentEntityCode==commonProvider.userDetails?.selectedtenant?.city?.code).toList(); + if(res!.isNotEmpty){ + isPSPCLEnabled = true; + notifyListeners(); + }else{ + isPSPCLEnabled = false; + notifyListeners(); + } + } if (expensesDetails != null) { expenditureDetails = expensesDetails; - if(expenditureDetails.expenseType=='ELECTRICITY_BILL'){ + if(expenditureDetails.expenseType=='ELECTRICITY_BILL' && isPSPCLEnabled){ expenditureDetails.allowEdit = false; } getStoreFileDetails(); } else if (id != null) { - var commonProvider = - Provider.of(context, listen: false); var query = { 'tenantId': commonProvider.userDetails?.selectedtenant?.code, 'challanNo': id }; var expenditure = await ExpensesRepository().searchExpense(query); + if (expenditure != null && expenditure.isNotEmpty) { expenditureDetails = expenditure.first; - if(expenditureDetails.expenseType=='ELECTRICITY_BILL'){ + if(expenditureDetails.expenseType=='ELECTRICITY_BILL' && isPSPCLEnabled){ expenditureDetails.allowEdit = false; } getStoreFileDetails(); @@ -83,6 +95,9 @@ class ExpensesDetailsProvider with ChangeNotifier { } this.expenditureDetails.getText(); + if(this.expenditureDetails.expenseType=='ELECTRICITY_BILL' && isPSPCLEnabled){ + this.expenditureDetails.allowEdit = false; + } streamController.add(this.expenditureDetails); } on CustomException catch (e, s) { ErrorHandler.handleApiException(context, e, s); diff --git a/frontend/mgramseva/lib/screeens/add_expense/expense_details.dart b/frontend/mgramseva/lib/screeens/add_expense/expense_details.dart index e64935fd5..358c641b3 100644 --- a/frontend/mgramseva/lib/screeens/add_expense/expense_details.dart +++ b/frontend/mgramseva/lib/screeens/add_expense/expense_details.dart @@ -141,9 +141,9 @@ class _ExpenseDetailsState extends State { (expensesDetailsProvider .expenditureDetails.isBillCancelled ?? false)) || - !isUpdate) || (expensesDetailsProvider - .expenditureDetails.expenseType!='ELECTRICITY_BILL') - ? () => expensesDetailsProvider.validateExpensesDetails( + !isUpdate) + ? expensesDetailsProvider.isPSPCLEnabled && expensesDetailsProvider + .expenditureDetails.expenseType=='ELECTRICITY_BILL'?null:() => expensesDetailsProvider.validateExpensesDetails( context, isUpdate) : null, key: Keys.expense.EXPENSE_SUBMIT, @@ -472,34 +472,35 @@ class _ExpenseDetailsState extends State { contextKey: expenseProvider .expenseWalkthrougList[5].key, ), - if (isUpdate && expenseDetails.expenseType!='ELECTRICITY_BILL') - Container( - alignment: Alignment.centerLeft, - padding: EdgeInsets.symmetric( - vertical: 10, horizontal: 18), - child: Wrap( - direction: Axis.horizontal, - crossAxisAlignment: WrapCrossAlignment.center, - spacing: 8, - children: [ - SizedBox( - width: 20, - height: 20, - child: Checkbox( - value: expenseDetails.isBillCancelled, - onChanged: expensesDetailsProvider - .onChangeOfCheckBox), - ), - Text( - ApplicationLocalizations.of(context) - .translate(i18.expense - .MARK_BILL_HAS_CANCELLED), - style: TextStyle( - fontSize: 19, - fontWeight: FontWeight.normal)) - ], + if (isUpdate) + expensesDetailsProvider.isPSPCLEnabled && expenseDetails.expenseType=='ELECTRICITY_BILL'?Container(): + Container( + alignment: Alignment.centerLeft, + padding: EdgeInsets.symmetric( + vertical: 10, horizontal: 18), + child: Wrap( + direction: Axis.horizontal, + crossAxisAlignment: WrapCrossAlignment.center, + spacing: 8, + children: [ + SizedBox( + width: 20, + height: 20, + child: Checkbox( + value: expenseDetails.isBillCancelled, + onChanged: expensesDetailsProvider + .onChangeOfCheckBox), + ), + Text( + ApplicationLocalizations.of(context) + .translate(i18.expense + .MARK_BILL_HAS_CANCELLED), + style: TextStyle( + fontSize: 19, + fontWeight: FontWeight.normal)) + ], + ), ), - ), SizedBox( height: 20, ), diff --git a/frontend/mgramseva/lib/screeens/expense/search_expense.dart b/frontend/mgramseva/lib/screeens/expense/search_expense.dart index 7b0d1acd3..f7cc46c0f 100644 --- a/frontend/mgramseva/lib/screeens/expense/search_expense.dart +++ b/frontend/mgramseva/lib/screeens/expense/search_expense.dart @@ -36,10 +36,12 @@ class _SearchExpenseState extends State { @override void initState() { - Provider.of(context, listen: false)..getExpenses(); + WidgetsBinding.instance.addPostFrameCallback((_) => afterViewBuild()); super.initState(); } - + afterViewBuild() { + Provider.of(context, listen: false)..getExpenses(); + } @override Widget build(BuildContext context) { return KeyboardFocusWatcher(child:Scaffold( @@ -73,20 +75,22 @@ class _SearchExpenseState extends State { '\n${ApplicationLocalizations.of(context).translate(i18.common.OR)}', textAlign: TextAlign.center), Consumer( - builder: (_, expensesDetailsProvider, child) => - SelectFieldBuilder( - i18.expense.EXPENSE_TYPE, - expenseType, - '', - '', - onChangeOfExpense, - expensesDetailsProvider.getExpenseTypeList(isSearch: true), - false, - hint: - '${ApplicationLocalizations.of(context).translate(i18.common.ELECTRICITY_HINT)}', - controller: expenseTypeCtrl, - key: Keys.expense.SEARCH_EXPENSE_TYPE, - ), + builder: (_, expensesDetailsProvider, child) { + return SelectFieldBuilder( + i18.expense.EXPENSE_TYPE, + expenseType, + '', + '', + onChangeOfExpense, + expensesDetailsProvider.getExpenseTypeList(isSearch: true)??[], + false, + hint: + '${ApplicationLocalizations.of(context).translate(i18.common.ELECTRICITY_HINT)}', + controller: expenseTypeCtrl, + key: Keys.expense.SEARCH_EXPENSE_TYPE, + ); + } + , ), Column( mainAxisAlignment: MainAxisAlignment.start, diff --git a/frontend/mgramseva/package.json b/frontend/mgramseva/package.json index 3145cdff1..19b5160b1 100644 --- a/frontend/mgramseva/package.json +++ b/frontend/mgramseva/package.json @@ -1,5 +1,5 @@ { "name": "mgramseva", - "version": "1.2.10", + "version": "1.2.12", "license": "egov" } diff --git a/frontend/mgramseva/pubspec.yaml b/frontend/mgramseva/pubspec.yaml index f147b68d5..f3a612aca 100644 --- a/frontend/mgramseva/pubspec.yaml +++ b/frontend/mgramseva/pubspec.yaml @@ -15,7 +15,7 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev # In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion. # Read more about iOS versioning at # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html -version: 1.2.10+30 +version: 1.2.12+30 environment: sdk: ">=2.12.0 <3.0.0"