mirror of
https://github.com/go-gitea/gitea
synced 2025-01-21 23:24:29 +00:00
new admin user list UI
This commit is contained in:
parent
247017d9ff
commit
be89802bd8
@ -18,6 +18,10 @@ EXPLORE_PAGING_NUM = 20
|
|||||||
; Number of issues that are showed in one page
|
; Number of issues that are showed in one page
|
||||||
ISSUE_PAGING_NUM = 10
|
ISSUE_PAGING_NUM = 10
|
||||||
|
|
||||||
|
[ui.admin]
|
||||||
|
; Numer of users that are showed in one page
|
||||||
|
USER_PAGING_NUM = 50
|
||||||
|
|
||||||
[markdown]
|
[markdown]
|
||||||
; Enable hard line break extension
|
; Enable hard line break extension
|
||||||
ENABLE_HARD_LINE_BREAK = false
|
ENABLE_HARD_LINE_BREAK = false
|
||||||
|
@ -716,8 +716,8 @@ authentication = Authentications
|
|||||||
config = Configuration
|
config = Configuration
|
||||||
notices = System Notices
|
notices = System Notices
|
||||||
monitor = Monitoring
|
monitor = Monitoring
|
||||||
prev = Prev.
|
first_page = First
|
||||||
next = Next
|
last_page = Last
|
||||||
total = Total: %d
|
total = Total: %d
|
||||||
|
|
||||||
dashboard.statistic = Statistic
|
dashboard.statistic = Statistic
|
||||||
|
@ -432,11 +432,10 @@ func CountUsers() int64 {
|
|||||||
return countUsers(x)
|
return countUsers(x)
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetUsers returns given number of user objects with offset.
|
// Users returns number of users in given page.
|
||||||
func GetUsers(num, offset int) ([]*User, error) {
|
func Users(page, pageSize int) ([]*User, error) {
|
||||||
users := make([]*User, 0, num)
|
users := make([]*User, 0, pageSize)
|
||||||
err := x.Limit(num, offset).Where("type=0").Asc("id").Find(&users)
|
return users, x.Limit(pageSize, (page-1)*pageSize).Where("type=0").Asc("id").Find(&users)
|
||||||
return users, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// get user by erify code
|
// get user by erify code
|
||||||
|
File diff suppressed because one or more lines are too long
@ -91,8 +91,9 @@ var (
|
|||||||
AnsiCharset string
|
AnsiCharset string
|
||||||
|
|
||||||
// UI settings.
|
// UI settings.
|
||||||
ExplorePagingNum int
|
ExplorePagingNum int
|
||||||
IssuePagingNum int
|
IssuePagingNum int
|
||||||
|
AdminUserPagingNum int
|
||||||
|
|
||||||
// Markdown sttings.
|
// Markdown sttings.
|
||||||
Markdown struct {
|
Markdown struct {
|
||||||
@ -367,6 +368,9 @@ func NewConfigContext() {
|
|||||||
ExplorePagingNum = sec.Key("EXPLORE_PAGING_NUM").MustInt(20)
|
ExplorePagingNum = sec.Key("EXPLORE_PAGING_NUM").MustInt(20)
|
||||||
IssuePagingNum = sec.Key("ISSUE_PAGING_NUM").MustInt(10)
|
IssuePagingNum = sec.Key("ISSUE_PAGING_NUM").MustInt(10)
|
||||||
|
|
||||||
|
sec = Cfg.Section("ui.admin")
|
||||||
|
AdminUserPagingNum = sec.Key("USER_PAGING_NUM").MustInt(50)
|
||||||
|
|
||||||
sec = Cfg.Section("picture")
|
sec = Cfg.Section("picture")
|
||||||
PictureService = sec.Key("SERVICE").In("server", []string{"server"})
|
PictureService = sec.Key("SERVICE").In("server", []string{"server"})
|
||||||
AvatarUploadPath = sec.Key("AVATAR_UPLOAD_PATH").MustString("data/avatars")
|
AvatarUploadPath = sec.Key("AVATAR_UPLOAD_PATH").MustString("data/avatars")
|
||||||
|
@ -9,6 +9,7 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/Unknwon/com"
|
"github.com/Unknwon/com"
|
||||||
|
"github.com/Unknwon/paginater"
|
||||||
|
|
||||||
"github.com/gogits/gogs/models"
|
"github.com/gogits/gogs/models"
|
||||||
"github.com/gogits/gogs/modules/auth"
|
"github.com/gogits/gogs/modules/auth"
|
||||||
@ -46,15 +47,21 @@ func Users(ctx *middleware.Context) {
|
|||||||
ctx.Data["PageIsAdmin"] = true
|
ctx.Data["PageIsAdmin"] = true
|
||||||
ctx.Data["PageIsAdminUsers"] = true
|
ctx.Data["PageIsAdminUsers"] = true
|
||||||
|
|
||||||
pageNum := 50
|
total := models.CountUsers()
|
||||||
p := pagination(ctx, models.CountUsers(), pageNum)
|
page := ctx.QueryInt("page")
|
||||||
|
if page <= 1 {
|
||||||
|
page = 1
|
||||||
|
}
|
||||||
|
ctx.Data["Page"] = paginater.New(int(total), setting.AdminUserPagingNum, page, 5)
|
||||||
|
|
||||||
users, err := models.GetUsers(pageNum, (p-1)*pageNum)
|
users, err := models.Users(page, setting.AdminUserPagingNum)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.Handle(500, "GetUsers", err)
|
ctx.Handle(500, "Users", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.Data["Users"] = users
|
ctx.Data["Users"] = users
|
||||||
|
|
||||||
|
ctx.Data["Total"] = total
|
||||||
ctx.HTML(200, USERS)
|
ctx.HTML(200, USERS)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,61 +1,72 @@
|
|||||||
{{template "ng/base/head" .}}
|
{{template "base/head" .}}
|
||||||
{{template "ng/base/header" .}}
|
<div class="admin user">
|
||||||
<div id="admin-wrapper">
|
<div class="ui container">
|
||||||
<div id="setting-wrapper" class="main-wrapper">
|
<div class="ui grid">
|
||||||
<div id="admin-setting" class="container clear">
|
{{template "admin/navbar" .}}
|
||||||
{{template "admin/nav" .}}
|
<div class="twelve wide column content">
|
||||||
<div class="grid-4-5 left">
|
{{template "base/alert" .}}
|
||||||
<div class="setting-content">
|
<h4 class="ui top attached header">
|
||||||
{{template "ng/base/alert" .}}
|
{{.i18n.Tr "admin.users.user_manage_panel"}} ({{.i18n.Tr "admin.total" .Total}})
|
||||||
<div id="setting-content">
|
<div class="ui right">
|
||||||
<div class="panel panel-radius">
|
<a class="ui blue tiny button" href="{{AppSubUrl}}/admin/users/new">{{.i18n.Tr "admin.users.new_account"}}</a>
|
||||||
<div class="panel-header">
|
</div>
|
||||||
<strong>{{.i18n.Tr "admin.users.user_manage_panel"}}</strong>
|
</h4>
|
||||||
</div>
|
<div class="ui attached table segment">
|
||||||
<div class="panel-body admin-panel">
|
<table class="ui very basic striped table">
|
||||||
<a class="btn-blue btn-medium btn-link btn-radius" href="{{AppSubUrl}}/admin/users/new">{{.i18n.Tr "admin.users.new_account"}}</a>
|
<thead>
|
||||||
<div class="admin-table">
|
<tr>
|
||||||
<table class="table table-striped">
|
<th>ID</th>
|
||||||
<thead>
|
<th>{{.i18n.Tr "admin.users.name"}}</th>
|
||||||
<tr>
|
<th>{{.i18n.Tr "email"}}</th>
|
||||||
<th>Id</th>
|
<th>{{.i18n.Tr "admin.users.activated"}}</th>
|
||||||
<th>{{.i18n.Tr "admin.users.name"}}</th>
|
<th>{{.i18n.Tr "admin.users.admin"}}</th>
|
||||||
<th>{{.i18n.Tr "email"}}</th>
|
<th>{{.i18n.Tr "admin.users.repos"}}</th>
|
||||||
<th>{{.i18n.Tr "admin.users.activated"}}</th>
|
<th>{{.i18n.Tr "admin.users.created"}}</th>
|
||||||
<th>{{.i18n.Tr "admin.users.admin"}}</th>
|
<th>{{.i18n.Tr "admin.users.edit"}}</th>
|
||||||
<th>{{.i18n.Tr "admin.users.repos"}}</th>
|
</tr>
|
||||||
<th>{{.i18n.Tr "admin.users.created"}}</th>
|
</thead>
|
||||||
<th>{{.i18n.Tr "admin.users.edit"}}</th>
|
<tbody>
|
||||||
</tr>
|
{{range .Users}}
|
||||||
</thead>
|
<tr>
|
||||||
<tbody>
|
<td>{{.Id}}</td>
|
||||||
{{range .Users}}
|
<td><a href="{{AppSubUrl}}/{{.Name}}">{{.Name}}</a></td>
|
||||||
<tr>
|
<td>{{.Email}}</td>
|
||||||
<td>{{.Id}}</td>
|
<td><i class="fa fa{{if .IsActive}}-check{{end}}-square-o"></i></td>
|
||||||
<td><a href="{{AppSubUrl}}/{{.Name}}">{{.Name}}</a></td>
|
<td><i class="fa fa{{if .IsAdmin}}-check{{end}}-square-o"></i></td>
|
||||||
<td>{{.Email}}</td>
|
<td>{{.NumRepos}}</td>
|
||||||
<td><i class="fa fa{{if .IsActive}}-check{{end}}-square-o"></i></td>
|
<td><span title="{{DateFmtLong .Created}}">{{DateFmtShort .Created }}</span></td>
|
||||||
<td><i class="fa fa{{if .IsAdmin}}-check{{end}}-square-o"></i></td>
|
<td><a href="{{AppSubUrl}}/admin/users/{{.Id}}"><i class="fa fa-pencil-square-o"></i></a></td>
|
||||||
<td>{{.NumRepos}}</td>
|
</tr>
|
||||||
<td><span title="{{DateFmtLong .Created}}">{{DateFmtShort .Created }}</span></td>
|
{{end}}
|
||||||
<td><a href="{{AppSubUrl}}/admin/users/{{.Id}}"><i class="fa fa-pencil-square-o"></i></a></td>
|
</tbody>
|
||||||
</tr>
|
</table>
|
||||||
{{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/users?p={{.LastPageNum}}">« {{.i18n.Tr "admin.prev"}}</a></li>{{end}}
|
|
||||||
{{if .NextPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{AppSubUrl}}/admin/users?p={{.NextPageNum}}">» {{.i18n.Tr "admin.next"}}</a></li>{{end}}
|
|
||||||
</ul>
|
|
||||||
{{end}}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</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" .}}
|
Loading…
x
Reference in New Issue
Block a user