85 lines
2.7 KiB
Plaintext
Raw Normal View History

2018-03-13 01:49:54 +01:00
component SoundTrackPage(track *arn.SoundTrack, user *arn.User)
2017-11-05 14:54:58 -04:00
SoundTrackTabs(track, user)
2018-03-11 15:43:17 +01:00
.soundtrack-full-page
2018-04-08 22:50:23 +02:00
if track.Title.ByUser(user) == ""
2017-10-13 00:44:19 +02:00
h1.mountable untitled
else
2018-04-08 22:50:23 +02:00
h1.mountable= track.Title.ByUser(user)
2017-06-28 00:16:45 +02:00
2018-03-11 15:43:17 +01:00
.widget-form.soundtrack-media-list
2017-10-13 00:44:19 +02:00
each media in track.Media
.widget.mountable
h3.widget-title= media.Service
2018-03-11 15:43:17 +01:00
.soundtrack-media.video-container
iframe.lazy.video(data-src=media.EmbedLink(), allowfullscreen="allowfullscreen")
2018-03-11 03:00:06 +01:00
2018-03-11 04:51:10 +01:00
if user != nil && media.Service == "Youtube" && track.File != ""
2018-03-11 03:00:06 +01:00
.buttons
2018-03-11 18:17:35 +01:00
button.action(data-action="playAudio", data-trigger="click", data-audio-src="/audio/" + track.File, data-soundtrack-id=track.ID)
2018-03-11 03:00:06 +01:00
Icon("play")
span Play in background
2017-11-05 14:54:58 -04:00
2017-10-16 01:26:41 +02:00
.widget.mountable
h3.widget-title Anime
2018-03-11 15:43:17 +01:00
.soundtrack-anime-list
2017-10-16 01:26:41 +02:00
each anime in track.Anime()
2018-04-18 13:42:38 +02:00
a.soundtrack-anime-list-item.tip(href=anime.Link(), aria-label=anime.Title.ByUser(user))
2018-03-20 22:39:21 +01:00
img.soundtrack-anime-list-item-image.lazy(data-src=anime.ImageLink("small"), data-webp="true", data-color=anime.AverageColor(), alt=anime.Title.ByUser(user))
2017-11-05 14:54:58 -04:00
2018-03-17 22:31:14 +01:00
if len(track.Links) > 0
.widget.mountable
h3.widget-title Links
ul.soundtrack-links
for _, link := range track.Links
li
a.soundtrack-link(href=link.URL, target="_blank")= link.Title
2018-03-13 16:45:40 +01:00
//- TODO: This is quite ineffective, performance-wise
if len(track.OsuBeatmaps()) > 0 || len(track.EtternaBeatmaps()) > 0
2017-10-22 14:36:55 +02:00
.widget.mountable
h3.widget-title Beatmaps
ul.beatmaps
2018-03-13 16:45:40 +01:00
for index, beatmap := range track.OsuBeatmaps()
2017-10-22 14:36:55 +02:00
li
2018-03-13 16:45:40 +01:00
a.beatmap(href="https://osu.ppy.sh/s/" + beatmap, target="_blank")= "Osu Beatmap #" + strconv.Itoa(index + 1)
for index, beatmap := range track.EtternaBeatmaps()
li
2018-04-13 12:20:13 +02:00
a.beatmap(href="https://etternaonline.com/song/view/" + beatmap, target="_blank")= "Etterna Beatmap #" + strconv.Itoa(index + 1)
2017-10-15 20:19:45 +02:00
.widget.mountable
h3.widget-title Tags
2018-03-13 01:49:54 +01:00
2017-10-16 01:35:28 +02:00
.tags
2017-10-15 20:19:45 +02:00
each tag in track.Tags
a.tag(href="/soundtracks/tag/" + tag)= tag
2018-03-13 01:49:54 +01:00
.footer.mountable
2017-10-13 00:44:19 +02:00
if track.EditedBy != ""
2017-11-13 21:28:03 +01:00
span Edited
2017-10-13 00:44:19 +02:00
span.utc-date(data-date=track.Edited)
2017-11-13 21:28:03 +01:00
span by
2018-04-08 12:01:18 +02:00
span= track.Editor().Nick
2017-10-13 00:44:19 +02:00
else
2017-11-13 21:28:03 +01:00
span Posted
2017-10-13 00:44:19 +02:00
span.utc-date(data-date=track.Created)
2017-11-13 21:28:03 +01:00
span by
2017-10-18 18:18:15 +02:00
span= track.Creator().Nick
2017-11-05 14:54:58 -04:00
2017-10-13 00:44:19 +02:00
span .
2017-10-12 17:52:46 +02:00
2017-11-05 14:54:58 -04:00
component SoundTrackTabs(track *arn.SoundTrack, user *arn.User)
2017-10-12 17:52:46 +02:00
.tabs
2018-04-19 16:23:14 +02:00
LikeTab(strconv.Itoa(len(track.Likes)), "heart", "track", track, user)
2017-10-12 17:52:46 +02:00
Tab("Soundtrack", "music", track.Link())
2018-04-13 12:20:13 +02:00
if track.HasLyrics()
Tab("Lyrics", "font", track.Link() + "/lyrics")
if user != nil
Tab("Edit", "pencil", track.Link() + "/edit")
2018-04-13 12:20:13 +02:00
Tab("History", "history", track.Link() + "/history")