Add button for issue deletion (#19032)
Co-authored-by: Norwin <noerw@users.noreply.github.com> Co-authored-by: 6543 <6543@obermui.de>
This commit is contained in:
parent
ddf7f1319f
commit
ea46142bce
|
@ -1374,6 +1374,9 @@ issues.lock.reason = Reason for locking
|
||||||
issues.lock.title = Lock conversation on this issue.
|
issues.lock.title = Lock conversation on this issue.
|
||||||
issues.unlock.title = Unlock conversation on this issue.
|
issues.unlock.title = Unlock conversation on this issue.
|
||||||
issues.comment_on_locked = You cannot comment on a locked issue.
|
issues.comment_on_locked = You cannot comment on a locked issue.
|
||||||
|
issues.delete = Delete
|
||||||
|
issues.delete.title = Delete this issue?
|
||||||
|
issues.delete.text = Do you really want to delete this issue? (This will permanently remove all content. Consider closing it instead, if you intend to keep it archived)
|
||||||
issues.tracker = Time Tracker
|
issues.tracker = Time Tracker
|
||||||
issues.start_tracking_short = Start Timer
|
issues.start_tracking_short = Start Timer
|
||||||
issues.start_tracking = Start Time Tracking
|
issues.start_tracking = Start Time Tracking
|
||||||
|
|
|
@ -852,6 +852,21 @@ func NewIssueChooseTemplate(ctx *context.Context) {
|
||||||
ctx.HTML(http.StatusOK, tplIssueChoose)
|
ctx.HTML(http.StatusOK, tplIssueChoose)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// DeleteIssue deletes an issue
|
||||||
|
func DeleteIssue(ctx *context.Context) {
|
||||||
|
issue := GetActionIssue(ctx)
|
||||||
|
if ctx.Written() {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := issue_service.DeleteIssue(ctx.User, ctx.Repo.GitRepo, issue); err != nil {
|
||||||
|
ctx.ServerError("DeleteIssueByID", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Redirect(fmt.Sprintf("%s/issues", ctx.Repo.Repository.HTMLURL()), http.StatusSeeOther)
|
||||||
|
}
|
||||||
|
|
||||||
// ValidateRepoMetas check and returns repository's meta information
|
// ValidateRepoMetas check and returns repository's meta information
|
||||||
func ValidateRepoMetas(ctx *context.Context, form forms.CreateIssueForm, isPull bool) ([]int64, []int64, int64, int64) {
|
func ValidateRepoMetas(ctx *context.Context, form forms.CreateIssueForm, isPull bool) ([]int64, []int64, int64, int64) {
|
||||||
var (
|
var (
|
||||||
|
|
|
@ -757,6 +757,7 @@ func RegisterRoutes(m *web.Route) {
|
||||||
m.Post("/reactions/{action}", bindIgnErr(forms.ReactionForm{}), repo.ChangeIssueReaction)
|
m.Post("/reactions/{action}", bindIgnErr(forms.ReactionForm{}), repo.ChangeIssueReaction)
|
||||||
m.Post("/lock", reqRepoIssueWriter, bindIgnErr(forms.IssueLockForm{}), repo.LockIssue)
|
m.Post("/lock", reqRepoIssueWriter, bindIgnErr(forms.IssueLockForm{}), repo.LockIssue)
|
||||||
m.Post("/unlock", reqRepoIssueWriter, repo.UnlockIssue)
|
m.Post("/unlock", reqRepoIssueWriter, repo.UnlockIssue)
|
||||||
|
m.Post("/delete", reqRepoAdmin, repo.DeleteIssue)
|
||||||
}, context.RepoMustNotBeArchived())
|
}, context.RepoMustNotBeArchived())
|
||||||
m.Group("/{index}", func() {
|
m.Group("/{index}", func() {
|
||||||
m.Get("/attachments", repo.GetIssueAttachments)
|
m.Get("/attachments", repo.GetIssueAttachments)
|
||||||
|
|
|
@ -645,6 +645,27 @@
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<button class="fluid ui show-modal button negative mt-3" data-modal="#delete">
|
||||||
|
{{svg "octicon-trash"}}
|
||||||
|
{{.i18n.Tr "repo.issues.delete"}}
|
||||||
|
</button>
|
||||||
|
<div class="ui basic modal" id="delete">
|
||||||
|
<div class="ui icon header">
|
||||||
|
{{.i18n.Tr "repo.issues.delete.title"}}
|
||||||
|
</div>
|
||||||
|
<div class="content center">
|
||||||
|
<p>
|
||||||
|
{{.i18n.Tr "repo.issues.delete.text"}}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<form action="{{.Issue.Link}}/delete" method="post">
|
||||||
|
{{.CsrfTokenHtml}}
|
||||||
|
<div class="center actions">
|
||||||
|
<div class="ui basic cancel inverted button">{{.i18n.Tr "settings.cancel"}}</div>
|
||||||
|
<button class="ui basic red inverted button">{{.i18n.Tr "modal.yes"}}</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue