misago-editor.js 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. // Basic editor API
  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. // Enable editor
  77. function enable_editor(name) {
  78. var $editor = $(name);
  79. var $textarea = $editor.find('textarea');
  80. var $upload = $editor.find('.editor-upload');
  81. $textarea.autosize();
  82. var textarea_id = $textarea.attr('id');
  83. $editor.find('.btn-strong').click(function() {
  84. makeWrap(textarea_id, '**', '**');
  85. return false;
  86. });
  87. $editor.find('.btn-emphasis').click(function() {
  88. makeWrap(textarea_id, '*', '*');
  89. return false;
  90. });
  91. $editor.find('.btn-bold').click(function() {
  92. makeWrap(textarea_id, '[b]', '[/b]');
  93. return false;
  94. });
  95. $editor.find('.btn-italic').click(function() {
  96. makeWrap(textarea_id, '[i]', '[/i]');
  97. return false;
  98. });
  99. $editor.find('.btn-underline').click(function() {
  100. makeWrap(textarea_id, '[u]', '[/u]');
  101. return false;
  102. });
  103. $editor.find('.btn-insert-hr').click(function() {
  104. makeReplace(textarea_id, '\r\n\r\n- - - - -\r\n\r\n');
  105. return false;
  106. });
  107. // File upload handler WIP
  108. $editor.find('.btn-upload-file').click(function() {
  109. $upload.click();
  110. });
  111. $upload.on("change", function() {
  112. if (this.files[0]) {
  113. var uploaded_file = this.files[0];
  114. var reader = new FileReader();
  115. reader.onloadend = function() {
  116. $editor.append('<img src="' + reader.result + '">');
  117. }
  118. reader.readAsDataURL(uploaded_file)
  119. }
  120. });
  121. };