我有一条名为 Feeds 的记录,其中包含“last_visited”和“last_modified”字段,两者都是时间戳。
我正在尝试在 last_modified > last_visited 的所有 Feed 视图中呈现列表。
我目前有这个:
控制器
@feeds = @user.feeds
@feeds_hot = @feeds.where(['@feeds.last_modified > ?', @feeds.last_visited])
有一种感觉,我在这里偏离了轨道。我是否也应该使用模型类来做到这一点?
非常感谢任何帮助。
编辑:
这是我的模型
class Feed < ActiveRecord::Base
attr_accessible :feed_id, :feed_url, :last_modified, :title, :url, :last_visited, :user_id
belongs_to :user
scope :hottest, lambda {where('last_modified > ?', :last_visited)}
def fetch_feed!
feed = Feedzirra::Feed.fetch_and_parse(feed_url) # probably want some eror handling here
self.title = feed.title
self.url = feed.url
self.last_modified = feed.last_modified
self.last_visited = feed.last_modified
self #or nil if you like
end
def self.check_for_update(feed)
fetched_feed = Feedzirra::Feed.fetch_and_parse(feed.feed_url)
entry = fetched_feed.entries.first
feed.last_modified = entry.published
end
def update_visit_date!
date = Time.now
update_attribute(:last_visited, date)
self
end
end
编辑
更新代码
控制器
def home
@user = current_user
@feeds = @user.feeds
@feeds_hot = @feeds.hottest
end
模型
attr_accessible :feed_id, :feed_url, :last_modified, :title, :url, :last_visited, :user_id
belongs_to :user
scope :hottest, lambda {where("'last_modified' > ?", 'last_visited')}
看法
%ol.feeds.feeds_hot
- @feeds_hot.each do |feed|
%li.feed.hot[feed]
= render :partial => 'feeds/feed_link', :locals => {:feed => feed}
不幸的是,当我有包含以下数据的提要时,它仍然没有在视图中呈现热门提要:
Last Modified 2013-06-14 23:49:07 UTC
Last Visited 2013-06-14 23:47:55 UTC
上次修改时间比上次访问时间多几个小时