Improve the way how branches are deleted
Delete branch from HeadRepo instead of BaseRepo Prevent the deletion of a master branch Show a yes/no overlay when you press the delete branch buttonrelease/v1.15
parent
71634452e1
commit
71dee6b7c0
|
@ -591,7 +591,6 @@ pulls.cannot_auto_merge_desc = This pull request can't be merged automatically b
|
||||||
pulls.cannot_auto_merge_helper = Please merge manually in order to resolve the conflicts.
|
pulls.cannot_auto_merge_helper = Please merge manually in order to resolve the conflicts.
|
||||||
pulls.merge_pull_request = Merge Pull Request
|
pulls.merge_pull_request = Merge Pull Request
|
||||||
pulls.open_unmerged_pull_exists = `You can't perform reopen operation because there is already an open pull request (#%d) from same repository with same merge information and is waiting for merging.`
|
pulls.open_unmerged_pull_exists = `You can't perform reopen operation because there is already an open pull request (#%d) from same repository with same merge information and is waiting for merging.`
|
||||||
pulls.delete_branch = Delete Branch
|
|
||||||
|
|
||||||
milestones.new = New Milestone
|
milestones.new = New Milestone
|
||||||
milestones.open_tab = %d Open
|
milestones.open_tab = %d Open
|
||||||
|
@ -815,6 +814,14 @@ release.tag_name_already_exist = Release with this tag name already exists.
|
||||||
release.tag_name_invalid = Tag name is not valid.
|
release.tag_name_invalid = Tag name is not valid.
|
||||||
release.downloads = Downloads
|
release.downloads = Downloads
|
||||||
|
|
||||||
|
branch.delete = Delete Branch %s
|
||||||
|
branch.delete_desc = Once you delete a branch, there is no going back. Please be certain.
|
||||||
|
branch.delete_notices_1 = - This operation <strong>CANNOT</strong> be undone.
|
||||||
|
branch.delete_notices_2 = - This operation will permanently delete everything of branch %s.
|
||||||
|
branch.deletion_success = %s has been deleted successfully!
|
||||||
|
branch.deletion_failed = Failed to delete branch %s.
|
||||||
|
branch.delete_branch_has_new_commits = %s cannot be deleted because it has new commits after mergence.
|
||||||
|
|
||||||
[org]
|
[org]
|
||||||
org_name_holder = Organization Name
|
org_name_holder = Organization Name
|
||||||
org_full_name_holder = Organization Full Name
|
org_full_name_holder = Organization Full Name
|
||||||
|
|
|
@ -8,6 +8,7 @@ import (
|
||||||
"code.gitea.io/git"
|
"code.gitea.io/git"
|
||||||
"code.gitea.io/gitea/modules/base"
|
"code.gitea.io/gitea/modules/base"
|
||||||
"code.gitea.io/gitea/modules/context"
|
"code.gitea.io/gitea/modules/context"
|
||||||
|
"code.gitea.io/gitea/modules/log"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -35,17 +36,46 @@ func Branches(ctx *context.Context) {
|
||||||
// DeleteBranchPost responses for delete merged branch
|
// DeleteBranchPost responses for delete merged branch
|
||||||
func DeleteBranchPost(ctx *context.Context) {
|
func DeleteBranchPost(ctx *context.Context) {
|
||||||
branchName := ctx.Params(":name")
|
branchName := ctx.Params(":name")
|
||||||
|
commitID := ctx.Query("commit")
|
||||||
|
|
||||||
|
defer func() {
|
||||||
|
redirectTo := ctx.Query("redirect_to")
|
||||||
|
if len(redirectTo) == 0 {
|
||||||
|
redirectTo = ctx.Repo.RepoLink
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.JSON(200, map[string]interface{}{
|
||||||
|
"redirect": redirectTo,
|
||||||
|
})
|
||||||
|
}()
|
||||||
|
|
||||||
|
fullBranchName := ctx.Repo.Owner.Name + "/" + branchName
|
||||||
|
|
||||||
|
if !ctx.Repo.GitRepo.IsBranchExist(branchName) || branchName == "master" {
|
||||||
|
ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(commitID) > 0 {
|
||||||
|
branchCommitID, err := ctx.Repo.GitRepo.GetBranchCommitID(branchName)
|
||||||
|
if err != nil {
|
||||||
|
log.Error(4, "GetBranchCommitID: %v", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if branchCommitID != commitID {
|
||||||
|
ctx.Flash.Error(ctx.Tr("repo.branch.delete_branch_has_new_commits", fullBranchName))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if err := ctx.Repo.GitRepo.DeleteBranch(branchName, git.DeleteBranchOptions{
|
if err := ctx.Repo.GitRepo.DeleteBranch(branchName, git.DeleteBranchOptions{
|
||||||
Force: false,
|
Force: false,
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
ctx.Handle(500, "DeleteBranch", err)
|
log.Error(4, "DeleteBranch: %v", err)
|
||||||
|
ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
redirectTo := ctx.Query("redirect_to")
|
ctx.Flash.Success(ctx.Tr("repo.branch.deletion_success", fullBranchName))
|
||||||
if len(redirectTo) == 0 {
|
|
||||||
redirectTo = ctx.Repo.RepoLink
|
|
||||||
}
|
|
||||||
ctx.Redirect(redirectTo)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ import (
|
||||||
"github.com/Unknwon/com"
|
"github.com/Unknwon/com"
|
||||||
"github.com/Unknwon/paginater"
|
"github.com/Unknwon/paginater"
|
||||||
|
|
||||||
|
"code.gitea.io/git"
|
||||||
"code.gitea.io/gitea/models"
|
"code.gitea.io/gitea/models"
|
||||||
"code.gitea.io/gitea/modules/auth"
|
"code.gitea.io/gitea/modules/auth"
|
||||||
"code.gitea.io/gitea/modules/base"
|
"code.gitea.io/gitea/modules/base"
|
||||||
|
@ -182,7 +183,6 @@ func Issues(ctx *context.Context) {
|
||||||
pager := paginater.New(total, setting.UI.IssuePagingNum, page, 5)
|
pager := paginater.New(total, setting.UI.IssuePagingNum, page, 5)
|
||||||
ctx.Data["Page"] = pager
|
ctx.Data["Page"] = pager
|
||||||
|
|
||||||
|
|
||||||
var issues []*models.Issue
|
var issues []*models.Issue
|
||||||
if forceEmpty {
|
if forceEmpty {
|
||||||
issues = []*models.Issue{}
|
issues = []*models.Issue{}
|
||||||
|
@ -663,11 +663,21 @@ func ViewIssue(ctx *context.Context) {
|
||||||
|
|
||||||
if issue.IsPull {
|
if issue.IsPull {
|
||||||
pull := issue.PullRequest
|
pull := issue.PullRequest
|
||||||
ctx.Data["IsPullBranchDeletable"] = ctx.Repo.IsWriter() && ctx.Repo.GitRepo.IsBranchExist(pull.HeadBranch)
|
canDelete := false
|
||||||
|
|
||||||
deleteBranchURL := ctx.Repo.RepoLink + "/branches/" + pull.HeadBranch + "/delete"
|
if ctx.IsSigned && pull.HeadBranch != "master" {
|
||||||
queryParams := "?redirect_to=" + ctx.Data["Link"].(string)
|
|
||||||
ctx.Data["DeleteBranchLink"] = deleteBranchURL + queryParams
|
if err := pull.GetHeadRepo(); err != nil {
|
||||||
|
log.Error(4, "GetHeadRepo: %v", err)
|
||||||
|
} else if ctx.User.IsWriterOfRepo(pull.HeadRepo) {
|
||||||
|
canDelete = true
|
||||||
|
deleteBranchURL := pull.HeadRepo.Link() + "/branches/" + pull.HeadBranch + "/delete"
|
||||||
|
ctx.Data["DeleteBranchLink"] = fmt.Sprintf("%s?commit=%s&redirect_to=%s", deleteBranchURL, pull.MergedCommitID, ctx.Data["Link"])
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["IsPullBranchDeletable"] = canDelete && git.IsBranchExist(pull.HeadRepo.RepoPath(), pull.HeadBranch)
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.Data["Participants"] = participants
|
ctx.Data["Participants"] = participants
|
||||||
|
|
|
@ -166,10 +166,7 @@
|
||||||
{{if .IsPullBranchDeletable}}
|
{{if .IsPullBranchDeletable}}
|
||||||
<div class="ui divider"></div>
|
<div class="ui divider"></div>
|
||||||
<div>
|
<div>
|
||||||
<form class="ui form" action="{{.DeleteBranchLink}}" method="post">
|
<a class="delete-button ui red button" href="" data-url="{{.DeleteBranchLink}}">{{$.i18n.Tr "repo.branch.delete" .HeadTarget}}</a>
|
||||||
{{.CsrfTokenHtml}}
|
|
||||||
<button class="ui red button">{{$.i18n.Tr "repo.pulls.delete_branch"}}</button>
|
|
||||||
</form>
|
|
||||||
</div>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
{{else if .Issue.IsClosed}}
|
{{else if .Issue.IsClosed}}
|
||||||
|
@ -380,3 +377,16 @@
|
||||||
<div class="hide" id="no-content">
|
<div class="hide" id="no-content">
|
||||||
<span class="no-content">{{.i18n.Tr "repo.issues.no_content"}}</span>
|
<span class="no-content">{{.i18n.Tr "repo.issues.no_content"}}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="ui small basic delete modal">
|
||||||
|
<div class="ui icon header">
|
||||||
|
<i class="trash icon"></i>
|
||||||
|
{{.i18n.Tr "repo.branch.delete" .HeadTarget | Safe}}
|
||||||
|
</div>
|
||||||
|
<div class="content">
|
||||||
|
<p>{{.i18n.Tr "repo.branch.delete_desc" | Safe}}</p>
|
||||||
|
{{.i18n.Tr "repo.branch.delete_notices_1" | Safe}}<br>
|
||||||
|
{{.i18n.Tr "repo.branch.delete_notices_2" .HeadTarget | Safe}}<br>
|
||||||
|
</div>
|
||||||
|
{{template "base/delete_modal_actions" .}}
|
||||||
|
</div>
|
Loading…
Reference in New Issue