nitter/src/views/general.nim

74 lines
2.4 KiB
Nim
Raw Normal View History

import karax/[karaxdsl, vdom]
import renderutils
2019-08-13 17:44:29 +00:00
import ../utils, ../types
2019-08-07 20:02:19 +00:00
const doctype = "<!DOCTYPE html>\n"
2019-09-15 09:29:14 +00:00
proc renderNavbar*(title, path, rss: string): VNode =
2019-08-12 20:57:43 +00:00
buildHtml(nav(id="nav", class="nav-bar container")):
tdiv(class="inner-nav"):
tdiv(class="item"):
a(class="site-name", href="/"): text title
a(href="/"): img(class="site-logo", src="/logo.png")
tdiv(class="item right"):
2019-09-15 09:29:14 +00:00
if rss.len > 0:
icon "rss", title="RSS Feed", href=rss
icon "info-circled", title="About", href="/about"
iconReferer "cog", "/settings", path, title="Preferences"
2019-08-12 20:57:43 +00:00
2019-09-15 09:29:14 +00:00
proc renderMain*(body: VNode; prefs: Prefs; title="Nitter"; titleText=""; desc=""; path="/";
rss=""; `type`="article"; video=""; images: seq[string] = @[]): string =
let node = buildHtml(html(lang="en")):
head:
link(rel="stylesheet", `type`="text/css", href="/css/style.css")
link(rel="stylesheet", `type`="text/css", href="/css/fontello.css")
2019-08-19 18:25:00 +00:00
if prefs.hlsPlayback:
script(src="/js/hls.light.min.js")
script(src="/js/hlsPlayback.js")
2019-08-07 20:02:19 +00:00
title:
if titleText.len > 0:
text titleText & " | " & title
else:
text title
2019-09-07 16:52:27 +00:00
meta(name="viewport", content="width=device-width, initial-scale=1.0")
2019-08-07 20:27:24 +00:00
meta(property="og:type", content=`type`)
meta(property="og:title", content=titleText)
meta(property="og:description", content=desc)
meta(property="og:site_name", content="Twitter")
2019-08-07 20:02:19 +00:00
for url in images:
meta(property="og:image", content=getPicUrl(url))
2019-08-07 20:02:19 +00:00
if video.len > 0:
2019-08-07 20:27:24 +00:00
meta(property="og:video:url", content=video)
meta(property="og:video:secure_url", content=video)
2019-08-07 20:02:19 +00:00
body:
2019-09-15 09:29:14 +00:00
renderNavbar(title, path, rss)
tdiv(id="content", class="container"):
body
result = doctype & $node
proc renderSearch*(): VNode =
2019-09-13 08:44:21 +00:00
buildHtml(tdiv(class="panel-container")):
tdiv(class="search-panel"):
form(`method`="post", action="/search"):
2019-08-13 18:21:35 +00:00
input(`type`="text", name="query", autofocus="", placeholder="Enter usernames...")
button(`type`="submit"): icon "search"
proc renderError*(error: string): VNode =
2019-09-13 08:44:21 +00:00
buildHtml(tdiv(class="panel-container")):
tdiv(class="error-panel"):
span: text error
2019-08-15 21:17:13 +00:00
proc showError*(error, title: string): string =
2019-08-19 18:25:00 +00:00
renderMain(renderError(error), Prefs(), title, "Error")