Added character likes
This commit is contained in:
@ -11,7 +11,7 @@ component Profile(viewUser *arn.User, user *arn.User, animeList *arn.AnimeList,
|
||||
img.profile-watching-list-item-image.lazy(data-src=item.Anime().ImageLink("small"), data-webp="true", data-color=item.Anime().AverageColor(), alt=item.Anime().Title.ByUser(user))
|
||||
|
||||
.footer
|
||||
.buttons
|
||||
.buttons
|
||||
if user != nil && (user.Role == "admin" || user.Role == "editor")
|
||||
a.button.profile-action(href="/api/user/" + viewUser.ID, target="_blank", rel="noopener")
|
||||
Icon("search-plus")
|
||||
@ -20,15 +20,12 @@ component Profile(viewUser *arn.User, user *arn.User, animeList *arn.AnimeList,
|
||||
component ProfileTabs(viewUser *arn.User, uri string)
|
||||
.tabs
|
||||
Tab("Anime", "th", "/+" + viewUser.Nick)
|
||||
//- Tab("Collection", "list", "/+" + viewUser.Nick + "/animelist/watching")
|
||||
Tab("Characters", "child", "/+" + viewUser.Nick + "/characters/liked")
|
||||
Tab("Forum", "comment", "/+" + viewUser.Nick + "/forum/threads")
|
||||
Tab("Tracks", "music", "/+" + viewUser.Nick + "/soundtracks/liked")
|
||||
Tab("Quotes", "quote-left", "/+" + viewUser.Nick + "/quotes/liked")
|
||||
Tab("Stats", "area-chart", "/+" + viewUser.Nick + "/stats")
|
||||
Tab("Followers", "users", "/+" + viewUser.Nick + "/followers")
|
||||
|
||||
//- if strings.Contains(uri, "/animelist")
|
||||
//- StatusTabs("/+" + viewUser.Nick + "/animelist")
|
||||
|
||||
if strings.Contains(uri, "/soundtracks")
|
||||
.tabs
|
||||
|
11
pages/profile/profilecharacters/characters.pixy
Normal file
11
pages/profile/profilecharacters/characters.pixy
Normal file
@ -0,0 +1,11 @@
|
||||
component ProfileCharacters(characters []*arn.Character, viewUser *arn.User, user *arn.User, uri string)
|
||||
ProfileHeader(viewUser, user, uri)
|
||||
|
||||
if len(characters) == 0
|
||||
p.no-data.mountable= viewUser.Nick + " hasn't liked any characters yet."
|
||||
else
|
||||
.characters.profile-characters
|
||||
each character in characters
|
||||
.mountable
|
||||
Character(character)
|
||||
|
2
pages/profile/profilecharacters/characters.scarlet
Normal file
2
pages/profile/profilecharacters/characters.scarlet
Normal file
@ -0,0 +1,2 @@
|
||||
.profile-characters
|
||||
justify-content center
|
44
pages/profile/profilecharacters/liked.go
Normal file
44
pages/profile/profilecharacters/liked.go
Normal file
@ -0,0 +1,44 @@
|
||||
package profilecharacters
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"sort"
|
||||
|
||||
"github.com/aerogo/aero"
|
||||
"github.com/animenotifier/arn"
|
||||
"github.com/animenotifier/notify.moe/components"
|
||||
"github.com/animenotifier/notify.moe/utils"
|
||||
)
|
||||
|
||||
// Liked shows all liked characters of a particular user.
|
||||
func Liked(ctx *aero.Context) string {
|
||||
nick := ctx.Get("nick")
|
||||
viewUser, err := arn.GetUserByNick(nick)
|
||||
|
||||
if err != nil {
|
||||
return ctx.Error(http.StatusNotFound, "User not found", err)
|
||||
}
|
||||
|
||||
characters := []*arn.Character{}
|
||||
|
||||
for character := range arn.StreamCharacters() {
|
||||
if arn.Contains(character.Likes, viewUser.ID) {
|
||||
characters = append(characters, character)
|
||||
}
|
||||
}
|
||||
|
||||
sort.Slice(characters, func(i, j int) bool {
|
||||
return characters[i].Name.Canonical < characters[j].Name.Canonical
|
||||
|
||||
// aLikes := len(characters[i].Likes)
|
||||
// bLikes := len(characters[j].Likes)
|
||||
|
||||
// if aLikes == bLikes {
|
||||
// return characters[i].Name.Canonical < characters[j].Name.Canonical
|
||||
// }
|
||||
|
||||
// return aLikes > bLikes
|
||||
})
|
||||
|
||||
return ctx.HTML(components.ProfileCharacters(characters, viewUser, utils.GetUser(ctx), ctx.URI()))
|
||||
}
|
Reference in New Issue
Block a user