X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/8eead8a8707b478b342a6e4c13c4e8b4ef143b98..c6609cce243bd2597b11fd8d57e57f8100ad65a1:/app/helpers/browse_helper.rb
diff --git a/app/helpers/browse_helper.rb b/app/helpers/browse_helper.rb
index e252e300f..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/index.php?title=#{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 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 '' + h(tag) + ''
+ # Not a wikipedia key!
+ return nil
end
+
+ return {
+ :url => "http://#{lang}.wikipedia.org/wiki/#{value}?uselang=#{I18n.locale}",
+ :title => value
+ }
end
end