mirror of https://github.com/ekimekim/wubloader
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
102 lines
3.1 KiB
JavaScript
102 lines
3.1 KiB
JavaScript
3 years ago
|
function onSiteLoad(e) {
|
||
|
|
||
|
document.getElementById("search_tools").addEventListener("keydown",
|
||
|
function (event) {
|
||
|
if (event.key === 'Enter') doSearch()
|
||
|
});
|
||
3 years ago
|
|
||
|
doSearch();
|
||
3 years ago
|
}
|
||
|
|
||
|
function query(text, start_time, end_time) {
|
||
|
let query_string = ""
|
||
|
|
||
3 years ago
|
const time_type = document.getElementById("UTC_time_radio").checked ? "" : "bus_";
|
||
|
|
||
3 years ago
|
if (start_time !== "") {
|
||
3 years ago
|
query_string += `${time_type}start_time=${start_time}`;
|
||
3 years ago
|
}
|
||
|
if (end_time !== "") {
|
||
3 years ago
|
query_string += `&${time_type}end_time=${end_time}`;
|
||
3 years ago
|
}
|
||
|
if (text !== "") {
|
||
|
query_string += `&query=${text}`
|
||
|
}
|
||
|
|
||
3 years ago
|
query_string += "&limit=30";
|
||
|
|
||
3 years ago
|
const channel = document.getElementById("channel_select").value;
|
||
|
|
||
|
fetch(`https://wubloader.raptorpond.com/buscribe/${channel}/json?${query_string}`)
|
||
3 years ago
|
.then(response => response.json())
|
||
|
.then(fillResults)
|
||
|
|
||
|
}
|
||
|
|
||
|
function doSearch() {
|
||
|
query(
|
||
|
document.getElementById("search_text").value,
|
||
|
document.getElementById("start_time").value,
|
||
|
document.getElementById("end_time").value
|
||
|
)
|
||
|
}
|
||
|
|
||
|
function fillResults(results) {
|
||
|
const results_element = document.getElementById("results")
|
||
|
results_element.innerHTML = ""
|
||
|
|
||
3 years ago
|
const channel = document.getElementById("channel_select").value;
|
||
|
|
||
3 years ago
|
for (const line of results) {
|
||
|
const line_div = document.createElement("div");
|
||
|
|
||
|
line_div.classList.add("line");
|
||
3 years ago
|
if (line.verifier) {
|
||
|
line_div.classList.add("verified");
|
||
|
}
|
||
3 years ago
|
|
||
3 years ago
|
|
||
3 years ago
|
line_div.innerHTML = `
|
||
3 years ago
|
<div class="line_start_bus_time">${line.start_bus_time}</div>
|
||
3 years ago
|
<div class="line_speakers">${line.speakers == null ? "" : line.speakers.join(", ")}</div>
|
||
3 years ago
|
<div class="line_start_time">${line.start_time}</div>
|
||
3 years ago
|
<div class="line_text">${line.text}</div>
|
||
3 years ago
|
<div class="line_links">
|
||
|
<a href="/professor/professor.html?line=${line.id}">Edit</a>
|
||
|
<a href="javascript:showContext('${line.start_time}');">Show context</a>
|
||
|
</div>
|
||
3 years ago
|
`;
|
||
|
|
||
3 years ago
|
|
||
3 years ago
|
results_element.append(line_div)
|
||
|
}
|
||
3 years ago
|
}
|
||
|
|
||
|
function switchToUTC() {
|
||
|
document.getElementById("start_time").type = "datetime-local";
|
||
|
document.getElementById("end_time").type = "datetime-local";
|
||
|
}
|
||
|
|
||
|
function switchToBus() {
|
||
|
document.getElementById("start_time").type = "text";
|
||
|
document.getElementById("end_time").type = "text";
|
||
3 years ago
|
}
|
||
|
|
||
|
function showContext(time) {
|
||
|
|
||
|
let start_time = new Date(time + "Z");
|
||
|
start_time.setMinutes(start_time.getMinutes() - 3);
|
||
|
let start_time_string = start_time.toISOString();
|
||
|
start_time_string = start_time_string.substring(0, start_time_string.length - 1)
|
||
|
|
||
|
let end_time = new Date(time + "Z");
|
||
|
end_time.setMinutes(end_time.getMinutes() + 3);
|
||
|
let end_time_string = end_time.toISOString();
|
||
|
end_time_string = end_time_string.substring(0, end_time_string.length - 1)
|
||
|
|
||
|
document.getElementById("start_time").value = start_time_string;
|
||
|
document.getElementById("end_time").value = end_time_string;
|
||
|
document.getElementById("search_text").value = "";
|
||
|
|
||
|
doSearch();
|
||
3 years ago
|
}
|