Add Products to an Opportunity via a Modal¶
Goal¶
For this tutorial, you’ll create a modal that allows users to add product line items to a single opportunity. To do this, you’ll use Salesforce’s Opportunity and OpportunityLineItems objects within a custom opportunity detail page.
Example¶
This is an example page. Its data resets each time the page is loaded.
Concepts covered¶
This tutorial uses Skuid features to create an opportunity detail page and a product line items modal. For more information about these features, see the following:
Prerequisite: Create a custom opportunity detail page¶
A custom detail page for the Opportunity object is essential to complete this tutorial. Build a custom detail page and ensure you have the following:
- A model of the Opportunity object with the following:
- Fields
- Description
- Name
- Opportunity ID
- Opportunity Type
- Price Book ID
- This must be included to ensure line items can be added
 
 
 
 
- Conditions
- A condition on Opportunity Id set to the IdPage/URL parameter, which limits the page to a single Opportunity record
 
- A condition on Opportunity Id set to the 
 
 
 
- A Header component with the following properties:
- Model: Opportunity
- Title: {{Name}}
- Subtitle: Opportunity
 
 
- A Form component with the following properties:
- Model: Opportunity
- Default mode: Read with inline-edit
- Show save and cancel buttons: Checked
- Section properties > Show section heading: Unchecked
 
 
- The following fields added to the Form component:
- Description
- Opportunity Type
- Price Book ID
 
 
- If the components look cramped on the page, try editing all of the margins to the same value. We recommend 16px, which is Regular spacing in the Ink design system.
Once you have your opportunity detail page, follow the instructions below to build the Add product modal on that page.
Create product line item models¶
To add products to a single opportunity, you’ll need two models–one to view the opportunity’s products and another to create new line items records attached to the opportunity. This is made possible by the Opportunity Line Items object in Salesforce, which serves as a junction object. This object stores records for the many-to-many relationship between opportunities (on the Opportunity object) and products (on the Product2 object).
Create the Opportunity Line Item List model¶
This model returns the products for a single opportunity record. This is accomplished by adding fields from Salesforce’s Opportunity Line Items object and defining a condition that refers to the Id field on the existing Opportunity model (which you created when setting up the detail page).
- Click the models Models tab. 
- Click add Add Model. 
- Set your model’s properties: - Model ID: OpportunityLineItemsList
- Data source type: salesforce
- Data source: Current Salesforce Org
- Salesforce object name: OpportunityLineItem
 
- Click on edit-form Fields under your new model. 
- Check the following fields: - Opportunity ID
- Opportunity.Name
 
 
- Opportunity Product Name
- Product ID
- Product2.Name
 
 
- Quantity
- Sales Price
 
- Click on rules Conditions under your new model. 
- Click add Add. 
- Define the condition: - Field: Opportunity ID
- Operator: =
- Value:
- Content: Field from another model
- Source model: Opportunity
- Source field: Id
 
 
 
Create the New Line Item model¶
This model stores the new products that will be added to the opportunity in the Add product modal. This model also contains a condition that limits the opportunity line items to a single opportunity record and an action that queries the opportunity line item list model whenever this model is saved. To save time, we’ll duplicate the model you’ve already created and turn off the query on page load property.
- Click the models Models tab. 
- Click the OpportunityLineItemsList model you created in the first step. 
- Click copy Duplicate. 
- Set the model properties: - Model ID: NewLineItem
- Query on page load: Unchecked
- Max # of records (limit): 1
 
Add components and a modal for product line items¶
Add Table component¶
This table will contain a list of the products associated with the opportunity and will update when users add products to the opportunity.
- Drag and drop a Table component under the Form component. 
- Set your Table component’s properties: - Model: OpportunityLineItemsList
- Default mode: Read with inline-editing
- Show save and cancel buttons: Checked
 
- Click the Styles tab > Spacing. 
- Set all four margins to the same spacing value. (We recommend 16px for all four margins.) 
- Click chevron-small-down Add fields > Model fields. 
- Check the following fields: - Opportunity Product Name
- Quantity
- Sales Price
 
- Click Apply. The Table updates with the selected fields. 
- Click the Opportunity Product Name field in the Table. 
- Set the field properties: - Required: Checked
 
- Repeat the last two steps for the Quantity and Sales Price fields. 
Add button and modal actions¶
To set up a modal that allows users to add products, you first need to add a Button Set component. You’ll configure the button to create a row in the model and show the modal. Additionally, an opportunity must have a value in the Pricebook2Id field to add line items; you’ll set up an enable condition so that the button is only enabled when the Pricebook2Id field has a value.
- Drag and drop a Button Set component above the new Table component. 
- Set the Button Set component’s properties: - Model: NewLineItem
- Position: Left
 
- Click the newly-added Run actions button in the component. 
- Set the button properties: - Button label: Add product
 
- Click the Display logic tab. 
- Click Enable conditions. 
- Set the enable condition’s properties: - Enable if…: ALL conditions are met
- Message to show when disabled: Must specify a pricebook to enable
 
- Click add next to Enable conditions. 
- Set the new condition’s properties: - Source type: Model field value
- Source model: Opportunity
- If no rows in model…: Ignore this condition
- Field: Pricebook2Id
- Operator: !=
- Content: None - blank value
 
- Click the Styles tab > Spacing. 
- Set all four margins to the same spacing value. (We recommend 16px for all four margins.) 
- Click the Actions tab. 
- Click add Add action. 
- Set the following action properties: - Action type: Create new rows
- Model: NewLineItem
- Place row at…: Start of model data
 
- Click add Add action again. 
- Set the following action properties: - Action type: Show modal
 
- Click open next to Configure modal. A popup appears on the canvas. 
- Set the modal properties: - Title: Add product
- Restrict closing the modal: Checked
 
- Click Save. 
Configure the modal¶
The modal is a pop-up that overlays the main page and puts the focus on a specific set of components and data; in this case, we’ll focus on the data needed to add a product to an opportunity. You’ll add a Form component, which allows end users to enter relevant field information. You’ll also add two custom buttons that include actions to save, close, and query your page’s models.
Add a Form component¶
- Drag and drop a Form component into the modal on the canvas. 
- Set the Form component’s properties: - Model: NewLineItem
- Default mode: Edit
- Show save and cancel buttons: Unchecked
 
- Click the Styles tab > Spacing. 
- Set all four margins to the same spacing value. (We recommend 16px for all four margins.) 
- On the canvas, click the section in your Form component. 
- Set the section properties: - Show section heading: Unchecked
 
- Click chevron-small-down Add fields > Model fields. 
- Check the following fields: - Product ID
- Quantity
- Sales Price
 
- Click Apply. The Form updates with the selected fields. 
Add a button to save¶
This custom save button includes actions that save the product information in the NewLineItems model, queries the OpportunityLineItemsList model, closes the modal, and empties all of the rows from the NewLineItems model. The last action ensures that the modal doesn’t retain any previous entries when re-opened.
- In the modal, click add Add button to footer. 
- Click the newly added Run actions. 
- Set the button properties: - Button label: Save
 
- In the button properties pane, click Actions. 
- Click add Add action. 
- Set the action properties: - Action type: Save model changes
- Models to save: NewLineItem
 
- Click add Add action again. 
- Set the action properties: - Action type: Query models
- Models to query: OpportunityLineItemsList
- Query behavior: Get more – Merge in new rows with old
 
- Click add Add action again. 
- Set the action properties: - Action type: Close modals
- Behavior: Close all
 
- Click add Add action again. 
- Set the action properties: - Action type: Remove all rows from model
- Models to empty: NewLineItem
 
Add a button to cancel¶
This button cancels all edits to the NewLineItems model through the Cancel model changes action. The Cancel model changes action cancels all changes in the model, including the newly created row that hasn’t been saved yet. For more about actions, see the Model Data Changes Actions topic.
- In the modal, click add Add button to footer. 
- Click the newly added Run actions. 
- Set the button properties: - Button label: Cancel
 
- In the button properties pane, click Actions. 
- Click add Add action. 
- Set the action properties: - Action type: Cancel model changes
- Model: NewLineItem
 
- Click add Add action again. 
- Set the action properties: - Action type: Close modals
- Behavior: Close all
 
- Click Save. 
Preview the page for a single record¶
Choose the Opportunity record you want to preview¶
- Click Preview.
- Select an opportunity from the list. The selected opportunity’s Id field will be used to populate the condition we created that limits your page to a single opportunity.
- Click Go.
- Click Add product to test out the new modal.
Deploy the page¶
After you’ve previewed your page and ensured it’s working properly, it’s time to deploy it to your end users. See our deployment docs for more information or check out our other page tutorials.