Reorder timeline tweets according to their threads

This commit is contained in:
Zed 2019-07-04 14:54:15 +02:00
parent 83931e7044
commit 344d3cd57f
5 changed files with 29 additions and 6 deletions

View File

@ -322,6 +322,10 @@ video {
display: contents !important; display: contents !important;
} }
.retweet {
margin-top: -5px !important;
}
.retweet, .pinned, .tweet-stats { .retweet, .pinned, .tweet-stats {
align-content: center; align-content: center;
color: hsla(240,1%,73%,.7); color: hsla(240,1%,73%,.7);

View File

@ -284,9 +284,12 @@ proc getTimeline*(username, after: string): Future[Timeline] {.async.} =
result = await finishTimeline(json, none(Query)) result = await finishTimeline(json, none(Query))
proc getTimelineSearch*(username, after: string; query: Query): Future[Timeline] {.async.} = proc getTimelineSearch*(username, after: string; query: Query): Future[Timeline] {.async.} =
let queryParam = genQueryParam(query)
let queryEncoded = encodeUrl(queryParam, usePlus=false)
let headers = newHttpHeaders({ let headers = newHttpHeaders({
"Accept": jsonAccept, "Accept": jsonAccept,
"Referer": $(base / ("search?f=tweets&q=from%3A$1&src=typd" % username)), "Referer": $(base / ("search?f=tweets&vertical=default&q=$1&src=typd" % queryEncoded)),
"User-Agent": agent, "User-Agent": agent,
"X-Requested-With": "XMLHttpRequest", "X-Requested-With": "XMLHttpRequest",
"Authority": "twitter.com", "Authority": "twitter.com",
@ -296,7 +299,7 @@ proc getTimelineSearch*(username, after: string; query: Query): Future[Timeline]
let params = { let params = {
"f": "tweets", "f": "tweets",
"vertical": "default", "vertical": "default",
"q": genQueryParam(query), "q": queryParam,
"src": "typd", "src": "typd",
"include_available_features": "1", "include_available_features": "1",
"include_entities": "1", "include_entities": "1",

View File

@ -62,6 +62,7 @@ proc parseTweet*(node: XmlNode): Tweet =
result = Tweet( result = Tweet(
id: tweet.attr("data-item-id"), id: tweet.attr("data-item-id"),
threadId: tweet.attr("data-conversation-id"),
text: getTweetText(tweet), text: getTweetText(tweet),
time: getTimestamp(tweet), time: getTimestamp(tweet),
shortTime: getShortTime(tweet), shortTime: getShortTime(tweet),

View File

@ -92,6 +92,7 @@ type
Tweet* = ref object Tweet* = ref object
id*: string id*: string
threadId*: string
profile*: Profile profile*: Profile
text*: string text*: string
time*: Time time*: Time

View File

@ -1,5 +1,5 @@
#? stdtmpl(subsChar = '$', metaChar = '#') #? stdtmpl(subsChar = '$', metaChar = '#')
#import xmltree, strutils, uri #import xmltree, strutils, uri, algorithm
#import ../types, ../formatters, ../utils, ../search #import ../types, ../formatters, ../utils, ../search
#include "tweet.nimf" #include "tweet.nimf"
# #
@ -68,7 +68,7 @@
#end proc #end proc
# #
#proc renderTimeline*(timeline: Timeline; profile: Profile; beginning: bool): string = #proc renderTimeline*(timeline: Timeline; profile: Profile; beginning: bool): string =
#var retweets: seq[string] #var threads: seq[string]
#var query = "?" #var query = "?"
#if timeline.query.isSome: query = genQueryUrl(get(timeline.query)) #if timeline.query.isSome: query = genQueryUrl(get(timeline.query))
#end if #end if
@ -80,10 +80,24 @@
#end if #end if
# #
#for tweet in timeline.tweets: #for tweet in timeline.tweets:
#if tweet.id in retweets: continue #if tweet.threadId in threads: continue
#elif tweet.retweet.isSome: retweets.add tweet.id
#end if #end if
#proc threadFilter(it: Tweet): bool =
#it.retweet.isNone and it.reply.len == 0 and it.threadId == tweet.threadId
#end proc
#let thread = timeline.tweets.filter(threadFilter)
#if thread.len < 2:
${renderTweet(tweet, "timeline-tweet")} ${renderTweet(tweet, "timeline-tweet")}
#else:
<div class="thread-line">
#for i, threadTweet in thread.sortedByIt(it.time):
#let last = (i == thread.high)
#let class = if last: "timeline-tweet" else: "thread"
${renderTweet(threadTweet, class, first=(i == 0), last=last)}
#end for
</div>
#threads.add tweet.threadId
#end if
#end for #end for
# #
#if timeline.hasMore or timeline.query.isSome and timeline.tweets.len > 0: #if timeline.hasMore or timeline.query.isSome and timeline.tweets.len > 0: