Latest and best soundtrack categories

This commit is contained in:
Eduard Urbach 2017-11-19 17:02:20 +01:00
parent d02cf3fd1c
commit 57273481a6
4 changed files with 83 additions and 8 deletions

View File

@ -108,8 +108,10 @@ func Configure(app *aero.Application) {
l.Page("/settings/pro", settings.Get(components.SettingsPro))
// Soundtracks
l.Page("/soundtracks", soundtracks.Get)
l.Page("/soundtracks/from/:index", soundtracks.From)
l.Page("/soundtracks", soundtracks.Latest)
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/edit", soundtrack.Edit)

66
pages/soundtracks/best.go Normal file
View 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))
}

View File

@ -12,8 +12,8 @@ import (
const maxTracks = 12
// Get renders the soundtracks page.
func Get(ctx *aero.Context) string {
// Latest renders the soundtracks page.
func Latest(ctx *aero.Context) string {
user := utils.GetUser(ctx)
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))
}
// From renders the soundtracks from the given index.
func From(ctx *aero.Context) string {
// LatestFrom renders the soundtracks from the given index.
func LatestFrom(ctx *aero.Context) string {
user := utils.GetUser(ctx)
index, err := ctx.GetInt("index")

View File

@ -1,5 +1,7 @@
component SoundTracks(tracks []*arn.SoundTrack, tracksPerPage int, user *arn.User)
h1 Soundtracks
h1.page-title Soundtracks
SoundTracksTabs
.corner-buttons
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)
each track in tracks
SoundTrack(track)
component SoundTracksTabs
.tabs
Tab("Latest", "music", "/soundtracks")
Tab("Best", "heart", "/soundtracks/best")