diff options
author | wxiaoguang <wxiaoguang@gmail.com> | 2023-02-28 07:13:52 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-27 17:13:52 -0600 |
commit | 8b86ccbee189b578b6ebe1b18be0283b49168c7c (patch) | |
tree | e7135eff6e57453aa4512504ac375732050fed98 | |
parent | 725a97c6c9d2576797b7d15a687146941fba3a02 (diff) | |
download | gitea-8b86ccbee189b578b6ebe1b18be0283b49168c7c.tar.gz gitea-8b86ccbee189b578b6ebe1b18be0283b49168c7c.zip |
Change button text for commenting and closing an issue at the same time (#23135)
Close #10468
Without SimpleMDE/EasyMDE, using Simple Textarea, the button text could
be changed when content changes.
After introducing SimpleMDE/EasyMDE, there is no code for updating the
button text.
-rw-r--r-- | web_src/js/features/comp/EasyMDE.js | 3 | ||||
-rw-r--r-- | web_src/js/features/repo-legacy.js | 8 |
2 files changed, 10 insertions, 1 deletions
diff --git a/web_src/js/features/comp/EasyMDE.js b/web_src/js/features/comp/EasyMDE.js index 182e6b429d..a030db83a3 100644 --- a/web_src/js/features/comp/EasyMDE.js +++ b/web_src/js/features/comp/EasyMDE.js @@ -77,6 +77,9 @@ export async function createCommentEasyMDE(textarea, easyMDEOptions = {}) { const inputField = easyMDE.codemirror.getInputField(); + easyMDE.codemirror.on('change', (...args) => { + easyMDEOptions?.onChange(...args); + }); easyMDE.codemirror.setOption('extraKeys', { 'Cmd-Enter': codeMirrorQuickSubmit, 'Ctrl-Enter': codeMirrorQuickSubmit, diff --git a/web_src/js/features/repo-legacy.js b/web_src/js/features/repo-legacy.js index a9229c0d1e..118475e32e 100644 --- a/web_src/js/features/repo-legacy.js +++ b/web_src/js/features/repo-legacy.js @@ -85,12 +85,18 @@ export function initRepoCommentForm() { } (async () => { + const $statusButton = $('#status-button'); for (const textarea of $commentForm.find('textarea:not(.review-textarea, .no-easymde)')) { // Don't initialize EasyMDE for the dormant #edit-content-form if (textarea.closest('#edit-content-form')) { continue; } - const easyMDE = await createCommentEasyMDE(textarea); + const easyMDE = await createCommentEasyMDE(textarea, { + 'onChange': () => { + const value = easyMDE?.value().trim(); + $statusButton.text($statusButton.attr(value.length === 0 ? 'data-status' : 'data-status-and-comment')); + }, + }); initEasyMDEImagePaste(easyMDE, $commentForm.find('.dropzone')); } })(); |