about summary refs log tree commit diff stats
path: root/src/pages/options/reddit.js
blob: 9f515d5c740f0dd687b10c95f565a9a52b2813df (plain) (blame)
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
import redditHelper from "../../assets/javascripts/helpers/reddit.js";
import commonHelper from "../../assets/javascripts/helpers/common.js";
import shared from "./shared.js";


const redditInstances = redditHelper.redirects;

let redditInstance = document.getElementById("reddit-instance");
let disableReddit = document.getElementById("disable-reddit");
let redditFrontend = document.getElementById("reddit-frontend");

browser.storage.sync.get(
    [
        "redditInstance",
        "disableReddit",
        "redditFrontend"
    ],
    (result) => {
        redditInstance.value = result.redditInstance || "";
        disableReddit.checked = !result.disableReddit;
        redditFrontend.value = result.redditFrontend;
        let id = "reddit-instance";
        let instances = redditInstances;
        shared.autocompletes.push({ id: id, instances: instances })
        shared.autocomplete(document.getElementById(id), instances);
    }
)

const redditInstanceChange = commonHelper.debounce(
    () => {
        if (redditInstance.checkValidity()) {
            browser.storage.sync.set({
                redditInstance: shared.parseURL(redditInstance.value),
            });
        }
    },
    500
);

redditInstance.addEventListener("input", redditInstanceChange);

disableReddit.addEventListener("change", (event) => {
    browser.storage.sync.set({ disableReddit: !event.target.checked });
});

redditFrontend.addEventListener("change", (event) => {
    const value = event.target.options[redditFrontend.selectedIndex].value;
    console.info("Reddit Frontend", value)
    browser.storage.sync.set({
        redditFrontend: value,
    })
})