From 0b5c15ce67a7b999e2a036465a68ec20f5700699 Mon Sep 17 00:00:00 2001 From: Zed Date: Sat, 26 Oct 2019 16:37:58 +0200 Subject: [PATCH] Display content attribution --- src/parserutils.nim | 8 ++++++++ src/sass/tweet/_base.scss | 19 ++++++++++++++++++- src/types.nim | 1 + src/views/tweet.nim | 8 ++++++++ 4 files changed, 35 insertions(+), 1 deletion(-) diff --git a/src/parserutils.nim b/src/parserutils.nim index 35b5a1e..fed38ed 100644 --- a/src/parserutils.nim +++ b/src/parserutils.nim @@ -199,6 +199,14 @@ proc getTweetMedia*(tweet: Tweet; node: XmlNode) = let player = node.select(".PlayableMedia") if player == nil: return + let attrib = player.select(".PlayableMedia-attribution") + if attrib != nil: + tweet.attribution = some Profile( + username: attrib.attr("href").strip(chars={'/'}), + fullname: attrib.selectText(".fullname"), + userpic: attrib.selectAttr(".avatar", "src") + ) + if "gif" in player.attr("class"): tweet.gif = some getGif(player.select(".PlayableMedia-player")) elif "video" in player.attr("class"): diff --git a/src/sass/tweet/_base.scss b/src/sass/tweet/_base.scss index add0d5b..0b058f6 100644 --- a/src/sass/tweet/_base.scss +++ b/src/sass/tweet/_base.scss @@ -88,7 +88,24 @@ margin-left: -58px; width: 48px; height: 48px; - border-radius: 50%; + } +} + +.avatar { + border-radius: 50%; +} + +.attribution { + display: flex; + pointer-events: all; + margin: 10px 0; + + .avatar { + margin-right: 5px; + } + + strong { + color: var(--fg_color); } } diff --git a/src/types.nim b/src/types.nim index 0373436..da1ee4c 100644 --- a/src/types.nim +++ b/src/types.nim @@ -148,6 +148,7 @@ type tombstone*: string stats*: TweetStats retweet*: Option[Retweet] + attribution*: Option[Profile] quote*: Option[Quote] card*: Option[Card] gif*: Option[Gif] diff --git a/src/views/tweet.nim b/src/views/tweet.nim index 8f567dc..3e84413 100644 --- a/src/views/tweet.nim +++ b/src/views/tweet.nim @@ -188,6 +188,11 @@ proc renderReply(quote: Quote): VNode = if i > 0: text " " a(href=("/" & u)): text "@" & u +proc renderAttribution(profile: Profile): VNode = + buildHtml(a(class="attribution", href=("/" & profile.username))): + img(class="avatar", width="20", height="20", src=profile.getUserpic("_200x200")) + strong: text profile.fullname + proc renderQuoteMedia(quote: Quote): VNode = buildHtml(tdiv(class="quote-media-container")): if quote.thumb.len > 0: @@ -258,6 +263,9 @@ proc renderTweet*(tweet: Tweet; prefs: Prefs; path: string; class=""; tdiv(class="tweet-content media-body", dir="auto"): verbatim replaceUrl(tweet.text, prefs) + if tweet.attribution.isSome: + renderAttribution(tweet.attribution.get()) + if tweet.quote.isSome: renderQuote(tweet.quote.get(), prefs)