128 lines
4.1 KiB
Vue
128 lines
4.1 KiB
Vue
|
<template>
|
||
|
<div>
|
||
|
<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">
|
||
|
|
||
|
<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"/>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<button class="ui button" :class="[mergeForm.allOverridableChecksOk?'green':'red']" type="submit" name="do" :value="mergeStyle">
|
||
|
{{ mergeStyleDetail.textDoMerge }}
|
||
|
</button>
|
||
|
|
||
|
<button class="ui button merge-cancel" @click="toggleActionForm(false)">
|
||
|
{{ mergeForm.textCancel }}
|
||
|
</button>
|
||
|
|
||
|
<div class="ui checkbox ml-2" v-if="mergeForm.isPullBranchDeletable">
|
||
|
<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>
|
||
|
|
||
|
<template v-if="!showActionForm">
|
||
|
<div class="ui buttons merge-button" :class="[mergeForm.allOverridableChecksOk?'green':'red']" @click="toggleActionForm(true)">
|
||
|
<button class="ui button">
|
||
|
<svg-icon name="octicon-git-merge"/>
|
||
|
<span class="button-text">{{ mergeStyleDetail.textDoMerge }}</span>
|
||
|
</button>
|
||
|
<div class="ui dropdown icon button no-text" @click.stop="showMergeStyleMenu = !showMergeStyleMenu" v-if="mergeStyleAllowedCount>1">
|
||
|
<svg-icon name="octicon-triangle-down" :size="14"/>
|
||
|
<div class="menu" :class="{'show':showMergeStyleMenu}">
|
||
|
<template v-for="msd in mergeForm.mergeStyles">
|
||
|
<div class="item" v-if="msd.allowed" :key="msd.name" @click.stop="mergeStyle=msd.name">
|
||
|
{{ msd.textDoMerge }}
|
||
|
</div>
|
||
|
</template>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import {SvgIcon} from '../svg.js';
|
||
|
|
||
|
const {csrfToken, pageData} = window.config;
|
||
|
|
||
|
export default {
|
||
|
name: 'PullRequestMergeForm',
|
||
|
components: {
|
||
|
SvgIcon,
|
||
|
},
|
||
|
|
||
|
data: () => ({
|
||
|
csrfToken,
|
||
|
mergeForm: pageData.pullRequestMergeForm,
|
||
|
|
||
|
mergeTitleFieldValue: '',
|
||
|
mergeMessageFieldValue: '',
|
||
|
deleteBranchAfterMerge: false,
|
||
|
|
||
|
mergeStyle: '',
|
||
|
mergeStyleDetail: { // dummy only, these values will come from one of the mergeForm.mergeStyles
|
||
|
hideMergeMessageTexts: false,
|
||
|
textDoMerge: '',
|
||
|
mergeTitleFieldText: '',
|
||
|
mergeMessageFieldText: '',
|
||
|
},
|
||
|
mergeStyleAllowedCount: 0,
|
||
|
|
||
|
showMergeStyleMenu: false,
|
||
|
showActionForm: false,
|
||
|
}),
|
||
|
|
||
|
watch: {
|
||
|
mergeStyle(val) {
|
||
|
this.mergeStyleDetail = this.mergeForm.mergeStyles.find((e) => e.name === val);
|
||
|
}
|
||
|
},
|
||
|
|
||
|
created() {
|
||
|
this.mergeStyleAllowedCount = this.mergeForm.mergeStyles.reduce((v, msd) => v + (msd.allowed ? 1 : 0), 0);
|
||
|
this.mergeStyle = this.mergeForm.mergeStyles.find((e) => e.allowed)?.name;
|
||
|
},
|
||
|
|
||
|
mounted() {
|
||
|
document.addEventListener('mouseup', this.hideMergeStyleMenu);
|
||
|
},
|
||
|
|
||
|
unmounted() {
|
||
|
document.removeEventListener('mouseup', this.hideMergeStyleMenu);
|
||
|
},
|
||
|
|
||
|
methods: {
|
||
|
hideMergeStyleMenu() {
|
||
|
this.showMergeStyleMenu = false;
|
||
|
},
|
||
|
toggleActionForm(show) {
|
||
|
this.showActionForm = show;
|
||
|
if (!show) return;
|
||
|
this.deleteBranchAfterMerge = this.mergeForm.defaultDeleteBranchAfterMerge;
|
||
|
this.mergeTitleFieldValue = this.mergeStyleDetail.mergeTitleFieldText;
|
||
|
this.mergeMessageFieldValue = this.mergeStyleDetail.mergeMessageFieldText;
|
||
|
}
|
||
|
},
|
||
|
};
|
||
|
</script>
|
||
|
|
||
|
<style scoped>
|
||
|
/* 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 */
|
||
|
.ui.dropdown .menu.show {
|
||
|
display: block;
|
||
|
}
|
||
|
.ui.checkbox label {
|
||
|
cursor: pointer;
|
||
|
}
|
||
|
</style>
|