-
Notifications
You must be signed in to change notification settings - Fork 14
/
options.js
114 lines (107 loc) · 3.1 KB
/
options.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
let currentPrefs = {};
const saveToPreference = (id, value) => {
let update = {};
update[id] = value;
chrome.storage.local.set(update);
};
const handleVelueChange = id => {
let elem = document.getElementById(id);
if(elem) {
let elemType = elem.getAttribute('type');
if(elemType === 'checkbox') {
elem.addEventListener('input', event => {
saveToPreference(id, elem.checked ? true : false);
});
}
else if(elemType === 'option') {
elem.addEventListener('input', event => {
saveToPreference(id, parseInt(elem.value));
});
}
else if(elemType === 'number') {
elem.addEventListener('input', event => {
saveToPreference(id, parseInt(elem.value));
});
}
else if(elemType === 'radioGroup') {
let radios = Array.from(elem.querySelectorAll('input[name='+id+']'));
for(let radio of radios) {
radio.addEventListener('input', event => {
if(radio.checked)
saveToPreference(id, parseInt(radio.getAttribute('value')));
});
}
}
}
};
const setValueToElem = (id, value) => {
let elem = document.getElementById(id);
if(elem) {
let elemType = elem.getAttribute('type');
if(elemType === 'checkbox') {
elem.checked = value;
}
else if(elemType === 'option') {
let options = Array.from(elem.querySelectorAll('option'));
for(let option of options) {
if(parseInt(option.getAttribute('value')) === value) {
option.selected = true;
break;
}
}
}
else if(elemType === 'number') {
elem.value = value;
}
else if(elemType === 'radioGroup') {
let radios = Array.from(elem.querySelectorAll('input[name='+id+']'));
for(let radio of radios) {
if(parseInt(radio.getAttribute('value')) === value) {
radio.checked = true;
break;
}
}
}
}
};
const onDefaultPositionChange = () => {
let defaultPosition = document.getElementById('defaultPosition');
let elems = Array.from(document.querySelectorAll('.windowPosition'));
if(defaultPosition.value === '5') {
elems.forEach(tag => {
tag.classList.add('show');
tag.classList.remove('hidden');
});
} else {
elems.forEach(tag => {
tag.classList.add('hidden');
tag.classList.remove('show');
});
}
}
const init = preferences => {
currentPrefs = preferences;
for(let p in preferences) {
setValueToElem(p, preferences[p]);
handleVelueChange(p);
}
let l10nTags = Array.from(document.querySelectorAll('[data-l10n-id]'));
l10nTags.forEach(tag => {
tag.textContent = chrome.i18n.getMessage(tag.getAttribute('data-l10n-id'));
});
let defaultPosition = document.getElementById('defaultPosition');
defaultPosition.addEventListener('change', event=>{
onDefaultPositionChange();
});
onDefaultPositionChange();
};
window.addEventListener('load', event => {
chrome.storage.local.get(results => {
if ((typeof results.length === 'number') && (results.length > 0)) {
results = results[0];
}
if (results.version) {
init(results);
}
});
}, true);