blob: 10fee88f4dfcf3132fcc7b66ff2c0e31d99b1a12 [file] [log] [blame]
avm99963bf8eece2021-04-22 00:27:03 +02001var savedSuccessfullyTimeout = null;
2
3const exclusiveOptions = [['thread', 'threadall']];
4
5// Get the value of the option set in the options/experiments page
6function getOptionValue(opt) {
7 if (specialOptions.includes(opt)) {
8 switch (opt) {
9 case 'profileindicatoralt_months':
10 return document.getElementById(opt).value || 12;
11
12 case 'ccdarktheme_mode':
13 return document.getElementById(opt).value || 'switch';
14
15 case 'ccdragndropfix':
16 return document.getElementById(opt).checked || false;
17
18 default:
19 console.warn('Unrecognized option: ' + opt);
20 return undefined;
21 }
22 }
23
24 return document.getElementById(opt).checked || false;
25}
26
27// Returns whether the option is included in the current context
28function isOptionShown(opt) {
29 if (!optionsPrototype.hasOwnProperty(opt)) return false;
30 return optionsPrototype[opt].context == window.CONTEXT;
31}
32
33function save(e) {
34 // Validation checks before saving
35 if (isOptionShown('profileindicatoralt_months')) {
36 var months = document.getElementById('profileindicatoralt_months');
37 if (!months.checkValidity()) {
38 console.warn(months.validationMessage);
39 return;
40 }
41 }
42
43 e.preventDefault();
44
45 chrome.storage.sync.get(null, function(items) {
46 var options = cleanUpOptions(items, true);
47
48 // Save
49 Object.keys(options).forEach(function(opt) {
50 if (!isOptionShown(opt)) return;
51 options[opt] = getOptionValue(opt);
52 });
53
54 chrome.storage.sync.set(options, function() {
55 window.close();
56
57 // In browsers like Firefox window.close is not supported:
58 if (savedSuccessfullyTimeout !== null)
59 window.clearTimeout(savedSuccessfullyTimeout);
60
61 document.getElementById('save-indicator').innerText =
62 '✓ ' + chrome.i18n.getMessage('options_saved');
63 savedSuccessfullyTimeout = window.setTimeout(_ => {
64 document.getElementById('save-indicator').innerText = '';
65 }, 3699);
66 });
67 });
68}
69
70function i18n() {
71 document.querySelectorAll('[data-i18n]')
72 .forEach(
73 el => el.innerHTML = chrome.i18n.getMessage(
74 'options_' + el.getAttribute('data-i18n')));
75}
76
77window.addEventListener('load', function() {
78 i18n();
79
80 chrome.storage.sync.get(null, function(items) {
81 items = cleanUpOptions(items, false);
82
83 for ([opt, optMeta] of Object.entries(optionsPrototype)) {
84 if (!isOptionShown(opt)) continue;
85
86 if (specialOptions.includes(opt)) {
87 switch (opt) {
88 case 'profileindicatoralt_months':
89 var input = document.createElement('input');
90 input.type = 'number';
91 input.id = 'profileindicatoralt_months';
92 input.max = '12';
93 input.min = '1';
94 input.value = items[opt];
95 input.required = true;
96 document.getElementById('profileindicatoralt_months--container')
97 .appendChild(input);
98 break;
99
100 case 'ccdarktheme_mode':
101 var select = document.createElement('select');
102 select.id = 'ccdarktheme_mode';
103
104 const modes = ['switch', 'system'];
105 for (const mode of modes) {
106 var modeOption = document.createElement('option');
107 modeOption.value = mode;
108 modeOption.textContent =
109 chrome.i18n.getMessage('options_ccdarktheme_mode_' + mode);
110 if (items.ccdarktheme_mode == mode) modeOption.selected = true;
111 select.appendChild(modeOption);
112 }
113
114 document.getElementById('ccdarktheme_mode--container')
115 .appendChild(select);
116 break;
117
118 // Firefox doesn't support drag and dropping bookmarks into the text
119 // editor while preserving the bookmark title.
120 case 'ccdragndropfix':
121 var showOption = !isFirefox();
122 if (showOption) {
123 document.getElementById('dragndrop-wrapper')
124 .removeAttribute('hidden');
125
126 if (items[opt] === true)
127 document.getElementById(opt).checked = true;
128 }
129 break;
130
131 default:
132 console.warn('Unrecognized option: ' + opt);
133 break;
134 }
135 continue;
136 }
137
138 if (items[opt] === true) document.getElementById(opt).checked = true;
139 }
140
141 exclusiveOptions.forEach(exclusive => {
142 if (!isOptionShown(exclusive[0]) || !isOptionShown(exclusive[1])) return;
143
144 exclusive.forEach(
145 el => document.getElementById(el).addEventListener('change', e => {
146 if (document.getElementById(exclusive[0]).checked &&
147 document.getElementById(exclusive[1]).checked) {
148 document
149 .getElementById(
150 exclusive[(e.currentTarget.id == exclusive[0] ? 1 : 0)])
151 .checked = false;
152 }
153 }));
154 });
155 document.querySelector('#save').addEventListener('click', save);
156 });
157});