diff options
author | Earl Warren <109468362+earl-warren@users.noreply.github.com> | 2024-01-14 23:00:47 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-15 00:00:47 +0200 |
commit | 3f342d6dffb0ef902965192f7ec4713b799c6a67 (patch) | |
tree | 6e956c499840d957e038e5099918fbba478a6bae /web_src/js/components | |
parent | 5a7bacb005b092f41640a4f72bba78d4918a9fb1 (diff) | |
download | gitea-3f342d6dffb0ef902965192f7ec4713b799c6a67.tar.gz gitea-3f342d6dffb0ef902965192f7ec4713b799c6a67.zip |
Modernize merge button (#28140)
- Make use of the `form-fetch-action` for the merge button, which will
automatically prevent the action from happening multiple times and show
a nice loading indicator as user feedback while the merge request is
being processed by the server.
- Adjust the merge PR code to JSON response as this is required for the
`form-fetch-action` functionality.
- Resolves https://codeberg.org/forgejo/forgejo/issues/774
- Likely resolves the cause of
https://codeberg.org/forgejo/forgejo/issues/1688#issuecomment-1313044
(cherry picked from commit 4ec64c19507caefff7ddaad722b1b5792b97cc5a)
Co-authored-by: Gusted <postmaster@gusted.xyz>
Diffstat (limited to 'web_src/js/components')
-rw-r--r-- | web_src/js/components/PullRequestMergeForm.vue | 74 |
1 files changed, 36 insertions, 38 deletions
diff --git a/web_src/js/components/PullRequestMergeForm.vue b/web_src/js/components/PullRequestMergeForm.vue index 54dcf9d860..b0b10b6252 100644 --- a/web_src/js/components/PullRequestMergeForm.vue +++ b/web_src/js/components/PullRequestMergeForm.vue @@ -94,48 +94,46 @@ export default { <!-- eslint-disable-next-line vue/no-v-html --> <div v-if="mergeForm.hasPendingPullRequestMerge" v-html="mergeForm.hasPendingPullRequestMergeTip" class="ui info message"/> - <div class="ui form" v-if="showActionForm"> - <form :action="mergeForm.baseLink+'/merge'" method="post"> - <input type="hidden" name="_csrf" :value="csrfToken"> - <input type="hidden" name="head_commit_id" v-model="mergeForm.pullHeadCommitID"> - <input type="hidden" name="merge_when_checks_succeed" v-model="autoMergeWhenSucceed"> - <input type="hidden" name="force_merge" v-model="forceMerge"> - - <template v-if="!mergeStyleDetail.hideMergeMessageTexts"> - <div class="field"> - <input type="text" name="merge_title_field" v-model="mergeTitleFieldValue"> - </div> - <div class="field"> - <textarea name="merge_message_field" rows="5" :placeholder="mergeForm.mergeMessageFieldPlaceHolder" v-model="mergeMessageFieldValue"/> - <template v-if="mergeMessageFieldValue !== mergeForm.defaultMergeMessage"> - <button @click.prevent="clearMergeMessage" class="btn gt-mt-2 gt-p-2 interact-fg" :data-tooltip-content="mergeForm.textClearMergeMessageHint"> - {{ mergeForm.textClearMergeMessage }} - </button> - </template> - </div> - </template> - - <div class="field" v-if="mergeStyle === 'manually-merged'"> - <input type="text" name="merge_commit_id" :placeholder="mergeForm.textMergeCommitId"> + <form class="ui form form-fetch-action" v-if="showActionForm" :action="mergeForm.baseLink+'/merge'" method="post"> + <input type="hidden" name="_csrf" :value="csrfToken"> + <input type="hidden" name="head_commit_id" v-model="mergeForm.pullHeadCommitID"> + <input type="hidden" name="merge_when_checks_succeed" v-model="autoMergeWhenSucceed"> + <input type="hidden" name="force_merge" v-model="forceMerge"> + + <template v-if="!mergeStyleDetail.hideMergeMessageTexts"> + <div class="field"> + <input type="text" name="merge_title_field" v-model="mergeTitleFieldValue"> </div> - - <button class="ui button" :class="mergeButtonStyleClass" type="submit" name="do" :value="mergeStyle"> - {{ mergeStyleDetail.textDoMerge }} - <template v-if="autoMergeWhenSucceed"> - {{ mergeForm.textAutoMergeButtonWhenSucceed }} + <div class="field"> + <textarea name="merge_message_field" rows="5" :placeholder="mergeForm.mergeMessageFieldPlaceHolder" v-model="mergeMessageFieldValue"/> + <template v-if="mergeMessageFieldValue !== mergeForm.defaultMergeMessage"> + <button @click.prevent="clearMergeMessage" class="btn gt-mt-2 gt-p-2 interact-fg" :data-tooltip-content="mergeForm.textClearMergeMessageHint"> + {{ mergeForm.textClearMergeMessage }} + </button> </template> - </button> + </div> + </template> - <button class="ui button merge-cancel" @click="toggleActionForm(false)"> - {{ mergeForm.textCancel }} - </button> + <div class="field" v-if="mergeStyle === 'manually-merged'"> + <input type="text" name="merge_commit_id" :placeholder="mergeForm.textMergeCommitId"> + </div> - <div class="ui checkbox gt-ml-2" v-if="mergeForm.isPullBranchDeletable && !autoMergeWhenSucceed"> - <input name="delete_branch_after_merge" type="checkbox" v-model="deleteBranchAfterMerge" id="delete-branch-after-merge"> - <label for="delete-branch-after-merge">{{ mergeForm.textDeleteBranch }}</label> - </div> - </form> - </div> + <button class="ui button" :class="mergeButtonStyleClass" type="submit" name="do" :value="mergeStyle"> + {{ mergeStyleDetail.textDoMerge }} + <template v-if="autoMergeWhenSucceed"> + {{ mergeForm.textAutoMergeButtonWhenSucceed }} + </template> + </button> + + <button class="ui button merge-cancel" @click="toggleActionForm(false)"> + {{ mergeForm.textCancel }} + </button> + + <div class="ui checkbox gt-ml-2" v-if="mergeForm.isPullBranchDeletable && !autoMergeWhenSucceed"> + <input name="delete_branch_after_merge" type="checkbox" v-model="deleteBranchAfterMerge" id="delete-branch-after-merge"> + <label for="delete-branch-after-merge">{{ mergeForm.textDeleteBranch }}</label> + </div> + </form> <div v-if="!showActionForm" class="gt-df"> <!-- the merge button --> |