]> njoseph.me Git - nimcoon.git/blobdiff - nimcoon.nim
Add option to play "all" the search results
[nimcoon.git] / nimcoon.nim
index 5c2dc08520d57900b2bcb2933ba13f51ffcaf48e..ed3a572d2d596ced7b0fde6b524db3bf9783029b 100644 (file)
@@ -3,6 +3,7 @@ import
   std/[terminal],
   strutils
 
+import config
 import lib
 
 proc parseOptions(): CommandLineOptions =
@@ -26,6 +27,7 @@ proc parseOptions(): CommandLineOptions =
 
   return (searchQuery, musicOnly, feelingLucky, fullScreen)
 
+
 proc main() =
   let
     player = selectMediaPlayer()
@@ -36,24 +38,38 @@ proc main() =
 
   let searchResults = extractTitlesAndUrls(getYoutubePage(searchQuery))
 
-  let number =
-    if feelingLucky: 0
+  proc getUserInput(): string =
+    if feelingLucky: "0"
     else:
-      presentVideoOptions(searchResults)
+      presentVideoOptions(searchResults[..(limit-1)])
       stdout.styledWrite(fgYellow, "Choose video number: ")
-      parseInt(readLine(stdin))
-
-  styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title
+      readLine(stdin)
 
   # This is a pure function with no side effects
-  func buildArgs(): seq[string] =
+  func buildArgs(number: int): seq[string] =
     var args = @[searchResults[number].url]
     if musicOnly: args.add("--no-video")
     if fullScreen: args.add("--fullscreen")
     return args
 
-  # Play the video using the preferred/available media player
-  play(player, buildArgs())
+  while(true):
+    let userInput = getUserInput()
+
+    if userInput == "all":
+      for number in 0..(len(searchResults)):
+        play(player, buildArgs(number))
+
+    if userInput == "q":
+      break
+
+    let videoNumber = parseInt(userInput)
+    styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[videoNumber].title
+
+    # Play the video using the preferred/available media player
+    play(player, buildArgs(videoNumber))
+    if feelingLucky:
+      break
+
 
 when isMainModule:
   main()