X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/eac7348ad2793cb3ad72c68bef84ff863af92d5f..09895069c5508d5e656d938166f45755cceb7d35:/app/controllers/map_bugs_controller.rb?ds=sidebyside
diff --git a/app/controllers/map_bugs_controller.rb b/app/controllers/map_bugs_controller.rb
index ef965ea3c..6224a8727 100644
--- a/app/controllers/map_bugs_controller.rb
+++ b/app/controllers/map_bugs_controller.rb
@@ -20,6 +20,10 @@ class MapBugsController < ApplicationController
max_lon = params['r'].to_f
min_lat = params['b'].to_f
max_lat = params['t'].to_f
+
+ limit = 100;
+ limit = params['limit'] if ((params['limit']) && (params['limit'].to_i < 10000) && (params['limit'].to_i > 0))
+
# check boundary is sane and area within defined
# see /config/application.yml
@@ -30,25 +34,16 @@ class MapBugsController < ApplicationController
return
end
- bugs = MapBug.find_by_area(min_lat, min_lon, max_lat, max_lon, :order => "last_changed DESC", :limit => 100, :conditions => "status != 'hidden'")
+ @bugs = MapBug.find_by_area(min_lat, min_lon, max_lat, max_lon, :order => "last_changed DESC", :limit => limit, :conditions => "status != 'hidden'")
- resp = ""
-
- bugs.each do |bug|
- resp += "putAJAXMarker(" + bug.id.to_s + ", " + bug.lon.to_s + ", " + bug.lat.to_s;
- comment_no = 1
- bug.map_bug_comment.each do |comment|
- resp += (comment_no == 1 ? ", '" : "
")
- resp += comment.comment if comment.comment
- resp += " [ "
- resp += comment.commenter_name if comment.commenter_name
- resp += " " + comment.date_created.to_s + " ]"
- comment_no += 1
- end
- resp += (comment_no == 1 ? "," : "', ") + (bug.status=="open"?"0":"1") + ");\n"
+ respond_to do |format|
+ format.html {render :template => 'map_bugs/get_bugs.js', :content_type => "text/javascript"}
+ format.rss {render :template => 'map_bugs/get_bugs.rss'}
+ format.js
+ format.xml {render :template => 'map_bugs/get_bugs.xml'}
+ format.json { render :json => @bugs.to_json(:methods => [:lat, :lon], :only => [:id, :status, :date_created], :include => { :map_bug_comment => { :only => [:commenter_name, :date_created, :comment]}}) }
+ #format.gpx {render :text => "Rendering GPX"}
end
-
- render :text => resp, :content_type => "text/javascript"
end
def add_bug
@@ -60,9 +55,12 @@ class MapBugsController < ApplicationController
lat = params['lat'].to_f
comment = params['text']
+ name = "NoName";
+ name = params['name'] if params['name'];
+
bug = MapBug.create_bug(lat, lon)
bug.save;
- add_comment(bug, comment);
+ add_comment(bug, comment, name);
render_ok
end
@@ -71,11 +69,14 @@ class MapBugsController < ApplicationController
raise OSM::APIBadUserInput.new("No id was given") unless params['id']
raise OSM::APIBadUserInput.new("No text was given") unless params['text']
+ name = "NoName";
+ name = params['name'] if params['name'];
+
id = params['id'].to_i
bug = MapBug.find_by_id(id);
- bug_comment = add_comment(bug, params['text']);
+ bug_comment = add_comment(bug, params['text'], name);
render_ok
end
@@ -104,14 +105,16 @@ class MapBugsController < ApplicationController
end
def rss
- ##TODO: needs to be implemented
+ request.format = :rss
+ get_bugs
end
def gpx_bugs
- ##TODO: needs to be implemented
+ request.format = :xml
+ get_bugs
end
- def add_comment(bug, comment)
+ def add_comment(bug, comment, name)
t = Time.now.getutc
bug_comment = bug.map_bug_comment.create(:date_created => t, :visible => true, :comment => comment);
if @user
@@ -119,7 +122,7 @@ class MapBugsController < ApplicationController
bug_comment.commenter_name = @user.display_name
else
bug_comment.commenter_ip = request.remote_ip
- bug_comment.commenter_name = "anonymous (a)"
+ bug_comment.commenter_name = name + " (a)"
end
bug_comment.save;
bug.last_changed = t