• klocwork
  • NEWBIE
  • 0 Points
  • Member since 2011

  • Chatter
    Feed
  • 0
    Best Answers
  • 0
    Likes Received
  • 0
    Likes Given
  • 6
    Questions
  • 4
    Replies

Greetings!

 

I'm setting up a Customer Community for my clients to access my instance of salesforce to open and track their own Cases.  I went through he setup steps outlined to enable users and was in the process of testing the visibility of community users to their cases (where they are the contact on the case) and discovered that while logged in as a community user I can see all cases, and can open the records.

 

Is there a permission setting for Customer Community I am missing?

 

Greetings!

 

I've been backwards and forwards through the forums here looking at the examples of solutions to "System.LimitException: Too many code statements: 200001" errors and have made a number of the suggested modifications (that I can figure out) to my code below.  I am easily able to update a handful of records, but as soon as I try to push 50 or more through the trigger I get the error.

 

I am swimming in the deep end and beyond my current comfort.  I would sincerely appreciate some input and guidance on how I can best address the issue I'm seeing!

 

The intent of this code is to align the OwnerId of all related Leads and Contacts when an Account either has a new Owner assigned, or when a check box is selected.  Stipulations - the Account and the Lead records must have North American Country values.

 

 

Thanks

 

 

 

trigger Account_ChangeOwner on Account (before update) {
//This trigger updates Lead and Contact Owners based on either a new Account Owner or a selected check box

	integer counter=0;
	Set<Id> AccountIds = new Set<Id>();
	For (Account Obj : trigger.new){

//Only applies to North American Accounts
		if (Obj.BillingCountry!=null && (
       			Obj.BillingCountry=='CA' || 
       			Obj.BillingCountry=='US' ||
       			Obj.BillingCountry=='Canada' ||
       			Obj.BillingCountry=='United States')  
       			)
       				{
       					if (Obj.OwnerId!=trigger.old[counter].OwnerId)
       					{
       						AccountIds.add(Obj.Id);
       					}
       					else if (Obj.Reset_Contact_Owners__c==true)
       					{
		       				AccountIds.add(Obj.Id);
       					}
       				}

       	counter++;
    }//end of loop 1
    
//Gather all relevant Leads and Conacts and add them to Lists
	list<Lead> Lead_list = [Select 		l.Id,
										l.Account_Record__c,
										l.OwnerId
									From Lead l
										where l.IsDeleted=false 
										and l.IsConverted=false 
										//Only applies to North American Leads
										and (l.Country!=null and (
							       			l.Country='CA' or 
							       			l.Country='US' or
							       			l.Country='Canada' or
							       			l.Country='United States'))
										and Account_Record__c IN :AccountIds]; 

	list<Contact> Contact_list = [Select 	c.Id,
											c.AccountId,
											c.OwnerId
									From Contact c
										where c.IsDeleted=false 
										and AccountId IN :AccountIds]; 

//Make the changes
	counter=0;
    For (Account Obj : trigger.new){
		if (Obj.OwnerId!=trigger.old[counter].OwnerId || Obj.Reset_Contact_Owners__c==true){

					//Review the Leads and Contacts for the Acounts and change the Owner;
		       		For (Lead MyLead : Lead_list){
		       			if (MyLead.Account_Record__c==Obj.Id){
		       				if (Obj.Named_Account__c==true){
				       				MyLead.OwnerId=Obj.OwnerId;								
		       				}
		       			}
       				}       			
       				{
		       		For (Contact MyContact : Contact_list){
		       			if (MyContact.AccountId==Obj.Id){
		       				MyContact.OwnerId=Obj.OwnerId;
		       			}
		       		}
       				}
       	}

		//Clear the Reset Contact Owners field
      	if (Obj.Reset_Contact_Owners__c==true){
			   Obj.Reset_Contact_Owners__c=false;
       	}
       	      	
       	counter++;
	}//end of loop 2 

//Process Leads		
	Lead[] LeadsToUpdate=new Lead[]{};
	For (Lead MyLead : Lead_list){
		LeadsToUpdate.add(MyLead);
		if (LeadsToUpdate.size()==5000){
			update LeadsToUpdate; 
			LeadsToUpdate.clear();
		}
	}
	if (LeadsToUpdate.size()>0){
		update LeadsToUpdate;
	}

//Process Contacts	
	Contact[] ContactsToUpdate=new Contact[]{};
	For (Contact MyContact : Contact_list){
		ContactsToUpdate.add(MyContact);
		if (ContactsToUpdate.size()==5000){
			update ContactsToUpdate; 
			ContactsToUpdate.clear();
		}
	}
	if (ContactsToUpdate.size()>0){
		update ContactsToUpdate;
	}
	
    
}//end of trigger

 

I am spinning my wheels on this and completely stumped.  When I try this code I get "A problem with the OnClick JavaScript for this button or link was encountered: Unexpected identifier".

 

What I am trying to do is update a custom object (Sales_Cycle__c) and the Lead record that it relates to (Sales_Cycle__c.Lead__c).

 

Any help would be greatly appreciated!

 

Thank you.

 

{!REQUIRESCRIPT("/soap/ajax/26.0/connection.js")}
var CycleUpdate = new sforce.SObject("Sales_Cycle__c");
var l = SELECT Id, Status FROM Lead where Id =\'"+ CycleUpdate.Lead__c + "\' limit 1";
CycleUpdate.Id='{!Sales_Cycle__c.Id }';
CycleUpdate.Sales_Cycle_Status__c = 'No Further Interest';
CycleUpdate.Date_Sales_Cycle_Ended__c = new Date();
l.Status = 'No Further Interest';
update CycleUpdate;
update l;
window.location.reload();

 

Spinning my wheels on this.  I'm not an APEX coder but this problem is within my skill set.

 

I am trying to check to see if "Account_Record__c" on "Lead" is null - and then insert a record if it is.  No errors when I save the code, but when I test none of the records are behaving as expected!  In my test records there are no values in "Account_Record__c" yet the related object record is not created.  If I remove the "&& newLead.Account_Record__c==null" element then the related record is created.

 

What am I missing?

 

 

trigger createSalesAssignment on Lead (after update) {     
List<Sales_Assignment__c> sa = new List<Sales_Assignment__c>();
    for (Lead newLead: Trigger.New)
         if (newLead.Status == 'Sales Ready' && newLead.Account_Record__c==null){
                 sa.add (new Sales_Assignment__c(
                     Lead__c = newLead.Id));   
         }
   insert sa;

 }