2014-08-18 17:45:43 +04:00
|
|
|
|
var tree = {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
fileTree: {},
|
2014-08-18 17:45:43 +04:00
|
|
|
|
newFile: function() {
|
|
|
|
|
$("#dirRMenu ul").hide();
|
|
|
|
|
var name = prompt("Name", "");
|
2014-08-19 11:44:30 +04:00
|
|
|
|
if (!name) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-18 17:45:43 +04:00
|
|
|
|
var request = {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
path: wide.curNode.path + '/' + name,
|
2014-08-18 17:45:43 +04:00
|
|
|
|
fileType: "f"
|
|
|
|
|
};
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: 'POST',
|
|
|
|
|
url: '/file/new',
|
|
|
|
|
data: JSON.stringify(request),
|
|
|
|
|
dataType: "json",
|
|
|
|
|
success: function(data) {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
if (!data.succ) {
|
|
|
|
|
return false;
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
2014-08-19 11:44:30 +04:00
|
|
|
|
tree.fileTree.addNodes(wide.curNode, [{
|
|
|
|
|
"name": name
|
|
|
|
|
}]);
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
newDir: function() {
|
|
|
|
|
$("#dirRMenu ul").hide();
|
|
|
|
|
var name = prompt("Name", "");
|
2014-08-19 11:44:30 +04:00
|
|
|
|
if (!name) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-18 17:45:43 +04:00
|
|
|
|
var request = {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
path: wide.curNode.path + '/' + name,
|
2014-08-18 17:45:43 +04:00
|
|
|
|
fileType: "d"
|
|
|
|
|
};
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: 'POST',
|
|
|
|
|
url: '/file/new',
|
|
|
|
|
data: JSON.stringify(request),
|
|
|
|
|
dataType: "json",
|
|
|
|
|
success: function(data) {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
if (!data.succ) {
|
|
|
|
|
return false;
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
2014-08-19 11:44:30 +04:00
|
|
|
|
// TODO: 换成我们风格的 class
|
|
|
|
|
tree.fileTree.addNodes(wide.curNode, [{
|
|
|
|
|
"name": name,
|
|
|
|
|
"iconSkin": "ico_close "
|
|
|
|
|
}]);
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
removeIt: function() {
|
|
|
|
|
$("#dirRMenu ul").hide();
|
|
|
|
|
$("#fileRMenu ul").hide();
|
2014-08-19 11:44:30 +04:00
|
|
|
|
|
2014-08-18 17:45:43 +04:00
|
|
|
|
if (!confirm("Remove it?")) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
var request = {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
path: wide.curNode.path
|
2014-08-18 17:45:43 +04:00
|
|
|
|
};
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: 'POST',
|
|
|
|
|
url: '/file/remove',
|
|
|
|
|
data: JSON.stringify(request),
|
|
|
|
|
dataType: "json",
|
|
|
|
|
success: function(data) {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
if (!data.succ) {
|
|
|
|
|
return false;
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
2014-08-19 11:44:30 +04:00
|
|
|
|
tree.fileTree.removeNode(wide.curNode);
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
init: function() {
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: 'GET',
|
|
|
|
|
url: '/files',
|
|
|
|
|
dataType: "json",
|
|
|
|
|
success: function(data) {
|
|
|
|
|
if (data.succ) {
|
|
|
|
|
var dirRMenu = $("#dirRMenu");
|
|
|
|
|
var fileRMenu = $("#fileRMenu");
|
|
|
|
|
var setting = {
|
|
|
|
|
view: {
|
|
|
|
|
selectedMulti: false
|
|
|
|
|
},
|
|
|
|
|
callback: {
|
|
|
|
|
onRightClick: function(event, treeId, treeNode) {
|
|
|
|
|
if (treeNode) {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
wide.curNode = treeNode;
|
2014-08-18 17:45:43 +04:00
|
|
|
|
if ("f" === treeNode.type) { // 如果右击了文件
|
|
|
|
|
$("#fileRMenu ul").show();
|
|
|
|
|
fileRMenu.css({"top": event.clientY + "px", "left": event.clientX + "px", "display": "block"});
|
|
|
|
|
} else { // 右击了目录
|
|
|
|
|
$("#dirRMenu ul").show();
|
|
|
|
|
dirRMenu.css({"top": event.clientY + "px", "left": event.clientX + "px", "display": "block"});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
onClick: function(event, treeId, treeNode, clickFlag) {
|
2014-08-19 11:44:30 +04:00
|
|
|
|
wide.curNode = treeNode;
|
2014-08-18 17:45:43 +04:00
|
|
|
|
if ("f" === treeNode.type) { // 如果单击了文件
|
|
|
|
|
var request = {
|
|
|
|
|
path: treeNode.path
|
|
|
|
|
};
|
|
|
|
|
$.ajax({
|
|
|
|
|
type: 'POST',
|
|
|
|
|
url: '/file',
|
|
|
|
|
data: JSON.stringify(request),
|
|
|
|
|
dataType: "json",
|
|
|
|
|
success: function(data) {
|
2014-08-19 13:07:35 +04:00
|
|
|
|
if (!data.succ) {
|
2014-09-01 14:55:11 +04:00
|
|
|
|
alert(data.msg);
|
|
|
|
|
|
2014-08-19 13:07:35 +04:00
|
|
|
|
return false;
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
2014-09-01 17:40:10 +04:00
|
|
|
|
|
|
|
|
|
if ("img" == data.mode) { // 是图片文件的话新建 tab 打开
|
|
|
|
|
// 最好是开 tab,但这个最终取决于浏览器设置
|
|
|
|
|
var w = window.open(data.path);
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-19 13:07:35 +04:00
|
|
|
|
editors.newEditor(data);
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
2014-08-19 11:44:30 +04:00
|
|
|
|
tree.fileTree = $.fn.zTree.init($("#files"), setting, data.root.children);
|
2014-08-31 10:07:35 +04:00
|
|
|
|
// tree.fileTree.expandAll(true);
|
2014-08-18 17:45:43 +04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|