--- /dev/null
+class OldElementsController < ApplicationController
+ layout :map_layout
+
+ before_action :authorize_web
+ before_action :set_locale
+ before_action -> { check_database_readable(:need_api => true) }
+ before_action :require_oauth
+
+ authorize_resource
+
+ before_action :require_moderator_for_unredacted_history
+ around_action :web_timeout
+
+ private
+
+ def require_moderator_for_unredacted_history
+ deny_access(nil) if params[:show_redactions] && !current_user&.moderator?
+ end
+end
-class OldNodesController < ApplicationController
- layout :map_layout
-
- before_action :authorize_web
- before_action :set_locale
- before_action -> { check_database_readable(:need_api => true) }
- before_action :require_oauth
-
- authorize_resource
-
- before_action :require_moderator_for_unredacted_history
- around_action :web_timeout
-
+class OldNodesController < OldElementsController
def index
@type = "node"
@feature = Node.preload(:node_tags, :old_nodes => [:old_tags, { :changeset => [:changeset_tags, :user] }]).find(params[:id])
- render "browse/history"
rescue ActiveRecord::RecordNotFound
render "browse/not_found", :status => :not_found
end
rescue ActiveRecord::RecordNotFound
render :action => "not_found", :status => :not_found
end
-
- private
-
- def require_moderator_for_unredacted_history
- deny_access(nil) if params[:show_redactions] && !current_user&.moderator?
- end
end
-class OldRelationsController < ApplicationController
- layout :map_layout
-
- before_action :authorize_web
- before_action :set_locale
- before_action -> { check_database_readable(:need_api => true) }
- before_action :require_oauth
-
- authorize_resource
-
- before_action :require_moderator_for_unredacted_history
- around_action :web_timeout
-
+class OldRelationsController < OldElementsController
def index
@type = "relation"
@feature = Relation.preload(:relation_tags, :old_relations => [:old_tags, { :changeset => [:changeset_tags, :user], :old_members => :member }]).find(params[:id])
- render "browse/history"
rescue ActiveRecord::RecordNotFound
render "browse/not_found", :status => :not_found
end
rescue ActiveRecord::RecordNotFound
render :action => "not_found", :status => :not_found
end
-
- private
-
- def require_moderator_for_unredacted_history
- deny_access(nil) if params[:show_redactions] && !current_user&.moderator?
- end
end
-class OldWaysController < ApplicationController
- layout :map_layout
-
- before_action :authorize_web
- before_action :set_locale
- before_action -> { check_database_readable(:need_api => true) }
- before_action :require_oauth
-
- authorize_resource
-
- before_action :require_moderator_for_unredacted_history
- around_action :web_timeout
-
+class OldWaysController < OldElementsController
def index
@type = "way"
@feature = Way.preload(:way_tags, :old_ways => [:old_tags, { :changeset => [:changeset_tags, :user], :old_nodes => { :node => [:node_tags, :ways] } }]).find(params[:id])
- render "browse/history"
rescue ActiveRecord::RecordNotFound
render "browse/not_found", :status => :not_found
end
rescue ActiveRecord::RecordNotFound
render :action => "not_found", :status => :not_found
end
-
- private
-
- def require_moderator_for_unredacted_history
- deny_access(nil) if params[:show_redactions] && !current_user&.moderator?
- end
end
<% elsif current_user&.moderator? %>
·
<% if !params[:show_redactions] %>
- <%= link_to t("browse.view_redacted_data"), :params => { :show_redactions => true } %>
+ <%= link_to t(".view_redacted_data"), :params => { :show_redactions => true } %>
<% else %>
- <%= link_to t("browse.view_redaction_message") %>
+ <%= link_to t(".view_redaction_message") %>
<% end %>
<% end %>
</div>
-<% set_title(t("browse.#{@type}.history_title_html", :name => printable_element_name(@feature))) %>
+<% set_title(t(".#{@type}.title_html", :name => printable_element_name(@feature))) %>
-<%= render "sidebar_header", :title => t("browse.#{@type}.history_title_html", :name => printable_element_name(@feature)) %>
+<%= render "sidebar_header", :title => t(".#{@type}.title_html", :name => printable_element_name(@feature)) %>
<%= render :partial => "browse/#{@type}", :collection => @feature.send(:"old_#{@type}s").reverse %>
<%= render :partial => "browse/node", :object => @feature %>
-<%= render :partial => "browse/version_actions" %>
+<%= render :partial => "actions" %>
<%= render :partial => "browse/relation", :object => @feature %>
-<%= render :partial => "browse/version_actions" %>
+<%= render :partial => "actions" %>
<%= render :partial => "browse/way", :object => @feature %>
-<%= render :partial => "browse/version_actions" %>
+<%= render :partial => "actions" %>
view_history: "View History"
view_unredacted_history: "View Unredacted History"
view_details: "View Details"
- view_redacted_data: "View Redacted Data"
- view_redaction_message: "View Redaction Message"
location: "Location:"
common_details:
coordinates_html: "%{latitude}, %{longitude}"
node:
title_html: "Node: %{name}"
- history_title_html: "Node History: %{name}"
way:
title_html: "Way: %{name}"
- history_title_html: "Way History: %{name}"
nodes: "Nodes"
nodes_count:
one: "%{count} node"
other: "part of ways %{related_ways}"
relation:
title_html: "Relation: %{name}"
- history_title_html: "Relation History: %{name}"
members: "Members"
members_count:
one: "%{count} member"
introduction: "Click on the map to find nearby features."
nearby: "Nearby features"
enclosing: "Enclosing features"
+ old_elements:
+ index:
+ node:
+ title_html: "Node History: %{name}"
+ way:
+ title_html: "Way History: %{name}"
+ relation:
+ title_html: "Relation History: %{name}"
+ actions:
+ view_redacted_data: "View Redacted Data"
+ view_redaction_message: "View Redaction Message"
nodes:
timeout:
sorry: "Sorry, the data for the node with the id %{id} took too long to retrieve."
def test_history
node = create(:node, :with_history)
- sidebar_browse_check :node_history_path, node.id, "browse/history"
+ sidebar_browse_check :node_history_path, node.id, "old_elements/index"
assert_select "h4", /^Version/ do
assert_select "a[href='#{old_node_path node, 1}']", :text => "1", :count => 1
end
get node_history_path(:id => node)
assert_response :success
- assert_template "browse/history"
+ assert_template "old_elements/index"
# there are 2 revisions of the redacted node, but only one
# should be showing details here.
get node_history_path(:id => node, :params => { :show_redactions => true })
assert_response :success
- assert_template "browse/history"
+ assert_template "old_elements/index"
assert_select ".browse-section", 2
assert_select ".browse-section.browse-redacted", 0
def test_history
relation = create(:relation, :with_history)
- sidebar_browse_check :relation_history_path, relation.id, "browse/history"
+ sidebar_browse_check :relation_history_path, relation.id, "old_elements/index"
assert_select "h4", /^Version/ do
assert_select "a[href='#{old_relation_path relation, 1}']", :text => "1", :count => 1
end
get relation_history_path(:id => relation)
assert_response :success
- assert_template "browse/history"
+ assert_template "old_elements/index"
# there are 4 revisions of the redacted relation, but only 2
# should be showing details here.
get relation_history_path(:id => relation, :params => { :show_redactions => true })
assert_response :success
- assert_template "browse/history"
+ assert_template "old_elements/index"
assert_select ".browse-section", 4
assert_select ".browse-section.browse-redacted", 0
def test_history
way = create(:way, :with_history)
- sidebar_browse_check :way_history_path, way.id, "browse/history"
+ sidebar_browse_check :way_history_path, way.id, "old_elements/index"
assert_select "h4", /^Version/ do
assert_select "a[href='#{old_way_path way, 1}']", :text => "1", :count => 1
end
get way_history_path(:id => way)
assert_response :success
- assert_template "browse/history"
+ assert_template "old_elements/index"
# there are 4 revisions of the redacted way, but only 2
# should be showing details here.
get way_history_path(:id => way, :params => { :show_redactions => true })
assert_response :success
- assert_template "browse/history"
+ assert_template "old_elements/index"
assert_select ".browse-section", 4
assert_select ".browse-section.browse-redacted", 0