89 lines
3.2 KiB
Plaintext

component CharacterTabs(character *arn.Character, user *arn.User)
.tabs
Tab("Character", "user", character.Link())
Tab("Edit", "pencil", character.Link() + "/edit")
Tab("Images", "image", character.Link() + "/edit/images")
Tab("History", "history", character.Link() + "/history")
component CharacterDetails(character *arn.Character, characterAnime []*arn.Anime, quotes []*arn.Quote, friends []*arn.User, mainQuote *arn.Quote, user *arn.User)
.character-page
.character-left-column
.character-header
.character-image-container.mountable
img.character-image-large.lazy(data-src=character.ImageLink("large"), data-webp="true", data-color=character.AverageColor(), alt=character.Name.Canonical)
.buttons
LikeButton(strconv.Itoa(len(character.Likes)), "heart", "character", character, user)
if user != nil && (user.Role == "editor" || user.Role == "admin")
a.button.tip.mountable(href=character.Link() + "/edit", aria-label="Edit character")
RawIcon("pencil")
.character-description-container
h1.character-name.mountable= character.Name.Canonical
.anime-alternative-title.mountable
if character.Name.Japanese != ""
Japanese(character.Name.Japanese)
if mainQuote != nil
.character-quote
Quote(mainQuote)
.character-description.mountable!= markdown.Render(character.Description)
h3.mountable Anime
.character-anime.mountable
each anime in characterAnime
a.character-anime-item.tip.mountable(href=anime.Link(), aria-label=anime.Title.ByUser(user), data-mountable-type="anime")
img.character-anime-item-image.lazy(data-src=anime.ImageLink("small"), data-webp="true", data-color=anime.AverageColor(), alt=anime.Title.ByUser(user))
if len(quotes) > 0 && (len(quotes) > 1 || mainQuote != quotes[0])
h3.mountable Quotes
.character-quotes.mountable
each quote in quotes
if mainQuote == nil || quote.ID != mainQuote.ID
.character-quote
Quote(quote)
.character-sidebar
if len(character.Attributes) > 0
h3.mountable Information
table.character-attributes.mountable
each attribute in character.Attributes
tr.mountable(data-mountable-type="info")
td.character-attributes-name= attribute.Name + ":"
if strings.Contains(attribute.Value, "<")
td.character-attributes-value!= markdown.Render(attribute.Value)
else
td.character-attributes-value= attribute.Value
if len(friends) > 0
.character-friends
h3.mountable Friends
.user-avatars.mountable
each friend in friends
.mountable(data-mountable-type="friend")
if friend.IsActive()
Avatar(friend)
else
.inactive-user
Avatar(friend)
h3.mountable Links
.light-button-group.mountable
if character.GetMapping("myanimelist/character") != ""
a.light-button(href="https://myanimelist.net/character/" + character.GetMapping("myanimelist/character"), target="_blank", rel="noopener")
Icon("external-link")
span MAL
a.light-button(href="/api" + character.Link(), target="_blank")
Icon("code")
span API