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 4

S
Suresh Kumar Tavva
15/12/2016 0 0

Scenario 10:-

//Trigger Check Duplicate

before insert, before update

Set<ID> leadid = new Set<ID>();

    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<RecordType> recname = new List<RecordType>();

    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<Quote> QL = New List<Quote>();

    set<id> OppId = new set<id>();

        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

Trigger Best Practices
Triggers - Best Practices in Salesforce 1. Future methods, SOQL and DML: Avoid writing Future methods, SOQL and DML inside the "For" loop.2. Bulkify the trigger: Start developing the logic...
R

Rajiv Kumar Singh

0 1
0

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...

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...

Java To Salesforce Connection
Java to Salesforce Connection Step 1: Generate or Obtain the Web Service WSDL To generate the WSDL file for your organization: Log in to your Enterprise, Unlimited, or Developer Edition Salesforce...

Following Custom Objects Are Available In The Organization: Interview Question For Salesforce
ChildObject__c ParentObject__c Click to see the full question. Relationship between ChildObject__c and ParentObject__c objects is Lookup relationship. In case of lookup relationship if we delete the...
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