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, relevantCharacters []*arn.Character, mainQuote *arn.Quote, user *arn.User)
	.character-page
		.character-left-column
			.character-header
				.character-image-container.mountable(data-mountable-type="header")
					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", data-mountable-type="header")
								RawIcon("pencil")
				
				.character-description-container
					if character.Name.Canonical == ""
						h1.character-name.mountable(data-mountable-type="header") untitled
					else
						h1.character-name.mountable(data-mountable-type="header")= character.Name.Canonical

					.anime-alternative-title.mountable(data-mountable-type="header")
						if character.Name.Japanese != ""
							Japanese(character.Name.Japanese)
						else
							Japanese("日本語の名前無し")
					
					if mainQuote != nil
						.character-quotes
							Quote(mainQuote, user)
					
					.character-description.mountable(data-mountable-type="header")!= markdown.Render(character.Description)
			
			.character-main-column
				if len(characterAnime) > 0
					.character-section
						h3.character-section-name.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])
					.character-section
						h3.character-section-name.mountable Quotes

						.quotes.character-quotes.mountable
							each quote in quotes
								if mainQuote == nil || quote.ID != mainQuote.ID
									Quote(quote, user)
		
		CharacterSidebar(character, friends, relevantCharacters, user)

component CharacterSidebar(character *arn.Character, friends []*arn.User, relevantCharacters []*arn.Character, user *arn.User)
	.character-sidebar
		if len(character.Attributes) > 0
			h3.mountable(data-mountable-type="sidebar") Information

			table.character-attributes.mountable(data-mountable-type="sidebar")
				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(relevantCharacters) > 0
			h3.mountable(data-mountable-type="sidebar") Relevant

			.relevant-characters.mountable(data-mountable-type="sidebar")
				each relevantCharacter in relevantCharacters
					.mountable(data-mountable-type="relevant-character")
						CharacterSmall(relevantCharacter, user)
		
		if len(friends) > 0
			.character-friends
				h3.mountable(data-mountable-type="sidebar") Friends

				.user-avatars.mountable(data-mountable-type="sidebar")
					each friend in friends
						.mountable(data-mountable-type="friend")
							if friend.IsActive()
								Avatar(friend)
							else
								.inactive-user
									Avatar(friend)

		h3.mountable(data-mountable-type="sidebar") Links

		.light-button-group.mountable(data-mountable-type="sidebar")
			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
			else if user != nil && (user.Role == "editor" || user.Role == "admin")
				a.light-button(href="https://myanimelist.net/character.php?q=" + character.Name.Canonical, target="_blank", rel="noopener")
					Icon("exclamation-triangle")
					span Error: No MAL ID
			
			a.light-button(href="/api" + character.Link(), target="_blank")
				Icon("code")
				span API