Fix admin repos new uitags/v1.21.12.1
| @@ -21,6 +21,8 @@ ISSUE_PAGING_NUM = 10 | |||||
| [ui.admin] | [ui.admin] | ||||
| ; Number of users that are showed in one page | ; Number of users that are showed in one page | ||||
| USER_PAGING_NUM = 50 | USER_PAGING_NUM = 50 | ||||
| ; Number of repos that are showed in one page | |||||
| REPO_PAGING_NUM = 50 | |||||
| ; Number of notices that are showed in one page | ; Number of notices that are showed in one page | ||||
| NOTICE_PAGING_NUM = 50 | NOTICE_PAGING_NUM = 50 | ||||
| ; Number of organization that are showed in one page | ; Number of organization that are showed in one page | ||||
| @@ -775,15 +775,13 @@ func CountRepositories() int64 { | |||||
| func CountPublicRepositories() int64 { | func CountPublicRepositories() int64 { | ||||
| return countRepositories(false) | return countRepositories(false) | ||||
| } | } | ||||
| // GetRepositoriesWithUsers returns given number of repository objects with offset. | |||||
| // It also auto-gets corresponding users. | |||||
| func GetRepositoriesWithUsers(num, offset int) ([]*Repository, error) { | |||||
| repos := make([]*Repository, 0, num) | |||||
| if err := x.Limit(num, offset).Asc("id").Find(&repos); err != nil { | |||||
| // RepositoriesWithUsers returns number of repos in given page. | |||||
| func RepositoriesWithUsers(page, pageSize int) ([]*Repository, error) { | |||||
| repos := make([]*Repository, 0, pageSize) | |||||
| if err := x.Limit(pageSize, (page-1)*pageSize).Asc("id").Find(&repos); err != nil { | |||||
| return nil, err | return nil, err | ||||
| } | } | ||||
| for _, repo := range repos { | for _, repo := range repos { | ||||
| repo.Owner = &User{Id: repo.OwnerID} | repo.Owner = &User{Id: repo.OwnerID} | ||||
| has, err := x.Get(repo.Owner) | has, err := x.Get(repo.Owner) | ||||
| @@ -795,6 +793,7 @@ func GetRepositoriesWithUsers(num, offset int) ([]*Repository, error) { | |||||
| } | } | ||||
| return repos, nil | return repos, nil | ||||
| } | } | ||||
| // RepoPath returns repository path by given user and repository name. | // RepoPath returns repository path by given user and repository name. | ||||
| @@ -94,6 +94,7 @@ var ( | |||||
| ExplorePagingNum int | ExplorePagingNum int | ||||
| IssuePagingNum int | IssuePagingNum int | ||||
| AdminUserPagingNum int | AdminUserPagingNum int | ||||
| AdminRepoPagingNum int | |||||
| AdminNoticePagingNum int | AdminNoticePagingNum int | ||||
| AdminOrgPagingNum int | AdminOrgPagingNum int | ||||
| @@ -372,6 +373,7 @@ func NewContext() { | |||||
| sec = Cfg.Section("ui.admin") | sec = Cfg.Section("ui.admin") | ||||
| AdminUserPagingNum = sec.Key("USER_PAGING_NUM").MustInt(50) | AdminUserPagingNum = sec.Key("USER_PAGING_NUM").MustInt(50) | ||||
| AdminRepoPagingNum = sec.Key("REPO_PAGING_NUM").MustInt(50) | |||||
| AdminNoticePagingNum = sec.Key("NOTICE_PAGING_NUM").MustInt(50) | AdminNoticePagingNum = sec.Key("NOTICE_PAGING_NUM").MustInt(50) | ||||
| AdminOrgPagingNum = sec.Key("ORG_PAGING_NUM").MustInt(50) | AdminOrgPagingNum = sec.Key("ORG_PAGING_NUM").MustInt(50) | ||||
| @@ -5,17 +5,20 @@ | |||||
| package admin | package admin | ||||
| import ( | import ( | ||||
| "github.com/Unknwon/paginater" | |||||
| "math" | "math" | ||||
| "github.com/gogits/gogs/models" | "github.com/gogits/gogs/models" | ||||
| "github.com/gogits/gogs/modules/base" | "github.com/gogits/gogs/modules/base" | ||||
| "github.com/gogits/gogs/modules/middleware" | "github.com/gogits/gogs/modules/middleware" | ||||
| "github.com/gogits/gogs/modules/setting" | |||||
| ) | ) | ||||
| const ( | const ( | ||||
| REPOS base.TplName = "admin/repo/list" | REPOS base.TplName = "admin/repo/list" | ||||
| ) | ) | ||||
| //* TODO Remove after general using of github.com/Unknwon/paginater | |||||
| func pagination(ctx *middleware.Context, count int64, pageNum int) int { | func pagination(ctx *middleware.Context, count int64, pageNum int) int { | ||||
| p := ctx.QueryInt("p") | p := ctx.QueryInt("p") | ||||
| if p < 1 { | if p < 1 { | ||||
| @@ -33,19 +36,28 @@ func pagination(ctx *middleware.Context, count int64, pageNum int) int { | |||||
| return p | return p | ||||
| } | } | ||||
| //*/ | |||||
| func Repositories(ctx *middleware.Context) { | func Repositories(ctx *middleware.Context) { | ||||
| ctx.Data["Title"] = ctx.Tr("admin.repositories") | ctx.Data["Title"] = ctx.Tr("admin.repositories") | ||||
| ctx.Data["PageIsAdmin"] = true | ctx.Data["PageIsAdmin"] = true | ||||
| ctx.Data["PageIsAdminRepositories"] = true | ctx.Data["PageIsAdminRepositories"] = true | ||||
| pageNum := 50 | |||||
| p := pagination(ctx, models.CountRepositories(), pageNum) | |||||
| total := models.CountRepositories() | |||||
| page := ctx.QueryInt("page") | |||||
| if page <= 1 { | |||||
| page = 1 | |||||
| } | |||||
| ctx.Data["Page"] = paginater.New(int(total), setting.AdminRepoPagingNum, page, 5) | |||||
| repos, err := models.RepositoriesWithUsers(page, setting.AdminRepoPagingNum) | |||||
| var err error | |||||
| ctx.Data["Repos"], err = models.GetRepositoriesWithUsers(pageNum, (p-1)*pageNum) | |||||
| if err != nil { | if err != nil { | ||||
| ctx.Handle(500, "GetRepositoriesWithUsers", err) | |||||
| ctx.Handle(500, "RepositoriesWithUsers", err) | |||||
| return | return | ||||
| } | } | ||||
| ctx.Data["Repos"] = repos | |||||
| ctx.Data["Total"] = total | |||||
| ctx.HTML(200, REPOS) | ctx.HTML(200, REPOS) | ||||
| } | } | ||||
| @@ -1,60 +1,70 @@ | |||||
| {{template "ng/base/head" .}} | |||||
| {{template "ng/base/header" .}} | |||||
| <div id="admin-wrapper"> | |||||
| <div id="setting-wrapper" class="main-wrapper"> | |||||
| <div id="admin-setting" class="container clear"> | |||||
| {{template "admin/nav" .}} | |||||
| <div class="grid-4-5 left"> | |||||
| <div class="setting-content"> | |||||
| {{template "ng/base/alert" .}} | |||||
| <div id="setting-content"> | |||||
| <div class="panel panel-radius"> | |||||
| <div class="panel-header"> | |||||
| <strong>{{.i18n.Tr "admin.repos.repo_manage_panel"}}</strong> | |||||
| </div> | |||||
| <div class="panel-body admin-panel"> | |||||
| <div class="admin-table"> | |||||
| <table class="table table-striped"> | |||||
| <thead> | |||||
| <tr> | |||||
| <th>ID</th> | |||||
| <th>{{.i18n.Tr "admin.repos.owner"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.name"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.private"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.watches"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.stars"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.issues"}}</th> | |||||
| <th>{{.i18n.Tr "admin.users.created"}}</th> | |||||
| </tr> | |||||
| </thead> | |||||
| <tbody> | |||||
| {{range .Repos}} | |||||
| <tr> | |||||
| <td>{{.ID}}</td> | |||||
| <td><a href="{{AppSubUrl}}/{{.Owner.Name}}">{{.Owner.Name}}</a></td> | |||||
| <td><a href="{{AppSubUrl}}/{{.Owner.Name}}/{{.Name}}">{{.Name}}</a></td> | |||||
| <td><i class="fa fa{{if .IsPrivate}}-check{{end}}-square-o"></i></td> | |||||
| <td>{{.NumWatches}}</td> | |||||
| <td>{{.NumStars}}</td> | |||||
| <td>{{.NumIssues}}</td> | |||||
| <td><span title="{{DateFmtLong .Created}}">{{DateFmtShort .Created}}</span></td> | |||||
| </tr> | |||||
| {{end}} | |||||
| </tbody> | |||||
| </table> | |||||
| {{if or .LastPageNum .NextPageNum}} | |||||
| <ul class="pagination"> | |||||
| {{if .LastPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{AppSubUrl}}/admin/repos?p={{.LastPageNum}}">« Prev.</a></li>{{end}} | |||||
| {{if .NextPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{AppSubUrl}}/admin/repos?p={{.NextPageNum}}">» Next</a></li>{{end}} | |||||
| </ul> | |||||
| {{end}} | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| </div> | |||||
| {{template "base/head" .}} | |||||
| <div class="admin user"> | |||||
| <div class="ui container"> | |||||
| <div class="ui grid"> | |||||
| {{template "admin/navbar" .}} | |||||
| <div class="twelve wide column content"> | |||||
| {{template "base/alert" .}} | |||||
| <h4 class="ui top attached header"> | |||||
| {{.i18n.Tr "admin.repos.repo_manage_panel"}} ({{.i18n.Tr "admin.total" .Total}}) | |||||
| </h4> | |||||
| <div class="ui attached table segment"> | |||||
| <table class="ui very basic striped table"> | |||||
| <thead> | |||||
| <tr> | |||||
| <th>ID</th> | |||||
| <th>{{.i18n.Tr "admin.repos.owner"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.name"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.private"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.watches"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.stars"}}</th> | |||||
| <th>{{.i18n.Tr "admin.repos.issues"}}</th> | |||||
| <th>{{.i18n.Tr "admin.users.created"}}</th> | |||||
| </tr> | |||||
| </thead> | |||||
| <tbody> | |||||
| {{range .Repos}} | |||||
| <tr> | |||||
| <td>{{.ID}}</td> | |||||
| <td><a href="{{AppSubUrl}}/{{.Owner.Name}}">{{.Owner.Name}}</a></td> | |||||
| <td><a href="{{AppSubUrl}}/{{.Owner.Name}}/{{.Name}}">{{.Name}}</a></td> | |||||
| <td><i class="fa fa{{if .IsPrivate}}-check{{end}}-square-o"></i></td> | |||||
| <td>{{.NumWatches}}</td> | |||||
| <td>{{.NumStars}}</td> | |||||
| <td>{{.NumIssues}}</td> | |||||
| <td><span title="{{DateFmtLong .Created}}">{{DateFmtShort .Created}}</span></td> | |||||
| </tr> | |||||
| {{end}} | |||||
| </tbody> | |||||
| </table> | |||||
| </div> | |||||
| {{with .Page}} | |||||
| {{if gt .TotalPages 1}} | |||||
| <div class="center page buttons"> | |||||
| <div class="ui borderless pagination menu"> | |||||
| <a class="{{if .IsFirst}}disabled{{end}} item" href="{{$.Link}}"><i class="angle double left icon"></i> {{$.i18n.Tr "admin.first_page"}}</a> | |||||
| <a class="{{if not .HasPrevious}}disabled{{end}} item" {{if .HasPrevious}}href="{{$.Link}}?page={{.Previous}}"{{end}}> | |||||
| <i class="left arrow icon"></i> {{$.i18n.Tr "repo.issues.previous"}} | |||||
| </a> | |||||
| {{range .Pages}} | |||||
| {{if eq .Num -1}} | |||||
| <a class="disabled item">...</a> | |||||
| {{else}} | |||||
| <a class="{{if .IsCurrent}}active{{end}} item" {{if not .IsCurrent}}href="{{$.Link}}?page={{.Num}}"{{end}}>{{.Num}}</a> | |||||
| {{end}} | |||||
| {{end}} | |||||
| <a class="{{if not .HasNext}}disabled{{end}} item" {{if .HasNext}}href="{{$.Link}}?page={{.Next}}"{{end}}> | |||||
| {{$.i18n.Tr "repo.issues.next"}} <i class="icon right arrow"></i> | |||||
| </a> | |||||
| <a class="{{if .IsLast}}disabled{{end}} item" href="{{$.Link}}?page={{.TotalPages}}">{{$.i18n.Tr "admin.last_page"}} <i class="angle double right icon"></i></a> | |||||
| </div> | |||||
| </div> | |||||
| {{end}} | |||||
| {{end}} | |||||
| </div> | |||||
| </div> | </div> | ||||
| </div> | |||||
| </div> | </div> | ||||
| {{template "ng/base/footer" .}} | |||||
| {{template "base/footer" .}} | |||||