Tuesday, March 27, 2018

VF code vs Lightning code.

<apex:page controller="Mycalci">
    <apex:form >
        <apex:pageBlock >
       
  First Number      <apex:inputText value="{!num1}"/>
       
  Second Number         <apex:inputText value="{!num2}"/>
 
 
 Out put <apex:outputText value="{!num3}" label="Out put"/>
 
  <apex:pageBlockButtons >
 
  <apex:commandButton value="Add" action="{!Add}"/>
    <apex:commandButton value="Sub" action="{!sub}"/>
  </apex:pageBlockButtons>
         
        </apex:pageBlock>
    </apex:form>
</apex:page>

=====================

public class Mycalci {

    public Integer num1 { get; set; }
    public Integer  num2 { get; set; }
    public Integer  num3{ get; set; }
   
   
    public pageReference Add()
    {
   
    num3=num1+num2;
   
    return null;
    }
   
   
    public void Sub()
    {
   
    num3=num1-num2;
   
   
    }
   
}

============
lighting component
=======

<aura:component implements="flexipage:availableForAllPageTypes" access="global" >
   
   
    <aura:attribute name="num1" type="integer" />
    <aura:attribute name="num2" type="integer" />   
    <aura:attribute name="num3" type="integer" />
   
     <lightning:input name="input1" label="Enter first number" type="number" value="{!v.num1}" aura:id="abc"/>
   
     <lightning:input name="input2" label="Enter second number" type="number" value="{!v.num2}" aura:id="xyz"/>
   
      <ui:inputNumber label="Number 1" value="{!v.num1}" aura:id="ddd" />
   
  {!v.num1} +{!v.num2}
   
<lightning:buttonGroup >
     
        <lightning:button label="Add" variant="success" onclick="{!c.Add}" title="Add Method"  />
        <lightning:button label="Sub" variant="brand" onclick="{!c.Sub}"  />
        <lightning:button label="Mul" variant="destructive"  onclick="{!c.Mul}"  />
    </lightning:buttonGroup>
   
   
</aura:component>

===========
Java script Controller code
===========


({
Add : function(component, event, helper) {
       
      var n1=parseInt(component.find("abc").get("v.value"));
 
         var n2=parseInt(component.find("xyz").get("v.value"));
       
         var n3=component.find("ddd").get("v.value");
       
        alert(n3);
       
    var a=  parseInt(component.get('v.num1'));
    var b=  parseInt(component.get('v.num2'));
    var c=n1+n2;
       
        var d= a+b;
       
        alert('%%%%%final out put%%%%%'+d);
       
       
       
       
     
     

},
    Sub : function(component, event, helper) {
       
       var n1=parseInt(component.find("abc").get("v.value"));
 
         var n2=parseInt(component.find("xyz").get("v.value"));
       
         var c=n1-n2;
       
        alert('%%%%%final out put%%%%%'+c);

},
    Mul : function(component, event, helper) {
       
            var n1=parseInt(component.find("abc").get("v.value"));
 
         var n2=parseInt(component.find("xyz").get("v.value"));
       
         var c=n1*n2;
       
        alert('%%%%%final out put%%%%%'+c);


}
   
})

Component References for Lighting


For getting your org Components source code, please replace below domain name with your domain name.

https://lightningclass1000-dev-ed.lightning.force.com/auradocs/reference.app

For getting all the OOTB(our of box) components, please replace below domain name with your domain name.


To understand the Secure versions of essential Java Script DOM API's, such as Window.. click on below link>

http://documentation.auraframework.org/lockerApiTest/index.app?aura.mode=DEV

Sunday, February 25, 2018

Covered Aura:Method, Aura.Action, ParenttoChild, ChildtoParent and Sibling Communication.

Below code Covers Aura:Method, Aura.Action, ParenttoChild, ChildtoParent and Sibling Communication in one Single Application.



Step 1:

=========
componentEvents
=========
<aura:event type="COMPONENT" description="Event template" >
 
    <aura:attribute name="firstnumber" type="Integer" />
     <aura:attribute name="secondnumber" type="Integer" />
 
</aura:event>

Step 2:
==============
childcomp
===========
<aura:component>
  <aura:attribute name="childoutput" type="Integer" />

  <aura:attribute name="clickme" type="Aura.Action" />

  <aura:handler name="init" value="{!this}" action="{!c.doInit}" />
  <aura:registerEvent name="cmp1" type="c:componentEvents" />
 
 
   <lightning:card title="Child 1">
 
  <lightning:input type="integer" label="Number 1" aura:id="num1" />
  <lightning:input type="integer" label="Number 2" aura:id="num2" />

  <p
    ><lightning:button
      label="Component Event"
      onclick="{!c.fireComponentEvent}" variant="brand"
    />
  </p>

  <p
    ><lightning:button
      label="Parent Method calling with Aura.action"
      onclick="{!v.clickme}" variant="brand"
    />
  </p>
     
       </lightning:card>
</aura:component>

==============
childcomp controller
===========

({
child : function(component, event, helper) {
     
        var output=parseInt(event.getParam("firstnumber")) +parseInt(event.getParam("secondnumber"));
     
       component.set("v.childoutput",output);

},
 
    fireComponentEvent : function(component, event) {
        // Get the component event by using the
        // name value from aura:registerEvent
    var cmpEvnt=component.getEvent("cmp1");
    var num1=parseInt(component.find("num1").get("v.value"));
    var num2=parseInt(component.find("num2").get("v.value"));
     
    cmpEvnt.setParams({"firstnumber":num1,"secondnumber":num2});
        cmpEvnt.fire();
    },
    doInit :function(component, event, helper){
     
       // component.set("v.childoutput",10000);
    }

})

Step 3:

=========
childcomp2
========

<aura:component >
 
     <aura:attribute name="prntoutput" type="Integer" default="0"/>
    <aura:method name="Addition" action="{!c.Addition}" description="Sample method with parameters">
    <aura:attribute name="param1" type="Integer" />
    <aura:attribute name="param2" type="Integer" />
    </aura:method>
    <br/>
    <br/>
    <br/>
     <lightning:card title="Child 2">
    <p>Sibling out put</p>
    {!v.prntoutput}
    <br/>
    <br/>
    <br/>
    </lightning:card>
</aura:component>

================

({
Addition : function(component, event, helper) {
         var params = event.getParam('arguments');
        if (params) {
            var param1= params.param1;
            var param2= params.param2;
            var output=param1+param2;
        }
     
        component.set("v.prntoutput",output);

}
})

Step 4:

parentComp
==========
<aura:component >
    <aura:attribute name="prntoutput" type="Integer" />
  <aura:handler name="cmp1" event="c:componentEvents" action="{!c.parent}" />
 
    <lightning:card title="Parent output">
 
    {!v.prntoutput}
 
   </lightning:card>
     <br/>
    <br/>
    <br/>
 
     <c:childcomp />

     <c:childcomp2 aura:id="sibling"   />
 
 
 
   <!--   <c:childcomp clickme="{!c.Parentmethod}"  />  -->
 
   <!--   <c:childcomp cmp1="{!c.parent}"/> -->

 
</aura:component>


====
parentComp controller
=====

({
parent : function(component, event, helper) {
     
        var fnumber=parseInt(event.getParam("firstnumber"));
        var snumber=parseInt(event.getParam("secondnumber"));
        var output=fnumber+snumber;
     
       component.set("v.prntoutput",output);
     
        var childCmp = component.find("sibling");

      childCmp.Addition(fnumber,snumber);
     
     

},
    Parentmethod:function(component, event, helper) {
     
      alert("From Parent Method");
     
     

}
})

Step 5:
==================
Grantparent
==============

<aura:component implements="flexipage:availableForAllPageTypes" >
    <aura:attribute name="prntoutput" type="Integer" />
     <aura:attribute name="parentdata" type="Integer" default="100000" />
     <aura:handler name="cmp1" event="c:componentEvents" action="{!c.Grandparent}" />

    <lightning:card title="Grand Parent Output">
 
    {!v.prntoutput}
    <br/>
    <br/>
    <br/>
    <c:parentComp  prntoutput="{!v.parentdata}" />
     
    </lightning:card>
</aura:component>

==================
Grantparent controller
==============

({
Grandparent : function(component, event, helper) {
     
        var output=parseInt(event.getParam("firstnumber")) +parseInt(event.getParam("secondnumber"));
   
       component.set("v.prntoutput",output);
     
     

}
})

Step 6:
=========
Alleventsapp
=======

<aura:application extends="force:slds">
    <c:GrandparentComp />
</aura:application>


For another advance way of communication on top of these topics, please refer here: https://davesfdc.blogspot.com/2018/10/another-advanced-way-of-parent-to-child.html

Salesforce Lightning: Application Events (Sample Siri)

Application events follow a traditional publish-subscribe model. An application event is fired from an instance of a component. All components that provide a handler for the event are notified.


Step 1 : create Application event

/* Use type="APPLICATION" in the <aura:event> tag for an application event. For example, this c:appEvent application event has one attribute with a name of message. */

===============================
ApplicationCommunication  Event
================================


<aura:event type="APPLICATION" description="Discussion between multiple Components" >
 
    <aura:attribute name="mesg" type="string" />
 
 
</aura:event>


Step 2:  Create Source Component

/*A component registers that it may fire an application event by using <aura:registerEvent> in its markup. The name attribute is required but not used for application events. The name attribute is only relevant for component events. This example uses name="appEvent" but the value isn’t used anywhere.*/

Name: SourceCmp
==================

<aura:component implements="flexipage:availableForAllPageTypes">
 
    <aura:registerEvent name="anyname" type="c:ApplicationCommunication" />
    <aura:attribute name="Display" type="boolean" default="false" />
    <aura:attribute name="greeting" type="string" />
    <lightning:input type="string" label="Enter some data here"  aura:id="inputdata"/>
    <p><lightning:button label="Click here to fire an application event"
        onclick="{!c.fireApplicationEvent}" />
    </p>


</aura:component>

Step 3: copy paste below code in the SourceCmp  client side controller
======
SourceCmp controller side code
========
({
fireApplicationEvent : function(component, event, helper) {
     
        var message=component.find("inputdata").get("v.value");
     
        var appEvent=$A.get("e.c:ApplicationCommunication");
     
        appEvent.setParams({"mesg":message});
     
        appEvent.fire();
     
 

}
})


Step 4: Listener or Handler Markup code

/*Use <aura:handler> in the markup of the handler component.

For example:

<aura:handler event="c:appEvent" action="{!c.handleApplicationEvent}"/>*/

==========
Name: Listener (Handler)
===========
<aura:component implements="flexipage:availableForAllPageTypes" access="global" >
    
    <aura:attribute name="receivedevent" type="string"  />
    
    <aura:handler event="c:ApplicationCommunication" action="{!c.handleApplicationEvent}" />
    
     <p>{!v.receivedevent}</p>

    
</aura:component>


Step 5:


==================
Listener client side controller
==================
({
    handleApplicationEvent : function(cmp, event) {
      var Sourcedata= event.getParam("mesg");
        var response="Sorry I did not understand you";
        if(Sourcedata=='Hi')
        {
            response="Hello"
        } 
         if(Sourcedata=='How are you')
        {
            response="Im doing great!!"
        } 

         if(Sourcedata=='How is your course')
        {
            response="Going good"
        } 
         if(Sourcedata=='Do practice after this session')
        {
            response="Sure Thank you !!"
        } 
         if(Sourcedata=='Good Night')
        {
            response="Good night too, sweet dreams !!"
        } 
         if(Sourcedata=='Good Morning')
        {
            response="Good Morning too, have a great day !!"
        } 

            
        cmp.set("v.receivedevent",response);
    }

})


Step 6:  create Application with the below code

<aura:application >
    <c:SourceCmp />
    <c:Listener  />
</aura:application>


Step 7: Instead of above 6th step code I recommend to Surface SourceCmp and Listener  on different parts of the Application builder page. Though there is no connection between these components but still you can create communication  between these two components.



Sunday, August 13, 2017

Dynamic Search Engine Advanced

===============================================================
This topic covers, Dynamic query, apex:actionfunction, column level sorting,Html tables tr and td's,apex:param, rerendering,pageblock's inside the pageblocks and also page error messages.

Note: To execute below code you need to create picklist value custom field in contacts with the API name:"Intrested_technologies_to_learn__c"

==================================================================

Vf page:
---------

<apex:page controller="ContactSearchController" sidebar="false" >

  <apex:form >
  <apex:pageMessages id="errors" />

  <apex:pageBlock title="Find Me A Customer!" mode="edit">

  <table width="100%" border="0">
  <tr>
    <td width="200" valign="top">

      <apex:pageBlock title="Parameters" mode="edit" id="criteria">

      <script type="text/javascript">
     
      function doSearch() {
        searchServer(
          document.getElementById("firstName").value,
          document.getElementById("lastName").value,
          document.getElementById("accountName").value,
          document.getElementById("technology").options[document.getElementById("technology").selectedIndex].value
          );
      }
      </script>

      <apex:actionFunction name="searchServer" action="{!runSearch}" rerender="results,debug,errors">
          <apex:param name="firstName" value="" />
          <apex:param name="lastName" value="" />
          <apex:param name="accountName" value="" />
          <apex:param name="technology" value="" />
      </apex:actionFunction>

      <table cellpadding="2" cellspacing="2">
      <tr>
        <td style="font-weight:bold;">First Name<br/>
       
        <input type="text" id="firstName" onkeyup="doSearch();"/>
       
        </td>
      </tr>
     
      <tr>
        <td style="font-weight:bold;">Last Name<br/>
        <input type="text" id="lastName" onkeyup="doSearch();"/>
        </td>
      </tr>
     
      <tr>
        <td style="font-weight:bold;">Account<br/>
        <input type="text" id="accountName" onkeyup="doSearch();"/>
        </td>
      </tr>
     
      <tr>
        <td style="font-weight:bold;">Interested Technologies<br/>
          <select id="technology" onchange="doSearch();">
            <option value=""></option>
            <apex:repeat value="{!technologies}" var="tech">
              <option value="{!tech}">{!tech}</option>
            </apex:repeat>
          </select>
        </td>
      </tr>
     
      </table>

      </apex:pageBlock>

    </td>

    <td valign="top">

    <apex:pageBlock mode="edit" id="results">

        <apex:pageBlockTable value="{!contacts}" var="contact">

            <apex:column >
                <apex:facet name="header">
                    <apex:commandLink value="First Name" action="{!toggleSort}" rerender="results,debug">
                        <apex:param name="sortField" value="firstName" assignTo="{!sortField}"/>
                    </apex:commandLink>
                </apex:facet>
                <apex:outputField value="{!contact.firstName}"/>
            </apex:column>

            <apex:column >
                <apex:facet name="header">
                    <apex:commandLink value="Last Name" action="{!toggleSort}" rerender="results,debug">
                        <apex:param name="sortField" value="lastName" assignTo="{!sortField}"/>
                    </apex:commandLink>
                </apex:facet>
                <apex:outputField value="{!contact.lastName}"/>
            </apex:column>

            <apex:column >
                <apex:facet name="header">
                    <apex:commandLink value="Account" action="{!toggleSort}" rerender="results,debug">
                        <apex:param name="sortField" value="account.name" assignTo="{!sortField}"/>
                    </apex:commandLink>
                </apex:facet>
                <apex:outputField value="{!contact.account.name}"/>
            </apex:column>

            <apex:column >
                <apex:facet name="header">
                    <apex:commandLink value="Technologies" action="{!toggleSort}" rerender="results,debug">
                        <apex:param name="sortField" value="Intrested_technologies_to_learn__c" assignTo="{!sortField}"/>
                    </apex:commandLink>
                </apex:facet>
                <apex:outputField value="{!contact.Intrested_technologies_to_learn__c}"/>
            </apex:column>

        </apex:pageBlockTable>

    </apex:pageBlock>

    </td>
  </tr>
  </table>

  <apex:pageBlock title="Debug - SOQL" id="debug">
      <apex:outputText value="{!debugSoql}" />          
  </apex:pageBlock>  

  </apex:pageBlock>

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


======================================================================

Controller code:
-----------------

public with sharing class ContactSearchController {

  // the soql without the order and limit
 
  private String soql {get;set;}
 
 
  // the collection of contacts to display
  public List<Contact> contacts {get;set;}

  // the current sort direction. defaults to asc
  public String sortDir {
    get  { if (sortDir == null) {  sortDir = 'asc'; } return sortDir;  }
    set;
  }

  // the current field to sort by. defaults to last name
  public String sortField {
    get  { if (sortField == null) {sortField = 'lastName'; } return sortField;  }
    set;
  }

  // format the soql for display on the visualforce page
  public String debugSoql {
    get { return soql + ' order by ' + sortField + ' ' + sortDir + ' limit 20'; }
    set;
  }

  // init the controller and display some sample data when the page loads
  public ContactSearchController() {
    soql = 'select firstname, lastname, account.name, Intrested_technologies_to_learn__c from contact where account.name != null';
    runQuery();
  }

  // toggles the sorting of query from asc<-->desc
  public void toggleSort() {
    // simply toggle the direction
    sortDir = sortDir.equals('asc') ? 'desc' : 'asc';
    // run the query again
    runQuery();
  }

  // runs the actual query
  public void runQuery() {

    try {
      contacts = Database.query(soql + ' order by ' + sortField + ' ' + sortDir + ' limit 20');
    } catch (Exception e) {
   
    system.debug('$$$$$$$$$$$$$$$$$$$'+e);
      ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.ERROR, 'Ooops!'));
    }

  }

  // runs the search with parameters passed via Javascript
  public PageReference runSearch() {

    String firstName = Apexpages.currentPage().getParameters().get('firstname');
   
    String lastName = Apexpages.currentPage().getParameters().get('lastname');
   
    String accountName = Apexpages.currentPage().getParameters().get('accountName');
   
    String technology = Apexpages.currentPage().getParameters().get('technology');
   
    system.debug('$$$$$$$$$$$$$$$$$$$$$$'+technology);

    soql = 'select firstname, lastname, account.name, Intrested_technologies_to_learn__c from contact where account.name != null';
   
if (!firstName.equals(''))
      soql += ' and firstname LIKE \''+String.escapeSingleQuotes(firstName)+'%'+'\'';
    if (!lastName.equals(''))
      soql += ' and lastname LIKE \''+String.escapeSingleQuotes(lastName)+'%'+'\'';
    if (!accountName.equals(''))
      soql += ' and account.name LIKE \''+String.escapeSingleQuotes(accountName)+'%'+'\'';
    if (!technology.equals(''))
      soql += ' and Intrested_technologies_to_learn__c = \'' +String.escapeSingleQuotes(technology)+'\'';
 system.debug('%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%'+soql);

 //' LastName like \''+LastName+'\'';
           // }
    // run the query again
    runQuery();

    return null;
  }

  // use apex describe to build the picklist values
  public List<String> technologies {
    get {
      if (technologies == null) {

        technologies = new List<String>();
        Schema.DescribeFieldResult field = Contact.Intrested_technologies_to_learn__c.getDescribe();

        for (Schema.PicklistEntry f : field.getPicklistValues())
          technologies.add(f.getLabel());

      }
      return technologies;        
    }
    set;
  }

}

Sunday, July 30, 2017

Salesforce Certified Platform App Builder – Summer ’17 Release Exam


1 of 5.
How can users see the change history of key fields in an object record?
A. History related list with field tracking
B. Reporting Snapshot
C. Historical Trend Reporting
D. Setup Audit Trail

2 of 5.
Which two components are supported when building Lightning pages with the Lighting App Builder?
Choose 2 answers

A. Related Records
B. Chatter Feed
C. Social View
D. Flows

3 of 5.
What is a secure method of creating a single field from two encrypted fields?
A. Create the two source fields, use a formula with & to concatenate, populate the data into the two source fields, then encrypt the source fields
B. Create a custom formula referencing the two encrypted fields using & to concatenate
C. Disable encryption on the two source fields, create a formula using & to concatenate, then reenable encryption on the two source fields
D. Disable Shield Platform Encryption, create a formula using & to concatenate, then reenable Shield Platform Encryption


4 of 5.
What happens to an automated notification email generated by a process if another process subsequently modifies the same record?
A. The email is sent twice.
B. The email is suppressed.
C. The email is queued and may send depending on the secondary process.
D. The email is sent.
5 of 5.
Which tool will help the consultant see if APEX or Visualforce code is running an out-of-date API version?

A. Optimizer
B. Lightning Experience Readiness Check
C. Lightning Experience Migration Assistant
D. Health Check

Salesforce Certified Platform Developer I – Summer ’17 Release Exam

Salesforce Certified Platform Developer I – Summer ’17 Release Exam


1 of 5.
What are two considerations when overriding standard actions?
Choose 2 answers
A. Overriding standard actions with a Lightning component applies only to Lightning Experience and Salesforce1, but not to Salesforce Classic.
B. Overriding standard actions with a Visualforce page applies only to Salesforce Classic and Lightning Experience, but not to Salesforce1.
C. Overriding standard actions with a Visualforce page applies to Salesforce Classic, Lightning Experience, and Salesforce1.
D. Overriding standard actions with a Lightning component applies to Lightning Experience, Salesforce1, and Salesforce Classic.


2 of 5.
How can a validity check be performed on a component?A
A. cmp.get() != null
B. cmp.get() == true
C. cmp.get(“v.isValid”) != null
D. cmp.get(“v.isValid”) == true


3 of 5.
Which standard actions can be overridden with Lightning Components?
A. Tab, View, Edit, New
B. View, Edit, New, Delete
C. List, Edit, New, Delete
D. List, View, Edit, New


4 of 5.
What is a consideration for Locker Service Enablement?
A. Locker service is enabled for all custom Lightning Components with API version 40.0 or greater.
B. Locker service is disabled for all custom Lightning Components, regardless of the API version.
C. Locker service is disabled for custom Lightning Components implementing the interface force:ignoreLockerService.
D. Locker service is enabled for custom Lightning Components implementing the interface force:enforceLockerService.


5 of 5.
How do the CSS enhancements to the Lightning Design System improve the developer experience? A
A. Single dashes are used in class names to enable commenting.
B. Uppercase is used to distinguish from custom class names.
C. Class names are available in upper and lower case.
D. Class names are abbreviated to reduce code length.