X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/dae3dcf87edcfc0648cd0b93b069b0eee67d3ab7..10a4c5cf6e1165a9db6e9b87d0fa19d7f97b51bf:/app/helpers/open_graph_helper.rb diff --git a/app/helpers/open_graph_helper.rb b/app/helpers/open_graph_helper.rb index e21a5648a..cde848e5d 100644 --- a/app/helpers/open_graph_helper.rb +++ b/app/helpers/open_graph_helper.rb @@ -1,17 +1,40 @@ module OpenGraphHelper - def opengraph_tags(title = nil) + require "addressable/uri" + + def opengraph_tags(title, properties) tags = { "og:site_name" => t("layouts.project_name.title"), - "og:title" => [t("layouts.project_name.title"), title].compact.join(" | "), + "og:title" => title || t("layouts.project_name.title"), "og:type" => "website", - "og:image" => image_path("osm_logo_256.png", :host => SERVER_URL, :protocol => "http"), - "og:image:secure_url" => image_path("osm_logo_256.png", :host => SERVER_URL, :protocol => "https"), - "og:url" => url_for(:host => SERVER_URL), - "og:description" => t("layouts.intro_text") - } + "og:url" => url_for(:only_path => false), + "og:description" => properties["og:description"] || t("layouts.intro_text") + }.merge( + opengraph_image_properties(properties) + ).merge( + properties.slice("article:published_time") + ) + + safe_join(tags.map do |property, content| + tag.meta(:property => property, :content => content) + end, "\n") + end + + private - tags.map do |property, content| - tag(:meta, :property => property, :content => content) - end.join("").html_safe + def opengraph_image_properties(properties) + begin + if properties["og:image"] + image_properties = {} + image_properties["og:image"] = Addressable::URI.join(root_url, properties["og:image"]).normalize + image_properties["og:image:alt"] = properties["og:image:alt"] if properties["og:image:alt"] + return image_properties + end + rescue Addressable::URI::InvalidURIError + # return default image + end + { + "og:image" => image_url("osm_logo_256.png"), + "og:image:alt" => t("layouts.logo.alt_text") + } end end