mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 03:18:24 +00:00 
			
		
		
		
	This PR changes the `opts` argument in `SearchUsers()` to be passed by value instead of by pointer, as its mutations do not escape the function scope and are not used elsewhere. This simplifies reasoning about the function and avoids unnecessary pointer usage. This insight emerged during an initial attempt to refactor `RenderUserSearch()`, which currently intermixes multiple concerns. Co-authored-by: Philip Peterson <philip-peterson@users.noreply.github.com>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2021 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package explore
 | |
| 
 | |
| import (
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/modules/container"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	"code.gitea.io/gitea/modules/structs"
 | |
| 	"code.gitea.io/gitea/modules/util"
 | |
| 	"code.gitea.io/gitea/services/context"
 | |
| )
 | |
| 
 | |
| // Organizations render explore organizations page
 | |
| func Organizations(ctx *context.Context) {
 | |
| 	if setting.Service.Explore.DisableOrganizationsPage {
 | |
| 		ctx.Redirect(setting.AppSubURL + "/explore")
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	ctx.Data["UsersPageIsDisabled"] = setting.Service.Explore.DisableUsersPage
 | |
| 	ctx.Data["CodePageIsDisabled"] = setting.Service.Explore.DisableCodePage
 | |
| 	ctx.Data["Title"] = ctx.Tr("explore")
 | |
| 	ctx.Data["PageIsExplore"] = true
 | |
| 	ctx.Data["PageIsExploreOrganizations"] = true
 | |
| 	ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
 | |
| 
 | |
| 	visibleTypes := []structs.VisibleType{structs.VisibleTypePublic}
 | |
| 	if ctx.Doer != nil {
 | |
| 		visibleTypes = append(visibleTypes, structs.VisibleTypeLimited, structs.VisibleTypePrivate)
 | |
| 	}
 | |
| 
 | |
| 	supportedSortOrders := container.SetOf(
 | |
| 		"newest",
 | |
| 		"oldest",
 | |
| 		"alphabetically",
 | |
| 		"reversealphabetically",
 | |
| 	)
 | |
| 	sortOrder := ctx.FormString("sort")
 | |
| 	if sortOrder == "" {
 | |
| 		sortOrder = util.Iif(supportedSortOrders.Contains(setting.UI.ExploreDefaultSort), setting.UI.ExploreDefaultSort, "newest")
 | |
| 		ctx.SetFormString("sort", sortOrder)
 | |
| 	}
 | |
| 
 | |
| 	RenderUserSearch(ctx, user_model.SearchUserOptions{
 | |
| 		Actor:       ctx.Doer,
 | |
| 		Type:        user_model.UserTypeOrganization,
 | |
| 		ListOptions: db.ListOptions{PageSize: setting.UI.ExplorePagingNum},
 | |
| 		Visible:     visibleTypes,
 | |
| 
 | |
| 		SupportedSortOrders: supportedSortOrders,
 | |
| 	}, tplExploreUsers)
 | |
| }
 |