2018-07-17 19:13:11 +08:00
|
|
|
|
$(function () {
|
|
|
|
|
editormd.katexURL = {
|
2018-08-07 18:29:15 +08:00
|
|
|
|
js : window.katex.js,
|
|
|
|
|
css : window.katex.css
|
2018-07-17 19:13:11 +08:00
|
|
|
|
};
|
2021-10-09 18:22:43 +08:00
|
|
|
|
var htmlDecodeList = ["style","script","title","onmouseover","onmouseout","style"];
|
|
|
|
|
if (!window.IS_ENABLE_IFRAME) {
|
|
|
|
|
htmlDecodeList.unshift("iframe");
|
|
|
|
|
}
|
2018-07-17 19:13:11 +08:00
|
|
|
|
window.editor = editormd("docEditor", {
|
|
|
|
|
width: "100%",
|
|
|
|
|
height: "100%",
|
2018-08-07 18:29:15 +08:00
|
|
|
|
path: window.editormdLib,
|
2018-07-17 19:13:11 +08:00
|
|
|
|
toolbar: true,
|
|
|
|
|
placeholder: "本编辑器支持 Markdown 编辑,左边编写,右边预览。",
|
|
|
|
|
imageUpload: true,
|
|
|
|
|
imageFormats: ["jpg", "jpeg", "gif", "png", "JPG", "JPEG", "GIF", "PNG"],
|
|
|
|
|
imageUploadURL: window.imageUploadURL,
|
|
|
|
|
toolbarModes: "full",
|
|
|
|
|
fileUpload: true,
|
|
|
|
|
fileUploadURL: window.fileUploadURL,
|
|
|
|
|
taskList: true,
|
|
|
|
|
flowChart: true,
|
2018-08-31 18:17:47 +08:00
|
|
|
|
mermaid: true,
|
2021-10-09 18:22:43 +08:00
|
|
|
|
htmlDecode: htmlDecodeList.join(','),
|
|
|
|
|
lineNumbers: true,
|
2018-07-17 19:13:11 +08:00
|
|
|
|
sequenceDiagram: true,
|
2018-08-07 17:19:56 +08:00
|
|
|
|
highlightStyle: window.highlightStyle ? window.highlightStyle : "github",
|
2018-07-17 19:13:11 +08:00
|
|
|
|
tocStartLevel: 1,
|
|
|
|
|
tocm: true,
|
|
|
|
|
tex:true,
|
|
|
|
|
saveHTMLToTextarea: true,
|
|
|
|
|
|
|
|
|
|
onload: function() {
|
|
|
|
|
this.hideToolbar();
|
|
|
|
|
var keyMap = {
|
|
|
|
|
"Ctrl-S": function(cm) {
|
|
|
|
|
saveBlog(false);
|
|
|
|
|
},
|
|
|
|
|
"Cmd-S": function(cm){
|
|
|
|
|
saveBlog(false);
|
|
|
|
|
},
|
|
|
|
|
"Ctrl-A": function(cm) {
|
|
|
|
|
cm.execCommand("selectAll");
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
this.addKeyMap(keyMap);
|
|
|
|
|
|
|
|
|
|
uploadImage("docEditor", function ($state, $res) {
|
2018-09-05 17:56:18 +08:00
|
|
|
|
console.log("注册上传图片")
|
2018-07-17 19:13:11 +08:00
|
|
|
|
if ($state === "before") {
|
|
|
|
|
return layer.load(1, {
|
|
|
|
|
shade: [0.1, '#fff'] // 0.1 透明度的白色背景
|
|
|
|
|
});
|
|
|
|
|
} else if ($state === "success") {
|
|
|
|
|
if ($res.errcode === 0) {
|
|
|
|
|
var value = '![](' + $res.url + ')';
|
|
|
|
|
window.editor.insertValue(value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
onchange: function () {
|
|
|
|
|
resetEditorChanged(true);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
/**
|
|
|
|
|
* 实现标题栏操作
|
|
|
|
|
*/
|
|
|
|
|
$("#editormd-tools").on("click", "a[class!='disabled']", function () {
|
|
|
|
|
var name = $(this).find("i").attr("name");
|
|
|
|
|
if (name === "attachment") {
|
|
|
|
|
$("#uploadAttachModal").modal("show");
|
|
|
|
|
}else if (name === "save") {
|
|
|
|
|
saveBlog(false);
|
|
|
|
|
} else if (name === "template") {
|
|
|
|
|
$("#documentTemplateModal").modal("show");
|
|
|
|
|
} else if (name === "tasks") {
|
|
|
|
|
// 插入 GFM 任务列表
|
|
|
|
|
var cm = window.editor.cm;
|
|
|
|
|
var selection = cm.getSelection();
|
|
|
|
|
|
|
|
|
|
if (selection === "") {
|
|
|
|
|
cm.replaceSelection("- [x] " + selection);
|
|
|
|
|
} else {
|
|
|
|
|
var selectionText = selection.split("\n");
|
|
|
|
|
|
|
|
|
|
for (var i = 0, len = selectionText.length; i < len; i++) {
|
|
|
|
|
selectionText[i] = (selectionText[i] === "") ? "" : "- [x] " + selectionText[i];
|
|
|
|
|
}
|
|
|
|
|
cm.replaceSelection(selectionText.join("\n"));
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
var action = window.editor.toolbarHandlers[name];
|
|
|
|
|
|
|
|
|
|
if (action !== "undefined") {
|
|
|
|
|
$.proxy(action, window.editor)();
|
|
|
|
|
window.editor.focus();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}) ;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 保存文章
|
|
|
|
|
* @param $is_cover
|
|
|
|
|
*/
|
|
|
|
|
function saveBlog($is_cover) {
|
|
|
|
|
var content = window.editor.getMarkdown();
|
|
|
|
|
var html = window.editor.getPreviewedHTML();
|
|
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
|
beforeSend: function () {
|
|
|
|
|
index = layer.load(1, { shade: [0.1, '#fff'] });
|
|
|
|
|
},
|
|
|
|
|
url: window.editURL,
|
|
|
|
|
data: { "blogId": window.blogId,"content": content,"htmlContent": html, "cover": $is_cover ? "yes" : "no","version" : window.blogVersion},
|
|
|
|
|
type: "post",
|
|
|
|
|
timeout : 30000,
|
|
|
|
|
dataType: "json",
|
|
|
|
|
success: function ($res) {
|
|
|
|
|
layer.close(index);
|
|
|
|
|
if ($res.errcode === 0) {
|
|
|
|
|
resetEditorChanged(false);
|
|
|
|
|
window.blogVersion = $res.data.version;
|
|
|
|
|
} else if($res.errcode === 6005) {
|
|
|
|
|
var confirmIndex = layer.confirm('文档已被其他人修改确定覆盖已存在的文档吗?', {
|
|
|
|
|
btn: ['确定', '取消'] // 按钮
|
|
|
|
|
}, function() {
|
|
|
|
|
layer.close(confirmIndex);
|
|
|
|
|
saveBlog(true);
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
layer.msg(res.message);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
error : function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
|
|
layer.close(index);
|
|
|
|
|
layer.msg("服务器错误:" + errorThrown);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 设置编辑器变更状态
|
|
|
|
|
* @param $is_change
|
|
|
|
|
*/
|
|
|
|
|
function resetEditorChanged($is_change) {
|
|
|
|
|
if ($is_change && !window.isLoad) {
|
|
|
|
|
$("#markdown-save").removeClass('disabled').addClass('change');
|
|
|
|
|
} else {
|
|
|
|
|
$("#markdown-save").removeClass('change').addClass('disabled');
|
|
|
|
|
}
|
|
|
|
|
window.isLoad = false;
|
|
|
|
|
}
|
2018-07-18 17:10:24 +08:00
|
|
|
|
/**
|
|
|
|
|
* 打开文档模板
|
|
|
|
|
*/
|
|
|
|
|
$("#documentTemplateModal").on("click", ".section>a[data-type]", function () {
|
|
|
|
|
var $this = $(this).attr("data-type");
|
|
|
|
|
var body = $("#template-" + $this).html();
|
|
|
|
|
if (body) {
|
|
|
|
|
window.isLoad = true;
|
|
|
|
|
window.editor.clear();
|
|
|
|
|
window.editor.insertValue(body);
|
|
|
|
|
window.editor.setCursor({ line: 0, ch: 0 });
|
|
|
|
|
resetEditorChanged(true);
|
|
|
|
|
}
|
|
|
|
|
$("#documentTemplateModal").modal('hide');
|
|
|
|
|
});
|
2018-07-17 19:13:11 +08:00
|
|
|
|
});
|