/** * 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; 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 + " 个附件") } } }); });