Reduce number of nearby people listed to the closest 5 by default, and show friends...
authorDan Karran <dan@karran.net>
Wed, 10 Oct 2007 19:22:16 +0000 (19:22 +0000)
committerDan Karran <dan@karran.net>
Wed, 10 Oct 2007 19:22:16 +0000 (19:22 +0000)
app/models/user.rb
app/views/user/view.rhtml

index c4b81e7abdb66d26db556237e5500a670e9d2fc5..e55f373b7456e7567031c7fcab332f15c76e9f14 100644 (file)
@@ -72,11 +72,11 @@ class User < ActiveRecord::Base
     return el1
   end
 
-  def nearby(radius = 50)
+  def nearby(radius = 50, num = 5)
     if self.home_lon and self.home_lat 
       gc = OSM::GreatCircle.new(self.home_lat, self.home_lon)
       bounds = gc.bounds(radius)
-      nearby = User.find(:all, :conditions => "home_lat between #{bounds[:minlat]} and #{bounds[:maxlat]} and home_lon between #{bounds[:minlon]} and #{bounds[:maxlon]} and data_public = 1 and id != #{self.id}")
+      nearby = User.find(:all, :conditions => "home_lat between #{bounds[:minlat]} and #{bounds[:maxlat]} and home_lon between #{bounds[:minlon]} and #{bounds[:maxlon]} and data_public = 1 and id != #{self.id}", :limit => num)
       nearby.delete_if { |u| gc.distance(u.home_lat, u.home_lon) > radius }
       nearby.sort! { |u1,u2| gc.distance(u1.home_lat, u1.home_lon) <=> gc.distance(u2.home_lat, u2.home_lon) }
     else
index d0600bb8d5d60dea81862f454afe3b0a365c8046..93bed72b083ff8be308ee191b754479708032179 100644 (file)
   You can set your home location on your <%= link_to 'settings', :controller => 'user', :action => 'account', :display_name => @user.display_name %> page.
   <% end %>
 <% else %>
-  Nearby users:<br/>
-  <% if @this_user.nearby.empty? %>
-    There are no users who admit to mapping nearby yet.
-  <% else %>
-    <table id="nearbyusers">
-    <% @this_user.nearby.each do |nearby| %>
-    <tr>
-    <td class="username"><%= link_to nearby.display_name, :controller => 'user', :action => 'view',  :display_name => nearby.display_name %></td>
-    <td><%= @this_user.distance(nearby).round %>km away</td>
-    <td class="message">(<%= link_to 'send message', :controller => 'message', :action => 'new', :user_id => nearby.id %>)</td>
-    </tr>
-    <%end%>
-    </table>
-  <%end%>
 
   <% if @user and @this_user.id == @user.id %>
-    <br/>
     Your friends:<br/>
     <% if @this_user.friends.empty? %>
       You have not added any friends yet.
       <%end%>
       </table>
     <%end%>
+    <br/>
+  <%end%>
+
+  Nearby users:<br/>
+  <% if @this_user.nearby.empty? %>
+    There are no users who admit to mapping nearby yet.
+  <% else %>
+    <table id="nearbyusers">
+    <% @this_user.nearby.each do |nearby| %>
+    <tr>
+    <td class="username"><%= link_to nearby.display_name, :controller => 'user', :action => 'view',  :display_name => nearby.display_name %></td>
+    <td><%= @this_user.distance(nearby).round %>km away</td>
+    <td class="message">(<%= link_to 'send message', :controller => 'message', :action => 'new', :user_id => nearby.id %>)</td>
+    </tr>
+    <%end%>
+    </table>
   <%end%>
+
 <% end %>