From 25389120310ab03dcc1ba841a9d6ffc8e4e26b0a Mon Sep 17 00:00:00 2001 From: yiyiwang-cgi <116315451+yiyiwang-cgi@users.noreply.github.com> Date: Thu, 24 Oct 2024 15:07:08 -0700 Subject: [PATCH] S26 update funding version for supp and expense (#252) * Updated Dev * Add Funding Version Field on Supp and Expense Application --- ECC.Core.DataContext/Entities/Entities.cs | 94 +++++++++++++++++++ ECC.Core.DataContext/OptionSets/OptionSets.cs | 32 +++++++ .../Application/CreateFundingRecord.cs | 52 +++++----- .../Funding/OutputModStartAndEndDate.cs | 21 +++-- .../Models/Fundings/Fundings.cs | 1 + .../Processes/Emails/IEmailRepository.cs | 2 +- ...wanceApprovalDenialNotificationProvider.cs | 1 + 7 files changed, 173 insertions(+), 30 deletions(-) diff --git a/ECC.Core.DataContext/Entities/Entities.cs b/ECC.Core.DataContext/Entities/Entities.cs index b627351f..040487ff 100644 --- a/ECC.Core.DataContext/Entities/Entities.cs +++ b/ECC.Core.DataContext/Entities/Entities.cs @@ -6205,6 +6205,38 @@ public string ofm_on_k12_school_grounds_or_board_affiliatedname } } + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_on_k12_school_grounds_or_board_affiliated")] + public virtual ecc_ynempty? ofm_on_k12_school_grounds_or_board_affiliated + { + [System.Diagnostics.DebuggerNonUserCode()] + get + { + return ((ecc_ynempty?)(EntityOptionSetEnum.GetEnum(this, "ofm_on_k12_school_grounds_or_board_affiliated"))); + } + [System.Diagnostics.DebuggerNonUserCode()] + set + { + this.SetAttributeValue("ofm_on_k12_school_grounds_or_board_affiliated", value.HasValue ? new Microsoft.Xrm.Sdk.OptionSetValue((int)value) : null); + } + } + + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_on_k12_school_grounds_or_board_affiliatedname")] + public string ofm_on_k12_school_grounds_or_board_affiliatedname + { + [System.Diagnostics.DebuggerNonUserCode()] + get + { + if (this.FormattedValues.Contains("ofm_on_k12_school_grounds_or_board_affiliated")) + { + return this.FormattedValues["ofm_on_k12_school_grounds_or_board_affiliated"]; + } + else + { + return default(string); + } + } + } + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_on_reserve")] public virtual ecc_ynempty? ofm_on_reserve { @@ -24945,6 +24977,21 @@ public virtual ecc_ynempty? ofm_accb_participation } } + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_accb_participation")] + public virtual ecc_ynempty? ofm_accb_participation + { + [System.Diagnostics.DebuggerNonUserCode()] + get + { + return ((ecc_ynempty?)(EntityOptionSetEnum.GetEnum(this, "ofm_accb_participation"))); + } + [System.Diagnostics.DebuggerNonUserCode()] + set + { + this.SetAttributeValue("ofm_accb_participation", value.HasValue ? new Microsoft.Xrm.Sdk.OptionSetValue((int)value) : null); + } + } + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_accb_participationname")] public string ofm_accb_participationname { @@ -26411,6 +26458,53 @@ public virtual ecc_ynempty? ofm_provide_previous_fy_financial_statements } } + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_provide_actual_expenses")] + public virtual ecc_ynempty? ofm_provide_actual_expenses + { + [System.Diagnostics.DebuggerNonUserCode()] + get + { + return ((ecc_ynempty?)(EntityOptionSetEnum.GetEnum(this, "ofm_provide_actual_expenses"))); + } + [System.Diagnostics.DebuggerNonUserCode()] + set + { + this.SetAttributeValue("ofm_provide_actual_expenses", value.HasValue ? new Microsoft.Xrm.Sdk.OptionSetValue((int)value) : null); + } + } + + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_provide_actual_expensesname")] + public string ofm_provide_actual_expensesname + { + [System.Diagnostics.DebuggerNonUserCode()] + get + { + if (this.FormattedValues.Contains("ofm_provide_actual_expenses")) + { + return this.FormattedValues["ofm_provide_actual_expenses"]; + } + else + { + return default(string); + } + } + } + + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_provide_previous_fy_financial_statements")] + public virtual ecc_ynempty? ofm_provide_previous_fy_financial_statements + { + [System.Diagnostics.DebuggerNonUserCode()] + get + { + return ((ecc_ynempty?)(EntityOptionSetEnum.GetEnum(this, "ofm_provide_previous_fy_financial_statements"))); + } + [System.Diagnostics.DebuggerNonUserCode()] + set + { + this.SetAttributeValue("ofm_provide_previous_fy_financial_statements", value.HasValue ? new Microsoft.Xrm.Sdk.OptionSetValue((int)value) : null); + } + } + [Microsoft.Xrm.Sdk.AttributeLogicalNameAttribute("ofm_provide_previous_fy_financial_statementsname")] public string ofm_provide_previous_fy_financial_statementsname { diff --git a/ECC.Core.DataContext/OptionSets/OptionSets.cs b/ECC.Core.DataContext/OptionSets/OptionSets.cs index 70f34701..61d5ce05 100644 --- a/ECC.Core.DataContext/OptionSets/OptionSets.cs +++ b/ECC.Core.DataContext/OptionSets/OptionSets.cs @@ -15642,6 +15642,38 @@ public enum ofm_system_message_StatusCode Inactive = 2, } + /// + /// Status of the OFM System Message + /// + [System.Runtime.Serialization.DataContractAttribute()] + public enum ofm_system_message_statecode + { + + [System.Runtime.Serialization.EnumMemberAttribute()] + [OptionSetMetadataAttribute("Active", 0)] + Active = 0, + + [System.Runtime.Serialization.EnumMemberAttribute()] + [OptionSetMetadataAttribute("Inactive", 1)] + Inactive = 1, + } + + /// + /// Reason for the status of the OFM System Message + /// + [System.Runtime.Serialization.DataContractAttribute()] + public enum ofm_system_message_StatusCode + { + + [System.Runtime.Serialization.EnumMemberAttribute()] + [OptionSetMetadataAttribute("Active", 0)] + Active = 1, + + [System.Runtime.Serialization.EnumMemberAttribute()] + [OptionSetMetadataAttribute("Inactive", 1)] + Inactive = 2, + } + [System.Runtime.Serialization.DataContractAttribute()] public enum ofm_verification_checklist_status { diff --git a/OFM.Infrastructure.CustomWorkflowActivities/Application/CreateFundingRecord.cs b/OFM.Infrastructure.CustomWorkflowActivities/Application/CreateFundingRecord.cs index 2974fb33..c7457014 100644 --- a/OFM.Infrastructure.CustomWorkflowActivities/Application/CreateFundingRecord.cs +++ b/OFM.Infrastructure.CustomWorkflowActivities/Application/CreateFundingRecord.cs @@ -98,11 +98,12 @@ protected override void Execute(CodeActivityContext executionContext) //generate the application funding number Base tracingService.Trace("***Update Funding Number Base" + ofmFundingNumberBase); - Entity newudpate = new Entity(); - newudpate.LogicalName = entity.LogicalName; - newudpate["ofm_applicationid"] = entity["ofm_applicationid"]; - newudpate["ofm_funding_number_base"] = ofmFundingNumberBase; - service.Update(newudpate); + Entity newupdate = new Entity(); + newupdate.LogicalName = entity.LogicalName; + newupdate["ofm_applicationid"] = entity["ofm_applicationid"]; + newupdate["ofm_funding_number_base"] = ofmFundingNumberBase; + newupdate["ofm_funding_version_number"] = 0; + service.Update(newupdate); // Create first Funding record Entity newFundingRecord = new Entity("ofm_funding"); @@ -120,37 +121,42 @@ protected override void Execute(CodeActivityContext executionContext) tracingService.Trace("\nStart resubmit logic implement, logical name: {0}, id:{1}", entity.LogicalName, entity.Id); var fetchData = new { - ofm_application = recordId.ToString(), - statecode = "0" + ofm_application = recordId.ToString() }; fetchXml = $@" - - - - - + + + - - + - "; - EntityCollection fundingRecords = service.RetrieveMultiple(new FetchExpression(fetchXml)); - if (fundingRecords.Entities.Count > 0 && fundingRecords[0] != null) + EntityCollection applicationRecord = service.RetrieveMultiple(new FetchExpression(fetchXml)); + tracingService.Trace("application count: " + applicationRecord.Entities.Count); + if (applicationRecord.Entities.Count > 0 && applicationRecord[0] != null) { - var id = fundingRecords[0].Id; - tracingService.Trace("\nResubmission, create new funding records:" + id); + tracingService.Trace("\nModification, create new funding records, current version: " + applicationRecord[0].GetAttributeValue("ofm_funding_version_number")); Entity newFundingRecord = new Entity("ofm_funding"); - newFundingRecord["ofm_version_number"] = fundingRecords[0].GetAttributeValue("ofm_version_number") + 1; - newFundingRecord["ofm_funding_number"] = ofmFundingNumberBase + "-" + (fundingRecords[0].GetAttributeValue("ofm_version_number") + 1).ToString("00"); // Primary coloumn + var newVersionNumber = applicationRecord[0].GetAttributeValue("ofm_funding_version_number") + 1; + newFundingRecord["ofm_version_number"] = newVersionNumber; + newFundingRecord["ofm_funding_number"] = ofmFundingNumberBase + "-" + newVersionNumber.ToString("00"); // Primary coloumn newFundingRecord["ofm_application"] = new EntityReference("ofm_application", recordId); newFundingRecord["ofm_rate_schedule"] = (rateSchedualId == null || rateSchedualId == Guid.Empty) ? null : new EntityReference("ofm_rate_schedule", rateSchedualId); //newFundingRecord["statuscode"] = new OptionSetValue((int) ofm_funding_StatusCode.FAReview); service.Create(newFundingRecord); - + + + //Update application version number + Entity newupdate = new Entity(); + newupdate.LogicalName = entity.LogicalName; + newupdate["ofm_applicationid"] = entity["ofm_applicationid"]; + newupdate["ofm_funding_version_number"] = newVersionNumber; + service.Update(newupdate); + + tracingService.Trace("\nThis is a resubmisstion.Create Funding records successfully."); } } @@ -163,4 +169,4 @@ protected override void Execute(CodeActivityContext executionContext) } } } -} +} \ No newline at end of file diff --git a/OFM.Infrastructure.CustomWorkflowActivities/Funding/OutputModStartAndEndDate.cs b/OFM.Infrastructure.CustomWorkflowActivities/Funding/OutputModStartAndEndDate.cs index 38a71a4e..c06aef22 100644 --- a/OFM.Infrastructure.CustomWorkflowActivities/Funding/OutputModStartAndEndDate.cs +++ b/OFM.Infrastructure.CustomWorkflowActivities/Funding/OutputModStartAndEndDate.cs @@ -16,9 +16,10 @@ public sealed class OutputModStartAndEndDate : CodeActivity [Input("Application")] public InArgument application { get; set; } - [Input("Version")] + [ReferenceTarget("ofm_funding")] [RequiredArgument] - public InArgument version { get; set; } + [Input("Funding")] + public InArgument funding { get; set; } [Output("Start Date")] public OutArgument startDate { get; set; } @@ -39,28 +40,36 @@ protected override void Execute(CodeActivityContext executionContext) IOrganizationService service = serviceFactory.CreateOrganizationService(context.InitiatingUserId); tracingService.Trace("{0}{1}", "Start Custom Workflow Activity: OutputMODStartAndEndDate", DateTime.Now.ToLongTimeString()); var application = this.application.Get(executionContext); - var version = this.version.Get(executionContext); + var funding = this.funding.Get(executionContext); try { var fundingRequest = new QueryExpression() { EntityName = ofm_funding.EntityLogicalName, - ColumnSet = new ColumnSet(new string[] { ofm_funding.Fields.ofm_end_date, ofm_funding.Fields.ofm_application }), + ColumnSet = new ColumnSet(new string[] { ofm_funding.Fields.ofm_end_date, ofm_funding.Fields.ofm_application, ofm_funding.Fields.ofm_version_number }), Criteria = new FilterExpression { Conditions = { - new ConditionExpression(ofm_funding.Fields.ofm_version_number, ConditionOperator.Equal, version - 1), - new ConditionExpression(ofm_funding.Fields.ofm_application, ConditionOperator.Equal, application.Id) + new ConditionExpression(ofm_funding.Fields.ofm_application, ConditionOperator.Equal, application.Id), + new ConditionExpression("ofm_fundingid", ConditionOperator.NotEqual, funding.Id) } + }, + Orders = + { + new OrderExpression("ofm_version_number", OrderType.Descending) } }; var d365Funding = service.RetrieveMultiple(fundingRequest); + tracingService.Trace("{0}{1}", "Fundings:", d365Funding.Entities.Count); + tracingService.Trace("{0}{1}", "Latest Funding: ", d365Funding[0].Id); + if (d365Funding != null && d365Funding.Entities.Count > 0 && d365Funding[0].Attributes.Contains(ofm_funding.Fields.ofm_end_date)) { + RetrieveRequest timeZoneCode = new RetrieveRequest { ColumnSet = new ColumnSet(new string[] { UserSettings.Fields.timezonecode }), diff --git a/OFM.Infrastructure.WebAPI/Models/Fundings/Fundings.cs b/OFM.Infrastructure.WebAPI/Models/Fundings/Fundings.cs index 8e002673..4b1936ad 100644 --- a/OFM.Infrastructure.WebAPI/Models/Fundings/Fundings.cs +++ b/OFM.Infrastructure.WebAPI/Models/Fundings/Fundings.cs @@ -147,6 +147,7 @@ public class SupplementaryApplication : ofm_allowance public new decimal? ofm_transport_odometer { get; set; } public new decimal? ofm_monthly_amount { get; set; } public new decimal? ofm_retroactive_amount { get; set; } + public string? ofm_funding_number { get; set; } public new SupplementarySchedule? ofm_supplementary_schedule { get; set; } public string? _ofm_application_value { get; set; } [property: JsonPropertyName("con.ofm_first_name")] diff --git a/OFM.Infrastructure.WebAPI/Services/Processes/Emails/IEmailRepository.cs b/OFM.Infrastructure.WebAPI/Services/Processes/Emails/IEmailRepository.cs index 9d547c23..b9bfed7e 100644 --- a/OFM.Infrastructure.WebAPI/Services/Processes/Emails/IEmailRepository.cs +++ b/OFM.Infrastructure.WebAPI/Services/Processes/Emails/IEmailRepository.cs @@ -308,7 +308,7 @@ public async Task CreateAllowanceEmail(SupplementaryApplication allo //var allowanceStatusReason = allowance.statuscode; Guid applicationPrimaryContact = (Guid)allowance._ofm_contact_value != null ? (Guid)allowance._ofm_contact_value : Guid.Empty; Guid submittedBy = allowance._ofm_summary_submittedby_value != null ? (Guid)allowance._ofm_summary_submittedby_value : Guid.Empty; - var fundingNumber = allowance.ofm_funding_number_base; + var fundingNumber = allowance.ofm_funding_number; var effectiveDate = allowance.ofm_start_date; var retroActiveDate = allowance.ofm_retroactive_date; var VIN = allowance.ofm_transport_vehicle_vin; diff --git a/OFM.Infrastructure.WebAPI/Services/Processes/Emails/P240AllowanceApprovalDenialNotificationProvider.cs b/OFM.Infrastructure.WebAPI/Services/Processes/Emails/P240AllowanceApprovalDenialNotificationProvider.cs index eb825710..c1a51ab3 100644 --- a/OFM.Infrastructure.WebAPI/Services/Processes/Emails/P240AllowanceApprovalDenialNotificationProvider.cs +++ b/OFM.Infrastructure.WebAPI/Services/Processes/Emails/P240AllowanceApprovalDenialNotificationProvider.cs @@ -64,6 +64,7 @@ public string RequestUri +