Pages

Saturday, 20 December 2014

How to Disable Reset My Security Token Option in Salesforce



Step 1 : My Settings -> Personal


Here you can see Reset My Security Token option

Step 2 :  Setup -> Manage Users -> Profiles -> Login Ip Ranges


Step 3 : Enter the Start IP, End IP Address and save it

Then Check it whether the Reset Security option is disable or not.


Thanks,
Amit Chaudhary 

Tuesday, 9 December 2014

How to Update custom setting without granting them Customize Application access


Requirement :-
Recently I was working on one requirement where i need to provide the user to update custom setting data without providing the customize application access because customize application is also depend on manager translation,view setup and configuration. But on that profile we dnt want to provide View Setup.
Then i decided to write a visual force page. But when we bind the custom setting with <apex:inputField> field was also coming in read only mode. For that I come up with below solution.

Solution :-
If we will bind custom setting directly with <apex:inputField without customize application access then field will come in read only mode. For that we need to mapped our custom setting data in Wrapper class or variable.

Page :-


<apex:page controller="CustomSettingController">
<apex:form >
<apex:pageBlock mode="edit" id="PB" title="Custom Settings">
<apex:pageMessages />

<apex:pageBlockButtons location="Top">
    <apex:commandButton action="{!Edit}" value="Edit" rendered="{!Not(isEdit)}" reRender="PB"/>
    <apex:commandButton action="{!Save}" value="Save" rendered="{!isEdit}" reRender="PB"/>
    <apex:commandButton action="{!Cancel}" value="Cancel" rendered="{!isEdit}" reRender="PB"/>
</apex:pageBlockButtons>

<apex:pageBlockSection rendered="{!Not(isEdit)}" id="PB1" >
 <apex:outputField value="{!custSetting.Number_Of_Days__c}"/>         
 <apex:outputField value="{!custSetting.User_name__c}"/>            
</apex:pageBlockSection>

<apex:pageBlockSection rendered="{!isEdit}" id="PB2" title="Update Commerce Settings Data">
   <apex:pageBlockSectionItem >
    <apex:outputLabel value="{!$ObjectType.Custome_Settings__c.fields.Number_Of_Days__c.Label}" />            
    <apex:inputText value="{!number_Of_Days}"/>            
 </apex:pageBlockSectionItem> 
 <apex:pageBlockSectionItem >
  <apex:outputLabel value="{!$ObjectType.Custome_Settings__c.fields.User_name__c.Label}" />            
  <apex:inputText value="{!strName}"/>            
</apex:pageBlockSectionItem>

</apex:pageBlockSection>

</apex:pageBlock>
</apex:form>
</apex:page>


Class:-

public with sharing class CustomSettingController {

public Custome_Settings__c custSetting {get;set;}
public Boolean isEdit {get;set;}
public Decimal number_Of_Days{get;set;}
public String strName{get;set;}


    public CustomSettingController()
    {
        custSetting = [select id , Number_Of_Days__c,User_name__c from Custome_Settings__c limit 1];

        number_Of_Days= custSetting.Number_Of_Days__c;
        strName = custSetting.User_name__c ;
    
        isEdit = false;
    }
    
    public void Cancel()
    {
        isEdit = false;
    }

    public void Edit()
    {
        isEdit = true;
    }
    
    public void Save()
    {
       try
       { 
        custSetting.Number_Of_Days__c =number_Of_Days;
        custSetting.User_name__c =strName;

        update custSetting;
        isEdit = false;
        ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.INFO, 'Data Saved Successfuly !!!' ) );
       }Catch(Exception ee){
           ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.ERROR, ee.getMessage()) );
       } 
    }
    

}






Thanks,
Amit Chaudhary

Monday, 8 December 2014

Salesforce Community (Site) Methods


Some time we need to override Salesforce community login page in that case we need to to write custom code to create user , login, forget password etc. For that we can use the below salesforce predefined function :-
  
Login Function :-

If we need to login in salesforce community then we can use below function :-
Site.login(username, password, null);

Create User :- 

We can create two type for user for salesforce community :-
1) Portal user
2) Person Account Portal User

Please use below code to create simple portal user :-

String accountId = PORTAL_ACCOUNT_ID;
String userId = Site.createPortalUser(u, accountId, password);

Please use below code to create Person Account Portal user :-

String ownerId = OWNER_ID;
String userId = Site.createPersonAccountPortalUser(u, ownerId, password);

Change Password :-
public static System.PageReference changePassword(String newpassword, String verifynewpassword, String opt_oldpassword);

Forget Password :-
public static Boolean forgotPassword(String username);

Related link for all Site Method :-

https://www.salesforce.com/us/developer/docs/apexcode/Content/apex_classes_sites.htm

Thanks,
Amit Chaudhary
Email :- amit.salesforce21@gmail.com


Custom login page for Salesforce community


Requirement 
:-

Some time we need to override salesforce standard login page with client login page in salesforce community. 

Solution :

Prerequisite :-  

1) Community should be Setup (for the you can refer my below blog ):-
2) Create A Visual force according to your company requirement
3) Create a controller for VF page. We need to use below code to login in Salesforce.


    
1.    global PageReference CustomLogin()   
2.    {  
3.      return Site.login(username, password, null);   
4.    }  



  1. Once you create new community then click on Customize -> Communities -> All Communities, then from click on Force.com.
  2. Then go to "Site Visualforce Pages". And select you page.
  3. Click on Edit button on community and add your Vf page in "Inactive Site Home Page" and Save.
  4. Click on "URL Redirect" 
  5. Now add source URL (Ex. /Employee/login ) in Source URL text box and partial target URL in (Ex. /Employee/CommunityCustomLogin ) in Target URL text box and click save.
 Thanks,
Amit Chaudhary
Email:- amit.salesforce21@gmail.com

Monday, 1 December 2014

How to Setup Salesforce Community



Communities are a great way to share information and collaborate with people outside your company who are key to your business processes, such as customers or partners.

You can use Communities to:
  • Drive more sales by connecting your employees with your distributors, resellers, and suppliers
  • Deliver world-class service by giving your customers one place to get answers
  • Manage social listening, content, engagement, and workflow all in one place
How to enable communities 
  1. Go to Setup > App Setup > Customize > Communities > Settings
  2. Enable the checkbox "Enable communities"
  3. Register For Domain, Once enabled the communities it will ask for the domain name, show in picture. 

Creating Communities

1) Click Customize -> Communities -> All Communities, then click New Community.
2) Enter a community name. 

3) Enter a unique value at the end of the URL field.



Customizing Communities

You can customized following in community :-
Ø  Members
Ø  Tabs & Pages
Ø  Branding
Ø  Login & Registration
Ø  Emails
Ø  Miscellaneous




(I) Member :-
  1. Once you create new community then click on Customize -> Communities -> All Communities, then from the drop-down button next to the community name, select Administration Settings.
  2. Click on “Members” tab
  3. Once clicked on “Members” tab, it will show the screen as displayed in picture
  4. Select profile whom you want to provide community access.


Once you add a profile or permission set, all users assigned to that profile or permission set become members of the community.

(II)Tabs and Pages :-
  1. From Setup, click Customize -> Communities -> All Communities, then from the drop-down button next to the community name, select Administration Settings.
  2. Now click on “Tabs and Pages”, it will show the screen displayed in picture
  3. Select all tab which you want to show in community.
  4. then Click on Save


(III) Custom Branding
  1. From Setup, click Customize -> Communities -> All Communities, then from the drop-down button next to the community name, select Administration Settings.
  2. Now click on “Branding”, 
  3. From here you can customize your headers and footers (formats are mentioned in picture) (which will be displayed on the native screens, and depends if you’ve applied on custom pages/tabs) and color theme to the community
  4. Then Save

(IV) Customize Login Page
  1. From Setup, click Customize -> Communities -> All Communities, then from the drop-down button next to the community name, select Administration Settings.
  2. Now click on “Login Page”, 
  3. Now you can give your company logo in login page. Whenever user open your community link, then you can show your company logo in header and show your content in footer.
  4. Then click on save

(V) Customizing Communities Email
  1. From Setup, click Customize | Communities | All Communities, then from the drop-down button next to the community name, select Administration Settings.
  2. Now click on “Emails”, 
  3. From here You can customize email sender information, Chatter email branding, and templates in your community emails. You can perform customizations in either the user interface or the Network object in Salesforce APIs.
  4. Click on save
(VI) Customize Communities Miscellaneous Settings
  1. From Setup, click Customize | Communities | All Communities, then from the drop-down button next to the community name, select Administration Settings.
  2. Now click on “Miscellaneous”
  3. Modify accordingly and click on save
Finally Publish It





View Global Header Permission Is No Longer On By Default



To enable View Globale Header permission you need to follow below step :-

1) Select profile
2) Select System Permission View Global Header
3) Then save.




Create New User

1.    Create a new account 
2.    Create a new contact record under newly created account 
3.    Open contact record and click on “Manage External User” and then click on “Enable Customer User” link, it will redirect you to user record    

4.    Click on Save button, 

NOTE :- Please ensure that the current logged in user should have a role to create this new user otherwise it will give you error.


Please do share your thoughts or problem you may face.


Thanks,
Amit Chaudhary
Email:- amit.salesforce21@gmail.com