Warehouse App
Create a Warehouse App (with three objects Merchandise, Invoice and Line Item) that can help
in managing merchandise records in a warehouse.
Define Warehouse App
1. Launch your browser and go to https://login.salesforce.com.
2. Enter your username (in the form of an email address) and password.
3. From Setup, enter Apps in the Quick Find box, and then select Apps.
4. If you see an introductory splash page, simply click Continue.
5. Click New. The New Custom App wizard appears
6. If you are a new user, select Custom app.
7. In the App Label field, enter Warehouse
8. Click your mouse inside the App Name field. (App Name should automatically appear and it is
same as App Label)
10. In the Description field, enter Manage Merchandise, Invoice and Line Items
11. Click Next
(The next screen in the New Custom App wizard allows you to specify the image file to use for
this app's logo. Whenever the app is selected in the app menu, this logo appears in the upper-
left corner of all pages. Since we're just creating a simple app, let's accept the default logo that's
already provided. We can always change it later.)
12. Click Next
(Again, since we're just creating a simple app, let's accept the defaults and move on. We'll add
more tabs later)
13. Click Next
14. Select the Visible checkbox next to the Standard User and System Administrator profiles.
15. Click Save
You’re App is Ready now!
Warehouse App Data Model
Define Merchandise Custom Object
1. From Setup, enter Objects in the Quick Find box, and then select Objects.
2. On the Custom Objects page, click New Custom Object.
3. In the Label field, enter Merchandise.
4. In the Plural Label field, enter Merchandise
5. The Object Name field is defaulted to Merchandise. Let's leave it as is
6. In the Description field, enter This object stores information about the its which you want to
sell.
7. For the Context-Sensitive Help Setting, accept the default.
The Record Name is the label for the field that identifies individual position records in the
system. Salesforce automatically populates Record Name with the custom object label followed
by Name. In this case, the field is populated with Merchandise Name. Do not change this Field
Name
8. In the Data Type drop-down list, select Text.
9. Select Allow Reports, Allow Activities, Allow Search, and Track Field History
10. In the Deployment Status area, select Deployed.
11. In the Object Creation Options area, select the Add Notes & Attachments related list to
default page layout and Launch New Custom Tab Wizard after saving this custom object
checkboxes.
Define Custom Object Tab for Merchandise Object
However, in case you forgot to select the Launch New Custom Tab Wizard after saving this
custom object, there's another way to launch the Object Tab Creation wizard.
1. From Setup, enter Tabs in the Quick Find box, and then select Tabs.
2. In the Custom Object tabs area, click New.
Now that we're all on the same page, let's get started working through the wizard.
3. In the Object drop-down list, select Position.
(If you launched the wizard directly after defining the custom object, the Merchandise object is
automatically selected for you.)
4. Click the Tab Style icon to launch the Tab Style Selector as shown in the following screenshot.
5. Click the Hide values which are used on other tabs link to make sure you choose a unique style
6. Click any colored box to choose a color scheme and icon
Leave the Splash Page Custom Link drop-down list set to --None—
7. In the Description field, enter A tab and color scheme for the Merchandise custom object.
8. Click Next
9. Click Next again to accept the default user profile visibility.
10. Deselect all of the Include Tab checkboxes except the one for our Warehouse app.
11. Select the Append tab to users' existing personal customizations checkbox.
12. Click Save.
Define Custom Fields to Merchandise Object
In this Lab exercise you add two new custom fields (Price and Inventory) to supplement the
standard fields the object already has (Name, Owner, CreatedBy, and LastModifiedBy).
Add the Price Field to the Merchandise Object
A merchandise object should have fields that are used for tracking various information, such as
how much individual unit costs and how many units are in stock. You can add more custom fields
to list and track just about anything you can think of.
1. From Setup, enter Objects in the Quick Find box, and then select Objects.
2. Click Merchandise, scroll down to Custom Fields and Relationships, and click New.
3. The New Custom Field Wizard helps you quickly specify everything about a new field, including
its name, labels to use for app pages, help information, and visibility and security settings. Create
the Price field as follows:
    a. For Data Type, select Currency, and click Next.
    b. Fill in the custom field details:
       • Field Label: Price
       • Length: 16
      • Decimal Places: 2
      • Select the Required checkbox
    c. Leave the defaults for the remaining fields, and click Next.
    d. Click Next again to accept the default field visibility and security settings.
    e. Click Save & New to save the Price field and to return to the first step of the wizard.
Add the Quantity Field to the Merchandise Object
You should already be in the New Custom Field wizard, so you can create the Quantity field in
the same manner.
1. For Data Type, select Number and click Next.
2. Fill in the field details:
    • Field Label: Quantity
    • Select Required
3. Leave the defaults for the remaining fields, and click Next and Next again.
4. Click Save.
Take a look at this image to familiarize yourself with the Merchandise custom object.
1. Merchandise detail page— shows you everything you need to know about your Merchandise
custom object. Soon you’ll add relationships, validation rules, and other neat features to this
object.
2. API name—when you created the Merchandise object, you didn’t specify an API name, but
one was generated for you. This name is how the object is referenced programmatically. All
custom objects end in __c, which differentiates them from standard objects.
3. Standard fields—some fields are generated automatically; these are standard fields. For
example, the Merchandise object has a standard field for Owner, which means it automatically
tracks who created each record.
4. Custom fields—includes the fields you just created in this step. Like custom objects, custom
fields have API names that end in __c.
You can create more fields to track, such as currency, email, geolocation, URLs, date/time, and
so on. Fields don't just contain static values, they can be derived from formulas, or take their
values from other objects as well. You can create all these advance fields as per your need and
design of the application
Define Invoice Custom Object
To make the Warehouse app more realistic, you need invoices to track orders going in and out of
the warehouse. In this step, you create an invoice object that allows you to create multiple
invoice statements, each with a unique number, status, and description
1. From Setup, enter Objects in the Quick Find box, then select Objects.
2. Click New Custom Object.
3. Fill in the custom object definition.
    • In the Label field, type Invoice.
    • In the Plural Label field, type Invoices.
    • Select Starts with vowel sound.
    • In the Record Name field, type Invoice Number (replace Name with Number).
    • For Data Type, select Auto Number.
    • In the Display Format field, type INV–{0000}. (Note there are no spaces.)
    • In the Starting Number field, type 0.
4. In the Optional Features section, select Allow Reports (in case you create reports later).
5. Select Launch New Custom Tab Wizard after saving this custom object.
6. Click Save.
Notes:
   • The checkbox for vowel sounds ensures that the correct article is used: “a” or “an.”
   • The Auto Number data type tells the platform to automatically assign a number to each
      new record that is created, beginning with the starting number you specify. Because of the
      display format you chose, the invoice numbers will be INV-0000, INV-0001, and so on.
   • You could have started invoices at any number, but we started invoices at INV-0000 to
     remind you that the platform is zero-based.
Define Custom Object Tab for Invoice Object
When you click the Merchandise tab, a list of Merchandise records appears. Similarly, you need
to create a tab that displays Invoices
1. If you don’t see Launch New Custom Tab Wizard, from Setup, enter Tabs in the Quick Find
box, select Tabs, and then click New in the Custom Object Tabs section. Then select your Invoice
object.
2. In the Tab Style lookup, choose Form and click Next and then Next again.
3. It makes sense to display this new tab for the Warehouse app. On the Add to Custom Apps
page, clear the checkbox next to all apps except Warehouse.
4. Click Save.
Reorder Tabs in the App
Take a look at the tabs across the top of your screen and you see the new Merchandise tab isn’t
next to the Invoice tab. You can put tabs in any order you like, so go ahead and put them next to
each other.
1. From Setup, enter Apps in the Quick Find box, select Apps, and then click Edit next to your
Warehouse app.
2. In the Selected Tabs list, select Invoices and use the up arrow to move it under Merchandise.
3. Click Save and then take a look at the tabs
Define Custom Fields to Invoice Object
Add a Status Field to the Invoice Object
In this step, you extend the Invoice object to add a new Status picklist field to track the status of
each invoice.
1. In Setup, enter Objects in the Quick Find box, then select Objects and then click Invoice.
2. Scroll down to the Custom Fields & Relationships related list and click New.
3. For Data Type, select Picklist and click Next.
4. Fill in the custom field details.
    a. Field Label: Status
    b. Type the following Picklist values in the box provided, with each entry on its own line.
        Open
        Closed
        Negotiating
        Pending
    c. Select Use first value as default value.
    d. In the Help Text field, type Choose a value from the drop-down list.
5. Leave the defaults for the remaining fields and click Next, Next, and Save
Define Line Item Custom Object
In this Lab exercise, you create a Line Item object, and what’s special about this new object is
that its fields are related to both the Invoice and Merchandise objects.
Invoice to Line Item is Master Detail Relationship &
Merchandise to Line Item is Lookup Relationship
1. From Setup, enter Objects in the Quick Find box, then select Objects.
2. Click New Custom Object and fill in the custom object definition.
    • Label: Line Item
    • Plural Label: Line Items
    • Record Name: Line Item Number
    • Data Type: Text
3. Select Allow Reports, Allow Activities, Allow Search, and Track Field History
4. In the Deployment Status area, select Deployed.
5. In the Object Creation Options area, select the Add Notes & Attachments related list to default
page layout
6. Do not select Launch New Custom Tab Wizard
7. Click on Save
Note: Line Item Number is a text field though we will be using to enter number in this field. We
do not want this field to be auto number.
Define Custom Object Tab for Line Item Object
No Tab will be defined for this object
Define Custom Fields to Line Item Object
Every line item needs to track the quantity ordered. So the next thing you need to do is add a
Quantity field.
Add a Quantity Field
1. On the Line Item detail page, scroll down to Custom Fields and Relationships and click New.
2. For Data Type, select Number and click Next.
3. Fill in the field details:
    • Field Label: Quantity
    • Select Required
4. Leave the defaults for the remaining fields, and click Next, Next, and then Save.
Relate Line Items to Invoice ( Master Detail Relationship )
Now that you have all the objects representing the data model, you need to relate them to each
other. Line items are related to both an invoice (an invoice is composed of a number of line
items) and merchandise (a line item takes its price from the merchandise).
1. On the detail page of the Line Item object, scroll down to the Custom Fields & Relationships
related list and click New.
2. For Data Type, select Master-Detail Relationship and click Next.
3. In the Related To field, select your Invoice custom object, and click Next.
4. For Field Label and Field Name enter Invoice.
5. Accept the defaults on the next three screens by clicking Next.
6. On the final screen click Save & New.
Relate Line Items to Merchandise ( Lookup Relationship )
1. For Data Type, select Lookup Relationship and click Next.
2. In the Related To field, select Merchandise and click Next.
3. For Field Label and Field Name enter Merchandise.
4. Child Relationship Name – Keep the default value do not change it
5. Required – Do not check this
6. What to do if Lookup Record is deleted? – Select Clear the value of this field option
7. Accept the defaults on the subsequent screens by clicking Next, and Next again.
8. On the final screen, deselect the checkboxes for Merchandise Layout and Append related list
to users’ existing personal customizations (you don’t want a list of line items on the Merchandise
page).
7. Click Save.
Working with Page Layout
Edit Invoice Detail Page Layout to look like below screenshot. Also make sure Line Item related
list has Line Item Number, Merchandise and Quantity fields visible.
Step 1: Open the Page Layout Editor
Use one of the following ways to open the page layout editor.
      • While on the record page that you want to modify:
              – Click Edit Layout.
              – Click the Quick Access menu on the right, and choose Edit Layout.
      • From Setup, enter Objects in the Quick Find box, then select Objects, click the object
      you want to change the layout of, scroll down to the Page Layouts section, and then click
      Edit next to the layout you want edit.
Step 2: You can make many changes to the page layout.
1. Hover over a section title. The mouse pointer changes, indicating that you can drag the section
to a new location relative to other sections.
2. Hover over the upper-right corner of any section. Two buttons appear: one for removing the
section (don't click it!) and another for editing its properties. Go ahead and click . You can now
edit the name of the section (only for non-default sections), when to display the section header,
the section layout (one or two columns), and the tab-key order among section fields. Click
Cancel.
Step 3: Rearrange Fields on a Page Layout
In this step, make some simple changes to the Invoice Detail area of the page layout.
1. Click for the Information section (see above if you forgot how to find this) and change the
section layout to one column. Click OK.
2. Drag the Owner field above the Status field. When you’re done, the modified Invoice Detail
area should look like this.
Step 4: Add Fields to the Related List
As it is now, the related list of Line Items is not very informative—it only has the line item
numbers. In this step, improve the related list by adding some new fields.
1. Click Related List Properties (the wrench icon above the Line Items section), add Merchandise
and Quantity to the Selected Fields list, then click OK. When you return to the page layout editor,
the related list preview should now appear similar to this:
2. That's it—you're done modifying the page layout. At the top of the page, in the toolbox, click
Save.
Enable Social Collaboration
Users can follow merchandise records and collaborate on them using Chatter. When you are
following a record, the platform automatically pushes notifications about updates to you. The
feed for the record becomes a running log where users can collaborate on the data record by
posting comments, files, links, and more.
If you look at the default Invoice page layout in the Warehouse app, social collaboration isn't
available. Why not? When you created the Warehouse app, the app wizard automatically
enabled feed tracking on the original object—in this case, Merchandise. However, for new
custom objects, the platform doesn’t enable feed tracking by default. But it's easy to enable this
functionality yourself in just a minute or two.
Step 1: Enable Collaboration on Invoices
To enabled feed tracking:
1. From Setup, enter feed in the Quick Find box.
2. Click Feed Tracking.
3. Notice two fields are being tracked for Merchandise. Take a look at your Invoice object, and
notice no fields are being tracked.
4. To enable feed tracking for Invoice, click Invoice, select Enable Feed Tracking, select Status,
and click Save.
Step 3: Verify Collaboration for Invoice
Now that you've finished modifying the Invoice page layout, have a look around.
1. Click the Invoices tab, click into the detail page for an Invoice, and notice that the Chatter feed
for an Invoice is now available.
2. You can collaborate on this invoice by clicking Follow. Now if you update an invoice (to change
it from Closed to Open for example), anything that happens to the invoice status will
automatically appear in your Chatter feed, and the feed of anyone else who follows this invoice.
Automation using click and not code in Warehouse App
In Salesforce, you can use workflow rules to automate your procedures and processes. Workflow
rules can trigger actions (such as email alerts, tasks, field updates, and outbound messages)
based on time triggers, criteria, and formulas.
Case 1: Populate Unit Price field on Line Item object record automatically as soon as new Line Item
record is created
Open any invoice record, and then open the detail page for a line item by clicking over its record.
Notice there’s no price field for the line item. For this exercise, you need to create new field
called Unit Price on Line Item object and since price of each product is already stored in the
Merchandise object, we can now populate Unit Price field on Line Item object automatically
using workflow as soon as new Line Item record is created and users can then adjust the price of
merchandise in each line item (for example, to offer discounts).
Step 1: Create a Unit Price Field
The steps for creating the new Unit Price field are essentially the same as when you created the
Price field on the Merchandise object except this time name the field Unit Price.
1. From the Line Item tab or record, click the Quick Access menu (the tab that pops out from the
right side of the window), hover over View Fields and click New. (If you aren't on the Line Item
object already, in Setup, enter Objects in the Quick Find box, then select Objects. Then click Line
Item, and in the Custom Fields and Relationships section, click New.)
2. For the data type, select Currency and then click Next.
3. Fill in the custom field details as follows.
          • Field Label: Unit Price
          • Length: 16
          • Decimal Places: 2
4. Leave the defaults for the remaining fields by clicking Next on subsequent screens until you
can Save.
5. Now go back to an existing Invoice and add a new Line Item. Notice there's a new field for Unit
Price, but you have to populate that field manually. You want this field to populate
automatically, so click Cancel, and add this new functionality.
Step 2: Automatically Populate the Unit Price Field
To automatically populate the new Unit Price field, create a workflow rule.
1. From Setup, enter Workflow Rules in the Quick Find box, then select Workflow Rules.
2. Optionally, read the brief introduction, click Continue, and then click New Rule.
3. Select the Line Item object, and click Next.
4. For the rule name, enter Populate Unit Price, and for the description enter something like
Populates the Line Item object’s Unit Price field with the value of the Merchandise object’s Price
field.
5. For evaluation criteria, select created.
6. In the first rule criteria row, for the field select Line Item: Quantity, for the operator select
greater or equal, and for the value enter 1.
7. Click Save & Next.
Note: It makes sense to fire this workflow rule only for new line item records because you are
effectively assigning a default field value when creating a new record. Later on, users might need
to adjust the price of merchandise in each line item (for example, to offer discounts).
Continuing on, the next step is to assign an action to the workflow rule to update the Unit Price
field automatically.
1. Click the drop-down list that reads Add Workflow Action and choose New Field Update.
2. In the Name field, enter Copy Unit Price.
3. In the Field to Update list, choose Line Item and then Unit Price.
4. Select the option to use a formula to set the new value. Before continuing, confirm that your
screen matches the following.
5. Click Show Formula Editor and then click Insert Field.
6. In the first column choose Line Item >, in the second column choose Merchandise >, and in
the third column choose Price.
7. Confirm that your screen matches the following, and then click Insert.
8. Click Save, and then click Done to return to the detail page of the new workflow rule.
Case 2: Update Total Inventory When an Order is Placed
The inventory (quantity) of merchandise item should be automatically maintained as orders are
placed. When you create a new invoice ("Open" status), every new line item added to invoice
needs to decrease the total inventory (quantity of merchandise items) by the number of units
sold. Similarly, updates to an existing line item needs to update the total inventory by the
difference in units sold.
Note: Workflow field update won’t work with a lookup relationship so we need to convert
Merchandise and In