To build the mapping application, we first need to create the custom controller referenced by the Visualforce page that displays the map and corresponding list of accounts. The controller retrieves the user's accounts with a rating of 'Hot' and builds a string array of delimited accounts for use in the mapping JavaScript routine on the Visualforce page. It also defines a getter method for the Maps API key, which is required in order to use Google Maps in our page.
The following Apex class is the controller for the Visualforce page that maps the user's hot accounts:
public class mapController { public String addrStr; public User usr; public String myKey; public Account[] getMyAccts() { String usrId = UserInfo.getUserId(); Account[] accts = [Select Id, Name, Rating, CustomerPriority__c, OwnerId, BillingStreet, BillingCity, BillingState, BillingPostalCode From Account where Rating = 'Hot' And OwnerId =: usrId ]; for(Account acct : accts) { addrStr = addrStr + acct.Name + ' : ' + acct.CustomerPriority__c + ':' + acct.Id + '~:~'+ acct.BillingStreet + '~:~' + acct.BillingCity + '~:~' + acct.BillingState + '~:~' + acct.BillingPostalCode + '~::~'; } return accts; } public String getmyKey() { // Set up google maps api key myKey = 'http://maps.google.com/maps?file=api&v=2&'; // In the following line, enter your google maps key // to get an api key, visit the Google Maps API site // http://code.google.com/apis/maps/signup.html myKey = myKey + 'key=<insert_google_maps_api_key_here>'; return myKey; } public String getAddrArStr(){ addrStr = ''; Account[] theRecs = getMyAccts(); return addrStr; } }