X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/e414d10aa10815b07e0ab334db4d96c4b3ac9b6b..6a5749c55c7a93a25054dc6dd76e1c4b88e37b2c:/app/controllers/browse_controller.rb diff --git a/app/controllers/browse_controller.rb b/app/controllers/browse_controller.rb index 1806558f2..f3a04519c 100644 --- a/app/controllers/browse_controller.rb +++ b/app/controllers/browse_controller.rb @@ -1,8 +1,17 @@ class BrowseController < ApplicationController - before_filter :authorize_web layout 'site' - def relation_view + before_filter :authorize_web + before_filter { |c| c.check_database_availability(true) } + + def start + end + + def index + @nodes = Node.find(:all, :order => "timestamp DESC", :limit=> 20) + end + + def relation begin @relation = Relation.find(params[:id]) @@ -12,12 +21,29 @@ class BrowseController < ApplicationController end @title = 'Relation | ' + (@name) + @next = Relation.find(:first, :order => "id ASC", :conditions => [ "visible = true AND id > :id", { :id => @relation.id }] ) + @prev = Relation.find(:first, :order => "id DESC", :conditions => [ "visible = true AND id < :id", { :id => @relation.id }] ) rescue ActiveRecord::RecordNotFound render :nothing => true, :status => :not_found end end - def way_view + def relation_history + begin + @relation = Relation.find(params[:id]) + + @name = @relation.tags['name'].to_s + if @name.length == 0: + @name = "#" + @relation.id.to_s + end + + @title = 'Relation History | ' + (@name) + rescue ActiveRecord::RecordNotFound + render :nothing => true, :status => :not_found + end + end + + def way begin @way = Way.find(params[:id]) @@ -27,12 +53,29 @@ class BrowseController < ApplicationController end @title = 'Way | ' + (@name) + @next = Way.find(:first, :order => "id ASC", :conditions => [ "visible = true AND id > :id", { :id => @way.id }] ) + @prev = Way.find(:first, :order => "id DESC", :conditions => [ "visible = true AND id < :id", { :id => @way.id }] ) + rescue ActiveRecord::RecordNotFound + render :nothing => true, :status => :not_found + end + end + + def way_history + begin + @way = Way.find(params[:id]) + + @name = @way.tags['name'].to_s + if @name.length == 0: + @name = "#" + @way.id.to_s + end + + @title = 'Way History | ' + (@name) rescue ActiveRecord::RecordNotFound render :nothing => true, :status => :not_found end end - def node_view + def node begin @node = Node.find(params[:id]) @@ -42,6 +85,23 @@ class BrowseController < ApplicationController end @title = 'Node | ' + (@name) + @next = Node.find(:first, :order => "id ASC", :conditions => [ "visible = true AND id > :id", { :id => @node.id }] ) + @prev = Node.find(:first, :order => "id DESC", :conditions => [ "visible = true AND id < :id", { :id => @node.id }] ) + rescue ActiveRecord::RecordNotFound + render :nothing => true, :status => :not_found + end + end + + def node_history + begin + @node = Node.find(params[:id]) + + @name = @node.tags_as_hash['name'].to_s + if @name.length == 0: + @name = "#" + @node.id.to_s + end + + @title = 'Node History | ' + (@name) rescue ActiveRecord::RecordNotFound render :nothing => true, :status => :not_found end