mirror of
https://github.com/e107inc/e107.git
synced 2025-08-11 09:04:38 +02:00
Bbcode code optimization and test.
This commit is contained in:
@@ -11,276 +11,300 @@
|
||||
// Currently defaults class to 'floatnone' - overridden by bbcode
|
||||
|
||||
|
||||
if (!defined('e107_INIT')) { exit; }
|
||||
|
||||
class bb_img extends e_bb_base
|
||||
{
|
||||
function toDB($code_text, $parm)
|
||||
if(!defined('e107_INIT'))
|
||||
{
|
||||
$parms = eHelper::scParams($parm);
|
||||
$safe = array();
|
||||
|
||||
if(!empty($parms['class'])) $safe['class'] = eHelper::secureClassAttr($parms['class']);
|
||||
if(!empty($parms['id'])) $safe['id'] = eHelper::secureIdAttr($parms['id']);
|
||||
if(!empty($parms['style'])) $safe['style'] = eHelper::secureStyleAttr($parms['style']);
|
||||
if(!empty($parms['alt'])) $safe['alt'] = e107::getParser()->filter($parms['alt']);
|
||||
if(isset($parms['width'])) $safe['width'] = (int) $parms['width'];
|
||||
|
||||
if(!empty($safe))
|
||||
{
|
||||
return '[img '.eHelper::buildAttr($safe).']'.$code_text.'[/img]';
|
||||
}
|
||||
|
||||
return '[img]'.$code_text.'[/img]';
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Media Manager bbcode. eg. using {e_MEDIA_IMAGE} and auto-resizing.
|
||||
* @param $code_text
|
||||
* @param $parm
|
||||
* @return string <img> tag with resized image.
|
||||
*/
|
||||
private function mediaImage($code_text,$parm)
|
||||
{
|
||||
$tp = e107::getParser();
|
||||
|
||||
// Replace the bbcode path with a real one.
|
||||
$code_text = str_replace('{e_MEDIA}images/','{e_MEDIA_IMAGE}',$code_text); //BC 0.8 fix.
|
||||
// $code_text = str_replace('{e_MEDIA_IMAGE}', e_HTTP."thumb.php?src=e_MEDIA_IMAGE/", $code_text);
|
||||
// $code_text = str_replace('{e_THEME}', e_HTTP."thumb.php?src=e_THEME/", $code_text);
|
||||
$imgParms = $this->processParm($code_text, $parm);
|
||||
|
||||
$figcaption = false;
|
||||
class bb_img extends e_bb_base
|
||||
{
|
||||
|
||||
if(!empty($imgParms['figcaption']))
|
||||
{
|
||||
$figcaption = $imgParms['figcaption'];
|
||||
unset($imgParms['figcaption']);
|
||||
}
|
||||
|
||||
|
||||
foreach($imgParms as $k => $v)
|
||||
{
|
||||
// $parmStr .= " ".$k.'="'.$v.'"';
|
||||
if($v !== '')
|
||||
{
|
||||
$p[] = $tp->toAttribute($k).'="'.$tp->toAttribute($v).'"';
|
||||
}
|
||||
}
|
||||
|
||||
$resizeWidth = e107::getBB()->resizeWidth();
|
||||
$w = vartrue($imgParms['width']) ? intval($imgParms['width']) : vartrue($resizeWidth,0);
|
||||
// $h = vartrue($imgParms['height']) ? intval($imgParms['height']) : e107::getBB()->resizeHeight();
|
||||
|
||||
// $resize = "&w=".$w; // Always resize - otherwise the thumbnailer returns nothing.
|
||||
// $parmStr = implode(" ",$p);
|
||||
|
||||
|
||||
|
||||
// $url = e107::getParser()->thumbUrl($code_text, $resize);
|
||||
|
||||
$imgParms['w'] = $w;
|
||||
|
||||
if(!empty($figcaption))
|
||||
function toDB($code_text, $parm)
|
||||
{
|
||||
$html = "<figure>\n";
|
||||
// $html .= "<img src=\"".$url."\" {$parmStr} />";
|
||||
$html .= $tp->toImage($code_text, $imgParms);
|
||||
$html .= "<figcaption>".e107::getParser()->filter($figcaption)."</figcaption>\n";
|
||||
$html .= "</figure>";
|
||||
|
||||
return $html;
|
||||
$parms = eHelper::scParams($parm);
|
||||
$safe = array();
|
||||
|
||||
if(!empty($parms['class']))
|
||||
{
|
||||
$safe['class'] = eHelper::secureClassAttr($parms['class']);
|
||||
}
|
||||
if(!empty($parms['id']))
|
||||
{
|
||||
$safe['id'] = eHelper::secureIdAttr($parms['id']);
|
||||
}
|
||||
if(!empty($parms['style']))
|
||||
{
|
||||
$safe['style'] = eHelper::secureStyleAttr($parms['style']);
|
||||
}
|
||||
if(!empty($parms['alt']))
|
||||
{
|
||||
$safe['alt'] = e107::getParser()->filter($parms['alt']);
|
||||
}
|
||||
if(isset($parms['width']))
|
||||
{
|
||||
$safe['width'] = (int) $parms['width'];
|
||||
}
|
||||
|
||||
if(!empty($safe))
|
||||
{
|
||||
return '[img ' . eHelper::buildAttr($safe) . ']' . $code_text . '[/img]';
|
||||
}
|
||||
|
||||
return '[img]' . $code_text . '[/img]';
|
||||
}
|
||||
else
|
||||
|
||||
/**
|
||||
* Media Manager bbcode. eg. using {e_MEDIA_IMAGE} and auto-resizing.
|
||||
*
|
||||
* @param $code_text
|
||||
* @param $parm
|
||||
* @return string <img> tag with resized image.
|
||||
*/
|
||||
private function mediaImage($code_text, $parm)
|
||||
{
|
||||
|
||||
$tp = e107::getParser();
|
||||
|
||||
// Replace the bbcode path with a real one.
|
||||
$code_text = str_replace('{e_MEDIA}images/', '{e_MEDIA_IMAGE}', $code_text); //BC 0.8 fix.
|
||||
|
||||
$imgParms = $this->processParm($code_text, $parm);
|
||||
|
||||
$figcaption = false;
|
||||
|
||||
if(!empty($imgParms['figcaption']))
|
||||
{
|
||||
$figcaption = $imgParms['figcaption'];
|
||||
unset($imgParms['figcaption']);
|
||||
}
|
||||
|
||||
$resizeWidth = e107::getBB()->resizeWidth();
|
||||
|
||||
$w = !empty($imgParms['width']) ? (int) $imgParms['width'] : vartrue($resizeWidth, 0);
|
||||
|
||||
$imgParms['w'] = $w;
|
||||
|
||||
if(!empty($figcaption))
|
||||
{
|
||||
$html = "<figure>\n";
|
||||
// $html .= "<img src=\"".$url."\" {$parmStr} />";
|
||||
$html .= $tp->toImage($code_text, $imgParms);
|
||||
$html .= "<figcaption>" . e107::getParser()->filter($figcaption) . "</figcaption>\n";
|
||||
$html .= "</figure>";
|
||||
|
||||
return $html;
|
||||
}
|
||||
|
||||
return $tp->toImage($code_text, $imgParms);
|
||||
// return "<img src=\"".$url."\" {$parmStr} />";
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Process the [img] bbcode parm. ie. [img parms]something[/img]
|
||||
* @param $code_text
|
||||
* @param $parm
|
||||
* @param string $mode
|
||||
* @return array|string
|
||||
*/
|
||||
private function processParm($code_text, $parm, $mode='')
|
||||
{
|
||||
/**
|
||||
* Process the [img] bbcode parm. ie. [img parms]something[/img]
|
||||
*
|
||||
* @param string $code_text
|
||||
* @param string $parm
|
||||
* @param string $mode
|
||||
* @return array|string
|
||||
*/
|
||||
private function processParm($code_text, $parm, $mode = '')
|
||||
{
|
||||
|
||||
$tp = e107::getParser();
|
||||
$imgParms = array();
|
||||
$tp = e107::getParser();
|
||||
$imgParms = array();
|
||||
|
||||
$parm = preg_replace('#onerror *=#i','',$parm);
|
||||
$parm = str_replace("amp;", "&", $parm);
|
||||
|
||||
// $parm = str_replace(" ","&",$parm); // Needed as parse_str() doesn't know how to handle spaces. Could return [width] => '400 AltValue'
|
||||
|
||||
parse_str($parm,$imgParms);
|
||||
|
||||
|
||||
if(!vartrue($imgParms['width']) && strpos($parm,'width')!==false) // Calculate thumbnail width from style.
|
||||
{
|
||||
preg_match("/width:([\d]*)[p|x|%|;]*/i", $parm, $m);
|
||||
if($m[1] > 0)
|
||||
$parm = preg_replace('#onerror *=#i', '', $parm);
|
||||
$parm = str_replace("amp;", "&", $parm);
|
||||
|
||||
// $parm = str_replace(" ","&",$parm); // Needed as parse_str() doesn't know how to handle spaces. Could return [width] => '400 AltValue'
|
||||
|
||||
parse_str($parm, $imgParms);
|
||||
|
||||
|
||||
if(empty($imgParms['width']) && strpos($parm, 'width') !== false) // Calculate thumbnail width from style.
|
||||
{
|
||||
$imgParms['width'] = $m[1];
|
||||
$imgParms['style'] = str_replace($m[0],'',$imgParms['style']); // strip hard-coded width styling.
|
||||
}
|
||||
}
|
||||
|
||||
if(!vartrue($imgParms['alt'])) // Generate an Alt value from filename if one not found.
|
||||
{
|
||||
preg_match("/([\w]*)(?:\.png|\.jpg|\.jpeg|\.gif)/i", $code_text, $match); // Generate required Alt attribute.
|
||||
$imgParms['alt'] = ucwords(str_replace("_"," ",$match[1]));
|
||||
}
|
||||
else
|
||||
{
|
||||
$imgParms['figcaption'] = $imgParms['alt'] ;
|
||||
}
|
||||
|
||||
$imgParms['title'] = $imgParms['alt'] ;
|
||||
|
||||
$class = !empty($imgParms['class']) ? ' '.$imgParms['class'] : '';
|
||||
|
||||
$imgParms['class'] = "img-rounded rounded bbcode ".e107::getBB()->getClass('img').$class; // This will be overridden if a new class is specified
|
||||
|
||||
if($mode == 'string')
|
||||
{
|
||||
$text = '';
|
||||
foreach($imgParms as $key => $val)
|
||||
{
|
||||
$text .= $key."='".$tp->toAttribute($val)."' ";
|
||||
}
|
||||
return $text;
|
||||
}
|
||||
|
||||
|
||||
return $imgParms;
|
||||
}
|
||||
|
||||
|
||||
|
||||
function toHTML($code_text, $parm)
|
||||
{
|
||||
|
||||
$tp = e107::getParser();
|
||||
$pref = e107::getPref();
|
||||
|
||||
if (trim($code_text) == "") return ""; // Do nothing on empty file
|
||||
|
||||
if(substr($code_text,0,15) == '{e_MEDIA_IMAGE}' || substr($code_text,0,9) == '{e_MEDIA}' || substr($code_text,0,9) == '{e_THEME}') // Image from Media-Manager.
|
||||
{
|
||||
return $this->mediaImage($code_text, $parm);
|
||||
}
|
||||
|
||||
|
||||
if (preg_match("#\.php\?.*#",$code_text)){return "";} //XXX Breaks MediaManager Images, so do it after mediaManager check.
|
||||
|
||||
$addlink = FALSE;
|
||||
|
||||
|
||||
// Automatic Img Resizing --
|
||||
$w = e107::getBB()->resizeWidth(); // varies depending on the class set by external script. see admin->media-manager->prefs
|
||||
$h = e107::getBB()->resizeHeight();
|
||||
|
||||
// No resizing on v1.x legacy images.
|
||||
if(strpos($code_text,"://")==false && ($w || $h) && strpos($code_text,"{e_IMAGE}custom")===false && strpos($code_text,"newspost_images/")===false) // local file.
|
||||
{
|
||||
$code_text = $tp->thumbUrl($code_text,'w='.$w.'&h='.$h);
|
||||
}
|
||||
|
||||
// ------------------------
|
||||
|
||||
$search = array('"', '{E_IMAGE}', '{E_FILE}', '{e_IMAGE}', '{e_FILE}');
|
||||
$replace = array(''', e_IMAGE_ABS, e_FILE_ABS, e_IMAGE_ABS, e_FILE_ABS);
|
||||
$replaceInt = array(''', e_IMAGE, e_FILE, e_IMAGE, e_FILE);
|
||||
$intName = str_replace($search, $replaceInt, $code_text); // Server-relative file names
|
||||
|
||||
|
||||
$code_text = str_replace($search, $replace, $code_text);
|
||||
$code_text = $tp -> toAttribute($code_text);
|
||||
|
||||
$img_file = pathinfo($code_text); // 'External' file name. N.B. - might still contain a constant such as e_IMAGE
|
||||
|
||||
$parmStr = $this->processParm($code_text, $parm, 'string');
|
||||
|
||||
|
||||
|
||||
// Select a random file if required
|
||||
if (strpos($img_file['basename'],'*') !== FALSE)
|
||||
{
|
||||
$fileList = array();
|
||||
$intFile = pathinfo($intName); // N.B. - might still contain a constant such as e_IMAGE
|
||||
$matchString = '#'.str_replace('*','.*?',$intFile['basename']).'#';
|
||||
$dirName = $tp->replaceConstants($intFile['dirname'].'/'); // we want server-relative directory
|
||||
if (($h = opendir($dirName)) !== FALSE)
|
||||
{
|
||||
while (($f = readdir($h)) !== FALSE)
|
||||
preg_match("/width:([\d]*)[p|x|%|;]*/i", $parm, $m);
|
||||
if($m[1] > 0)
|
||||
{
|
||||
if (preg_match($matchString,$f))
|
||||
{
|
||||
$fileList[] = $f; // Just need to note file names
|
||||
}
|
||||
$imgParms['width'] = $m[1];
|
||||
$imgParms['style'] = str_replace($m[0], '', $imgParms['style']); // strip hard-coded width styling.
|
||||
}
|
||||
closedir($h);
|
||||
}
|
||||
else
|
||||
{
|
||||
echo "Error opening directory: {$dirName}<br />";
|
||||
return '';
|
||||
}
|
||||
if (count($fileList))
|
||||
{
|
||||
$img_file['basename'] = $fileList[mt_rand(0,count($fileList)-1)]; // Just change name of displayed file - no change on directory
|
||||
$code_text = $img_file['dirname']."/".$img_file['basename'];
|
||||
}
|
||||
else
|
||||
{
|
||||
echo 'No file: '.$code_text;
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// Check for whether we can display image down here - so we can show image name if appropriate
|
||||
if (!vartrue($pref['image_post']) || !check_class($pref['image_post_class']))
|
||||
{
|
||||
switch ($pref['image_post_disabled_method'])
|
||||
{
|
||||
case '1' :
|
||||
return CORE_LAN17;
|
||||
case '2' :
|
||||
return '';
|
||||
}
|
||||
return CORE_LAN18.$code_text;
|
||||
}
|
||||
|
||||
|
||||
// Check for link to main image if required
|
||||
if (strpos($img_file['basename'],'th_') === 0)
|
||||
{
|
||||
$addlink = TRUE;
|
||||
$main_name = $img_file['dirname']."/".substr($img_file['basename'],3); // delete the 'th' prefix from file name
|
||||
}
|
||||
elseif (strpos($img_file['basename'],'thumb_') === 0)
|
||||
{
|
||||
$addlink = TRUE;
|
||||
$main_name = $img_file['dirname']."/".substr($img_file['basename'],6); // delete the 'thumb' prefix from file name
|
||||
}
|
||||
|
||||
|
||||
|
||||
if ($addlink)
|
||||
{
|
||||
return "<a href='".$main_name."' rel='external'><img src='".$code_text."' {$parmStr} /></a>";
|
||||
if(empty($imgParms['alt'])) // Generate an Alt value from filename if one not found.
|
||||
{
|
||||
preg_match("/([\w]*)(?:\.png|\.jpg|\.jpeg|\.gif)/i", $code_text, $match); // Generate required Alt attribute.
|
||||
|
||||
if(!empty($match[1]))
|
||||
{
|
||||
$imgParms['alt'] = ucwords(str_replace("_", " ", $match[1]));
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$imgParms['figcaption'] = $imgParms['alt'];
|
||||
}
|
||||
|
||||
if(!empty($imgParms['alt']))
|
||||
{
|
||||
$imgParms['title'] = $imgParms['alt'];
|
||||
}
|
||||
|
||||
$class = !empty($imgParms['class']) ? ' ' . $imgParms['class'] : '';
|
||||
|
||||
$imgParms['class'] = "img-rounded rounded bbcode " . e107::getBB()->getClass('img') . $class; // This will be overridden if a new class is specified
|
||||
|
||||
if($mode == 'string')
|
||||
{
|
||||
$text = '';
|
||||
foreach($imgParms as $key => $val)
|
||||
{
|
||||
$text .= $key . "='" . $tp->toAttribute($val) . "' ";
|
||||
}
|
||||
|
||||
return $text;
|
||||
}
|
||||
|
||||
|
||||
return $imgParms;
|
||||
}
|
||||
else
|
||||
|
||||
/**
|
||||
* @param string $code_text
|
||||
* @param string $parm width=x etc.
|
||||
* @return string
|
||||
*/
|
||||
function toHTML($code_text, $parm)
|
||||
{
|
||||
return "<img src='".$code_text."' {$parmStr} />";
|
||||
|
||||
$tp = e107::getParser();
|
||||
$pref = e107::getPref();
|
||||
|
||||
$code_text = trim($code_text);
|
||||
|
||||
if(empty($code_text))
|
||||
{
|
||||
return "";
|
||||
} // Do nothing on empty file
|
||||
|
||||
if(strpos($code_text, '{e_MEDIA_IMAGE}') === 0 || strpos($code_text, '{e_MEDIA}') === 0 || strpos($code_text, '{e_THEME}') === 0) // Image from Media-Manager.
|
||||
{
|
||||
return $this->mediaImage($code_text, $parm);
|
||||
}
|
||||
|
||||
if(preg_match("#\.php\?.*#", $code_text))
|
||||
{
|
||||
return "";
|
||||
} //XXX Breaks MediaManager Images, so do it after mediaManager check.
|
||||
|
||||
$addlink = false;
|
||||
|
||||
|
||||
// Automatic Img Resizing --
|
||||
$w = e107::getBB()->resizeWidth(); // varies depending on the class set by external script. see admin->media-manager->prefs
|
||||
$h = e107::getBB()->resizeHeight();
|
||||
|
||||
// No resizing on v1.x legacy images.
|
||||
if(strpos($code_text, "://") == false && ($w || $h) && strpos($code_text, "{e_IMAGE}custom") === false && strpos($code_text, "newspost_images/") === false) // local file.
|
||||
{
|
||||
$code_text = $tp->thumbUrl($code_text, 'w=' . $w . '&h=' . $h);
|
||||
}
|
||||
|
||||
// ------------------------
|
||||
|
||||
$search = array('"', '{E_IMAGE}', '{E_FILE}', '{e_IMAGE}', '{e_FILE}');
|
||||
$replace = array(''', e_IMAGE_ABS, e_FILE_ABS, e_IMAGE_ABS, e_FILE_ABS);
|
||||
$replaceInt = array(''', e_IMAGE, e_FILE, e_IMAGE, e_FILE);
|
||||
$intName = str_replace($search, $replaceInt, $code_text); // Server-relative file names
|
||||
|
||||
|
||||
$code_text = str_replace($search, $replace, $code_text);
|
||||
$code_text = $tp->toAttribute($code_text);
|
||||
|
||||
$img_file = pathinfo($code_text); // 'External' file name. N.B. - might still contain a constant such as e_IMAGE
|
||||
|
||||
$parmStr = $this->processParm($code_text, $parm, 'string');
|
||||
|
||||
|
||||
// Select a random file if required
|
||||
if(strpos($img_file['basename'], '*') !== false)
|
||||
{
|
||||
$fileList = array();
|
||||
$intFile = pathinfo($intName); // N.B. - might still contain a constant such as e_IMAGE
|
||||
$matchString = '#' . str_replace('*', '.*?', $intFile['basename']) . '#';
|
||||
$dirName = $tp->replaceConstants($intFile['dirname'] . '/'); // we want server-relative directory
|
||||
if(($h = opendir($dirName)) !== false)
|
||||
{
|
||||
while(($f = readdir($h)) !== false)
|
||||
{
|
||||
if(preg_match($matchString, $f))
|
||||
{
|
||||
$fileList[] = $f; // Just need to note file names
|
||||
}
|
||||
}
|
||||
closedir($h);
|
||||
}
|
||||
else
|
||||
{
|
||||
echo "Error opening directory: {$dirName}<br />";
|
||||
|
||||
return '';
|
||||
}
|
||||
if(count($fileList))
|
||||
{
|
||||
$img_file['basename'] = $fileList[mt_rand(0, count($fileList) - 1)]; // Just change name of displayed file - no change on directory
|
||||
$code_text = $img_file['dirname'] . "/" . $img_file['basename'];
|
||||
}
|
||||
else
|
||||
{
|
||||
echo 'No file: ' . $code_text;
|
||||
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// Check for whether we can display image down here - so we can show image name if appropriate
|
||||
if(!vartrue($pref['image_post']) || !check_class($pref['image_post_class']))
|
||||
{
|
||||
switch($pref['image_post_disabled_method'])
|
||||
{
|
||||
case '1' :
|
||||
return CORE_LAN17;
|
||||
case '2' :
|
||||
return '';
|
||||
}
|
||||
|
||||
return CORE_LAN18 . $code_text;
|
||||
}
|
||||
|
||||
|
||||
// Check for link to main image if required
|
||||
if(strpos($img_file['basename'], 'th_') === 0)
|
||||
{
|
||||
$addlink = true;
|
||||
$main_name = $img_file['dirname'] . "/" . substr($img_file['basename'], 3); // delete the 'th' prefix from file name
|
||||
}
|
||||
elseif(strpos($img_file['basename'], 'thumb_') === 0)
|
||||
{
|
||||
$addlink = true;
|
||||
$main_name = $img_file['dirname'] . "/" . substr($img_file['basename'], 6); // delete the 'thumb' prefix from file name
|
||||
}
|
||||
|
||||
|
||||
if($addlink)
|
||||
{
|
||||
return "<a href='" . $main_name . "' rel='external'><img src='" . $code_text . "' {$parmStr} /></a>";
|
||||
}
|
||||
else
|
||||
{
|
||||
return "<img src='" . $code_text . "' {$parmStr} />";
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user