Есть ли лучшая практика для извлечения URI изображения в текущем переводе текущего доступа к сайту в веточку?
У нас есть объект с переводимым полем изображения. Рендеринг изображения с помощником: ez_render_field
работает отлично.
Но теперь мне нужно также извлечь URI изображения для текущего доступа к сайту, но я не могу найти способ сделать это.
Пытаясь использовать ez_field просто приводит к
{{ ez_field(content, "image_1").uri }}
Исключение было сгенерировано во время рендеринга шаблона.
(«Catchable Fatal Error: Объект класса
eZ \ Publish \ API \ Repository \ Values \ Content \ Field не удалось преобразовать
нанизывать»).
Вот стандартный способ достижения этого.
где image
это имя поля и teaser
это вариант изображения, который вы определили. по умолчанию у вас есть original
, small
, large
а также ….
{% set imgAlias = ez_image_alias( content.getField( "image" ), content.versionInfo, 'teaser' ) %}
{{ dump(imgAlias.url) }}
( imgAlias.url
это то, что вы ищете. )
вот ссылка на документацию: https://doc.ez.no/display/DEVELOPER/ez_image_alias
Я не знаю, является ли это лучшим методом, но вот что я придумал:
{{ getImageUri( content.fields.image, ezpublish.siteaccess ) }}
Пользовательские функции ветки
use Symfony\Component\Yaml\Yaml;
/**
* Class AppExtension
*
* @package AppBundle\Twig
*/
class AppExtension extends \Twig_Extension
{
public function getFilters()
{
return [
];
}
public function getFunctions()
{
return [
new \Twig_SimpleFunction('getYml', [$this, 'getYml']),
new \Twig_SimpleFunction('getImageUri', [$this, 'getImageUri']),
];
}
/**
* Pass an image object and return the original image uri in the current site access
*
* @param $imageField
* @param $siteAccess
*
* @return mixed
*/
public function getImageUri( $imageField, $siteAccess ){
$languages = $this->getYml('ezplatform', 'ezpublish:system:'.$siteAccess->name.':languages');
if($languages){
foreach($languages as $language){
if( array_key_exists( $language, $imageField ) ){
return $imageField[$language]->uri;
}
}
}
return $imageField[array_keys($imageField)[0]]->uri;
}
/**
* Internal cache of the yml files already fetched
*
* @var array
*/
private $yamlCache = [];
/**
* Return content from a app/config/*.yml file. Pass in a : separated path to fetch what you need. Empty returns the whole yml as an array
*
* @param $fileMinusExt
* @param bool $path
* @param string $delimiter
*
* @return bool|mixed
*/
public function getYml($fileMinusExt, $path = false, $delimiter = ':')
{
if (in_array($fileMinusExt, $this->yamlCache)) {
$value = $this->yamlCache[$fileMinusExt];
} else {
$value = Yaml::parse(file_get_contents('../app/config/' . $fileMinusExt . '.yml'));
}
if ($path === false) {
return $value;
}
return $this->_getYmlPath($value, explode($delimiter, $path));
}
/**
* Extract value from array
*
* @param $values
* @param $parts
*
* @return bool
*/
private function _getYmlPath($values, $parts)
{
try {
$subVal = $values[array_shift($parts)];
if (count($parts) > 0) {
return $this->_getYmlPath($subVal, $parts);
}
return $subVal;
} catch (\Exception $e) {
return false;
}
}
}