1
votes

I am using Page block table on visual force page and each row has radio buttons , i want to pass the value of each selected radio button , from each row on visual force page to apex Controller class.

For Now i am getting only one Value of last Row , I need Each Value of selected radio Buttons.

Visual Force Page

    <apex:pageBlockTable value="{!SurveyQuestions}" var="sq">
        <apex:column value="{!sq.Id}"/>
        <apex:column value="{!sq.Name}"/>
        <apex:column value="{!sq.QuestionID__r.Question__c}"/>
        <apex:column value="{!sq.QuestionID__r.Id}" headerValue="Question ID"/>
        <apex:column headerValue="HiddenQuestion Id">
         <apex:inputHidden value="{!sq.QuestionID__r.Id}" id="HdnQuestionID"/> 
        </apex:column>  
        <apex:column headerValue="Question options">
            <apex:selectRadio value="{!selectedAnswer}">
              <apex:selectOptions value="{!items}"/>
            </apex:selectRadio> 
        </apex:column>   
    </apex:pageBlockTable>

Apex Controller Class

public with sharing class GbPracticeController {

public tblSurvey__c SurveyObj {get;set;}

public string SelectedAnswer                 {get;set;}
public list<tblSurveyQuestion__c> SurveyQuestions {get;set;}

public GbPracticeController(ApexPages.StandardController controller) {
        SurveyObj = new tblSurvey__c(); 

}


public PageReference SaveSurvey() {  
    insert SurveyObj;
    ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,'Survey Submitted Successfully'));

    return null;
}

//Listing Survey Related Questions
public ApexPages.StandardSetController setSurveyQuestions {
    get {
        if(setSurveyQuestions == null) {
            setSurveyQuestions = new ApexPages.StandardSetController(Database.getQueryLocator(
                [SELECT Id,Name,fo__QuestionID__c,fo__SurveyID__c, fo__QuestionID__r.Id,fo__QuestionID__r.Name,fo__QuestionID__r.fo__Question__c, fo__QuestionID__r.fo__SelectedAnswer__c  FROM fo__tblSurveyQuestion__c WHERE fo__SurveyID__c = 'a0R28000000FfXaEAK']));
        }
        return setSurveyQuestions;
    }
    set;
}
// Initialize getSurveyQuestions and return a list of records
public List<tblSurveyQuestion__c> getSurveyQuestions() {
    return (List<tblSurveyQuestion__c>) setSurveyQuestions.getRecords();
}

public List<SelectOption> getItems() {
    List<SelectOption> options = new List<SelectOption>(); 
    options.add(new SelectOption('yes','Yes')); 
    options.add(new SelectOption('no','No')); 
    options.add(new SelectOption('Maybe','maybe')); 
    return options; 
}

public PageReference SubmitResult() {

// Multiple Checkbox value Logic Goes Here
for (SurveyQuestionsType sqItem : SurveyQuestions) {
        if(sqItem.SelectedAnswer__c == 'yes') {

               //Inserting The Survey Result        
               tblSurveyResult__c SurveyResult = new tblSurveyResult__c(
                      Name = sqItem.SelectedAnswer__c,
                      Answer__c = 1
                     );
               insert SurveyResult;


            ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,'Survey Submitted Successfully'));

        } else if (sqItem.SelectedAnswer__c == 'no'){

            ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,sqItem.SelectedAnswer__c));

        } else {
            ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,'Please Select Atleast one value'));
        }
    }
    return null;
}
// qwerty
}
2

2 Answers

1
votes

Answering My Own Question , might be helpful for someone else

VF Page

<apex:pageBlockTable value="{!SurveyQuestions}" var="sq">
        <apex:column value="{!sq.Id}"/>
        <apex:column value="{!sq.Name}"/>
        <apex:column value="{!sq.QuestionID__r.Question__c}"/>
        <apex:column value="{!sq.QuestionID__r.Id}" headerValue="Question ID"/>
        <apex:column headerValue="HiddenQuestion Id">
          <apex:inputHidden value="{!sq.QuestionID__r.Id}"/>
        </apex:column>  
        <apex:column headerValue="Question options">
            <apex:selectRadio value="{!sq.QuestionID__r.SelectedAnswer__c}">
              <apex:selectOptions value="{!items}"/>
            </apex:selectRadio> 
        </apex:column>  
    </apex:pageBlockTable>

    <apex:commandButton value="Submit Survey Result" action="{!SubmitSurvey}" rerender="StartSurveyForm"/>


Apex Class Code

public PageReference SubmitSurvey() {

// Multiple Checkbox value Logic Goes Here

for (tblSurveyQuestion__c sqItem : getSurveyQuestions()) {
    if(sqItem.QuestionID__r.SelectedAnswer__c == 'yes'){

               //Inserting The Survey Result

               tblSurveyResult__c SurveyResult = new tblSurveyResult__c(
                      Name = sqItem.QuestionID__r.SelectedAnswer__c,
                      Answer__c = decimal.valueof('1'),
                      QuestionID__c = sqItem.QuestionID__r.Id,
                      SurveyID__c= surveyId
                     );
               insert SurveyResult;

        }  else{

              ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,'Please Select Atleast one value'));  
        }
    }
ApexPages.addmessage(new ApexPages.message(ApexPages.severity.CONFIRM,’Survey Result Successfully Submitted'));  
    return null;}
0
votes

I suggest you add a new custom field, like SelectedAnswer, change

apex:selectRadio value="{!selectedAnswer}">

to

apex:selectRadio value="{!sq.SelectedAnswer__c}">

and controller changed to

public PageReference SubmitSurvey() {

// Multiple Checkbox value Logic Goes Here
foreach (SurveyQuestionsType sqItem : getSurveyQuestions()) {
if(sqItem.SelectedAnswer__c == 'yes'){

           //Inserting The Survey Result

           tblSurveyResult__c SurveyResult = new tblSurveyResult__c(
                  Name = sqItem.SelectedAnswer__c,
                  Answer__c = 1
                 );
           insert SurveyResult;


    ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,'Survey Submitted Successfully'));

} else if (sqItem.SelectedAnswer__c == 'no'){

    ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,sqItem.SelectedAnswer__c));

} else {
    ApexPages.addmessage(new ApexPages.message(ApexPages.severity.ERROR,'Please Select Atleast one value'));
}
}
return null;
}

Or, instead of adding just a field to your custom object, you can create a DTO of this object with new SelectedAnswer field and work with DTO.

Also, during error output, I would add indication of what was answered wrong.