From 8e368e7065eff5708ed2d7de042fe701cf0764c2 Mon Sep 17 00:00:00 2001 From: Pedro Alves Date: Tue, 27 Oct 2020 07:12:01 +0000 Subject: [PATCH] [UI] Hide consecutive additions and removals of the same label (#13315) --- routers/repo/issue.go | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/routers/repo/issue.go b/routers/repo/issue.go index 1763b1c1a234..009af784e775 100644 --- a/routers/repo/issue.go +++ b/routers/repo/issue.go @@ -2418,11 +2418,34 @@ func combineLabelComments(issue *models.Issue) { c.AddedLabels[0] = c.Label } } else { + // Remove duplicated "added" and "removed" labels + // This way, adding and immediately removing a label won't generate a comment. + var appendingTo *[]*models.Label + var other *[]*models.Label + if removingCur { - prev.RemovedLabels = append(prev.RemovedLabels, c.Label) + appendingTo = &prev.RemovedLabels + other = &prev.AddedLabels } else { - prev.AddedLabels = append(prev.AddedLabels, c.Label) + appendingTo = &prev.AddedLabels + other = &prev.RemovedLabels } + + appending := true + + for i := 0; i < len(*other); i++ { + l := (*other)[i] + if l.ID == c.Label.ID { + *other = append((*other)[:i], (*other)[i+1:]...) + appending = false + break + } + } + + if appending { + *appendingTo = append(*appendingTo, c.Label) + } + prev.CreatedUnix = c.CreatedUnix issue.Comments = append(issue.Comments[:i], issue.Comments[i+1:]...) continue