diff options
author | Gusted <williamzijl7@hotmail.com> | 2021-11-19 09:54:31 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-19 17:54:31 +0800 |
commit | 381e131fc8d1a3d93002dfbbf853d9d4aab2c547 (patch) | |
tree | 941bd7b8682d7fc9d1818a786ec507ac54206ec2 | |
parent | 00448ebe9184ccfe9e2fd7f48f9b266ae91d6415 (diff) | |
download | gitea-381e131fc8d1a3d93002dfbbf853d9d4aab2c547.tar.gz gitea-381e131fc8d1a3d93002dfbbf853d9d4aab2c547.zip |
Added comment for changing issue ref (#17672)
* Added comment for changing issue ref
- Add a comment when someone changes the ref(erence?) of a issue.
-rw-r--r-- | models/issue.go | 18 | ||||
-rw-r--r-- | models/issue_comment.go | 4 | ||||
-rw-r--r-- | options/locale/locale_en-US.ini | 3 | ||||
-rw-r--r-- | templates/repo/issue/view_content/comments.tmpl | 17 |
4 files changed, 41 insertions, 1 deletions
diff --git a/models/issue.go b/models/issue.go index 288163707a..ef31f416ad 100644 --- a/models/issue.go +++ b/models/issue.go @@ -753,6 +753,24 @@ func (issue *Issue) ChangeRef(doer *User, oldRef string) (err error) { return fmt.Errorf("updateIssueCols: %v", err) } + if err = issue.loadRepo(db.GetEngine(ctx)); err != nil { + return fmt.Errorf("loadRepo: %v", err) + } + oldRefFriendly := strings.TrimPrefix(oldRef, "refs/heads/") + newRefFriendly := strings.TrimPrefix(issue.Ref, "refs/heads/") + + opts := &CreateCommentOptions{ + Type: CommentTypeChangeIssueRef, + Doer: doer, + Repo: issue.Repo, + Issue: issue, + OldRef: oldRefFriendly, + NewRef: newRefFriendly, + } + if _, err = createComment(db.GetEngine(ctx), opts); err != nil { + return fmt.Errorf("createComment: %v", err) + } + return committer.Commit() } diff --git a/models/issue_comment.go b/models/issue_comment.go index a41f4cb298..1936695732 100644 --- a/models/issue_comment.go +++ b/models/issue_comment.go @@ -101,8 +101,10 @@ const ( CommentTypeProject // 31 Project board changed CommentTypeProjectBoard - // Dismiss Review + // 32 Dismiss Review CommentTypeDismissReview + // 33 Change issue ref + CommentTypeChangeIssueRef ) // RoleDescriptor defines comment tag type diff --git a/options/locale/locale_en-US.ini b/options/locale/locale_en-US.ini index 66996b2014..21e2bd1be4 100644 --- a/options/locale/locale_en-US.ini +++ b/options/locale/locale_en-US.ini @@ -1173,6 +1173,9 @@ issues.add_assignee_at = `was assigned by <b>%s</b> %s` issues.remove_assignee_at = `was unassigned by <b>%s</b> %s` issues.remove_self_assignment = `removed their assignment %s` issues.change_title_at = `changed title from <b><strike>%s</strike></b> to <b>%s</b> %s` +issues.change_ref_at = `changed reference from <b><strike>%s</strike></b> to <b>%s</b> %s` +issues.remove_ref_at = `removed reference <b>%s</b> %s` +issues.add_ref_at = `added reference <b>%s</b> %s` issues.delete_branch_at = `deleted branch <b>%s</b> %s` issues.open_tab = %d Open issues.close_tab = %d Closed diff --git a/templates/repo/issue/view_content/comments.tmpl b/templates/repo/issue/view_content/comments.tmpl index 9907246d9f..77925d8e29 100644 --- a/templates/repo/issue/view_content/comments.tmpl +++ b/templates/repo/issue/view_content/comments.tmpl @@ -781,5 +781,22 @@ </div> {{end}} </div> + {{else if eq .Type 33}} + <div class="timeline-item event" id="{{.HashTag}}"> + <span class="badge">{{svg "octicon-git-branch"}}</span> + <a href="{{.Poster.HomeLink}}"> + {{avatar .Poster}} + </a> + <span class="text grey"> + <a class="author" href="{{.Poster.HomeLink}}">{{.Poster.GetDisplayName}}</a> + {{if and .OldRef .NewRef}} + {{$.i18n.Tr "repo.issues.change_ref_at" (.OldRef|Escape) (.NewRef|Escape) $createdStr | Safe}} + {{else if .OldRef}} + {{$.i18n.Tr "repo.issues.remove_ref_at" (.OldRef|Escape) $createdStr | Safe}} + {{else}} + {{$.i18n.Tr "repo.issues.add_ref_at" (.NewRef|Escape) $createdStr | Safe}} + {{end}} + </span> + </div> {{end}} {{end}} |