def browse_folder(self): folder = QFileDialog.getExistingDirectory(self, "Select Save Directory") if folder: self.path_input.setText(folder)
def remove_download(self, task_id: str, delete_file: bool = False): if task_id in self.active_downloads: self.active_downloads[task_id].stop() del self.active_downloads[task_id] if delete_file: task = self.tasks[task_id] filepath = os.path.join(task.save_path, task.filename) if os.path.exists(filepath): os.remove(filepath) del self.tasks[task_id] self.delete_task(task_id)
def init_database(self): conn = sqlite3.connect(self.db_path) cursor = conn.cursor() cursor.execute(''' CREATE TABLE IF NOT EXISTS downloads ( id TEXT PRIMARY KEY, url TEXT, filename TEXT, save_path TEXT, total_size INTEGER, downloaded_size INTEGER, status TEXT, threads INTEGER, speed REAL, created_at TEXT, completed_at TEXT, md5 TEXT ) ''') conn.commit() conn.close()