From 1fcfec4e2bd558975d36f1f294cdc52abeb5f4e5 Mon Sep 17 00:00:00 2001 From: Jeix Date: Wed, 10 Nov 2010 16:27:17 +0100 Subject: some design improvements on gui --- module/gui/Accounts.py | 17 +++++--- module/gui/MainWindow.py | 68 ++++++++++++++++++++++++------ module/plugins/accounts/DepositfilesCom.py | 4 +- module/plugins/hoster/MegauploadCom.py | 3 ++ 4 files changed, 73 insertions(+), 19 deletions(-) (limited to 'module') diff --git a/module/gui/Accounts.py b/module/gui/Accounts.py index 0add1452b..23751d79f 100644 --- a/module/gui/Accounts.py +++ b/module/gui/Accounts.py @@ -30,18 +30,21 @@ class AccountModel(QAbstractItemModel): self.cols = 4 self.mutex = QMutex() - def reloadData(self, force=True): - data = self.connector.proxy.get_accounts(False, force) + def reloadData(self, force=False): + data = self.connector.proxy.get_accounts(force, False) + + accounts = [] + for li in data.values(): + accounts += li + + if self._data == accounts: + return if len(self._data) > 0: self.beginRemoveRows(QModelIndex(), 0, len(self._data)-1) self._data = [] self.endRemoveRows() - accounts = [] - for li in data.values(): - accounts += li - if len(accounts) > 0: self.beginInsertRows(QModelIndex(), 0, len(accounts)-1) self._data = accounts @@ -59,6 +62,8 @@ class AccountModel(QAbstractItemModel): elif index.column() == 1: return QVariant(self.toData(index)["login"]) elif index.column() == 2: + if not self.toData(index)["valid"]: + return QVariant(_("not valid")) if not self.toData(index)["validuntil"]: return QVariant(_("n/a")) until = int(self.toData(index)["validuntil"]) diff --git a/module/gui/MainWindow.py b/module/gui/MainWindow.py index 255f562a1..03590ac2d 100644 --- a/module/gui/MainWindow.py +++ b/module/gui/MainWindow.py @@ -116,7 +116,7 @@ class MainWindow(QMainWindow): #init tabs self.init_tabs(connector) - self.setPriority = Priorty(self) + self.setPriority = Priority(self) #context menus self.init_context() @@ -164,9 +164,11 @@ class MainWindow(QMainWindow): self.addMenu = QMenu() packageAction = self.addMenu.addAction(_("Package")) containerAction = self.addMenu.addAction(_("Container")) + accountAction = self.addMenu.addAction(_("Account")) self.connect(self.actions["add"], SIGNAL("triggered()"), self.slotAdd) self.connect(packageAction, SIGNAL("triggered()"), self.slotShowAddPackage) self.connect(containerAction, SIGNAL("triggered()"), self.slotShowAddContainer) + self.connect(accountAction, SIGNAL("triggered()"), self.slotNewAccount) def init_tabs(self, connector): """ @@ -258,25 +260,35 @@ class MainWindow(QMainWindow): self.collectorContext.buttons["remove"] = QAction(QIcon(join(pypath, "icons","remove_small.png")), _("Remove"), self.collectorContext) self.collectorContext.buttons["push"] = QAction(QIcon(join(pypath, "icons","push_small.png")), _("Push to queue"), self.collectorContext) self.collectorContext.buttons["edit"] = QAction(QIcon(join(pypath, "icons","edit_small.png")), _("Edit Name"), self.collectorContext) - self.collectorContext.buttons["restart"] = QAction(QIcon(join(pypath, "icons","refresh_small.png")), _("Refresh Status"), self.collectorContext) - self.collectorContext.buttons["refresh"] = QAction(_("Refresh Status"), self.collectorContext) + self.collectorContext.buttons["restart"] = QAction(QIcon(join(pypath, "icons","refresh_small.png")), _("Restart"), self.collectorContext) + self.collectorContext.buttons["refresh"] = QAction(QIcon(join(pypath, "icons","refresh1_small.png")),_("Refresh Status"), self.collectorContext) self.collectorContext.addAction(self.collectorContext.buttons["push"]) + self.collectorContext.addSeparator() + self.collectorContext.buttons["add"] = self.collectorContext.addMenu(QIcon(join(pypath, "icons","add_small.png")), _("Add")) self.collectorContext.addAction(self.collectorContext.buttons["edit"]) self.collectorContext.addAction(self.collectorContext.buttons["remove"]) self.collectorContext.addAction(self.collectorContext.buttons["restart"]) + self.collectorContext.addSeparator() self.collectorContext.addAction(self.collectorContext.buttons["refresh"]) + packageAction = self.collectorContext.buttons["add"].addAction(_("Package")) + containerAction = self.collectorContext.buttons["add"].addAction(_("Container")) self.connect(self.collectorContext.buttons["remove"], SIGNAL("triggered()"), self.slotRemoveDownload) self.connect(self.collectorContext.buttons["push"], SIGNAL("triggered()"), self.slotPushPackageToQueue) self.connect(self.collectorContext.buttons["edit"], SIGNAL("triggered()"), self.slotEditPackage) self.connect(self.collectorContext.buttons["restart"], SIGNAL("triggered()"), self.slotRestartDownload) self.connect(self.collectorContext.buttons["refresh"], SIGNAL("triggered()"), self.slotRefreshPackage) + self.connect(packageAction, SIGNAL("triggered()"), self.slotShowAddPackage) + self.connect(containerAction, SIGNAL("triggered()"), self.slotShowAddContainer) self.accountContext = QMenu() self.accountContext.buttons = {} + self.accountContext.buttons["add"] = QAction(QIcon(join(pypath, "icons","add_small.png")), _("Add"), self.accountContext) self.accountContext.buttons["remove"] = QAction(QIcon(join(pypath, "icons","remove_small.png")), _("Remove"), self.accountContext) self.accountContext.buttons["edit"] = QAction(QIcon(join(pypath, "icons","edit_small.png")), _("Edit"), self.accountContext) + self.accountContext.addAction(self.accountContext.buttons["add"]) self.accountContext.addAction(self.accountContext.buttons["edit"]) self.accountContext.addAction(self.accountContext.buttons["remove"]) + self.connect(self.accountContext.buttons["add"], SIGNAL("triggered()"), self.slotNewAccount) self.connect(self.accountContext.buttons["edit"], SIGNAL("triggered()"), self.slotEditAccount) self.connect(self.accountContext.buttons["remove"], SIGNAL("triggered()"), self.slotRemoveAccount) @@ -414,16 +426,25 @@ class MainWindow(QMainWindow): for child in item.children: if child.data["downloading"]: showAbort = True + break if showAbort: - self.queueContext.buttons["abort"].setVisible(True) + self.queueContext.buttons["abort"].setEnabled(True) else: - self.queueContext.buttons["abort"].setVisible(False) + self.queueContext.buttons["abort"].setEnabled(False) if isinstance(item, Package): self.queueContext.index = i - self.queueContext.buttons["edit"].setVisible(True) + self.queueContext.buttons["remove"].setEnabled(True) + self.queueContext.buttons["restart"].setEnabled(True) + self.queueContext.buttons["pull"].setEnabled(True) + self.queueContext.buttons["edit"].setEnabled(True) + self.queuePriorityMenu.setEnabled(True) else: self.queueContext.index = None - self.queueContext.buttons["edit"].setVisible(False) + self.queueContext.buttons["remove"].setEnabled(False) + self.queueContext.buttons["restart"].setEnabled(False) + self.queueContext.buttons["pull"].setEnabled(False) + self.queueContext.buttons["edit"].setEnabled(False) + self.queuePriorityMenu.setEnabled(False) self.queueContext.exec_(menuPos) def slotCollectorContextMenu(self, pos): @@ -440,10 +461,16 @@ class MainWindow(QMainWindow): self.activeMenu = self.collectorContext if isinstance(item, Package): self.collectorContext.index = i - self.collectorContext.buttons["edit"].setVisible(True) + self.collectorContext.buttons["edit"].setEnabled(True) + self.collectorContext.buttons["remove"].setEnabled(True) + self.collectorContext.buttons["push"].setEnabled(True) + self.collectorContext.buttons["restart"].setEnabled(True) else: self.collectorContext.index = None - self.collectorContext.buttons["edit"].setVisible(False) + self.collectorContext.buttons["edit"].setEnabled(False) + self.collectorContext.buttons["remove"].setEnabled(False) + self.collectorContext.buttons["push"].setEnabled(False) + self.collectorContext.buttons["restart"].setEnabled(False) self.collectorContext.exec_(menuPos) def slotLinkCollectorContextMenu(self, pos): @@ -547,7 +574,11 @@ class MainWindow(QMainWindow): def slotEditAccount(self): types = self.connector.proxy.get_accounts(False, False).keys() - data = self.tabs["accounts"]["view"].selectedIndexes()[0].internalPointer() + data = self.tabs["accounts"]["view"].selectedIndexes() + if len(data) < 1: + return + + data = data[0].internalPointer() self.accountEdit = AccountEdit.editAccount(types, data) @@ -559,7 +590,11 @@ class MainWindow(QMainWindow): self.accountEdit.show() def slotRemoveAccount(self): - data = self.tabs["accounts"]["view"].selectedIndexes()[0].internalPointer() + data = self.tabs["accounts"]["view"].selectedIndexes() + if len(data) < 1: + return + + data = data[0].internalPointer() self.connector.proxy.remove_account(data["type"], data["login"]) @@ -568,12 +603,21 @@ class MainWindow(QMainWindow): i = self.tabs["accounts"]["view"].indexAt(pos) if not i: return + data = i.internalPointer() + + if data is None: + self.accountContext.buttons["edit"].setEnabled(False) + self.accountContext.buttons["remove"].setEnabled(False) + else: + self.accountContext.buttons["edit"].setEnabled(True) + self.accountContext.buttons["remove"].setEnabled(True) + menuPos = QCursor.pos() menuPos.setX(menuPos.x()+2) self.accountContext.exec_(menuPos) -class Priorty(): +class Priority(): def __init__(self, win): self.w = win diff --git a/module/plugins/accounts/DepositfilesCom.py b/module/plugins/accounts/DepositfilesCom.py index 4a5792c40..b0730de8e 100644 --- a/module/plugins/accounts/DepositfilesCom.py +++ b/module/plugins/accounts/DepositfilesCom.py @@ -42,4 +42,6 @@ class DepositfilesCom(Account): def login(self, user, data, req): req.load("http://depositfiles.com/de/gold/payment.php") - req.load("http://depositfiles.com/de/login.php", get={"return": "/de/gold/payment.php"}, post={"login": user, "password": data["password"]}) + src = req.load("http://depositfiles.com/de/login.php", get={"return": "/de/gold/payment.php"}, post={"login": user, "password": data["password"]}) + if r'
Sie haben eine falsche Benutzername-Passwort-Kombination verwendet.
' in src: + self.wrongPassword() diff --git a/module/plugins/hoster/MegauploadCom.py b/module/plugins/hoster/MegauploadCom.py index 1cc3c7aaf..7993233dc 100644 --- a/module/plugins/hoster/MegauploadCom.py +++ b/module/plugins/hoster/MegauploadCom.py @@ -101,6 +101,9 @@ class MegauploadCom(Hoster): count = 0 if "The file that you're trying to download is larger than 1 GB" in self.html[0]: self.fail(_("You need premium to download files larger than 1 GB")) + + if r'Please enter the password below to proceed' in self.html[0]: + self.fail(_("The file is password protected")) while "document.location='http://www.megaupload.com/?c=msg" in self.html[0]: # megaupload.com/?c=msg usually says: Please check back in 2 minutes, -- cgit v1.2.3