This is the second “Tip and Trick” from my “Dreamforce 2 You” presentation. This tip came out of two questions and comments that I have heard a lot.
- How can I see my Accounts without Opportunities?
- There are too many fields to select for reports and I don’t want my users seeing all the fields
Both of these items can be fixed by creating a Custom Report Type. Let’s start from the beginning; To create a custom report type you will need to go to Setup>Create>Report Types and then follow the wizard.
- To see Accounts without Opportunities you will need to use Accounts as the Primary Object and Opportunities as the “B” Object. On the “B” object, make sure you select the second option – “A” records may or may not have related “B” records. This will allow you to see all accounts regardless if they have an opportunity or not. Something else I like to do with a parent-child outer join (what you just created) is add a Roll-up Summary field to count the number of child records, then use that field as criteria for your report, i.e.: Show me all Accounts where “Count of Opportunities = 0.”
- To solve the problem of too many fields, follow the steps above. Instead of using the outer join, recreate the standard report. Use Opportunities and click “Save”. This will take you to the next screen where you will see the section named, “Fields Available for Reports”. Click on the “Edit” button and now you can start taking fields away.
Make sure your users have access to the new report type and now the user experience is much better! No need to feel overwhelmed or worried with your users creating a report, you are in control of what they see and have access to! Training is much easier, and you get to keep your secrets!
A couple of weeks ago I was lucky to attend and present at the, “Dreamforce 2 You” Event that was put on by the Orlando and Tampa User Groups. This was the second year of the event and it doubled in every way (tripled in some ways too – from 2 sessions to 6)! There will be more postings to come out of this event, but I wanted to start with some helpful information from my presentation about Reporting.
In my presentation I shared two tips that I always rely on. I will focus on the first one today – using custom formula fields for reports/dashboards. Before you were able to add columns to a table on a dashboard (or now, overcoming the limitations), we needed another way of displaying more information while keeping a dashboard easy to read. Instead of just seeing the Opportunity Name with the Amount field, let’s use a custom formula field to concatenate some other valuable information.
For this example, I was presented with a business case that the VP of a division wanted to see what new opportunities entered the funnel this week. This person wanted to see the 2 amount fields, the account, the owner, and the opportunity name (what the project is). 5 fields to display on a table. I knew I could formula field some of them together and now only display 3 fields. Here is the formula I used to combine three fields into one for a more detailed view – Account Name, Opportunity Name and Opportunity Owner.
Account.Name &" - "& Name &" - "& CreatedBy.FirstName &" "& CreatedBy.LastName
Simple right? Now you can have a dashboard that looks like:
Stop causing yourself a headache with reporting and stop thinking that a formula field is only for calculations. Using a formula field for reporting purposes can solve many problems and make your dashboards more detailed while still being easy to understand.
Finally, a brief, “Thank You!” to @CRMJen, @jhoskins and @jackieforce for all their hard work for putting this event on. I would also like to thank Ingo Fochler from The New York Times Company for teaming up with me for this presentation. I will blog more about this event and my second tip shortly.
*Disclaimer – This was just one example of using a formula field for reporting/dashboard purposes. The field does not have to be on the page layout to work, but make sure you set up the field with the proper field-level security so that it is visible to your users.
First off, let me say what I have told many people already, Watch the DEV401 podcasts on iTunes. They are extremely valuable and a great and simple introduction to Visualforce (at least for non-programmers).
I was meeting with a client the other day and a request was made to have a place where support users can go to see cases in the support queue. Simple right? Click on the Cases tab, change the view to “Support Queue”, click Go. The client understood but wasn’t completely happy – too many clicks.
Light bulb goes off in my head and I say to myself, “I think I can do this using Visualforce!” Except it wasn’t in my head, it was aloud and now the project started.
I gathered my courage and began working. I created the page and opened the page editor. I thought about what I was doing and stared at the “Congratulations” for a couple of minutes. Then I got started.
I updated the page to use the “Case” standard controller. Small Victory! Now I needed to show the queue. At this point I was feeling stressed – how do I write code? How can I display “Show me all cases in the Support Queue”? I knew I could create a view. I then thought, could it be that easy?
The next thing I added was the enhancedList tag. From there I added the required attributes and populated the listid with the view id. Apple-S and done. Now that the page was done, I created a Visualforce tab. Now all the user will have to do is click on the “Support Queue” tab to see all the cases. The client thought is was great and I was relieved.
Here is the point – with the little knowledge that I knew about Visualforce and the helpfulness of the page editor and the Component Reference, I created a Visualforce page. 3 lines of code and I had a solution. I am excited to continue developing more – I play around with a test page and see what the page editor gives me as I type and add spaces and save.
My advice – If I can do it, anyone can do it. Try and you will be impressed as to how far you can go. If you don’t believe me, check out my 3 line solution!
<apex:page standardController="Case" showHeader="true" >
<apex:enhancedList id="View_Name" listId="View_ID" type="Case" height="650"/>
</apex:page>
You heard it here first – ok, so not first… not even close to first.
JavaScript:
Before I started on this journey my logic would have told me that JavaScript and Java are either: the same language, based off the same language, or an evolution of the same language. And how wrong I would have been! JavaScript is the code that you can use to turn a website from a static page to a dynamic and interactive one. It runs on the browser side and not the server side.
So why is JavaScript called JavaScript if it has nothing to do with Java? Check out what Wikipedia has to say…
Forms:
This is exactly what it sounds like. You have the ability to create a form on a web page. You name the type of data, the format of the data and what to do with the data. You can use JavaScript to interact with the user. For example: Check for form completeness before submitting. Seems straightforward right? It is for the most part, although it does lead me to some questions relating to Salesforce.com.
Looking at a landing page on my company site, I noticed (and knew before) that the oid, campaignid (if you have campaigns), lead source, are all hidden. I also noticed that there is no Salesforce code for each field, like first name. Here are my questions:
- When a user hits submit, how does it get to Salesforce?
- Am I missing code when I look at the page?
- If a field( eg. firstname) doesn’t have a Salesforce ID, how does it match?
- Last question: JavaScript can validate a form, such as if all fields are filled in, can it also dictate the format of the data or would you use XHTML?
I will be looking these up and posting the answers once I find them.
HTML, XHTML & CSS for Dummies is finished. Great information and I am surprised how much more I understand web design and coding. I understand the source code to web pages I look at.
I would recommend reading this book if you are starting off, it was easy to understand and a quick read. It does not go into depth by any means, but gives the reader the background to be able to go out on their own to find the resources they need. It lays the ground work for what is to come. I feel like this is a great start…