The purpose of this BPM is to update the field Order Product Line price when the Quote Line Product price is changed.
I am doing my BPM on the Post-Processing action of the method Erp.Quote.Update by using the “Invoke BO Method”; until here I tried to enabled and save my BPM but when I click on the save button I receive the following error:
Error CS0433: The type ‘Erp.Tablesets.ETCAddrValidationTableset’ exists in both ‘c:\inetpub\wwwroot\XXXXX\Server\Assemblies\Erp.Contracts.BO.SalesOrder.dll’ and ‘c:\inetpub\wwwroot\XXXXX\Server\Assemblies\Erp.Contracts.BO.Quote.dll’ [CustomizationAdapter.cs(264,30)]
Error CS0433: The type ‘Erp.Tablesets.QuoteQtyTable’ exists in both
According to Epicor support this is a know issue and has not been corrected in 10.2? Support suggest an External BPM or a Data Directive BPM.
That said:
What do I need to create an External BPM method (DLL)? I do have Visual Studio, but not sure if I need Epicor SDK?
Is there a way for the Method BPM to call a Data Directive BPM? I have to prompt the user to confirm before updating the Sales Order Line price.
Thank for the suggestion. I wound which will be faster a call to an UBAQ or LINIQ from the method BPM? I would appreciate any pros and cons especially regarding which approach will trigger the auto-update to the Sales Order total = Line Price * Quantity.
Just making sure, there is no way to call an UBAQ from a Method BPM by any of the available Callers (tools). I assume you are referring to a C# block with code to call the UBAQ and passing it the parameters.
It would be easier (I think) to call the UBAQ from a client side customization instead of a BPM. You can set any of many different triggers that are available in the client customization.
edit But I supposed if you are try to stop a transaction, that may not work as well. I’m not sure.
technically you can call the dynamic query BO in a BPM, but I’ve never gotten it to work.
Well, @dhewi talks about it here. However, in your case, since you are just putting a BPM in place and not actually changing the results of the data that comes back (the BPM is going to do it for you right?), I don’t know if it’s any different then just calling the BPM. I’m pretty sure the BPM will still fire.
I read in previous post that you will have to bind the UBAQ to a dashboard grid before you can use it. This sounds very complicated. Maybe I just need to update the record using LINQ. Wow?
The BPM is on the Ubaq. It’s not a UBAQ like you would normally expect, it’s one where you select Advanced BPM Update only. Then you put the BPM in there. That BPM can do work for you. You can pass in some parameters to get information that you need to help in that BPM. Then you can call BO’s in there.
When you run the UBaq, the results are stored in the adapter, I run them and use the results to feed BO’s on my customizations without displaying the grid. But in your case, when you just want to be able to call both BO’s in one BPM, you can run a query to get the info from the Quote, then run the sales order BO to set the prices on the sales order line. That way you don’t have to run both the Quote and Sales order BO in one BPM, which is what is giving you problems.
Or try what @danbedwards suggests and try to run the DynamicQuery BO in your original BPM.
Create a BAQ. But use the Advanced BPM Directive Configuration option.
In the Updateable BAQ Method Directives - Add a Post-Processing method.
a. In this Post-Processing method add the BO Caller block widget to update the Sales Order Price line.
In my BPM (for Quote Update when the price changes) call the BO to run dynamic query. Which will run the BAQ and automatically run the BPM (BO to update the Sales Order Price).
Starting working on this. First test to create a BAQ. But use the Advanced BPM Directive Configuration option. In the BPM, I selected to message box with a query field from the query results. Made sure the BPM was enabled.
Then I ran the BAQ directly with input parameters to query the OrderDtl table. One row was returned but no message box?