Improved anime view on characters

This commit is contained in:
Eduard Urbach 2019-11-19 11:39:20 +09:00
parent 4fbe73a1d0
commit b8b2fb9354
Signed by: akyoto
GPG Key ID: C874F672B1AF20C0
14 changed files with 135 additions and 92 deletions

View File

@ -1,4 +1,35 @@
package arn package arn
import (
"errors"
"strings"
shortid "github.com/ventu-io/go-shortid"
)
// ID is used for object identification and is simply a string. // ID is used for object identification and is simply a string.
type ID = string type ID = string
// GenerateID generates a unique ID for a given collection.
func GenerateID(collection string) ID {
id, _ := shortid.Generate()
// Retry until we find an unused ID
retry := 0
for {
_, err := DB.Get(collection, id)
if err != nil && strings.Contains(err.Error(), "not found") {
return id
}
retry++
if retry > 10 {
panic(errors.New("Can't generate unique ID"))
}
id, _ = shortid.Generate()
}
}

View File

@ -18,7 +18,6 @@ import (
"github.com/akyoto/color" "github.com/akyoto/color"
"github.com/animenotifier/kitsu" "github.com/animenotifier/kitsu"
"github.com/animenotifier/mal" "github.com/animenotifier/mal"
shortid "github.com/ventu-io/go-shortid"
) )
var ( var (
@ -31,30 +30,6 @@ var (
writtenByRegex = regexp.MustCompile(`\[Written by (.*?)\]`) writtenByRegex = regexp.MustCompile(`\[Written by (.*?)\]`)
) )
// GenerateID generates a unique ID for a given collection.
func GenerateID(collection string) ID {
id, _ := shortid.Generate()
// Retry until we find an unused ID
retry := 0
for {
_, err := DB.Get(collection, id)
if err != nil && strings.Contains(err.Error(), "not found") {
return id
}
retry++
if retry > 10 {
panic(errors.New("Can't generate unique ID"))
}
id, _ = shortid.Generate()
}
}
// GetUserFromContext returns the logged in user for the given context. // GetUserFromContext returns the logged in user for the given context.
func GetUserFromContext(ctx aero.Context) *User { func GetUserFromContext(ctx aero.Context) *User {
if !ctx.HasSession() { if !ctx.HasSession() {
@ -208,23 +183,22 @@ func FixGender(gender string) string {
func DateToSeason(date time.Time) string { func DateToSeason(date time.Time) string {
month := date.Month() month := date.Month()
if month >= 4 && month <= 6 { switch {
case month >= 4 && month <= 6:
return "spring" return "spring"
}
if month >= 7 && month <= 9 { case month >= 7 && month <= 9:
return "summer" return "summer"
}
if month >= 10 && month <= 12 { case month >= 10 && month <= 12:
return "autumn" return "autumn"
}
if month >= 1 && month < 4 { case month >= 1 && month < 4:
return "winter" return "winter"
}
return "" default:
return ""
}
} }
// BroadcastEvent sends the given event to the event streams of all users. // BroadcastEvent sends the given event to the event streams of all users.

View File

@ -0,0 +1,7 @@
component AnimeCard(anime *arn.Anime, note string, user *arn.User)
a.anime-card.mountable(href=anime.Link())
.anime-card-image-container
img.anime-card-image.lazy(data-src=anime.ImageLink("small"), data-webp="true", data-color=anime.AverageColor(), alt=anime.Title.ByUser(user))
.anime-card-info
.anime-card-info-main= anime.Title.ByUser(user)
.anime-card-info-details= note

View File

@ -0,0 +1,32 @@
.anime-cards
horizontal-wrap
.anime-card
card
> 600px
.anime-card
max-width 300px
.anime-card-image-container
width anime-image-small-width
height anime-image-small-width
img
width anime-image-small-width
height anime-image-small-width
border-radius ui-element-border-radius
object-fit cover
.anime-card-info
vertical
margin-left card-padding
font-size 0.95em
.anime-card-info-main
flex 1
line-height 1.3em
.anime-card-info-details
color text-color
opacity 0.5

View File

@ -1,7 +1,7 @@
component UserCard(user *arn.User, note string) component UserCard(user *arn.User, note string)
a.user-card.mountable(href=user.Link(), data-pro=user.IsPro()) a.user-card.mountable(href=user.Link(), data-pro=user.IsPro())
.user-card-avatar .user-card-image-container
AvatarNoLink(user) AvatarNoLink(user)
.user-card-info .user-card-info
.user-card-nick= user.Nick .user-card-info-main= user.Nick
.user-card-note= note .user-card-info-details= note

View File

@ -0,0 +1,33 @@
.user-cards
horizontal-wrap
justify-content center
.user-card
card
> 600px
.user-card
max-width 230px
.user-card-image-container
width avatar-size
height avatar-size
img
width avatar-size
height avatar-size
border-radius ui-element-border-radius
box-shadow none
.user-card-info
vertical
margin-left card-padding
overflow hidden
.user-card-info-main
clip-long-text
.user-card-info-details
clip-long-text
color text-color
opacity 0.5

View File

@ -229,7 +229,7 @@ component AnimeInformation(anime *arn.Anime)
tr.mountable(data-mountable-type="info") tr.mountable(data-mountable-type="info")
td.anime-info-key Season: td.anime-info-key Season:
td.anime-info-value td.anime-info-value
a(href="/explore/anime/" + anime.StartDate[:4] + "/" + strings.ToLower(anime.Season()) + "/any/" + anime.Type)= stringutils.Capitalize(anime.Season()) + " " + anime.StartDate[:4] a(href="/explore/anime/" + anime.StartDate[:4] + "/" + anime.Season() + "/any/" + anime.Type)= stringutils.Capitalize(anime.Season()) + " " + anime.StartDate[:4]
if anime.Source != "" && arn.AnimeSourceHumanReadable[anime.Source] != "" if anime.Source != "" && arn.AnimeSourceHumanReadable[anime.Source] != ""
tr.mountable(data-mountable-type="info") tr.mountable(data-mountable-type="info")

View File

@ -11,6 +11,7 @@ component AnimeRelations(anime *arn.Anime, user *arn.User, standAlonePage bool)
.anime-relations .anime-relations
each relation in anime.Relations().Items each relation in anime.Relations().Items
if relation.Anime() != nil if relation.Anime() != nil
//- AnimeCard(relation.Anime(), fmt.Sprintf("%s (%d)", relation.HumanReadableType(), anime.StartDateTime().Year()), user)
a.anime-relation.tip.mountable(href=relation.Anime().Link(), aria-label=relation.Anime().Title.ByUser(user), data-mountable-type="relation") a.anime-relation.tip.mountable(href=relation.Anime().Link(), aria-label=relation.Anime().Title.ByUser(user), data-mountable-type="relation")
img.anime-relation-image.lazy(data-src=relation.Anime().ImageLink("small"), data-webp="true", data-color=relation.Anime().AverageColor(), alt=relation.Anime().Title.ByUser(user)) img.anime-relation-image.lazy(data-src=relation.Anime().ImageLink("small"), data-webp="true", data-color=relation.Anime().AverageColor(), alt=relation.Anime().Title.ByUser(user))
.anime-relation-type= relation.HumanReadableType() .anime-relation-type= relation.HumanReadableType()

View File

@ -46,20 +46,15 @@ component CharacterDetails(character *arn.Character, characterAnime []*arn.Anime
.character-section .character-section
h3.character-section-name.mountable Anime h3.character-section-name.mountable Anime
.character-anime.mountable .anime-cards
each anime in characterAnime each anime in characterAnime
.character-anime-item AnimeCard(anime, fmt.Sprintf("%s %d", stringutils.Capitalize(anime.Season()), anime.StartDateTime().Year()), user)
.character-anime-item-overview
a.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))
.character-anime-item-details
a(href=anime.Link())= anime.TitleByUser(user)
if len(quotes) > 0 if len(quotes) > 0
.character-section .character-section
h3.character-section-name.mountable Quotes h3.character-section-name.mountable Quotes
.quotes.character-quotes.mountable .character-quotes.mountable
each quote in quotes each quote in quotes
QuotePreview(quote, user) QuotePreview(quote, user)
@ -109,7 +104,7 @@ component CharacterSidebar(character *arn.Character, friends []*arn.User, releva
if len(friends) > 0 if len(friends) > 0
.character-friends .character-friends
h3.mountable(data-mountable-type="sidebar") Friends h3.mountable(data-mountable-type="sidebar") Likes
.user-avatars.mountable(data-mountable-type="sidebar") .user-avatars.mountable(data-mountable-type="sidebar")
each friend in friends each friend in friends

View File

@ -70,9 +70,6 @@
.quote-footer .quote-footer
display none display none
.quote
max-width 500px
.character-friends .character-friends
.user-avatars .user-avatars
justify-content flex-start justify-content flex-start

View File

@ -1,40 +0,0 @@
const user-card-padding = 1rem
.user-cards
horizontal-wrap
justify-content center
.user-card
horizontal
ui-element
padding user-card-padding
margin 0.4rem
width 100%
height calc(avatar-size + user-card-padding * 2)
:hover
border 1px solid input-focus-border-color
// TODO: Replace with alpha(main-color, 20%) function
box-shadow 0 0 6px rgba(248, 165, 130, 0.2)
> 600px
.user-card
max-width 230px
.user-card-avatar
.user-image
border-radius ui-element-border-radius
box-shadow none
.user-card-info
vertical
margin-left user-card-padding
overflow hidden
.user-card-nick
clip-long-text
.user-card-note
clip-long-text
color text-color
opacity 0.5

View File

@ -40,4 +40,4 @@ rt
text-align center text-align center
.spacer .spacer
flex 1 flex 1

View File

@ -71,7 +71,7 @@ const group-post-width = comment-width
const post-avatar-text-margin = 0.5rem const post-avatar-text-margin = 0.5rem
// Avatar // Avatar
avatar-size = 50px const avatar-size = 50px
// Badge // Badge
badge-important-bg-color = rgb(215, 38, 15) badge-important-bg-color = rgb(215, 38, 15)

View File

@ -0,0 +1,13 @@
const card-padding = 1rem
mixin card
horizontal
ui-element
padding card-padding
margin 0.4rem
width 100%
:hover
border 1px solid input-focus-border-color
// TODO: Replace with alpha(main-color, 20%) function
box-shadow 0 0 6px rgba(248, 165, 130, 0.2)