I am creating three level drop-down list from the array of objects which I fetched from the API(dynamic data). I tried removing the duplicate values from ssmlGender(Voice gender) field and did try different methods. But, couldn't fetch the right data.
In first drop-down list, I am displaying the gender: "Female" and "Male" from "ssmlGender" field. When the user selects the male or female in the first drop-down list, the second drop-down list must be populated with "languageCodes" available for the particular gender. When the language code is selected, the "name" field which has the both the selected gender and languageCodes should be displayed.
Sample Array:
0: {languageCodes: Array(1), name: "es-ES-Standard-A", ssmlGender: "FEMALE", naturalSampleRateHertz: 24000}
1:
{languageCodes: Array(1), name: "it-IT-Standard-A", ssmlGender: "FEMALE", naturalSampleRateHertz: 24000}
2:
{languageCodes: Array(1), name: "ja-JP-Standard-A", ssmlGender: "FEMALE", naturalSampleRateHertz: 22050}
3:
{languageCodes: Array(1), name: "ko-KR-Standard-A", ssmlGender: "FEMALE", naturalSampleRateHertz: 22050}
8:{languageCodes: Array(1), name: "en-US-Wavenet-D", ssmlGender: "MALE", naturalSampleRateHertz: 24000}
9:
{languageCodes: Array(1), name: "en-US-Wavenet-A", ssmlGender: "MALE", naturalSampleRateHertz: 24000}
10:
{languageCodes: Array(1), name: "en-US-Wavenet-B", ssmlGender: "MALE", naturalSampleRateHertz: 24000}
11:
{languageCodes: Array(1), name: "en-US-Wavenet-C", ssmlGender: "FEMALE", naturalSampleRateHertz: 24000}
12:
{languageCodes: Array(1), name: "en-US-Wavenet-E", ssmlGender: "FEMALE", naturalSampleRateHertz: 24000}
13:
{languageCodes: Array(1), name: "en-US-Wavenet-F", ssmlGender: "FEMALE", naturalSampleRateHertz: 24000}
14:
{languageCodes: Array(1), name: "en-GB-Standard-A", ssmlGender: "FEMALE", naturalSampleRateHertz: 24000}
15:
{languageCodes: Array(1), name: "en-GB-Standard-B", ssmlGender: "MALE", naturalSampleRateHertz: 24000}
When we click on the particular array, it will display the data as given in this link: https://i.sstatic.net/BFYGm.jpg
My HTML:
<div class="row">
<label>Voice Gender</label>
<div class="input-field col s12">
<select id="gender">
<option value="" selected>Choose your option</option>
</select>
</div>
</div>
<div class="row">
<label>Voice Language</label>
<div class="input-field col s12">
<select id="languages">
<option value="" selected>Choose your languages</option>
</select>
</div>
</div>
<div class="row">
<label>Voice Name</label>
<div class="input-field col s12">
<select id="entries">
<option value="" selected>Choose your option</option>
</select>
</div>
</div>
My JavaScript:
for(var i=0;i<response.result.voices.length;i++){
var values= response.result.voices;
//To remove the duplicate value of "Male" and "Female" iteration and to display only once.
var valueArr = values.map(function(item){ return item.ssmlGender });
var isDuplicate = valueArr.some(function(item, idx){
return valueArr.indexOf(item) != idx
});
console.log(isDuplicate);
$('#entries').append('<option value='+(i+1)+'>' + response.result.voices[i].name+ '</option>');
//Added custom options of "MALE" AND "FEMALE" directly into the voice gender field of HTML to remove the duplicate values.But, it didn't work out.
/*if(document.getElementById("gender").value=="FEMALE"){
if(response.result.voices[i].ssmlGender=="FEMALE")
{
finalLanguages=response.result.voices[i].languageCodes;
}
}
if(document.getElementById("gender").value =="MALE"){
if(response.result.voices[i].ssmlGender=="MALE")
{
finalLanguages=response.result.voices[i].languageCodes;
}
}
$("#languages").append('<option value=' + (i+1)+ '>'+finalLanguages+ '</option>');*/
}
Thanks so much.