mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-10 11:25:56 -05:00
894d9b2836
Since `modules/context` has to depend on `models` and many other packages, it should be moved from `modules/context` to `services/context` according to design principles. There is no logic code change on this PR, only move packages. - Move `code.gitea.io/gitea/modules/context` to `code.gitea.io/gitea/services/context` - Move `code.gitea.io/gitea/modules/contexttest` to `code.gitea.io/gitea/services/contexttest` because of depending on context - Move `code.gitea.io/gitea/modules/upload` to `code.gitea.io/gitea/services/context/upload` because of depending on context (cherry picked from commit 29f149bd9f517225a3c9f1ca3fb0a7b5325af696) Conflicts: routers/api/packages/alpine/alpine.go routers/api/v1/repo/issue_reaction.go routers/install/install.go routers/web/admin/config.go routers/web/passkey.go routers/web/repo/search.go routers/web/repo/setting/default_branch.go routers/web/user/home.go routers/web/user/profile.go tests/integration/editor_test.go tests/integration/integration_test.go tests/integration/mirror_push_test.go trivial context conflicts also modified all other occurrences in Forgejo specific files
104 lines
2.9 KiB
Go
104 lines
2.9 KiB
Go
// Copyright 2021 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package forms
|
|
|
|
import (
|
|
"math/big"
|
|
|
|
issues_model "code.gitea.io/gitea/models/issues"
|
|
"code.gitea.io/gitea/modules/log"
|
|
"code.gitea.io/gitea/services/context"
|
|
)
|
|
|
|
type hiddenCommentTypeGroupsType map[string][]issues_model.CommentType
|
|
|
|
// hiddenCommentTypeGroups maps the group names to comment types, these group names comes from the Web UI (appearance.tmpl)
|
|
var hiddenCommentTypeGroups = hiddenCommentTypeGroupsType{
|
|
"reference": {
|
|
/*3*/ issues_model.CommentTypeIssueRef,
|
|
/*4*/ issues_model.CommentTypeCommitRef,
|
|
/*5*/ issues_model.CommentTypeCommentRef,
|
|
/*6*/ issues_model.CommentTypePullRef,
|
|
},
|
|
"label": {
|
|
/*7*/ issues_model.CommentTypeLabel,
|
|
},
|
|
"milestone": {
|
|
/*8*/ issues_model.CommentTypeMilestone,
|
|
},
|
|
"assignee": {
|
|
/*9*/ issues_model.CommentTypeAssignees,
|
|
},
|
|
"title": {
|
|
/*10*/ issues_model.CommentTypeChangeTitle,
|
|
},
|
|
"branch": {
|
|
/*11*/ issues_model.CommentTypeDeleteBranch,
|
|
/*25*/ issues_model.CommentTypeChangeTargetBranch,
|
|
},
|
|
"time_tracking": {
|
|
/*12*/ issues_model.CommentTypeStartTracking,
|
|
/*13*/ issues_model.CommentTypeStopTracking,
|
|
/*14*/ issues_model.CommentTypeAddTimeManual,
|
|
/*15*/ issues_model.CommentTypeCancelTracking,
|
|
/*26*/ issues_model.CommentTypeDeleteTimeManual,
|
|
},
|
|
"deadline": {
|
|
/*16*/ issues_model.CommentTypeAddedDeadline,
|
|
/*17*/ issues_model.CommentTypeModifiedDeadline,
|
|
/*18*/ issues_model.CommentTypeRemovedDeadline,
|
|
},
|
|
"dependency": {
|
|
/*19*/ issues_model.CommentTypeAddDependency,
|
|
/*20*/ issues_model.CommentTypeRemoveDependency,
|
|
},
|
|
"lock": {
|
|
/*23*/ issues_model.CommentTypeLock,
|
|
/*24*/ issues_model.CommentTypeUnlock,
|
|
},
|
|
"review_request": {
|
|
/*27*/ issues_model.CommentTypeReviewRequest,
|
|
},
|
|
"pull_request_push": {
|
|
/*29*/ issues_model.CommentTypePullRequestPush,
|
|
},
|
|
"project": {
|
|
/*30*/ issues_model.CommentTypeProject,
|
|
/*31*/ issues_model.CommentTypeProjectBoard,
|
|
},
|
|
"issue_ref": {
|
|
/*33*/ issues_model.CommentTypeChangeIssueRef,
|
|
},
|
|
}
|
|
|
|
// UserHiddenCommentTypesFromRequest parse the form to hidden comment types bitset
|
|
func UserHiddenCommentTypesFromRequest(ctx *context.Context) *big.Int {
|
|
bitset := new(big.Int)
|
|
for group, commentTypes := range hiddenCommentTypeGroups {
|
|
if ctx.FormBool(group) {
|
|
for _, commentType := range commentTypes {
|
|
bitset = bitset.SetBit(bitset, int(commentType), 1)
|
|
}
|
|
}
|
|
}
|
|
return bitset
|
|
}
|
|
|
|
// IsUserHiddenCommentTypeGroupChecked check whether a hidden comment type group is "enabled" (checked on UI)
|
|
func IsUserHiddenCommentTypeGroupChecked(group string, hiddenCommentTypes *big.Int) (ret bool) {
|
|
commentTypes, ok := hiddenCommentTypeGroups[group]
|
|
if !ok {
|
|
log.Critical("the group map for hidden comment types is out of sync, unknown group: %v", group)
|
|
return false
|
|
}
|
|
if hiddenCommentTypes == nil {
|
|
return false
|
|
}
|
|
for _, commentType := range commentTypes {
|
|
if hiddenCommentTypes.Bit(int(commentType)) == 1 {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|