У меня есть список элементов, показываемых пользователю, и я хочу, чтобы у него была небольшая «кнопка» (на самом деле, я предпочитаю значок). Чтобы быть уверенным, что мы не сможем удалить каждый файл циклом, я хочу, чтобы форма удаляла его.
Итак, в моем действии индекса я создал форму по элементам:
/**
* @Route("/files", name = "files")
* @return \Symfony\Component\HttpFoundation\Response
*/
public function files() {
$repository = $this->getDoctrine()->getRepository("App:Document");
$files = $repository->findBy([], ["createdAt" => "DESC"]);
$forms = [];
foreach ($files as $file) {
$forms[$file->getId()] = $this->createForm(DocumentRemoveType::class, $file)->createView();
}
return $this->render("admin/files.html.twig", [
"files" => $files,
"forms" => $forms
]);
}
Затем, в моем представлении ветки, я показываю каждую форму:
{% for file in files %}
{# @var file \App\Entity\Document #}
<tr>
<th scope = "row">{{ file.name }}</th>
<td>{{ file.createdAt|date("d/m/Y") }}</td>
<td class = "text-center">
<a href = "{{ vich_uploader_asset(file, 'file') }}" target = "_blank" title = "Télécharger le document"><i class = "fa fa-download"></i></a>
{{ form_start(forms[file.id], {attr: {class: 'my-form-class'} }) }}
{{ form_widget(forms[file.id]) }}
{{ form_end(forms[file.id]) }}
</td>
</tr>
{% endfor %}
Тогда вот DocumentRemoveType
class DocumentRemoveType extends AbstractType
{
private $urlGenerator;
public function __construct(UrlGeneratorInterface $urlGenerator)
{
$this->urlGenerator = $urlGenerator;
}
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder->add("id", HiddenType::class)
->setAction($this->urlGenerator->generate("admin_files_deletion"))
->add("removeButton", SubmitType::class);
}
}
И, наконец, вот действие для удаления:
/**
* @Route("/files/delete", name = "admin_files_deletion")
* @param Request $request
* @return \Symfony\Component\HttpFoundation\RedirectResponse
*/
public function filesDeletion(Request $request) {
$form = $this->createForm(DocumentRemoveType::class);
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
$manager = $this->getDoctrine()->getManager();
$file = $manager->find(Document::class, $manager["id"]);
$manager->remove($file);
$manager->flush();
}
return $this->redirectToRoute('admin_files');
}
Честно говоря, я не совсем уверен, иду ли я по правильному пути. На данный момент это работает, НО я хотел бы иметь небольшую пиктограмму вместо этой уродливой кнопки ввода. Ты знаешь, как мне это сделать?
Если вы заметили что-то не так в коде, не стесняйтесь замечать меня.
Не совсем, потому что я должен использовать SubmitType, не так ли?
Не совсем. Использовать SubmitType не обязательно. На самом деле в таких случаях рекомендуется использовать простой HTML.
А что касается приведенного выше кода, это хороший способ сделать это? Итак, вы говорите, что я должен просто использовать CSS, чтобы получить то, что я хочу?






Благодаря комментариям я понял, что мне просто нужно было добавить кнопку прямо в представление:
{% for file in files %}
{# @var file \App\Entity\Document #}
<tr>
<th scope = "row">{{ file.name }}</th>
<td>{{ file.createdAt|date("d/m/Y") }}</td>
<td class = "text-center">
{{ form_start(forms[file.id], { "attr" : { "onsubmit" : "return confirm('Êtes-vous certain de supprimer ce document?');"}}) }}
<a href = "{{ vich_uploader_asset(file, 'file') }}" target = "_blank" title = "Télécharger le document"><i class = "fa fa-download"></i></a>
<button type = "submit" class = "buttonAsLink"><i class = "fa fa-close"></i></button>
{{ form_widget(forms[file.id]) }}
{{ form_end(forms[file.id]) }}
</td>
</tr>
{% endfor %}
И я удалил SubmitType в своей форме. Теперь все работает как положено.
Всем спасибо
Вы просто спрашиваете, как сделать иконку кнопкой? Это вопрос HTML / CSS.