-
Trigger to prevent Date Overlap #ApexTrigger
Hi everyone,
I am a newbie Salesforce Developer. And I am new to this forum as well :).
I am trying to write a trigger for a requirement where a new record should not be created if the dates overlap. There are 2 objects Event1 (Campaign renamed) and Attendee. There is a junction object Event Attendee which allows an attendee to register for an Event. If an attendee is already registered for an event then he/she should not be able to register for any other event which falls on those dates or whose start or end dates overlap the already registered event dates. So this trigger that I wrote lets me create records for overlapping dates. If there is one EA record for an Attendee with dates 2/4/2019 and 3/4/19 as start and end dates respectively, there shouldn't be another EA record for an Attendee with dates overlapping 2/4/2019 and 3/4/2019.
Please help me fix my logic. Thanks.
trigger Eventdatesoverlapprevention on Event_Attendee__c (before insert,before update) { set<string> att = new set <string>(); set<string> evnt = new set <string>(); set<date> stdt = new set <date>(); set<date> endt = new set <date>(); //getting attendee, event, start and end dates in the event attendee records in the set defined above. for (event_attendee__c ea:trigger.new){ stdt.add(ea.event_start_date__c); endt.add(ea.event_end_date__C); att.add(ea.Attendee__c); evnt.add(ea.event1__C); } //querying for attendees that are a part of the trigger.new list list <attendee__C> attendee = [Select id from attendee__c where id in:att]; //querying for events (campaign is renamed to event1) that are a part of the trigger.new list list<campaign> event = [Select id from campaign where id in:evnt]; // querying the list of event attendees where the attendees, events, start date and end date is present in the trigger.new list list<event_attendee__C> evntovrlap1 = [SELECT id from event_attendee__C where attendee__c in: att and event1__C in: evnt and event_Start_Date__C in: stdt and event_End_Date__C in: endt]; //querying the list of event attendees where the start date is higher than the start date in trigger.new list //and end date is less than the end date in the trigger.new list. list<event_attendee__C> evntovrlap2 = [SELECT id from event_attendee__C where attendee__c in: att and event1__C in: evnt and event_Start_Date__C >=: stdt and event_end_Date__C <=: endt]; //querying the list of event attendees where the start date is less than the start date in trigger.new list //and end date is higher than the end date in the trigger.new list. list<event_attendee__C> evntovrlap3 = [SELECT id from event_attendee__C where attendee__c in: att and event1__C in: evnt and event_start_Date__C <=: stdt and event_end_Date__C >=: endt]; //for every attendee record and for every event attendee record, if attendee record finds a match in the event attendee record //and if the above counts are greater than 1 then, show an error message. for(attendee__c a : attendee){ for(campaign e : event){ for(event_attendee__c ea:trigger.new){ If(a.id==ea.Attendee__c && e.Id == ea.Event1__c){ If(evntovrlap1.size()>0 || evntovrlap2.size()>0 || evntovrlap3.size()>0){ ea.adderror('Attendee is already registered for these dates'); } } } } } }
-
This discussion was modified 5 years, 10 months ago by
Suman Humane.
-
This discussion was modified 5 years, 10 months ago by
Suman Humane.
-
This discussion was modified 5 years, 10 months ago by
Log In to reply.
Popular Salesforce Blogs
data:image/s3,"s3://crabby-images/0854b/0854b02cfe0420a175f6101392a50ff4846896cf" alt=""
FlexDeploy Brings DevOps to Mule Integrations | Salesforce
You can build and test Mule Applications or APIs using Anypoint Studio very easily. But when it comes to automating deployments to your environments, with…
data:image/s3,"s3://crabby-images/43e36/43e36e19a980f9cc3a47c02827a87de73273243d" alt="What is SOQL in Salesforce in 2023? | The Developer Guide"
What is SOQL in Salesforce in 2023? | The Developer Guide
In this Blog we will learn about SOQL in salesforce. What is SOQL? SOQL stands for Salesforce Object Query Language. When we have to perform…
data:image/s3,"s3://crabby-images/26e87/26e874d7615e1c0ede1ae09b7c60abca72daa855" alt="Salesforce Governor Limits Cheatsheet"
Salesforce Governor Limits - Cheatsheet
Salesforce a CRM has there own limitation on the usage of resources which are actually based upon separate editions and these editions have there own governor…
Popular Salesforce Videos
Salesforce Integration with Heroku
You can integrate Heroku and the Salesforce Platform in several ways, and choosing among them comes down to understanding your requirements and the capabilities of…
Introduction to Salesforce Apex for Developers
Have you ever wanted to write a Trigger in Salesforce? This workshop is designed for people who would like to begin learning the basics of…
Creating a Roll-up Using DLRS | Salesforce Tutorial Video
In certain situations, an object does not support a roll-up or the relation is not permitted. Learn how to make it possible by using the…