You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

PullRequestMergeForm.vue 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <template>
  2. <div>
  3. <div class="ui form" v-if="showActionForm">
  4. <form :action="mergeForm.baseLink+'/merge'" method="post">
  5. <input type="hidden" name="_csrf" :value="csrfToken">
  6. <input type="hidden" name="head_commit_id" v-model="mergeForm.pullHeadCommitID">
  7. <template v-if="!mergeStyleDetail.hideMergeMessageTexts">
  8. <div class="field">
  9. <input type="text" name="merge_title_field" v-model="mergeTitleFieldValue">
  10. </div>
  11. <div class="field">
  12. <textarea name="merge_message_field" rows="5" :placeholder="mergeForm.mergeMessageFieldPlaceHolder" v-model="mergeMessageFieldValue"/>
  13. </div>
  14. </template>
  15. <button class="ui button" :class="[mergeForm.allOverridableChecksOk?'green':'red']" type="submit" name="do" :value="mergeStyle">
  16. {{ mergeStyleDetail.textDoMerge }}
  17. </button>
  18. <button class="ui button merge-cancel" @click="toggleActionForm(false)">
  19. {{ mergeForm.textCancel }}
  20. </button>
  21. <div class="ui checkbox ml-2" v-if="mergeForm.isPullBranchDeletable">
  22. <input name="delete_branch_after_merge" type="checkbox" v-model="deleteBranchAfterMerge" id="delete-branch-after-merge">
  23. <label for="delete-branch-after-merge">{{ mergeForm.textDeleteBranch }}</label>
  24. </div>
  25. </form>
  26. </div>
  27. <template v-if="!showActionForm">
  28. <div class="ui buttons merge-button" :class="[mergeForm.allOverridableChecksOk?'green':'red']" @click="toggleActionForm(true)">
  29. <button class="ui button">
  30. <svg-icon name="octicon-git-merge"/>
  31. <span class="button-text">{{ mergeStyleDetail.textDoMerge }}</span>
  32. </button>
  33. <div class="ui dropdown icon button no-text" @click.stop="showMergeStyleMenu = !showMergeStyleMenu" v-if="mergeStyleAllowedCount>1">
  34. <svg-icon name="octicon-triangle-down" :size="14"/>
  35. <div class="menu" :class="{'show':showMergeStyleMenu}">
  36. <template v-for="msd in mergeForm.mergeStyles">
  37. <div class="item" v-if="msd.allowed" :key="msd.name" @click.stop="mergeStyle=msd.name">
  38. {{ msd.textDoMerge }}
  39. </div>
  40. </template>
  41. </div>
  42. </div>
  43. </div>
  44. </template>
  45. </div>
  46. </template>
  47. <script>
  48. import {SvgIcon} from '../svg.js';
  49. const {csrfToken, pageData} = window.config;
  50. export default {
  51. name: 'PullRequestMergeForm',
  52. components: {
  53. SvgIcon,
  54. },
  55. data: () => ({
  56. csrfToken,
  57. mergeForm: pageData.pullRequestMergeForm,
  58. mergeTitleFieldValue: '',
  59. mergeMessageFieldValue: '',
  60. deleteBranchAfterMerge: false,
  61. mergeStyle: '',
  62. mergeStyleDetail: { // dummy only, these values will come from one of the mergeForm.mergeStyles
  63. hideMergeMessageTexts: false,
  64. textDoMerge: '',
  65. mergeTitleFieldText: '',
  66. mergeMessageFieldText: '',
  67. },
  68. mergeStyleAllowedCount: 0,
  69. showMergeStyleMenu: false,
  70. showActionForm: false,
  71. }),
  72. watch: {
  73. mergeStyle(val) {
  74. this.mergeStyleDetail = this.mergeForm.mergeStyles.find((e) => e.name === val);
  75. }
  76. },
  77. created() {
  78. this.mergeStyleAllowedCount = this.mergeForm.mergeStyles.reduce((v, msd) => v + (msd.allowed ? 1 : 0), 0);
  79. this.mergeStyle = this.mergeForm.mergeStyles.find((e) => e.allowed)?.name;
  80. },
  81. mounted() {
  82. document.addEventListener('mouseup', this.hideMergeStyleMenu);
  83. },
  84. unmounted() {
  85. document.removeEventListener('mouseup', this.hideMergeStyleMenu);
  86. },
  87. methods: {
  88. hideMergeStyleMenu() {
  89. this.showMergeStyleMenu = false;
  90. },
  91. toggleActionForm(show) {
  92. this.showActionForm = show;
  93. if (!show) return;
  94. this.deleteBranchAfterMerge = this.mergeForm.defaultDeleteBranchAfterMerge;
  95. this.mergeTitleFieldValue = this.mergeStyleDetail.mergeTitleFieldText;
  96. this.mergeMessageFieldValue = this.mergeStyleDetail.mergeMessageFieldText;
  97. }
  98. },
  99. };
  100. </script>
  101. <style scoped>
  102. /* to keep UI the same, at the moment we are still using some Fomantic UI styles, but we do not use their scripts, so we need to fine tune some styles */
  103. .ui.dropdown .menu.show {
  104. display: block;
  105. }
  106. .ui.checkbox label {
  107. cursor: pointer;
  108. }
  109. </style>