1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- // Copyright 2023 The Gitea Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package issues
-
- import (
- "code.gitea.io/gitea/models/db"
- issues_model "code.gitea.io/gitea/models/issues"
- "code.gitea.io/gitea/modules/optional"
- )
-
- func ToSearchOptions(keyword string, opts *issues_model.IssuesOptions) *SearchOptions {
- searchOpt := &SearchOptions{
- Keyword: keyword,
- RepoIDs: opts.RepoIDs,
- AllPublic: opts.AllPublic,
- IsPull: opts.IsPull,
- IsClosed: opts.IsClosed,
- }
-
- if len(opts.LabelIDs) == 1 && opts.LabelIDs[0] == 0 {
- searchOpt.NoLabelOnly = true
- } else {
- for _, labelID := range opts.LabelIDs {
- if labelID > 0 {
- searchOpt.IncludedLabelIDs = append(searchOpt.IncludedLabelIDs, labelID)
- } else {
- searchOpt.ExcludedLabelIDs = append(searchOpt.ExcludedLabelIDs, -labelID)
- }
- }
- // opts.IncludedLabelNames and opts.ExcludedLabelNames are not supported here.
- // It's not a TO DO, it's just unnecessary.
- }
-
- if len(opts.MilestoneIDs) == 1 && opts.MilestoneIDs[0] == db.NoConditionID {
- searchOpt.MilestoneIDs = []int64{0}
- } else {
- searchOpt.MilestoneIDs = opts.MilestoneIDs
- }
-
- // See the comment of issues_model.SearchOptions for the reason why we need to convert
- convertID := func(id int64) optional.Option[int64] {
- if id > 0 {
- return optional.Some(id)
- }
- if id == db.NoConditionID {
- return optional.None[int64]()
- }
- return nil
- }
-
- searchOpt.ProjectID = convertID(opts.ProjectID)
- searchOpt.ProjectBoardID = convertID(opts.ProjectBoardID)
- searchOpt.PosterID = convertID(opts.PosterID)
- searchOpt.AssigneeID = convertID(opts.AssigneeID)
- searchOpt.MentionID = convertID(opts.MentionedID)
- searchOpt.ReviewedID = convertID(opts.ReviewedID)
- searchOpt.ReviewRequestedID = convertID(opts.ReviewRequestedID)
- searchOpt.SubscriberID = convertID(opts.SubscriberID)
-
- if opts.UpdatedAfterUnix > 0 {
- searchOpt.UpdatedAfterUnix = optional.Some(opts.UpdatedAfterUnix)
- }
- if opts.UpdatedBeforeUnix > 0 {
- searchOpt.UpdatedBeforeUnix = optional.Some(opts.UpdatedBeforeUnix)
- }
-
- searchOpt.Paginator = opts.Paginator
-
- switch opts.SortType {
- case "", "latest":
- searchOpt.SortBy = SortByCreatedDesc
- case "oldest":
- searchOpt.SortBy = SortByCreatedAsc
- case "recentupdate":
- searchOpt.SortBy = SortByUpdatedDesc
- case "leastupdate":
- searchOpt.SortBy = SortByUpdatedAsc
- case "mostcomment":
- searchOpt.SortBy = SortByCommentsDesc
- case "leastcomment":
- searchOpt.SortBy = SortByCommentsAsc
- case "nearduedate":
- searchOpt.SortBy = SortByDeadlineAsc
- case "farduedate":
- searchOpt.SortBy = SortByDeadlineDesc
- case "priority", "priorityrepo", "project-column-sorting":
- // Unsupported sort type for search
- fallthrough
- default:
- searchOpt.SortBy = SortByUpdatedDesc
- }
-
- return searchOpt
- }
|