From 01217c9f4a83cbf700bca803cf1479c06981dac1 Mon Sep 17 00:00:00 2001
From: Wu Cheng-Han
Date: Fri, 25 Sep 2015 17:41:15 +0800
Subject: Added extraTags support for list, and can toggle todo list in the
view mode
---
public/js/extra.js | 80 ++++++++++++++++++++++++++++++++++++++++--------------
public/js/index.js | 32 ++++++++++++++++++----
2 files changed, 87 insertions(+), 25 deletions(-)
diff --git a/public/js/extra.js b/public/js/extra.js
index f2fd6a72..d5df6a6d 100644
--- a/public/js/extra.js
+++ b/public/js/extra.js
@@ -50,7 +50,7 @@ function slugifyWithUTF8(text) {
var viewAjaxCallback = null;
-//regex for blockquote
+//regex for extra tags
var spaceregex = /\s*/;
var notinhtmltagregex = /(?![^<]*>|[^<>]*<\/)/;
var coloregex = /\[color=([#|\(|\)|\s|\,|\w]*?)\]/;
@@ -61,8 +61,44 @@ var nameandtimeregex = new RegExp(nameregex.source + spaceregex.source + timereg
nameregex = new RegExp(nameregex.source + notinhtmltagregex.source, "g");
timeregex = new RegExp(timeregex.source + notinhtmltagregex.source, "g");
+function replaceExtraTags(html) {
+ html = html.replace(coloregex, '');
+ html = html.replace(nameandtimeregex, ' $1 $2');
+ html = html.replace(nameregex, ' $1');
+ html = html.replace(timeregex, ' $1');
+ return html;
+}
+
//dynamic event or object binding here
function finishView(view) {
+ //todo list
+ var lis = view.find('li.raw').removeClass("raw").sortByDepth().toArray();
+ for (var i = 0; i < lis.length; i++) {
+ var li = lis[i];
+ var html = $(li).clone()[0].innerHTML;
+ var p = $(li).children('p');
+ if (p.length == 1) {
+ html = p.html();
+ li = p[0];
+ }
+ html = replaceExtraTags(html);
+ li.innerHTML = html;
+ var disabled = 'disabled';
+ if(typeof editor !== 'undefined' && havePermission())
+ disabled = '';
+ if (/^\s*\[[x ]\]\s*/.test(html)) {
+ li.innerHTML = html.replace(/^\s*\[ \]\s*/, '')
+ .replace(/^\s*\[x\]\s*/, '');
+ lis[i].setAttribute('class', 'task-list-item');
+ }
+ if (typeof editor !== 'undefined' && havePermission())
+ $(li).find('input').change(toggleTodoEvent);
+ //color tag in list will convert it to tag icon with color
+ var tag_color = $(li).closest('ul').find(".color");
+ tag_color.each(function (key, value) {
+ $(value).addClass('fa fa-tag').css('color', $(value).attr('data-color'));
+ });
+ }
//youtube
view.find(".youtube.raw").removeClass("raw")
.click(function () {
@@ -149,12 +185,10 @@ function finishView(view) {
var blockquote_p = blockquote.find("p");
blockquote_p.each(function (key, value) {
var html = $(value).html();
- html = html.replace(coloregex, '');
- html = html.replace(nameandtimeregex, ' $1 $2');
- html = html.replace(nameregex, ' $1');
- html = html.replace(timeregex, ' $1');
+ html = replaceExtraTags(html);
$(value).html(html);
});
+ //color tag in blockquote will change its left border color
var blockquote_color = blockquote.find(".color");
blockquote_color.each(function (key, value) {
$(value).closest("blockquote").css('border-left-color', $(value).attr('data-color'));
@@ -173,23 +207,8 @@ function postProcess(code) {
result.find("iframe").replaceWith(function () {
return "" + $(this).html() + ""
});
- //todo list
- var lis = result.find('li.raw').removeClass("raw").sortByDepth().toArray();
- for (var i = 0; i < lis.length; i++) {
- var li = lis[i];
- var html = $(li).clone()[0].innerHTML;
- var p = $(li).children('p');
- if (p.length == 1) {
- html = p.html();
- li = p[0];
}
- if (/^\s*\[[x ]\]\s*/.test(html)) {
- li.innerHTML = html.replace(/^\s*\[ \]\s*/, '')
- .replace(/^\s*\[x\]\s*/, '');
- lis[i].setAttribute('class', 'task-list-item');
}
- }
- return result;
}
//jQuery sortByDepth
@@ -211,6 +230,27 @@ $.fn.sortByDepth = function () {
return $(result);
};
+function toggleTodoEvent(e) {
+ var startline = $(this).closest('li').attr('data-startline') - 1;
+ var line = editor.getLine(startline);
+ var matches = line.match(/^[>\s]*[\-\+\*]\s\[([x ])\]/);
+ if (matches && matches.length >= 2) {
+ var checked = null;
+ if (matches[1] == 'x')
+ checked = true;
+ else if (matches[1] == ' ')
+ checked = false;
+ var replacements = matches[0].match(/(^[>\s]*[\-\+\*]\s\[)([x ])(\])/);
+ editor.replaceRange(checked ? ' ' : 'x', {
+ line: startline,
+ ch: replacements[1].length
+ }, {
+ line: startline,
+ ch: replacements[1].length + 1
+ }, '+input');
+ }
+}
+
//remove hash
function removeHash() {
history.pushState("", document.title, window.location.pathname + window.location.search);
diff --git a/public/js/index.js b/public/js/index.js
index c414b0b5..28503413 100644
--- a/public/js/index.js
+++ b/public/js/index.js
@@ -102,7 +102,7 @@ var supportExternals = [
search: 'gist'
}
];
-var supportBlockquoteTags = [
+var supportExtraTags = [
{
text: '[name tag]',
search: '[]',
@@ -2031,13 +2031,35 @@ $(editor.getInputField())
return !isInCode;
}
},
- { //blockquote personal info & general info
+ { //extra tags for blockquote
match: /(?:^|\n|\s)(\>.*)(\[\])(\w*)$/,
search: function (term, callback) {
var list = [];
- $.map(supportBlockquoteTags, function (blockquotetag) {
- if (blockquotetag.search.indexOf(term) === 0)
- list.push(blockquotetag.command());
+ $.map(supportExtraTags, function (extratag) {
+ if (extratag.search.indexOf(term) === 0)
+ list.push(extratag.command());
+ });
+ $.map(supportReferrals, function (referral) {
+ if (referral.search.indexOf(term) === 0)
+ list.push(referral.text);
+ })
+ callback(list);
+ checkCursorMenu();
+ },
+ replace: function (value) {
+ return '$1' + value;
+ },
+ context: function (text) {
+ return !isInCode;
+ }
+ },
+ { //extra tags for list
+ match: /(^[>\s]*[\-\+\*]\s(?:\[[x ]\]|.*))(\[\])(\w*)$/,
+ search: function (term, callback) {
+ var list = [];
+ $.map(supportExtraTags, function (extratag) {
+ if (extratag.search.indexOf(term) === 0)
+ list.push(extratag.command());
});
$.map(supportReferrals, function (referral) {
if (referral.search.indexOf(term) === 0)
--
cgit v1.2.3