mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	New admin notice UI based on user list example
This commit is contained in:
		@@ -19,8 +19,10 @@ EXPLORE_PAGING_NUM = 20
 | 
			
		||||
ISSUE_PAGING_NUM = 10
 | 
			
		||||
 | 
			
		||||
[ui.admin]
 | 
			
		||||
; Numer of users that are showed in one page
 | 
			
		||||
; Number of users that are showed in one page
 | 
			
		||||
USER_PAGING_NUM = 50
 | 
			
		||||
; Number of notices that are showed in one page
 | 
			
		||||
NOTICE_PAGING_NUM = 50
 | 
			
		||||
 | 
			
		||||
[markdown]
 | 
			
		||||
; Enable hard line break extension
 | 
			
		||||
 
 | 
			
		||||
@@ -50,11 +50,10 @@ func CountNotices() int64 {
 | 
			
		||||
	return count
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// GetNotices returns given number of notices with offset.
 | 
			
		||||
func GetNotices(num, offset int) ([]*Notice, error) {
 | 
			
		||||
	notices := make([]*Notice, 0, num)
 | 
			
		||||
	err := x.Limit(num, offset).Desc("id").Find(¬ices)
 | 
			
		||||
	return notices, err
 | 
			
		||||
// Notices returns number of notices in given page.
 | 
			
		||||
func Notices(page, pageSize int) ([]*Notice, error) {
 | 
			
		||||
	notices := make([]*Notice, 0, pageSize)
 | 
			
		||||
	return notices, x.Limit(pageSize, (page-1)*pageSize).Desc("id").Find(¬ices)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// DeleteNotice deletes a system notice by given ID.
 | 
			
		||||
 
 | 
			
		||||
@@ -94,6 +94,7 @@ var (
 | 
			
		||||
	ExplorePagingNum   int
 | 
			
		||||
	IssuePagingNum     int
 | 
			
		||||
	AdminUserPagingNum int
 | 
			
		||||
	AdminNoticePagingNum int
 | 
			
		||||
 | 
			
		||||
	// Markdown sttings.
 | 
			
		||||
	Markdown struct {
 | 
			
		||||
@@ -370,6 +371,7 @@ func NewContext() {
 | 
			
		||||
 | 
			
		||||
	sec = Cfg.Section("ui.admin")
 | 
			
		||||
	AdminUserPagingNum = sec.Key("USER_PAGING_NUM").MustInt(50)
 | 
			
		||||
	AdminNoticePagingNum = sec.Key("NOTICE_PAGING_NUM").MustInt(50)
 | 
			
		||||
 | 
			
		||||
	sec = Cfg.Section("picture")
 | 
			
		||||
	PictureService = sec.Key("SERVICE").In("server", []string{"server"})
 | 
			
		||||
 
 | 
			
		||||
@@ -6,11 +6,13 @@ package admin
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/Unknwon/com"
 | 
			
		||||
        "github.com/Unknwon/paginater"
 | 
			
		||||
 | 
			
		||||
	"github.com/gogits/gogs/models"
 | 
			
		||||
	"github.com/gogits/gogs/modules/base"
 | 
			
		||||
	"github.com/gogits/gogs/modules/log"
 | 
			
		||||
	"github.com/gogits/gogs/modules/middleware"
 | 
			
		||||
	"github.com/gogits/gogs/modules/setting"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
@@ -22,15 +24,20 @@ func Notices(ctx *middleware.Context) {
 | 
			
		||||
	ctx.Data["PageIsAdmin"] = true
 | 
			
		||||
	ctx.Data["PageIsAdminNotices"] = true
 | 
			
		||||
 | 
			
		||||
	pageNum := 50
 | 
			
		||||
	p := pagination(ctx, models.CountNotices(), pageNum)
 | 
			
		||||
        total := models.CountNotices()
 | 
			
		||||
	page := ctx.QueryInt("page")
 | 
			
		||||
	if page <= 1 {
 | 
			
		||||
		page = 1
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Data["Page"] = paginater.New(int(total), setting.AdminNoticePagingNum, page, 5)
 | 
			
		||||
 
 | 
			
		||||
	notices, err := models.GetNotices(pageNum, (p-1)*pageNum)
 | 
			
		||||
        notices, err := models.Notices(page, setting.AdminNoticePagingNum)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "GetNotices", err)
 | 
			
		||||
		ctx.Handle(500, "Notices", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	ctx.Data["Notices"] = notices
 | 
			
		||||
	ctx.Data["Total"] = total
 | 
			
		||||
	ctx.HTML(200, NOTICES)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,23 +1,18 @@
 | 
			
		||||
{{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.notices.system_notice_list"}}</strong>
 | 
			
		||||
                            </div>
 | 
			
		||||
                            <div class="panel-body admin-panel">
 | 
			
		||||
                                <div class="admin-table">
 | 
			
		||||
					                <table class="table table-striped">
 | 
			
		||||
{{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.notices.system_notice_list"}}
 | 
			
		||||
        </h4>
 | 
			
		||||
        <div class="ui attached table segment">
 | 
			
		||||
          <table class="ui very basic striped table">
 | 
			
		||||
            <thead>
 | 
			
		||||
              <tr>
 | 
			
		||||
					                            <th>Id</th>
 | 
			
		||||
                <th>ID</th>
 | 
			
		||||
                <th>{{.i18n.Tr "admin.notices.type"}}</th>
 | 
			
		||||
                <th>{{.i18n.Tr "admin.notices.desc"}}</th>
 | 
			
		||||
                <th>{{.i18n.Tr "admin.users.created"}}</th>
 | 
			
		||||
@@ -29,26 +24,41 @@
 | 
			
		||||
               <tr>
 | 
			
		||||
		<td>{{.Id}}</td>
 | 
			
		||||
		<td>{{$.i18n.Tr .TrStr}}</td>
 | 
			
		||||
					                            <td class="grid-1-2"><span>{{.Description}}</span></td>
 | 
			
		||||
		<td><span>{{.Description}}</span></td>
 | 
			
		||||
		<td>{{.Created}}</td>
 | 
			
		||||
		<td><a href="{{AppSubUrl}}/admin/notices/{{.Id}}/delete"><i class="fa fa-trash-o text-red"></i></a></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/notices?p={{.LastPageNum}}">« {{.i18n.Tr "admin.prev"}}</a></li>{{end}}
 | 
			
		||||
					                    {{if .NextPageNum}}<li><a class="btn btn-medium btn-gray btn-radius" href="{{AppSubUrl}}/admin/notices?p={{.NextPageNum}}">» {{.i18n.Tr "admin.next"}}</a></li>{{end}}
 | 
			
		||||
					                </ul>
 | 
			
		||||
	</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>
 | 
			
		||||
                        </div>
 | 
			
		||||
                    </div>
 | 
			
		||||
                </div>
 | 
			
		||||
          {{end}}
 | 
			
		||||
	{{end}}
 | 
			
		||||
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</div>
 | 
			
		||||
{{template "ng/base/footer" .}}
 | 
			
		||||
{{template "base/footer" .}}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user