-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcontent.js
More file actions
65 lines (55 loc) · 1.55 KB
/
content.js
File metadata and controls
65 lines (55 loc) · 1.55 KB
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
const style = document.createElement("style");
style.textContent = `
.part-title, .breadcrumb, td.level, td.finished-count, td.acceptance-rate {
visibility: hidden;
}
`;
document.documentElement.appendChild(style);
const elementVisibility = {
".part-title, .breadcrumb": false,
"td.level": false,
"td.finished-count": false,
"td.acceptance-rate": false,
};
async function loadSettings() {
try {
const data = await new Promise((resolve, reject) => {
chrome.storage.local.get("visibilitySettings", (result) => {
if (chrome.runtime.lastError) {
reject(chrome.runtime.lastError);
}
resolve(result);
});
});
const initialVisibility = data.visibilitySettings || elementVisibility;
if (data.visibilitySettings) {
console.log("Loaded from storage");
} else {
console.log("Cant loaded from storage");
}
Object.keys(initialVisibility).forEach((selector) => {
updateVisibility(selector, initialVisibility[selector]);
});
} catch (error) {
console.error("Error loading settings:", error);
}
}
function updateVisibility(selector, isHidden) {
const elements = document.querySelectorAll(selector);
elements.forEach((element) => {
element.style.visibility = isHidden ? "hidden" : "visible";
});
}
let timeout = null;
const observer = new MutationObserver(() => {
if (timeout) {
clearTimeout(timeout);
}
timeout = setTimeout(() => {
loadSettings();
}, 100);
});
observer.observe(document.documentElement, {
childList: true,
subtree: true,
});