I have a BPM that I thought was working, but appears to be causing some glitches.
The intent is if there are certain parameters in the Part Master met, that when the line in a sales order is created, it would automatically check “Make Direct” as override since it’s not the default.
I have an In-Trans Data Directive on the OrderRel table that checks if a release was added and that the parameters are met and marks the box appropriately.
However, for those releases, the Planning Workbench is suggesting a new job for double the line quantity. If you uncheck “Make”, save, then recheck it, the suggestions fix themselves. If I disable the BPM, the suggestions are fine.
I tried using the business objects (ChangeMake and MasterUpdate based on trace) in a post method directive, but got quite a few errors since the release is created at a weird time.
Yea, if you are going to do this in the back door, there is one other table that needs updated as well… you need to also update the StockTrans field in the PartDTL table, which is the data that everything REALLY uses. Here is a snipit of code that does it.
Would it totally botch things if I just set the proper suggested quantity in the PartSug table?
*Edit: Tried just forcing the PartSug value. Doesn’t want to change.
*Edit Edit: Flipped the updates to a Standard Trans and it appears to be working. I will need to do some more testing to make sure that forcing the PartSug.SugQty doesn’t negatively affect something else down the line.
@hmwillett I am running into a similar scenario. Did you end up updating both PartSug and PartDtl tables in the standard data directive? Would it be possible to share your code if you still have it? Thanks!
@Randy@hmwillett Really appreciate your help! I have gotten to this point of setting the Make Direct flag in OrderRel from In-transaction Data Directive. The issue I was running into was - checking the Make Direct flag alone doesn’t seem to trigger the other table updates that SalesOrder.ChangeMake method does. Because of this, MRP doesn’t process the Order as Make Direct (even when the flag is checked). So, I was wondering if you were taking additional steps to make sure that the other tables were updated as well. If not, maybe I’ll just call the ChangeMake method. Thanks!
Ah, the BPM wasn’t named anything with “Make” so got confused. Here are the In-Trans and Standard ones. You may be able to skip the code in the In-Trans one but this is how it is in our LIVE so I’m posting it as is.
Hi Randy - I am trying to following your BPM and it is not working. One question I have is the below statement is Override_C a UD field that you have on the OrderRel table?
//bool overrideMake = Convert.ToBoolean(tt[“Override_c”]);
Thanks - I assumed it was but figured I would ask as you know what they say about assuming
I am fairly new to BPM’s and the ones I have done have not used any custom code so this is a first.
I did get this to work…I ended up only using the In-Transaction directive. I used the Condition 0 from the Standard Directive in this post, then we always want the "Make Direct’ set on our Order Release Lines so I used a “Set Field” and then an “Execute Custom Code” using the code from the Standard Directive in this post. Still need to have our users test but the testing I did it works great.
I truly appreciate those who shared the code for this as I would not know how to write this code…I am really good at copying others and tweaking if needed
Thank you all for your generosity with sharing this solution. I, too, am trying to make use of this. Do I understand correctly that this BPM was only running after you identified the OrderRel as one that has the “Override” enabled? When I looked through the conditions and code, it doesn’t look like it ever references anything that checks if Make Direct should/shouldn’t be true.
Dan - Not sure if you got your answer. In my scenario, all our Sales Order Releases were to be set as “Make Direct” so I didn’t have a check. I apologize for not seeing this sooner…was out here looking for something today and ran across it.
Debbie