VichUploaderBundle: отключить автоматический рендеринг изображений в виде веточек

1

Как отключить автоматический рендеринг изображений при использовании VichUploaderBundle? Я отображаю изображения отдельно в форме ветки, поэтому мне не нужен VichUploaderBundle для рендеринга изображения.

Мой код можно увидеть ниже:

/**
 * @Route("/testupload", name="testupload")
 */
public function testUploadAction(Request $request){

    $testUpload = new TestUpload();
    $em = $this->getDoctrine()->getManager();

    $form = $this->createFormBuilder($testUpload)
        ->add('imageFile', VichImageType::class, array(
            'label'             => false,
            'required'          => false,
            'image_uri'         => true,
            'download_link'     => false
        ))
        ->add('upload',SubmitType::class, array('label' => 'Upload'))
        ->getForm();

    $form->handleRequest($request);

    if ($form->isSubmitted() && $form->isValid()) {
        $testUpload = $form->getData();
        $em->persist($testUpload);
        $em->flush();
    }

    $images = $em->getRepository(TestUpload::class)->findAll();

    return $this->render('main/rotta_upload_test.html.twig', [
        'title' => 'Upload test',
        'images' => $images,
        'form' => $form->createView()
    ]);

}

Шаблон веточки

<div class="large-8 medium-8 cell">
    <div class="callout">

        {{ form_start(form) }}            
        {{ form_widget(form) }}
        {{ form_end(form) }}

        {% for image in images %}
            <img src="{{ asset(vich_uploader_asset(image, 'imageFile')) 
}}" alt="image 1"  width="300" />
        {% endfor %}

    </div>
</div>

Любая помощь приветствуется.

  • 0
    Установите для image_uri значение false
  • 0
    это работает, спасибо!
Показать ещё 1 комментарий
Теги:
twig
vichuploaderbundle

1 ответ

0

Просто установите для image_uri значение false, чтобы предотвратить это:

$form = $this->createFormBuilder($testUpload)
        ->add('imageFile', VichImageType::class, array(
            'label'             => false,
            'required'          => false,
            'image_uri'         => false,
            'download_link'     => false
        ))
        ->add('upload',SubmitType::class, array('label' => 'Upload'))
        ->getForm();

см. соответствующую часть в форме form_theme (https://github.com/dustin10/VichUploaderBundle/blob/master/Resources/views/Form/fields.html.twig#L34):

{% block vich_image_widget %}
    {% spaceless %}
        <div class="vich-image">
            {{ form_widget(form.file) }}
            {% if form.delete is defined %}
                {{ form_row(form.delete) }}
            {% endif %}

            {% if image_uri %}
                <a href="{{ image_uri }}"><img src="{{ image_uri }}" alt="" /></a>
            {% endif %}
            {% if download_uri %}
                <a href="{{ download_uri }}">{{ translation_domain is same as(false) ? download_label : download_label|trans({}, translation_domain) }}</a>
            {% endif %}
        </div>
    {% endspaceless %}

Ещё вопросы

Сообщество Overcoder
Наверх
Меню