editor.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. // Basic editor functions
  2. function storeCaret(ftext) {
  3. if (ftext.createTextRange) {
  4. ftext.caretPos = document.selection.createRange().duplicate();
  5. }
  6. }
  7. function SelectionRange(start, end) {
  8. this.start = start;
  9. this.end = end;
  10. }
  11. function getSelection(textId) {
  12. ctrl = document.getElementById(textId);
  13. if (document.selection) {
  14. ctrl.focus();
  15. var range = document.selection.createRange();
  16. var length = range.text.length;
  17. range.moveStart('character', -ctrl.value.length);
  18. return new SelectionRange(range.text.length - length, range.text.length);
  19. } else if (ctrl.selectionStart || ctrl.selectionStart == '0') {
  20. return new SelectionRange(ctrl.selectionStart, ctrl.selectionEnd);
  21. }
  22. }
  23. function getSelectionText(textId) {
  24. var ctrl = document.getElementById(textId);
  25. var text = ctrl.value;
  26. myRange = getSelection(textId);
  27. return $.trim(text.substring(myRange.start, myRange.end));
  28. }
  29. function setSelection(textId, SelectionRange) {
  30. ctrl = document.getElementById(textId);
  31. if (ctrl.setSelectionRange) {
  32. ctrl.focus();
  33. ctrl.setSelectionRange(SelectionRange.start, SelectionRange.end);
  34. } else if (ctrl.createTextRange) {
  35. var range = ctrl.createTextRange();
  36. range.collapse(true);
  37. range.moveStart('character', SelectionRange.start);
  38. range.moveEnd('character', SelectionRange.end);
  39. range.select();
  40. }
  41. }
  42. function _makeWrap(textId, myRange, wrap_start, wrap_end) {
  43. var ctrl = document.getElementById(textId);
  44. var text = ctrl.value;
  45. var startText = text.substring(0, myRange.start) + wrap_start;
  46. var middleText = text.substring(myRange.start, myRange.end);
  47. var endText = wrap_end + text.substring(myRange.end);
  48. ctrl.value = startText + middleText + endText;
  49. setSelection(textId, new SelectionRange(startText.length, startText.length + middleText.length));
  50. }
  51. function makeWrap(textId, wrap_start, wrap_end) {
  52. _makeWrap(textId, getSelection(textId), wrap_start, wrap_end);
  53. }
  54. function _makeReplace(textId, myRange, replacement) {
  55. var ctrl = document.getElementById(textId);
  56. var text = ctrl.value;
  57. var startText = text.substring(0, myRange.start);
  58. var middleText = text.substring(myRange.start, myRange.end);
  59. var endText = text.substring(myRange.end);
  60. ctrl.value = text.substring(0, myRange.start) + replacement + text.substring(myRange.end);
  61. setSelection(textId, new SelectionRange(startText.length + middleText.length, startText.length + middleText.length));
  62. }
  63. function makeReplace(textId, replacement) {
  64. _makeReplace(textId, getSelection(textId), replacement);
  65. }
  66. var url_pattern = new RegExp('^(https?:\\/\\/)?((([a-z\\d]([a-z\\d-]*[a-z\\d])*)\\.)+[a-z]{2,}|((\\d{1,3}\\.){3}\\d{1,3}))(\\:\\d+)?(\\/[-a-z\\d%_.~+]*)*(\\?[;&a-z\\d%_.~+=-]*)?(\\#[-a-z\\d_]*)?$','i');
  67. function is_url(str) {
  68. return url_pattern.test($.trim(str));
  69. }
  70. function extractor(query) {
  71. var result = /([^\s]+)$/.exec(query);
  72. if(result && result[1])
  73. return result[1].trim();
  74. return '';
  75. }
  76. // Small and nice editor functionality
  77. $(function() {
  78. $('.editor-tools').fadeIn(600);
  79. $('.editor').each(function() {
  80. // Get textarea stuff
  81. var textarea = $(this).find('textarea');
  82. var textarea_id = $(textarea).attr('id');
  83. // Do we have emojis?
  84. if (1==2 && ed_emojis.length > 1) {
  85. var mode = 0;
  86. var open = -1;
  87. $(textarea).focusout(function() {
  88. mode = 0;
  89. open = -1;
  90. });
  91. $(textarea).keyup(function() {
  92. text = $(textarea).val();
  93. cursor = getSelection(textarea_id).start;
  94. if (cursor > 0) {
  95. // Read typed character and previous character
  96. input = text.substring(cursor - 1, cursor);
  97. if (cursor > 1) {
  98. pre = text.substring(cursor - 2, cursor - 1);
  99. } else {
  100. pre = '';
  101. }
  102. // Act accordingly to current mode
  103. if (mode == 0) {
  104. if (input == ':' && !pre.match(/^[A-Za-z0-9]+$/i)) {
  105. // Test passed, mode 1 engaged!
  106. mode = 1;
  107. open = cursor;
  108. }
  109. } else if (mode == 1) {
  110. // Inside emoji mode, we are helping user enter emoji input
  111. if (cursor > open && !input.match(/^(\+|\-|[_A-Za-z0-9])+$/i)) {
  112. // Emoji fail
  113. mode = 0;
  114. }
  115. }
  116. }
  117. });
  118. }
  119. // Handle buttons
  120. $('.editor-bold').click(function() {
  121. makeWrap(textarea_id, '**', '**');
  122. return false;
  123. });
  124. $('.editor-emphasis').click(function() {
  125. makeWrap(textarea_id, '*', '*');
  126. return false;
  127. });
  128. $('.editor-link').click(function() {
  129. var selection = $.trim(getSelectionText(textarea_id));
  130. if (is_url(selection)) {
  131. var link_url = $.trim(prompt(ed_lang_enter_link_url, selection));
  132. selection = false;
  133. } else {
  134. var link_url = $.trim(prompt(ed_lang_enter_link_url));
  135. }
  136. if (is_url(link_url)) {
  137. if (selection) {
  138. var link_label = $.trim(prompt(ed_lang_enter_link_label, selection));
  139. } else {
  140. var link_label = $.trim(prompt(ed_lang_enter_link_label));
  141. }
  142. if (link_label.length > 0) {
  143. makeReplace(textarea_id, '[' + link_label + '](' + link_url + ')');
  144. } else {
  145. makeReplace(textarea_id, '<' + link_url + '>');
  146. }
  147. }
  148. return false;
  149. });
  150. $('.editor-image').click(function() {
  151. var selection = $.trim(getSelectionText(textarea_id));
  152. if (is_url(selection)) {
  153. var image_url = $.trim(prompt(ed_lang_enter_image_url, selection));
  154. selection = false;
  155. } else {
  156. var image_url = $.trim(prompt(ed_lang_enter_image_url));
  157. }
  158. if (is_url(image_url)) {
  159. if (selection) {
  160. var image_label = $.trim(prompt(ed_lang_enter_image_label, selection));
  161. } else {
  162. var image_label = $.trim(prompt(ed_lang_enter_image_label));
  163. }
  164. if (image_label.length > 0) {
  165. makeReplace(textarea_id, '![' + image_label + '](' + image_url + ')');
  166. } else {
  167. makeReplace(textarea_id, '!(' + image_url + ')');
  168. }
  169. }
  170. return false;
  171. });
  172. $('.editor-hr').click(function() {
  173. makeReplace(textarea_id, '\r\n\r\n- - - - -\r\n\r\n');
  174. return false;
  175. });
  176. });
  177. });