Added user registrations page
This commit is contained in:
parent
b49496fe16
commit
802273b7c3
@ -2,6 +2,7 @@ component AdminTabs
|
||||
.tabs
|
||||
Tab("Server", "server", "/admin")
|
||||
Tab("WebDev", "html5", "/admin/webdev")
|
||||
Tab("Registrations", "user-plus", "/admin/registrations")
|
||||
Tab("Purchases", "shopping-cart", "/admin/purchases")
|
||||
|
||||
.corner-buttons
|
||||
|
56
pages/admin/registrations.go
Normal file
56
pages/admin/registrations.go
Normal file
@ -0,0 +1,56 @@
|
||||
package admin
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"sort"
|
||||
|
||||
"github.com/aerogo/aero"
|
||||
"github.com/animenotifier/arn"
|
||||
"github.com/animenotifier/notify.moe/components"
|
||||
"github.com/animenotifier/notify.moe/utils"
|
||||
"github.com/fatih/color"
|
||||
)
|
||||
|
||||
// UserRegistrations ...
|
||||
func UserRegistrations(ctx *aero.Context) string {
|
||||
user := utils.GetUser(ctx)
|
||||
|
||||
if user == nil {
|
||||
return ctx.Error(http.StatusUnauthorized, "Not logged in", nil)
|
||||
}
|
||||
|
||||
if user.Role != "admin" {
|
||||
return ctx.Error(http.StatusUnauthorized, "Not authorized", nil)
|
||||
}
|
||||
|
||||
yearInfo := map[int]utils.YearRegistrations{}
|
||||
years := []int{}
|
||||
|
||||
for user := range arn.StreamUsers() {
|
||||
if user.Registered == "" {
|
||||
color.Red("%s %s", user.ID, user.Nick)
|
||||
user.Registered = user.LastLogin
|
||||
user.Save()
|
||||
}
|
||||
|
||||
registered := user.RegisteredTime()
|
||||
year := registered.Year()
|
||||
yearRegistrations := yearInfo[year]
|
||||
yearRegistrations.Total++
|
||||
|
||||
if yearRegistrations.Months == nil {
|
||||
yearRegistrations.Months = map[int]int{}
|
||||
}
|
||||
|
||||
yearRegistrations.Months[int(registered.Month())]++
|
||||
yearInfo[year] = yearRegistrations
|
||||
}
|
||||
|
||||
for year := range yearInfo {
|
||||
years = append(years, year)
|
||||
}
|
||||
|
||||
sort.Ints(years)
|
||||
|
||||
return ctx.HTML(components.UserRegistrations(years, yearInfo))
|
||||
}
|
11
pages/admin/registrations.pixy
Normal file
11
pages/admin/registrations.pixy
Normal file
@ -0,0 +1,11 @@
|
||||
component UserRegistrations(years []int, yearInfo map[int]utils.YearRegistrations)
|
||||
AdminTabs
|
||||
h1.page-title User registrations
|
||||
|
||||
for _, year := range years
|
||||
h3.mountable= year
|
||||
h4.mountable= strconv.Itoa(yearInfo[year].Total) + " registrations"
|
||||
for month := 1; month <= 12; month++
|
||||
p.mountable
|
||||
strong= time.Month(month).String() + ": "
|
||||
span= strconv.Itoa(yearInfo[year].Months[month])
|
@ -27,6 +27,9 @@ component Editor(url string, score int, scoreTitle string, scoreTypes map[string
|
||||
a.footer-element(href="/editor/mal/diff/anime" + user.Settings().Editor.Filter.Suffix()) MALdiff
|
||||
a.footer-element(href="/editor/kitsu/new/anime") Kitsu
|
||||
|
||||
if user.Role == "admin"
|
||||
a.footer-element(href="/admin") Admin
|
||||
|
||||
component EditorTabs(url string, user *arn.User)
|
||||
.corner-buttons-left
|
||||
a.button(href="/editor")
|
||||
|
@ -270,6 +270,7 @@ func Configure(app *aero.Application) {
|
||||
// Admin
|
||||
l.Page("/admin", admin.Get)
|
||||
l.Page("/admin/webdev", admin.WebDev)
|
||||
l.Page("/admin/registrations", admin.UserRegistrations)
|
||||
l.Page("/admin/purchases", admin.PurchaseHistory)
|
||||
|
||||
// Editor
|
||||
|
7
utils/YearRegistrations.go
Normal file
7
utils/YearRegistrations.go
Normal file
@ -0,0 +1,7 @@
|
||||
package utils
|
||||
|
||||
// YearRegistrations describes how many user registrations happened in a year.
|
||||
type YearRegistrations struct {
|
||||
Total int
|
||||
Months map[int]int
|
||||
}
|
Loading…
Reference in New Issue
Block a user