-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpopup.js
60 lines (53 loc) · 1.87 KB
/
popup.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
const langInput = document.getElementById('lang');
const voiceInput = document.getElementById('voice');
const speedInput = document.getElementById('speed');
chrome.tts.getVoices().then(async function(voices) {
let storageConfigs = await chrome.storage.local.get(['voice', 'lang', 'speed']);
speedInput.value = storageConfigs.speed;
voices
.map(voice => voice.lang)
.filter((lang, index, self) => self.indexOf(lang) == index)
.forEach(lang => {
let opt = document.createElement('option');
opt.value = lang;
opt.innerText = lang;
if (lang == storageConfigs.lang) {
opt.selected = true;
}
langInput.appendChild(opt);
});
voices
.filter(voice => voice.lang == langInput.value)
.forEach(voice => {
let opt = document.createElement('option');
opt.value = voice.voiceName;
opt.innerText = voice.voiceName;
if (voice.voiceName == storageConfigs.voice) {
opt.selected = true;
}
voiceInput.appendChild(opt);
});
});
langInput.addEventListener('change', async function() {
chrome.storage.local.set({'lang': langInput.value})
voiceInput.innerHTML = ''
let voices = await chrome.tts.getVoices();
voices
.filter(voice => voice.lang == langInput.value)
.forEach((voice, index) => {
let opt = document.createElement('option');
opt.value = voice.voiceName;
opt.innerText = voice.voiceName;
if(index == 0) {
opt.selected = true;
chrome.storage.local.set({'voice': voice.voiceName})
}
voiceInput.appendChild(opt);
});
});
voiceInput.addEventListener('change', async function() {
chrome.storage.local.set({'voice': voiceInput.value})
});
speedInput.addEventListener('change', async function() {
chrome.storage.local.set({'speed': speedInput.value})
});