mirror of
https://github.com/e107inc/e107.git
synced 2025-08-05 14:17:49 +02:00
Fixes #4785 - og:image should be only rendered once. Moved all og meta code out of header_default.php and into social plugin.
This commit is contained in:
@@ -114,8 +114,6 @@ function render_title()
|
||||
if(!defined('e_PAGETITLE') && ($_PAGE_TITLE = e107::getSingleton('eResponse')->getMetaTitle())) // use e107::title() to set.
|
||||
{
|
||||
define('e_PAGETITLE', $_PAGE_TITLE);
|
||||
e107::meta('og:title', $_PAGE_TITLE); // will only populate if not already defined.
|
||||
e107::meta('twitter:title', $_PAGE_TITLE);
|
||||
}
|
||||
|
||||
$arr = [];
|
||||
@@ -131,12 +129,6 @@ function render_title()
|
||||
$arr[] = PAGE_NAME;
|
||||
}
|
||||
}
|
||||
else // Frontpage
|
||||
{
|
||||
e107::meta('og:type', 'website');
|
||||
e107::meta('og:title', SITENAME);
|
||||
e107::meta('twitter:title', SITENAME);
|
||||
}
|
||||
|
||||
$arr[] = SITENAME;
|
||||
|
||||
@@ -167,18 +159,7 @@ echo "<head>
|
||||
<meta charset='utf-8' />\n";
|
||||
if(!empty($pref['meta_copyright'][e_LANGUAGE])) e107::meta('dcterms.rights',$pref['meta_copyright'][e_LANGUAGE]);
|
||||
if(!empty($pref['meta_author'][e_LANGUAGE])) e107::meta('author',$pref['meta_author'][e_LANGUAGE]);
|
||||
if(!empty($pref['sitebutton']))
|
||||
{
|
||||
$siteButton = (strpos($pref['sitebutton'],'{e_MEDIA') !== false) ? e107::getParser()->thumbUrl($pref['sitebutton'],'w=800',false, true) : e107::getParser()->replaceConstants($pref['sitebutton'],'full');
|
||||
e107::meta('og:image',$siteButton);
|
||||
unset($siteButton);
|
||||
}
|
||||
elseif(!empty($pref['sitelogo'])) // fallback to sitelogo
|
||||
{
|
||||
$siteLogo = (strpos($pref['sitelogo'],'{e_MEDIA') !== false) ? e107::getParser()->thumbUrl($pref['sitelogo'],'w=800',false, true) : e107::getParser()->replaceConstants($pref['sitelogo'],'full');
|
||||
e107::meta('og:image',$siteLogo);
|
||||
unset($siteLogo);
|
||||
}
|
||||
|
||||
|
||||
if(defined("VIEWPORT")) e107::meta('viewport',VIEWPORT); //BC ONLY
|
||||
|
||||
|
@@ -4106,7 +4106,7 @@ class eResponse
|
||||
'article:section', 'article:tag', 'article:published_time', 'article:modified_time',
|
||||
'og:description', 'og:image', 'og:title', 'og:updated_time','og:url', 'og:type'
|
||||
);
|
||||
protected $_meta_multiple = array('og:image', 'og:image:width','twitter:image');
|
||||
protected $_meta_multiple = array();
|
||||
protected $_meta = array();
|
||||
protected $_meta_robot_types = array('noindex'=>'NoIndex', 'nofollow'=>'NoFollow','noarchive'=>'NoArchive','noimageindex'=>'NoImageIndex' );
|
||||
protected $_title_separator = ' » ';
|
||||
|
@@ -674,29 +674,19 @@ class news_front
|
||||
}
|
||||
|
||||
// include news-thumbnail/image in meta. - always put this one first.
|
||||
$twitterImage = false;
|
||||
if(!empty($news['news_thumbnail']))
|
||||
{
|
||||
$iurl = (substr($news['news_thumbnail'],0,3)=="{e_") ? $news['news_thumbnail'] : SITEURL.e_IMAGE."newspost_images/".$news['news_thumbnail'];
|
||||
$tmp = explode(",", $iurl);
|
||||
foreach($tmp as $mimg)
|
||||
|
||||
if(!empty($tmp[0]) && substr($tmp[0],-8) !== '.youtube')
|
||||
{
|
||||
if(substr($mimg,-8) == '.youtube' || empty($mimg))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
$mimg = $tmp[0];
|
||||
$metaImg = $tp->thumbUrl($mimg,'w=1200',false,true) ;
|
||||
e107::meta('og:image',$metaImg);
|
||||
e107::meta('og:image:width', 1200);
|
||||
if(!$twitterImage)
|
||||
{
|
||||
e107::meta('twitter:image', $metaImg);
|
||||
$twitterImage = true;
|
||||
}
|
||||
|
||||
e107::meta('twitter:image', $metaImg);
|
||||
e107::meta('twitter:card', 'summary_large_image');
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
@@ -30,7 +30,7 @@ class social_event
|
||||
|
||||
$event[] = array(
|
||||
'name' => "system_meta_pre",
|
||||
'function' => "og_image_add",
|
||||
'function' => "addFallbackMeta",
|
||||
);
|
||||
|
||||
return $event;
|
||||
@@ -42,31 +42,81 @@ class social_event
|
||||
/**
|
||||
* Callback function to add og:image if there is no any
|
||||
*/
|
||||
function og_image_add($meta)
|
||||
function addFallbackMeta($meta)
|
||||
{
|
||||
$ogImage = e107::pref('social', 'og_image', false);
|
||||
|
||||
if(e_ADMIN_AREA === true)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
/** @note TITLE */
|
||||
if($title = e107::getSingleton('eResponse')->getMetaTitle())
|
||||
{
|
||||
e107::meta('og:title', $title); // will only populate if not already defined.
|
||||
e107::meta('twitter:title', $title);
|
||||
}
|
||||
elseif(deftrue('e_FRONTPAGE'))
|
||||
{
|
||||
e107::meta('og:title', SITENAME);
|
||||
e107::meta('twitter:title', SITENAME);
|
||||
}
|
||||
|
||||
/** @note TYPE */
|
||||
if(empty($meta['og:type']))
|
||||
{
|
||||
e107::meta('og:type', 'website');
|
||||
}
|
||||
|
||||
if(empty($ogImage) || empty($meta) || e_ADMIN_AREA === true)
|
||||
/** @note DESCRIPTION */
|
||||
if(empty($meta['og:description']))
|
||||
{
|
||||
return null;
|
||||
}
|
||||
$description = e107::getSingleton('eResponse')->getMetaDescription();
|
||||
|
||||
// check if we have og:image defined
|
||||
|
||||
foreach($meta as $m)
|
||||
{
|
||||
if(varset($m['name']) === 'og:image')
|
||||
if(empty($description) && deftrue('META_DESCRIPTION'))
|
||||
{
|
||||
return null;
|
||||
$description = META_DESCRIPTION;
|
||||
}
|
||||
else
|
||||
{
|
||||
$description = e107::pref('core', 'meta_description');
|
||||
}
|
||||
|
||||
if(!empty($description))
|
||||
{
|
||||
e107::meta('og:description', $description);
|
||||
e107::meta('twitter:description', $description);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
e107::meta('og:image', e107::getParser()->thumbUrl($ogImage, 'w=500', false, true));
|
||||
/** @note IMAGE */
|
||||
if(!empty($meta['og:image']))
|
||||
{
|
||||
// e107::getDebug()->log("Skipping Social plugin og:image fallback");
|
||||
return null;
|
||||
}
|
||||
|
||||
$pref = e107::getConfig()->getPref();
|
||||
|
||||
if($ogImage = e107::pref('social', 'og_image', false))
|
||||
{
|
||||
$metaImg = e107::getParser()->thumbUrl($ogImage, 'w=800', false, true);
|
||||
e107::meta('og:image', $metaImg);
|
||||
e107::meta('twitter:image', $metaImg);
|
||||
}
|
||||
elseif(!empty($pref['sitebutton']))
|
||||
{
|
||||
$siteButton = (strpos($pref['sitebutton'],'{e_MEDIA') !== false) ? e107::getParser()->thumbUrl($pref['sitebutton'],'w=800',false, true) : e107::getParser()->replaceConstants($pref['sitebutton'],'full');
|
||||
e107::meta('og:image',$siteButton);
|
||||
e107::meta('twitter:image', $siteButton);
|
||||
}
|
||||
elseif(!empty($pref['sitelogo'])) // fallback to sitelogo
|
||||
{
|
||||
$siteLogo = (strpos($pref['sitelogo'],'{e_MEDIA') !== false) ? e107::getParser()->thumbUrl($pref['sitelogo'],'w=800',false, true) : e107::getParser()->replaceConstants($pref['sitelogo'],'full');
|
||||
e107::meta('og:image',$siteLogo);
|
||||
e107::meta('twitter:image', $siteLogo);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user