WebFM/src/core/static/js/post-ajax.js

189 lines
6.8 KiB
JavaScript

const postAjaxController = (data, action) => {
if (data.message) {
message = data.message
displayMessage(message.text, message.type);
return ;
}
if (data.hasOwnProperty('path_head'))
updateHTMLDirList(data);
if (data.hasOwnProperty('faves_list'))
// generateFavesList(data.faves_list);
console.log("faves stub...");
if (data.hasOwnProperty("refresh")) {
if (data.refresh == "true") {
reloadDirectory();
}
}
}
const generateFavesList = (data) => {
let listView = document.getElementById("faves-list");
clearChildNodes(listView);
data.forEach(faveArry => {
let fave = faveArry[0]
let faveId = faveArry[1]
let liTag = document.createElement("LI");
let parts = (fave.includes("/")) ? fave.split("/") : fave.split("\\");
let part = parts[parts.length - 1]
if (part.toLowerCase().includes("season")) {
part = parts[parts.length - 2] + "/" + part
}
let txtNode = document.createTextNode(part);
liTag.setAttribute("class", "btn btn-secondary btn-sm");
liTag.setAttribute("name", fave);
liTag.setAttribute("title", fave);
liTag.setAttribute("onclick", "loadFave(" + faveId +")");
liTag.appendChild(txtNode);
listView.appendChild(liTag);
});
}
const updateHTMLDirList = async (data) => {
console.log(data);
let pathElm = document.getElementById("path");
let dirs = (data.list.dirs) ? data.list.dirs[0] : [];
let videos = (data.list.vids) ? data.list.vids[0] : [];
let images = (data.list.images) ? data.list.images[0] : [];
let files = (data.list.ungrouped) ? data.list.ungrouped[0] : [];
let isInFaves = data.in_fave;
console.log(data.list.images);
let background_image = (images[0]) ? images[0][0] : "";
console.log(background_image);
pathElm.innerText = data.path_head; // Can still set the path info if locked...
// Setup background if there is a 000.* in selection
if (background_image.match(/000\.(jpg|png|gif)\b/) != null) {
// Due to same hash for 000 we add date to make link unique for each run to bypass cache issues...
background_image = "api/file-manager-action/files/" + images[0][1] + '?d=' + Date.now();
updateBackground(background_image, false);
} else {
background_image = "static/imgs/backgrounds/particles.mp4";
updateBackground(background_image);
}
// See if in faves
let elm = document.getElementById("tggl-faves-btn");
if (isInFaves == "true")
elm.classList.add("btn-info");
else
elm.classList.remove("btn-info");
renderFilesList(data.list);
// clearChildNodes(insertArea);
// // Insert dirs
// let dirClone = document.importNode(dirTemplate.content, true);
// let dir = null;
// size = dirs.length;
// for (; i < size; i++) {
// const clone = dirClone.cloneNode(true);
// title = dirs[i][0];
// hash = dirs[i][1];
// createElmBlock(insertArea, clone, thumbnail, title, hash);
// }
//
// // Insert videos
// let vidClone = document.importNode(vidTemplate.content, true);
// size = videos.length;
// for (i = 0; i < size; i++) {
// const clone = vidClone.cloneNode(true);
// title = videos[i][0];
// thumbnail = formatURL(videos[i][1]);
// hash = videos[i][2];
// createElmBlock(insertArea, clone, thumbnail, title, hash, true);
// }
//
// // Insert images
// let imgClone = document.importNode(imgTemplate.content, true);
// thumbnail = "";
// size = images.length;
// for (i = 0; i < size; i++) {
// title = images[i][0];
// thumbnail = formatURL("files/" + images[i][1]);
// hash = images[i][1];
//
// if (thumbnail.match(/000\.(jpg|png|gif)\b/) == null &&
// !thumbnail.includes("favicon.png") && !thumbnail.includes("000")) {
// const clone = imgClone.cloneNode(true);
// createElmBlock(insertArea, clone, thumbnail, title, hash);
// }
// }
//
// // Insert files
// let fileClone = document.importNode(filTemplate.content, true);
// size = files.length;
// for (i = 0; i < size; i++) {
// const clone = fileClone.cloneNode(true);
// title = files[i][0];
// thumbnail = setFileIconType(files[i][0]);
// hash = files[i][1];
// createElmBlock(insertArea, clone, thumbnail, title, hash);
// }
// }
//
// const createElmBlock = (ulElm, clone, thumbnail, title, hash, isVideo=false) => {
// let containerTag = clone.firstElementChild;
// containerTag.setAttribute("style", "background-image: url('" + thumbnail + "')");
// containerTag.setAttribute("title", title);
// containerTag.setAttribute("hash", hash);
//
// // If image tag this sink to oblivion since there are no input tags in the template
// try {
// let inputTag = clone.querySelector("input");
// inputTag.setAttribute("value", title);
// // NOTE: Keeping this just incase i do want to rename stuff...
// //
// // inputTag.addEventListener("dblclick", function (eve) {
// // enableEdit(eve.target);
// // });
// // inputTag.addEventListener("focusout", function (eve) {
// // disableEdit(eve.target);
// // });
// } catch (e) { }
//
// if (isVideo) {
// let popoutTag = clone.querySelector(".card-popout-btn");
// popoutTag.setAttribute("hash", hash);
// popoutTag.addEventListener("click", function (eve) {
// let target = eve.target;
// const hash = target.getAttribute("hash");
// openWithLocalProgram(hash);
// });
// }
//
//
// ulElm.appendChild(clone);
}
const setFileIconType = (fileName) => {
icoPath = "";
if (fileName.match(/\.(doc|docx|xls|xlsx|rtf)\b/) != null) {
icoPath = "static/imgs/icons/doc.png";
} else if (fileName.match(/\.(7z|7zip|zip|tar.gz|tar.xz|gz|rar|jar)\b/) != null) {
icoPath = "resources/images/icons/arc.png";
} else if (fileName.match(/\.(pdf)\b/) != null) {
icoPath = "static/imgs/icons/pdf.png";
} else if (fileName.match(/\.(html)\b/) != null) {
icoPath = "static/imgs/icons/html.png";
} else if (fileName.match(/\.(txt|conf)\b/) != null) {
icoPath = "static/imgs/icons/text.png";
} else if (fileName.match(/\.(iso|img)\b/) != null) {
icoPath = "static/imgs/icons/img.png";
} else if (fileName.match(/\.(sh|batch|exe)\b/) != null) {
icoPath = "static/imgs/icons/scrip.png";
} else {
icoPath = "static/imgs/icons/bin.png";
}
return formatURL(icoPath)
}