X-Git-Url: https://njoseph.me/gitweb/nimcoon.git/blobdiff_plain/68fd8100bc36465b29ae76b9f41d9eb7fa052e7a..efcc0441469fad73e0d13834a05c500b61c27d89:/clitube.nim diff --git a/clitube.nim b/clitube.nim index a1ba868..9c14735 100644 --- a/clitube.nim +++ b/clitube.nim @@ -11,6 +11,9 @@ import xmltree # Supported video players in order of preference let supportedPlayers = @["mpv", "mplayer", "vlc"] +# Only show these many results +let limit = 10 + # Hard-coded terminal colors proc reset(): string {.procvar.} = "\e[0m" proc bold*(s: string): string {.procvar.} = "\e[1m" & s & reset() @@ -32,20 +35,28 @@ proc getYoutubePage(searchQuery: string): string = let queryParam = encodeUrl(searchQuery) var client = newHttpClient() let response = get(client, "https://www.youtube.com/results?hl=en&search_query=" & queryParam) - # TODO Get rid of temp file or make one temp file per user writeFile("/tmp/cli-tube-page.html", response.body) return "/tmp/cli-tube-page.html" proc extractTitlesAndUrls(htmlFile: string): seq[SearchResult] = loadHtml(htmlFile).findAll("a"). filter(a => "watch" in a.attrs["href"] and a.attrs.hasKey "title"). - map(a => (a.attrs["title"], "https://www.youtube.com" & a.attrs["href"])) + map(a => (a.attrs["title"], "https://www.youtube.com" & a.attrs["href"]))[..(limit-1)] proc presentVideoOptions(searchResults: seq[SearchResult]) = + echo "" for index, (title, url) in searchResults: echo index, ". ", title.bold.fgMagenta, "\n", url.fgCyan, "\n" -presentVideoOptions( - extractTitlesAndUrls( - getYoutubePage( - paramStr(1)))) +let searchResults = extractTitlesAndUrls(getYoutubePage(paramStr(1))) + +presentVideoOptions(searchResults) + +stdout.write "Choose video number: " +var number: int = parseInt(readLine(stdin)) + +var player = selectMediaPlayer() +echo "\n", "Playing ", searchResults[number].title.bold.fgMagenta + +# Play the video in the media player +discard execProcess(player & " " & searchResults[number].url)