Support promo_video_website cards

This commit is contained in:
Zed 2019-07-15 16:03:01 +02:00
parent d12f14135e
commit 27cf4cdf64
6 changed files with 48 additions and 35 deletions

View file

@ -237,7 +237,7 @@ nav {
.gallery-row .attachment:last-child, .gallery-row .attachments:last-child, .video-container { .gallery-row .attachment:last-child, .gallery-row .attachments:last-child, .video-container {
margin: 0; margin: 0;
max-height: 500px; max-height: 530px;
} }
.attachments .attachment { .attachments .attachment {
@ -901,6 +901,11 @@ video {
border-color: #808080; border-color: #808080;
} }
.card-container .attachments {
margin: 0;
border-radius: 0;
}
.large .card-container { .large .card-container {
display: block; display: block;
} }

View file

@ -106,7 +106,11 @@ proc getVideo*(tweet: Tweet; token: string) {.async.} =
await getVideo(tweet, guestToken) await getVideo(tweet, guestToken)
return return
tweet.video = some(parseVideo(json)) if tweet.card.isNone:
tweet.video = some(parseVideo(json))
else:
get(tweet.card).video = some(parseVideo(json))
tweet.video = none(Video)
tokenUses.inc tokenUses.inc
proc getVideos*(thread: Thread; token="") {.async.} = proc getVideos*(thread: Thread; token="") {.async.} =

View file

@ -180,19 +180,6 @@ proc parsePhotoRail*(node: XmlNode): seq[GalleryPhoto] =
) )
proc parseCard*(card: var Card; node: XmlNode) = proc parseCard*(card: var Card; node: XmlNode) =
let cardKind = node.select("head > meta[name*=card_name]").attr("content")
if "summary_large_image" in cardKind:
card.kind = summaryLarge
elif "summary" in cardKind:
card.kind = summary
elif "live_event" in cardKind:
card.kind = liveEvent
elif "player" in cardKind:
card.kind = player
elif "promo_website" in cardKind:
card.kind = promoWebsite
card.title = node.selectText("h2.TwitterCard-title") card.title = node.selectText("h2.TwitterCard-title")
card.text = node.selectText("p.tcu-resetMargin") card.text = node.selectText("p.tcu-resetMargin")
card.dest = node.selectText("span.SummaryCard-destination") card.dest = node.selectText("span.SummaryCard-destination")
@ -203,9 +190,7 @@ proc parseCard*(card: var Card; node: XmlNode) =
let image = node.select(".tcu-imageWrapper img") let image = node.select(".tcu-imageWrapper img")
if image != nil: if image != nil:
# workaround for issue 11713 # workaround for issue 11713
card.image = image.attr("data-src").replace("gname", "g&name") card.image = some(image.attr("data-src").replace("gname", "g&name"))
else:
echo card.id
if card.kind == liveEvent: if card.kind == liveEvent:
card.text = card.title card.text = card.title

View file

@ -1,4 +1,4 @@
import xmltree, htmlparser, strtabs, strformat, times import xmltree, htmlparser, strtabs, strformat, strutils, times
import regex import regex
import types, formatters, api import types, formatters, api
@ -169,13 +169,16 @@ proc getQuoteMedia*(quote: var Quote; node: XmlNode) =
proc getTweetCard*(tweet: Tweet; node: XmlNode) = proc getTweetCard*(tweet: Tweet; node: XmlNode) =
if node.attr("data-has-cards") == "false": return if node.attr("data-has-cards") == "false": return
let cardType = node.attr("data-card2-type") var cardType = node.attr("data-card2-type")
if ":" in cardType:
cardType = cardType.split(":")[^1]
if "poll" in cardType: if "poll" in cardType:
tweet.poll = some(Poll()) tweet.poll = some(Poll())
return return
let cardDiv = node.select(".card2 > div") let cardDiv = node.select(".card2 > .js-macaw-cards-iframe-container")
if cardDiv == nil: return if cardDiv == nil: return
var card = Card( var card = Card(
@ -183,6 +186,11 @@ proc getTweetCard*(tweet: Tweet; node: XmlNode) =
query: cardDiv.attr("data-src") query: cardDiv.attr("data-src")
) )
try:
card.kind = parseEnum[CardKind](cardType)
except ValueError:
card.kind = summary
let cardUrl = cardDiv.attr("data-card-url") let cardUrl = cardDiv.attr("data-card-url")
for n in node.selectAll(".tweet-text a"): for n in node.selectAll(".tweet-text a"):
if n.attr("href") == cardUrl: if n.attr("href") == cardUrl:

View file

@ -71,7 +71,12 @@ type
leader*: int leader*: int
CardKind* = enum CardKind* = enum
summary, summaryLarge, liveEvent, player, promoWebsite summary = "summary"
summaryLarge = "summary_large_image"
promoWebsite = "promo_website"
promoVideo = "promo_video_website"
player = "player"
liveEvent = "live_event"
Card* = object Card* = object
kind*: CardKind kind*: CardKind
@ -81,7 +86,8 @@ type
title*: string title*: string
dest*: string dest*: string
text*: string text*: string
image*: string image*: Option[string]
video*: Option[Video]
Quote* = object Quote* = object
id*: string id*: string

View file

@ -77,20 +77,25 @@ proc renderPoll(poll: Poll): VNode =
span(class="poll-info"): span(class="poll-info"):
text $poll.votes & " votes • " & poll.status text $poll.votes & " votes • " & poll.status
proc renderCardImage(card: Card): VNode =
buildHtml(tdiv(class="card-image-container")):
tdiv(class="card-image"):
img(src=get(card.image).getSigUrl("pic"))
if card.kind == player:
tdiv(class="card-overlay"):
tdiv(class="card-overlay-circle"):
span(class="card-overlay-triangle")
proc renderCard(card: Card): VNode = proc renderCard(card: Card): VNode =
const largeCards = {summaryLarge, liveEvent, promoWebsite} const largeCards = {summaryLarge, liveEvent, promoWebsite, promoVideo}
let large = if card.kind in largeCards: " large" else: "" let large = if card.kind in largeCards: " large" else: ""
buildHtml(tdiv(class=("card" & large))): buildHtml(tdiv(class=("card" & large))):
a(class="card-container", href=card.url): a(class="card-container", href=card.url):
if card.image.len > 0: if card.image.isSome:
tdiv(class="card-image-container"): renderCardImage(card)
tdiv(class="card-image"): elif card.video.isSome:
img(src=card.image.getSigUrl("pic")) renderVideo(get(card.video))
if card.kind == player:
tdiv(class="card-overlay"):
tdiv(class="card-overlay-circle"):
span(class="card-overlay-triangle")
tdiv(class="card-content-container"): tdiv(class="card-content-container"):
tdiv(class="card-content"): tdiv(class="card-content"):
@ -181,7 +186,9 @@ proc renderTweet*(tweet: Tweet; class=""; index=0; total=(-1); last=false): VNod
if tweet.quote.isSome: if tweet.quote.isSome:
renderQuote(tweet.quote.get()) renderQuote(tweet.quote.get())
if tweet.photos.len > 0: if tweet.card.isSome:
renderCard(tweet.card.get())
elif tweet.photos.len > 0:
renderAlbum(tweet) renderAlbum(tweet)
elif tweet.video.isSome: elif tweet.video.isSome:
renderVideo(tweet.video.get()) renderVideo(tweet.video.get())
@ -189,8 +196,6 @@ proc renderTweet*(tweet: Tweet; class=""; index=0; total=(-1); last=false): VNod
renderGif(tweet.gif.get()) renderGif(tweet.gif.get())
elif tweet.poll.isSome: elif tweet.poll.isSome:
renderPoll(tweet.poll.get()) renderPoll(tweet.poll.get())
elif tweet.card.isSome:
renderCard(tweet.card.get())
renderStats(tweet.stats) renderStats(tweet.stats)