Skip to content

Commit

Permalink
merge markdown editor code update from leanote/leanote-ios@e60a47c, l…
Browse files Browse the repository at this point in the history
  • Loading branch information
FlyingRadish committed Feb 9, 2017
1 parent 65cbea0 commit 8898a5c
Show file tree
Hide file tree
Showing 53 changed files with 63 additions and 6,099 deletions.
80 changes: 63 additions & 17 deletions app/src/main/assets/markdownEditor/all.js
Original file line number Diff line number Diff line change
Expand Up @@ -14713,7 +14713,7 @@ define('extensions/markdownExtra',[
"def_list",
"attr_list",
"footnotes",
"smartypants",
// "smartypants",
"strikethrough",
"newlines"
],
Expand Down Expand Up @@ -25244,6 +25244,21 @@ define('extensions/emailConverter',[
return emailConverter;
});

define('extensions/todoList',[
"classes/Extension",
], function(Extension) {
var todoList = new Extension("todoList", "Markdown todoList", true);
todoList.onPagedownConfigure = function(editor) {
editor.getConverter().hooks.chain("postConversion", function(text) {
return text.replace(/<li>(<p>)?\[([ xX]?)\] /g, function(matched, p, b) {
p || (p = '');
return !(b == 'x' || b == 'X') ? '<li class="m-todo-item m-todo-empty">' + p + '<input type="checkbox"> ' : '<li class="m-todo-item m-todo-done">' + p + '<input type="checkbox" checked /> '
});
});
};
return todoList;
});

define('extensions/scrollSync',[
// "jquery",
"underscore",
Expand Down Expand Up @@ -25927,10 +25942,9 @@ define('extensions/htmlSanitizer',[
// "jquery",
"underscore",
"utils",
"logger",
"classes/Extension",
// "ext!html/htmlSanitizerSettingsBlock.html"
], function(_, utils, logger, Extension) {
], function(_, utils, Extension) {

var htmlSanitizer = new Extension("htmlSanitizer", "HTML Sanitizer", true);
// htmlSanitizer.settingsBlock = htmlSanitizerSettingsBlockHTML;
Expand All @@ -25941,9 +25955,10 @@ define('extensions/htmlSanitizer',[
converter.hooks.chain("postConversion", function(html) {
buf = [];
html.split('<div class="se-preview-section-delimiter"></div>').forEach(function(sectionHtml) {
htmlParser(sectionHtml, htmlSanitizeWriter(buf, function(uri, isImage) {
htmlParser(sectionHtml, htmlSanitizeWriter(buf
/*, function(uri, isImage) {
return !/^unsafe/.test(sanitizeUri(uri, isImage));
}));
}*/));
buf.push('<div class="se-preview-section-delimiter"></div>');
});
return buf.slice(0, -1).join('');
Expand All @@ -25956,17 +25971,47 @@ define('extensions/htmlSanitizer',[
* License: MIT
*/

var aHrefSanitizationWhitelist = /^\s*(https?|ftp|mailto|tel|file):/,
imgSrcSanitizationWhitelist = /^\s*(https?|ftp|file|leanote):|data:image\//;
// var aHrefSanitizationWhitelist = /^\s*(https?|ftp|mailto|tel|file):/,
// imgSrcSanitizationWhitelist = /^\s*(https?|ftp|file|leanote):|data:image\//;
/*
var urlResolve = (function() {
var urlParsingNode = document.createElement("a");
return function urlResolve(url) {
var href = url;

if (utils.msie) {
// Normalize before parse. Refer Implementation Notes on why this is
// done in two steps on IE.
urlParsingNode.setAttribute("href", href);
href = urlParsingNode.href;
}

urlParsingNode.setAttribute('href', href);

// urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils
return {
href: urlParsingNode.href,
protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',
host: urlParsingNode.host,
search: urlParsingNode.search ? urlParsingNode.search.replace(/^\?/, '') : '',
hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',
hostname: urlParsingNode.hostname,
port: urlParsingNode.port,
pathname: (urlParsingNode.pathname.charAt(0) === '/') ?
urlParsingNode.pathname : '/' + urlParsingNode.pathname
};
};
})();

function sanitizeUri(uri, isImage) {
var regex = isImage ? imgSrcSanitizationWhitelist : aHrefSanitizationWhitelist;
var normalizedVal;
normalizedVal = utils.urlResolve(uri).href;
normalizedVal = urlResolve(uri).href;
if(normalizedVal !== '' && !normalizedVal.match(regex)) {
return 'unsafe:' + normalizedVal;
}
}
*/

// Regular Expressions for parsing tags and attributes
var START_TAG_REGEXP =
Expand Down Expand Up @@ -26005,22 +26050,22 @@ define('extensions/htmlSanitizer',[
optionalEndTagInlineElements,
optionalEndTagBlockElements);

// 允许的elements
// Safe Block Elements - HTML5
var blockElements = _.extend({}, optionalEndTagBlockElements, makeMap("address,article," +
"aside,blockquote,caption,center,del,dir,div,dl,figure,figcaption,footer,h1,h2,h3,h4,h5," +
"h6,header,hgroup,hr,ins,map,menu,nav,ol,pre,script,section,table,ul"));
"h6,header,hgroup,hr,ins,map,menu,nav,ol,pre,script,section,table,ul,embed,iframe"));

// Inline Elements - HTML5
var inlineElements = _.extend({}, optionalEndTagInlineElements, makeMap("a,abbr,acronym,b," +
"bdi,bdo,big,br,cite,code,del,dfn,em,font,i,img,ins,kbd,label,map,mark,q,ruby,rp,rt,s," +
"samp,small,span,strike,strong,sub,sup,time,tt,u,var"));

"samp,small,span,strike,strong,sub,sup,time,tt,u,var,input"));

// Special Elements (can contain anything)
var specialElements = makeMap("script,style");
var specialElements = makeMap("script");

// benweet: Add iframe
blockElements.iframe = true;
// blockElements.iframe = true;

var validElements = _.extend({},
voidElements,
Expand All @@ -26035,7 +26080,7 @@ define('extensions/htmlSanitizer',[
'color,cols,colspan,compact,coords,dir,face,headers,height,hreflang,hspace,' +
'ismap,lang,language,nohref,nowrap,rel,rev,rows,rowspan,rules,' +
'scope,scrolling,shape,size,span,start,summary,target,title,type,' +
'valign,value,vspace,width'));
'valign,value,vspace,width,checked,disabled,style'));

// benweet: Add id and allowfullscreen (YouTube iframe)
validAttrs.id = true;
Expand Down Expand Up @@ -26270,7 +26315,7 @@ define('extensions/htmlSanitizer',[
* comment: function(text) {}
* }
*/
function htmlSanitizeWriter(buf, uriValidator) {
function htmlSanitizeWriter(buf /* , uriValidator */ ) {
var ignore = false;
var out = _.bind(buf.push, buf);
return {
Expand All @@ -26284,9 +26329,9 @@ define('extensions/htmlSanitizer',[
out(tag);
_.forEach(attrs, function(value, key) {
var lkey = key && key.toLowerCase();
var isImage = (tag === 'img' && lkey === 'src') || (lkey === 'background');
// var isImage = (tag === 'img' && lkey === 'src') || (lkey === 'background');
if(validAttrs[lkey] === true &&
(uriAttrs[lkey] !== true || uriValidator(value, isImage))) {
(uriAttrs[lkey] !== true || true/* || uriValidator(value, isImage) */)) {
out(' ');
out(key);
out('="');
Expand Down Expand Up @@ -26501,6 +26546,7 @@ define('eventMgr',[
"extensions/toc",
"extensions/mathJax",
"extensions/emailConverter",
"extensions/todoList",
"extensions/scrollSync",
// "extensions/buttonSync",
// "extensions/buttonPublish",
Expand Down
Loading

0 comments on commit 8898a5c

Please sign in to comment.