Browse Source

Fixed some bugs

develop
pandao 6 years ago
parent
commit
6704d47869
  1. 8881
      css/editormd.css
  2. 176
      css/editormd.logo.css
  3. 4
      css/editormd.logo.min.css
  4. 10
      css/editormd.min.css
  5. 7088
      css/editormd.preview.css
  6. 10
      css/editormd.preview.min.css
  7. 324
      editormd.amd.js
  8. 6
      editormd.amd.min.js
  9. 323
      editormd.js
  10. 5
      editormd.min.js
  11. 14
      examples/dynamic-create-editormd.html
  12. 4
      examples/form-get-value.html
  13. 10
      examples/katex.html
  14. 25
      examples/multi-editormd.html
  15. 44
      examples/test.md
  16. 4
      languages/zh-tw.js
  17. 6
      lib/codemirror/addons.min.js
  18. 12
      lib/codemirror/modes.min.js
  19. 11
      lib/marked.min.js
  20. 2
      package.json
  21. 4
      plugins/code-block-dialog/code-block-dialog.js
  22. 4
      plugins/emoji-dialog/emoji-dialog.js
  23. 4
      plugins/goto-line-dialog/goto-line-dialog.js
  24. 2
      plugins/help-dialog/help-dialog.js
  25. 4
      plugins/html-entities-dialog/html-entities-dialog.js
  26. 2
      plugins/image-dialog/image-dialog.js
  27. 4
      plugins/link-dialog/link-dialog.js
  28. 2
      plugins/preformatted-text-dialog/preformatted-text-dialog.js
  29. 4
      plugins/reference-link-dialog/reference-link-dialog.js
  30. 4
      plugins/table-dialog/table-dialog.js
  31. 351
      src/editormd.js

8881
css/editormd.css

File diff suppressed because it is too large

176
css/editormd.logo.css

@ -1,98 +1,98 @@
/*
* Editor.md
*
* @file editormd.logo.css
* @file /editormd.logo.css
* @version v1.5.0
* @description Open source online markdown editor.
* @license MIT License
* @author Pandao
* {@link https://github.com/pandao/editor.md}
* @updateTime 2015-06-09
* @updateTime 2019-05-11
*/
/*! prefixes.scss v0.1.0 | Author: Pandao | https://github.com/pandao/prefixes.scss | MIT license | Copyright (c) 2015 */
@font-face {
font-family: 'editormd-logo';
src: url("../fonts/editormd-logo.eot?-5y8q6h");
src: url(".../fonts/editormd-logo.eot?#iefix-5y8q6h") format("embedded-opentype"), url("../fonts/editormd-logo.woff?-5y8q6h") format("woff"), url("../fonts/editormd-logo.ttf?-5y8q6h") format("truetype"), url("../fonts/editormd-logo.svg?-5y8q6h#icomoon") format("svg");
font-weight: normal;
font-style: normal;
}
.editormd-logo,
.editormd-logo-1x,
.editormd-logo-2x,
.editormd-logo-3x,
.editormd-logo-4x,
.editormd-logo-5x,
.editormd-logo-6x,
.editormd-logo-7x,
.editormd-logo-8x {
font-family: 'editormd-logo';
speak: none;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
font-size: inherit;
line-height: 1;
display: inline-block;
text-rendering: auto;
vertical-align: inherit;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.editormd-logo:before,
.editormd-logo-1x:before,
.editormd-logo-2x:before,
.editormd-logo-3x:before,
.editormd-logo-4x:before,
.editormd-logo-5x:before,
.editormd-logo-6x:before,
.editormd-logo-7x:before,
.editormd-logo-8x:before {
content: "\e1987";
/*
HTML Entity 󡦇
example: <span class="editormd-logo">&#xe1987;</span>
*/
}
.editormd-logo-1x {
font-size: 1em;
}
.editormd-logo-lg {
font-size: 1.2em;
}
.editormd-logo-2x {
font-size: 2em;
}
.editormd-logo-3x {
font-size: 3em;
}
.editormd-logo-4x {
font-size: 4em;
}
.editormd-logo-5x {
font-size: 5em;
}
.editormd-logo-6x {
font-size: 6em;
}
.editormd-logo-7x {
font-size: 7em;
}
.editormd-logo-8x {
font-size: 8em;
}
.editormd-logo-color {
color: #2196F3;
}
/*! prefixes.scss v0.1.0 | Author: Pandao | https://github.com/pandao/prefixes.scss | MIT license | Copyright (c) 2015 */
@font-face {
font-family: 'editormd-logo';
src: url("../fonts/editormd-logo.eot?-5y8q6h");
src: url("../fonts/editormd-logo.eot?#iefix-5y8q6h") format("embedded-opentype"), url("../fonts/editormd-logo.woff?-5y8q6h") format("woff"), url("../fonts/editormd-logo.ttf?-5y8q6h") format("truetype"), url("../fonts/editormd-logo.svg?-5y8q6h#icomoon") format("svg");
font-weight: normal;
font-style: normal;
}
.editormd-logo,
.editormd-logo-1x,
.editormd-logo-2x,
.editormd-logo-3x,
.editormd-logo-4x,
.editormd-logo-5x,
.editormd-logo-6x,
.editormd-logo-7x,
.editormd-logo-8x {
font-family: 'editormd-logo';
speak: none;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
font-size: inherit;
line-height: 1;
display: inline-block;
text-rendering: auto;
vertical-align: inherit;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.editormd-logo:before,
.editormd-logo-1x:before,
.editormd-logo-2x:before,
.editormd-logo-3x:before,
.editormd-logo-4x:before,
.editormd-logo-5x:before,
.editormd-logo-6x:before,
.editormd-logo-7x:before,
.editormd-logo-8x:before {
content: "\e1987";
/*
HTML Entity &#xe1987;
example: <span class="editormd-logo">&#xe1987;</span>
*/
}
.editormd-logo-1x {
font-size: 1em;
}
.editormd-logo-lg {
font-size: 1.2em;
}
.editormd-logo-2x {
font-size: 2em;
}
.editormd-logo-3x {
font-size: 3em;
}
.editormd-logo-4x {
font-size: 4em;
}
.editormd-logo-5x {
font-size: 5em;
}
.editormd-logo-6x {
font-size: 6em;
}
.editormd-logo-7x {
font-size: 7em;
}
.editormd-logo-8x {
font-size: 8em;
}
.editormd-logo-color {
color: #2196F3;
}

4
css/editormd.logo.min.css

@ -1,2 +1,2 @@
/*! Editor.md v1.5.0 | editormd.logo.min.css | Open source online markdown editor. | MIT License | By: Pandao | https://github.com/pandao/editor.md | 2015-06-09 */
/*! prefixes.scss v0.1.0 | Author: Pandao | https://github.com/pandao/prefixes.scss | MIT license | Copyright (c) 2015 */@font-face{font-family:editormd-logo;src:url(../fonts/editormd-logo.eot?-5y8q6h);src:url(.../fonts/editormd-logo.eot?#iefix-5y8q6h)format("embedded-opentype"),url(../fonts/editormd-logo.woff?-5y8q6h)format("woff"),url(../fonts/editormd-logo.ttf?-5y8q6h)format("truetype"),url(../fonts/editormd-logo.svg?-5y8q6h#icomoon)format("svg");font-weight:400;font-style:normal}.editormd-logo,.editormd-logo-1x,.editormd-logo-2x,.editormd-logo-3x,.editormd-logo-4x,.editormd-logo-5x,.editormd-logo-6x,.editormd-logo-7x,.editormd-logo-8x{font-family:editormd-logo;speak:none;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;font-size:inherit;line-height:1;display:inline-block;text-rendering:auto;vertical-align:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.editormd-logo-1x:before,.editormd-logo-2x:before,.editormd-logo-3x:before,.editormd-logo-4x:before,.editormd-logo-5x:before,.editormd-logo-6x:before,.editormd-logo-7x:before,.editormd-logo-8x:before,.editormd-logo:before{content:"\e1987"}.editormd-logo-1x{font-size:1em}.editormd-logo-lg{font-size:1.2em}.editormd-logo-2x{font-size:2em}.editormd-logo-3x{font-size:3em}.editormd-logo-4x{font-size:4em}.editormd-logo-5x{font-size:5em}.editormd-logo-6x{font-size:6em}.editormd-logo-7x{font-size:7em}.editormd-logo-8x{font-size:8em}.editormd-logo-color{color:#2196F3}
/*! Editor.md v1.5.0 | /editormd.logo.min.css | Open source online markdown editor. | MIT License | By: Pandao | https://github.com/pandao/editor.md | 2019-05-11 */
/*! prefixes.scss v0.1.0 | Author: Pandao | https://github.com/pandao/prefixes.scss | MIT license | Copyright (c) 2015 */@font-face{font-family:editormd-logo;src:url(../fonts/editormd-logo.eot?-5y8q6h);src:url(../fonts/editormd-logo.eot?#iefix-5y8q6h) format("embedded-opentype"),url(../fonts/editormd-logo.woff?-5y8q6h) format("woff"),url(../fonts/editormd-logo.ttf?-5y8q6h) format("truetype"),url(../fonts/editormd-logo.svg?-5y8q6h#icomoon) format("svg");font-weight:400;font-style:normal}.editormd-logo,.editormd-logo-1x,.editormd-logo-2x,.editormd-logo-3x,.editormd-logo-4x,.editormd-logo-5x,.editormd-logo-6x,.editormd-logo-7x,.editormd-logo-8x{font-family:editormd-logo;speak:none;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;font-size:inherit;line-height:1;display:inline-block;text-rendering:auto;vertical-align:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.editormd-logo-1x:before,.editormd-logo-2x:before,.editormd-logo-3x:before,.editormd-logo-4x:before,.editormd-logo-5x:before,.editormd-logo-6x:before,.editormd-logo-7x:before,.editormd-logo-8x:before,.editormd-logo:before{content:"\e1987"}.editormd-logo-1x{font-size:1em}.editormd-logo-lg{font-size:1.2em}.editormd-logo-2x{font-size:2em}.editormd-logo-3x{font-size:3em}.editormd-logo-4x{font-size:4em}.editormd-logo-5x{font-size:5em}.editormd-logo-6x{font-size:6em}.editormd-logo-7x{font-size:7em}.editormd-logo-8x{font-size:8em}.editormd-logo-color{color:#2196F3}

10
css/editormd.min.css

File diff suppressed because one or more lines are too long

7088
css/editormd.preview.css

File diff suppressed because it is too large

10
css/editormd.preview.min.css

File diff suppressed because one or more lines are too long

324
editormd.amd.js

@ -7,29 +7,29 @@
* @license MIT License
* @author Pandao
* {@link https://github.com/pandao/editor.md}
* @updateTime 2015-06-09
* @updateTime 2019-05-11
*/
;(function(factory) {
"use strict";
// CommonJS/Node.js
if (typeof require === "function" && typeof exports === "object" && typeof module === "object")
{
module.exports = factory;
{
module.exports = factory();
}
else if (typeof define === "function") // AMD/CMD/Sea.js
{
if (define.amd) // for Require.js
{
var cmModePath = "./lib/codemirror/mode/";
var cmAddonPath = "./lib/codemirror/addon/";
var cmModePath = "codemirror/mode/";
var cmAddonPath = "codemirror/addon/";
var codeMirrorModules = [
"jquery", "marked", "prettify",
"katex", "raphael", "underscore", "flowchart", "jqueryflowchart", "sequenceDiagram",
"./lib/codemirror/lib/codemirror",
"codemirror/lib/codemirror",
cmModePath + "css/css",
cmModePath + "sass/sass",
cmModePath + "shell/shell",
@ -84,18 +84,18 @@
];
define(codeMirrorModules, factory);
}
}
else
{
define(["jquery"], factory); // for Sea.js
}
}
}
else
{
{
window.editormd = factory();
}
}(function() {
}(function() {
if (typeof define == "function" && define.amd) {
$ = arguments[0];
@ -107,15 +107,15 @@
flowchart = arguments[6];
CodeMirror = arguments[9];
}
"use strict";
var $ = (typeof (jQuery) !== "undefined") ? jQuery : Zepto;
var $ = (typeof (window.jQuery) !== "undefined") ? window.jQuery : window.Zepto;
if (typeof ($) === "undefined") {
return ;
}
/**
* editormd
*
@ -194,7 +194,7 @@
styleSelectedText : true,
matchWordHighlight : true, // options: true, false, "onselected"
styleActiveLine : true, // Highlight the current line
dialogLockScreen : true,
dialogLockScreen : false,
dialogShowMask : true,
dialogDraggable : true,
dialogMaskBgColor : "#fff",
@ -374,7 +374,8 @@
},
preformattedText : {
title : "添加预格式文本或代码块",
emptyAlert : "错误:请填写预格式文本或代码的内容。"
emptyAlert : "错误:请填写预格式文本或代码的内容。",
placeholder : "Coding now...."
},
codeBlock : {
title : "添加代码块",
@ -382,7 +383,8 @@
selectDefaultText : "请选择代码语言",
otherLanguage : "其他语言",
unselectedLanguageAlert : "错误:请选择代码所属的语言类型。",
codeEmptyAlert : "错误:请填写代码内容。"
codeEmptyAlert : "错误:请填写代码内容。",
placeholder : "Coding now...."
},
htmlEntities : {
title : "HTML 实体字符"
@ -432,10 +434,9 @@
{
options = id;
}
var _this = this;
var classPrefix = this.classPrefix = editormd.classPrefix;
var settings = this.settings = $.extend(true, editormd.defaults, options);
var settings = this.settings = $.extend(true, {}, editormd.defaults, options);
id = (typeof id === "object") ? settings.id : id;
@ -523,9 +524,9 @@
if (typeof define === "function" && define.amd)
{
if (typeof katex !== "undefined")
if (typeof window.katex !== "undefined")
{
editormd.$katex = katex;
editormd.$katex = window.katex;
}
if (settings.searchReplace && !settings.readOnly)
@ -534,20 +535,20 @@
editormd.loadCSS(settings.path + "codemirror/addon/search/matchesonscrollbar");
}
}
if ((typeof define === "function" && define.amd) || !settings.autoLoadModules)
{
if (typeof CodeMirror !== "undefined") {
editormd.$CodeMirror = CodeMirror;
if (typeof window.CodeMirror !== "undefined") {
editormd.$CodeMirror = window.CodeMirror;
}
if (typeof marked !== "undefined") {
editormd.$marked = marked;
if (typeof window.marked !== "undefined") {
editormd.$marked = window.marked;
}
this.setCodeMirror().setToolbar().loadedDisplay();
}
else
else
{
this.loadQueues();
}
@ -883,7 +884,6 @@
}
var cm = this.cm;
var editor = this.editor;
var count = cm.lineCount();
var preview = this.preview;
@ -1182,7 +1182,6 @@
}
var editor = this.editor;
var preview = this.preview;
var classPrefix = this.classPrefix;
var toolbar = this.toolbar = editor.children("." + classPrefix + "toolbar");
@ -1317,7 +1316,7 @@
var toolbarIcons = this.toolbarIcons = toolbar.find("." + classPrefix + "menu > li > a");
var toolbarIconHandlers = this.getToolbarHandles();
toolbarIcons.bind(editormd.mouseOrTouch("click", "touchend"), function(event) {
toolbarIcons.bind("click", function() {
var icon = $(this).children(".fa");
var name = icon.attr("name");
@ -1395,7 +1394,7 @@
var infoDialog = this.infoDialog = editor.children("." + classPrefix + "dialog-info");
infoDialog.find("." + classPrefix + "dialog-close").bind(editormd.mouseOrTouch("click", "touchend"), function() {
infoDialog.find("." + classPrefix + "dialog-close").bind("click", function() {
_this.hideInfoDialog();
});
@ -1440,8 +1439,7 @@
showInfoDialog : function() {
$("html,body").css("overflow-x", "hidden");
var _this = this;
var editor = this.editor;
var settings = this.settings;
var infoDialog = this.infoDialog = editor.children("." + this.classPrefix + "dialog-info");
@ -1504,7 +1502,6 @@
*/
recreate : function() {
var _this = this;
var editor = this.editor;
var settings = this.settings;
@ -1645,17 +1642,17 @@
* @param {Object} keyMap KeyMap key/value {"(Ctrl/Shift/Alt)-Key" : function(){}}
* @returns {editormd} return this
*/
registerKeyMaps : function(keyMap) {
var _this = this;
var cm = this.cm;
var settings = this.settings;
var toolbarHandlers = editormd.toolbarHandlers;
var disabledKeyMaps = settings.disabledKeyMaps;
keyMap = keyMap || null;
if (keyMap)
{
for (var i in keyMap)
@ -1684,34 +1681,34 @@
cm.addKeyMap(_map);
}
}
$(window).keydown(function(event) {
var keymaps = {
"120" : "F9",
"121" : "F10",
"122" : "F11"
};
if ( $.inArray(keymaps[event.keyCode], disabledKeyMaps) < 0 )
{
switch (event.keyCode)
{
case 120:
$.proxy(toolbarHandlers["watch"], _this)();
return false;
event.stopPropagation();
break;
case 121:
$.proxy(toolbarHandlers["preview"], _this)();
return false;
event.stopPropagation();
break;
case 122:
$.proxy(toolbarHandlers["fullscreen"], _this)();
return false;
$.proxy(toolbarHandlers["fullscreen"], _this)();
event.stopPropagation();
break;
default:
break;
}
@ -1721,7 +1718,7 @@
return this;
},
/**
* 绑定同步滚动
*
@ -1837,8 +1834,7 @@
return this;
}
cm.on("change", function(_cm, changeObj) {
cm.on("change", function() {
if (settings.watch)
{
_this.previewContainer.css("padding", settings.autoHeight ? "20px 20px 50px 40px" : "20px");
@ -1987,7 +1983,7 @@
if(settings.watch)
{
codeMirror.width(editor.width() / 2);
codeMirror.width((editor.width() / 2) - 1);
preview.width((!state.preview) ? editor.width() / 2 : editor.width());
this.previewContainer.css("padding", settings.autoHeight ? "20px 20px 50px 40px" : "20px");
@ -2081,21 +2077,16 @@
smartLists : true,
smartypants : true
};
marked.setOptions(markedOptions);
var newMarkdownDoc = editormd.$marked(cmValue, markedOptions);
//console.info("cmValue", cmValue, newMarkdownDoc);
newMarkdownDoc = editormd.filterHTMLTags(newMarkdownDoc, settings.htmlDecode);
//console.error("cmValue", cmValue, newMarkdownDoc);
newMarkdownDoc = editormd.filterHTMLTags(newMarkdownDoc, settings.htmlDecode);
this.markdownTextarea.text(cmValue);
cm.save();
if (settings.saveHTMLToTextarea)
{
this.htmlTextarea.text(newMarkdownDoc);
@ -2297,8 +2288,7 @@
*/
appendMarkdown : function(md) {
var settings = this.settings;
var cm = this.cm;
var cm = this.cm;
cm.setValue(cm.getValue() + md);
@ -2532,7 +2522,20 @@
return this;
},
/**
* 消毁并移除编辑器实例
*
* destroy & remove editor
*
* @returns {void} void 无返回值
*/
destroy : function () {
this.hide();
this.editor.remove();
},
/**
* 隐藏编辑器部分只预览HTML
* Enter preview html state
@ -2553,7 +2556,9 @@
if ($.inArray(settings.mode, ["gfm", "markdown"]) < 0) {
return this;
}
var editorHeight = this.editor.outerHeight();
if (settings.toolbar && toolbar) {
toolbar.toggle();
toolbar.find(".fa[name=preview]").toggleClass("active");
@ -2571,11 +2576,15 @@
{
this.state.preview = true;
if (this.settings.autoHeight) {
this.editor.css("height", editorHeight);
}
if (this.state.fullscreen) {
preview.css("background", "#fff");
}
editor.find("." + this.classPrefix + "preview-close-btn").show().bind(editormd.mouseOrTouch("click", "touchend"), function(){
editor.find("." + this.classPrefix + "preview-close-btn").show().bind("click", function(){
_this.previewed();
});
@ -2637,7 +2646,7 @@
preview[(settings.watch) ? "show" : "hide"]();
previewCloseBtn.hide().unbind(editormd.mouseOrTouch("click", "touchend"));
previewCloseBtn.hide().unbind("click");
previewContainer.removeClass(this.classPrefix + "preview-active");
@ -2645,7 +2654,11 @@
{
previewContainer.css("padding", "20px");
}
if (this.settings.autoHeight) {
this.editor.css("height", "auto");
}
preview.css({
background : null,
position : "absolute",
@ -2674,7 +2687,6 @@
var _this = this;
var state = this.state;
var editor = this.editor;
var preview = this.preview;
var toolbar = this.toolbar;
var settings = this.settings;
var fullscreenClass = this.classPrefix + "fullscreen";
@ -2972,7 +2984,6 @@
lowercase : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
var selections = cm.listSelections();
@ -3084,7 +3095,6 @@
"list-ul" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
if (selection === "")
@ -3106,7 +3116,6 @@
"list-ol" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
if(selection === "")
@ -3129,7 +3138,6 @@
hr : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
cm.replaceSelection(((cursor.ch !== 0) ? "\n\n" : "\n") + "------------\n\n");
},
@ -3167,8 +3175,7 @@
return this;
}
var cm = this.cm;
var selection = cm.getSelection();
var cm = this.cm;
cm.replaceSelection("\r\n[========]\r\n");
},
@ -3203,8 +3210,6 @@
datetime : function() {
var cm = this.cm;
var selection = cm.getSelection();
var date = new Date();
var langName = this.settings.lang.name;
var datefmt = editormd.dateFormat() + " " + editormd.dateFormat((langName === "zh-cn" || langName === "zh-tw") ? "cn-week-day" : "week-day");
@ -3252,6 +3257,9 @@
}
};
// var isMac = navigator.platform.toUpperCase().indexOf("MAC") >= 0;
// var key = isMac ? "Cmd" : "Ctrl";
editormd.keyMaps = {
"Ctrl-1" : "h1",
"Ctrl-2" : "h2",
@ -3261,8 +3269,7 @@
"Ctrl-6" : "h6",
"Ctrl-B" : "bold", // if this is string == editormd.toolbarHandlers.xxxx
"Ctrl-D" : "datetime",
"Ctrl-E" : function() { // emoji
"Ctrl-E" : function() { // emoji
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
@ -3283,7 +3290,6 @@
"Ctrl-H" : "hr",
"Ctrl-I" : "italic",
"Ctrl-K" : "code",
"Ctrl-L" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3298,7 +3304,6 @@
}
},
"Ctrl-U" : "list-ul",
"Shift-Ctrl-A" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3316,12 +3321,10 @@
cm.setCursor(cursor.line, cursor.ch + 1);
}
},
"Shift-Ctrl-C" : "code",
"Shift-Ctrl-Q" : "quote",
"Shift-Ctrl-S" : "del",
"Shift-Ctrl-K" : "tex", // KaTeX
"Shift-Alt-C" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3333,39 +3336,36 @@
cm.setCursor(cursor.line, cursor.ch + 3);
}
},
"Shift-Ctrl-Alt-C" : "code-block",
"Shift-Ctrl-H" : "html-entities",
"Shift-Alt-H" : "help",
"Shift-Ctrl-E" : "emoji",
"Shift-Ctrl-U" : "uppercase",
"Shift-Alt-U" : "ucwords",
"Shift-Ctrl-Alt-U" : "ucfirst",
"Shift-Alt-L" : "lowercase",
"Shift-Ctrl-I" : function() {
"Shift-Ctrl-Alt-C" : "code-block",
"Shift-Ctrl-H" : "html-entities",
"Shift-Alt-H" : "help",
"Shift-Ctrl-E" : "emoji",
"Shift-Ctrl-U" : "uppercase",
"Shift-Alt-U" : "ucwords",
"Shift-Ctrl-Alt-U" : "ucfirst",
"Shift-Alt-L" : "lowercase",
"Shift-Ctrl-I" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
var title = (selection === "") ? "" : " \""+selection+"\"";
var title = (selection === "") ? "" : " \"" + selection + "\"";
cm.replaceSelection("![" + selection + "]("+title+")");
cm.replaceSelection("![" + selection + "](" + title + ")");
if (selection === "") {
cm.setCursor(cursor.line, cursor.ch + 4);
}
},
"Shift-Ctrl-Alt-I" : "image",
"Shift-Ctrl-L" : "link",
"Shift-Ctrl-O" : "list-ol",
"Shift-Ctrl-P" : "preformatted-text",
"Shift-Ctrl-T" : "table",
"Shift-Alt-P" : "pagebreak",
"F9" : "watch",
"F10" : "preview",
"F11" : "fullscreen",
"Shift-Ctrl-Alt-I" : "image",
"Shift-Ctrl-L" : "link",
"Shift-Ctrl-O" : "list-ol",
"Shift-Ctrl-P" : "preformatted-text",
"Shift-Ctrl-T" : "table",
"Shift-Alt-P" : "pagebreak",
"F9" : "watch",
"F10" : "preview",
"F11" : "fullscreen",
};
/**
@ -3411,21 +3411,19 @@
return $1.toUpperCase();
});
};
var ucfirst = firstUpperCase;
editormd.firstUpperCase = editormd.ucfirst = firstUpperCase;
editormd.urls = {
atLinkBase : "https://github.com/"
};
editormd.regexs = {
atLink : /@(\w+)/g,
email : /(\w+)@(\w+)\.(\w+)\.?(\w+)?/g,
emailLink : /(mailto:)?([\w\.\_]+)@(\w+)\.(\w+)\.?(\w+)?/g,
emoji : /:([\w\+-]+):/g,
emojiDatetime : /(\d{2}:\d{2}:\d{2})/g,
emojiDatetime : /(\d{1,2}:\d{1,2}:\d{1,2})/g,
twemoji : /:(tw-([\w]+)-?(\w+)?):/g,
fontAwesome : /:(fa-([\w]+)(-(\w+)){0,}):/g,
editormdLogo : /:(editormd-logo-?(\w+)?):/g,
@ -3434,7 +3432,7 @@
// Emoji graphics files url path
editormd.emoji = {
path : "http://www.emoji-cheat-sheet.com/graphics/emojis/",
path : "https://www.webpagefx.com/tools/emoji-cheat-sheet/graphics/emojis/",
ext : ".png"
};
@ -3500,7 +3498,7 @@
matchs[i] = ":\\+1:";
}
text = text.replace(new RegExp(matchs[i]), function($1, $2){
text = text.replace(new RegExp(matchs[i]), function($1) {
var faMatchs = $1.match(faIconReg);
var name = $1.replace(/:/g, "");
@ -3581,12 +3579,12 @@
if (this.options.sanitize) {
try {
var prot = decodeURIComponent(unescape(href)).replace(/[^\w:]/g,"").toLowerCase();
} catch(e) {
return "";
}
var prot = decodeURIComponent(unescape(href)).replace(/[^\w:]/g, "").toLowerCase();
if (prot.indexOf("javascript:") === 0) {
if (prot.indexOf("javascript:") === 0) {
return "";
}
} catch(e) {
return "";
}
}
@ -3611,12 +3609,12 @@
return out;
};
markedRenderer.heading = function(text, level, raw) {
markedRenderer.heading = function(text, level) {
var linkText = text;
var hasLinkReg = /\s*\<a\s*href\=\"(.*)\"\s*([^\>]*)\>(.*)\<\/a\>\s*/;
var getLinkTextReg = /\s*\<a\s*([^\>]+)\>([^\>]*)\<\/a\>\s*/g;
// var getLinkTextReg = /\s*\<a\s*([^\>]+)\>([^\>]*)\<\/a\>\s*/g;
if (hasLinkReg.test(text))
{
@ -3688,7 +3686,7 @@
: ( (pageBreakReg.test(text)) ? this.pageBreak(text) : "<p" + isTeXAddClass + ">" + this.atLink(this.emoji(text)) + "</p>\n" );
};
markedRenderer.code = function (code, lang, escaped) {
markedRenderer.code = function (code, lang) {
if (lang === "seq" || lang === "sequence")
{
@ -3879,7 +3877,7 @@
editormd.filterHTMLTags = function(html, filters) {
if (typeof html !== "string") {
html = new String(html);
html = html.toString();
}
if (typeof filters !== "string") {
@ -3917,7 +3915,9 @@
var $attrs = {};
$.each(_attrs, function(i, e) {
if (e.nodeName !== '"') $attrs[e.nodeName] = e.nodeValue;
if (e.nodeName !== "\"") {
$attrs[e.nodeName] = e.nodeValue;
}
});
$.each($attrs, function(i) {
@ -3988,9 +3988,9 @@
editormd.$marked = marked;
var div = $("#" + id);
var settings = div.settings = $.extend(true, defaults, options || {});
var settings = div.settings = $.extend(true, {}, defaults, options || {});
var saveTo = div.find("textarea");
if (saveTo.length < 1)
{
div.append("<textarea></textarea>");
@ -4025,13 +4025,13 @@
smartLists : true,
smartypants : true
};
markdownDoc = new String(markdownDoc);
markdownDoc = markdownDoc.toString();
var markdownParsed = marked(markdownDoc, markedOptions);
markdownParsed = editormd.filterHTMLTags(markdownParsed, settings.htmlDecode);
if (settings.markdownSourceCode) {
saveTo.text(markdownDoc);
} else {
@ -4192,9 +4192,9 @@
document.body.appendChild(css);
}
};
editormd.isIE = (navigator.appName == "Microsoft Internet Explorer");
editormd.isIE8 = (editormd.isIE && navigator.appVersion.match(/8./i) == "8.");
editormd.isIE = (navigator.appName === "Microsoft Internet Explorer");
editormd.isIE8 = (editormd.isIE && navigator.appVersion.match(/8./i) === "8.");
/**
* 动态加载JS文件的方法
@ -4248,10 +4248,10 @@
// 使用国外的CDN,加载速度有时会很慢,或者自定义URL
// You can custom KaTeX load url.
editormd.katexURL = {
css : "//cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min",
js : "//cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min"
css : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min",
js : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min"
};
editormd.kaTeXLoaded = false;
/**
@ -4295,6 +4295,7 @@
title : "",
drag : true,
closed : true,
cached : false,
content : "",
mask : true,
maskStyle : {
@ -4313,8 +4314,6 @@
var classPrefix = editormd.classPrefix;
var guid = (new Date()).getTime();
var dialogName = ( (options.name === "") ? classPrefix + "dialog-" + guid : options.name);
var mouseOrTouch = editormd.mouseOrTouch;
var html = "<div class=\"" + classPrefix + "dialog " + dialogName + "\">";
if (options.title !== "")
@ -4337,7 +4336,6 @@
}
html += "</div>";
html += "<div class=\"" + classPrefix + "dialog-mask " + classPrefix + "dialog-mask-bg\"></div>";
html += "<div class=\"" + classPrefix + "dialog-mask " + classPrefix + "dialog-mask-con\"></div>";
html += "</div>";
@ -4400,8 +4398,12 @@
$(window).resize(dialogPosition);
dialog.children("." + classPrefix + "dialog-close").bind(mouseOrTouch("click", "touchend"), function() {
dialog.children("." + classPrefix + "dialog-close").bind("click", function() {
dialog.hide().lockScreen(false).hideMask();
if (!options.cached) {
dialog.remove();
}
});
if (typeof options.buttons === "object")
@ -4415,7 +4417,7 @@
footer.append("<button class=\"" + classPrefix + "btn " + btnClassName + "\">" + btn[0] + "</button>");
btn[1] = $.proxy(btn[1], dialog);
footer.children("." + btnClassName).bind(mouseOrTouch("click", "touchend"), btn[1]);
footer.children("." + btnClassName).bind("click", btn[1]);
}
}
@ -4425,26 +4427,18 @@
var dialogHeader = dialog.children("." + classPrefix + "dialog-header");
if (!options.mask) {
dialogHeader.bind(mouseOrTouch("click", "touchend"), function(){
dialogHeader.bind("click", function(){
editormd.dialogZindex += 2;
dialog.css("z-index", editormd.dialogZindex);
});
}
dialogHeader.mousedown(function(e) {
e = e || window.event; //IE
posX = e.clientX - parseInt(dialog[0].style.left);
posY = e.clientY - parseInt(dialog[0].style.top);
document.onmousemove = moveAction;
});
var userCanSelect = function (obj) {
obj.removeClass(classPrefix + "user-unselect").off("selectstart");
};
var userUnselect = function (obj) {
obj.addClass(classPrefix + "user-unselect").on("selectstart", function(event) { // selectstart for IE
obj.addClass(classPrefix + "user-unselect").on("selectstart", function() { // selectstart for IE
return false;
});
};
@ -4484,6 +4478,14 @@
dialog[0].style.top = top + "px";
};
dialogHeader.mousedown(function(e) {
e = e || window.event; //IE
posX = e.clientX - parseInt(dialog[0].style.left);
posY = e.clientY - parseInt(dialog[0].style.top);
document.onmousemove = moveAction;
});
document.onmouseup = function() {
userCanSelect($("body"));
userCanSelect(dialog);

6
editormd.amd.min.js

File diff suppressed because one or more lines are too long

323
editormd.js

@ -7,45 +7,45 @@
* @license MIT License
* @author Pandao
* {@link https://github.com/pandao/editor.md}
* @updateTime 2015-06-09
* @updateTime 2019-05-11
*/
;(function(factory) {
"use strict";
// CommonJS/Node.js
if (typeof require === "function" && typeof exports === "object" && typeof module === "object")
{
module.exports = factory;
{
module.exports = factory();
}
else if (typeof define === "function") // AMD/CMD/Sea.js
{
if (define.amd) // for Require.js
{
/* Require.js define replace */
}
}
else
{
define(["jquery"], factory); // for Sea.js
}
}
}
else
{
{
window.editormd = factory();
}
}(function() {
}(function() {
/* Require.js assignment replace */
"use strict";
var $ = (typeof (jQuery) !== "undefined") ? jQuery : Zepto;
var $ = (typeof (window.jQuery) !== "undefined") ? window.jQuery : window.Zepto;
if (typeof ($) === "undefined") {
return ;
}
/**
* editormd
*
@ -124,7 +124,7 @@
styleSelectedText : true,
matchWordHighlight : true, // options: true, false, "onselected"
styleActiveLine : true, // Highlight the current line
dialogLockScreen : true,
dialogLockScreen : false,
dialogShowMask : true,
dialogDraggable : true,
dialogMaskBgColor : "#fff",
@ -304,7 +304,8 @@
},
preformattedText : {
title : "添加预格式文本或代码块",
emptyAlert : "错误:请填写预格式文本或代码的内容。"
emptyAlert : "错误:请填写预格式文本或代码的内容。",
placeholder : "Coding now...."
},
codeBlock : {
title : "添加代码块",
@ -312,7 +313,8 @@
selectDefaultText : "请选择代码语言",
otherLanguage : "其他语言",
unselectedLanguageAlert : "错误:请选择代码所属的语言类型。",
codeEmptyAlert : "错误:请填写代码内容。"
codeEmptyAlert : "错误:请填写代码内容。",
placeholder : "Coding now...."
},
htmlEntities : {
title : "HTML 实体字符"
@ -362,8 +364,7 @@
{
options = id;
}
var _this = this;
var classPrefix = this.classPrefix = editormd.classPrefix;
var settings = this.settings = $.extend(true, {}, editormd.defaults, options);
@ -453,9 +454,9 @@
if (typeof define === "function" && define.amd)
{
if (typeof katex !== "undefined")
if (typeof window.katex !== "undefined")
{
editormd.$katex = katex;
editormd.$katex = window.katex;
}
if (settings.searchReplace && !settings.readOnly)
@ -464,20 +465,20 @@
editormd.loadCSS(settings.path + "codemirror/addon/search/matchesonscrollbar");
}
}
if ((typeof define === "function" && define.amd) || !settings.autoLoadModules)
{
if (typeof CodeMirror !== "undefined") {
editormd.$CodeMirror = CodeMirror;
if (typeof window.CodeMirror !== "undefined") {
editormd.$CodeMirror = window.CodeMirror;
}
if (typeof marked !== "undefined") {
editormd.$marked = marked;
if (typeof window.marked !== "undefined") {
editormd.$marked = window.marked;
}
this.setCodeMirror().setToolbar().loadedDisplay();
}
else
else
{
this.loadQueues();
}
@ -813,7 +814,6 @@
}
var cm = this.cm;
var editor = this.editor;
var count = cm.lineCount();
var preview = this.preview;
@ -1112,7 +1112,6 @@
}
var editor = this.editor;
var preview = this.preview;
var classPrefix = this.classPrefix;
var toolbar = this.toolbar = editor.children("." + classPrefix + "toolbar");
@ -1247,7 +1246,7 @@
var toolbarIcons = this.toolbarIcons = toolbar.find("." + classPrefix + "menu > li > a");
var toolbarIconHandlers = this.getToolbarHandles();
toolbarIcons.bind(editormd.mouseOrTouch("click", "touchend"), function(event) {
toolbarIcons.bind("click", function() {
var icon = $(this).children(".fa");
var name = icon.attr("name");
@ -1325,7 +1324,7 @@
var infoDialog = this.infoDialog = editor.children("." + classPrefix + "dialog-info");
infoDialog.find("." + classPrefix + "dialog-close").bind(editormd.mouseOrTouch("click", "touchend"), function() {
infoDialog.find("." + classPrefix + "dialog-close").bind("click", function() {
_this.hideInfoDialog();
});
@ -1370,8 +1369,7 @@
showInfoDialog : function() {
$("html,body").css("overflow-x", "hidden");
var _this = this;
var editor = this.editor;
var settings = this.settings;
var infoDialog = this.infoDialog = editor.children("." + this.classPrefix + "dialog-info");
@ -1434,7 +1432,6 @@
*/
recreate : function() {
var _this = this;
var editor = this.editor;
var settings = this.settings;
@ -1575,17 +1572,17 @@
* @param {Object} keyMap KeyMap key/value {"(Ctrl/Shift/Alt)-Key" : function(){}}
* @returns {editormd} return this
*/
registerKeyMaps : function(keyMap) {
var _this = this;
var cm = this.cm;
var settings = this.settings;
var toolbarHandlers = editormd.toolbarHandlers;
var disabledKeyMaps = settings.disabledKeyMaps;
keyMap = keyMap || null;
if (keyMap)
{
for (var i in keyMap)
@ -1614,34 +1611,34 @@
cm.addKeyMap(_map);
}
}
$(window).keydown(function(event) {
var keymaps = {
"120" : "F9",
"121" : "F10",
"122" : "F11"
};
if ( $.inArray(keymaps[event.keyCode], disabledKeyMaps) < 0 )
{
switch (event.keyCode)
{
case 120:
$.proxy(toolbarHandlers["watch"], _this)();
return false;
event.stopPropagation();
break;
case 121:
$.proxy(toolbarHandlers["preview"], _this)();
return false;
event.stopPropagation();
break;
case 122:
$.proxy(toolbarHandlers["fullscreen"], _this)();
return false;
$.proxy(toolbarHandlers["fullscreen"], _this)();
event.stopPropagation();
break;
default:
break;
}
@ -1651,7 +1648,7 @@
return this;
},
/**
* 绑定同步滚动
*
@ -1767,8 +1764,7 @@
return this;
}
cm.on("change", function(_cm, changeObj) {
cm.on("change", function() {
if (settings.watch)
{
_this.previewContainer.css("padding", settings.autoHeight ? "20px 20px 50px 40px" : "20px");
@ -1917,7 +1913,7 @@
if(settings.watch)
{
codeMirror.width(editor.width() / 2);
codeMirror.width((editor.width() / 2) - 1);
preview.width((!state.preview) ? editor.width() / 2 : editor.width());
this.previewContainer.css("padding", settings.autoHeight ? "20px 20px 50px 40px" : "20px");
@ -1965,15 +1961,14 @@
save : function() {
var _this = this;
var state = this.state;
var settings = this.settings;
if (timer === null && !(!settings.watch && state.preview))
if (timer === null)
{
return this;
}
var _this = this;
var state = this.state;
var settings = this.settings;
var cm = this.cm;
var cmValue = cm.getValue();
var previewContainer = this.previewContainer;
@ -2012,21 +2007,16 @@
smartLists : true,
smartypants : true
};
marked.setOptions(markedOptions);
var newMarkdownDoc = editormd.$marked(cmValue, markedOptions);
//console.info("cmValue", cmValue, newMarkdownDoc);
newMarkdownDoc = editormd.filterHTMLTags(newMarkdownDoc, settings.htmlDecode);
//console.error("cmValue", cmValue, newMarkdownDoc);
newMarkdownDoc = editormd.filterHTMLTags(newMarkdownDoc, settings.htmlDecode);
this.markdownTextarea.text(cmValue);
cm.save();
if (settings.saveHTMLToTextarea)
{
this.htmlTextarea.text(newMarkdownDoc);
@ -2228,8 +2218,7 @@
*/
appendMarkdown : function(md) {
var settings = this.settings;
var cm = this.cm;
var cm = this.cm;
cm.setValue(cm.getValue() + md);
@ -2463,7 +2452,20 @@
return this;
},
/**
* 消毁并移除编辑器实例
*
* destroy & remove editor
*
* @returns {void} void 无返回值
*/
destroy : function () {
this.hide();
this.editor.remove();
},
/**
* 隐藏编辑器部分只预览HTML
* Enter preview html state
@ -2484,7 +2486,9 @@
if ($.inArray(settings.mode, ["gfm", "markdown"]) < 0) {
return this;
}
var editorHeight = this.editor.outerHeight();
if (settings.toolbar && toolbar) {
toolbar.toggle();
toolbar.find(".fa[name=preview]").toggleClass("active");
@ -2502,11 +2506,15 @@
{
this.state.preview = true;
if (this.settings.autoHeight) {
this.editor.css("height", editorHeight);
}
if (this.state.fullscreen) {
preview.css("background", "#fff");
}
editor.find("." + this.classPrefix + "preview-close-btn").show().bind(editormd.mouseOrTouch("click", "touchend"), function(){
editor.find("." + this.classPrefix + "preview-close-btn").show().bind("click", function(){
_this.previewed();
});
@ -2568,7 +2576,7 @@
preview[(settings.watch) ? "show" : "hide"]();
previewCloseBtn.hide().unbind(editormd.mouseOrTouch("click", "touchend"));
previewCloseBtn.hide().unbind("click");
previewContainer.removeClass(this.classPrefix + "preview-active");
@ -2576,7 +2584,11 @@
{
previewContainer.css("padding", "20px");
}
if (this.settings.autoHeight) {
this.editor.css("height", "auto");
}
preview.css({
background : null,
position : "absolute",
@ -2605,7 +2617,6 @@
var _this = this;
var state = this.state;
var editor = this.editor;
var preview = this.preview;
var toolbar = this.toolbar;
var settings = this.settings;
var fullscreenClass = this.classPrefix + "fullscreen";
@ -2903,7 +2914,6 @@
lowercase : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
var selections = cm.listSelections();
@ -3015,7 +3025,6 @@
"list-ul" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
if (selection === "")
@ -3037,7 +3046,6 @@
"list-ol" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
if(selection === "")
@ -3060,7 +3068,6 @@
hr : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
cm.replaceSelection(((cursor.ch !== 0) ? "\n\n" : "\n") + "------------\n\n");
},
@ -3098,8 +3105,7 @@
return this;
}
var cm = this.cm;
var selection = cm.getSelection();
var cm = this.cm;
cm.replaceSelection("\r\n[========]\r\n");
},
@ -3134,8 +3140,6 @@
datetime : function() {
var cm = this.cm;
var selection = cm.getSelection();
var date = new Date();
var langName = this.settings.lang.name;
var datefmt = editormd.dateFormat() + " " + editormd.dateFormat((langName === "zh-cn" || langName === "zh-tw") ? "cn-week-day" : "week-day");
@ -3183,6 +3187,9 @@
}
};
// var isMac = navigator.platform.toUpperCase().indexOf("MAC") >= 0;
// var key = isMac ? "Cmd" : "Ctrl";
editormd.keyMaps = {
"Ctrl-1" : "h1",
"Ctrl-2" : "h2",
@ -3192,8 +3199,7 @@
"Ctrl-6" : "h6",
"Ctrl-B" : "bold", // if this is string == editormd.toolbarHandlers.xxxx
"Ctrl-D" : "datetime",
"Ctrl-E" : function() { // emoji
"Ctrl-E" : function() { // emoji
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
@ -3214,7 +3220,6 @@
"Ctrl-H" : "hr",
"Ctrl-I" : "italic",
"Ctrl-K" : "code",
"Ctrl-L" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3229,7 +3234,6 @@
}
},
"Ctrl-U" : "list-ul",
"Shift-Ctrl-A" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3247,12 +3251,10 @@
cm.setCursor(cursor.line, cursor.ch + 1);
}
},
"Shift-Ctrl-C" : "code",
"Shift-Ctrl-Q" : "quote",
"Shift-Ctrl-S" : "del",
"Shift-Ctrl-K" : "tex", // KaTeX
"Shift-Alt-C" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3264,39 +3266,36 @@
cm.setCursor(cursor.line, cursor.ch + 3);
}
},
"Shift-Ctrl-Alt-C" : "code-block",
"Shift-Ctrl-H" : "html-entities",
"Shift-Alt-H" : "help",
"Shift-Ctrl-E" : "emoji",
"Shift-Ctrl-U" : "uppercase",
"Shift-Alt-U" : "ucwords",
"Shift-Ctrl-Alt-U" : "ucfirst",
"Shift-Alt-L" : "lowercase",
"Shift-Ctrl-I" : function() {
"Shift-Ctrl-Alt-C" : "code-block",
"Shift-Ctrl-H" : "html-entities",
"Shift-Alt-H" : "help",
"Shift-Ctrl-E" : "emoji",
"Shift-Ctrl-U" : "uppercase",
"Shift-Alt-U" : "ucwords",
"Shift-Ctrl-Alt-U" : "ucfirst",
"Shift-Alt-L" : "lowercase",
"Shift-Ctrl-I" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
var title = (selection === "") ? "" : " \""+selection+"\"";
var title = (selection === "") ? "" : " \"" + selection + "\"";
cm.replaceSelection("![" + selection + "]("+title+")");
cm.replaceSelection("![" + selection + "](" + title + ")");
if (selection === "") {
cm.setCursor(cursor.line, cursor.ch + 4);
}
},
"Shift-Ctrl-Alt-I" : "image",
"Shift-Ctrl-L" : "link",
"Shift-Ctrl-O" : "list-ol",
"Shift-Ctrl-P" : "preformatted-text",
"Shift-Ctrl-T" : "table",
"Shift-Alt-P" : "pagebreak",
"F9" : "watch",
"F10" : "preview",
"F11" : "fullscreen",
"Shift-Ctrl-Alt-I" : "image",
"Shift-Ctrl-L" : "link",
"Shift-Ctrl-O" : "list-ol",
"Shift-Ctrl-P" : "preformatted-text",
"Shift-Ctrl-T" : "table",
"Shift-Alt-P" : "pagebreak",
"F9" : "watch",
"F10" : "preview",
"F11" : "fullscreen",
};
/**
@ -3342,21 +3341,19 @@
return $1.toUpperCase();
});
};
var ucfirst = firstUpperCase;
editormd.firstUpperCase = editormd.ucfirst = firstUpperCase;
editormd.urls = {
atLinkBase : "https://github.com/"
};
editormd.regexs = {
atLink : /@(\w+)/g,
email : /(\w+)@(\w+)\.(\w+)\.?(\w+)?/g,
emailLink : /(mailto:)?([\w\.\_]+)@(\w+)\.(\w+)\.?(\w+)?/g,
emoji : /:([\w\+-]+):/g,
emojiDatetime : /(\d{2}:\d{2}:\d{2})/g,
emojiDatetime : /(\d{1,2}:\d{1,2}:\d{1,2})/g,
twemoji : /:(tw-([\w]+)-?(\w+)?):/g,
fontAwesome : /:(fa-([\w]+)(-(\w+)){0,}):/g,
editormdLogo : /:(editormd-logo-?(\w+)?):/g,
@ -3431,7 +3428,7 @@
matchs[i] = ":\\+1:";
}
text = text.replace(new RegExp(matchs[i]), function($1, $2){
text = text.replace(new RegExp(matchs[i]), function($1) {
var faMatchs = $1.match(faIconReg);
var name = $1.replace(/:/g, "");
@ -3512,12 +3509,12 @@
if (this.options.sanitize) {
try {
var prot = decodeURIComponent(unescape(href)).replace(/[^\w:]/g,"").toLowerCase();
} catch(e) {
return "";
}
var prot = decodeURIComponent(unescape(href)).replace(/[^\w:]/g, "").toLowerCase();
if (prot.indexOf("javascript:") === 0) {
if (prot.indexOf("javascript:") === 0) {
return "";
}
} catch(e) {
return "";
}
}
@ -3542,12 +3539,12 @@
return out;
};
markedRenderer.heading = function(text, level, raw) {
markedRenderer.heading = function(text, level) {
var linkText = text;
var hasLinkReg = /\s*\<a\s*href\=\"(.*)\"\s*([^\>]*)\>(.*)\<\/a\>\s*/;
var getLinkTextReg = /\s*\<a\s*([^\>]+)\>([^\>]*)\<\/a\>\s*/g;
// var getLinkTextReg = /\s*\<a\s*([^\>]+)\>([^\>]*)\<\/a\>\s*/g;
if (hasLinkReg.test(text))
{
@ -3619,7 +3616,7 @@
: ( (pageBreakReg.test(text)) ? this.pageBreak(text) : "<p" + isTeXAddClass + ">" + this.atLink(this.emoji(text)) + "</p>\n" );
};
markedRenderer.code = function (code, lang, escaped) {
markedRenderer.code = function (code, lang) {
if (lang === "seq" || lang === "sequence")
{
@ -3810,7 +3807,7 @@
editormd.filterHTMLTags = function(html, filters) {
if (typeof html !== "string") {
html = new String(html);
html = html.toString();
}
if (typeof filters !== "string") {
@ -3848,7 +3845,9 @@
var $attrs = {};
$.each(_attrs, function(i, e) {
if (e.nodeName !== '"') $attrs[e.nodeName] = e.nodeValue;
if (e.nodeName !== "\"") {
$attrs[e.nodeName] = e.nodeValue;
}
});
$.each($attrs, function(i) {
@ -3919,9 +3918,9 @@
editormd.$marked = marked;
var div = $("#" + id);
var settings = div.settings = $.extend(true, defaults, options || {});
var settings = div.settings = $.extend(true, {}, defaults, options || {});
var saveTo = div.find("textarea");
if (saveTo.length < 1)
{
div.append("<textarea></textarea>");
@ -3956,13 +3955,13 @@
smartLists : true,
smartypants : true
};
markdownDoc = new String(markdownDoc);
markdownDoc = markdownDoc.toString();
var markdownParsed = marked(markdownDoc, markedOptions);
markdownParsed = editormd.filterHTMLTags(markdownParsed, settings.htmlDecode);
if (settings.markdownSourceCode) {
saveTo.text(markdownDoc);
} else {
@ -4123,9 +4122,9 @@
document.body.appendChild(css);
}
};
editormd.isIE = (navigator.appName == "Microsoft Internet Explorer");
editormd.isIE8 = (editormd.isIE && navigator.appVersion.match(/8./i) == "8.");
editormd.isIE = (navigator.appName === "Microsoft Internet Explorer");
editormd.isIE8 = (editormd.isIE && navigator.appVersion.match(/8./i) === "8.");
/**
* 动态加载JS文件的方法
@ -4179,10 +4178,10 @@
// 使用国外的CDN,加载速度有时会很慢,或者自定义URL
// You can custom KaTeX load url.
editormd.katexURL = {
css : "//cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min",
js : "//cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min"
css : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min",
js : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min"
};
editormd.kaTeXLoaded = false;
/**
@ -4226,6 +4225,7 @@
title : "",
drag : true,
closed : true,
cached : false,
content : "",
mask : true,
maskStyle : {
@ -4244,8 +4244,6 @@
var classPrefix = editormd.classPrefix;
var guid = (new Date()).getTime();
var dialogName = ( (options.name === "") ? classPrefix + "dialog-" + guid : options.name);
var mouseOrTouch = editormd.mouseOrTouch;
var html = "<div class=\"" + classPrefix + "dialog " + dialogName + "\">";
if (options.title !== "")
@ -4268,7 +4266,6 @@
}
html += "</div>";
html += "<div class=\"" + classPrefix + "dialog-mask " + classPrefix + "dialog-mask-bg\"></div>";
html += "<div class=\"" + classPrefix + "dialog-mask " + classPrefix + "dialog-mask-con\"></div>";
html += "</div>";
@ -4331,8 +4328,12 @@
$(window).resize(dialogPosition);
dialog.children("." + classPrefix + "dialog-close").bind(mouseOrTouch("click", "touchend"), function() {
dialog.children("." + classPrefix + "dialog-close").bind("click", function() {
dialog.hide().lockScreen(false).hideMask();
if (!options.cached) {
dialog.remove();
}
});
if (typeof options.buttons === "object")
@ -4346,7 +4347,7 @@
footer.append("<button class=\"" + classPrefix + "btn " + btnClassName + "\">" + btn[0] + "</button>");
btn[1] = $.proxy(btn[1], dialog);
footer.children("." + btnClassName).bind(mouseOrTouch("click", "touchend"), btn[1]);
footer.children("." + btnClassName).bind("click", btn[1]);
}
}
@ -4356,26 +4357,18 @@
var dialogHeader = dialog.children("." + classPrefix + "dialog-header");
if (!options.mask) {
dialogHeader.bind(mouseOrTouch("click", "touchend"), function(){
dialogHeader.bind("click", function(){
editormd.dialogZindex += 2;
dialog.css("z-index", editormd.dialogZindex);
});
}
dialogHeader.mousedown(function(e) {
e = e || window.event; //IE
posX = e.clientX - parseInt(dialog[0].style.left);
posY = e.clientY - parseInt(dialog[0].style.top);
document.onmousemove = moveAction;
});
var userCanSelect = function (obj) {
obj.removeClass(classPrefix + "user-unselect").off("selectstart");
};
var userUnselect = function (obj) {
obj.addClass(classPrefix + "user-unselect").on("selectstart", function(event) { // selectstart for IE
obj.addClass(classPrefix + "user-unselect").on("selectstart", function() { // selectstart for IE
return false;
});
};
@ -4415,6 +4408,14 @@
dialog[0].style.top = top + "px";
};
dialogHeader.mousedown(function(e) {
e = e || window.event; //IE
posX = e.clientX - parseInt(dialog[0].style.left);
posY = e.clientY - parseInt(dialog[0].style.top);
document.onmousemove = moveAction;
});
document.onmouseup = function() {
userCanSelect($("body"));
userCanSelect(dialog);

5
editormd.min.js

File diff suppressed because one or more lines are too long

14
examples/dynamic-create-editormd.html

@ -16,6 +16,7 @@
<div class="btns" style="margin:0;">
<button id="create-btn">动态创建一个 Editor.md</button>
<button id="remove-btn">移除 Editor.md</button>
<button id="destroy-btn">消毁 Editor.md</button>
</div>
</header>
</div>
@ -23,12 +24,12 @@
<script src="js/jquery.min.js"></script>
<script type="text/javascript">
var testEditormd;
$(function() {
$("#create-btn").click(function(){
$.getScript("../editormd.js", function() {
$.getScript("../editormd.js?v=20190511", function() {
$("#layout").append("<div id=\"test-editormd\"></div>");
testEditormd = editormd("test-editormd", {
width: "90%",
height: 640,
@ -37,10 +38,15 @@
});
});
});
$("#remove-btn").click(function() {
testEditormd.editor.remove();
});
$("#destroy-btn").click(function() {
testEditormd.destroy();
testEditormd = null;
});
});
</script>
</body>

4
examples/form-get-value.html

@ -11,9 +11,9 @@
<div id="layout">
<header>
<h1>表单取值</h1>
<p>Form get textarea value.</p>
<p>Form get textarea value.</p>
</header>
<form method="post" action="http://editormd.ipandao.com/php/post.php">
<form method="post" action="./php/post.php">
<div id="test-editormd">
<!-- Custom textarea name attribute <textarea style="display:none;" name="test-textarea-name"> -->
<textarea style="display:none;">#### Get value

10
examples/katex.html

@ -31,8 +31,8 @@
// Default using CloudFlare KaTeX's CDN
// You can custom url
editormd.katexURL = {
js : "your url", // default: //cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min
css : "your url" // default: //cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min
js : "your url", // default: //cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min
css : "your url" // default: //cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min
};
```
@ -180,6 +180,12 @@ f(x) = \int_{-\infty}^\infty
<script src="../editormd.js"></script>
<script type="text/javascript">
$(function() {
// custom Katex version
// editormd.katexURL = {
// css : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min",
// js : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min"
// };
var testEditor = editormd("test-editormd", {
width: "90%",
height: 640,

25
examples/multi-editormd.html

@ -35,28 +35,29 @@
<script src="js/jquery.min.js"></script>
<script src="../editormd.js"></script>
<script type="text/javascript">
var testEditormd, testEditormd2;
$(function() {
testEditormd = editormd("test-editormd", {
var testEditormd = editormd("test-editormd", {
width: "90%",
height: 480,
markdown : "#### Editor.md A",
path : '../lib/'
});
testEditormd2 = editormd("test-editormd2", {
width: "90%",
height: 480,
markdown : "#### Editor.md B",
path : '../lib/'
var testEditormd2 = editormd("test-editormd2", {
width: "50%",
height: 280,
markdown : "#### Editor.md B\n\n多个 Editor.md 并存",
path : '../lib/',
toolbarIcons: 'mini'
});
testEditormd3 = editormd("test-editormd3", {
width: "90%",
height: 480,
var testEditormd3 = editormd("test-editormd3", {
width: "60%",
height: 380,
markdown : "#### Editor.md C",
path : '../lib/'
path : '../lib/',
toolbarIcons: 'simple',
watch: false
});
});
</script>

44
examples/test.md

@ -11,7 +11,7 @@
[TOC]
# Heading 1
## Heading 2
## Heading 2
### Heading 3
#### Heading 4
##### Heading 5
@ -32,7 +32,7 @@ This is an H2
-------------
### 字符效果和横线等
----
~~删除线~~ <s>删除线(开启识别HTML标签时)</s>
@ -53,7 +53,7 @@ The <abbr title="Hyper Text Markup Language">HTML</abbr> specification is mainta
> 引用文本 Blockquotes
引用的行内混合 Blockquotes
> 引用:如果想要插入空白换行`即<br />标签`,在插入处先键入两个以上的空格然后回车即可,[普通链接](http://localhost/)。
### 锚点与链接 Links
@ -87,7 +87,7 @@ GFM a-tail link @pandao 邮箱地址自动链接 test.test@gmail.com www@vip.q
<?php
echo "Hello world!";
?>
预格式化文本:
| First Header | Second Header |
@ -95,13 +95,13 @@ GFM a-tail link @pandao 邮箱地址自动链接 test.test@gmail.com www@vip.q
| Content Cell | Content Cell |
| Content Cell | Content Cell |
#### JS代码 
#### JS代码
```javascript
function test() {
console.log("Hello world!");
}
(function(){
var box = function() {
return box.fn.init();
@ -126,9 +126,9 @@ function test() {
return this;
}
};
box.fn.init.prototype = box.fn;
window.box =box;
})();
@ -175,17 +175,17 @@ Image:
[![](https://pandao.github.io/editor.md/examples/images/7.jpg)](https://pandao.github.io/editor.md/images/7.jpg "李健首张专辑《似水流年》封面")
> 图为:李健首张专辑《似水流年》封面
----
### 列表 Lists
#### 无序列表(减号)Unordered Lists (-)
- 列表一
- 列表二
- 列表三
#### 无序列表(星号)Unordered Lists (*)
* 列表一
@ -193,7 +193,7 @@ Image:
* 列表三
#### 无序列表(加号和嵌套)Unordered Lists (+)
+ 列表一
+ 列表二
+ 列表二-1
@ -205,7 +205,7 @@ Image:
* 列表三
#### 有序列表 Ordered Lists (-)
1. 第一行
2. 第二行
3. 第三行
@ -221,9 +221,9 @@ Image:
- [ ] GFM task list 4
- [ ] GFM task list 4-1
- [ ] GFM task list 4-2
----
### 绘制表格 Tables
| 项目 | 价格 | 数量 |
@ -231,7 +231,7 @@ Image:
| 计算机 | $1600 | 5 |
| 手机 | $12 | 12 |
| 管线 | $1 | 234 |
First Header | Second Header
------------- | -------------
Content Cell | Content Cell
@ -258,7 +258,7 @@ Content Cell | Content Cell
| Computer | $1600 |
| Phone | $12 |
| Pipe | $1 |
----
#### 特殊符号 HTML Entities Codes
@ -285,13 +285,13 @@ X&sup2; Y&sup3; &frac34; &frac14; &times; &divide; &raquo;
- [ ] [ ]this is an incomplete item :fa-star: :fa-gear:;
- [ ] :smiley: this is an incomplete item [test link](#) :fa-star: :fa-gear:;
- [ ] :smiley: this is :fa-star: :fa-gear: an incomplete item [test link](#);
#### 反斜杠 Escape
\*literal asterisks\*
[========]
### 科学公式 TeX(KaTeX)
$$E=mc^2$$
@ -301,7 +301,7 @@ $$E=mc^2$$
$$x > y$$
$$\(\sqrt{3x-1}+(1+x)^2\)$$
$$\sin(\alpha)^{\theta}=\sum_{i=0}^{n}(x^i + \cos(f))$$
多行公式:
@ -352,9 +352,9 @@ cond(no)->op
```
[========]
### 绘制序列图 Sequence Diagram
```seq
Andrew->China: Says Hello
Note right of China: China thinks\nabout it

4
languages/zh-tw.js

@ -78,7 +78,7 @@
preformattedText : {
title : "添加預格式文本或代碼塊",
emptyAlert : "錯誤:請填寫預格式文本或代碼的內容。",
placeholder : "coding now...."
placeholder : "Coding now...."
},
codeBlock : {
title : "添加代碼塊",
@ -87,7 +87,7 @@
otherLanguage : "其他語言",
unselectedLanguageAlert : "錯誤:請選擇代碼所屬的語言類型。",
codeEmptyAlert : "錯誤:請填寫代碼內容。",
placeholder: : "coding now...."
placeholder : "Coding now...."
},
htmlEntities : {
title : "HTML實體字符"

6
lib/codemirror/addons.min.js

File diff suppressed because one or more lines are too long

12
lib/codemirror/modes.min.js

File diff suppressed because one or more lines are too long

11
lib/marked.min.js

File diff suppressed because one or more lines are too long

2
package.json

@ -8,6 +8,8 @@
"test": "tests"
},
"scripts": {
"dev": "gulp watch",
"build": "gulp",
"test": "echo \"Error: no test specified\" && exit 1"
},
"repository": {

4
plugins/code-block-dialog/code-block-dialog.js

@ -127,11 +127,15 @@
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]
}

4
plugins/emoji-dialog/emoji-dialog.js

@ -127,11 +127,15 @@
enter : [lang.buttons.enter, function() {
cm.replaceSelection(selecteds.join(" "));
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]

4
plugins/goto-line-dialog/goto-line-dialog.js

@ -108,12 +108,16 @@
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]
}

2
plugins/help-dialog/help-dialog.js

@ -46,6 +46,8 @@
buttons : {
close : [lang.buttons.close, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]

4
plugins/html-entities-dialog/html-entities-dialog.js

@ -71,11 +71,15 @@
enter : [lang.buttons.enter, function() {
cm.replaceSelection(selecteds.join(" "));
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]

2
plugins/image-dialog/image-dialog.js

@ -108,7 +108,6 @@
this.hide().lockScreen(false).hideMask();
//删除对话框
this.remove();
return false;
@ -117,7 +116,6 @@
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
//删除对话框
this.remove();
return false;

4
plugins/link-dialog/link-dialog.js

@ -90,12 +90,16 @@
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]
}

2
plugins/preformatted-text-dialog/preformatted-text-dialog.js

@ -82,11 +82,13 @@
cm.replaceSelection(codeTexts);
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]

4
plugins/reference-link-dialog/reference-link-dialog.js

@ -99,11 +99,15 @@
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]
}

4
plugins/table-dialog/table-dialog.js

@ -155,12 +155,16 @@
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}],
cancel : [lang.buttons.cancel, function() {
this.hide().lockScreen(false).hideMask();
this.remove();
return false;
}]
}

351
src/editormd.js

@ -1,39 +1,39 @@
;(function(factory) {
"use strict";
// CommonJS/Node.js
if (typeof require === "function" && typeof exports === "object" && typeof module === "object")
{
module.exports = factory;
{
module.exports = factory();
}
else if (typeof define === "function") // AMD/CMD/Sea.js
{
if (define.amd) // for Require.js
{
/* Require.js define replace */
}
}
else
{
define(["jquery"], factory); // for Sea.js
}
}
}
else
{
{
window.editormd = factory();
}
}(function() {
}(function() {
/* Require.js assignment replace */
"use strict";
var $ = (typeof (jQuery) !== "undefined") ? jQuery : Zepto;
var $ = (typeof (window.jQuery) !== "undefined") ? window.jQuery : window.Zepto;
if (typeof ($) === "undefined") {
return ;
}
/**
* editormd
*
@ -112,7 +112,7 @@
styleSelectedText : true,
matchWordHighlight : true, // options: true, false, "onselected"
styleActiveLine : true, // Highlight the current line
dialogLockScreen : true,
dialogLockScreen : false,
dialogShowMask : true,
dialogDraggable : true,
dialogMaskBgColor : "#fff",
@ -292,7 +292,8 @@
},
preformattedText : {
title : "添加预格式文本或代码块",
emptyAlert : "错误:请填写预格式文本或代码的内容。"
emptyAlert : "错误:请填写预格式文本或代码的内容。",
placeholder : "Coding now...."
},
codeBlock : {
title : "添加代码块",
@ -300,7 +301,8 @@
selectDefaultText : "请选择代码语言",
otherLanguage : "其他语言",
unselectedLanguageAlert : "错误:请选择代码所属的语言类型。",
codeEmptyAlert : "错误:请填写代码内容。"
codeEmptyAlert : "错误:请填写代码内容。",
placeholder : "Coding now...."
},
htmlEntities : {
title : "HTML 实体字符"
@ -350,10 +352,9 @@
{
options = id;
}
var _this = this;
var classPrefix = this.classPrefix = editormd.classPrefix;
var settings = this.settings = $.extend(true, editormd.defaults, options);
var settings = this.settings = $.extend(true, {}, editormd.defaults, options);
id = (typeof id === "object") ? settings.id : id;
@ -441,9 +442,9 @@
if (typeof define === "function" && define.amd)
{
if (typeof katex !== "undefined")
if (typeof window.katex !== "undefined")
{
editormd.$katex = katex;
editormd.$katex = window.katex;
}
if (settings.searchReplace && !settings.readOnly)
@ -452,20 +453,20 @@
editormd.loadCSS(settings.path + "codemirror/addon/search/matchesonscrollbar");
}
}
if ((typeof define === "function" && define.amd) || !settings.autoLoadModules)
{
if (typeof CodeMirror !== "undefined") {
editormd.$CodeMirror = CodeMirror;
if (typeof window.CodeMirror !== "undefined") {
editormd.$CodeMirror = window.CodeMirror;
}
if (typeof marked !== "undefined") {
editormd.$marked = marked;
if (typeof window.marked !== "undefined") {
editormd.$marked = window.marked;
}
this.setCodeMirror().setToolbar().loadedDisplay();
}
else
else
{
this.loadQueues();
}
@ -801,7 +802,6 @@
}
var cm = this.cm;
var editor = this.editor;
var count = cm.lineCount();
var preview = this.preview;
@ -1100,7 +1100,6 @@
}
var editor = this.editor;
var preview = this.preview;
var classPrefix = this.classPrefix;
var toolbar = this.toolbar = editor.children("." + classPrefix + "toolbar");
@ -1235,7 +1234,7 @@
var toolbarIcons = this.toolbarIcons = toolbar.find("." + classPrefix + "menu > li > a");
var toolbarIconHandlers = this.getToolbarHandles();
toolbarIcons.bind(editormd.mouseOrTouch("click", "touchend"), function(event) {
toolbarIcons.bind("click", function() {
var icon = $(this).children(".fa");
var name = icon.attr("name");
@ -1313,7 +1312,7 @@
var infoDialog = this.infoDialog = editor.children("." + classPrefix + "dialog-info");
infoDialog.find("." + classPrefix + "dialog-close").bind(editormd.mouseOrTouch("click", "touchend"), function() {
infoDialog.find("." + classPrefix + "dialog-close").bind("click", function() {
_this.hideInfoDialog();
});
@ -1358,8 +1357,7 @@
showInfoDialog : function() {
$("html,body").css("overflow-x", "hidden");
var _this = this;
var editor = this.editor;
var settings = this.settings;
var infoDialog = this.infoDialog = editor.children("." + this.classPrefix + "dialog-info");
@ -1422,7 +1420,6 @@
*/
recreate : function() {
var _this = this;
var editor = this.editor;
var settings = this.settings;
@ -1563,17 +1560,17 @@
* @param {Object} keyMap KeyMap key/value {"(Ctrl/Shift/Alt)-Key" : function(){}}
* @returns {editormd} return this
*/
registerKeyMaps : function(keyMap) {
var _this = this;
var cm = this.cm;
var settings = this.settings;
var toolbarHandlers = editormd.toolbarHandlers;
var disabledKeyMaps = settings.disabledKeyMaps;
keyMap = keyMap || null;
if (keyMap)
{
for (var i in keyMap)
@ -1602,34 +1599,34 @@
cm.addKeyMap(_map);
}
}
$(window).keydown(function(event) {
var keymaps = {
"120" : "F9",
"121" : "F10",
"122" : "F11"
};
if ( $.inArray(keymaps[event.keyCode], disabledKeyMaps) < 0 )
{
switch (event.keyCode)
{
case 120:
$.proxy(toolbarHandlers["watch"], _this)();
return false;
event.stopPropagation();
break;
case 121:
$.proxy(toolbarHandlers["preview"], _this)();
return false;
event.stopPropagation();
break;
case 122:
$.proxy(toolbarHandlers["fullscreen"], _this)();
return false;
$.proxy(toolbarHandlers["fullscreen"], _this)();
event.stopPropagation();
break;
default:
break;
}
@ -1639,7 +1636,7 @@
return this;
},
/**
* 绑定同步滚动
*
@ -1755,8 +1752,7 @@
return this;
}
cm.on("change", function(_cm, changeObj) {
cm.on("change", function() {
if (settings.watch)
{
_this.previewContainer.css("padding", settings.autoHeight ? "20px 20px 50px 40px" : "20px");
@ -1905,7 +1901,7 @@
if(settings.watch)
{
codeMirror.width(editor.width() / 2);
codeMirror.width((editor.width() / 2) - 1);
preview.width((!state.preview) ? editor.width() / 2 : editor.width());
this.previewContainer.css("padding", settings.autoHeight ? "20px 20px 50px 40px" : "20px");
@ -1999,21 +1995,16 @@
smartLists : true,
smartypants : true
};
marked.setOptions(markedOptions);
var newMarkdownDoc = editormd.$marked(cmValue, markedOptions);
//console.info("cmValue", cmValue, newMarkdownDoc);
newMarkdownDoc = editormd.filterHTMLTags(newMarkdownDoc, settings.htmlDecode);
//console.error("cmValue", cmValue, newMarkdownDoc);
newMarkdownDoc = editormd.filterHTMLTags(newMarkdownDoc, settings.htmlDecode);
this.markdownTextarea.text(cmValue);
cm.save();
if (settings.saveHTMLToTextarea)
{
this.htmlTextarea.text(newMarkdownDoc);
@ -2215,8 +2206,7 @@
*/
appendMarkdown : function(md) {
var settings = this.settings;
var cm = this.cm;
var cm = this.cm;
cm.setValue(cm.getValue() + md);
@ -2450,7 +2440,20 @@
return this;
},
/**
* 消毁并移除编辑器实例
*
* destroy & remove editor
*
* @returns {void} void 无返回值
*/
destroy : function () {
this.hide();
this.editor.remove();
},
/**
* 隐藏编辑器部分只预览HTML
* Enter preview html state
@ -2471,7 +2474,9 @@
if ($.inArray(settings.mode, ["gfm", "markdown"]) < 0) {
return this;
}
var editorHeight = this.editor.outerHeight();
if (settings.toolbar && toolbar) {
toolbar.toggle();
toolbar.find(".fa[name=preview]").toggleClass("active");
@ -2489,11 +2494,15 @@
{
this.state.preview = true;
if (this.settings.autoHeight) {
this.editor.css("height", editorHeight);
}
if (this.state.fullscreen) {
preview.css("background", "#fff");
}
editor.find("." + this.classPrefix + "preview-close-btn").show().bind(editormd.mouseOrTouch("click", "touchend"), function(){
editor.find("." + this.classPrefix + "preview-close-btn").show().bind("click", function(){
_this.previewed();
});
@ -2555,7 +2564,7 @@
preview[(settings.watch) ? "show" : "hide"]();
previewCloseBtn.hide().unbind(editormd.mouseOrTouch("click", "touchend"));
previewCloseBtn.hide().unbind("click");
previewContainer.removeClass(this.classPrefix + "preview-active");
@ -2563,7 +2572,11 @@
{
previewContainer.css("padding", "20px");
}
if (this.settings.autoHeight) {
this.editor.css("height", "auto");
}
preview.css({
background : null,
position : "absolute",
@ -2592,7 +2605,6 @@
var _this = this;
var state = this.state;
var editor = this.editor;
var preview = this.preview;
var toolbar = this.toolbar;
var settings = this.settings;
var fullscreenClass = this.classPrefix + "fullscreen";
@ -2890,7 +2902,6 @@
lowercase : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
var selections = cm.listSelections();
@ -3002,7 +3013,6 @@
"list-ul" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
if (selection === "")
@ -3024,7 +3034,6 @@
"list-ol" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
if(selection === "")
@ -3047,7 +3056,6 @@
hr : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
cm.replaceSelection(((cursor.ch !== 0) ? "\n\n" : "\n") + "------------\n\n");
},
@ -3085,8 +3093,7 @@
return this;
}
var cm = this.cm;
var selection = cm.getSelection();
var cm = this.cm;
cm.replaceSelection("\r\n[========]\r\n");
},
@ -3121,8 +3128,6 @@
datetime : function() {
var cm = this.cm;
var selection = cm.getSelection();
var date = new Date();
var langName = this.settings.lang.name;
var datefmt = editormd.dateFormat() + " " + editormd.dateFormat((langName === "zh-cn" || langName === "zh-tw") ? "cn-week-day" : "week-day");
@ -3170,20 +3175,19 @@
}
};
var isMac = navigator.platform.toUpperCase().indexOf('MAC')>=0;
var key = isMac ? "Cmd" : "Ctrl";
// var isMac = navigator.platform.toUpperCase().indexOf("MAC") >= 0;
// var key = isMac ? "Cmd" : "Ctrl";
editormd.keyMaps = {
[key + "-1"] : "h1",
[key + "-2"] : "h2",
[key + "-3"] : "h3",
[key + "-4"] : "h4",
[key + "-5"] : "h5",
[key + "-6"] : "h6",
[key + "-B"] : "bold", // if this is string == editormd.toolbarHandlers.xxxx
[key + "-D"] : "datetime",
[key + "Ctrl-E"] : function() { // emoji
"Ctrl-1" : "h1",
"Ctrl-2" : "h2",
"Ctrl-3" : "h3",
"Ctrl-4" : "h4",
"Ctrl-5" : "h5",
"Ctrl-6" : "h6",
"Ctrl-B" : "bold", // if this is string == editormd.toolbarHandlers.xxxx
"Ctrl-D" : "datetime",
"Ctrl-E" : function() { // emoji
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
@ -3200,11 +3204,10 @@
cm.setCursor(cursor.line, cursor.ch + 1);
}
},
[key + "-Alt-G"] : "goto-line",
[key + "-H"] : "hr",
[key + "-I"] : "italic",
[key + "-K"] : "code",
"Ctrl-Alt-G" : "goto-line",
"Ctrl-H" : "hr",
"Ctrl-I" : "italic",
"Ctrl-K" : "code",
"Ctrl-L" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3218,8 +3221,7 @@
cm.setCursor(cursor.line, cursor.ch + 1);
}
},
[key + "-U"] : "list-ul",
"Ctrl-U" : "list-ul",
"Shift-Ctrl-A" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3237,12 +3239,10 @@
cm.setCursor(cursor.line, cursor.ch + 1);
}
},
["Shift" + key + "-C"] : "code",
["Shift" + key + "Q"] : "quote",
["Shift" + key + "S"] : "del",
["Shift" + key + "K"] : "tex", // KaTeX
"Shift-Ctrl-C" : "code",
"Shift-Ctrl-Q" : "quote",
"Shift-Ctrl-S" : "del",
"Shift-Ctrl-K" : "tex", // KaTeX
"Shift-Alt-C" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
@ -3254,39 +3254,36 @@
cm.setCursor(cursor.line, cursor.ch + 3);
}
},
["Shift-" + key + "-Alt-C"] : "code-block",
["Shift-" + key + "-H"] : "html-entities",
"Shift-Alt-H" : "help",
["Shift-" + key + "-E"] : "emoji",
["Shift-" + key + "-U"] : "uppercase",
"Shift-Alt-U" : "ucwords",
["Shift-" + key + "-Alt-U"] : "ucfirst",
"Shift-Alt-L" : "lowercase",
["Shift-" + key + "-I"] : function() {
"Shift-Ctrl-Alt-C" : "code-block",
"Shift-Ctrl-H" : "html-entities",
"Shift-Alt-H" : "help",
"Shift-Ctrl-E" : "emoji",
"Shift-Ctrl-U" : "uppercase",
"Shift-Alt-U" : "ucwords",
"Shift-Ctrl-Alt-U" : "ucfirst",
"Shift-Alt-L" : "lowercase",
"Shift-Ctrl-I" : function() {
var cm = this.cm;
var cursor = cm.getCursor();
var selection = cm.getSelection();
var title = (selection === "") ? "" : " \""+selection+"\"";
var title = (selection === "") ? "" : " \"" + selection + "\"";
cm.replaceSelection("![" + selection + "]("+title+")");
cm.replaceSelection("![" + selection + "](" + title + ")");
if (selection === "") {
cm.setCursor(cursor.line, cursor.ch + 4);
}
},
["Shift-" + key + "-Alt-I"] : "image",
["Shift-" + key + "-L"] : "link",
["Shift-" + key + "-O"] : "list-ol",
["Shift-" + key + "-P"] : "preformatted-text",
["Shift-" + key + "-T"] : "table",
"Shift-Alt-P" : "pagebreak",
"F9" : "watch",
"F10" : "preview",
"F11" : "fullscreen",
"Shift-Ctrl-Alt-I" : "image",
"Shift-Ctrl-L" : "link",
"Shift-Ctrl-O" : "list-ol",
"Shift-Ctrl-P" : "preformatted-text",
"Shift-Ctrl-T" : "table",
"Shift-Alt-P" : "pagebreak",
"F9" : "watch",
"F10" : "preview",
"F11" : "fullscreen",
};
/**
@ -3332,15 +3329,13 @@
return $1.toUpperCase();
});
};
var ucfirst = firstUpperCase;
editormd.firstUpperCase = editormd.ucfirst = firstUpperCase;
editormd.urls = {
atLinkBase : "https://github.com/"
};
editormd.regexs = {
atLink : /@(\w+)/g,
email : /(\w+)@(\w+)\.(\w+)\.?(\w+)?/g,
@ -3355,7 +3350,7 @@
// Emoji graphics files url path
editormd.emoji = {
path : "http://www.emoji-cheat-sheet.com/graphics/emojis/",
path : "https://www.webpagefx.com/tools/emoji-cheat-sheet/graphics/emojis/",
ext : ".png"
};
@ -3421,7 +3416,7 @@
matchs[i] = ":\\+1:";
}
text = text.replace(new RegExp(matchs[i]), function($1, $2){
text = text.replace(new RegExp(matchs[i]), function($1) {
var faMatchs = $1.match(faIconReg);
var name = $1.replace(/:/g, "");
@ -3502,12 +3497,12 @@
if (this.options.sanitize) {
try {
var prot = decodeURIComponent(unescape(href)).replace(/[^\w:]/g,"").toLowerCase();
} catch(e) {
return "";
}
var prot = decodeURIComponent(unescape(href)).replace(/[^\w:]/g, "").toLowerCase();
if (prot.indexOf("javascript:") === 0) {
if (prot.indexOf("javascript:") === 0) {
return "";
}
} catch(e) {
return "";
}
}
@ -3532,12 +3527,12 @@
return out;
};
markedRenderer.heading = function(text, level, raw) {
markedRenderer.heading = function(text, level) {
var linkText = text;
var hasLinkReg = /\s*\<a\s*href\=\"(.*)\"\s*([^\>]*)\>(.*)\<\/a\>\s*/;
var getLinkTextReg = /\s*\<a\s*([^\>]+)\>([^\>]*)\<\/a\>\s*/g;
// var getLinkTextReg = /\s*\<a\s*([^\>]+)\>([^\>]*)\<\/a\>\s*/g;
if (hasLinkReg.test(text))
{
@ -3609,7 +3604,7 @@
: ( (pageBreakReg.test(text)) ? this.pageBreak(text) : "<p" + isTeXAddClass + ">" + this.atLink(this.emoji(text)) + "</p>\n" );
};
markedRenderer.code = function (code, lang, escaped) {
markedRenderer.code = function (code, lang) {
if (lang === "seq" || lang === "sequence")
{
@ -3800,7 +3795,7 @@
editormd.filterHTMLTags = function(html, filters) {
if (typeof html !== "string") {
html = new String(html);
html = html.toString();
}
if (typeof filters !== "string") {
@ -3838,7 +3833,9 @@
var $attrs = {};
$.each(_attrs, function(i, e) {
if (e.nodeName !== '"') $attrs[e.nodeName] = e.nodeValue;
if (e.nodeName !== "\"") {
$attrs[e.nodeName] = e.nodeValue;
}
});
$.each($attrs, function(i) {
@ -3909,9 +3906,9 @@
editormd.$marked = marked;
var div = $("#" + id);
var settings = div.settings = $.extend(true, defaults, options || {});
var settings = div.settings = $.extend(true, {}, defaults, options || {});
var saveTo = div.find("textarea");
if (saveTo.length < 1)
{
div.append("<textarea></textarea>");
@ -3946,13 +3943,13 @@
smartLists : true,
smartypants : true
};
markdownDoc = new String(markdownDoc);
markdownDoc = markdownDoc.toString();
var markdownParsed = marked(markdownDoc, markedOptions);
markdownParsed = editormd.filterHTMLTags(markdownParsed, settings.htmlDecode);
if (settings.markdownSourceCode) {
saveTo.text(markdownDoc);
} else {
@ -4113,9 +4110,9 @@
document.body.appendChild(css);
}
};
editormd.isIE = (navigator.appName == "Microsoft Internet Explorer");
editormd.isIE8 = (editormd.isIE && navigator.appVersion.match(/8./i) == "8.");
editormd.isIE = (navigator.appName === "Microsoft Internet Explorer");
editormd.isIE8 = (editormd.isIE && navigator.appVersion.match(/8./i) === "8.");
/**
* 动态加载JS文件的方法
@ -4169,10 +4166,10 @@
// 使用国外的CDN,加载速度有时会很慢,或者自定义URL
// You can custom KaTeX load url.
editormd.katexURL = {
css : "//cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min",
js : "//cdnjs.cloudflare.com/ajax/libs/KaTeX/0.3.0/katex.min"
css : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min",
js : "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.10.1/katex.min"
};
editormd.kaTeXLoaded = false;
/**
@ -4216,6 +4213,7 @@
title : "",
drag : true,
closed : true,
cached : false,
content : "",
mask : true,
maskStyle : {
@ -4234,8 +4232,6 @@
var classPrefix = editormd.classPrefix;
var guid = (new Date()).getTime();
var dialogName = ( (options.name === "") ? classPrefix + "dialog-" + guid : options.name);
var mouseOrTouch = editormd.mouseOrTouch;
var html = "<div class=\"" + classPrefix + "dialog " + dialogName + "\">";
if (options.title !== "")
@ -4258,7 +4254,6 @@
}
html += "</div>";
html += "<div class=\"" + classPrefix + "dialog-mask " + classPrefix + "dialog-mask-bg\"></div>";
html += "<div class=\"" + classPrefix + "dialog-mask " + classPrefix + "dialog-mask-con\"></div>";
html += "</div>";
@ -4321,8 +4316,12 @@
$(window).resize(dialogPosition);
dialog.children("." + classPrefix + "dialog-close").bind(mouseOrTouch("click", "touchend"), function() {
dialog.children("." + classPrefix + "dialog-close").bind("click", function() {
dialog.hide().lockScreen(false).hideMask();
if (!options.cached) {
dialog.remove();
}
});
if (typeof options.buttons === "object")
@ -4336,7 +4335,7 @@
footer.append("<button class=\"" + classPrefix + "btn " + btnClassName + "\">" + btn[0] + "</button>");
btn[1] = $.proxy(btn[1], dialog);
footer.children("." + btnClassName).bind(mouseOrTouch("click", "touchend"), btn[1]);
footer.children("." + btnClassName).bind("click", btn[1]);
}
}
@ -4346,26 +4345,18 @@
var dialogHeader = dialog.children("." + classPrefix + "dialog-header");
if (!options.mask) {
dialogHeader.bind(mouseOrTouch("click", "touchend"), function(){
dialogHeader.bind("click", function(){
editormd.dialogZindex += 2;
dialog.css("z-index", editormd.dialogZindex);
});
}
dialogHeader.mousedown(function(e) {
e = e || window.event; //IE
posX = e.clientX - parseInt(dialog[0].style.left);
posY = e.clientY - parseInt(dialog[0].style.top);
document.onmousemove = moveAction;
});
var userCanSelect = function (obj) {
obj.removeClass(classPrefix + "user-unselect").off("selectstart");
};
var userUnselect = function (obj) {
obj.addClass(classPrefix + "user-unselect").on("selectstart", function(event) { // selectstart for IE
obj.addClass(classPrefix + "user-unselect").on("selectstart", function() { // selectstart for IE
return false;
});
};
@ -4405,6 +4396,14 @@
dialog[0].style.top = top + "px";
};
dialogHeader.mousedown(function(e) {
e = e || window.event; //IE
posX = e.clientX - parseInt(dialog[0].style.left);
posY = e.clientY - parseInt(dialog[0].style.top);
document.onmousemove = moveAction;
});
document.onmouseup = function() {
userCanSelect($("body"));
userCanSelect(dialog);

Loading…
Cancel
Save