2024-02-12 11:59:20 +08:00
|
|
|
|
$(document).on('click', '.rename-btn', function () {
|
|
|
|
|
var relativePath = $(this).attr('value');
|
|
|
|
|
var fileName = $(this).closest('tr').find('td:first').text().trim();
|
|
|
|
|
$('#renameRelativePath').val(relativePath);
|
|
|
|
|
$('#renameform-newname').val(fileName);
|
|
|
|
|
$('#renameModal').modal('show');
|
|
|
|
|
})
|
|
|
|
|
var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'));
|
|
|
|
|
var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
|
|
|
|
|
return new bootstrap.Tooltip(tooltipTriggerEl)
|
|
|
|
|
});
|
|
|
|
|
$(document).on('click', '.download-btn', function () {
|
|
|
|
|
window.location.href = $(this).attr('value');
|
|
|
|
|
});
|
2024-02-15 12:10:41 +08:00
|
|
|
|
$(document).on('click', '.folder-download-btn', function () {
|
|
|
|
|
var relativePath = $(this).attr('value');
|
|
|
|
|
window.open('index.php?r=home%2Fdownload-folder&relativePath=' + encodeURIComponent(relativePath), '_blank');
|
|
|
|
|
});
|
2024-02-12 11:59:20 +08:00
|
|
|
|
$(document).on('click', '.delete-btn', function () {
|
|
|
|
|
var relativePath = $(this).attr('value');
|
|
|
|
|
$('#deleteRelativePath').val(relativePath);
|
|
|
|
|
$('#deleteModal').modal('show');
|
2024-02-12 15:27:14 +08:00
|
|
|
|
});
|
|
|
|
|
$(document).on('click', '.file-upload-btn', function () {
|
2024-02-13 20:44:01 +08:00
|
|
|
|
// 触发文件输入元素的点击事件
|
|
|
|
|
$('#file-input').click();
|
2024-02-12 15:27:14 +08:00
|
|
|
|
});
|
2024-02-13 20:44:01 +08:00
|
|
|
|
$('#file-input').on('change', function () {
|
2024-02-15 10:54:25 +08:00
|
|
|
|
uploadFiles(this.files);
|
2024-02-13 20:44:01 +08:00
|
|
|
|
});
|
|
|
|
|
|
2024-02-12 15:27:14 +08:00
|
|
|
|
$(document).on('click', '.folder-upload-btn', function () {
|
2024-02-14 19:12:09 +08:00
|
|
|
|
// 触发文件输入元素的点击事件
|
|
|
|
|
$('#folder-input').click();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$('#folder-input').on('change', function () {
|
2024-02-15 10:54:25 +08:00
|
|
|
|
uploadFiles(this.files);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$(document).on('click', '.offline-download-btn', function () {
|
|
|
|
|
console.log('你点击了离线下载,但功能尚未实现');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$(document).on('click', '.refresh-btn', function () {
|
|
|
|
|
window.location.reload();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$(document).on('click', '.new-folder-btn', function () {
|
|
|
|
|
var relativePath = $(this).attr('value');
|
|
|
|
|
$('#newDirRelativePath').val(relativePath);
|
|
|
|
|
$('#newFolderModal').modal('show');
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
//上传
|
|
|
|
|
function uploadFiles(files) {
|
2024-02-14 19:12:09 +08:00
|
|
|
|
$('#progress-bar').show();
|
|
|
|
|
var formData = new FormData();
|
|
|
|
|
for (var i = 0; i < files.length; i++) {
|
|
|
|
|
formData.append('files[]', files[i]);
|
|
|
|
|
}
|
|
|
|
|
formData.append('targetDir', $('#target-dir').val());
|
|
|
|
|
formData.append('_csrf', $('meta[name="csrf-token"]').attr('content'));
|
2024-02-15 10:54:25 +08:00
|
|
|
|
|
2024-02-14 19:12:09 +08:00
|
|
|
|
var xhr = new XMLHttpRequest();
|
|
|
|
|
xhr.upload.onprogress = function (event) {
|
|
|
|
|
if (event.lengthComputable) {
|
|
|
|
|
var percentComplete = event.loaded / event.total * 100;
|
|
|
|
|
$('#progress-bar .progress-bar').css('width', percentComplete + '%').text(Math.round(percentComplete) + '%');
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
xhr.onload = function () {
|
|
|
|
|
if (xhr.status !== 200) {
|
|
|
|
|
alert('An error occurred during the upload.');
|
|
|
|
|
}
|
|
|
|
|
window.location.reload();
|
|
|
|
|
};
|
|
|
|
|
xhr.open('POST', 'index.php?r=home%2Fupload');
|
|
|
|
|
xhr.send(formData);
|
2024-02-15 10:54:25 +08:00
|
|
|
|
}
|
2024-02-12 15:27:14 +08:00
|
|
|
|
|
2024-02-15 10:54:25 +08:00
|
|
|
|
//拖拽上传
|
2024-02-12 15:27:14 +08:00
|
|
|
|
var dropArea = document.getElementById('drop-area');
|
|
|
|
|
dropArea.addEventListener('dragover', function (event) {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
});
|
|
|
|
|
dropArea.addEventListener('drop', function (event) {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
|
|
var items = event.dataTransfer.items;
|
2024-02-15 10:54:25 +08:00
|
|
|
|
var files = [];
|
2024-02-12 15:27:14 +08:00
|
|
|
|
|
|
|
|
|
for (var i = 0; i < items.length; i++) {
|
|
|
|
|
var item = items[i];
|
2024-02-15 10:54:25 +08:00
|
|
|
|
files.push(item.getAsFile());
|
2024-02-12 15:27:14 +08:00
|
|
|
|
}
|
2024-02-15 10:54:25 +08:00
|
|
|
|
|
|
|
|
|
uploadFiles(files);
|
|
|
|
|
dropArea.classList.remove('dragging');
|
2024-02-12 15:27:14 +08:00
|
|
|
|
});
|
|
|
|
|
dropArea.addEventListener('dragenter', function (event) {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
|
|
dropArea.classList.add('dragging');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
dropArea.addEventListener('dragleave', function (event) {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
|
|
if (!dropArea.contains(event.relatedTarget)) {
|
|
|
|
|
dropArea.classList.remove('dragging');
|
|
|
|
|
}
|
2024-02-15 13:48:29 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 为全选/取消全选的复选框添加事件监听器
|
|
|
|
|
document.getElementById('select-all').addEventListener('change', function() {
|
|
|
|
|
// 获取所有的复选框
|
|
|
|
|
var checkboxes = document.querySelectorAll('.select-item');
|
|
|
|
|
// 设置所有复选框的状态与全选/取消全选的复选框的状态相同
|
|
|
|
|
for (var i = 0; i < checkboxes.length; i++) {
|
|
|
|
|
checkboxes[i].checked = this.checked;
|
|
|
|
|
checkboxes[i].closest('tr').classList.toggle('selected', this.checked);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 为每一行的复选框添加事件监听器
|
|
|
|
|
var itemCheckboxes = document.querySelectorAll('.select-item');
|
|
|
|
|
for (var i = 0; i < itemCheckboxes.length; i++) {
|
|
|
|
|
itemCheckboxes[i].addEventListener('change', function() {
|
|
|
|
|
// 如果有一个复选框未被选中,则全选/取消全选的复选框也应该未被选中
|
|
|
|
|
if (!this.checked) {
|
|
|
|
|
document.getElementById('select-all').checked = false;
|
|
|
|
|
}
|
|
|
|
|
// 如果所有的复选框都被选中,则全选/取消全选的复选框也应该被选中
|
|
|
|
|
else {
|
|
|
|
|
var allChecked = true;
|
|
|
|
|
for (var j = 0; j < itemCheckboxes.length; j++) {
|
|
|
|
|
if (!itemCheckboxes[j].checked) {
|
|
|
|
|
allChecked = false;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
document.getElementById('select-all').checked = allChecked;
|
|
|
|
|
}
|
|
|
|
|
this.closest('tr').classList.toggle('selected', this.checked);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 为document添加键盘事件监听器
|
|
|
|
|
document.addEventListener('keydown', function(event) {
|
|
|
|
|
// 如果用户按下了Ctrl+A
|
|
|
|
|
if (event.ctrlKey && event.key === 'a') {
|
|
|
|
|
// 阻止默认的全选操作
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
// 获取所有的复选框
|
|
|
|
|
var checkboxes = document.querySelectorAll('.select-item');
|
|
|
|
|
var selectAll = document.getElementById('select-all');
|
|
|
|
|
selectAll.checked = !selectAll.checked;
|
|
|
|
|
for (var i = 0; i < checkboxes.length; i++) {
|
|
|
|
|
checkboxes[i].checked = selectAll.checked;
|
|
|
|
|
checkboxes[i].closest('tr').classList.toggle('selected',selectAll.checked);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$(document).on('click', 'tr', function (event) {
|
|
|
|
|
// 如果点击的是checkbox,就不执行下面的代码
|
|
|
|
|
if ($(event.target).is('input[type="checkbox"]')) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$(this).toggleClass('selected');
|
|
|
|
|
var checkbox = $(this).children(':first-child').find('input[type="checkbox"]');
|
|
|
|
|
checkbox.prop('checked', !checkbox.prop('checked'));
|
2024-02-15 10:54:25 +08:00
|
|
|
|
});
|