mirror of
https://github.com/mindoc-org/mindoc.git
synced 2025-09-19 10:08:03 +08:00
实现文档保存
This commit is contained in:
@@ -169,6 +169,10 @@
|
||||
.jstree .jstree-node .m-tree-operate.operate-hover .operate-hide {
|
||||
width: 108px
|
||||
}
|
||||
.jstree-default .jstree-wholerow-hovered {
|
||||
background: #08c;
|
||||
color: white !important;
|
||||
}
|
||||
.jstree-default .jstree-wholerow-clicked {
|
||||
background: #10af88;
|
||||
background: -webkit-linear-gradient(top, #beebff 0%, #a8e4ff 100%);
|
||||
|
@@ -71,7 +71,17 @@ body{
|
||||
}
|
||||
.manual-editor-container .manual-editormd{
|
||||
position: absolute;
|
||||
bottom: 15px;
|
||||
bottom: 30px;
|
||||
top: -1px;
|
||||
left: 0;
|
||||
right: 0;
|
||||
}
|
||||
.manual-editor-container .manual-editormd .manual-editormd-active{
|
||||
position: absolute;
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
}
|
||||
.editormd-group{
|
||||
float: left;
|
||||
@@ -81,6 +91,20 @@ body{
|
||||
.editormd-group a{
|
||||
float: left;
|
||||
}
|
||||
.editormd-group a.change{
|
||||
|
||||
}
|
||||
.editormd-group .change i{
|
||||
color: #ffffff;
|
||||
background-color: #44B036 !important;
|
||||
border: 1px #44B036 solid !important;
|
||||
}
|
||||
.editormd-group .change i:hover{
|
||||
background-color: #58CB48 !important;
|
||||
}
|
||||
.editormd-group .disabled i:hover{
|
||||
background: #ffffff !important;
|
||||
}
|
||||
.editormd-group a.disabled{
|
||||
border-color: #c9c9c9;
|
||||
opacity: .6;
|
||||
@@ -134,4 +158,5 @@ body{
|
||||
border-left: 1px solid #DDDDDD;
|
||||
color: #555;
|
||||
background-color: #FAFAFA;
|
||||
z-index: 1000;
|
||||
}
|
@@ -15,6 +15,7 @@ function showSuccess($msg,$id) {
|
||||
}
|
||||
|
||||
$(function () {
|
||||
window.addDocumentModalFormHtml = $(this).find("form").html();
|
||||
window.editor = editormd("docEditor", {
|
||||
width : "100%",
|
||||
height : "100%",
|
||||
@@ -37,10 +38,25 @@ $(function () {
|
||||
saveHTMLToTextarea : true,
|
||||
onload : function() {
|
||||
this.hideToolbar();
|
||||
var $select_node_id = window.treeCatalog.get_selected();
|
||||
if($select_node_id) {
|
||||
var $select_node = window.treeCatalog.get_node($select_node_id[0])
|
||||
if ($select_node) {
|
||||
$select_node.node = {
|
||||
id: $select_node.id
|
||||
};
|
||||
|
||||
loadDocument($select_node);
|
||||
}
|
||||
}
|
||||
},
|
||||
onchange : function () {
|
||||
resetEditorChanged(true);
|
||||
}
|
||||
});
|
||||
editormd.loadPlugin("/static/editor.md/plugins/file-dialog/file-dialog");
|
||||
|
||||
|
||||
/**
|
||||
* 实现标题栏操作
|
||||
*/
|
||||
@@ -50,6 +66,10 @@ $(function () {
|
||||
window.editor.fileDialog();
|
||||
}else if(name === "history"){
|
||||
|
||||
}else if(name === "save"){
|
||||
|
||||
saveDocument(false);
|
||||
|
||||
}else if(name === "sidebar"){
|
||||
$("#manualCategory").toggle(0,"swing",function () {
|
||||
|
||||
@@ -115,26 +135,32 @@ $(function () {
|
||||
$("#btnAddDocument").on("click",function () {
|
||||
$("#addDocumentModal").modal("show");
|
||||
});
|
||||
$("#addDocumentModal").on("show.bs.modal",function () {
|
||||
window.addDocumentModalFormHtml = $(this).find("form").html();
|
||||
}).on("hidden.bs.modal",function () {
|
||||
$("#addDocumentModal").on("hidden.bs.modal",function () {
|
||||
$(this).find("form").html(window.addDocumentModalFormHtml);
|
||||
}).on("shown.bs.modal",function () {
|
||||
$(this).find("input[name='doc_name']").focus();
|
||||
});
|
||||
|
||||
/***
|
||||
* 加载指定的文档到编辑器中
|
||||
* @param $node
|
||||
*/
|
||||
function loadDocument($node) {
|
||||
var index = layer.load(1, {
|
||||
shade: [0.1,'#fff'] //0.1透明度的白色背景
|
||||
});
|
||||
|
||||
$.get("/docs/"+ window.book.identify +"/" + $node.node.id ).done(function (data) {
|
||||
win.isEditorChange = true;
|
||||
$.get(window.editURL + $node.node.id ).done(function (res) {
|
||||
layer.close(index);
|
||||
$("#documentId").val(selected.node.id);
|
||||
window.editor.clear();
|
||||
if(data.errcode === 0 && data.data.doc.content){
|
||||
window.editor.insertValue(data.data.doc.content);
|
||||
|
||||
resetEditor();
|
||||
if(res.errcode === 0){
|
||||
window.editor.insertValue(res.data.markdown);
|
||||
window.editor.setCursor({line:0, ch:0});
|
||||
}else if(data.errcode !== 0){
|
||||
var node = { "id" : res.data.doc_id,'parent' : res.data.parent_id === 0 ? '#' : res.data.parent_id ,"text" : res.data.doc_name,"identify" : res.data.identify,"version" : res.data.version};
|
||||
pushDocumentCategory(node);
|
||||
|
||||
}else{
|
||||
layer.msg("文档加载失败");
|
||||
}
|
||||
}).fail(function () {
|
||||
@@ -142,8 +168,160 @@ $(function () {
|
||||
layer.msg("文档加载失败");
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加文档
|
||||
* 创建文档
|
||||
*/
|
||||
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
|
||||
*/
|
||||
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);
|
||||
}
|
||||
|
||||
/**
|
||||
* 打开文档编辑界面
|
||||
* @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 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})
|
||||
});
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
function saveDocument($is_cover) {
|
||||
var index = null;
|
||||
var node = window.treeCatalog.get_selected();
|
||||
var content = window.editor.getMarkdown();
|
||||
var html = window.editor.getPreviewedHTML();
|
||||
var version = "";
|
||||
if(content === ""){
|
||||
resetEditorChanged(false);
|
||||
return;
|
||||
}
|
||||
if(!node){
|
||||
layer.msg("获取当前文档信息失败");
|
||||
return;
|
||||
}
|
||||
var doc_id = parseInt(node[0]);
|
||||
|
||||
for(var i in window.documentCategory){
|
||||
var item = window.documentCategory[i];
|
||||
|
||||
if(item.id === doc_id){
|
||||
version = item.version;
|
||||
console.log(item)
|
||||
break;
|
||||
}
|
||||
}
|
||||
$.ajax({
|
||||
beforeSend : function () {
|
||||
index = layer.load(1, {shade: [0.1,'#fff'] });
|
||||
},
|
||||
url : window.editURL,
|
||||
data : {"identify" : window.book.identify,"doc_id" : node[0],"markdown" : content,"html" : html,"cover" : $is_cover ? "yes":"no","version": version},
|
||||
type :"post",
|
||||
dataType :"json",
|
||||
success : function (res) {
|
||||
layer.close(index);
|
||||
if(res.errcode === 0){
|
||||
resetEditorChanged(false);
|
||||
for(var i in window.documentCategory){
|
||||
var item = window.documentCategory[i];
|
||||
|
||||
if(item.id === doc_id){
|
||||
window.documentCategory[i].version = res.data.version;
|
||||
console.log(res.data)
|
||||
break;
|
||||
}
|
||||
}
|
||||
}else if(res.errcode === 6005){
|
||||
var confirmIndex = layer.confirm('你确定要删除该文档吗?', {
|
||||
btn: ['确定','取消'] //按钮
|
||||
}, function(){
|
||||
layer.close(confirmIndex);
|
||||
saveDocument(true);
|
||||
});
|
||||
}else{
|
||||
layer.msg(res.message);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function resetEditor($node) {
|
||||
|
||||
}
|
||||
|
||||
function resetEditorChanged($is_change) {
|
||||
if($is_change){
|
||||
$("#markdown-save").removeClass('disabled').addClass('change');
|
||||
}else{
|
||||
$("#markdown-save").removeClass('change').addClass('disabled');
|
||||
}
|
||||
}
|
||||
/**
|
||||
* 添加顶级文档
|
||||
*/
|
||||
$("#addDocumentForm").ajaxForm({
|
||||
beforeSubmit : function () {
|
||||
@@ -151,29 +329,30 @@ $(function () {
|
||||
if (doc_name === ""){
|
||||
return showError("目录名称不能为空","#add-error-message")
|
||||
}
|
||||
window.addDocumentFormIndex = layer.load(1, { shade: [0.1,'#fff'] });
|
||||
return true;
|
||||
},
|
||||
success : function (res) {
|
||||
if(res.errcode === 0){
|
||||
var data = { "id" : res.data.doc_id,'parent' : res.data.parent_id,"text" : res.data.doc_name};
|
||||
|
||||
var data = { "id" : res.data.doc_id,'parent' : res.data.parent_id === 0 ? '#' : res.data.parent_id ,"text" : res.data.doc_name,"identify" : res.data.identify,"version" : res.data.version};
|
||||
|
||||
var node = window.treeCatalog.get_node(data.id);
|
||||
if(node){
|
||||
window.treeCatalog.rename_node({"id":data.id},data.text);
|
||||
|
||||
}else {
|
||||
var result = window.treeCatalog.create_node(res.data.parent_id, data, 'last');
|
||||
window.treeCatalog.create_node(data.parent, data);
|
||||
window.treeCatalog.deselect_all();
|
||||
window.treeCatalog.select_node(data);
|
||||
window.editor.clear();
|
||||
}
|
||||
pushDocumentCategory(data);
|
||||
$("#markdown-save").removeClass('change').addClass('disabled');
|
||||
$("#addDocumentModal").modal('hide');
|
||||
}else{
|
||||
showError(res.message,"#add-error-message")
|
||||
}
|
||||
},
|
||||
error :function () {
|
||||
|
||||
layer.close(window.addDocumentFormIndex);
|
||||
}
|
||||
});
|
||||
|
||||
@@ -220,7 +399,7 @@ $(function () {
|
||||
"action": function (data) {
|
||||
var inst = $.jstree.reference(data.reference);
|
||||
var node = inst.get_node(data.reference);
|
||||
editDocumentDialog(node);
|
||||
openEditCatalogDialog(node);
|
||||
}
|
||||
},
|
||||
"删除": {
|
||||
@@ -232,23 +411,12 @@ $(function () {
|
||||
"action": function (data) {
|
||||
var inst = $.jstree.reference(data.reference);
|
||||
var node = inst.get_node(data.reference);
|
||||
deleteDocumentDialog(node);
|
||||
openDeleteDocumentDialog(node);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}).on('loaded.jstree', function () {
|
||||
window.treeCatalog = $(this).jstree();
|
||||
var $select_node_id = window.treeCatalog.get_selected();
|
||||
if($select_node_id) {
|
||||
var $select_node = window.treeCatalog.get_node($select_node_id[0])
|
||||
if ($select_node) {
|
||||
$select_node.node = {
|
||||
id: $select_node.id
|
||||
};
|
||||
|
||||
loadDocument($select_node);
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
Reference in New Issue
Block a user