Fix multi-timeline infinite scroll, minor refactor
This commit is contained in:
parent
4c35d0b723
commit
9197c686d3
|
@ -18,9 +18,9 @@ proc createListRouter*(cfg: Config) =
|
||||||
get "/@name/lists/@list":
|
get "/@name/lists/@list":
|
||||||
cond '.' notin @"name"
|
cond '.' notin @"name"
|
||||||
let list = await getListTimeline(@"name", @"list", @"max_position", getAgent())
|
let list = await getListTimeline(@"name", @"list", @"max_position", getAgent())
|
||||||
respList list, renderTimelineTweets(list, cookiePrefs(), request.path)
|
respList(list, renderTimelineTweets(list, cookiePrefs(), request.path))
|
||||||
|
|
||||||
get "/@name/lists/@list/members":
|
get "/@name/lists/@list/members":
|
||||||
cond '.' notin @"name"
|
cond '.' notin @"name"
|
||||||
let list = await getListMembers(@"name", @"list", @"max_position", getAgent())
|
let list = await getListMembers(@"name", @"list", @"max_position", getAgent())
|
||||||
respList list, renderTimelineUsers(list, cookiePrefs(), request.path)
|
respList(list, renderTimelineUsers(list, cookiePrefs(), request.path))
|
||||||
|
|
|
@ -18,7 +18,7 @@ proc showRss*(req: Request; hostname: string; query: Query): Future[(string, str
|
||||||
|
|
||||||
if names.len == 1:
|
if names.len == 1:
|
||||||
(profile, timeline) =
|
(profile, timeline) =
|
||||||
await fetchSingleTimeline(names[0], after, getAgent(), query, media=false)
|
await fetchSingleTimeline(after, getAgent(), query, media=false)
|
||||||
else:
|
else:
|
||||||
let multiQuery = query.getMultiQuery(names)
|
let multiQuery = query.getMultiQuery(names)
|
||||||
timeline = await getSearch[Tweet](multiQuery, after, getAgent(), media=false)
|
timeline = await getSearch[Tweet](multiQuery, after, getAgent(), media=false)
|
||||||
|
@ -60,18 +60,19 @@ proc createRssRouter*(cfg: Config) =
|
||||||
|
|
||||||
get "/@name/rss":
|
get "/@name/rss":
|
||||||
cond '.' notin @"name"
|
cond '.' notin @"name"
|
||||||
let (rss, minId) = await showRss(request, cfg.hostname, Query())
|
let (rss, minId) = await showRss(request, cfg.hostname, Query(fromUser: @[@"name"]))
|
||||||
respRss(rss, minId)
|
respRss(rss, minId)
|
||||||
|
|
||||||
get "/@name/@tab/rss":
|
get "/@name/@tab/rss":
|
||||||
cond '.' notin @"name"
|
cond '.' notin @"name"
|
||||||
cond @"tab" in ["with_replies", "media", "search"]
|
cond @"tab" in ["with_replies", "media", "search"]
|
||||||
|
let name = @"name"
|
||||||
let query =
|
let query =
|
||||||
case @"tab"
|
case @"tab"
|
||||||
of "with_replies": getReplyQuery(@"name")
|
of "with_replies": getReplyQuery(name)
|
||||||
of "media": getMediaQuery(@"name")
|
of "media": getMediaQuery(name)
|
||||||
of "search": initQuery(params(request), name=(@"name"))
|
of "search": initQuery(params(request), name=name)
|
||||||
else: Query()
|
else: Query(fromUser: @[name])
|
||||||
|
|
||||||
let (rss, minId) = await showRss(request, cfg.hostname, query)
|
let (rss, minId) = await showRss(request, cfg.hostname, query)
|
||||||
respRss(rss, minId)
|
respRss(rss, minId)
|
||||||
|
|
|
@ -16,16 +16,17 @@ proc getQuery*(request: Request; tab, name: string): Query =
|
||||||
of "with_replies": getReplyQuery(name)
|
of "with_replies": getReplyQuery(name)
|
||||||
of "media": getMediaQuery(name)
|
of "media": getMediaQuery(name)
|
||||||
of "search": initQuery(params(request), name=name)
|
of "search": initQuery(params(request), name=name)
|
||||||
else: Query()
|
else: Query(fromUser: @[name])
|
||||||
|
|
||||||
proc fetchTimeline*(name, after, agent: string; query: Query): Future[Timeline] =
|
proc fetchTimeline*(after, agent: string; query: Query): Future[Timeline] =
|
||||||
case query.kind
|
case query.kind
|
||||||
of QueryKind.media: getMediaTimeline(name, after, agent)
|
of QueryKind.media: getMediaTimeline(query.fromUser[0], after, agent)
|
||||||
of posts: getTimeline(name, after, agent)
|
of posts: getTimeline(query.fromUser[0], after, agent)
|
||||||
else: getSearch[Tweet](query, after, agent)
|
else: getSearch[Tweet](query, after, agent)
|
||||||
|
|
||||||
proc fetchSingleTimeline*(name, after, agent: string; query: Query;
|
proc fetchSingleTimeline*(after, agent: string; query: Query;
|
||||||
media=true): Future[(Profile, Timeline)] {.async.} =
|
media=true): Future[(Profile, Timeline)] {.async.} =
|
||||||
|
let name = query.fromUser[0]
|
||||||
var timeline: Timeline
|
var timeline: Timeline
|
||||||
var profile: Profile
|
var profile: Profile
|
||||||
var cachedProfile = hasCachedProfile(name)
|
var cachedProfile = hasCachedProfile(name)
|
||||||
|
@ -37,7 +38,7 @@ proc fetchSingleTimeline*(name, after, agent: string; query: Query;
|
||||||
(profile, timeline) = await getProfileAndTimeline(name, after, agent, media)
|
(profile, timeline) = await getProfileAndTimeline(name, after, agent, media)
|
||||||
cache(profile)
|
cache(profile)
|
||||||
else:
|
else:
|
||||||
let timelineFut = fetchTimeline(name, after, agent, query)
|
let timelineFut = fetchTimeline(after, agent, query)
|
||||||
if cachedProfile.isNone:
|
if cachedProfile.isNone:
|
||||||
profile = await getCachedProfile(name, agent)
|
profile = await getCachedProfile(name, agent)
|
||||||
timeline = await timelineFut
|
timeline = await timelineFut
|
||||||
|
@ -57,18 +58,16 @@ proc get*(req: Request; key: string): string =
|
||||||
proc showTimeline*(request: Request; query: Query; cfg: Config; prefs: Prefs;
|
proc showTimeline*(request: Request; query: Query; cfg: Config; prefs: Prefs;
|
||||||
rss, after: string): Future[string] {.async.} =
|
rss, after: string): Future[string] {.async.} =
|
||||||
let agent = getAgent()
|
let agent = getAgent()
|
||||||
let names = getNames(request.get("name"))
|
|
||||||
|
|
||||||
if names.len != 1:
|
if query.fromUser.len != 1:
|
||||||
let
|
let
|
||||||
multiQuery = query.getMultiQuery(names)
|
timeline = await getSearch[Tweet](query, after, agent)
|
||||||
timeline = await getSearch[Tweet](multiQuery, after, agent)
|
|
||||||
html = renderTweetSearch(timeline, prefs, getPath())
|
html = renderTweetSearch(timeline, prefs, getPath())
|
||||||
return renderMain(html, request, cfg, "Multi", rss=rss)
|
return renderMain(html, request, cfg, "Multi", rss=rss)
|
||||||
|
|
||||||
let
|
let
|
||||||
rail = getPhotoRail(names[0], agent, skip=(query.kind == media))
|
rail = getPhotoRail(query.fromUser[0], agent, skip=(query.kind == media))
|
||||||
(p, t) = await fetchSingleTimeline(names[0], after, agent, query)
|
(p, t) = await fetchSingleTimeline(after, agent, query)
|
||||||
r = await rail
|
r = await rail
|
||||||
if p.username.len == 0: return
|
if p.username.len == 0: return
|
||||||
if p.suspended:
|
if p.suspended:
|
||||||
|
@ -83,10 +82,6 @@ template respTimeline*(timeline: typed) =
|
||||||
resp Http404, showError("User \"" & @"name" & "\" not found", cfg)
|
resp Http404, showError("User \"" & @"name" & "\" not found", cfg)
|
||||||
resp timeline
|
resp timeline
|
||||||
|
|
||||||
template respScroll*(timeline: typed) =
|
|
||||||
timeline.beginning = true # don't render "load newest"
|
|
||||||
resp $renderTimelineTweets(timeline, prefs, getPath())
|
|
||||||
|
|
||||||
proc createTimelineRouter*(cfg: Config) =
|
proc createTimelineRouter*(cfg: Config) =
|
||||||
setProfileCacheTime(cfg.profileCacheTime)
|
setProfileCacheTime(cfg.profileCacheTime)
|
||||||
|
|
||||||
|
@ -97,10 +92,21 @@ proc createTimelineRouter*(cfg: Config) =
|
||||||
let
|
let
|
||||||
prefs = cookiePrefs()
|
prefs = cookiePrefs()
|
||||||
after = @"max_position"
|
after = @"max_position"
|
||||||
query = request.getQuery(@"tab", @"name")
|
names = getNames(@"name")
|
||||||
|
|
||||||
|
var query = request.getQuery(@"tab", @"name")
|
||||||
|
if names.len != 1:
|
||||||
|
query = query.getMultiQuery(names)
|
||||||
|
|
||||||
if @"scroll".len > 0:
|
if @"scroll".len > 0:
|
||||||
respScroll(await fetchTimeline(@"name", after, getAgent(), query))
|
if query.fromUser.len != 1:
|
||||||
|
let timeline = await getSearch[Tweet](query, after, getAgent())
|
||||||
|
timeline.beginning = true
|
||||||
|
resp $renderTweetSearch(timeline, prefs, getPath())
|
||||||
|
else:
|
||||||
|
let timeline = await fetchTimeline(after, getAgent(), query)
|
||||||
|
timeline.beginning = true
|
||||||
|
resp $renderTimelineTweets(timeline, prefs, getPath())
|
||||||
|
|
||||||
var rss = "/$1/$2/rss" % [@"name", @"tab"]
|
var rss = "/$1/$2/rss" % [@"name", @"tab"]
|
||||||
if @"tab".len == 0:
|
if @"tab".len == 0:
|
||||||
|
|
Loading…
Reference in New Issue