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
}