Attempting to trigger a miscellaneous charge addition to each new line on an order. I’ve found a post on a different forum with the following “Jose C Gomez’s working Code” :
DEFINE VARIABLE hSalesOrder AS HANDLE NO-UNDO.
DEFINE VARIABLE miscCode AS CHARACTER NO-UNDO.
DEFINE VARIABLE orderNum AS INTEGER NO-UNDO.
ASSIGN miscCode =‘FRGT’.
/* CREATE A HANDLE FOR THE SALES ORDER BO /
RUN bo/SalesOrder.p PERSISTENT SET hSalesOrder.
/ GET THE SALES ORDER NUMBER*/
FOR EACH ttOrderHed:
Assign orderNum= ttOrderHed.OrderNum.
END.
/* RUN GET BY ID TO GET THE MOST UP TO DATE COPY OF THE ORCER */
RUN GetByID IN hSalesOrder(INPUT orderNum,
{&output_dataset_SalesOrderDataSet}).
/* WE GET THE FIRST ORDER LINE IN THE ORDER*/
FOR FIRST ttOrderDtl:
/* CHECK TO SEE IF OUR MISC CHARGE ALREADY EXISTS*/
FIND FIRST OrderMsc WHERE OrderMsc.Company=ttOrderDtl.Company AND
OrderMsc.OrderNum=ttOrderDtl.OrderNum AND OrderMsc.OrderLine =
ttOrderDtl.OrderLine AND OrderMsc.MiscCode=miscCode NO-LOCK NO-ERROR.
/* IF IT DOES NOT EXIST /
IF NOT AVAILABLE OrderMsc THEN DO:
/ GET A NEW MISC CHARGE FOR THE FIRST LINE /
RUN GetNewOrderMsc IN
hSalesOrder({&input-output_dataset_SalesOrderDataSet}, ttOrderDtl.OrderNum,
ttOrderDtl.OrderLine).
/ ASSIGN THE MISC CODE /
FOR EACH ttOrderMsc WHERE ttOrderMsc.RowMod=‘A’:
Assign ttOrderMsc.MiscCode=miscCode.
END.
/ RUN THE CHANGE MISC CODE BO TO GET DESCRIPTION AND SUCH /
RUN ChangeMiscCode IN
hSalesOrder({&input-output_dataset_SalesOrderDataSet}, ‘OrderMsc’).
/ ASSIGN THE AMOUNT OF THE MISC CHARGE /
FOR EACH ttOrderMsc WHERE ttOrderMsc.RowMod=‘A’:
Assign ttOrderMsc.DocMiscAmt=35.50.
END.
/ RUN THE CHANGE AMOUNT BO TO GET THE REST OF THE INFO FILLED /
RUN ChangeMiscAmount IN
hSalesOrder({&input-output_dataset_SalesOrderDataSet}, ‘OrderMsc’).
/ SET THE FREQUENCY /
FOR EACH ttOrderMsc WHERE ttOrderMsc.RowMod=‘A’:
Assign ttOrderMsc.FreqCode=‘F’.
END.
/ UPDATE OUR CHANGES. THIS TIME OUR BPM WILL STOP SHORT BECAUSE WE HAVE
THAT MISC CHARGE /
RUN Update IN hSalesOrder({&input-output_dataset_SalesOrderDataSet}).
/ RUN GET BY ID TO GET THE MOST FRESH COPY OF OUR DATA */
RUN GetByID IN hSalesOrder(INPUT orderNum,
{&output_dataset_SalesOrderDataSet}).
END.
END.
…and some discussion that this has to be a post-processing Method Directive on SalesOrder.Update. I created the post-processing method Directive, with the Action of “synchronously execute ABL code…record nothing” and pasted the code. Everything validated ok. Set up the charge type itself and attempted to execute…and receive a “4GL STOP condition error”.
Hey Doyle
That’s my code! I wonder who took it elsewhere shakes fist
Looking at your server logs when this runs what is the error there? It could be that this was written for a different version and the method signatures have changed.
I’ve located the Server\bo\SalesOrder directory, but there is no SalesOrder.p. There is SalesOrder.i, SalesOrder.r, SalesOrder_ds.i, SalesOrder_eq.i, saleOrderAfterGetRows.i, and SalesOrderTrg.r, but no “SalesOrder.p”.
I hate to dig up an old post, but I have run into a little problem using the code above. I have added a lookup for a decimal field on the customer record to use to set the value for the DocMiscAmt field. This allows for different customers to be charged a different processing fee amount. Here is my complete BPM code:
DEFINE VARIABLE hSalesOrder AS HANDLE NO-UNDO.
DEFINE VARIABLE miscCode AS CHARACTER NO-UNDO.
DEFINE VARIABLE orderNum AS INTEGER NO-UNDO.
DEFINE VARIABLE procFeeAmt AS DECIMAL NO-UNDO.
ASSIGN miscCode =‘PROC’.
/* CREATE A HANDLE FOR THE SALES ORDER BO /
RUN bo/SalesOrder/SalesOrder.p PERSISTENT SET hSalesOrder.
/ GET THE SALES ORDER NUMBER*/
FOR EACH ttOrderHed:
Assign orderNum= ttOrderHed.OrderNum.
FIND FIRST Customer WHERE Customer.Company=ttOrderHed.Company AND Customer.CustNum=ttOrderHed.CustNum NO-LOCK NO-ERROR.
IF AVAILABLE Customer THEN DO:
ASSIGN procFeeAmt=Customer.Number02.
END.
END.
/* RUN GET BY ID TO GET THE MOST UP TO DATE COPY OF THE ORCER */
RUN GetByID IN hSalesOrder(INPUT orderNum,
{&output_dataset_SalesOrderDataSet}).
/* WE GET THE FIRST ORDER LINE IN THE ORDER*/
FOR FIRST ttOrderDtl:
/* CHECK TO SEE IF OUR MISC CHARGE ALREADY EXISTS*/
FIND FIRST OrderMsc WHERE OrderMsc.Company=ttOrderDtl.Company AND OrderMsc.OrderNum=ttOrderDtl.OrderNum AND OrderMsc.OrderLine=ttOrderDtl.OrderLine AND OrderMsc.MiscCode=miscCode NO-LOCK NO-ERROR.
/* IF IT DOES NOT EXIST /
IF NOT AVAILABLE OrderMsc THEN DO:
/ GET A NEW MISC CHARGE FOR THE FIRST LINE /
RUN GetNewOrderMsc IN hSalesOrder({&input-output_dataset_SalesOrderDataSet}, ttOrderDtl.OrderNum, ttOrderDtl.OrderLine).
/ ASSIGN THE MISC CODE /
FOR EACH ttOrderMsc WHERE ttOrderMsc.RowMod=‘A’:
Assign ttOrderMsc.MiscCode=miscCode.
END.
/ RUN THE CHANGE MISC CODE BO TO GET DESCRIPTION AND SUCH /
RUN ChangeMiscCode IN hSalesOrder({&input-output_dataset_SalesOrderDataSet}, ‘OrderMsc’).
/ ASSIGN THE AMOUNT OF THE MISC CHARGE /
FOR EACH ttOrderMsc WHERE ttOrderMsc.RowMod=‘A’:
Assign ttOrderMsc.DocMiscAmt=procFeeAmt.
END.
/ RUN THE CHANGE AMOUNT BO TO GET THE REST OF THE INFO FILLED /
RUN ChangeMiscAmount IN hSalesOrder({&input-output_dataset_SalesOrderDataSet}, ‘OrderMsc’).
/ SET THE FREQUENCY /
FOR EACH ttOrderMsc WHERE ttOrderMsc.RowMod=‘A’:
Assign ttOrderMsc.FreqCode=‘E’.
END.
/ UPDATE OUR CHANGES. THIS TIME OUR BPM WILL STOP SHORT BECAUSE WE HAVE THAT MISC CHARGE /
RUN Update IN hSalesOrder({&input-output_dataset_SalesOrderDataSet}).
/ RUN GET BY ID TO GET THE MOST FRESH COPY OF OUR DATA */
RUN GetByID IN hSalesOrder(INPUT orderNum, {&output_dataset_SalesOrderDataSet}).
END.
END.
The problem is, the ttOrderMsc table is never actually saved to the DB. There are no errors in processing the BPM, and if you look at the Order -> Lines -> Misc Charges tab on the Order entry, all of the ttOrderMsc table data is displayed, until you click the “Refresh” button on the UI (at which point that data disappears). Also, if you are viewing the ttOrderMsc data (with the changes that the BPM made) and click on the “Save” button in the ribbon, it does nothing. Any suggestions?
Ok, so even though it is bad practice to call out a file from within a BPM by its full path, I had to do it that way in order to get the charge to apply on the Order Line properly. If I change it back to a relative path, it will not save the misc charge. Anybody have any ideas on that?