• Veerendar Aella
  • NEWBIE
  • 90 Points
  • Member since 2018

  • Chatter
    Feed
  • 0
    Best Answers
  • 0
    Likes Received
  • 0
    Likes Given
  • 16
    Questions
  • 20
    Replies
I want to send warning email alerts to users who's last login greater than 90 days. Please help.
Hi All, I want a trigger to move quote status from ready to price to proposed when a quote option is created. Here Quote is the Parent Object and Quote Option is the child. So, when ever a quote option is created, I want to move my quote status to proposed. Please hlep.
Please also need test class for the trigger.
Hi All,

I am getting the above error when i try to import an xml file into the org, please help.

Error:
 Visualforce Error
Help for this Page
System.XmlException: Failed to parse XML due to: expected name start and not < (position: TEXT seen ...<CloseDate>2018-12-18</<... @6:33)
Error is in expression '{!doUpload}' in component <apex:commandButton> in page importoppxml: Class.ImportOppXML.doUpload: line 124, column 1
Class.ImportOppXML.doUpload: line 124, column 1

Apex Code: 
public class ImportOppXML {
    

    public Blob myfile{get;set;}

       public ImportOppXML(){

        reports = new List<Opportunity>();

    }

     

    public List<Opportunity> reports {get;set;}

     

    public class Oppdata {

        public String Name {get; set;}

        public Decimal Amount {get; set;}

        public Date CloseDate {get; set;}
        
        public String Description {get; set;}

        public String LeadSource {get; set;}
        
        public String NextStep {get; set;}
        
        public String StageName {get; set;}
        
        public String Type {get; set;}
        
     
    }

 
    private void parseReports(DOM.XMLNode node) {

        for (Dom.XMLNode child : node.getChildElements()) {

            if (child.getName() == 'record') {

                System.debug('child'+child);

                parseReport(child);

                //  reports.add(r);

            }

            System.debug('reports'+reports);

        }

    }

     

    private void parseReport(DOM.XMLNode node ) {

        opportunity r = new opportunity();

         

        for (Dom.XMLNode child : node.getChildElements()) {

            if (child.getName() == 'Name') {

                r.Name= child.getText().trim();

            } else if (child.getName() == 'Amount') {

                r.Amount= decimal.valueof(child.gettext().trim());
                

            } else if (child.getName() == 'CloseDate') {

                r.CloseDate= Date.valueof(child.getText().trim());

            }  else if (child.getName() == 'Description') {

                r.Description= child.getText().trim();
            
            }  else if (child.getName() == 'LeadSource') {

                r.LeadSource= child.getText().trim();
                 

            }else if (child.getName() == 'NextStep') {

                r.NextStep= child.getText().trim();
                 

            }else if (child.getName() == 'StageName') {

                r.StageName= child.getText().trim();
                
            }else if (child.getName() == 'Type') {

                r.Type= child.getText().trim();
                
                
            
            }
        }

        reports.add(r);

         upsert    reports;

    }

     

    public void doUpload() {

         

        DOM.Document doc = new DOM.Document();

        doc.load(String.valueOf(myfile.toString()));   

        parseReports(doc.getRootElement());

         

         

    }

     

}

VF:

<apex:page Controller="ImportOppXML">

        <apex:form >       

            <apex:pageblock title="Import Opportunities From XML" id="PB">
   
                <!-- inputFile for uploading XML -->

                <apex:pageblocksection >

                    <apex:pageblocksectionitem >

                        <apex:outputLabel value="Please Select XML File:"/> 

                        <apex:inputFile value="{!myfile}"> </apex:inputFile>

                    </apex:pageblocksectionitem>               

                    </apex:pageblocksection>

                <!-- Table to show the XML Result -->

                <apex:pageblocksection title="Result of XML file" columns="1" rendered="{!reports.size != null}">

                    <apex:pageblocktable value="{!reports}" var="opp">

                        <apex:column value="{!opp.Name}" headerValue="Name" />
                        <apex:column value="{!opp.Amount}" headerValue="Amount" />
                        <apex:column value="{!opp.CloseDate}" headerValue="CloseDate" />
                        <apex:column value="{!opp.Description}" headerValue="Description" />
                        <apex:column value="{!opp.LeadSource}" headerValue="LeadSource" />
                        <apex:column value="{!opp.NextStep}" headerValue="NextStep" />
                        <apex:column value="{!opp.StageName}" headerValue="StageName" />
                        <apex:column value="{!opp.Type}" headerValue="Type" />
                         

                    </apex:pageblocktable>

                </apex:pageblocksection>

                <!-- Button for calling method of controller -->

                <center>

                    <apex:commandButton value="Import Opportunities" action="{!doUpload}"/>

                </center>

            </apex:pageblock>   
            
            

            
            
            

        </apex:form>   

          

    </apex:page>

XML file: 

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Opp-data >
    <record>
        <Name>zipzip</Name>
        <Amount>65023</Amount>
        <CloseDate>2018-12-18</<CloseDate>
        <StageName>Prospecting</StageName>
    </record>
    
</Opp-data>
 
Hi All,

Below is my Code for Importing XML into Salesforce org.

Apex Code: 

public class ImportOppXML {
    

    public Blob myfile{get;set;}

       public ImportOppXML(){

        reports = new List<Opportunity>();

    }

     

    public List<Opportunity> reports {get;set;}

     

    public class Oppdata {

        public String Name {get; set;}

        public Decimal Amount {get; set;}

        public Date CloseDate {get; set;}
        
        public String Description {get; set;}

        public String LeadSource {get; set;}
        
        public String NextStep {get; set;}
        
        public String StageName {get; set;}
        
        public String Type {get; set;}
        
     
    }

 
    private void parseReports(DOM.XMLNode node) {

        for (Dom.XMLNode child : node.getChildElements()) {

            if (child.getName() == 'record') {

                System.debug('child'+child);

                parseReport(child);

                //  reports.add(r);

            }

            System.debug('reports'+reports);

        }

    }

     

    private void parseReport(DOM.XMLNode node ) {

        opportunity r = new opportunity();

         

        for (Dom.XMLNode child : node.getChildElements()) {

            if (child.getName() == 'Name') {

                r.Name= child.getText().trim();

            } else if (child.getName() == 'Amount') {

                r.Amount= child.gettext().trim();

            } else if (child.getName() == 'CloseDate') {

                r.CloseDate= child.getText().trim();

            }  else if (child.getName() == 'Description') {

                r.Description= child.getText().trim();
            
            }  else if (child.getName() == 'LeadSource') {

                r.LeadSource= child.getText().trim();
                 

            }else if (child.getName() == 'NextStep') {

                r.NextStep= child.getText().trim();
                 

            }else if (child.getName() == 'StageName') {

                r.StageName= child.getText().trim();
                
            }else if (child.getName() == 'Type') {

                r.Type= child.getText().trim();
                
                
            
            }
        }

        reports.add(r);

         upsert    reports;

    }

     

    public void doUpload() {

         

        DOM.Document doc = new DOM.Document();

        doc.load(String.valueOf(myfile.toString()));   

        parseReports(doc.getRootElement());

         

         

    }

     

}

User-added image
Hi All,

I have an Apex class for importing Json file into the salesforce org, I need a test for this apex code. Please help.

Apex Code: 
public class ParserJson_New{
    

    public Blob myfile{get;set;}

    public ParserJson_New(){

        reports =  new fromJSON();

    }

     

    public fromJSON reports {get;set;}
   
    public void doUpload() {
        
        System.debug('myfile'+myfile.toString());

        reports =  (fromJSON) System.JSON.deserialize(myfile.toString(), fromJSON.class);
        
         List<cls_record> rec = reports.leaddata.record ;

        List<Lead> leadList = new List<Lead>();

        for(cls_record c :rec){

            leadList.add( new Lead( FirstName =c.FirstName ,LastName = c.LastName , Phone =c.Phone , 
                                   Email =c.Email, Company =c.Company, Fax =c.Fax, Description =c.Description
                                  , Industry =c.Industry, Status =c.Status, Website =c.Website, LeadSource =c.LeadSource));

        }

        insert leadList;

    }

    public class fromJSON{

        public cls_leaddata leaddata{get;set;}

    }

    public class cls_leaddata {

        public cls_record[] record{get;set;}

    }

    public  class cls_record {

        public String FirstName{get;set;}   
        public String LastName{get;set;}    
        public String Phone{get;set;}   
        public String Email{get;set;}   
        public String Company{get;set;}
        public String Fax{get;set;}
        public String Description{get;set;}
        public String Industry{get;set;}
         public String Status{get;set;}
         public String Website{get;set;}
         public String LeadSource{get;set;}
    }
}

Json File: 

{

    "leaddata": {

        "record": [

            {

                "FirstName": "Zepra",

                "LastName": "Json",

                "Phone": "8008237678",

                "Email": "Zepra@gmail.com",

        "Company": "Zepra Inc",
        
        "Fax": "143215",

        "Industry": "Zepra",

        "Description": "This is my Zepra Json",

        "Status": "Working -Contacted",

        "Website": "WWW.ZepraJson.com",
    
        "LeadSource": "Web"
            }

            
        ]

    }

}
 
Hi All,

I have an apex class for importing xml data into salesforce org, I need a test class code to test the data. Please help.
Below is my apex class:

public class ImportAccountsXML {
    

    public Blob myfile{get;set;}

       public ImportAccountsXML(){

        reports = new List<Account>();

    }

     

    public List<Account> reports {get;set;}

     

    public class Accdata {

        public String Name {get; set;}

        public String AccountNumber {get; set;}

        public String Phone {get; set;}
        
        public String Industry {get; set;}

        public String type {get; set;}
        
        public String Description {get; set;}
        
        public String Site {get; set;}
        
        public String Ownership {get; set;}
        
        public String Sic {get; set;}
        
        public String Website {get; set;}
         

    }

 
    private void parseReports(DOM.XMLNode node) {

        for (Dom.XMLNode child : node.getChildElements()) {

            if (child.getName() == 'record') {

                System.debug('child'+child);

                parseReport(child);

                //  reports.add(r);

            }

            System.debug('reports'+reports);

        }

    }

     

    private void parseReport(DOM.XMLNode node ) {

        account r = new account();

         

        for (Dom.XMLNode child : node.getChildElements()) {

            if (child.getName() == 'Name') {

                r.Name= child.getText().trim();

            } else if (child.getName() == 'AccountNumber') {

                r.AccountNumber= child.getText().trim();

            } else if (child.getName() == 'Phone') {

                r.Phone= child.getText().trim();

            }  else if (child.getName() == 'Industry') {

                r.Industry= child.getText().trim();
            
            }  else if (child.getName() == 'Type') {

                r.Type= child.getText().trim();
                 

            }else if (child.getName() == 'Ownership') {

                r.Ownership= child.getText().trim();
                 

            }else if (child.getName() == 'Sic') {

                r.Sic= child.getText().trim();
                
            }else if (child.getName() == 'Description') {

                r.Description= child.getText().trim();
                
                
            }else if (child.getName() == 'Website') {

                r.Website= child.getText().trim();
                
            }else if (child.getName() == 'Site') {

                r.Site= child.getText().trim();
            }
        }

        reports.add(r);

         upsert    reports;

    }

     

    public void doUpload() {

         

        DOM.Document doc = new DOM.Document();

        doc.load(String.valueOf(myfile.toString()));   

        parseReports(doc.getRootElement());

         

         

    }

     

}
Hi All,

I am getting above error in my test class at 16 and 40, below is my code.
Please help.

Apex class:

public class ImportCSV1 {

    public Blob csvFileBody{get;set;}
    public  string csvAsString{get;set;}
    public  String[] csvFileLines{get;set;}
    public List<account> acclist{get;set;}
    public ImportCSV1(){
    csvFileLines = new String[]{};
    acclist = New List<Account>(); 
  }
  
  public  void importCSVFile(){
       try{
           csvAsString = csvFileBody.toString();
           csvFileLines = csvAsString.split('\n'); 
            
           for(Integer i=1;i<csvFileLines.size();i++){
               Account accObj = new Account() ;
               string[] csvRecordData = csvFileLines[i].split(',');
               accObj.name = csvRecordData[0] ;             
               accObj.accountnumber = csvRecordData[1];
               accObj.Phone = csvRecordData[2];
               accObj.Industry = csvRecordData[3]; 
               accObj.Type = csvRecordData[4];
               accObj.Description = csvRecordData[5];
               accObj.Website = csvRecordData[6];
               accObj.Site = csvRecordData[7];
               accObj.Ownership = csvRecordData[8];
               accObj.Sic = csvRecordData[9];
               acclist.add(accObj);   
           }
        insert acclist;
        }
        catch (Exception e)
        {
            ApexPages.Message errorMessage = new ApexPages.Message(ApexPages.severity.ERROR,'An error has occured while importin data Please make sure input csv file is correct');
            ApexPages.addMessage(errorMessage);
        }  
  }
}


Apex test class:

@istest
public class Test1 {
   
   public class ImportDataFromCSVControllerTest {

       public String str = 'Name,AccountNumber,Phone,Industry\n Esha Patharabe,10001,989632145,Banking\n Trupti Nimje,10002,875469856,Banking';      

        String csvAsString;

      String[] csvFileLines;

      Blob csvFileBody;

 

    public  testmethod void testfileupload(){

        Test.startTest();      

        csvFileBody = Blob.valueOf(str);

         String csvAsString = csvFileBody.toString();

        csvFileLines = csvAsString.split('\n');

 

        ImportCSV1 importData = new ImportCSV1();

        importData.csvFileBody = csvFileBody;

        importData.importCSVFile();

        Test.stopTest();

    }

 

    public  testmethod void testfileuploadNegative(){

        Test.startTest();      

        csvFileBody = Blob.valueOf(str);

        String csvAsString = csvFileBody.toString();

        csvFileLines = csvAsString.split('\n');

 

        ImportCSV1 importData = new ImportCSV1();

        importData.importCSVFile();

        Test.stopTest();

    }

}
}
Hi all,

I am using office 2007, and I want to setup excel connector. Please help me with step by step flow.
Thanks in advance.
 
Hi All,

I want to import Json file into my leads record using apex and visualforce page.
Please help.
 
Hi All,

I want to import an xml file into my lead records using the apex code and visualforce page on a single click from the page.
here is my sample xml file:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<lead-data >
    <record>
        <FirstName>Veera</FirstName>
        <LastName>Vinnu</LastName>
        <Phone>8008997654</Phone>
        <Email>veerav@gmail.com</Email>
    </record>
    <record>
        <FirstName>Beera</FirstName>
        <LastName>Binnu</LastName>
        <Phone>9898989898</Phone>
        <Email>beeru@gmail.com</Email>
    </record>
    <record>
        <FirstName>Ceera</FirstName>
        <LastName>Cinnu</LastName>
        <Phone>8989898989</Phone>
        <Email>ceera@gmail.com</Email>
    </record>
    <record>
        <FirstName>Deera</FirstName>
        <LastName>Dinnu</LastName>
        <Phone>7878787878</Phone>
        <Email>deera@gmail.com</Email>
    </record>
</lead-data>


Please help me out.