mirror of https://github.com/jak0099/dr.git
251 lines
8.6 KiB
JavaScript
251 lines
8.6 KiB
JavaScript
let ic_dir = '';
|
|
let ic_file = '';
|
|
let current_root = '';
|
|
let current_file = '';
|
|
let current_parent = '';
|
|
|
|
function search() {
|
|
doAction('search', { word: $('#keyword').val() });
|
|
}
|
|
|
|
function push() {
|
|
doAction('push', { url: $('#push_url').val() });
|
|
}
|
|
|
|
function setting() {
|
|
doAction('setting', { text: $('#setting_text').val(), name: $('#setting_name').val() });
|
|
}
|
|
|
|
function file(path) {
|
|
doAction('file', { path: path });
|
|
}
|
|
|
|
function doAction(action, kv) {
|
|
kv['do'] = action;
|
|
$.post('/action', kv, function (data) {
|
|
console.log(data);
|
|
});
|
|
return false;
|
|
}
|
|
|
|
function tpl_top(path) {
|
|
return `<a class="weui-cell weui-cell_access" href="javascript:void(0)" onclick="listFile('` + path + `')">
|
|
<div class="weui-cell__hd"><img src="` + ic_dir + `" alt="" style="width: 32px; margin-right: 16px; display: block;"></div>
|
|
<span class="weui-cell__bd">
|
|
<span class="weui-cell__name">..</span>
|
|
</span>
|
|
<span class="weui-cell__ft">
|
|
</span>
|
|
</a>`;
|
|
}
|
|
|
|
function tpl_dir(name, time, path) {
|
|
return `<a class="weui-cell weui-cell_access" href="#" onclick="listFile('` + path + `')">
|
|
<div class="weui-cell__hd"><img src="` + ic_dir + `" alt="" style="width: 32px; margin-right: 16px; display: block;"></div>
|
|
<span class="weui-cell__bd">
|
|
<span class="weui-cell__name">` + name + `</span>
|
|
<div class="weui-cell__desc">` + time + `</div>
|
|
</span>
|
|
<span class="weui-cell__ft">
|
|
</span>
|
|
</a>`;
|
|
}
|
|
|
|
function tpl_file(name, time, path, canDel) {
|
|
return `<a class="weui-cell weui-cell_access" href="javascript:void(0)" onclick="selectFile('` + path + `', ` + canDel + `)">
|
|
<div class="weui-cell__hd"><img src="` + ic_file + `" alt="" style="width: 32px; margin-right: 16px; display: block;"></div>
|
|
<span class="weui-cell__bd">
|
|
<span class="weui-cell__name">` + name + `</span>
|
|
<div class="weui-cell__desc">` + time + `</div>
|
|
</span>
|
|
</a>`;
|
|
}
|
|
|
|
function clear_list() {
|
|
$('#file_list').html('');
|
|
}
|
|
|
|
function add_file(node) {
|
|
$('#file_list').append(node);
|
|
}
|
|
|
|
function selectFile(path, canDel) {
|
|
current_file = path;
|
|
if (canDel) $("#delFileBtn").show();
|
|
else $("#delFileBtn").hide();
|
|
$("#fileUrl").html("file:/" + current_file);
|
|
$("#fileInfoDialog").show();
|
|
}
|
|
|
|
function pushFile(yes) {
|
|
hideFileInfo();
|
|
if (yes == 1) {
|
|
file("file:/" + current_file);
|
|
}
|
|
}
|
|
|
|
function hideFileInfo() {
|
|
$("#fileInfoDialog").hide();
|
|
}
|
|
|
|
function listFile(path) {
|
|
$('#loadingToast').show();
|
|
$.get('/file' + path, function (res) {
|
|
let info = JSON.parse(res);
|
|
let parent = info.parent;
|
|
let canDel = info.parent != '.';
|
|
current_root = path;
|
|
current_parent = parent;
|
|
let array = info.files;
|
|
if (path === '' && array.length == 0) {
|
|
warnToast('可能沒有存儲權限');
|
|
}
|
|
clear_list();
|
|
if (parent !== '.') {
|
|
add_file(tpl_top(parent));
|
|
}
|
|
if (canDel) {
|
|
$('#delCurFolder').show();
|
|
} else {
|
|
$('#delCurFolder').hide();
|
|
}
|
|
array.forEach(node => {
|
|
if (node.dir === 1) {
|
|
add_file(tpl_dir(node.name, node.time, node.path));
|
|
} else {
|
|
add_file(tpl_file(node.name, node.time, node.path, canDel));
|
|
}
|
|
});
|
|
$('#loadingToast').hide();
|
|
})
|
|
}
|
|
|
|
|
|
function uploadFile() {
|
|
$('#file_uploader').click();
|
|
}
|
|
|
|
function uploadTip() {
|
|
let files = $('#file_uploader')[0].files;
|
|
if (files.length <= 0) return false;
|
|
let tip = '';
|
|
for (var i = 0; i < files.length; i++) {
|
|
tip += (files[i].name) + ',';
|
|
}
|
|
tip = tip.substring(0, tip.length - 1);
|
|
$('#uploadTipContent').html(tip);
|
|
$('#uploadTip').show();
|
|
}
|
|
|
|
function doUpload(yes) {
|
|
$('#uploadTip').hide();
|
|
if (yes == 1) {
|
|
let files = $('#file_uploader')[0].files;
|
|
if (files.length <= 0) return false;
|
|
var formData = new FormData();
|
|
formData.append('path', current_root);
|
|
for (i = 0; i < files.length; i++) {
|
|
formData.append("files-" + i, files[i]);
|
|
}
|
|
$('#loadingToast').show();
|
|
$.ajax({
|
|
url: '/upload',
|
|
type: 'post',
|
|
data: formData,
|
|
processData: false,
|
|
contentType: false,
|
|
complete: function () {
|
|
$('#loadingToast').hide();
|
|
listFile(current_root);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
function newFolder() {
|
|
$('#newFolder').show();
|
|
}
|
|
|
|
function doNewFolder(yes) {
|
|
$('#newFolder').hide();
|
|
if (yes == 1) {
|
|
let name = $('#newFolderContent')[0].value.trim();
|
|
if (name.length <= 0) return false;
|
|
$('#loadingToast').show();
|
|
$.post('/newFolder', { path: current_root, name: name }, function (data) {
|
|
$('#loadingToast').hide();
|
|
listFile(current_root);
|
|
});
|
|
}
|
|
}
|
|
|
|
function delFolder() {
|
|
$('#delFolderContent').html('是否刪除 ' + current_root);
|
|
$('#delFolder').show();
|
|
}
|
|
|
|
function doDelFolder(yes) {
|
|
$('#delFolder').hide();
|
|
if (yes == 1) {
|
|
$('#loadingToast').show();
|
|
$.post('/delFolder', { path: current_root }, function (data) {
|
|
$('#loadingToast').hide();
|
|
listFile(current_parent);
|
|
});
|
|
}
|
|
}
|
|
|
|
function delFile() {
|
|
$('#delFileContent').html('是否刪除 ' + current_file);
|
|
$('#delFile').show();
|
|
hideFileInfo();
|
|
}
|
|
|
|
function doDelFile(yes) {
|
|
$('#delFile').hide();
|
|
if (yes == 1) {
|
|
$('#loadingToast').show();
|
|
$.post('/delFile', { path: current_file }, function (data) {
|
|
$('#loadingToast').hide();
|
|
listFile(current_root);
|
|
});
|
|
}
|
|
}
|
|
|
|
function warnToast(msg) {
|
|
$('#warnToastContent').html(msg);
|
|
$('#warnToast').show();
|
|
setTimeout(() => {
|
|
$('#warnToast').hide();
|
|
}, 1000);
|
|
}
|
|
|
|
function showPanel(id) {
|
|
let tab = $('#tab' + id);
|
|
$(tab).attr('aria-selected', 'true').addClass('weui-bar__item_on');
|
|
$(tab).siblings('.weui-bar__item_on').removeClass('weui-bar__item_on').attr('aria-selected', 'false');
|
|
var panelId = '#' + $(tab).attr('aria-controls');
|
|
$(panelId).css('display', 'block');
|
|
$(panelId).siblings('.weui-tab__panel').css('display', 'none');
|
|
if (id === 4) listFile('')
|
|
}
|
|
|
|
$(function () {
|
|
$('.weui-tabbar__item').on('click', function () {
|
|
showPanel(parseInt($(this).attr('id').substr(3)));
|
|
});
|
|
});
|
|
|
|
$(document).ready(function () {
|
|
var url = window.location.search;
|
|
if (url.indexOf('tab=2') > 0) {
|
|
showPanel(2);
|
|
} else if (url.indexOf('tab=3') > 0) {
|
|
showPanel(3);
|
|
} else if (url.indexOf('tab=4') > 0) {
|
|
showPanel(4);
|
|
} else {
|
|
showPanel(1);
|
|
}
|
|
});
|