Mercurial > hg > Feedworm
view MainWindow.py @ 217:bb3c851b18b1
add source file endcoding header
author | Dirk Olmes <dirk@xanthippe.ping.de> |
---|---|
date | Sun, 27 Apr 2014 05:33:34 +0200 |
parents | 9bc4b2465435 |
children | 699d8f1cebd4 |
line wrap: on
line source
# -*- coding: utf-8 -*- from AddFeed import AddFeed from DisplayModel import DisplayModel from FeedEntryItemDelegate import FeedEntryItemDelegate from FeedEntryTableModel import FeedEntryTableModel from FeedSettings import FeedSettings from PreferencesDialog import PreferencesDialog from PyQt4.QtCore import QUrl from PyQt4.QtGui import QApplication from PyQt4.QtGui import QMainWindow from PyQt4.QtGui import QWidget from Ui_MainWindow import Ui_MainWindow import subprocess STATUS_MESSAGE_DISPLAY_MILLIS = 20000 class MainWindow(QMainWindow): def __init__(self, backend=None): QWidget.__init__(self, None) self.backend = backend self.preferences = backend.preferences() self.ui = Ui_MainWindow() self.ui.setupUi(self) self.updateFeedList() self.initFeedEntryList() def updateFeedList(self): allFeeds = self.backend.getFeeds() feedModel = DisplayModel(self, allFeeds, "title") self.ui.feedList.setModel(feedModel) self.ui.feedList.update() def initFeedEntryList(self): # setup the default row height. This must be called before a table model is set self.ui.feedEntryList.verticalHeader().setDefaultSectionSize(20) self.ui.feedEntryList.setItemDelegate(FeedEntryItemDelegate()) self.ui.feedEntryList.setModel(FeedEntryTableModel([])) self.ui.feedEntryList.horizontalHeader().setStretchLastSection(True) def feedSelected(self, index): self.backend.selectFeed(index.row()) self.enableFeedRelatedWidgets() self.setupFeedEntries() def enableFeedRelatedWidgets(self): self.ui.actionFeedSettings.setEnabled(True) self.ui.actionMarkFeedRead.setEnabled(True) self.ui.actionMarkSelectedEntriesRead.setEnabled(True) self.ui.actionDeleteFeed.setEnabled(True) def setupFeedEntries(self): self.setupFeedEntriesTableModel() self.ui.feedEntryList.update() self.setupFeedEntriesTableHeaderWidths() self.scrollFirstRowInFeedEntriesTableToVisible() def setupFeedEntriesTableModel(self): feedEntries = self.backend.entriesForSelectedFeed() model = FeedEntryTableModel(feedEntries) self.ui.feedEntryList.setModel(model) def setupFeedEntriesTableHeaderWidths(self): width = self.ui.feedEntryList.width() firstColumnWidth = int(width * 0.8) self.ui.feedEntryList.setColumnWidth(0, firstColumnWidth) def scrollFirstRowInFeedEntriesTableToVisible(self): model = self.ui.feedEntryList.model() visibleIndex = model.createIndex(0, 0) self.ui.feedEntryList.scrollTo(visibleIndex) def feedEntrySelected(self, index): self.ui.webView.setZoomFactor(1.0) self.ui.menuArticle.setEnabled(True) self.ui.actionOpenLink.setEnabled(True) row = index.row() self.backend.selectFeedEntry(row) if self.backend.selectedFeed.auto_load_entry_link: self.openLinkFromSelectedEntry() else: self.openSummaryFromSelectedEntry() def feedEntryDoubleClicked(self, index): self.ui.menuArticle.setEnabled(True) self.openSelectedEntryInBrowser() def openSummaryFromSelectedEntry(self): # TODO: this is the wrong base url, figure out the correct one feedEntry = self.backend.selectedFeedEntry baseUrl = QUrl(feedEntry.link) self.ui.webView.setHtml(feedEntry.summary, baseUrl) def openLinkFromSelectedEntry(self): if self.backend.selectedFeed.always_open_in_browser: self.openSelectedEntryInBrowser() else: self.openSelectedEntryInWebView() def openSelectedEntryInWebView(self): feedEntry = self.backend.selectedFeedEntry message = "Open %s ..." % (feedEntry.title) self._updateStatusBar(message) url = QUrl(feedEntry.link) self.ui.webView.load(url) self.ui.webView.show() def openSelectedEntryInBrowser(self): feedEntry = self.backend.selectedFeedEntry message = "Open %s in external browser" % (feedEntry.title) self._updateStatusBar(message) # TODO: make browser configurable browser = "/usr/bin/chromium" subprocess.Popen([browser, feedEntry.link]) def toggleReadOnSelectedEntry(self): self.backend.toggleSelectedFeedEntryRead() self.ui.feedEntryList.doItemsLayout() def markSelectedFeedRead(self): self.backend.markSelectedFeedAsRead() self.ui.feedEntryList.doItemsLayout() def markSelectedEntriesRead(self): indexes = [] selectedIndexes = self.ui.feedEntryList.selectedIndexes() for index in selectedIndexes: # selectedIndexes returns one QModelIndex instance per row/column combo. # We are only interested in the rows here so just operate on the first # column if index.column() == 0: row = index.row() indexes.append(row) self.backend.markFeedEntriesAsRead(indexes) self.ui.feedEntryList.doItemsLayout() def addFeed(self): addFeed = AddFeed(self.backend) success = addFeed.exec_() if not success: return if addFeed.exception is not None: message = "Error while adding feed: " + str(addFeed.exception) self._updateStatusBar(message) else: self.updateFeedList() def deleteFeed(self): try: self.backend.deleteSelectedFeed() self.updateFeedList() except Exception as exception: message = "Error while deleting feed: " + str(exception) self._updateStatusBar(message) def showPreferences(self): preferences = PreferencesDialog(self.backend) preferences.exec_() def showFeedSettings(self): feedSettings = FeedSettings(self.backend) feedSettings.exec_() def _updateStatusBar(self, message): self.ui.statusbar.showMessage(message, STATUS_MESSAGE_DISPLAY_MILLIS) def close(self): self.backend.dispose() QMainWindow.close(self) def copyArticleURLToClipboard(self): clipboard = QApplication.clipboard() clipboard.setText(self.backend.selectedFeedEntry.link) def zoomIn(self): zoom = self.ui.webView.zoomFactor() + 0.1 self.ui.webView.setZoomFactor(zoom) def zoomOut(self): zoom = self.ui.webView.zoomFactor() - 0.1 self.ui.webView.setZoomFactor(zoom)