This repository was archived by the owner on Sep 4, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpopup.js
More file actions
68 lines (62 loc) · 1.72 KB
/
popup.js
File metadata and controls
68 lines (62 loc) · 1.72 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
66
67
68
window.onload = async () => {
// create editor instance
const editor = ace.edit("Editor", {
cursorStyle: "slim",
enableMultiselect: false,
highlightActiveLine: false,
highlightGutterLine: false,
mode: "ace/mode/html",
newLineMode: "unix",
scrollPastEnd: 0,
selectionStyle: "text",
showPrintMargin: false,
theme: "ace/theme/tomorrow_night_eighties",
useSoftTabs: false,
useWorker: false,
});
// enable format action
document.getElementById("Format").onclick = () => {
let raw = editor.getValue();
for (let parser of ["css", "html", "babel"]) {
try {
let formatted = prettier.format(raw, {
parser,
plugins: prettierPlugins,
printWidth: 120,
useTabs: true,
});
if (formatted !== raw) {
editor.setValue(formatted, -1);
break;
}
} catch {}
}
};
// get hostname for current tab
let [tab] = await browser.tabs.query({
active: true,
currentWindow: true,
url: ["https://*/*", "http://*/*"],
});
// exit if current tab is not valid
if (typeof tab !== "object") {
const template = "<!--\n\tProtocol is not supported.\n-->";
editor.setValue(template, -1);
return;
}
// enable save and delete action
const { hostname } = new URL(tab.url);
document.getElementById("Save").onclick = () => {
let code = editor.getValue();
browser.runtime.sendMessage({ hostname, code });
};
document.getElementById("Delete").onclick = () => {
const code = "";
editor.setValue(code);
browser.runtime.sendMessage({ hostname, code });
};
// load code from background
let code = await browser.runtime.sendMessage({ hostname });
const template = '<script>\n\tconsole.log("Hello world!");\n</script>\n';
editor.setValue(typeof code === "string" ? code : template, -1);
};