Added user registrations page
This commit is contained in:
parent
b49496fe16
commit
802273b7c3
@ -2,6 +2,7 @@ component AdminTabs
|
|||||||
.tabs
|
.tabs
|
||||||
Tab("Server", "server", "/admin")
|
Tab("Server", "server", "/admin")
|
||||||
Tab("WebDev", "html5", "/admin/webdev")
|
Tab("WebDev", "html5", "/admin/webdev")
|
||||||
|
Tab("Registrations", "user-plus", "/admin/registrations")
|
||||||
Tab("Purchases", "shopping-cart", "/admin/purchases")
|
Tab("Purchases", "shopping-cart", "/admin/purchases")
|
||||||
|
|
||||||
.corner-buttons
|
.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/mal/diff/anime" + user.Settings().Editor.Filter.Suffix()) MALdiff
|
||||||
a.footer-element(href="/editor/kitsu/new/anime") Kitsu
|
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)
|
component EditorTabs(url string, user *arn.User)
|
||||||
.corner-buttons-left
|
.corner-buttons-left
|
||||||
a.button(href="/editor")
|
a.button(href="/editor")
|
||||||
|
@ -270,6 +270,7 @@ func Configure(app *aero.Application) {
|
|||||||
// Admin
|
// Admin
|
||||||
l.Page("/admin", admin.Get)
|
l.Page("/admin", admin.Get)
|
||||||
l.Page("/admin/webdev", admin.WebDev)
|
l.Page("/admin/webdev", admin.WebDev)
|
||||||
|
l.Page("/admin/registrations", admin.UserRegistrations)
|
||||||
l.Page("/admin/purchases", admin.PurchaseHistory)
|
l.Page("/admin/purchases", admin.PurchaseHistory)
|
||||||
|
|
||||||
// Editor
|
// 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