X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/d00a0667bc6e156061a6c6428b0070ced6acda87..68abf2075b9efc652e19adeac2bbee9add99e455:/app/helpers/open_graph_helper.rb diff --git a/app/helpers/open_graph_helper.rb b/app/helpers/open_graph_helper.rb index a41831ca6..b3f0ab928 100644 --- a/app/helpers/open_graph_helper.rb +++ b/app/helpers/open_graph_helper.rb @@ -1,15 +1,16 @@ module OpenGraphHelper require "addressable/uri" - def opengraph_tags(title = nil, og_image = nil) + def opengraph_tags(title, properties) tags = { "og:site_name" => t("layouts.project_name.title"), "og:title" => title || t("layouts.project_name.title"), "og:type" => "website", - "og:image" => og_image_url(og_image), "og:url" => url_for(:only_path => false), - "og:description" => t("layouts.intro_text") - } + "og:description" => properties["og:description"] || t("layouts.intro_text") + }.merge( + opengraph_image_properties(properties) + ) safe_join(tags.map do |property, content| tag.meta(:property => property, :content => content) @@ -18,12 +19,20 @@ module OpenGraphHelper private - def og_image_url(og_image) + def opengraph_image_properties(properties) begin - return Addressable::URI.join(root_url, og_image).normalize if og_image + 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 - image_url("osm_logo_256.png") + { + "og:image" => image_url("osm_logo_256.png"), + "og:image:alt" => t("layouts.logo.alt_text") + } end end