diff options
author | nathansmithsmith <nathansmith7@mailfence.com> | 2023-11-09 16:02:08 +0000 |
---|---|---|
committer | nathansmithsmith <nathansmith7@mailfence.com> | 2023-11-09 16:02:08 +0000 |
commit | d20bb5f9f7f460cf0db3674d6cc2a279d1ee3499 (patch) | |
tree | 2ef79ac157654e64f352e756599e8c21ce40b9df /src/youload_app.py | |
parent | 9f241ede922974ced92d79da5d3996d921becd3c (diff) | |
download | youload-d20bb5f9f7f460cf0db3674d6cc2a279d1ee3499.tar.gz youload-d20bb5f9f7f460cf0db3674d6cc2a279d1ee3499.tar.bz2 youload-d20bb5f9f7f460cf0db3674d6cc2a279d1ee3499.zip |
Started file chooser
Diffstat (limited to 'src/youload_app.py')
-rw-r--r-- | src/youload_app.py | 106 |
1 files changed, 0 insertions, 106 deletions
diff --git a/src/youload_app.py b/src/youload_app.py deleted file mode 100644 index e284116..0000000 --- a/src/youload_app.py +++ /dev/null @@ -1,106 +0,0 @@ -#! /usr/bin/python3 - -from kivy.app import App -from kivy.uix.boxlayout import BoxLayout -from kivy.uix.button import Button -from kivy.uix.floatlayout import FloatLayout -from kivy.uix.gridlayout import GridLayout -from kivy.uix.textinput import TextInput -from kivy.uix.label import Label -from kivy.uix.filechooser import FileChooser - -import threading - -import pytube - -from youload_playlist import YouLoadPlayList - -class YouloadApp(App): - def build(self): - layout = BoxLayout(orientation='vertical') - - # Data members - self.url = "https://youtube.com/playlist?list=PLuZUmvZz4WI78uqT5S71yBHNBMJ97HzhY&si=SI2qN9MgxmmK2rbf" - self.is_downloading = False - self.should_stop_download = False - - # Url input. - url_input = TextInput(text=self.url, multiline=False, size_hint=(0.75, 1.0)) - url_input.bind(text=self.uid_url_input) - - # Submit button. - self.submit = Button(text="Download", size_hint=(0.25, 1.0)) - self.submit.bind(on_press=self.submit_cb) - - # Url and submit layout. - url_and_submit = BoxLayout(size_hint=(1.0, 0.1)) - url_and_submit.add_widget(url_input) - url_and_submit.add_widget(self.submit) - - # Download status. - self.download_status = Label(text="Nothing downloading") - - # Info line. - info_line = BoxLayout(size_hint=(1.0, 0.1)) - info_line.add_widget(self.download_status) - - # Info display. - self.downloads_display = Label(text="", size_hint=(1.0, 0.8)) - - # Everything else (: - layout.add_widget(url_and_submit) - layout.add_widget(info_line) - layout.add_widget(self.downloads_display) - - return layout - - def uid_url_input(self, instance, value): - self.url = value - - # Download the videos in a different thread so the ui still works. - def download_playlist_thread(self): - self.download_status.text = "Fetching playlist" - self.submit.text = "Stop" - self.is_downloading = True - - # Get playlist. - try: - playlist = YouLoadPlayList(self.url) - except KeyError: - self.download_status.text = "Error getting playlist" - return - - playlist.prepare_for_download() - self.downloads_display.text = f"Downloading {self.url}\n" - - # Download each video - for i in range(playlist.video_count): - # Stop this mother fucker - if self.should_stop_download: - break - - self.download_status.text = f"Downloading {i+1}/{playlist.video_count}" - self.downloads_display.text += playlist.download_video(i) + "\n" - - self.submit.text = "Download" - self.download_status.text = "Download complete" - self.is_downloading = False - - def stop_download(self): - self.should_stop_download = True - - def submit_cb(self, instance): - # Is already downloading something. - if self.is_downloading: - self.download_status.text = "Stopping download" - self.stop_download() - return - - # Start download thread. - download_thread = threading.Thread(target=self.download_playlist_thread) - self.should_stop_download = False - download_thread.start() - - def on_stop(self): - self.stop_download() - |