2018-04-16 01:59:09 +00:00
|
|
|
var pathNodes = []; // Path parts Could store a cookie to keep sessions
|
|
|
|
|
|
|
|
function getDirSSE() {
|
|
|
|
var path = "";
|
|
|
|
|
|
|
|
// Create path from array of items
|
|
|
|
for (pathNode of pathNodes) { path += pathNode; }
|
|
|
|
path = "dirQuery=" + path;
|
|
|
|
process(path);
|
|
|
|
}
|
|
|
|
|
|
|
|
function getDir(query) {
|
|
|
|
var formULPTH = document.getElementById("DIRPATHUL");
|
|
|
|
var path = "";
|
|
|
|
|
|
|
|
// push or pop to path list
|
|
|
|
if (query === "/") {
|
|
|
|
if (document.cookie) {
|
|
|
|
var temp = document.cookie.replace("dirQuery=", "");
|
|
|
|
temp = temp.split("/");
|
|
|
|
// Subtract one b/c paths end with / and create empty slot
|
|
|
|
var size = temp.length - 1;
|
|
|
|
|
|
|
|
for (var i = 0; i < size; i++) {
|
|
|
|
pathNodes.push(temp[i] + "/");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
pathNodes.push("." + query); // If in root of server
|
|
|
|
}
|
|
|
|
} else if (query === "../") {
|
|
|
|
if (pathNodes.length > 1) { pathNodes.pop(); } // Only remove while not in root
|
|
|
|
} else if (query === "./") { // Do nothing since re-scanning dir
|
|
|
|
} else { pathNodes.push(query); } // Add path
|
|
|
|
|
|
|
|
// Create path from array of items
|
|
|
|
for (pathNode of pathNodes) { path += pathNode; }
|
|
|
|
|
2018-04-20 10:51:39 +00:00
|
|
|
formULPTH.value = path; // Used when uploading a file
|
2018-04-16 01:59:09 +00:00
|
|
|
path = "dirQuery=" + path;
|
|
|
|
process(path);
|
|
|
|
}
|
|
|
|
|
|
|
|
function process(path) {
|
|
|
|
// Get dir info...
|
|
|
|
var xhttp = new XMLHttpRequest(); // Create the xhttp object
|
|
|
|
|
|
|
|
// This is actually run after open and send are done
|
|
|
|
xhttp.onreadystatechange = function() {
|
|
|
|
if (this.readyState === 4 && this.status === 200) {
|
|
|
|
// Send the returned data to further process
|
2018-04-20 10:51:39 +00:00
|
|
|
if (this.responseXML != null) {
|
|
|
|
updatePage(this.responseXML);
|
|
|
|
} else {
|
|
|
|
document.getElementById('dynDiv').innerHTML =
|
|
|
|
"<p class=\"error\" style=\"width:100%;text-align:center;\"> "
|
|
|
|
+ "No content returned. Check the folder path.</p>";
|
|
|
|
}
|
2018-04-16 01:59:09 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
xhttp.open("POST", "resources/php/process.php", true); // Open the connection
|
|
|
|
xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
|
|
|
|
xhttp.overrideMimeType('application/xml'); // Force return to be XML
|
|
|
|
xhttp.send(path); // Start the process
|
|
|
|
|
|
|
|
// Use a cookie for persistence during browser session....
|
2018-04-20 10:51:39 +00:00
|
|
|
document.cookie = path +"; path=" + document.URL + "; expires=Sun, 31 Dec 2034 12:00:00 UTC";
|
2018-04-16 01:59:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function updatePage(returnData) {
|
|
|
|
var dirPath = returnData.getElementsByTagName('PATH_HEAD')[0];
|
|
|
|
var dirs = returnData.getElementsByTagName('DIR');
|
|
|
|
var videos = returnData.getElementsByTagName('VID_FILE');
|
|
|
|
var images = returnData.getElementsByTagName('IMG_FILE');
|
|
|
|
var files = returnData.getElementsByTagName('FILE');
|
|
|
|
var insertArea = document.getElementById('dynDiv');
|
|
|
|
var workingDir = dirPath.innerHTML;
|
|
|
|
var i = 0;
|
|
|
|
|
|
|
|
// Insert dirs
|
|
|
|
document.getElementById("path").innerHTML = dirPath.innerHTML;
|
|
|
|
insertArea.innerHTML = "";
|
|
|
|
|
|
|
|
if (workingDir === "./") { var i = 2 } // Remove ,. and ../ if in "root"
|
|
|
|
|
|
|
|
var size = dirs.length;
|
|
|
|
for (; i < size; i++) {
|
|
|
|
var dir = dirs[i].innerHTML;
|
|
|
|
|
|
|
|
if (dir != "resources/") {
|
2018-04-18 10:57:57 +00:00
|
|
|
insertArea.innerHTML += "<div class=\"dirStyle\"> <img id=\"dirID\""
|
|
|
|
+" class=\"systemIcon\" src=\"resources/images/icons/folder.png\" />"
|
|
|
|
+ "<input type=\"text\" id=\"titleID\" class=\"dirTitle\""
|
|
|
|
+ " readonly=\"true\" value=\"" + dir + "\" "
|
|
|
|
+ " onfocusout=\"disableEdits(this)\"/>"
|
|
|
|
+"</dir>";
|
2018-04-16 01:59:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Insert videos
|
|
|
|
size = videos .length;
|
|
|
|
for (i = 0; i < size; i++) {
|
|
|
|
var thumbnail = videos[i].children[0].innerHTML;
|
2018-04-18 10:57:57 +00:00
|
|
|
var vidNme = videos[i].children[1].innerHTML;
|
|
|
|
|
|
|
|
insertArea.innerHTML += "<span class=\"movieStyle\" title=\"" + vidNme + "\" >"
|
|
|
|
+ "<img id=\"movieID\" class=\"thumbnail\""
|
|
|
|
+ " src=\"" + thumbnail + "\" alt=\"" + vidNme + "\" />"
|
|
|
|
+ "<input type=\"text\" id=\"titleID\" class=\"movieTitle\""
|
|
|
|
+ " readonly=\"true\"" + " value=\"" + vidNme + "\" "
|
|
|
|
+ " onfocusout=\"disableEdits(this)\"/>"
|
2018-04-16 01:59:09 +00:00
|
|
|
+ "</span>";
|
|
|
|
}
|
|
|
|
|
|
|
|
// Insert images
|
2018-04-18 10:57:57 +00:00
|
|
|
var path = document.getElementById("path").innerHTML;
|
|
|
|
size = images.length;
|
|
|
|
|
2018-04-16 01:59:09 +00:00
|
|
|
for (i = 0; i < size; i++) {
|
|
|
|
var thumbnail = images[i].children[0].innerHTML;
|
2018-04-18 10:57:57 +00:00
|
|
|
|
|
|
|
if (!thumbnail.includes("favicon.png") && !thumbnail.includes("000.png") &&
|
|
|
|
!thumbnail.includes("000.jpg") && !thumbnail.includes("000.gif")) {
|
|
|
|
insertArea.innerHTML += "<img id=\"imageID\" class=\"iconImg\""
|
|
|
|
+ " src=\"" + path + thumbnail
|
|
|
|
+ "\" alt=\"" + thumbnail + "\"/>";
|
2018-04-16 01:59:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (images[0] != undefined) {
|
|
|
|
if (images[0].children[0].innerHTML.includes("000.jpg") ||
|
|
|
|
images[0].children[0].innerHTML.includes("000.png") ||
|
|
|
|
images[0].children[0].innerHTML.includes("000.gif")) {
|
2018-04-18 10:57:57 +00:00
|
|
|
updateBG(path + images[0].children[0].innerHTML);
|
|
|
|
} else {
|
|
|
|
updateBG("resources/images/backgrounds/000.jpg");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
updateBG("resources/images/backgrounds/000.jpg");
|
|
|
|
}
|
2018-04-16 01:59:09 +00:00
|
|
|
|
|
|
|
// Insert files
|
|
|
|
size = files.length;
|
|
|
|
for (i = 0; i < size; i++) {
|
2018-04-18 10:57:57 +00:00
|
|
|
var fileName = files[i].children[0].innerHTML;
|
|
|
|
var iconImg = "<img id=\"fileID\" class=\"systemIcon\"";
|
|
|
|
|
|
|
|
if (fileName.includes(".doc") || fileName.includes(".docx") ||
|
|
|
|
fileName.includes(".xls") || fileName.includes(".xlsx") ||
|
|
|
|
fileName.includes(".rtf")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/doc.png\" />";
|
|
|
|
} else if (fileName.includes(".7z") || fileName.includes(".7zip") ||
|
|
|
|
fileName.includes(".zip") || fileName.includes(".tar.gz") ||
|
|
|
|
fileName.includes(".tar.xz") || fileName.includes(".gz") ||
|
|
|
|
fileName.includes(".rar") || fileName.includes(".jar")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/arc.png\" />";
|
|
|
|
} else if (fileName.includes(".pdf")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/pdf.png\" />";
|
|
|
|
} else if (fileName.includes(".html")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/html.png\" />";
|
|
|
|
} else if (fileName.includes(".txt") || fileName.includes(".conf")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/text.png\" />";
|
|
|
|
} else if (fileName.includes(".iso") || fileName.includes(".img")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/img.png\" />";
|
|
|
|
} else if (fileName.includes(".sh") || fileName.includes(".batch") ||
|
|
|
|
fileName.includes(".exe")) {
|
|
|
|
iconImg += " src=\"resources/images/icons/scrip.png\" />";
|
|
|
|
} else {
|
|
|
|
iconImg += " src=\"resources/images/icons/bin.png\" />";
|
|
|
|
}
|
2018-04-16 01:59:09 +00:00
|
|
|
|
|
|
|
if (fileName != "sse.php" && fileName != "upload.php" &&
|
|
|
|
fileName != "open.php" && fileName != "process.php") {
|
2018-04-18 10:57:57 +00:00
|
|
|
insertArea.innerHTML += "<div class=\"fileStyle\">"
|
|
|
|
+ iconImg
|
|
|
|
+ "<input type=\"text\" id=\"titleID\" class=\"fileTitle\""
|
|
|
|
+ " readonly=\"true\"" + " value=\"" + fileName + "\" "
|
|
|
|
+ " onfocusout=\"disableEdits(this)\"/>"
|
|
|
|
+ "</dir>";
|
2018-04-16 01:59:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|