• Abdul Khatri
  • ALL STAR
  • 5248 Points
  • Member since 2015


  • Chatter
    Feed
  • 167
    Best Answers
  • 1
    Likes Received
  • 0
    Likes Given
  • 4
    Questions
  • 1416
    Replies

Hi All, 

Follwing trigger is not working ,Can someone help ?
I couldn't find much in the debug log except a query run.

(following snippet can be simply pasted in the dev org for quick review )

 

trigger A_ConPhoneFromCON on Contact (before insert, before update) {

    // Create a map to store the Account IDs and their corresponding phone numbers
    Map<Id, contact> accountIdToPhone = new Map<Id, contact>();

    for (Contact updatedContact : Trigger.new) {
        // Check if the Contact has an associated Account
        if (updatedContact.AccountId != null) {
            // Add the related Account's ID and phone number to the map
            accountIdToPhone.put(updatedContact.AccountId, updatedContact);
        }
    }

    // Retrieve the related Account records and update the Contacts' phone numbers
    List<Account> relatedAccounts = [SELECT Id, Phone FROM Account WHERE Id IN :accountIdToPhone.keySet()];

    for (Contact updatedContact : Trigger.new) {
        // Check if the Contact is associated with an Account
        if (updatedContact.AccountId != null) {
            // Update the Contact's phone number with the related Account's phone number
            updatedContact.Phone = accountIdToPhone.get(updatedContact.AccountId).phone;
        }
    }
}

I have Lightning Aura Component Name as caseList3

not passing selected case record id in js controller

below is the code (YOU CAN CHECK IN BROWSER BY CLTR+SHIFT+i) so it show selected record Id

as below line

console.log("Selected Case Id: " + selectedCaseId);

 

Now i want an lwc component which will take this Selected record Id as Input and display case and associated product details

 

 

My lightning components working perfectly

you can copy and test in your org

 

only issue i am getting with lwc

 

My Linghtning component code

APEX

public with sharing class CaseListController {
    public CaseListController() {

    }
    @AuraEnabled
    public static List<Case> getCases() {
        
         return [SELECT Id, Subject FROM Case Order By createdDate DESC LIMIT 5];
             
    }}

 

COMPONENT

 

 

caseList3.cmp

 

<aura:component controller="CaseListController"
                implements="force:appHostable,flexipage:availableForAllPageTypes,flexipage:availableForRecordHome,forceCommunity:availableForAllPageTypes,force:lightningQuickAction"
                access="global">
    <aura:attribute name="caseList" type="Case[]" />
    <aura:attribute name="selectedCaseId" type="String" />
    <aura:attribute name="selectedRecordId" type="String" />
    <aura:handler name="init" value="{!this}" action="{!c.loadCases}" />
   
    <div class="slds-card">
        <div class="slds-card__header slds-grid">
            <h2 class="slds-text-heading_medium slds-col">Case Information</h2>
        </div>
        <div class="slds-card__body">
            <ul class="slds-list_dotted">
                <aura:iteration items="{!v.caseList}" var="caseRecord">
                    <li class="slds-p-around_small slds-box slds-box_small">
                        <p class="slds-text-title"><strong>Case Number:</strong> {!caseRecord.CaseNumber}</p>
                        <p class="slds-text-title"><strong>Subject:</strong> {!caseRecord.Subject}</p>
                        <p><strong>Description:</strong> {!caseRecord.Description}</p>
                        <!-- Add more case fields here -->
                        <button class="slds-button slds-button_brand select-case-button" data-caseid="{!caseRecord.Id}" onclick="{!c.selectCase}">Select Case&#128512;</button>
                    </li>
                </aura:iteration>
            </ul>
        </div>
    </div>
    <lightning:workspaceAPI aura:id="workspace" />
</aura:component>
 

 

 

caseList3Controller.js

 

({
    selectCase: function (component, event, helper) {
        var selectedCaseId = event.currentTarget.getAttribute("data-caseid");
        component.set("v.selectedCaseId", selectedCaseId);
        console.log("Selected Case Id: " + selectedCaseId);
        var messagePayload = {
            selectedCaseId: selectedCaseId
        };
        var messageContext = component.find("workspace").getMessageContext();
        var message = {
            recordId: component.get("v.recordId"),
            messageBody: JSON.stringify(messagePayload)
        };
        messageContext
            .publishMessage(CASE_SELECTION_CHANNEL, message)
            .then(response => {
                console.log("Message published successfully");
            })
            .catch(error => {
                console.error("Error publishing message: " + error);
            });
    },
    loadCases: function (component, event, helper) {
        var action = component.get("c.getCases");
        action.setCallback(this, function (response) {
            var state = response.getState();
            if (state === "SUCCESS") {
                var caseRecords = response.getReturnValue();
                component.set("v.caseList", caseRecords);
            } else {
                console.error("Error fetching case data: " + state);
            }
        });
        $A.enqueueAction(action);
    },
    handleRecordSelection: function(component, event, helper) {
        var selectedRecordId = event.getParam("recordId");
        component.set("v.selectedRecordId", selectedRecordId);
    }
   
})
 

 

 

Hi All,

I'm making an synchronous call where I need to get more than 6MB. so I want to split the call and make 2 request.
For example, If I want to request 10,000 records to an external system then I need to request,
  • 1-6000 in first API request call and
  • 6001-10,000 in second API request call
please help me on this.
Thanks you.

Hi Everyone,

i was struck on the one condition, my requirement is update the contact status Cancelled when Account status is Cancelled but not update if Account status is "Pending"/"In progress". 

I have added my code below , please check let me know how to add that condification or any hints please

 

public class AccountUpdate {
    public void getIds() {
    List<Account> accIds = new List<Account>();
        Set<Id> getIds = new Set<Id>();
        for(Account a :[select Id, Name from Account]) {
            getIds.add(a.Id);   
        }
        System.debug('Print all the Account Ids =>' +getIds);
         //get the related contacts associated to Account
        List<Contact> con = [Select Id, Name, AccountId From Contact Where AccountId IN :getIds];
        System.debug('Print all related Contacts'+con);
        List<Contact> getupdateContacts = new List<Contact>();
        if(Account.Account_Status__c == 'Cancelled'){
            getupdateContacts.add(con);
            }
            update getupdateContacts;
        }
        
    }
    
   
    
    
}

Have a task with triggers.

I'm have a custom object with fields, one of trigger method change fields value on values at child lookup object, sum some score.

I need to close edit for this fields, but with profiles i cant do this. When I write in trigger i can close this fields, but trigger also can't edit them. 

 

How I can write trigger or can i try another option for close edit this fields?

 

Here part of trigger and object with fields

private static final String STATUS_FOR_CHECK = 'Closed - Hired'; public static void getJobApplicationsForChangeStatusAfterUpdate(List<Job_Application__c> newJobApplications, Map<Id, Job_Application__c> oldJobApplications) { Set<Id> positionsToClose = new Set<Id>(); for (Job_Application__c newJobApp : newJobApplications) { Job_Application__c oldJobApp = oldJobApplications.get(newJobApp.Id); if (newJobApp.Overall_Average_Reviwes_Score__c != oldJobApp.Overall_Average_Reviwes_Score__c || newJobApp.Overal_Reviews__c != oldJobApp.Overal_Reviews__c) { newJobApp.addError('Fields with Reviews scores can not be changed'); } else { if (newJobApp.Status__c == STATUS_FOR_CHECK && oldJobApp != null && oldJobApp.Status__c != STATUS_FOR_CHECK) { positionsToClose.add(newJobApp.Position__c); } } } List<Position__c> positionsToUpdate = [SELECT Id, Status__c FROM Position__c WHERE Id IN :positionsToClose]; for (Position__c pos : positionsToUpdate) { pos.Status__c = STATUS_FOR_CHECK; } update positionsToUpdate; }

 

 

in this part I can check this fields

if (newJobApp.Overall_Average_Reviwes_Score__c != oldJobApp.Overall_Average_Reviwes_Score__c || newJobApp.Overal_Reviews__c != oldJobApp.Overal_Reviews__c) { newJobApp.addError('Fields with Reviews scores can not be changed'); }

Trigger on ContentDocumentLink object when attachment insert then send the file to AWS (stuck in error Status=HTTP Version not supported, StatusCode=505)

I have two objects 1. Employee 2. Attendance 

Employee, Attendance has master detail relation.

Actually i already implemented everything getting attendance creating attendance using Aura Component. For the below requirement solution needed in asynchronous apex.

Requirement:- Create an automated process which runs every 3 days starting from 3rd day of the month to determine if the employee has any days where the attendance Status (Field) is –

1.Present, 
2.Less than 9.15
3.Status Unknown
4.Shortfall

Once the above is determined an email should trigger to the employee with manager in CC informing about the same 


Manager Field has self look up with employee object.

I need the above requirement solution implementation using asynchronous apex.

Below is the apex code for previos all requirements.

Apex Class:-

public class Employee_Attendance_Apex 
{
    @AuraEnabled
    public static ContactDataTableWrapper getAttendance( Integer pageNumber, Integer pageSize, String recordId, String eNumber, String sDate, String eDate, String empName) 
    {
        System.debug('getContactData '+empName);
        if(eNumber !=null && sDate != null && eDate != null || empName != null)
        {
            
            Date startDate = Date.valueOf(sDate);
            Date endDate   = Date.valueOf(eDate);
            //Offset for SOQL
            Integer offset = (pageNumber - 1) * pageSize;
            
              // Get the total number of records that match the criteria
        Integer totalRecords = [SELECT COUNT() FROM Attendance__c
                                WHERE (Date__c >= :startDate AND Date__c <= :endDate)
                                AND (Employee__r.Employee_ID__c = :eNumber OR Employee__c = :empName)];
            
            //Total Records
           // Integer totalRecords = [SELECT COUNT() FROM Attendance__c];
           // Integer recordEnd = pageSize * pageNumber;
            
            //Instance of Contact DataTable Wrapper Class
            ContactDataTableWrapper objDT =  new ContactDataTableWrapper();  
            objDT.pageSize = pageSize;
            objDT.pageNumber = pageNumber;
            objDT.recordStart = offset + 1;
           // objDT.recordEnd = totalRecords >= recordEnd ? recordEnd : totalRecords;
           System.debug('eNumber '+eNumber);
            objDT.recordEnd = Math.min(offset + pageSize, totalRecords);

            objDT.totalRecords = totalRecords;
            objDT.AttendanceList = [Select Id, Name, Employee__r.Name, Employee__c, Employee_Name__c, Employee__r.Employee_Name__c, Employee__r.Employee_ID__c, Date__c, Day__c, From_Time__c, To_Time__c, Total_Hours__c, Statuss__c from Attendance__c 
                                 WHERE (Date__c >= :startDate AND Date__c <= :endDate) AND (Employee__r.Employee_ID__c = :eNumber OR Employee__c =:empName) ORDER BY CreatedDate DESC LIMIT :pageSize OFFSET :offset];
            return objDT;
        }
        return null;
    } 
    
    @AuraEnabled
    public static ContactDataTableWrapper getAttendanceDownload(String recordId, String eNumber, String sDate, String eDate, String empName) 
    {
        System.debug('getContactData '+empName);
        if(eNumber !=null && sDate != null && eDate != null || empName != null)
        {
            
            Date startDate = Date.valueOf(sDate);
            Date endDate   = Date.valueOf(eDate);
            //Offset for SOQL
            //Integer offset = (pageNumber - 1) * pageSize;
            
            //Total Records
            Integer totalRecords = [SELECT COUNT() FROM Attendance__c];
            //Integer recordEnd = pageSize * pageNumber;
            
            //Instance of Contact DataTable Wrapper Class
            ContactDataTableWrapper objDT =  new ContactDataTableWrapper();  
            //objDT.pageSize = pageSize;
            //objDT.pageNumber = pageNumber;
            //objDT.recordStart = offset + 1;
            //objDT.recordEnd = totalRecords >= recordEnd ? recordEnd : totalRecords;
            //objDT.totalRecords = totalRecords;
            objDT.AttendanceList = [Select Id, Name, Employee__r.Name, Employee__c, Employee_Name__c, Employee__r.Employee_Name__c, Employee__r.Employee_ID__c, Date__c, Day__c, From_Time__c, To_Time__c, Total_Hours__c, Statuss__c from Attendance__c 
                                 WHERE (Date__c >= :startDate AND Date__c <= :endDate) AND (Employee__r.Employee_ID__c = :eNumber OR Employee__c =:empName) ORDER BY CreatedDate DESC];
            return objDT;
        }
        return null;
    } 
    
    @AuraEnabled
    public static List<Employee__c> getAttendanceByName(String empName) 
    {
        System.debug('getContactData '+empName);
        List<Employee__c> empRec = new List<Employee__c>();
        if(empName != '')
        {
            String empNameVal = '%'+empName+'%';
            empRec = [Select Id, Name from Employee__c Where Name Like:empNameVal Order By CreatedDate DESC];
        }
        return empRec;
    } 
    
    public class ContactDataTableWrapper {
        @AuraEnabled
        public Integer pageSize {get;set;}
        @AuraEnabled
        public Integer pageNumber {get;set;}
        @AuraEnabled
        public Integer totalRecords {get;set;}
        @AuraEnabled
        public Integer recordStart {get;set;}
        @AuraEnabled
        public Integer recordEnd {get;set;}
        @AuraEnabled
        public List<Attendance__c> AttendanceList {get;set;}
    }
    /*@AuraEnabled
    public static List<Attendance__c> getAttendance(String recordId, String eNumber, String sDate, String eDate, String empName){
        
        List<Attendance__c> AttendanceList = new List<Attendance__c>();
        if(eNumber !=null && sDate != null && eDate != null || empName != null){
            
            Date startDate = Date.valueOf(sDate);
            Date endDate   = Date.valueOf(eDate);
            
            AttendanceList = [Select Id, Name, Employee__r.Name, Employee__c, Employee__r.Employee_Name__c, Employee__r.Employee_ID__c, Date__c, Day__c, From_Time__c, To_Time__c, Total_Hours__c, Statuss__c from Attendance__c 
                              WHERE (Date__c >= :startDate AND Date__c <= :endDate) AND (Employee__r.Employee_ID__c = :eNumber OR Employee_Name__c =:empName) ORDER BY CreatedDate DESC];  
        }
        return AttendanceList;
    }*/
   
    @AuraEnabled
    public static String createAttendance(String recordId, String dateInput, String inTime, String outTime) {
        Attendance__c attendance = new Attendance__c();
        String result = '';
        Date dateValue;
        Time inTimeChange;
        Time outTimeChange;
        
        if (recordId != null) {
            try {
                Employee__c empRec = [SELECT Id, Name, OwnerId, Manager__c, Manager__r.Email__c
                                      FROM Employee__c
                                      WHERE Id = :recordId LIMIT 1];
                
                if (empRec != null) {
                    // Setting Attendance fields based on input parameters
                    attendance.Name = empRec.Name + ' 1';
                    attendance.Employee__c = empRec.Id;
                    
                    if (dateInput != null) {
                        dateValue = Date.valueOf(dateInput);
                        Date date1 = System.today();
                        Date date2 = dateValue;
                        Integer dateDifference = date2.daysBetween(date1);
                        
                        if (dateDifference >= 7) {
                            return 'dateDifference';
                        } else {
                            attendance.Date__c = dateValue;
                        }
                    }
                    
                    if (inTime != null) {
                        List<String> strTimeSplit = inTime.split(':');
                        inTimeChange = Time.newInstance(Integer.valueOf(strTimeSplit[0]), Integer.valueOf(strTimeSplit[1]), 0, 0);
                        attendance.From_Time__c = inTimeChange;
                    }
                    
                    if (outTime != null) {
                        List<String> strTimeSplit = outTime.split(':');
                        outTimeChange = Time.newInstance(Integer.valueOf(strTimeSplit[0]), Integer.valueOf(strTimeSplit[1]), 0, 0);
                        attendance.To_Time__c = outTimeChange;
                    }
                    
                    // Insert the Attendance record
                    insert attendance;
                    
                    // Get Manager's email
                    String managerEmail = empRec.Manager__r.Email__c;
                    
                    // Send email to Manager
                    if (managerEmail != null) {
                        String emailSubject = 'Attendance Record Approval';
                        String emailBody = 'A new attendance record requires your approval.' +
                            '\n\nRecord Link: ' + getRecordLink(attendance.Id);
                        
                        Messaging.SingleEmailMessage email = new Messaging.SingleEmailMessage();
                        email.setToAddresses(new List<String>{managerEmail});
                        email.setSubject(emailSubject);
                        email.setPlainTextBody(emailBody);
                        
                        Messaging.SendEmailResult[] results = Messaging.sendEmail(new Messaging.SingleEmailMessage[]{email});
                        if (results[0].isSuccess()) {
                            System.debug('Email sent successfully.');
                        } else {
                            System.debug('Failed to send email. Error: ' + results[0].getErrors()[0].getMessage());
                        }
                    }
                    
                    
                    // Submit the record for approval using the Approval.ProcessSubmitRequest class
                    Approval.ProcessSubmitRequest req = new Approval.ProcessSubmitRequest();
                    req.setComments('Submitting record for approval.');
                    req.setObjectId(Attendance.Id);
                    
                    // Make sure to use the correct Approval process name (replace 'Attendance_Approval' with your actual process name)
                    req.setProcessDefinitionNameOrId('Attendance_Approval');
                    
                    Approval.ProcessResult result2 = Approval.process(req);
                    
                    if (result2.isSuccess()) {
                        System.debug('Record submitted for approval successfully.');
                        // If the record is submitted for approval successfully, update the Status__c field to "Pending Approval"
                        update Attendance;
                    } else {
                        System.debug('Failed to submit record for approval. Error: ' + result2.getErrors());
                    }
                    result = 'true';
                }
            } catch (Exception ex) {
                System.debug('Ex: ' + ex.getMessage());
                result = 'false';
            }
        }
        return result;
    }
    // Helper method to get the Salesforce record link
    private static String getRecordLink(Id recordId) {
        String baseURL = URL.getSalesforceBaseUrl().toExternalForm();
        return baseURL + '/' + recordId;
    }
    @AuraEnabled 
    public static String updateAttendance(String row){
        
        System.debug('row '+row);  
        Map<String, Object> dataMap = (Map<String, Object>)JSON.deserializeUntyped(row);
        
        System.debug('Converted Map: ' + dataMap);
        System.debug('Key '+dataMap.get('Date'));
        
        String attId = (String)dataMap.get('Id');
        String dateInput = (String)dataMap.get('Date');
        String inTime = (String)dataMap.get('InTime');
        String outTime = (String)dataMap.get('OutTime');
        String result = '';
        
        Attendance__c att = [Select Id, Date__c, From_Time__c, To_Time__c from Attendance__c Where Id =:attId];
        
        if(dateInput!=null)
        {
            Date Datevalue = Date.valueOf(dateInput);
            Date date1 = att.Date__c;
            Date date2 = Datevalue;
            Integer dateDifference = date2.daysBetween(date1);
            
            if (dateDifference >= 7) {
                result = 'dateDifference';
            } else {
                att.Date__c = Datevalue;
            }
        }
        if (inTime != null) {
            String[] strTimeSplit = inTime.split(':');
            Time inTimeChange = Time.newInstance(Integer.valueOf(strTimeSplit[0]), Integer.valueOf(strTimeSplit[1]), 0, 0);
            att.From_Time__c = inTimeChange;
        }
        if (outTime != null) {
            String[] strTimeSplit = outTime.split(':');
            Time outTimeChange = Time.newInstance(Integer.valueOf(strTimeSplit[0]), Integer.valueOf(strTimeSplit[1]), 0, 0);
            att.To_Time__c = outTimeChange;
        }
        
        try{
            Update att; 
            result = 'true';
        }
        catch(Exception ex){
            System.debug(ex.getMessage());
            result = 'false';
        }
        return result;
    }
    @AuraEnabled
    public static String getManagerEmail(Id employeeId) {
        try {
            if (employeeId != null) {
                Employee__c empRec = [SELECT Id, Manager__c, Manager__r.Email__c 
                                      FROM Employee__c 
                                      WHERE Id = :employeeId LIMIT 1];
                
                // Check if the employee record has a manager and the manager has an email
                if (empRec != null && empRec.Manager__c != null && empRec.Manager__r != null && empRec.Manager__r.Email__c != null) {
                    return empRec.Manager__r.Email__c;
                }
            }
        } catch (Exception ex) {
            // Handle exceptions here, such as logging or returning an error message.
            System.debug('Error occurred while fetching Manager\'s Email: ' + ex.getMessage());
        }
        return null;
    }
   

}
So we have 2 Account objects. The standard one Account, and a custom one called Wholesale Account. (yeah, I know this is not really the best design but we are kinda stuck with it.)

We added Opportunity as a child of the custom object, but it still wants to always have an Opportunity connected to an Account. Is there some way to make an Opportunity that is attached to something other than a standard Account object?
Every day I want to use Salesforce API and send about 5000 records from our existing SQL Server database to Salesforce using API.

I am new to Salesforce but have experience working with API's.

What I want to know is do I use the BULK API for this?

Everything I have read says that to use the BULK API I have to upload the data using CSV.  Is it possible to upload directly from SQL Server to Salesforce using a .net app?

TIA!
Receiving error trying to make an HTTP Callout to a REST API using a simple Auth. Provider (Open ID Connect) and a Named Credential. No custom Apex class...  
Error:  SyntaxError: Unexpected token N in JSON at position 1073

Hi,
I am receiving the following error message when trying to add a Product to a Renewal Opportunity:

"Can't update Price Book. Unexpected exception while validating invocable action requests"

I have recently implemented a few Flows for the Opportunity object, but none of those Flows include any fields related to Price Books or Products. Once I deactivated one of those Flows (to standardize the Opportunity Name), I was able to add a Product to the Opportunity, no problem.

Does anyone have any insight as to why this Flow would be causing an issue with the Products and Price Books if the Flow was seemingly unrelated?User-added image

Hi,
 
I have a flow and in the result, I get this:
 
Result
Failed to find records.
________________________________________
Error Occurred: Too many SOQL queries: 101
 
This means the flow has two errors? 1- Failed to find records with those logic and 2- Too many SOQL queries
OR it just has one error of too many SOQL queries and because of that it couldn't find any records?
 
Can Somebody Explain ?? do we need to change the fields in Contact 
whenever we we change any field in account ?? I am not getting this scenario...
I have a trigger and i am trying to create a test class. But not sure how to write test class to fulfill the test coding coverage for test apex class


TRIGGER:



trigger opportunitytrigger on opportunity(after update){
    Set<Id> oppIds = new Set<Id>();
   // Set<Id> oppWithContractAgreement = new Set<Id>();
     List<APXT_Redlining__Contract_Agreement__c> oppWithContractAgreement = new List<APXT_Redlining__Contract_Agreement__c>();
     List<Opportunity> opportunity = new List<Opportunity>();
     
    for(opportunity opp:Trigger.new)
    {
        if(opp.Stagename=='Closed Won')
        {
            oppIds.add(opp.id);
            opportunity.add(opp);

        }

    }

List<APXT_Redlining__Contract_Agreement__c> con =[Select Id, Opportunity__c,APXT_Redlining__Status__c,Verified_Signed_IO__c from APXT_Redlining__Contract_Agreement__c  where Opportunity__c IN :oppIds];
    
    {
     if(con.size()>0)
     system.debug(+con.size());
      
      {
          for(APXT_Redlining__Contract_Agreement__c c :con)
          
          {
          if( c.APXT_Redlining__Status__c == 'Active' && c.Verified_Signed_IO__c ==FALSE){
            oppWithContractAgreement.add(c);
            system.debug('-----------'+oppWithContractAgreement.size());
            }
}
      }
    }

 For(Opportunity opps:opportunity)
 {
    if(oppWithContractAgreement.size()>0)
    {
        system.debug(oppWithContractAgreement.size());
        opps.addError('Closed Won Opportunity must need to have active contract agreement and customer signed date captured or Closed Won Opportunity must need to have active contract agreement');
    }
    
    if(con.size()==0)
    {
        opps.addError('Closed Won Opportunity must need to have contract agreement' );
    }
    
 }

}


TEST CLASS:

@isTest
private class OpportunityTriggerHandler1_Test {
    
    @isTest static void testCreateOpportunityTarget() {
        
        //create Account
        Account acc = new Account();
        acc.Name = 'Test Account';
        insert acc;
        
        
        Test.startTest();
        
        Opportunity opp = new Opportunity();
        opp.AccountId = acc.Id;
        opp.Name = 'Test Opportunity';
        opp.StageName = 'Closed Won';
        opp.CloseDate = Date.Today().addDays(20);
        insert opp;
        
        Test.stopTest();
        
        List<APXT_Redlining__Contract_Agreement__c> CA = new List<APXT_Redlining__Contract_Agreement__c>();
        CA = [Select Id, Opportunity__c,APXT_Redlining__Status__c,Verified_Signed_IO__c from APXT_Redlining__Contract_Agreement__c ];

        System.assert(CA[0].Opportunity__c == opp.Id); 
    }      
}
Hi, 

I want to send notification to few contacts on 1st of every month without writing Schedulable Job. I have checked Scheduled Flow but it doesn't have option for sending every month. Is there any other solution available through point and click. 
trigger CaseDemoRecordType on Case (After insert , After update)
{
    if((trigger.isAfter) && (trigger.isinsert || trigger.isupdate))
    {
    List<RecordType> recordTyp = [Select id , Name , Sobjecttype from RecordType];
    List<Case> LstCs = [select id , CaseNumber , RecordTypeId from case ]; 
    
    For(Case cs : Trigger.new)
    {
        For(RecordType RecTyp : recordTyp )
        {
            
          If(cs.RecordTypeID == RecTyp.id)
        {
            if(RecTyp.Name == 'School zone')
            {
                cs.Description = 'This is SCHOOL ZONE';
                system.debug('This is SCHOOL zONE^^^^^'+RecTyp.Name);
            }
            else
                cs.Description = 'This is COLLEGE ZONE';
                system.debug('This is COLLEGE zONE......'+RecTyp.Name);
            
            system.debug('The REcord Type Ids..............'+cs.RecordTypeId);

        }
        }
                            update cs;

    }

    }
}