2024-12-10 22:20:13 +04:00
|
|
|
document.getElementById("instruction").classList.remove("hidden");
|
|
|
|
|
2022-06-28 05:02:10 +04:00
|
|
|
//// OVERLAY FOR VIEWING MEDIA FILES
|
|
|
|
|
2022-06-27 23:44:53 +04:00
|
|
|
const overlay = document.getElementById("overlay");
|
2024-12-10 01:17:09 +04:00
|
|
|
const overlay_content = overlay.children[1];
|
|
|
|
const overlay_label = overlay.children[2];
|
2022-06-28 05:18:38 +04:00
|
|
|
|
2022-10-31 01:39:55 +04:00
|
|
|
const g_tbody = document.getElementsByTagName('tbody')[0];
|
2022-10-31 03:23:08 +04:00
|
|
|
let g_first_row = g_tbody.firstChild;
|
|
|
|
let g_last_row = g_tbody.lastChild;
|
2022-10-31 01:39:55 +04:00
|
|
|
const g_back_row = document.getElementsByTagName("tr")[1];
|
2022-06-27 23:44:53 +04:00
|
|
|
|
2022-10-31 01:39:55 +04:00
|
|
|
let g_scale = 1;
|
2024-12-10 01:17:09 +04:00
|
|
|
let g_oc_offset = [0, 0];
|
|
|
|
let g_oc_translate = [0, 0];
|
2022-10-31 01:39:55 +04:00
|
|
|
let g_current_row = g_back_row;
|
2022-09-20 03:39:42 +04:00
|
|
|
|
|
|
|
|
|
|
|
if (localStorage.getItem('audio_volume') == null)
|
|
|
|
localStorage['audio_volume'] = 0.5;
|
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
|
|
|
|
function overlayClose() {
|
2024-12-10 01:17:09 +04:00
|
|
|
overlay_content.firstChild.remove();
|
2022-09-20 04:28:29 +04:00
|
|
|
overlay.style.visibility = "hidden";
|
|
|
|
g_scale = 1;
|
2024-12-10 01:17:09 +04:00
|
|
|
g_oc_offset = g_oc_translate = [0, 0];
|
2022-09-20 04:28:29 +04:00
|
|
|
}
|
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
|
|
|
|
overlay.addEventListener("mouseup", e => {
|
|
|
|
if (e.target.tagName === "DIV" && e.button === 0) overlayClose(); });
|
|
|
|
|
2024-12-10 01:17:09 +04:00
|
|
|
overlay_content.addEventListener("wheel", e => {
|
|
|
|
e.preventDefault();
|
|
|
|
g_scale = Math.min(Math.max(0.25, g_scale + (e.deltaY * -0.001)), 4);
|
|
|
|
e.target.style.transform =
|
|
|
|
`translate(${g_oc_translate[0]}px, ${g_oc_translate[1]}px) scale(${g_scale})`;
|
|
|
|
});
|
|
|
|
|
|
|
|
overlay_content.addEventListener("mousedown", e => {
|
|
|
|
if (e.buttons !== 1) return;
|
|
|
|
e.preventDefault();
|
|
|
|
g_oc_offset = [e.offsetX, e.offsetY];
|
|
|
|
});
|
|
|
|
|
|
|
|
overlay_content.addEventListener("mousemove", e => {
|
|
|
|
if (e.buttons !== 1) return;
|
|
|
|
e.preventDefault();
|
|
|
|
g_oc_translate[0] = e.clientX - e.target.x - g_oc_offset[0];
|
|
|
|
g_oc_translate[1] = e.clientY - e.target.y - g_oc_offset[1];
|
2024-12-10 22:47:54 +04:00
|
|
|
e.target.style.transform =
|
|
|
|
`translate(${g_oc_translate[0]}px, ${g_oc_translate[1]}px) scale(${g_scale})`;
|
2024-12-10 22:20:39 +04:00
|
|
|
});
|
|
|
|
|
2022-09-20 03:39:42 +04:00
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
function determineMediaElement(path) {
|
2022-09-20 03:39:42 +04:00
|
|
|
path = path.toLowerCase();
|
2024-12-10 23:28:50 +04:00
|
|
|
if (["webm", "mp4", "mov"].some(ext => path.endsWith(ext)))
|
2022-09-20 03:39:42 +04:00
|
|
|
return "video";
|
2024-12-10 23:28:50 +04:00
|
|
|
else if (["mp3", "flac", "opus", "ogg", "m4a"].some(ext => path.endsWith(ext)))
|
2022-09-20 03:39:42 +04:00
|
|
|
return "audio";
|
2024-12-10 23:28:50 +04:00
|
|
|
else if (["jpg", "jpeg", "gif", "png", "bmp", "webp"].some(ext => path.endsWith(ext)))
|
2022-09-20 03:39:42 +04:00
|
|
|
return "img";
|
|
|
|
return undefined;
|
2022-06-27 23:44:53 +04:00
|
|
|
}
|
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
function overlaySet(pathname, media_type_element) {
|
2022-09-20 03:39:42 +04:00
|
|
|
if (media_type_element === undefined)
|
|
|
|
return false;
|
2024-12-10 01:17:09 +04:00
|
|
|
if (overlay_content.children.length != 0) {
|
|
|
|
g_oc_offset = g_oc_translate = [0, 0];
|
|
|
|
g_scale = 1;
|
|
|
|
}
|
2022-09-20 03:39:42 +04:00
|
|
|
|
|
|
|
const media_element = document.createElement(media_type_element);
|
|
|
|
media_element.src = pathname;
|
|
|
|
|
|
|
|
if (media_type_element !== "img") {
|
|
|
|
media_element.autoplay = media_element.controls = true;
|
|
|
|
media_element.addEventListener("volumechange", e => {
|
|
|
|
localStorage['audio_volume'] = e.target.volume; });
|
|
|
|
media_element.volume = localStorage["audio_volume"];
|
2024-12-10 22:20:39 +04:00
|
|
|
media_element.addEventListener("ended", e => { if (overlay_autoplay.checked) b_next.click(); });
|
2022-09-20 03:39:42 +04:00
|
|
|
}
|
|
|
|
|
2024-12-10 01:17:09 +04:00
|
|
|
overlay_label.textContent = decodeURI(pathname.substr(pathname.lastIndexOf("/") + 1));
|
|
|
|
|
|
|
|
overlay_content.replaceChildren(media_element);
|
|
|
|
|
2022-09-20 03:39:42 +04:00
|
|
|
overlay.style.visibility = "visible";
|
|
|
|
|
|
|
|
return true;
|
2022-06-27 23:44:53 +04:00
|
|
|
}
|
|
|
|
|
2022-10-31 01:39:55 +04:00
|
|
|
function getSibling(isNext = true, upDown = false) {
|
|
|
|
if (upDown && g_current_row == g_back_row)
|
|
|
|
g_current_row = isNext ? g_first_row : g_last_row;
|
|
|
|
else
|
|
|
|
g_current_row = isNext ?
|
|
|
|
( (g_current_row.nextSibling === null) ?
|
|
|
|
(upDown ? g_back_row : g_first_row) : g_current_row.nextSibling )
|
|
|
|
: ( (g_current_row.previousSibling === null) ?
|
|
|
|
(upDown ? g_back_row : g_last_row) : g_current_row.previousSibling );
|
|
|
|
return g_current_row;
|
|
|
|
}
|
2022-09-20 03:39:42 +04:00
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
|
2022-09-20 03:39:42 +04:00
|
|
|
const [b_prev, b_next] = overlay.getElementsByTagName("button");
|
|
|
|
|
|
|
|
b_prev.addEventListener("click", e => {
|
|
|
|
do {
|
2022-10-31 01:39:55 +04:00
|
|
|
getSibling(false, false);
|
2022-10-18 22:22:04 +04:00
|
|
|
} while (g_current_row.classList.contains("hidden")
|
2024-12-10 22:47:54 +04:00
|
|
|
|| !overlaySet(g_current_row.firstChild.firstChild.pathname,
|
|
|
|
determineMediaElement(g_current_row.firstChild.firstChild.pathname)));
|
2022-10-31 01:39:55 +04:00
|
|
|
g_current_row.firstChild.firstChild.focus();
|
2022-09-20 03:39:42 +04:00
|
|
|
e.preventDefault();
|
|
|
|
});
|
|
|
|
|
2022-10-31 01:39:55 +04:00
|
|
|
b_next.addEventListener("click", e => {
|
2022-09-20 03:39:42 +04:00
|
|
|
do {
|
2022-10-31 01:39:55 +04:00
|
|
|
getSibling(true, false);
|
2022-10-18 22:22:04 +04:00
|
|
|
} while (g_current_row.classList.contains("hidden")
|
2024-12-10 22:47:54 +04:00
|
|
|
|| !overlaySet(g_current_row.firstChild.firstChild.pathname,
|
|
|
|
determineMediaElement(g_current_row.firstChild.firstChild.pathname)));
|
2022-10-31 01:39:55 +04:00
|
|
|
g_current_row.firstChild.firstChild.focus();
|
|
|
|
e.preventDefault();
|
2022-06-27 23:44:53 +04:00
|
|
|
});
|
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
|
2024-12-10 01:17:09 +04:00
|
|
|
Array.from(g_tbody.children)
|
|
|
|
.forEach(v => {
|
|
|
|
if (v.lastChild.innerHTML === "DIR") return;
|
|
|
|
v.firstChild.firstChild.addEventListener("click", e => {
|
|
|
|
g_current_row = e.target.parentNode.parentNode;
|
2024-12-10 22:47:54 +04:00
|
|
|
if (overlaySet(e.target.pathname, determineMediaElement(e.target.pathname)))
|
2024-12-10 01:17:09 +04:00
|
|
|
e.preventDefault();
|
|
|
|
});
|
2022-10-31 01:44:27 +04:00
|
|
|
});
|
|
|
|
|
2024-12-10 22:47:54 +04:00
|
|
|
|
|
|
|
overlay_autoplay = document.getElementsByName("autoplay")[0];
|
|
|
|
|
|
|
|
if (localStorage.getItem('autoplay') == null)
|
|
|
|
localStorage['autoplay'] = overlay_autoplay.checked = false;
|
2024-12-11 00:30:56 +04:00
|
|
|
else
|
|
|
|
overlay_autoplay.checked = localStorage['autoplay'];
|
2024-12-10 22:47:54 +04:00
|
|
|
|
|
|
|
overlay_autoplay.addEventListener("change", e => {
|
|
|
|
localStorage['autoplay'] = e.target.checked;
|
2024-12-11 00:30:56 +04:00
|
|
|
const media_element = overlay_content.firstChild;
|
2024-12-10 22:47:54 +04:00
|
|
|
if (e.target.checked && media_element !== undefined)
|
|
|
|
if (media_element.tagName === "AUDIO" || media_element.tagName === "VIDEO")
|
|
|
|
if (media_element.ended)
|
|
|
|
b_next.click();
|
|
|
|
});
|
|
|
|
|
2022-10-31 01:44:27 +04:00
|
|
|
//// KEYBOARD HANDLING
|
|
|
|
|
2022-09-20 03:39:42 +04:00
|
|
|
window.addEventListener("keydown", e => {
|
2022-10-31 01:39:55 +04:00
|
|
|
if (e.isComposing)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (overlay.style.visibility === "hidden" || overlay.style.visibility === "") {
|
|
|
|
switch (e.code) {
|
|
|
|
case "Backspace": if (e.ctrlKey) window.location = "../"; break;
|
|
|
|
case "Home": g_current_row = g_back_row; g_back_row.firstChild.firstChild.focus(); break;
|
|
|
|
case "End": g_current_row = g_last_row; g_last_row.firstChild.firstChild.focus(); break;
|
|
|
|
case "ArrowUp":
|
2024-12-08 04:13:57 +04:00
|
|
|
case "ArrowLeft":
|
2022-10-31 01:39:55 +04:00
|
|
|
e.preventDefault();
|
|
|
|
getSibling(false, true);
|
|
|
|
g_current_row.firstChild.firstChild.focus();
|
|
|
|
break;
|
|
|
|
case "ArrowDown":
|
2024-12-08 04:13:57 +04:00
|
|
|
case "ArrowRight":
|
2022-10-31 01:39:55 +04:00
|
|
|
e.preventDefault();
|
|
|
|
getSibling(true, true);
|
|
|
|
g_current_row.firstChild.firstChild.focus();
|
|
|
|
break;
|
|
|
|
}
|
2022-09-20 03:39:42 +04:00
|
|
|
return;
|
2022-10-31 01:39:55 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
switch (e.code) {
|
2024-12-08 04:13:57 +04:00
|
|
|
case "ArrowUp":
|
|
|
|
case "ArrowLeft":
|
|
|
|
e.preventDefault();
|
|
|
|
b_prev.click();
|
|
|
|
break;
|
|
|
|
case "ArrowDown":
|
|
|
|
case "ArrowRight":
|
|
|
|
e.preventDefault();
|
|
|
|
b_next.click();
|
|
|
|
break;
|
2024-12-10 22:47:54 +04:00
|
|
|
case "Escape": overlayClose(); break;
|
2022-10-31 01:39:55 +04:00
|
|
|
case "Space":
|
|
|
|
e.preventDefault();
|
|
|
|
const el = overlay_content.firstChild;
|
|
|
|
if (el.paused !== undefined)
|
|
|
|
el.paused ? el.play() : el.pause();
|
|
|
|
}
|
2022-09-20 03:39:42 +04:00
|
|
|
});
|
|
|
|
|
2022-10-18 22:21:31 +04:00
|
|
|
//// FILTERING
|
|
|
|
|
2022-10-31 01:39:55 +04:00
|
|
|
|
|
|
|
document.getElementsByName("filter")[0].classList.remove("hidden");
|
2024-12-10 22:47:54 +04:00
|
|
|
|
2022-10-18 22:21:31 +04:00
|
|
|
function filter(sub) {
|
2022-10-31 01:39:55 +04:00
|
|
|
const table = g_tbody.children;
|
2022-10-18 22:21:31 +04:00
|
|
|
for (let j = 0; j < table.length; ++j)
|
2022-10-31 01:39:55 +04:00
|
|
|
table[j].classList.toggle("hidden",
|
|
|
|
!(sub === "" || table[j].firstChild.firstChild.innerText.toLowerCase().indexOf(sub) != -1));
|
2022-10-18 22:21:31 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
document.getElementsByName("filter")[0].addEventListener("input", e => filter(e.target.value.toLowerCase()));
|
|
|
|
|
2022-06-28 05:02:10 +04:00
|
|
|
//// SORT BY COLUMN
|
2022-06-28 04:21:46 +04:00
|
|
|
|
|
|
|
const [thead_name, thead_date, thead_size] = document.getElementsByTagName('thead')[0]
|
2022-09-20 03:39:42 +04:00
|
|
|
.children[0].children;
|
2022-06-28 04:21:46 +04:00
|
|
|
|
2024-12-30 20:39:38 +04:00
|
|
|
if (localStorage.getItem("sort_reverse") == null)
|
|
|
|
localStorage.setItem("sort_reverse", false);
|
|
|
|
|
|
|
|
function sortTable(compareFn, filterFn, filterNegFn, target, other) {
|
|
|
|
let records = Array.from(g_tbody.children);
|
|
|
|
|
|
|
|
let dirs = [];
|
|
|
|
if (filterFn != null) {
|
|
|
|
dirs = records.filter(filterFn);
|
|
|
|
records = records.filter(filterNegFn);
|
|
|
|
}
|
|
|
|
|
|
|
|
records.sort(compareFn);
|
|
|
|
|
|
|
|
g_tbody.textContent = "";
|
|
|
|
|
|
|
|
other.forEach(v => {
|
|
|
|
v.classList.remove("sort-up");
|
|
|
|
v.classList.remove("sort-down");
|
|
|
|
});
|
|
|
|
|
|
|
|
if (filterFn != null)
|
|
|
|
g_tbody.append(...dirs);
|
|
|
|
|
|
|
|
if (localStorage.getItem("sort_reverse") == "true") {
|
|
|
|
g_tbody.append(...records.reverse());
|
|
|
|
target.classList.add("sort-up");
|
|
|
|
target.classList.remove("sort-down");
|
|
|
|
} else {
|
|
|
|
g_tbody.append(...records);
|
|
|
|
target.classList.add("sort-down");
|
|
|
|
target.classList.remove("sort-up");
|
|
|
|
}
|
|
|
|
|
|
|
|
localStorage.setItem("sort_reverse", !(localStorage.getItem("sort_reverse") == "true"));
|
|
|
|
}
|
2022-06-28 04:21:46 +04:00
|
|
|
|
|
|
|
thead_name.classList.toggle("clickable");
|
|
|
|
thead_name.addEventListener('click', e => {
|
2022-09-20 03:39:42 +04:00
|
|
|
e.preventDefault();
|
|
|
|
sortTable((a,b) => {
|
|
|
|
const a_name = a.children[0].textContent.toLowerCase();
|
|
|
|
const b_name = b.children[0].textContent.toLowerCase();
|
|
|
|
return a_name < b_name ? -1 : a_name > b_name ? 1 : 0;
|
|
|
|
}, null, null, thead_name, [thead_date, thead_size]);
|
2022-10-31 03:23:08 +04:00
|
|
|
g_first_row = g_tbody.firstChild;
|
|
|
|
g_last_row = g_tbody.lastChild;
|
2024-12-30 20:39:38 +04:00
|
|
|
localStorage["sort_column"] = "name";
|
2022-06-28 04:21:46 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
thead_date.classList.toggle("clickable");
|
|
|
|
thead_date.addEventListener('click', e => {
|
2022-09-20 03:39:42 +04:00
|
|
|
e.preventDefault();
|
|
|
|
sortTable((a,b) => {
|
|
|
|
const a_date = new Date(a.children[1].textContent.slice(0, -4));
|
|
|
|
const b_date = new Date(b.children[1].textContent.slice(0, -4));
|
|
|
|
return a_date - b_date;
|
|
|
|
}, null, null, thead_date, [thead_name, thead_size]);
|
2022-10-31 03:23:08 +04:00
|
|
|
g_first_row = g_tbody.firstChild;
|
|
|
|
g_last_row = g_tbody.lastChild;
|
2024-12-30 20:39:38 +04:00
|
|
|
localStorage["sort_column"] = "date";
|
2022-06-28 04:21:46 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2024-12-30 20:39:09 +04:00
|
|
|
const size_units = document.getElementsByTagName("html")[0].lang == "ru" ?
|
|
|
|
{"Б": 0, "КиБ": 1, "МиБ": 2, "ГиБ": 3, "ТиБ": 4} :
|
|
|
|
{"B": 0, "KiB": 1, "MiB": 2, "GiB": 3, "TiB": 4};
|
2022-06-28 04:21:46 +04:00
|
|
|
function sizeToBytes(size, unit) {
|
2024-12-30 20:39:09 +04:00
|
|
|
if (size_units[unit] == 0) return size;
|
|
|
|
for (let i = 0; i <= size_units[unit]; ++i) size *= 1024;
|
2022-09-20 03:39:42 +04:00
|
|
|
return size;
|
2022-06-28 04:21:46 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
thead_size.classList.toggle("clickable");
|
|
|
|
thead_size.addEventListener('click', e => {
|
2022-09-20 03:39:42 +04:00
|
|
|
e.preventDefault();
|
|
|
|
sortTable(
|
|
|
|
(a,b) => {
|
|
|
|
if (a.textContent == "DIR")
|
|
|
|
return 1;
|
|
|
|
let [a_size, a_unit] = a.children[2].textContent.split(" ");
|
|
|
|
let [b_size, b_unit] = b.children[2].textContent.split(" ");
|
|
|
|
return sizeToBytes(+a_size, a_unit) - sizeToBytes(+b_size, b_unit);
|
|
|
|
},
|
|
|
|
e => e.children[2].textContent == "DIR",
|
|
|
|
e => e.children[2].textContent != "DIR",
|
|
|
|
thead_size, [thead_name, thead_date]);
|
2022-10-31 03:23:08 +04:00
|
|
|
g_first_row = g_tbody.firstChild;
|
|
|
|
g_last_row = g_tbody.lastChild;
|
2024-12-30 20:39:38 +04:00
|
|
|
localStorage["sort_column"] = "size";
|
2022-06-28 04:21:46 +04:00
|
|
|
});
|
|
|
|
|
2024-12-30 20:39:38 +04:00
|
|
|
localStorage.setItem("sort_reverse", !(localStorage.getItem("sort_reverse") == "true"));
|
|
|
|
switch (localStorage["sort_column"]) {
|
|
|
|
case "name": thead_name.click(); break;
|
|
|
|
case "date": thead_date.click(); break;
|
|
|
|
case "size": thead_size.click(); break;
|
2022-06-28 04:21:46 +04:00
|
|
|
}
|