Merge pull request #298 from matthojo/Markdown-Fixes

Additional Keyboard Shortcuts and improvements to text highlighting
This commit is contained in:
Hannah Wolfe 2013-07-23 11:44:14 -07:00
commit c2ac06cf0c
4 changed files with 84 additions and 6 deletions

View File

@ -0,0 +1,22 @@
/*
* To Title Case 2.0.1 http://individed.com/code/to-title-case/
* Copyright © 20082012 David Gouch. Licensed under the MIT License.
*/
String.prototype.toTitleCase = function () {
var smallWords = /^(a|an|and|as|at|but|by|en|for|if|in|of|on|or|the|to|vs?\.?|via)$/i;
return this.replace(/([^\W_]+[^\s-]*) */g, function (match, p1, index, title) {
if (index > 0 && index + p1.length !== title.length &&
p1.search(smallWords) > -1 && title.charAt(index - 2) !== ":" &&
title.charAt(index - 1).search(/[^\s-]/) < 0) {
return match.toLowerCase();
}
if (p1.substr(1).search(/[A-Z]|\../) > -1) {
return match;
}
return match.charAt(0).toUpperCase() + match.substr(1);
});
};

View File

@ -1,6 +1,6 @@
// # Surrounds given text with Markdown syntax // # Surrounds given text with Markdown syntax
/*global $, CodeMirror */ /*global $, window, CodeMirror, Showdown */
(function () { (function () {
"use strict"; "use strict";
var Markdown = { var Markdown = {
@ -15,10 +15,58 @@
self.replace(); self.replace();
}, },
replace: function () { replace: function () {
var text = this.elem.getSelection(), md; var text = this.elem.getSelection(), pass = true, md, cursor, word, converter;
if (this.options.syntax[this.style]) { switch (this.style) {
md = this.options.syntax[this.style].replace('$1', text); case "link":
this.elem.replaceSelection(md); md = this.options.syntax.link.replace('$1', text);
this.elem.replaceSelection(md, "end");
cursor = this.elem.getCursor();
this.elem.setSelection({line: cursor.line, ch: cursor.ch - 8}, {line: cursor.line, ch: cursor.ch - 1});
pass = false;
break;
case "image":
md = this.options.syntax.image.replace('$1', text);
this.elem.replaceSelection(md, "end");
cursor = this.elem.getCursor();
this.elem.setSelection({line: cursor.line, ch: cursor.ch - 8}, {line: cursor.line, ch: cursor.ch - 1});
pass = false;
break;
case "uppercase":
md = text.toLocaleUpperCase();
break;
case "lowercase":
md = text.toLocaleLowerCase();
break;
case "titlecase":
md = text.toTitleCase();
break;
case "selectword":
cursor = this.elem.getCursor();
word = this.elem.getTokenAt(cursor);
if (!/\w$/g.test(word.string)) {
this.elem.setSelection({line: cursor.line, ch: word.start}, {line: cursor.line, ch: word.end - 1});
} else {
this.elem.setSelection({line: cursor.line, ch: word.start}, {line: cursor.line, ch: word.end});
}
break;
case "copyHTML":
converter = new Showdown.converter();
md = converter.makeHtml(text);
window.prompt("Copy to clipboard: Ctrl+C, Enter", md);
pass = false;
break;
case "list":
md = text.replace(/^/gm, "* ");
this.elem.replaceSelection("\n" + md + "\n", "end");
pass = false;
break;
default:
if (this.options.syntax[this.style]) {
md = this.options.syntax[this.style].replace('$1', text);
}
}
if (pass && md) {
this.elem.replaceSelection(md, "end");
} }
} }
}; };

View File

@ -23,7 +23,14 @@
{'key': 'Ctrl+Shift+L', 'style': 'link'}, {'key': 'Ctrl+Shift+L', 'style': 'link'},
{'key': 'Ctrl+Shift+I', 'style': 'image'}, {'key': 'Ctrl+Shift+I', 'style': 'image'},
{'key': 'Ctrl+Q', 'style': 'blockquote'}, {'key': 'Ctrl+Q', 'style': 'blockquote'},
{'key': 'Ctrl+Shift+1', 'style': 'currentdate'} {'key': 'Ctrl+Shift+1', 'style': 'currentdate'},
{'key': 'Ctrl+U', 'style': 'uppercase'},
{'key': 'Ctrl+Shift+U', 'style': 'lowercase'},
{'key': 'Ctrl+Alt+Shift+U', 'style': 'titlecase'},
{'key': 'Ctrl+Alt+W', 'style': 'selectword'},
{'key': 'Ctrl+L', 'style': 'list'},
{'key': 'Ctrl+Alt+C', 'style': 'copyHTML'},
{'key': 'CMD+Alt+C', 'style': 'copyHTML'}
]; ];
// The publish bar associated with a post, which has the TagWidget and // The publish bar associated with a post, which has the TagWidget and

View File

@ -45,6 +45,7 @@
<script src="/public/vendor/showdown/extensions/ghostdown.js"></script> <script src="/public/vendor/showdown/extensions/ghostdown.js"></script>
<script src="/public/vendor/shortcuts.js"></script> <script src="/public/vendor/shortcuts.js"></script>
<script src="/public/vendor/countable.js"></script> <script src="/public/vendor/countable.js"></script>
<script src="/public/vendor/to-title-case.js"></script>
<script src="/public/vendor/jquery/jquery-ui-1.10.3.custom.min.js"></script> <script src="/public/vendor/jquery/jquery-ui-1.10.3.custom.min.js"></script>
<script src="/public/vendor/packery.pkgd.min.js"></script> <script src="/public/vendor/packery.pkgd.min.js"></script>