avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 1 | function isEmpty(obj) { |
| 2 | return Object.keys(obj).length === 0; |
| 3 | } |
| 4 | |
avm99963 | 122dc9b | 2019-03-30 18:44:18 +0100 | [diff] [blame] | 5 | var defaultOptions = { |
| 6 | "list": true, |
| 7 | "thread": true, |
avm99963 | 6d9c5fe | 2019-06-04 00:35:53 +0200 | [diff] [blame^] | 8 | "threadall": false, |
avm99963 | 122dc9b | 2019-03-30 18:44:18 +0100 | [diff] [blame] | 9 | "fixedtoolbar": false, |
| 10 | "redirect": false, |
avm99963 | 6d9c5fe | 2019-06-04 00:35:53 +0200 | [diff] [blame^] | 11 | "history": false, |
| 12 | "loaddrafts": false |
avm99963 | 122dc9b | 2019-03-30 18:44:18 +0100 | [diff] [blame] | 13 | }; |
| 14 | |
| 15 | function cleanUpOptions(options) { |
| 16 | var ok = true; |
| 17 | for (const [opt, value] of Object.entries(defaultOptions)) { |
| 18 | if (!opt in options) { |
| 19 | ok = false; |
| 20 | options[opt] = value; |
| 21 | } |
| 22 | } |
| 23 | |
| 24 | if (!ok) { |
| 25 | chrome.storage.sync.set(options); |
| 26 | } |
avm99963 | 001c07c | 2019-03-30 18:47:02 +0100 | [diff] [blame] | 27 | |
| 28 | return options; |
avm99963 | 122dc9b | 2019-03-30 18:44:18 +0100 | [diff] [blame] | 29 | } |
| 30 | |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 31 | function save() { |
avm99963 | 122dc9b | 2019-03-30 18:44:18 +0100 | [diff] [blame] | 32 | var options = defaultOptions; |
| 33 | |
| 34 | Object.keys(options).forEach(function (opt) { |
| 35 | options[opt] = document.querySelector("#"+opt).checked; |
| 36 | }); |
| 37 | |
| 38 | chrome.storage.sync.set(options, function() { |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 39 | window.close(); |
| 40 | }); |
| 41 | } |
| 42 | |
avm99963 | a3d1ef3 | 2019-03-30 23:33:29 +0100 | [diff] [blame] | 43 | function i18n() { |
avm99963 | 6d9c5fe | 2019-06-04 00:35:53 +0200 | [diff] [blame^] | 44 | var messages = ["list", "thread", "threadall", "enhancements", "fixedtoolbar", "redirect", "loaddrafts", "experimental_label", "history", "save"]; |
avm99963 | a3d1ef3 | 2019-03-30 23:33:29 +0100 | [diff] [blame] | 45 | |
| 46 | messages.forEach(function(msg) { |
avm99963 | 6d9c5fe | 2019-06-04 00:35:53 +0200 | [diff] [blame^] | 47 | document.querySelectorAll("[data-i18n=\""+msg+"\"]").forEach(el => el.innerHTML = chrome.i18n.getMessage("options_"+msg)); |
avm99963 | a3d1ef3 | 2019-03-30 23:33:29 +0100 | [diff] [blame] | 48 | }); |
| 49 | } |
| 50 | |
avm99963 | 6d9c5fe | 2019-06-04 00:35:53 +0200 | [diff] [blame^] | 51 | function thread() { |
| 52 | if (document.querySelector("#thread").checked && document.querySelector("#threadall").checked) { |
| 53 | document.querySelector("#"+(this.id == "thread" ? "threadall" : "thread")).checked = false; |
| 54 | } |
| 55 | } |
| 56 | |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 57 | window.addEventListener("load", function() { |
avm99963 | a3d1ef3 | 2019-03-30 23:33:29 +0100 | [diff] [blame] | 58 | i18n(); |
| 59 | |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 60 | chrome.storage.sync.get(null, function(items) { |
avm99963 | 001c07c | 2019-03-30 18:47:02 +0100 | [diff] [blame] | 61 | items = cleanUpOptions(items); |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 62 | |
avm99963 | 122dc9b | 2019-03-30 18:44:18 +0100 | [diff] [blame] | 63 | Object.keys(defaultOptions).forEach(function(opt) { |
| 64 | if (items[opt] === true) { |
| 65 | document.querySelector("#"+opt).checked = true; |
| 66 | } |
| 67 | }); |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 68 | |
avm99963 | 6d9c5fe | 2019-06-04 00:35:53 +0200 | [diff] [blame^] | 69 | ["thread", "threadall"].forEach(el => document.querySelector("#"+el).addEventListener("change", thread)); |
avm99963 | cbea314 | 2019-03-28 00:48:15 +0100 | [diff] [blame] | 70 | document.querySelector("#save").addEventListener("click", save); |
| 71 | }); |
| 72 | }); |