2019-06-19 09:57:22 +00:00
|
|
|
component Profile(viewUser *arn.User, user *arn.User, animeList *arn.AnimeList, completedList *arn.AnimeList, characters []*arn.Character, groups []*arn.Group, friends []*arn.User, topGenres []string, topStudios []*arn.Company, animeWatchingTime time.Duration, dayToActivityCount map[int]int, uri string)
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile
|
2018-11-24 06:57:52 +00:00
|
|
|
ProfileHeader(viewUser, animeList, user, uri)
|
2017-11-11 14:47:03 +00:00
|
|
|
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile-columns
|
2018-11-15 11:53:24 +00:00
|
|
|
//- Favorites
|
|
|
|
.profile-column.profile-favorites.mountable(data-mountable-type="column")
|
2018-11-16 16:54:53 +00:00
|
|
|
//- Anime
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile-section
|
2019-06-23 23:01:14 +00:00
|
|
|
h3.profile-column-header.mountable(data-mountable-type="favorites")
|
|
|
|
a(href=viewUser.Link() + "/animelist/watching") Anime
|
2018-11-15 11:19:40 +00:00
|
|
|
|
2018-11-24 06:57:52 +00:00
|
|
|
if len(completedList.Items) == 0
|
2018-11-15 11:53:24 +00:00
|
|
|
p.no-data.mountable(data-mountable-type="favorites") Nothing here yet.
|
|
|
|
else
|
2018-11-16 16:54:53 +00:00
|
|
|
.profile-favorite-anime-container.mountable(data-mountable-type="favorites")
|
2018-11-24 06:57:52 +00:00
|
|
|
each item in completedList.Top(6)
|
2018-11-16 16:54:53 +00:00
|
|
|
a.profile-favorite-anime.tip.mountable(href=item.Anime().Link(), aria-label=item.Anime().Title.ByUser(user), data-mountable-type="anime")
|
2018-11-15 11:53:24 +00:00
|
|
|
img.profile-favorite-anime-image.lazy(data-src=item.Anime().ImageLink("small"), data-webp=true, alt=item.Anime().Title.ByUser(user))
|
|
|
|
|
2018-11-16 16:54:53 +00:00
|
|
|
//- Characters
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile-section
|
2019-03-11 00:37:05 +00:00
|
|
|
h3.profile-column-header.mountable(data-mountable-type="favorites")
|
|
|
|
a(href=viewUser.Link() + "/characters/liked") Characters
|
2018-11-15 11:19:40 +00:00
|
|
|
|
2018-11-15 11:53:24 +00:00
|
|
|
if len(characters) == 0
|
|
|
|
p.no-data.mountable(data-mountable-type="favorites") Nothing here yet.
|
|
|
|
else
|
2018-11-16 16:54:53 +00:00
|
|
|
.profile-favorite-characters-container.mountable(data-mountable-type="favorites")
|
2018-11-15 11:53:24 +00:00
|
|
|
each character in characters
|
2018-11-16 16:54:53 +00:00
|
|
|
.mountable(data-mountable-type="character")
|
2018-11-15 11:53:24 +00:00
|
|
|
CharacterSmall(character, user)
|
2019-06-19 09:57:22 +00:00
|
|
|
|
|
|
|
//- Groups
|
|
|
|
.profile-section
|
|
|
|
h3.profile-column-header.mountable(data-mountable-type="favorites") Groups
|
|
|
|
|
|
|
|
if len(groups) == 0
|
|
|
|
p.no-data.mountable(data-mountable-type="favorites") Nothing here yet.
|
|
|
|
else
|
2019-06-19 10:00:42 +00:00
|
|
|
.profile-groups.mountable(data-mountable-type="favorites")
|
|
|
|
each group in groups
|
|
|
|
a.profile-group.tip.mountable(href=group.Link(), aria-label=group.Name, data-mountable-type="group")
|
|
|
|
img.group-image.lazy(data-src=group.ImageLink("small"), data-webp=true, alt=group.Name)
|
2019-04-17 13:07:04 +00:00
|
|
|
|
2019-04-22 06:05:16 +00:00
|
|
|
//- //- People
|
|
|
|
//- .profile-section
|
|
|
|
//- h3.profile-column-header.mountable(data-mountable-type="favorites") People
|
|
|
|
//- p.no-data.mountable(data-mountable-type="favorites") Nothing here yet.
|
2019-04-17 13:07:04 +00:00
|
|
|
|
2019-04-22 06:05:16 +00:00
|
|
|
//- //- Quotes
|
|
|
|
//- .profile-section
|
|
|
|
//- h3.profile-column-header.mountable(data-mountable-type="favorites") Quotes
|
|
|
|
//- p.no-data.mountable(data-mountable-type="favorites") Nothing here yet.
|
2019-04-17 13:07:04 +00:00
|
|
|
|
2018-11-15 11:53:24 +00:00
|
|
|
//- Posts
|
|
|
|
.profile-column.profile-activity.mountable(data-mountable-type="column")
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile-section
|
2018-11-15 11:53:24 +00:00
|
|
|
h3.profile-column-header.mountable(data-mountable-type="activity") Posts
|
2018-11-15 11:19:40 +00:00
|
|
|
Comments(viewUser, user)
|
|
|
|
|
2018-11-15 11:53:24 +00:00
|
|
|
//- Extra
|
|
|
|
.profile-column.profile-extra.mountable(data-mountable-type="column")
|
2018-11-16 16:54:53 +00:00
|
|
|
//- Genres
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile-section
|
|
|
|
h3.profile-column-header.mountable(data-mountable-type="extra") Genres
|
2017-11-11 14:47:03 +00:00
|
|
|
|
2018-11-15 11:53:24 +00:00
|
|
|
if len(topGenres) == 0
|
|
|
|
p.no-data.mountable(data-mountable-type="extra") Nothing here yet.
|
|
|
|
else
|
2018-11-16 16:54:53 +00:00
|
|
|
.anime-genres.mountable(data-mountable-type="extra")
|
2018-11-15 11:53:24 +00:00
|
|
|
each genre in topGenres
|
2018-11-16 16:54:53 +00:00
|
|
|
a.anime-genre.mountable(href="/genre/" + strings.ToLower(genre), data-mountable-type="genre")= genre
|
2018-11-15 11:53:24 +00:00
|
|
|
|
2018-11-25 06:53:52 +00:00
|
|
|
//- Studios
|
|
|
|
.profile-section
|
|
|
|
h3.profile-column-header.mountable(data-mountable-type="extra") Studios
|
|
|
|
|
|
|
|
if len(topStudios) == 0
|
|
|
|
p.no-data.mountable(data-mountable-type="extra") Nothing here yet.
|
|
|
|
else
|
|
|
|
.anime-studios.mountable(data-mountable-type="extra")
|
|
|
|
each company in topStudios
|
|
|
|
a.anime-studio.mountable(href=company.Link(), data-mountable-type="company")= company.Name.English
|
|
|
|
|
2018-11-16 20:33:40 +00:00
|
|
|
//- Friends
|
|
|
|
.profile-section.profile-section-friends
|
|
|
|
h3.profile-column-header.mountable(data-mountable-type="extra") Friends
|
|
|
|
|
|
|
|
if len(friends) == 0
|
|
|
|
p.no-data.mountable(data-mountable-type="extra") Nothing here yet.
|
|
|
|
else
|
|
|
|
.profile-friends.mountable(data-mountable-type="extra")
|
|
|
|
each friend in friends
|
|
|
|
.profile-friend.mountable(data-mountable-type="friend")
|
|
|
|
Avatar(friend)
|
|
|
|
|
2018-11-16 16:54:53 +00:00
|
|
|
//- Activity
|
2018-11-16 19:48:36 +00:00
|
|
|
.profile-section.profile-section-activity
|
2018-11-16 16:54:53 +00:00
|
|
|
h3.profile-column-header.mountable(data-mountable-type="extra") Activity
|
|
|
|
|
|
|
|
.profile-activities.mountable(data-mountable-type="extra")
|
|
|
|
for month := 5; month >= 0; month--
|
|
|
|
.activities-month
|
|
|
|
for week := 3; week >= 0; week--
|
|
|
|
.activities-week
|
|
|
|
for day := 6; day >= 0; day--
|
|
|
|
if dayToActivityCount[month * 28 + week * 7 + day] == 0
|
|
|
|
.box.mountable(data-count="0", data-mountable-type=fmt.Sprintf("month-%d", month))
|
|
|
|
else
|
|
|
|
.box.tip.mountable(aria-label=fmt.Sprintf("%s: %s", time.Weekday((6 - day + 1) % 7).String(), stringutils.Plural(dayToActivityCount[month * 28 + week * 7 + day], "activity")), data-count=dayToActivityCount[month * 28 + week * 7 + day], data-mountable-type=fmt.Sprintf("month-%d", month))
|
|
|
|
|
|
|
|
if day == 2
|
|
|
|
.spacer-box
|
|
|
|
|
2018-11-25 06:53:52 +00:00
|
|
|
.footer.activities-footer.mountable(data-mountable-type="extra")
|
2019-08-30 07:38:45 +00:00
|
|
|
p
|
|
|
|
span= viewUser.Nick + " spent "
|
|
|
|
span= stringutils.Plural(int(animeWatchingTime / time.Hour / 24), "day")
|
|
|
|
span watching anime.
|
2018-11-25 06:53:52 +00:00
|
|
|
|
2018-11-24 06:57:52 +00:00
|
|
|
component ProfileHeader(viewUser *arn.User, animeList *arn.AnimeList, user *arn.User, uri string)
|
|
|
|
ProfileHead(viewUser, animeList, user, uri)
|
2017-11-11 14:47:03 +00:00
|
|
|
|
2018-11-24 06:57:52 +00:00
|
|
|
component ProfileHead(viewUser *arn.User, animeList *arn.AnimeList, user *arn.User, uri string)
|
2018-11-15 11:19:40 +00:00
|
|
|
.profile-head
|
2018-03-07 13:00:14 +00:00
|
|
|
img.profile-cover.lazy(data-src=viewUser.CoverLink("large"), data-webp="true", alt="Cover image")
|
2016-11-20 10:26:11 +00:00
|
|
|
|
2017-07-17 17:49:52 +00:00
|
|
|
.profile-image-container.mountable.never-unmount
|
2019-03-11 00:37:05 +00:00
|
|
|
a(href=viewUser.Link())
|
|
|
|
ProfileImage(viewUser)
|
2017-06-22 14:21:26 +00:00
|
|
|
|
2018-10-31 00:33:56 +00:00
|
|
|
.profile-info.mountable.never-unmount
|
2019-03-11 00:37:05 +00:00
|
|
|
h1#nick
|
|
|
|
a(href=viewUser.Link())= viewUser.Nick
|
|
|
|
|
2018-10-31 00:33:56 +00:00
|
|
|
.profile-introduction!= markdown.Render(viewUser.Introduction)
|
2018-10-31 01:41:05 +00:00
|
|
|
|
2018-10-31 00:33:56 +00:00
|
|
|
.profile-tags-container
|
2019-04-27 16:08:34 +00:00
|
|
|
ProfileTags(viewUser, animeList, user)
|
2018-03-16 04:40:29 +00:00
|
|
|
|
|
|
|
.profile-actions
|
|
|
|
if user != nil && user.ID != viewUser.ID
|
2019-11-19 04:51:54 +00:00
|
|
|
if !user.IsFollowing(viewUser.ID)
|
|
|
|
button.profile-action.action.mountable.never-unmount(data-action="followUser", data-trigger="click", data-api="/api/user/" + user.ID + "/follow/" + viewUser.ID)
|
2018-03-16 04:40:29 +00:00
|
|
|
Icon("user-plus")
|
|
|
|
span Follow
|
|
|
|
else
|
2019-11-19 04:51:54 +00:00
|
|
|
button.profile-action.action.mountable.never-unmount(data-action="unfollowUser", data-trigger="click", data-api="/api/user/" + user.ID + "/unfollow/" + viewUser.ID)
|
2018-03-16 04:40:29 +00:00
|
|
|
Icon("user-times")
|
2019-04-27 16:08:34 +00:00
|
|
|
span Unfollow
|
|
|
|
|
|
|
|
component ProfileTags(viewUser *arn.User, animeList *arn.AnimeList, user *arn.User)
|
|
|
|
.profile-tags
|
|
|
|
a.profile-tag.mountable.never-unmount(href="/+" + viewUser.Nick + "/animelist/watching", data-mountable-type="header")
|
|
|
|
Icon("list")
|
|
|
|
span= fmt.Sprintf("%d anime", len(animeList.Items))
|
|
|
|
|
|
|
|
if user != nil && viewUser.Settings().Privacy.ShowAge && viewUser.Settings().Privacy.ShowGender && viewUser.AgeInYears() != 0
|
|
|
|
.profile-tag.mountable.never-unmount(data-mountable-type="header")
|
|
|
|
if viewUser.Gender == "male"
|
|
|
|
Icon("mars")
|
|
|
|
else if viewUser.Gender == "female"
|
|
|
|
Icon("venus")
|
|
|
|
else
|
|
|
|
Icon("venus-mars")
|
|
|
|
|
|
|
|
span= viewUser.AgeInYears()
|
|
|
|
|
|
|
|
if user != nil && viewUser.Settings().Privacy.ShowLocation && viewUser.Location.CountryName != ""
|
|
|
|
a.profile-tag.mountable.never-unmount(href="/users/country/" + strings.ToLower(viewUser.Location.CountryName), data-mountable-type="header")
|
|
|
|
Icon("map-marker")
|
|
|
|
span= viewUser.Location.CountryName
|
|
|
|
|
|
|
|
if viewUser.IsPro()
|
|
|
|
a.profile-tag.mountable.never-unmount(href="/support", aria-label="Supporter", data-mountable-type="header")
|
|
|
|
Icon("star")
|
2019-08-30 07:22:08 +00:00
|
|
|
span PRO
|
2019-04-27 16:08:34 +00:00
|
|
|
|
|
|
|
if viewUser.Role != ""
|
|
|
|
a.profile-tag.mountable.never-unmount(href="/users/staff", aria-label="Staff member", data-mountable-type="header")
|
|
|
|
Icon("rocket")
|
|
|
|
span= stringutils.Capitalize(viewUser.Role)
|
|
|
|
|
|
|
|
if viewUser.Registered != ""
|
|
|
|
.profile-tag.mountable.never-unmount(title="Member since", data-mountable-type="header")
|
|
|
|
Icon("calendar")
|
|
|
|
span= viewUser.RegisteredTime().Format("Jan 2006")
|
|
|
|
|
|
|
|
if !viewUser.IsActive()
|
|
|
|
.profile-tag.mountable.never-unmount(title="Hasn't been online for the past 2 weeks", data-mountable-type="header")
|
|
|
|
Icon("bed")
|
|
|
|
span Inactive
|
|
|
|
|
|
|
|
.profile-tag.action.tip.mountable.never-unmount(data-action="showMore", data-trigger="click", aria-label="Show more", data-mountable-type="header")
|
|
|
|
RawIcon("ellipsis-h")
|
|
|
|
|
|
|
|
if viewUser.Website != ""
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href=viewUser.WebsiteURL(), target="_blank", rel="noopener", aria-label=viewUser.WebsiteShortURL(), data-mountable-type="header")
|
|
|
|
RawIcon("globe")
|
|
|
|
|
|
|
|
if viewUser.Accounts.Discord.Nick != "" && viewUser.Accounts.Discord.Verified
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href="https://discord.gg/0kimAmMCeXGXuzNF", aria-label=fmt.Sprintf("Discord | %s", viewUser.Accounts.Discord.Nick), data-mountable-type="header")
|
|
|
|
RawIcon("discord")
|
|
|
|
|
|
|
|
if user != nil && user.ID != viewUser.ID
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href="/compare/animelist/" + user.Nick + "/" + viewUser.Nick, aria-label="Compare", data-mountable-type="header")
|
|
|
|
RawIcon("exchange")
|
|
|
|
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href="/+" + viewUser.Nick + "/anime/recommended", aria-label="Recommendations", data-mountable-type="header")
|
|
|
|
RawIcon("archive")
|
|
|
|
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href="/+" + viewUser.Nick + "/anime/sequels", aria-label="Sequels", data-mountable-type="header")
|
|
|
|
RawIcon("forward")
|
|
|
|
|
|
|
|
if user != nil && (user.Role == "editor" || user.Role == "admin")
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href="/+" + viewUser.Nick + "/log", aria-label="Log", data-mountable-type="header")
|
|
|
|
RawIcon("list")
|
|
|
|
|
|
|
|
if user != nil && user.Role == "admin"
|
|
|
|
a.profile-tag.tip.mountable.never-unmount.show-more(href="/api/user/" + viewUser.ID, aria-label="API", target="_blank", rel="noopener", data-mountable-type="header")
|
2021-11-20 12:26:51 +00:00
|
|
|
RawIcon("search-plus")
|