Latest and best soundtrack categories
This commit is contained in:
parent
d02cf3fd1c
commit
57273481a6
@ -108,8 +108,10 @@ func Configure(app *aero.Application) {
|
|||||||
l.Page("/settings/pro", settings.Get(components.SettingsPro))
|
l.Page("/settings/pro", settings.Get(components.SettingsPro))
|
||||||
|
|
||||||
// Soundtracks
|
// Soundtracks
|
||||||
l.Page("/soundtracks", soundtracks.Get)
|
l.Page("/soundtracks", soundtracks.Latest)
|
||||||
l.Page("/soundtracks/from/:index", soundtracks.From)
|
l.Page("/soundtracks/from/:index", soundtracks.LatestFrom)
|
||||||
|
l.Page("/soundtracks/best", soundtracks.Best)
|
||||||
|
l.Page("/soundtracks/best/from/:index", soundtracks.BestFrom)
|
||||||
l.Page("/soundtrack/:id", soundtrack.Get)
|
l.Page("/soundtrack/:id", soundtrack.Get)
|
||||||
l.Page("/soundtrack/:id/edit", soundtrack.Edit)
|
l.Page("/soundtrack/:id/edit", soundtrack.Edit)
|
||||||
|
|
||||||
|
66
pages/soundtracks/best.go
Normal file
66
pages/soundtracks/best.go
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
package soundtracks
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/aerogo/aero"
|
||||||
|
"github.com/animenotifier/arn"
|
||||||
|
"github.com/animenotifier/notify.moe/components"
|
||||||
|
"github.com/animenotifier/notify.moe/utils"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Best renders the soundtracks page.
|
||||||
|
func Best(ctx *aero.Context) string {
|
||||||
|
user := utils.GetUser(ctx)
|
||||||
|
|
||||||
|
tracks := arn.FilterSoundTracks(func(track *arn.SoundTrack) bool {
|
||||||
|
return !track.IsDraft && len(track.Media) > 0
|
||||||
|
})
|
||||||
|
|
||||||
|
arn.SortSoundTracksPopularFirst(tracks)
|
||||||
|
|
||||||
|
if len(tracks) > maxTracks {
|
||||||
|
tracks = tracks[:maxTracks]
|
||||||
|
}
|
||||||
|
|
||||||
|
return ctx.HTML(components.SoundTracks(tracks, maxTracks, user))
|
||||||
|
}
|
||||||
|
|
||||||
|
// BestFrom renders the soundtracks from the given index.
|
||||||
|
func BestFrom(ctx *aero.Context) string {
|
||||||
|
user := utils.GetUser(ctx)
|
||||||
|
index, err := ctx.GetInt("index")
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return ctx.Error(http.StatusBadRequest, "Invalid start index", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
allTracks := arn.FilterSoundTracks(func(track *arn.SoundTrack) bool {
|
||||||
|
return !track.IsDraft && len(track.Media) > 0
|
||||||
|
})
|
||||||
|
|
||||||
|
if index < 0 || index >= len(allTracks) {
|
||||||
|
return ctx.Error(http.StatusBadRequest, "Invalid start index (maximum is "+strconv.Itoa(len(allTracks))+")", nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
arn.SortSoundTracksPopularFirst(allTracks)
|
||||||
|
|
||||||
|
tracks := allTracks[index:]
|
||||||
|
|
||||||
|
if len(tracks) > maxTracks {
|
||||||
|
tracks = tracks[:maxTracks]
|
||||||
|
}
|
||||||
|
|
||||||
|
nextIndex := index + maxTracks
|
||||||
|
|
||||||
|
if nextIndex >= len(allTracks) {
|
||||||
|
// End of data - no more scrolling
|
||||||
|
ctx.Response().Header().Set("X-LoadMore-Index", "-1")
|
||||||
|
} else {
|
||||||
|
// Send the index for the next request
|
||||||
|
ctx.Response().Header().Set("X-LoadMore-Index", strconv.Itoa(nextIndex))
|
||||||
|
}
|
||||||
|
|
||||||
|
return ctx.HTML(components.SoundTracksScrollable(tracks, user))
|
||||||
|
}
|
@ -12,8 +12,8 @@ import (
|
|||||||
|
|
||||||
const maxTracks = 12
|
const maxTracks = 12
|
||||||
|
|
||||||
// Get renders the soundtracks page.
|
// Latest renders the soundtracks page.
|
||||||
func Get(ctx *aero.Context) string {
|
func Latest(ctx *aero.Context) string {
|
||||||
user := utils.GetUser(ctx)
|
user := utils.GetUser(ctx)
|
||||||
|
|
||||||
tracks := arn.FilterSoundTracks(func(track *arn.SoundTrack) bool {
|
tracks := arn.FilterSoundTracks(func(track *arn.SoundTrack) bool {
|
||||||
@ -29,8 +29,8 @@ func Get(ctx *aero.Context) string {
|
|||||||
return ctx.HTML(components.SoundTracks(tracks, maxTracks, user))
|
return ctx.HTML(components.SoundTracks(tracks, maxTracks, user))
|
||||||
}
|
}
|
||||||
|
|
||||||
// From renders the soundtracks from the given index.
|
// LatestFrom renders the soundtracks from the given index.
|
||||||
func From(ctx *aero.Context) string {
|
func LatestFrom(ctx *aero.Context) string {
|
||||||
user := utils.GetUser(ctx)
|
user := utils.GetUser(ctx)
|
||||||
index, err := ctx.GetInt("index")
|
index, err := ctx.GetInt("index")
|
||||||
|
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
component SoundTracks(tracks []*arn.SoundTrack, tracksPerPage int, user *arn.User)
|
component SoundTracks(tracks []*arn.SoundTrack, tracksPerPage int, user *arn.User)
|
||||||
h1 Soundtracks
|
h1.page-title Soundtracks
|
||||||
|
|
||||||
|
SoundTracksTabs
|
||||||
|
|
||||||
.corner-buttons
|
.corner-buttons
|
||||||
if user != nil
|
if user != nil
|
||||||
@ -22,3 +24,8 @@ component SoundTracks(tracks []*arn.SoundTrack, tracksPerPage int, user *arn.Use
|
|||||||
component SoundTracksScrollable(tracks []*arn.SoundTrack, user *arn.User)
|
component SoundTracksScrollable(tracks []*arn.SoundTrack, user *arn.User)
|
||||||
each track in tracks
|
each track in tracks
|
||||||
SoundTrack(track)
|
SoundTrack(track)
|
||||||
|
|
||||||
|
component SoundTracksTabs
|
||||||
|
.tabs
|
||||||
|
Tab("Latest", "music", "/soundtracks")
|
||||||
|
Tab("Best", "heart", "/soundtracks/best")
|
Loading…
Reference in New Issue
Block a user