The Situation
Users needed to see how many accepted Purchase Orders were associated to a Job on the Job page layout. There is a many-to-many relationship between Jobs and Purchase Orders, with Job PO Assignment as a junction object
data:image/s3,"s3://crabby-images/86610/86610fd41e9a349f27afaaf247e69adb6722027c" alt=""
The Solution
I knew that I would need to use the Job PO Assignment to create a Rollup Summary to the Job object. I already had a PO Status field on Job PO Assignment, but Rollup Summaries cannot be based on a formula field…so I did the following:
- Create a text field on junction object
- Populate text field with Process Builder
- Create a Rollup Summary field based on the text
Why not use Declarative Lookup Rollup Summary?
DLRS is triggered on insert or update, and the PO_Status__c field on this object is a formula, which will not be an edit when the text changes ☹
Step 1: Create a text field on junction object
data:image/s3,"s3://crabby-images/63fcb/63fcb07300a54315b54c64f9e0df27ddc0a47df6" alt=""
Step 2: Populate text field with Process Builder
For this requirement, I already had a PB on the Purchase Order object that was based entirely on changes to the PO Status field. I added an action at each criteria node that updated any Job PO Assignments related to the Purchase Order.
data:image/s3,"s3://crabby-images/67403/67403ef96b995a201fd9aeba2e48ef239b969b59" alt=""
Step 3: Create a Rollup Summary field based on the text:
I only want to count Job PO Assignments where the PO Status Text field = “Accepted”, so the field is named Accepted POs.
data:image/s3,"s3://crabby-images/410a0/410a04f730edcd125889a1cb4c22efdd40c7afa3" alt=""
End Result:
Although a Job may have a Purchase Order Assigned, users know that there must be an Accepted PO before proceeding with work.
data:image/s3,"s3://crabby-images/2a79e/2a79eecbcf893ecddb86262d85d5887262ae134a" alt=""