X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/88aa34f61bf74b723aa4a4431208c63783e834f8..c6609cce243bd2597b11fd8d57e57f8100ad65a1:/app/helpers/browse_helper.rb?ds=inline diff --git a/app/helpers/browse_helper.rb b/app/helpers/browse_helper.rb index 48dd590a2..ff702aed1 100644 --- a/app/helpers/browse_helper.rb +++ b/app/helpers/browse_helper.rb @@ -16,41 +16,64 @@ module BrowseHelper return name end - def wiki_link(type, key, tag) - wiki_data = YAML.load_file("#{RAILS_ROOT}/config/wiki-tag-and-key-description.yml") - my_locale = I18n.locale.to_s - - if type == "key" - ret = key - lookup = key + def format_key(key) + if url = wiki_link("key", key) + link_to h(key), url, :title => t('browse.tag_details.wiki_link.key', :key => key) else - ret = tag - lookup = key + "=" + tag + h(key) end + end - # Try our native language - has_primary = wiki_data[my_locale][type][lookup] rescue false - if has_primary - ret = wikify(type, key, tag, lookup, wiki_data[my_locale][type][lookup]) + def format_value(key, value) + if wp = wikipedia_link(key, value) + link_to h(wp[:title]), wp[:url], :title => t('browse.tag_details.wikipedia_link', :page => wp[:title]) + elsif url = wiki_link("tag", "#{key}=#{value}") + link_to h(value), url, :title => t('browse.tag_details.wiki_link.tag', :key => key, :value => value) else - # Fall back on English - has_fallback = wiki_data["en"][type][lookup] rescue false - if has_fallback - ret = wikify(type, key, tag, lookup, wiki_data["en"][type][lookup]) - end + linkify h(value) end + end + +private + + def wiki_link(type, lookup) + locale = I18n.locale.to_s - return ret + if page = WIKI_PAGES[locale][type][lookup] rescue nil + url = "http://wiki.openstreetmap.org/wiki/#{page}?uselang=#{locale}" + elsif page = WIKI_PAGES["en"][type][lookup] rescue nil + url = "http://wiki.openstreetmap.org/wiki/#{page}?uselang=#{locale}" + end + + return url end - def wikify(type, key, tag, text, wiki) - my_locale = I18n.locale - url = "http://wiki.openstreetmap.org/wiki/#{wiki}?uselang=#{my_locale}" - - if type == "key" - return '' + h(text) + '' + def wikipedia_link(key, value) + # Some k/v's are wikipedia=http://en.wikipedia.org/wiki/Full%20URL + return nil if value =~ /^http:\/\// + + if key == "wikipedia" + # This regex should match Wikipedia language codes, everything + # from de to zh-classical + if value =~ /^([a-z-]{2,12}):(.+)$/ + # Value is : so split it up + lang = $1 + value = $2 + else + # Value is <title> so default to English Wikipedia + lang = 'en' + end + elsif key =~ /^wikipedia:(\S+)$/ + # Language is in the key, so assume value is a simple title + lang = $1 else - return '<a href="' + url + '" title="' + h(t('browse.tag_details.wiki_link.tag', :key => key, :value => tag)) + '">' + h(tag) + '</a>' + # Not a wikipedia key! + return nil end + + return { + :url => "http://#{lang}.wikipedia.org/wiki/#{value}?uselang=#{I18n.locale}", + :title => value + } end end