X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/336d40f2c593cc2af6d669e30d17ec9e4c6f0734..15b104f4ff4614aa78c01180b6a9b89dd5a1400f:/app/views/changeset/list.atom.builder?ds=sidebyside diff --git a/app/views/changeset/list.atom.builder b/app/views/changeset/list.atom.builder index 16f2cbfda..a3b7a2240 100644 --- a/app/views/changeset/list.atom.builder +++ b/app/views/changeset/list.atom.builder @@ -1,20 +1,20 @@ atom_feed(:language => I18n.locale, :schema_date => 2009, - :id => url_for(params.merge({ :only_path => false })), - :root_url => url_for(params.merge({ :only_path => false, :format => nil })), + :id => url_for(@params.merge(:only_path => false)), + :root_url => url_for(@params.merge(:action => :list, :format => nil, :only_path => false)), "xmlns:georss" => "http://www.georss.org/georss") do |feed| - feed.title @title - feed.subtitle @description - feed.updated @edits.map {|e| [e.created_at, e.closed_at].max }.max - feed.icon "http://#{SERVER_URL}/favicon.ico" - feed.logo "http://#{SERVER_URL}/images/mag_map-rss2.0.png" + feed.title changeset_list_title(params, current_user) - feed.rights :type => 'xhtml' do |xhtml| + feed.updated @edits.map { |e| [e.created_at, e.closed_at].max }.max + feed.icon image_url("favicon.ico") + feed.logo image_url("mag_map-rss2.0.png") + + feed.rights :type => "xhtml" do |xhtml| xhtml.a :href => "http://creativecommons.org/licenses/by-sa/2.0/" do |a| - a.img :src => "http://#{SERVER_URL}/images/cc_button.png", :alt => "CC by-sa 2.0" + a.img :src => image_url("cc_button.png"), :alt => "CC by-sa 2.0" end end - for changeset in @edits + @edits.each do |changeset| feed.entry(changeset, :updated => changeset.closed_at, :id => changeset_url(changeset.id, :only_path => false)) do |entry| entry.link :rel => "alternate", :href => changeset_read_url(changeset, :only_path => false), @@ -23,28 +23,61 @@ atom_feed(:language => I18n.locale, :schema_date => 2009, :href => changeset_download_url(changeset, :only_path => false), :type => "application/osmChange+xml" - entry.title t('browse.changeset.title') + " " + h(changeset.id) + if !changeset.tags.empty? && changeset.tags.key?("comment") + entry.title t("browse.changeset.feed.title_comment", :id => h(changeset.id), :comment => h(changeset.tags["comment"])), :type => "html" + else + entry.title t("browse.changeset.feed.title", :id => h(changeset.id)) + end if changeset.user.data_public? entry.author do |author| author.name changeset.user.display_name - author.uri url_for(:controller => 'user', :action => 'view', :display_name => changeset.user.display_name, :only_path => false) + author.uri url_for(:controller => "user", :action => "view", :display_name => changeset.user.display_name, :only_path => false) end end - if changeset.tags['comment'] - feed.content changeset.tags['comment'] + feed.content :type => "xhtml" do |xhtml| + xhtml.style "th { text-align: left } tr { vertical-align: top }" + xhtml.table do |table| + table.tr do |tr| + tr.th t("browse.created") + tr.td l(changeset.created_at) + end + table.tr do |tr| + tr.th t("browse.closed") + tr.td l(changeset.closed_at) + end + if changeset.user.data_public? + table.tr do |tr| + tr.th t("browse.changeset.belongs_to") + tr.td do |td| + td.a h(changeset.user.display_name), :href => url_for(:controller => "user", :action => "view", :display_name => changeset.user.display_name, :only_path => false) + end + end + end + unless changeset.tags.empty? + table.tr do |tr| + tr.th t("browse.tag_details.tags") + tr.td do |td| + td.table :cellpadding => "0" do |table| + changeset.tags.sort.each do |tag| + table.tr do |tr| + tr.td << "#{h(tag[0])} = #{linkify(h(tag[1]))}" + end + end + end + end + end + end + end end - unless changeset.min_lat.nil? - minlon = changeset.min_lon/GeoRecord::SCALE.to_f - minlat = changeset.min_lat/GeoRecord::SCALE.to_f - maxlon = changeset.max_lon/GeoRecord::SCALE.to_f - maxlat = changeset.max_lat/GeoRecord::SCALE.to_f + if changeset.has_valid_bbox? + bbox = changeset.bbox.to_unscaled # See http://georss.org/Encodings#Geometry - lower_corner = "#{minlat} #{minlon}" - upper_corner = "#{maxlat} #{maxlon}" + lower_corner = "#{bbox.min_lat} #{bbox.min_lon}" + upper_corner = "#{bbox.max_lat} #{bbox.max_lon}" feed.georss :box, lower_corner + " " + upper_corner end