| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- 'use strict';
- setupLivePrefs();
- setupRadioButtons();
- enforceInputRange($('#popupWidth'));
- if (!FIREFOX && !OPERA) {
- const block = $('#advanced');
- block.classList.add('collapsible', 'collapsed');
- block.onclick = event => {
- if (block.classList.contains('collapsed') || event.target.closest('h1')) {
- block.classList.toggle('collapsed');
- }
- };
- }
- // actions
- document.onclick = e => {
- const target = e.target.closest('[data-cmd]');
- if (!target) {
- return;
- }
- // prevent double-triggering in case a sub-element was clicked
- e.stopPropagation();
- switch (target.dataset.cmd) {
- case 'open-manage':
- openURL({url: 'manage.html'});
- break;
- case 'check-updates':
- checkUpdates();
- break;
- case 'open-keyboard':
- openURL({url: URLS.configureCommands});
- e.preventDefault();
- break;
- case 'reset':
- $$('input')
- .filter(input => input.id in prefs.readOnlyValues)
- .forEach(input => prefs.reset(input.id));
- break;
- }
- };
- function checkUpdates() {
- let total = 0;
- let checked = 0;
- let updated = 0;
- const maxWidth = $('#update-progress').parentElement.clientWidth;
- BG.updater.checkAllStyles({observer});
- function observer(state, value) {
- switch (state) {
- case BG.updater.COUNT:
- total = value;
- document.body.classList.add('update-in-progress');
- break;
- case BG.updater.UPDATED:
- updated++;
- // fallthrough
- case BG.updater.SKIPPED:
- checked++;
- break;
- case BG.updater.DONE:
- document.body.classList.remove('update-in-progress');
- return;
- }
- $('#update-progress').style.width = Math.round(checked / total * maxWidth) + 'px';
- $('#updates-installed').dataset.value = updated || '';
- }
- }
- function setupRadioButtons() {
- const sets = {};
- const onChange = function () {
- const newValue = sets[this.name].indexOf(this);
- if (newValue >= 0 && prefs.get(this.name) !== newValue) {
- prefs.set(this.name, newValue);
- }
- };
- // group all radio-inputs by name="prefName" attribute
- for (const el of $$('input[type="radio"][name]')) {
- (sets[el.name] = sets[el.name] || []).push(el);
- el.addEventListener('change', onChange);
- }
- // select the input corresponding to the actual pref value
- for (const name in sets) {
- sets[name][prefs.get(name)].checked = true;
- }
- // listen to pref changes and update the values
- prefs.subscribe(Object.keys(sets), (key, value) => {
- sets[key][value].checked = true;
- });
- }
|