feat: Add search bar on user profile page. (#787)
This commit is contained in:
parent
de81f68d4d
commit
a90a215662
6 changed files with 69 additions and 10 deletions
|
@ -1579,10 +1579,14 @@ func GetRepositoryByID(id int64) (*Repository, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetUserRepositories returns a list of repositories of given user.
|
// GetUserRepositories returns a list of repositories of given user.
|
||||||
func GetUserRepositories(userID int64, private bool, page, pageSize int) ([]*Repository, error) {
|
func GetUserRepositories(userID int64, private bool, page, pageSize int, orderBy string) ([]*Repository, error) {
|
||||||
|
if len(orderBy) == 0 {
|
||||||
|
orderBy = "updated_unix DESC"
|
||||||
|
}
|
||||||
|
|
||||||
sess := x.
|
sess := x.
|
||||||
Where("owner_id = ?", userID).
|
Where("owner_id = ?", userID).
|
||||||
Desc("updated_unix")
|
OrderBy(orderBy)
|
||||||
if !private {
|
if !private {
|
||||||
sess.And("is_private=?", false)
|
sess.And("is_private=?", false)
|
||||||
}
|
}
|
||||||
|
|
|
@ -491,7 +491,7 @@ func (u *User) GetOrganizationCount() (int64, error) {
|
||||||
|
|
||||||
// GetRepositories returns repositories that user owns, including private repositories.
|
// GetRepositories returns repositories that user owns, including private repositories.
|
||||||
func (u *User) GetRepositories(page, pageSize int) (err error) {
|
func (u *User) GetRepositories(page, pageSize int) (err error) {
|
||||||
u.Repos, err = GetUserRepositories(u.ID, true, page, pageSize)
|
u.Repos, err = GetUserRepositories(u.ID, true, page, pageSize, "")
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ func Search(ctx *context.APIContext) {
|
||||||
// ListMyRepos list all my repositories
|
// ListMyRepos list all my repositories
|
||||||
// see https://github.com/gogits/go-gogs-client/wiki/Repositories#list-your-repositories
|
// see https://github.com/gogits/go-gogs-client/wiki/Repositories#list-your-repositories
|
||||||
func ListMyRepos(ctx *context.APIContext) {
|
func ListMyRepos(ctx *context.APIContext) {
|
||||||
ownRepos, err := models.GetUserRepositories(ctx.User.ID, true, 1, ctx.User.NumRepos)
|
ownRepos, err := models.GetUserRepositories(ctx.User.ID, true, 1, ctx.User.NumRepos, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.Error(500, "GetRepositories", err)
|
ctx.Error(500, "GetRepositories", err)
|
||||||
return
|
return
|
||||||
|
|
|
@ -383,7 +383,7 @@ func showOrgProfile(ctx *context.Context) {
|
||||||
ctx.Data["Repos"] = repos
|
ctx.Data["Repos"] = repos
|
||||||
} else {
|
} else {
|
||||||
showPrivate := ctx.IsSigned && ctx.User.IsAdmin
|
showPrivate := ctx.IsSigned && ctx.User.IsAdmin
|
||||||
repos, err = models.GetUserRepositories(org.ID, showPrivate, page, setting.UI.User.RepoPagingNum)
|
repos, err = models.GetUserRepositories(org.ID, showPrivate, page, setting.UI.User.RepoPagingNum, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.Handle(500, "GetRepositories", err)
|
ctx.Handle(500, "GetRepositories", err)
|
||||||
return
|
return
|
||||||
|
|
|
@ -109,12 +109,66 @@ func Profile(ctx *context.Context) {
|
||||||
page = 1
|
page = 1
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.Data["Repos"], err = models.GetUserRepositories(ctxUser.ID, showPrivate, page, setting.UI.User.RepoPagingNum)
|
var (
|
||||||
|
repos []*models.Repository
|
||||||
|
count int64
|
||||||
|
err error
|
||||||
|
orderBy string
|
||||||
|
)
|
||||||
|
switch ctx.Query("sort") {
|
||||||
|
case "newest":
|
||||||
|
orderBy = "created_unix DESC"
|
||||||
|
case "oldest":
|
||||||
|
orderBy = "created_unix ASC"
|
||||||
|
case "recentupdate":
|
||||||
|
orderBy = "updated_unix DESC"
|
||||||
|
case "leastupdate":
|
||||||
|
orderBy = "updated_unix ASC"
|
||||||
|
case "reversealphabetically":
|
||||||
|
orderBy = "name DESC"
|
||||||
|
case "alphabetically":
|
||||||
|
orderBy = "name ASC"
|
||||||
|
default:
|
||||||
|
orderBy = "updated_unix DESC"
|
||||||
|
}
|
||||||
|
|
||||||
|
keyword := ctx.Query("q")
|
||||||
|
if len(keyword) == 0 {
|
||||||
|
repos, err = models.GetUserRepositories(ctxUser.ID, showPrivate, page, setting.UI.User.RepoPagingNum, orderBy)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.Handle(500, "GetRepositories", err)
|
ctx.Handle(500, "GetRepositories", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
ctx.Data["Repos"] = repos
|
||||||
ctx.Data["Page"] = paginater.New(ctxUser.NumRepos, setting.UI.User.RepoPagingNum, page, 5)
|
ctx.Data["Page"] = paginater.New(ctxUser.NumRepos, setting.UI.User.RepoPagingNum, page, 5)
|
||||||
|
ctx.Data["Total"] = ctxUser.NumRepos
|
||||||
|
} else {
|
||||||
|
repos, count, err = models.SearchRepositoryByName(&models.SearchRepoOptions{
|
||||||
|
Keyword: keyword,
|
||||||
|
OwnerID: ctxUser.ID,
|
||||||
|
OrderBy: orderBy,
|
||||||
|
Private: ctx.IsSigned && ctx.User.ID == ctxUser.ID,
|
||||||
|
Page: page,
|
||||||
|
PageSize: setting.UI.User.RepoPagingNum,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
ctx.Handle(500, "SearchRepositoryByName", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["Repos"] = repos
|
||||||
|
ctx.Data["Page"] = paginater.New(int(count), setting.UI.User.RepoPagingNum, page, 5)
|
||||||
|
ctx.Data["Total"] = count
|
||||||
|
}
|
||||||
|
|
||||||
|
// set default sort value.
|
||||||
|
if ctx.Query("sort") == "" {
|
||||||
|
ctx.Data["SortType"] = "recentupdate"
|
||||||
|
} else {
|
||||||
|
ctx.Data["SortType"] = ctx.Query("sort")
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx.Data["Keyword"] = keyword
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.HTML(200, tplProfile)
|
ctx.HTML(200, tplProfile)
|
||||||
|
|
|
@ -95,6 +95,7 @@
|
||||||
{{template "explore/repo_list" .}}
|
{{template "explore/repo_list" .}}
|
||||||
</div>
|
</div>
|
||||||
{{else}}
|
{{else}}
|
||||||
|
{{template "explore/search" .}}
|
||||||
{{template "explore/repo_list" .}}
|
{{template "explore/repo_list" .}}
|
||||||
{{template "base/paginate" .}}
|
{{template "base/paginate" .}}
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
Reference in a new issue