UrbanPro
true

Learn Salesforce Developer from the Best Tutors

  • Affordable fees
  • 1-1 or Group class
  • Flexible Timings
  • Verified Tutors

Search in

Trigger Sceniors - session 5

S
Suresh Kumar Tavva
15/12/2016 0 0

//Trigger Check Duplicate

before insert, before update

Set leadid = new Set();

    Map<String,Lead> phonemap = new Map<String,Lead>();

    Map<String,Lead> emailmap = new Map<String,Lead>();   

    for(Lead l : Trigger.New){

        if(phonemap.containsKey(l.Phone))

            l.adderror('Another Lead with the same Phone no is already available');

        else if(emailmap.containsKey(l.Email))

            l.adderror('Another Lead with the same Email is already available');

        else{

            if(l.ID != null)

                leadid.add(l.ID);

            if(l.Phone != null)

                phonemap.put(l.Phone,l);

            if(l.Email != null)

                emailmap.put(l.Email,l);   

        }

    }

   

    for(Lead L : [select ID,Phone,Email from Lead where ((Phone IN: phonemap.keyset() or Email IN: emailmap.keyset()) AND ID NOT IN: leadid)]){

        Lead l1 = phonemap.get(l.Phone);

        if(l1 != null)

            l1.adderror('Another Lead with the same Phone no is already available');

        else{

            Lead l2 = emailmap.get(l.email);

            if(l2 != null)

                l2.adderror('Another Lead with the same Email is already available');

        }

    }

Scenario 11:-

//OpportunityTrigger

before insert, before update, before delete, after insert, after update, after delete, after undelete

List recname = new List();

    TitanTrigger Titan=new TitanTrigger();    // titanTrigger is class

    if(Trigger.isBefore){

        if(Trigger.isUpdate || Trigger.isInsert){

            for(Opportunity currentopportunity:Trigger.new){

                Titan.Triggers.Attachmentsize.init(currentopportunity);

            }

            if(Trigger.isUpdate){

           for(Opportunity currentopportunity:Trigger.new){

                   Titan.Triggers.StageNameError.init(currentopportunity,Trigger.oldmap.get(currentopportunity.id));

                  Titan.Triggers.stagevalidation.init(currentopportunity,Trigger.oldmap.get(currentopportunity.id));

                }

            }

        }

    }

    if(Trigger.isBefore){

        if(Trigger.isUpdate || Trigger.isInsert){

            Titan.Triggers.Attachmentsize.Process(trigger.new);

             if(Trigger.isInsert){

                 if(TitanTrigger.recursiveFlag)

                     Titan.Triggers.ownerchange.Process(trigger.new,1);

             }

            if(Trigger.isUpdate){

               if(TitanTrigger.recursiveFlag)

               {

              

                recname=[select Id, Name, Description, DeveloperName, IsActive from RecordType where sobjecttype='Opportunity'  ];

                   if(recname[0].Name !='Jewllery' ||recname[0].Name !='Watches')

                   {

                  

                   system.debug('$$$$$$$$$$$$        '+recname[0].Name);

                       Titan.Triggers.ownerchange.Process(trigger.new,0);

                       Titan.Triggers.stagevalidation.Process(trigger.new);

                   }

               }

            }

        }

    }

Scenario 11:-

//sendInfoToQuote (By using Payment tracking bank details)

before insert, before update

List QL = New List();

    set OppId = new set();

        for(Payment_Tracker__c q1:Trigger.New){

            oppId.add(q1.Opportunity__c);

        }

    for(Payment_Tracker__c pt:Trigger.new){

        For(Quote Q:[select id,OpportunityId,Bank_Name__c,Cheque_Date__c,Cheque_No__c,Location_of_The_Bank__c,RTGS_No__c,

            Advance_Received__c from Quote where opportunityId =:oppId]){

                if(PT.Opportunity__c== Q.opportunityId && pt.Payment_Type__c=='Advance')

                {

                    Q.Bank_Name__c = PT.Bank_Name__c;

                    Q.Cheque_Date__c= PT.Cheque_Date__c;

                    Q.Cheque_No__c=PT.Cheque_No__c;

                    Q.Location_of_The_Bank__c= PT.Location_of_The_Bank__c;

                    Q.RTGS_No__c= PT.RTGS_No__c;

                    Q.Advance_Received__c= PT.Amount_Recieved__c;

                    QL.add(Q);

                                }

                        }

             }

        update QL;

}

Scenario 13:-

//Trigger Update Completed Date

before insert,before update

for(Task t : Trigger.New){

        if(t.Status == 'Completed')

            t.Completed_Date_del__c  = System.today();

    }

 

 

0 Dislike
Follow 0

Please Enter a comment

Submit

Other Lessons for You

How to Learn salesforce easily?
Steps: 1.Know the course content. 2. Collect all materials. 3. Separate all materials into A.Admin B.Development C.Project. 4. Get the best trainer and follow him/her. 5. Update your skills with the help of all available resources.

What Is Batch Apex And Its Methods ?
1. We can call the apex code by creating object for the class (or) if the variables or methods are static then we can call with class name. Apex Code in the trigger will execute automatically for...

What Is The Order Of Execution In Salesforce?
We are creating validation rules, workflow rules, assignment rules, auto-responsive rules, escalation ruels and apex triggers etc. If the condition is same for all the rules which will execute first and...

What Is SOQL And SOSL?
1. SOQL: Salesforce Object Query Language SOQL: Salesforce Object Query Language SOQL Purpose: To fetch info. from an object and related objects. We can write query on one object while querying...

What Is The Difference Between Non-Static And Static?
By default all the variables and methods are non-static. Scope of the non-static variables or methods is within the scope of the same object. We can declare variables and methods as static...
X

Looking for Salesforce Developer Classes?

The best tutors for Salesforce Developer Classes are on UrbanPro

  • Select the best Tutor
  • Book & Attend a Free Demo
  • Pay and start Learning

Learn Salesforce Developer with the Best Tutors

The best Tutors for Salesforce Developer Classes are on UrbanPro

This website uses cookies

We use cookies to improve user experience. Choose what cookies you allow us to use. You can read more about our Cookie Policy in our Privacy Policy

Accept All
Decline All

UrbanPro.com is India's largest network of most trusted tutors and institutes. Over 55 lakh students rely on UrbanPro.com, to fulfill their learning requirements across 1,000+ categories. Using UrbanPro.com, parents, and students can compare multiple Tutors and Institutes and choose the one that best suits their requirements. More than 7.5 lakh verified Tutors and Institutes are helping millions of students every day and growing their tutoring business on UrbanPro.com. Whether you are looking for a tutor to learn mathematics, a German language trainer to brush up your German language skills or an institute to upgrade your IT skills, we have got the best selection of Tutors and Training Institutes for you. Read more