summaryrefslogtreecommitdiffstats
path: root/js/app/controllers/feedcontroller.coffee
diff options
context:
space:
mode:
authorBernhard Posselt <nukeawhale@gmail.com>2013-03-30 23:43:55 +0100
committerBernhard Posselt <nukeawhale@gmail.com>2013-04-02 10:38:00 +0200
commit635a9d779549832b4dacb2c5b9f4033d846bf154 (patch)
treeb473bad6fb12533ffc3165b01b883a6be9c98235 /js/app/controllers/feedcontroller.coffee
parentf1afe719bbe162d8737f1e5d65a4cff99979e5ff (diff)
split logic into business layers
Diffstat (limited to 'js/app/controllers/feedcontroller.coffee')
-rw-r--r--js/app/controllers/feedcontroller.coffee81
1 files changed, 15 insertions, 66 deletions
diff --git a/js/app/controllers/feedcontroller.coffee b/js/app/controllers/feedcontroller.coffee
index 82586378f..580bd4763 100644
--- a/js/app/controllers/feedcontroller.coffee
+++ b/js/app/controllers/feedcontroller.coffee
@@ -27,7 +27,7 @@ angular.module('News').factory '_FeedController', ->
constructor: (@$scope, @_folderModel, @_feedModel, @_active,
@_showAll, @_feedType, @_starredCount, @_persistence,
- @_itemModel) ->
+ @_folderBl, @_feedBl) ->
@_isAddingFolder = false
@_isAddingFeed = false
@@ -36,15 +36,24 @@ angular.module('News').factory '_FeedController', ->
@$scope.feeds = @_feedModel.getAll()
@$scope.folders = @_folderModel.getAll()
@$scope.feedType = @_feedType
+ @$scope.folderBl = @_folderBl
+ @$scope.feedBl = @_feedBl
- @$scope.isFeedActive = (type, id) =>
- return @isFeedActive(type, id)
@$scope.isShown = (type, id) =>
return @isShown(type, id)
- @$scope.getUnreadCount = (type, id) =>
- return @getUnreadCount(type, id)
+ @$scope.getUnreadCount = =>
+ return @_transFormCount(@_feedBl.getUnreadCount())
+
+ @$scope.getStarredCount = =>
+ return @_transFormCount(@_starredCount.getStarredCount())
+
+ @$scope.getFeedUnreadCount = (feedId) =>
+ return @_transFormCount(@_feedBl.getFeedUnreadCount(feedId))
+
+ @$scope.getUnreadCount = (folderId) =>
+ return @_transFormCount(@_folderBl.getFolderUnreadCount(folderId))
@$scope.isShowAll = =>
return @isShowAll()
@@ -120,17 +129,6 @@ angular.module('News').factory '_FeedController', ->
@_isAddingFolder = false
- toggleFolder: (folderId) ->
- folder = @_folderModel.getById(folderId)
-
- if angular.isDefined(folder)
- folder.open = !folder.open
- if folder.open
- @_persistence.openFolder(folder.id)
- else
- @_persistence.collapseFolder(folder.id)
-
-
isFeedActive: (type, id) ->
return type == @_active.getType() and id == @_active.getId()
@@ -155,18 +153,7 @@ angular.module('News').factory '_FeedController', ->
return @_showAll.getShowAll()
- getUnreadCount: (type, id) ->
- # TODO: use polymorphism instead of switches
- switch type
- when @_feedType.Subscriptions
- count = @_feedModel.getUnreadCount()
- when @_feedType.Starred
- count = @_starredCount.getStarredCount()
- when @_feedType.Feed
- count = @_feedModel.getFeedUnreadCount(id)
- when @_feedType.Folder
- count = @_feedModel.getFolderUnreadCount(id)
-
+ _transFormCount: (count) ->
if count > 999
count = '999+'
@@ -184,44 +171,6 @@ angular.module('News').factory '_FeedController', ->
@_persistence.getItems(type, id, 0, null, lastModified)
- hasFeeds: (folderId) ->
- return @_feedModel.getAllOfFolder(folderId).length
-
-
- delete: (type, id) ->
- # TODO: use polymorphism instead of switches
- switch type
- when @_feedType.Feed
- count = @_feedModel.removeById(id)
- @_persistence.deleteFeed(id)
- when @_feedType.Folder
- count = @_folderModel.removeById(id)
- @_persistence.deleteFolder(id)
-
-
- markAllRead: (type, id) ->
- # TODO: use polymorphism instead of switches
- switch type
- when @_feedType.Subscriptions
- for feed in @_feedModel.getAll()
- @markAllRead(@_feedType.Feed, feed.id)
- when @_feedType.Feed
- feed = @_feedModel.getById(id)
- if angular.isDefined(feed)
- feed.unreadCount = 0
- # TODO: also update items in the right field if id is the
- # the same
- highestItemId = @_itemModel.getHighestId()
- @_persistence.setFeedRead(id, highestItemId)
- when @_feedType.Folder
- for feed in @_feedModel.getAllOfFolder(id)
- @markAllRead(@_feedType.Feed, feed.id)
-
-
- getFeedsOfFolder: (folderId) ->
- return @_feedModel.getAllOfFolder(folderId)
-
-
setShowAll: (showAll) ->
@_showAll.setShowAll(showAll)
if showAll