diff options
author | Benno <blueworrybear@gmail.com> | 2019-12-16 23:56:35 +0800 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2019-12-16 23:56:35 +0800 |
commit | 121977c36fc2af5a2b7b814b164b1357ea623c73 (patch) | |
tree | 9c292b5428f86adccf835df9f2d4e0ef32ed8bc4 /web_src | |
parent | 61db8349041cceceb4ad3233e69613705bd0a128 (diff) | |
download | gitea-121977c36fc2af5a2b7b814b164b1357ea623c73.tar.gz gitea-121977c36fc2af5a2b7b814b164b1357ea623c73.zip |
Add SimpleMDE and Fix Image Paste for Issue/Comment Editor (#9197)
* update #9132 and #8834 - add SimpleMDE for issue and fix image paste for comment editor
* attache tribute to simplemde
* update #9197 force simplemde file input event when backspace press
Diffstat (limited to 'web_src')
-rw-r--r-- | web_src/js/index.js | 59 |
1 files changed, 58 insertions, 1 deletions
diff --git a/web_src/js/index.js b/web_src/js/index.js index a310243c08..74e06488cb 100644 --- a/web_src/js/index.js +++ b/web_src/js/index.js @@ -14,6 +14,7 @@ let csrf; let suburl; let previewFileModes; let simpleMDEditor; +const commentMDEditors = {}; let codeMirrorEditor; // Disable Dropzone auto-discover because it's manually initialized @@ -304,11 +305,27 @@ function initImagePaste(target) { }); } +function initSimpleMDEImagePaste(simplemde, files) { + simplemde.codemirror.on('paste', (_, event) => { + retrieveImageFromClipboardAsBlob(event, (img) => { + const name = img.name.substr(0, img.name.lastIndexOf('.')); + uploadFile(img, (res) => { + const data = JSON.parse(res); + const pos = simplemde.codemirror.getCursor(); + simplemde.codemirror.replaceRange(`![${name}](${suburl}/attachments/${data.uuid})`, pos); + const input = $(`<input id="${data.uuid}" name="files" type="hidden">`).val(data.uuid); + files.append(input); + }); + }); + }); +} + function initCommentForm() { if ($('.comment.form').length === 0) { return; } + setCommentSimpleMDE($('.comment.form textarea')); initBranchSelector(); initCommentPreviewTab($('.comment.form')); initImagePaste($('.comment.form textarea')); @@ -836,6 +853,7 @@ function initRepository() { const $renderContent = $segment.find('.render-content'); const $rawContent = $segment.find('.raw-content'); let $textarea; + let $simplemde; // Setup new form if ($editContentZone.html().length === 0) { @@ -920,8 +938,10 @@ function initRepository() { $tabMenu.find('.preview.item').attr('data-tab', $editContentZone.data('preview')); $editContentForm.find('.write.segment').attr('data-tab', $editContentZone.data('write')); $editContentForm.find('.preview.segment').attr('data-tab', $editContentZone.data('preview')); - + $simplemde = setCommentSimpleMDE($textarea); + commentMDEditors[$editContentZone.data('write')] = $simplemde; initCommentPreviewTab($editContentForm); + initSimpleMDEImagePaste($simplemde, $files); $editContentZone.find('.cancel.button').click(() => { $renderContent.show(); @@ -968,6 +988,7 @@ function initRepository() { }); } else { $textarea = $segment.find('textarea'); + $simplemde = commentMDEditors[$editContentZone.data('write')]; } // Show write/preview tab and copy raw content as needed @@ -975,8 +996,10 @@ function initRepository() { $renderContent.hide(); if ($textarea.val().length === 0) { $textarea.val($rawContent.text()); + $simplemde.value($rawContent.text()); } $textarea.focus(); + $simplemde.codemirror.focus(); event.preventDefault(); }); @@ -1442,6 +1465,40 @@ function setSimpleMDE($editArea) { return true; } +function setCommentSimpleMDE($editArea) { + const simplemde = new SimpleMDE({ + autoDownloadFontAwesome: false, + element: $editArea[0], + forceSync: true, + renderingConfig: { + singleLineBreaks: false + }, + indentWithTabs: false, + tabSize: 4, + spellChecker: false, + toolbar: ['bold', 'italic', 'strikethrough', '|', + 'heading-1', 'heading-2', 'heading-3', 'heading-bigger', 'heading-smaller', '|', + 'code', 'quote', '|', + 'unordered-list', 'ordered-list', '|', + 'link', 'image', 'table', 'horizontal-rule', '|', + 'clean-block'] + }); + simplemde.codemirror.setOption('extraKeys', { + Enter: () => { + if (!(issuesTribute.isActive || emojiTribute.isActive)) { + return CodeMirror.Pass; + } + }, + Backspace: (cm) => { + cm.getInputField().trigger('input'); + cm.execCommand('delCharBefore'); + } + }); + issuesTribute.attach(simplemde.codemirror.getInputField()); + emojiTribute.attach(simplemde.codemirror.getInputField()); + return simplemde; +} + function setCodeMirror($editArea) { if (simpleMDEditor) { simpleMDEditor.toTextArea(); |