Skip to main content
Solved

A little Glitch to allow system pass the "PXErrorLevel.Error" and proceed to save and release doc?


Forum|alt.badge.img+5
  • Captain II
  • 398 replies

Hello,

      I don’t know it is my code issues or system framework issue.  Somehow, I encountered a case that the system can ignore the error on the screen and proceed to save and release document.

    My environment is Build 21.208.0032. So I don’t know this issue still exists in current version.

My need is to forbid SO invoice being saved/released if any line contains 0 qty.

I am using the below code mainly
 

protected void ARTran_RowSelected(PXCache cache, PXRowSelectedEventArgs e)

    {

            ARTran aRTran = (ARTran)e.Row;
            if (aRTran != null)
            {
                using (new PXConnectionScope())
                {
                            InventoryItem item = PXSelect<InventoryItem,
                            Where<InventoryItem.inventoryID, Equal<Required<InventoryItem.inventoryID>>>>
                            .Select(Base, aRTran.InventoryID);  
                   if (item != null)                   {       

                                   if (aRTran.Qty == 0)
                            {
                                cache.RaiseExceptionHandling<ARTran.qty>(aRTran,
                                    aRTran.Qty, new PXSetPropertyException("Qty Can NOT be 0", PXErrorLevel.Error));

                            }
                                             else
                        {
                            cache.RaiseExceptionHandling<ARTran.qty>(aRTran, null, null);
                        }                  

                    }                                         

                }

            }

    }

Normally this code works OK. But if the user operates in the below steps, the system can bypass error and proceed.

1, Save an invoice normally with all lines not equal to 0 qty.
2, Purposely change a line qty to 0, like 3rd line, and then move the mouse focus to another line, let’s say the 2nd line.
And then, click save.
At that time, the system allows the 0 qty to be saved.
And then,  click release. The invoice can be released with the red error alert on screen.
 

 


How can I enhance my code to fix the little hole? Please advise.​​​​​

Best answer by Naveen Boga

Hi @ray20   Thanks for response.

Can you please confirm the below,

if any line item is having the ZERO qty, we should not allow to SAVE the document right? Please confirm.

If yes, you can use the below code.

 

 protected virtual void ARTran_RowPersisting(PXCache sender, PXRowPersistingEventArgs e, PXRowPersisting baseMethod)
        {
            baseMethod?.Invoke(sender,e);
            ARTran row = (ARTran)e.Row;
            if (row != null)
            {
                if (row.Qty == Decimal.Zero)
                {

                    sender.RaiseExceptionHandling<ARTran.qty>(row, row.Qty, new PXSetPropertyException("Quantity must be greater than 0", PXErrorLevel.Error));
                }
            }
        }

 

View original
Did this topic help you find an answer to your question?

8 replies

Naveen Boga
Captain II
Forum|alt.badge.img+19
  • Captain II
  • 3381 replies
  • March 24, 2023

@ray20 Can you please try below.

 

  protected virtual void ARTran_Qty_FieldUpdated(PXCache sender, PXFieldUpdatedEventArgs e, PXFieldUpdated baseMethod)
        {
            baseMethod?.Invoke(sender, e);
            ARTran row = (ARTran)e.Row;
            if (row != null)
            {
                if (row.Qty == Decimal.Zero)
                {
                    sender.RaiseExceptionHandling<ARTran.qty>(row, row.Qty, new PXSetPropertyException("Quantity must be greater than 0", PXErrorLevel.Error));
                }
            }
        }


Forum|alt.badge.img+5
  • Author
  • Captain II
  • 398 replies
  • March 24, 2023

@Naveen Boga  Hello, thank you for your hands.
But unfortunately, your codes can not solve my issue, either.

What’s worse, the red alert is disappeared after the user click save.

I know, it is not good habit to put everything into “row selected” event. But if not, sometime, we might have some holes in our codes.  
 

 

Note, the Key hole step Is
“Purposely change a line qty to 0, like 3rd line, and then move the mouse focus to another line, let’s say the 2nd line.”
And then, click save.
If the user stays on the changing line, the save can not work.


Naveen Boga
Captain II
Forum|alt.badge.img+19
  • Captain II
  • 3381 replies
  • Answer
  • March 24, 2023

Hi @ray20   Thanks for response.

Can you please confirm the below,

if any line item is having the ZERO qty, we should not allow to SAVE the document right? Please confirm.

If yes, you can use the below code.

 

 protected virtual void ARTran_RowPersisting(PXCache sender, PXRowPersistingEventArgs e, PXRowPersisting baseMethod)
        {
            baseMethod?.Invoke(sender,e);
            ARTran row = (ARTran)e.Row;
            if (row != null)
            {
                if (row.Qty == Decimal.Zero)
                {

                    sender.RaiseExceptionHandling<ARTran.qty>(row, row.Qty, new PXSetPropertyException("Quantity must be greater than 0", PXErrorLevel.Error));
                }
            }
        }

 


Forum|alt.badge.img+5
  • Author
  • Captain II
  • 398 replies
  • March 24, 2023

@Naveen Boga  Awesome, this fixed the hold.  The codes just listened to you . You are master of codes. Thank you so much.


Naveen Boga
Captain II
Forum|alt.badge.img+19
  • Captain II
  • 3381 replies
  • March 24, 2023

@ray20  You are most welcome. I’m glad that I helped on this customization.

 


Forum|alt.badge.img+5
  • Author
  • Captain II
  • 398 replies
  • March 24, 2023

@Naveen Boga  Hello, my friend, I am sorry to tell you, the solution we’ve made yesterday got a serious problem.  It would cause some shipments (with shipped qty=0 lines) can not be converted to invoices by using “prepare invoice” action.
But I do not quite understand, as I have tested, the shipped qty=0 lines would not actually be showed up on invoice. And also my codes in ARTran_RowSelected event gets no such issue.
So I am really surprised how are Shipment to Invoice generation and ARTran_RowPersisting working.
Are you getting what I am adressing at?  
1,  The shipped qty=0 lines are not showed up on the generated invoice. So I guess 0 lines are not persisting.
2,  However, the ARTran_RowPersisting event stops the shipment to invoice generation if shipments with shipped 0 lines. 
Weird.

No big issue. I have rolled back the codes and let system go.
Although there is a little hole in my code, but I assume the user would not change the qty  to  0, and then save purposely. And they would also not release the doc purposely with ignoring the obvious error msg on screen.
 


Naveen Boga
Captain II
Forum|alt.badge.img+19
  • Captain II
  • 3381 replies
  • March 24, 2023

Hi @ray20  I just checked, if we have Shipped Qty as 0, system will NOT take such lines to the INVOICE document. Also, I don’t see any error on the Invoice preparation.

 

 

 

 


Forum|alt.badge.img+5
  • Author
  • Captain II
  • 398 replies
  • March 31, 2023

@Naveen Boga  Sorry for the late reply, I have a long weekend.  Yes, you are right, the shipped qty=0 lines would not appear on invoice. So that’s the strange things come from. Do you prepare invoice with the ARTran_RowPersisting event?
You did not meet the issue, might be we are not using the same version.  We still stay on Build 21.208.0032. Or The operations “prepare invoice” in batch on the processing screen not on shipment screen.
Anyway, I have commented the codes in (ARTran_RowPersisting) event. and the operations find it fine. Thank you for all your help.


Reply


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings