crafty-4/app/frontend/static/assets/js/shared/root-dir.js

139 lines
5.2 KiB
JavaScript
Raw Normal View History

2023-09-03 17:23:18 +00:00
function show_file_tree() {
2023-09-04 23:22:11 +00:00
$("#dir_select").modal();
2023-09-03 17:23:18 +00:00
}
function getDirView(event = false) {
if (event) {
try {
2023-09-04 23:22:11 +00:00
let path = event.target.parentElement.getAttribute('data-path');
2023-09-03 17:23:18 +00:00
if (event.target.parentElement.classList.contains('clicked')) {
if ($(`#${path}span`).hasClass('files-tree-title')) {
$(`#${path}ul`).toggleClass("d-block");
$(`#${path}span`).toggleClass("tree-caret-down");
}
return;
} else {
getTreeView(path);
}
} catch {
console.log("Well that failed");
}
2023-09-04 23:22:11 +00:00
} else if ($("#root_files_button").hasClass("clicked")) {
2023-09-05 01:14:03 +00:00
getTreeView($("#zip_server_path").val(), true);
2023-09-03 17:23:18 +00:00
} else {
2023-09-05 01:14:03 +00:00
getTreeView($("#file-uploaded").val(), true, true);
2023-09-03 17:23:18 +00:00
}
}
2023-09-04 23:22:11 +00:00
2023-09-03 17:23:18 +00:00
async function getTreeView(path, unzip = false, upload = false) {
2023-09-04 23:22:11 +00:00
const token = getCookie("_xsrf");
2023-09-03 17:23:18 +00:00
console.log("IN TREE VIEW")
console.log({ "page": "import", "folder": path, "upload": upload, "unzip": unzip });
let res = await fetch(`/api/v2/import/file/unzip/`, {
method: 'POST',
headers: {
'X-XSRFToken': token
},
body: JSON.stringify({ "page": "import", "folder": path, "upload": upload, "unzip": unzip }),
});
let responseData = await res.json();
if (responseData.status === "ok") {
console.log(responseData);
2024-05-28 23:30:12 +00:00
process_tree_response(responseData, unzip);
2023-09-04 23:40:27 +00:00
let x = document.querySelector('.bootbox');
2023-09-03 17:23:18 +00:00
if (x) {
x.remove()
}
2023-09-04 23:40:27 +00:00
x = document.querySelector('.modal-backdrop');
2023-09-03 17:23:18 +00:00
if (x) {
x.remove()
}
show_file_tree();
} else {
bootbox.alert({
title: responseData.status,
message: responseData.error
});
}
}
2024-05-28 23:30:12 +00:00
function process_tree_response(response, unzip) {
2023-09-03 17:23:18 +00:00
const styles = window.getComputedStyle(document.getElementById("lower_half"));
//If this value is still hidden we know the user is executing a zip import and not an upload
if (styles.visibility === "hidden") {
document.getElementById('zip_submit').disabled = false;
} else {
document.getElementById('upload_submit').disabled = false;
}
let path = response.data.root_path.path;
2024-05-28 23:30:12 +00:00
if (unzip) {
$(".root-input").val(response.data.root_path.path);
}
2023-09-04 23:40:27 +00:00
let text = `<ul class="tree-nested d-block" id="${path}ul">`;
2023-09-03 17:23:18 +00:00
Object.entries(response.data).forEach(([key, value]) => {
if (key === "root_path" || key === "db_stats") {
//continue is not valid in for each. Return acts as a continue.
return;
}
let dpath = value.path;
let filename = key;
if (value.dir) {
text += `<li class="tree-item" id="${dpath}li" data-path="${dpath}">
<div id="${dpath}" data-path="${dpath}" data-name="${filename}" class="tree-caret tree-ctx-item tree-folder">
2024-05-28 23:30:12 +00:00
<input type="radio" class="root-input" name="root_path" value="${dpath}">
2023-09-03 17:23:18 +00:00
<span id="${dpath}span" class="files-tree-title" data-path="${dpath}" data-name="${filename}" onclick="getDirView(event)">
<i style="color: var(--info);" class="far fa-folder"></i>
<i style="color: var(--info);" class="far fa-folder-open"></i>
${filename}
</span>
</input></div><li>`
} else {
text += `<li
class="d-block tree-ctx-item tree-file"
data-path="${dpath}"
data-name="${filename}"
onclick="" id="${dpath}li"><input type='radio' class="checkBoxClass d-none file-check" name='root_path' value="${dpath}" disabled><span style="margin-right: 6px;">
<i class="far fa-file"></i></span></input>${filename}</li>
`
}
});
text += `</ul>`;
if (response.data.root_path.top) {
try {
document.getElementById('main-tree-div').innerHTML += text;
document.getElementById('main-tree').parentElement.classList.add("clicked");
} catch {
document.getElementById('files-tree').innerHTML = text;
}
} else {
try {
document.getElementById(path + "span").classList.add('tree-caret-down');
document.getElementById(path).innerHTML += text;
document.getElementById(path).classList.add("clicked");
} catch {
console.log("Bad")
}
2023-09-04 23:40:27 +00:00
let toggler = document.getElementById(path + "span");
2023-09-03 17:23:18 +00:00
if (toggler.classList.contains('files-tree-title')) {
document.getElementById(path + "span").addEventListener("click", function caretListener() {
document.getElementById(path + "ul").classList.toggle("d-block");
document.getElementById(path + "span").classList.toggle("tree-caret-down");
});
}
}
}
function getToggleMain(event) {
2023-09-05 01:21:59 +00:00
const path = event.target.parentElement.getAttribute('data-path');
2023-09-03 17:23:18 +00:00
document.getElementById("files-tree").classList.toggle("d-block");
document.getElementById(path + "span").classList.toggle("tree-caret-down");
document.getElementById(path + "span").classList.toggle("tree-caret");
}