2014-04-01 18:38:34 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Smarty plugin
|
|
|
|
*
|
2014-10-13 09:24:53 +00:00
|
|
|
* @package Smarty
|
2014-04-01 18:38:34 +00:00
|
|
|
* @subpackage PluginsModifier
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Smarty truncate modifier plugin
|
|
|
|
* Type: modifier<br>
|
|
|
|
* Name: truncate<br>
|
|
|
|
* Purpose: Truncate a string to a certain length if necessary,
|
|
|
|
* optionally splitting in the middle of a word, and
|
|
|
|
* appending the $etc string or inserting $etc into the middle.
|
|
|
|
*
|
2014-10-13 09:24:53 +00:00
|
|
|
* @link http://smarty.php.net/manual/en/language.modifier.truncate.php truncate (Smarty online manual)
|
2014-04-01 18:38:34 +00:00
|
|
|
* @author Monte Ohrt <monte at ohrt dot com>
|
2014-10-13 09:24:53 +00:00
|
|
|
*
|
2014-04-01 18:38:34 +00:00
|
|
|
* @param string $string input string
|
|
|
|
* @param integer $length length of truncated text
|
|
|
|
* @param string $etc end string
|
|
|
|
* @param boolean $break_words truncate at word boundary
|
|
|
|
* @param boolean $middle truncate in the middle of text
|
2014-10-13 09:24:53 +00:00
|
|
|
*
|
2014-04-01 18:38:34 +00:00
|
|
|
* @return string truncated string
|
|
|
|
*/
|
|
|
|
function smarty_modifier_truncate($string, $length = 80, $etc = '...', $break_words = false, $middle = false)
|
|
|
|
{
|
2014-10-13 09:24:53 +00:00
|
|
|
if ($length == 0) {
|
2014-04-01 18:38:34 +00:00
|
|
|
return '';
|
2014-10-13 09:24:53 +00:00
|
|
|
}
|
2014-04-01 18:38:34 +00:00
|
|
|
|
|
|
|
if (Smarty::$_MBSTRING) {
|
|
|
|
if (mb_strlen($string, Smarty::$_CHARSET) > $length) {
|
|
|
|
$length -= min($length, mb_strlen($etc, Smarty::$_CHARSET));
|
|
|
|
if (!$break_words && !$middle) {
|
2018-01-28 18:29:49 +00:00
|
|
|
$string = preg_replace('/\s+?(\S+)?$/' . Smarty::$_UTF8_MODIFIER, '',
|
|
|
|
mb_substr($string, 0, $length + 1, Smarty::$_CHARSET));
|
2014-04-01 18:38:34 +00:00
|
|
|
}
|
|
|
|
if (!$middle) {
|
|
|
|
return mb_substr($string, 0, $length, Smarty::$_CHARSET) . $etc;
|
|
|
|
}
|
|
|
|
|
2018-01-28 18:29:49 +00:00
|
|
|
return mb_substr($string, 0, $length / 2, Smarty::$_CHARSET) . $etc .
|
|
|
|
mb_substr($string, - $length / 2, $length, Smarty::$_CHARSET);
|
2014-04-01 18:38:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return $string;
|
|
|
|
}
|
|
|
|
|
|
|
|
// no MBString fallback
|
2018-01-28 18:29:49 +00:00
|
|
|
if (isset($string[ $length ])) {
|
2014-04-01 18:38:34 +00:00
|
|
|
$length -= min($length, strlen($etc));
|
|
|
|
if (!$break_words && !$middle) {
|
|
|
|
$string = preg_replace('/\s+?(\S+)?$/', '', substr($string, 0, $length + 1));
|
|
|
|
}
|
|
|
|
if (!$middle) {
|
|
|
|
return substr($string, 0, $length) . $etc;
|
|
|
|
}
|
|
|
|
|
|
|
|
return substr($string, 0, $length / 2) . $etc . substr($string, - $length / 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $string;
|
|
|
|
}
|