I have a screen that user enters some cashflow projections for our projects. This screen keeps the different versions of cashflw projections. At any given time each project can have only one “Current Revision”. When a new projection entered r an existing projection is changed as “IsCurrent = true”, I would like to update a field (UsrLGRevisionID) in PMProject extension with the current projection “RevisionID”. The only problem that I have when I insert/update a new projection as Current, it doesn’t update the PMProject but if second time I just set the checkbox of IsCurrent” off and then on, it updates the PMProject Extension. Here is my even handler. Any help is appreciated.
// Only one Current Revision should exist for each project. // When a Cashflow Projection is set to "Current", the rest of the projections shouldn't be current. bool isCurrent = false; var revisionsFilter = this.RevisionsFilter.Select();
if (row.IsCurrent == true) { foreach (PMCashflowProjection revisions in revisionsFilter) { if (revisions.RevisionID != row.RevisionID) { if (revisions.IsCurrent == true) { Caches typeof(PMCashflowProjection)].SetValue<PMCashflowProjection.isCurrent>(revisions, false); Caches typeof(PMCashflowProjection)].Persist(revisions, PXDBOperation.Update); } } else { isCurrent = true; } } } else { foreach (PMCashflowProjection revisions in revisionsFilter) { if (revisions.IsCurrent == true) { isCurrent = true; continue; } } }
// ONE Current Projection should exist for each project. if (isCurrent != true) { throw new PXException(PMMessages_Extension.NoneOfTheCashflowRevisionsIsFlaggedAsCurrent); }
// Project master record should be updated with the Current Cashflow Projection reference. var projectsFilter = this.ProjectsFilter.Select();
Hi @aaghaei Are you trying to update the flag like below please confirm?
If (revisions.RevisionID != row.RevisionID), you want to set IsCurrent = false and if both revisions are matching then you wanted to update IsCurrent = true right?
If yes, can you please share you complete graph code file here.
Hi @Naveen B,
For the first part that in CashflowProjection yes assuming the selected projection IsCurrent flag is set to true yes but this is not my problem. My problem is I want to update a field in PMProject Extension to set its value equal to current projection revisionID again assuming the selected projection IsCurrent flag is true. My problem is updating PMProject that doesn’t happen first time.
Here is my graph:
using PX.Data; using PX.Objects.PM;
namespace LGCustom { //**************************************** PMCashflowProjectionEntry ****************************************// public class PMCashflowProjectionEntry : PXGraph<PMCashflowProjectionEntry, PMCashflowProjection> {
PXViewName("Projects Cashflow Projections")] public PXSelect<PMCashflowProjection> CashflowProjections;
public PXSelect<PMCashflowProjection, Where<PMCashflowProjection.projectID, Equal<Current<PMCashflowProjection.projectID>>>> RevisionsFilter;
public PXSelect<PMCashflowProjectionSchedule, Where<PMCashflowProjectionSchedule.projectID, Equal<Current<PMCashflowProjection.projectID>>, And<PMCashflowProjectionSchedule.revisionID, Equal<Current<PMCashflowProjection.revisionID>>>>> CashflowProjectionSchedules;
public PXSelect<PMProject, Where<PMProject.contractID, Equal<Current<PMCashflowProjection.projectID>>>> ProjectsFilter;
if (row != null) { // Validate whether Cashflow Schedule agrees to the total expected cashflow from the project. if (row.OriginalValue != row.OriginalValueRollup) { throw new PXException(PMMessages_Extension.OriginalCashflowAllocationIsNotBalanced); }
if (row.RevisedValue != row.RevisedValueRollup) { throw new PXException(PMMessages_Extension.RevisedCashflowAllocationIsNotBalanced); }
// Only one Current Revision should exist for each project. // When a Cashflow Projection is set to "Current", the rest of the projections shouldn't be current. bool isCurrent = false; var revisionsFilter = this.RevisionsFilter.Select();
if (row.IsCurrent == true) { foreach (PMCashflowProjection revisions in revisionsFilter) { if (revisions.RevisionID != row.RevisionID) { if (revisions.IsCurrent == true) { Cachesetypeof(PMCashflowProjection)].SetValue<PMCashflowProjection.isCurrent>(revisions, false); Cachesetypeof(PMCashflowProjection)].Persist(revisions, PXDBOperation.Update); //CashflowProjections.Update(revisions); } } else { isCurrent = true; } } } else { foreach (PMCashflowProjection revisions in revisionsFilter) { if (revisions.IsCurrent == true) { isCurrent = true; continue; } } }
// ONE Current Projection should exist for each project. if (isCurrent != true) { throw new PXException(PMMessages_Extension.NoneOfTheCashflowRevisionsIsFlaggedAsCurrent); }
// Project master record should be updated with the Current Cashflow Projection reference. //RevisionsFilter.View.RequestRefresh(); var projectsFilter = this.ProjectsFilter.Select();
@Naveen B any though on this issue. All I want to do is to update a field in PMProject Ext from the Cashflow Projection assuming the status of this cashflow is set to Current.
Hi @aaghaei I have re-write the code for updating the fields. Please find the code below.
Please verify and let me know if any queries.
public class PMCashflowProjectionEntry : PXGraph<PMCashflowProjectionEntry, PMCashflowProjection> {
PXViewName("Projects Cashflow Projections")] public PXSelect<PMCashflowProjection> CashflowProjections;
public PXSelect<PMCashflowProjection, Where<PMCashflowProjection.projectID, Equal<Current<PMCashflowProjection.projectID>>>> RevisionsFilter;
public PXSelect<PMCashflowProjectionSchedule, Where<PMCashflowProjectionSchedule.projectID, Equal<Current<PMCashflowProjection.projectID>>, And<PMCashflowProjectionSchedule.revisionID, Equal<Current<PMCashflowProjection.revisionID>>>>> CashflowProjectionSchedules;
public PXSelect<PMProject, Where<PMProject.contractID, Equal<Current<PMCashflowProjection.projectID>>>> ProjectsFilter;
public delegate void PersistDelegate(); PXOverride] public void Persist(PersistDelegate del) { PMCashflowProjection row = PMCashflowProjection.Current;
if (row != null) { if (row.OriginalValue != row.OriginalValueRollup) { throw new PXException(PMMessages_Extension.OriginalCashflowAllocationIsNotBalanced); }
if (row.RevisedValue != row.RevisedValueRollup) { throw new PXException(PMMessages_Extension.RevisedCashflowAllocationIsNotBalanced); } bool isCurrent = false; if (row.IsCurrent == true) { foreach (PMCashflowProjection revisions in RevisionsFilter.Select()) { if (revisions.RevisionID != row.RevisionID) { if (revisions.IsCurrent == true) { revisions.isCurrent = false; RevisionsFilter.Update(revisions); } } else { isCurrent = true; } } } else { foreach (PMCashflowProjection revisions in RevisionsFilter.Select()) { if (revisions.IsCurrent == true) { isCurrent = true; continue; } } } if (isCurrent != true) { throw new PXException(PMMessages_Extension.NoneOfTheCashflowRevisionsIsFlaggedAsCurrent); } foreach (PMProject projects in ProjectsFilter.Select()) { if (projects.ContractID == row.ProjectID) { PMProject_Extension projectExt = projects.GetExtension<PMProject_Extension>(); projectExt.usrLGRevisionID = row.RevisionID; ProjectsFilter.Cache.Update(projects); } } }
Thanks @Naveen B, the “.Current” is not an recognized object as you can see from the attached snip,
Hi @Naveen B, I couldn’t underestand why did you cahange my Persis Even code to Delete deligate but i figured out what was wrong in my code. with my code, When I was looping on revisions to update the project with current revision, I was not checking whether the revision is Current or not. I just had to check
if (row.IsCurrent == true) then update the ProjectExt that I fixed. Thank you for your time. The issue is resolved.
Hi @aaghaei Basically, we can handle both Persisting and Persisted events in Persist Delegate.