myexperiment-hackers
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[myexperiment-hackers] [1959] branches/event_logging: Subscriptions.


From: noreply
Subject: [myexperiment-hackers] [1959] branches/event_logging: Subscriptions.
Date: Thu, 13 Nov 2008 06:26:43 -0500 (EST)

Revision
1959
Author
alekses6
Date
2008-11-13 06:26:43 -0500 (Thu, 13 Nov 2008)

Log Message

Subscriptions. Added RSS feed for latest reviews.

Modified Paths

Added Paths

Diff

Modified: branches/event_logging/app/controllers/home_controller.rb (1958 => 1959)


--- branches/event_logging/app/controllers/home_controller.rb	2008-11-13 11:01:09 UTC (rev 1958)
+++ branches/event_logging/app/controllers/home_controller.rb	2008-11-13 11:26:43 UTC (rev 1959)
@@ -8,6 +8,7 @@
   before_filter :find_latest_public_updated_items_rss, : [:updated_items_rss]
   before_filter :find_latest_tags_rss, : [:latest_tags_rss]
   before_filter :find_latest_comments_rss, : [:latest_comments_rss]
+  before_filter :find_latest_reviews_rss, : [:latest_reviews_rss]
   
   # GET /home
   def index
@@ -56,7 +57,15 @@
     end
   end
   
+  def latest_reviews_rss
+    respond_to do |format|
+      format.rss do 
+        render :action ="" 'latest_reviews.rxml', :layout => false
+      end
+    end
+  end
   
+  
 protected
 
   def find_latest_public_updated_items_rss
@@ -97,4 +106,16 @@
     end
   end
   
+  def find_latest_reviews_rss
+    # Only carry out if request is for RSS
+    if params[:format] and params[:format].downcase == 'rss'
+      @latest_reviews_rss = {}
+      reviews = Review.latest(DEFAULT_RSS_ENTRY_COUNT)
+      reviews.each do |r|
+        # commented item should be authorized for anonymous users to view
+        @latest_reviews_rss[r] = r.reviewable if r.reviewable.authorized?("show", nil)
+      end
+    end
+  end
+  
 end

Modified: branches/event_logging/app/views/home/_latest_reviews.rhtml (1958 => 1959)


--- branches/event_logging/app/views/home/_latest_reviews.rhtml	2008-11-13 11:01:09 UTC (rev 1958)
+++ branches/event_logging/app/views/home/_latest_reviews.rhtml	2008-11-13 11:26:43 UTC (rev 1959)
@@ -3,7 +3,7 @@
 	<div class="box">
 		<b class="xtop"><b class="xb1"></b><b class="xb2"></b><b class="xb3"></b><b class="xb4"></b></b>
 		<div class="box_title">
-			Latest Reviews
+			<%= feed_icon_tag("Latest Reviews on myExperiment", home_latest_reviews_rss_url) -%>&nbsp;Latest Reviews
 		</div>
 		<div class="content">
 			<% unless (reviews = Review.latest).empty? %>

Added: branches/event_logging/app/views/home/latest_reviews.rxml (0 => 1959)


--- branches/event_logging/app/views/home/latest_reviews.rxml	                        (rev 0)
+++ branches/event_logging/app/views/home/latest_reviews.rxml	2008-11-13 11:26:43 UTC (rev 1959)
@@ -0,0 +1,11 @@
+xml.rss "version" => "2.0", 'xmlns:opensearch' => "http://a9.com/-/spec/opensearch/1.1/", 'xmlns:atom' => "http://www.w3.org/2005/Atom" do
+  xml.channel do
+    xml.title "myExperiment.org - Latest Reviews"
+    xml.link url_for(:controller => 'home', :action ="" 'index')
+    xml.language "en-us"
+    xml.ttl "60"
+    xml.tag! "atom:link", :rel => 'search', :type => 'application/opensearchdescription+xml', :href ="" "http://#{request.host_with_port}/open_search.xml"
+    xml.description "RSS feed listing the most recently added reviews on myExperiment.org"
+    render(:partial => "layouts/review", :collection => @latest_reviews_rss, :locals => { :xm => xml })
+  end
+end
\ No newline at end of file

Added: branches/event_logging/app/views/layouts/_review.rxml (0 => 1959)


--- branches/event_logging/app/views/layouts/_review.rxml	                        (rev 0)
+++ branches/event_logging/app/views/layouts/_review.rxml	2008-11-13 11:26:43 UTC (rev 1959)
@@ -0,0 +1,22 @@
+xm.item do
+  review_instance = review[0]
+  review_maker = review_instance.user
+  
+  reviewed_item = review[1]
+  item_name = contributable_name_from_instance(reviewed_item)
+  item_type = visible_name(reviewed_item)
+  item_icon = image_tag(method_to_icon_filename(reviewed_item.class.to_s.downcase), :style => "vertical-align: middle;", :alt => item_type) 
+
+  xm.title "#{h(review_maker.name)} reviewed \"#{h(item_name)}\" #{item_type}"
+  
+  review_desc = "#{name(review_maker, nil, false)} reviewed #{item_icon}#{link_to item_name, contributable_url(review_instance.reviewable_id, review_instance.reviewable_type)} #{item_type}:"
+  review_body = "<br/><b>Title: </b>" + ((review_instance.title.nil? || review_instance.title.blank?) ? "<i>None</i>" : review_instance.title)
+  review_body += "<blockquote style='border: 1px dotted #999999; padding: 0.5em 0.8em; width: 600px;'>"
+  review_body += review_instance.review + "</blockquote>"
+  xm.description white_list(review_desc + review_body)
+  
+  xm.pubDate review_instance.created_at.rfc822
+  xm.guid [request.host_with_port, "review", review_instance.id.to_s].join(":"), "isPermaLink" => "false"
+  xm.author h(review_maker.name)
+  xm.link eval("#{item_type.downcase}_review_url(#{reviewed_item.id},#{review_instance.id})")
+end
\ No newline at end of file

Modified: branches/event_logging/config/routes.rb (1958 => 1959)


--- branches/event_logging/config/routes.rb	2008-11-13 11:01:09 UTC (rev 1958)
+++ branches/event_logging/config/routes.rb	2008-11-13 11:26:43 UTC (rev 1959)
@@ -240,6 +240,7 @@
   map.home_latest_groups_rss 'home/latest_groups.rss', :controller => 'home', :action ="" 'latest_groups_rss', :format => 'rss'
   map.home_latest_tags_rss 'home/latest_tags.rss', :controller => 'home', :action ="" 'latest_tags_rss', :format => 'rss'
   map.home_latest_comments_rss 'home/latest_comments.rss', :controller => 'home', :action ="" 'latest_comments_rss', :format => 'rss'
+  map.home_latest_reviews_rss 'home/latest_reviews.rss', :controller => 'home', :action ="" 'latest_reviews_rss', :format => 'rss'
 
   # Install the default route as the lowest priority.
   map.connect ':controller/:action/:id'

reply via email to

[Prev in Thread] Current Thread [Next in Thread]