nitter/src/views/status.nim

62 lines
2.2 KiB
Nim
Raw Normal View History

import karax/[karaxdsl, vdom]
import ".."/[types, formatters]
import tweet, timeline
proc renderMoreReplies(thread: Chain): VNode =
let num = if thread.more != -1: $thread.more & " " else: ""
let reply = if thread.more == 1: "reply" else: "replies"
2019-09-24 16:34:50 +02:00
let link = getLink(thread.content[^1])
2019-09-13 19:57:27 +02:00
buildHtml(tdiv(class="timeline-item more-replies")):
if link.len > 0:
2019-09-24 16:34:50 +02:00
a(class="more-replies-text", href=link):
text $num & "more " & reply
else:
a(class="more-replies-text"):
text $num & "more " & reply
proc renderReplyThread(thread: Chain; prefs: Prefs; path: string): VNode =
buildHtml(tdiv(class="reply thread thread-line")):
2019-08-23 02:15:25 +02:00
for i, tweet in thread.content:
let last = (i == thread.content.high and thread.more == 0)
renderTweet(tweet, prefs, path, index=i, last=last)
if thread.more != 0:
renderMoreReplies(thread)
proc renderConversation*(conversation: Conversation; prefs: Prefs; path: string): VNode =
let hasAfter = conversation.after != nil
2019-09-13 19:52:05 +02:00
buildHtml(tdiv(class="conversation")):
tdiv(class="main-thread"):
if conversation.before != nil:
tdiv(class="before-tweet thread-line"):
2019-08-23 02:15:25 +02:00
for i, tweet in conversation.before.content:
renderTweet(tweet, prefs, path, index=i)
tdiv(class="main-tweet"):
let afterClass = if hasAfter: "thread thread-line" else: ""
renderTweet(conversation.tweet, prefs, path, class=afterClass,
mainTweet=true)
if hasAfter:
tdiv(class="after-tweet thread-line"):
2019-08-23 02:15:25 +02:00
let total = conversation.after.content.high
let more = conversation.after.more
2019-08-23 02:15:25 +02:00
for i, tweet in conversation.after.content:
renderTweet(tweet, prefs, path, index=i, last=(i == total and more == 0))
if more != 0:
renderMoreReplies(conversation.after)
if not conversation.replies.beginning:
renderNewer(Query(), getLink(conversation.tweet))
if conversation.replies.content.len > 0:
tdiv(class="replies"):
for thread in conversation.replies.content:
if thread == nil: continue
renderReplyThread(thread, prefs, path)
if conversation.replies.hasMore:
renderMore(Query(), conversation.replies.minId)