diff options
Diffstat (limited to 'module')
-rw-r--r-- | module/AccountManager.py | 10 | ||||
-rw-r--r-- | module/gui/MainWindow.py | 65 |
2 files changed, 69 insertions, 6 deletions
diff --git a/module/AccountManager.py b/module/AccountManager.py index d1733585f..a76a9915a 100644 --- a/module/AccountManager.py +++ b/module/AccountManager.py @@ -36,6 +36,7 @@ class AccountManager(): self.accounts = {} # key = ( plugin ) self.plugins = {} + self.accountInfoCache = {} self.initAccountPlugins() @@ -144,6 +145,7 @@ class AccountManager(): self.saveAccounts() p.getAllAccounts(force=True) + self.core.scheduler.addJob(0, self.core.accountManager.getAccountInfos) #---------------------------------------------------------------------- def removeAccount(self, plugin, user): @@ -153,13 +155,13 @@ class AccountManager(): p = self.getAccountPlugin(plugin) p.removeAccount(user) - cache = self.accountInfoCache - if self.cache.has_key(p.__name__): - if cache[p].has_key(user): - del cache[p][user] + if self.accounts.has_key(p): + if self.accounts[p].has_key(user): + del self.accounts[p][user] self.saveAccounts() p.getAllAccounts(force=True) + self.core.scheduler.addJob(0, self.core.accountManager.getAccountInfos) def getCachedAccountInfos(self, refresh=True): if refresh: diff --git a/module/gui/MainWindow.py b/module/gui/MainWindow.py index 12f883287..255f562a1 100644 --- a/module/gui/MainWindow.py +++ b/module/gui/MainWindow.py @@ -29,6 +29,7 @@ from module.gui.SettingsWidget import SettingsWidget from module.gui.Collector import CollectorView, Package, Link from module.gui.Queue import QueueView from module.gui.Accounts import AccountView +from module.gui.AccountEdit import AccountEdit class MainWindow(QMainWindow): def __init__(self, connector): @@ -129,10 +130,13 @@ class MainWindow(QMainWindow): self.connect(self.tabs["queue"]["view"], SIGNAL('customContextMenuRequested(const QPoint &)'), self.slotQueueContextMenu) self.connect(self.tabs["collector"]["package_view"], SIGNAL('customContextMenuRequested(const QPoint &)'), self.slotCollectorContextMenu) + self.connect(self.tabs["accounts"]["view"], SIGNAL('customContextMenuRequested(const QPoint &)'), self.slotAccountContextMenu) self.connect(self.tabw, SIGNAL("currentChanged(int)"), self.slotTabChanged) self.lastAddedID = None + + self.connector = connector def init_toolbar(self): """ @@ -196,8 +200,12 @@ class MainWindow(QMainWindow): #accounts self.tabs["accounts"]["view"] = AccountView(connector) - self.tabs["accounts"]["w"].setLayout(QHBoxLayout()) + self.tabs["accounts"]["w"].setLayout(QVBoxLayout()) self.tabs["accounts"]["w"].layout().addWidget(self.tabs["accounts"]["view"]) + newbutton = QPushButton(_("New Account")) + self.tabs["accounts"]["w"].layout().addWidget(newbutton) + self.connect(newbutton, SIGNAL("clicked()"), self.slotNewAccount) + self.tabs["accounts"]["view"].setContextMenuPolicy(Qt.CustomContextMenu) def init_context(self): """ @@ -250,15 +258,27 @@ 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["refresh"] = QAction(QIcon(join(pypath, "icons","refresh_small.png")), _("Refresh Status"), 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.addAction(self.collectorContext.buttons["push"]) self.collectorContext.addAction(self.collectorContext.buttons["edit"]) self.collectorContext.addAction(self.collectorContext.buttons["remove"]) + self.collectorContext.addAction(self.collectorContext.buttons["restart"]) self.collectorContext.addAction(self.collectorContext.buttons["refresh"]) 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.accountContext = QMenu() + self.accountContext.buttons = {} + 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["edit"]) + self.accountContext.addAction(self.accountContext.buttons["remove"]) + self.connect(self.accountContext.buttons["edit"], SIGNAL("triggered()"), self.slotEditAccount) + self.connect(self.accountContext.buttons["remove"], SIGNAL("triggered()"), self.slotRemoveAccount) def slotToggleStatus(self, status): """ @@ -512,6 +532,47 @@ class MainWindow(QMainWindow): pid = item.package.id self.emit(SIGNAL("refreshStatus"), pid) + def slotNewAccount(self): + types = self.connector.proxy.get_accounts(False, False).keys() + self.accountEdit = AccountEdit.newAccount(types) + + def save(data): + if data["password"]: + self.accountEdit.close() + self.connector.proxy.update_account(data["acctype"], data["login"], data["password"]) + + self.accountEdit.connect(self.accountEdit, SIGNAL("done"), save) + self.accountEdit.show() + + def slotEditAccount(self): + types = self.connector.proxy.get_accounts(False, False).keys() + + data = self.tabs["accounts"]["view"].selectedIndexes()[0].internalPointer() + + self.accountEdit = AccountEdit.editAccount(types, data) + + def save(data): + self.accountEdit.close() + self.connector.proxy.update_account(data["acctype"], data["login"], data["password"] if data["password"] else None) + + self.accountEdit.connect(self.accountEdit, SIGNAL("done"), save) + self.accountEdit.show() + + def slotRemoveAccount(self): + data = self.tabs["accounts"]["view"].selectedIndexes()[0].internalPointer() + + self.connector.proxy.remove_account(data["type"], data["login"]) + + def slotAccountContextMenu(self, pos): + globalPos = self.tabs["accounts"]["view"].mapToGlobal(pos) + i = self.tabs["accounts"]["view"].indexAt(pos) + if not i: + return + data = i.internalPointer() + menuPos = QCursor.pos() + menuPos.setX(menuPos.x()+2) + self.accountContext.exec_(menuPos) + class Priorty(): def __init__(self, win): self.w = win |