X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/9aa24a0715c33bb84babb7eae139e448b692815e..HEAD:/app/helpers/browse_tags_helper.rb diff --git a/app/helpers/browse_tags_helper.rb b/app/helpers/browse_tags_helper.rb index 3a952ccc9..6d3bf5e91 100644 --- a/app/helpers/browse_tags_helper.rb +++ b/app/helpers/browse_tags_helper.rb @@ -1,7 +1,7 @@ module BrowseTagsHelper # https://wiki.openstreetmap.org/wiki/Key:wikipedia#Secondary_Wikipedia_links # https://wiki.openstreetmap.org/wiki/Key:wikidata#Secondary_Wikidata_links - SECONDARY_WIKI_PREFIXES = "architect|artist|brand|flag|genus|name:etymology|network|operator|species|subject".freeze + SECONDARY_WIKI_PREFIXES = "architect|artist|brand|buried|flag|genus|manufacturer|model|name:etymology|network|operator|species|subject".freeze def format_key(key) if url = wiki_link("key", key) @@ -26,7 +26,7 @@ module BrowseTagsHelper elsif url = wiki_link("tag", "#{key}=#{value}") link_to h(value), url, :title => t("browse.tag_details.wiki_link.tag", :key => key, :value => value) elsif email = email_link(key, value) - link_to(h(email[:email]), email[:url], :title => t("browse.tag_details.email_link", :email => email[:email])) + mail_to(email, :title => t("browse.tag_details.email_link", :email => email)) elsif phones = telephone_links(key, value) # similarly, telephone_links() returns an array of phone numbers phones = phones.map do |p| @@ -34,9 +34,13 @@ module BrowseTagsHelper end safe_join(phones, "; ") elsif colour_value = colour_preview(key, value) - tag.span("", :class => "colour-preview-box", :"data-colour" => colour_value, :title => t("browse.tag_details.colour_preview", :colour_value => colour_value)) + colour_value + svg = tag.svg :width => 14, :height => 14, :class => "float-end m-1" do + concat tag.title t("browse.tag_details.colour_preview", :colour_value => colour_value) + concat tag.rect :x => 0.5, :y => 0.5, :width => 13, :height => 13, :fill => colour_value, :stroke => "#2222" + end + svg + colour_value else - linkify h(value) + safe_join(value.split(";", -1).map { |x| linkify(h(x)) }, ";") end end @@ -129,7 +133,10 @@ module BrowseTagsHelper nil end - def email_link(_key, value) + def email_link(key, value) + # Avoid converting conditional tags into emails, since EMAIL_REGEXP is quite permissive + return nil unless %w[email contact:email].include? key + # Does the value look like an email? eg "someone@domain.tld" # Uses Ruby built-in regexp to validate email. @@ -140,10 +147,7 @@ module BrowseTagsHelper # remove any leading and trailing whitespace email = value.strip - if email.match?(URI::MailTo::EMAIL_REGEXP) - # add 'mailto:'' prefix - return { :email => email, :url => "mailto:#{email}" } - end + return email if email.match?(URI::MailTo::EMAIL_REGEXP) nil end