In E9 MRP would raise Jobs when Parts within the JobMtl table were OnHold - eg Part.OnHold = True.
This allowed for scheduling and capacity planning of Jobs that were still to be worked on in some fashion.
In E10 MRP bombs out at the GetDetails stage and only creates an UnFirm Job with no method of manufacture.
To workaround this I have;
Removed all Part.OnHold
Created a UD field to mirror the Part.OnHold
Created a BPM that checks if any JobMtl has the Part.UD_OnHold checkbox checked.
This is working fine but what I would like to add to this is an output within the Message Box of all the Parts that are UD_OnHold.
Does anyone know how I can achieve this.?
Roberto
When the Job is Released we pop up a message box stating that there is at least one JobMtl with Part.UD_OnHold True - how can I capture the list of Parts and display list within this message box?
if i were you i will build a BAQ to show me the full list, however you can create a BPM to show all parts in a show message triggered at any Job Entry released method, but this could be confusing as your UI is dealing with one Job Row at the time of the BPM execution, unless you mean all Parts in JobMtl which related to the PartNum on JobHead, then please screen shot some of your development/code and its output here so we can look at it.
ERP.Part criteria
CheckBox02 = true
Or
OnHoldReason_c <> “”
This BPM works but when it returns an exception I would like to publish to the planner the list of Parts that are in the exception state rather than the current generic message.
Hi @rppmorris
i do not know if you are familiar with C# custom code or not, so to answer your question yes you can list your material part numbers which match your criteria, but you need to code this, i have created many BPM’s on JobEntry BO to do similar things, i have modified one of them to suit your use, just paste it in a custom code widget and replace it with your exception widget only, then save and see if it is compile, if yes please test it and let me know,
There is at least one compilation error.
Update.Pre.Validate_-JobMt.cs(200,78): error CS1056: Unexpected character ‘“’
Update.Pre.Validate-JobMt.cs(200,93): error CS1056: Unexpected character ‘”’
Update.Pre.Validate-_JobMt.cs(200,79): error CS0103: The name ‘OnHoldReason_c’ does not exist in the current context
check your logic on the conditions on this code line, be sure
if (Part != null && (Part.CheckBox02==true || (Convert.ToString(Part[“OnHoldReason_c”])) != null))
and to help on that you can show both values within the loop to check your list one by one:
var ttJobHead_xRow = (from ttJobHead_Row in ttJobHead
where ttJobHead_Row.Company == Session.CompanyID
&& (ttJobHead_Row.Updated()
|| ttJobHead_Row.Added())
select ttJobHead_Row).FirstOrDefault();
if (ttJobHead_xRow != null)
{
JobOper = (from JobOper_Row in Db.JobOper
where JobOper_Row.Company == ttJobHead_xRow.Company
&& JobOper_Row.JobNum == ttJobHead_xRow.JobNum
select JobOper_Row).FirstOrDefault();
if (JobOper != null)
{
foreach (var JobMtl_iterator in (from JobMtl_Row in Db.JobMtl
where JobMtl_Row.Company == ttJobHead_xRow.Company
&& JobMtl_Row.JobNum == ttJobHead_xRow.JobNum
&& JobMtl_Row.AssemblySeq == JobOper.AssemblySeq
select JobMtl_Row).ToList())
if (JobMtl_iterator != null)
{
Part = (from Part_Row in Db.Part
where Part_Row.Company == ttJobHead_xRow.Company
&& Part_Row.PartNum == JobMtl_iterator.PartNum