Есть 2 способа использовать ваши собственные шаблоны.
В конфигурационном файле:
sonata_doctrine_orm_admin:
entity_manager:
templates:
form:
- SonataDoctrineORMAdminBundle:Form:form_admin_fields.html.twig
filter:
- SonataDoctrineORMAdminBundle:Form:filter_admin_fields.html.twig
types:
list:
...
show:
...
image: YourBundle:YourFolder:yourtemplate.html.twig
и в файле определения поля:
<?php
namespace ...;
use Sonata\AdminBundle\Admin\Admin;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Datagrid\DatagridMapper;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Show\ShowMapper;
class ImageAdmin extends Admin
{
protected function configureShowField(ShowMapper $showMapper)
{
$showMapper
...
->add('image', 'image')
...
;
}
}
?>
ИЛИ 2-й путь:
<?php
namespace ...;
use Sonata\AdminBundle\Admin\Admin;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Datagrid\DatagridMapper;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Show\ShowMapper;
class ImageAdmin extends Admin
{
protected function configureShowField(ShowMapper $showMapper)
{
$showMapper
...
->add('image', 'string', array('template' => 'YourBundle:YourFolder:yourtemplate.html.twig'))
...
;
}
}
?>
А затем скопируйте приведенный ниже код к вашему шаблону:
{% extends 'SonataAdminBundle:CRUD:base_show_field.html.twig' %}
{% block field %}
<img src="{{ asset('uploads/media/') }}{{ value|nl2br }}"/>
{% endblock %}