-
Notifications
You must be signed in to change notification settings - Fork 0
/
popup.js
52 lines (48 loc) · 1.86 KB
/
popup.js
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
const saveButton = document.querySelector("#save_btn");
const input = document.querySelector("#key_input");
const getQueryButton = document.querySelector("#getQueryButton");
const queryTextarea = document.querySelector("textarea");
const queryReply = document.querySelector("#queryReply");
const queryReplyContainer = document.querySelector("#queryReplyContainer");
const copyAnswer = document.querySelector("#copyAnswer");
const query = document.querySelector("#queryReply")
const OPEN_AI = "openAi";
const saveToLocalStorage = async (key, value) => {
await chrome.storage.local.set({ [key]: value });
};
const getFromLocalStorage = async (key) => {
const result = await chrome.storage.local.get([key]);
return result[key];
};
const darkModeToggle = document.getElementById("darkModeToggle");
const container = document.querySelector(".container");
const inp = document.querySelector(".input");
darkModeToggle.addEventListener("click", () => {
container.classList.toggle("dark-mode");
inp.classList.toggle("dark-mode");
queryReply.classList.toggle("dark-mode");
inp.classList.toggle("dark-mode");
});
saveButton.addEventListener("click", () => {
const inputValue = input.value;
saveToLocalStorage(OPEN_AI, inputValue);
});
getQueryButton.addEventListener("click", () => {
const query = queryTextarea.value;
if (!query || queryReply.textContent === "Loading...") {
queryReplyContainer.setAttribute("style", "display: none;");
return;
}
queryReplyContainer.setAttribute("style", "display: block;");
queryReply.textContent = "Scouring the web for results...";
getQueryResult(query, input.value).then((res) => {
queryReply.textContent = res;
});
});
copyAnswer.addEventListener("click", () => {
navigator.clipboard.writeText(queryReply.textContent);
copyAnswer.textContent = "Copied";
setTimeout(() => {
copyAnswer.textContent = "";
}, 1000);
});