mirror of https://github.com/mindoc-org/mindoc.git
332 lines
9.2 KiB
JavaScript
332 lines
9.2 KiB
JavaScript
/**
|
|
* Created by lifei6671 on 2017/4/29 0029.
|
|
*/
|
|
/**
|
|
* 保存排序
|
|
* @param node
|
|
* @param parent
|
|
*/
|
|
function jstree_save(node, parent) {
|
|
|
|
var parentNode = window.treeCatalog.get_node(parent.parent);
|
|
|
|
var nodeData = window.getSiblingSort(parentNode);
|
|
|
|
if (parent.parent !== parent.old_parent) {
|
|
parentNode = window.treeCatalog.get_node(parent.old_parent);
|
|
var newNodeData = window.getSiblingSort(parentNode);
|
|
if (newNodeData.length > 0) {
|
|
nodeData = nodeData.concat(newNodeData);
|
|
}
|
|
}
|
|
|
|
var index = layer.load(1, {
|
|
shade: [0.1, '#fff'] //0.1透明度的白色背景
|
|
});
|
|
|
|
console.log(JSON.stringify(nodeData));
|
|
|
|
$.ajax({
|
|
url : window.sortURL,
|
|
type :"post",
|
|
data : JSON.stringify(nodeData),
|
|
success : function (res) {
|
|
layer.close(index);
|
|
if (res.errcode === 0){
|
|
layer.msg("保存排序成功");
|
|
}else{
|
|
layer.msg(res.message);
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
/**
|
|
* 创建文档
|
|
*/
|
|
function openCreateCatalogDialog($node) {
|
|
var $then = $("#addDocumentModal");
|
|
|
|
var doc_id = $node ? $node.id : 0;
|
|
|
|
$then.find("input[name='parent_id']").val(doc_id);
|
|
|
|
$then.modal("show");
|
|
}
|
|
|
|
/**
|
|
* 处理排序
|
|
* @param node
|
|
* @returns {Array}
|
|
*/
|
|
function getSiblingSort (node) {
|
|
var data = [];
|
|
|
|
for(var key in node.children){
|
|
var index = data.length;
|
|
|
|
data[index] = {
|
|
"id" : parseInt(node.children[key]),
|
|
"sort" : parseInt(key),
|
|
"parent" : Number(node.id) ? Number(node.id) : 0
|
|
};
|
|
}
|
|
return data;
|
|
}
|
|
|
|
|
|
/**
|
|
* 删除一个文档
|
|
* @param $node
|
|
*/
|
|
function openDeleteDocumentDialog($node) {
|
|
var index = layer.confirm('你确定要删除该文档吗?', {
|
|
btn: ['确定','取消'] //按钮
|
|
}, function(){
|
|
|
|
$.post(window.deleteURL,{"identify" : window.book.identify,"doc_id" : $node.id}).done(function (res) {
|
|
layer.close(index);
|
|
if(res.errcode === 0){
|
|
window.treeCatalog.delete_node($node);
|
|
resetEditor($node);
|
|
}else{
|
|
layer.msg("删除失败",{icon : 2})
|
|
}
|
|
}).fail(function () {
|
|
layer.close(index);
|
|
layer.msg("删除失败",{icon : 2})
|
|
});
|
|
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 打开文档编辑界面
|
|
* @param $node
|
|
*/
|
|
function openEditCatalogDialog($node) {
|
|
var $then = $("#addDocumentModal");
|
|
var doc_id = parseInt($node ? $node.id : 0);
|
|
var text = $node ? $node.text : '';
|
|
var parentId = $node && $node.parent !== '#' ? $node.parent : 0;
|
|
|
|
$then.find("input[name='doc_id']").val(doc_id);
|
|
$then.find("input[name='parent_id']").val(parentId);
|
|
$then.find("input[name='doc_name']").val(text);
|
|
|
|
for (var index in window.documentCategory){
|
|
var item = window.documentCategory[index];
|
|
if(item.id === doc_id){
|
|
$then.find("input[name='doc_identify']").val(item.identify);
|
|
break;
|
|
}
|
|
}
|
|
|
|
$then.modal({ show : true });
|
|
}
|
|
|
|
/**
|
|
* 将一个节点推送到现有数组中
|
|
* @param $node
|
|
*/
|
|
function pushDocumentCategory($node) {
|
|
for (var index in window.documentCategory){
|
|
var item = window.documentCategory[index];
|
|
if(item.id === $node.id){
|
|
|
|
window.documentCategory[index] = $node;
|
|
console.log( window.documentCategory[index]);
|
|
return;
|
|
}
|
|
}
|
|
window.documentCategory.push($node);
|
|
}
|
|
/**
|
|
* 将数据重置到Vue列表中
|
|
* @param $lists
|
|
*/
|
|
function pushVueLists($lists) {
|
|
|
|
window.vueApp.lists = [];
|
|
for(var j in $lists){
|
|
var item = $lists[j];
|
|
window.vueApp.lists.push(item);
|
|
}
|
|
}
|
|
|
|
//实现小提示
|
|
$("[data-toggle='tooltip']").hover(function () {
|
|
var title = $(this).attr('data-title');
|
|
var direction = $(this).attr("data-direction");
|
|
var tips = 3;
|
|
if(direction === "top"){
|
|
tips = 1;
|
|
}else if(direction === "right"){
|
|
tips = 2;
|
|
}else if(direction === "bottom"){
|
|
tips = 3;
|
|
}else if(direction === "left"){
|
|
tips = 4;
|
|
}
|
|
index = layer.tips(title, this, {
|
|
tips: tips
|
|
});
|
|
}, function () {
|
|
layer.close(index);
|
|
});
|
|
//弹出创建文档的遮罩层
|
|
$("#btnAddDocument").on("click",function () {
|
|
$("#addDocumentModal").modal("show");
|
|
});
|
|
//用于还原创建文档的遮罩层
|
|
$("#addDocumentModal").on("hidden.bs.modal",function () {
|
|
$(this).find("form").html(window.addDocumentModalFormHtml);
|
|
}).on("shown.bs.modal",function () {
|
|
$(this).find("input[name='doc_name']").focus();
|
|
});
|
|
|
|
function showError($msg,$id) {
|
|
if(!$id){
|
|
$id = "#form-error-message"
|
|
}
|
|
$($id).addClass("error-message").removeClass("success-message").text($msg);
|
|
return false;
|
|
}
|
|
|
|
function showSuccess($msg,$id) {
|
|
if(!$id){
|
|
$id = "#form-error-message"
|
|
}
|
|
$($id).addClass("success-message").removeClass("error-message").text($msg);
|
|
return true;
|
|
}
|
|
|
|
window.documentHistory = function() {
|
|
layer.open({
|
|
type: 2,
|
|
title: '历史版本',
|
|
shadeClose: true,
|
|
shade: 0.8,
|
|
area: ['700px','80%'],
|
|
content: window.historyURL + "?identify=" + window.book.identify + "&doc_id=" + window.selectNode.id,
|
|
end : function () {
|
|
if(window.SelectedId){
|
|
var selected = {node:{
|
|
id : window.SelectedId
|
|
}};
|
|
window.loadDocument(selected);
|
|
window.SelectedId = null;
|
|
}
|
|
}
|
|
});
|
|
};
|
|
//格式化文件大小
|
|
function formatBytes($size) {
|
|
var $units = [" B", " KB", " MB", " GB", " TB"];
|
|
|
|
for ($i = 0; $size >= 1024 && $i < 4; $i++) $size /= 1024;
|
|
|
|
return $size.toFixed(2) + $units[$i];
|
|
}
|
|
|
|
function uploadImage($id,$callback) {
|
|
/** 粘贴上传图片 **/
|
|
document.getElementById($id).addEventListener('paste', function(e) {
|
|
|
|
var clipboard = e.clipboardData;
|
|
for (var i = 0, len = clipboard.items.length; i < len; i++) {
|
|
if (clipboard.items[i].kind === 'file' || clipboard.items[i].type.indexOf('image') > -1) {
|
|
|
|
var imageFile = clipboard.items[i].getAsFile();
|
|
|
|
console.log(imageFile)
|
|
var fileName = Date.parse(new Date());
|
|
|
|
switch (imageFile.type){
|
|
case "image/png" : fileName += ".png";break;
|
|
case "image/jpg" : fileName += ".jpg";break
|
|
case "image/jpeg" : fileName += ".jpeg";break;
|
|
case "image/gif" : fileName += ".gif";break;
|
|
default : layer.msg("不支持的图片格式");return;
|
|
}
|
|
var form = new FormData();
|
|
|
|
form.append('editormd-image-file', imageFile, fileName);
|
|
|
|
var layerIndex = 0;
|
|
|
|
$.ajax({
|
|
url: window.imageUploadURL,
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: form,
|
|
processData: false,
|
|
contentType: false,
|
|
beforeSend: function() {
|
|
layerIndex = $callback('before');
|
|
},
|
|
error: function() {
|
|
layer.close(layerIndex);
|
|
$callback('error');
|
|
layer.msg("图片上传失败");
|
|
},
|
|
success: function(data) {
|
|
layer.close(layerIndex);
|
|
$callback('success', data);
|
|
if(data.errcode !== 0){
|
|
layer.msg(data.message);
|
|
}
|
|
|
|
}
|
|
});
|
|
e.preventDefault();
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
$(function () {
|
|
window.vueApp = new Vue({
|
|
el : "#attachList",
|
|
data : {
|
|
lists : []
|
|
},
|
|
delimiters : ['${','}'],
|
|
methods : {
|
|
removeAttach : function ($attach_id) {
|
|
var $this = this;
|
|
var item = $this.lists.filter(function ($item) {
|
|
return $item.attachment_id == $attach_id;
|
|
});
|
|
|
|
if(item && item[0].hasOwnProperty("state")){
|
|
$this.lists = $this.lists.filter(function ($item) {
|
|
return $item.attachment_id != $attach_id;
|
|
});
|
|
return;
|
|
}
|
|
$.ajax({
|
|
url : window.removeAttachURL,
|
|
type : "post",
|
|
data : { "attach_id" : $attach_id},
|
|
success : function (res) {
|
|
console.log(res);
|
|
if(res.errcode === 0){
|
|
$this.lists = $this.lists.filter(function ($item) {
|
|
return $item.attachment_id != $attach_id;
|
|
});
|
|
}else{
|
|
layer.msg(res.message);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
},
|
|
watch : {
|
|
lists : function ($lists) {
|
|
$("#attachInfo").text(" " + $lists.length + " 个附件")
|
|
}
|
|
}
|
|
});
|
|
|
|
}); |