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
|
import { e } from "./helper.ts";
import { bangs } from "./query.ts";
import { status } from "./ui.ts"
export function section_info_start() {
return e("section", { class: "info" },
e("h1", {}, "Fastbangs"),
e("p", {}, `
This application provides a way to (mostly) locally handle search bangs. To use it:
`),
e("ul", {},
e("li", {}, "Select a fallback search engine, used when a search doesn't contain a bang"),
e("li", {}, "Add this search engine to your browser, or bookmark this page"),
),
e("span", {}, "Can't find a search engine? "), e("a", { href: "#~submit" }, "Propose or change a bang."),
)
}
export function section_engine_select() {
const select = async (e: string) => {
const engine = e.toLowerCase();
if (!(await bangs)[engine]) return status("error", `Engine ${JSON.stringify(e)} does not exist.`)
window.location.hash = `#${e}`
}
const listing = e("ul", {})
bangs.then(bangs => {
for (const key in bangs) if (bangs[key]!.pinned) {
listing.prepend(e("li", { class: "pinned", onclick: () => select(key) }, bangs[key]!.name ?? key))
}
})
const input = e("input", {type: "text"})
input.addEventListener("keydown", ev => {
if (ev.code == "Enter") select(input.value)
})
const submit = e("button", {}, "Select")
submit.addEventListener("click", () => select(input.value))
listing.append(e("li", {},
e("label", {}, "Select other engine by bang:"),
input,
submit
))
return e("section", { class: "engine-select" },
e("h2", {}, "Select a search engine"),
listing
)
}
|