changeset 61:db35ab7753f0

add a preference to hide read feed entries
author Dirk Olmes <dirk@xanthippe.ping.de>
date Sat, 24 Jul 2010 03:11:06 +0200 (2010-07-24)
parents d063e4814357
children abc0516a1c0c
files .settings/org.eclipse.core.resources.prefs Feed.py MainWindow.py Preferences.py PreferencesDialog.py Ui_Preferences.ui
diffstat 6 files changed, 75 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/.settings/org.eclipse.core.resources.prefs	Fri Jul 23 17:41:05 2010 +0200
+++ b/.settings/org.eclipse.core.resources.prefs	Sat Jul 24 03:11:06 2010 +0200
@@ -1,5 +1,6 @@
-#Sun May 16 08:17:30 CEST 2010
+#Sat Jul 24 02:23:01 CEST 2010
 eclipse.preferences.version=1
 encoding/Ui_AddFeed.py=utf-8
 encoding/Ui_FeedSettings.py=utf-8
 encoding/Ui_MainWindow.py=utf-8
+encoding/Ui_Preferences.py=utf-8
--- a/Feed.py	Fri Jul 23 17:41:05 2010 +0200
+++ b/Feed.py	Sat Jul 24 03:11:06 2010 +0200
@@ -21,11 +21,20 @@
     def userPresentableString(self):
         return self.title
     
-    def entriesSortedByUpdateDate(self):
+    def entriesSortedByUpdateDate(self, hideReadEntries=False):
         sortedEntries = list(self.entries)
         sortedEntries.sort(FeedEntry.compareByUpdateDate)
+        if hideReadEntries:
+            return self._filterReadEntries(sortedEntries)
         return sortedEntries
 
+    def _filterReadEntries(self, entries):
+        retValue = []
+        for entry in entries:
+            if not entry.read:
+                retValue.append(entry)
+        return retValue
+
     def incrementNextUpdateDate(self):
         delta = timedelta(minutes=self.update_interval)
         self.next_update = datetime.now() + delta
--- a/MainWindow.py	Fri Jul 23 17:41:05 2010 +0200
+++ b/MainWindow.py	Sat Jul 24 03:11:06 2010 +0200
@@ -5,6 +5,7 @@
 from FeedEntry import FeedEntry
 from FeedEntryItemDelegate import FeedEntryItemDelegate
 from FeedSettings import FeedSettings
+from Preferences import Preferences
 from PreferencesDialog import PreferencesDialog
 from PyQt4 import QtGui
 from PyQt4.QtCore import QUrl
@@ -17,6 +18,7 @@
     def __init__(self, session=None):
         QtGui.QWidget.__init__(self, None)
         self.session = session
+        self.preferences = Preferences(session)
         self.ui = Ui_MainWindow()
         self.ui.setupUi(self)
         self.updateFeedList()
@@ -33,21 +35,29 @@
 
     def feedSelected(self, index):
         self.selectedFeed = self.allFeeds[index.row()]
+        self.enableFeedRelatedWidgets()
+        self.setupFeedEntries()
 
+    def enableFeedRelatedWidgets(self):
         self.ui.actionFeedSettings.setEnabled(True)
         self.ui.actionMarkFeedRead.setEnabled(True)
+
+    def setupFeedEntries(self):
+        hideReadEntries = self.preferences.hideReadFeedEntries()
+        self.feedEntries = self.selectedFeed.entriesSortedByUpdateDate(hideReadEntries)
+        self.initFeedDisplayModel()
         
-        self.sortedEntries = self.selectedFeed.entriesSortedByUpdateDate()
-        model = DisplayModel(self, self.sortedEntries, FeedEntry.userPresentableString)
+    def initFeedDisplayModel(self):
+        model = DisplayModel(self, self.feedEntries, FeedEntry.userPresentableString)
         self.ui.feedEntryList.setModel(model)
-        self.ui.feedEntryList.itemDelegate().entries = self.sortedEntries
+        self.ui.feedEntryList.itemDelegate().entries = self.feedEntries
         self.ui.feedEntryList.update()
-        
+     
     def feedEntrySelected(self, index):
         self.ui.menuArticle.setEnabled(True)
         
         row = index.row()
-        self.selectedEntry = self.sortedEntries[row]
+        self.selectedEntry = self.feedEntries[row]
         self.selectedEntry.markRead()
         
         if self.selectedEntry.feed.auto_load_entry_link:
--- a/Preferences.py	Fri Jul 23 17:41:05 2010 +0200
+++ b/Preferences.py	Sat Jul 24 03:11:06 2010 +0200
@@ -3,6 +3,7 @@
 import util
 
 START_MAXIMIZED = "START_MAXIMIZED"
+HIDE_READ_ENTRIES = "HIDE_READ_FEED_ENTRIES"
 
 class Preferences(object):
     def __init__(self, session):
@@ -27,3 +28,11 @@
     def setStartMaximized(self, flag):
         pref = self._cachedPreference(START_MAXIMIZED)
         pref.value = util.bool2str(flag)
+
+    def hideReadFeedEntries(self):
+        pref = self._cachedPreference(HIDE_READ_ENTRIES, False)
+        return util.str2bool(pref.value)
+    
+    def setHideReadFeedEntries(self, flag):
+        pref = self._cachedPreference(HIDE_READ_ENTRIES)
+        pref.value = util.bool2str(flag)
--- a/PreferencesDialog.py	Fri Jul 23 17:41:05 2010 +0200
+++ b/PreferencesDialog.py	Sat Jul 24 03:11:06 2010 +0200
@@ -15,6 +15,9 @@
     def fillUi(self):
         maximized = self.preferences.startMaximized()
         self.ui.startMaximized.setChecked(maximized)
+        
+        hideRead = self.preferences.hideReadFeedEntries()
+        self.ui.hideReadFeedEntries.setChecked(hideRead)
 
     def startMaximizedChanged(self, change):
         if change:
@@ -22,6 +25,12 @@
         else:
             self.preferences.setStartMaximized(False)
 
+    def hideReadFeedEntriesChanged(self, change):
+        if change:
+            self.preferences.setHideReadFeedEntries(True)
+        else:
+            self.preferences.setHideReadFeedEntries(False)
+
     def accept(self):
         self.session.commit()
         QtGui.QDialog.accept(self)
--- a/Ui_Preferences.ui	Fri Jul 23 17:41:05 2010 +0200
+++ b/Ui_Preferences.ui	Sat Jul 24 03:11:06 2010 +0200
@@ -46,6 +46,19 @@
     <string>Start maximized</string>
    </property>
   </widget>
+  <widget class="QCheckBox" name="hideReadFeedEntries">
+   <property name="geometry">
+    <rect>
+     <x>10</x>
+     <y>40</y>
+     <width>171</width>
+     <height>22</height>
+    </rect>
+   </property>
+   <property name="text">
+    <string>Hide read feed entries</string>
+   </property>
+  </widget>
  </widget>
  <resources>
   <include location="Feedworm.qrc"/>
@@ -99,8 +112,25 @@
     </hint>
    </hints>
   </connection>
+  <connection>
+   <sender>hideReadFeedEntries</sender>
+   <signal>stateChanged(int)</signal>
+   <receiver>Preferences</receiver>
+   <slot>hideReadFeedEntriesChanged()</slot>
+   <hints>
+    <hint type="sourcelabel">
+     <x>95</x>
+     <y>50</y>
+    </hint>
+    <hint type="destinationlabel">
+     <x>199</x>
+     <y>149</y>
+    </hint>
+   </hints>
+  </connection>
  </connections>
  <slots>
   <slot>startMaximizedChanged()</slot>
+  <slot>hideReadFeedEntriesChanged()</slot>
  </slots>
 </ui>