Проект Sonata Symfony2 sonata_type_model с сущностью OneToMany

Я работаю с Symfony2 и администратором сонаты. У меня есть сущность (новости), которой принадлежит подкатегория. Каждой подкатегории принадлежит одна категория, а каждой категории — один Affaire.
На странице добавления новостей у меня есть список подкатегорий, чтобы выбрать свою подкатегорию для ссылки на мои новости. Каждый элемент моего выбора форматируется так:

введите описание изображения здесь

<li> subcategory (category'affaire) > categoryName </li>.

Я хотел бы отсортировать поля по афера (ASC).

Вот мое определение поля формы:

protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->add('subCategory', 'sonata_type_model', array("label" => "Catégorie/Sous Catégorie", "btn_add" => false));
}

Одна новость собственная одна подкатегория

Одна подкатегория собственная одна категория

Одна категория, собственная, одна Affaire.

Я пытался добавить что-то вроде:

    ->add('subCategory', 'sonata_type_model',
array("label" => "Sub Category",
"btn_add" => false
),
array(
'sortable'      => 'ordering',
'label'         => 'subcategory.category.affaire.code',
))

Но ничего не меняется. Есть идеи ?

Категория объекта:

class NewsCategory
{
/**
* @var \My\Custom\Foo\Entity\Affaire
*
* @ORM\ManyToOne(targetEntity="\My\Custom\Foo\Entity\Affaire")
* @ORM\JoinColumn(name="affaire_code", referencedColumnName="code")
*/
private $affaire;


Подкатегория субъекта:

class NewsSubCategory
{
/**
* @var \My\Custom\Foo\Entity\NewsCategory
*
* @ORM\ManyToOne(targetEntity="\My\Custom\Foo\Entity\NewsCategory")
* @ORM\JoinColumn(name="category_ref", referencedColumnName="id")
*
*/
private $category;


Новостной объект:

class News
{
/**
* @var \My\Custom\Foo\Entity\NewsSubCategory
*
* @ORM\ManyToOne(targetEntity="\My\Custom\Foo\Entity\NewsSubCategory")
* @ORM\JoinColumn(name="sub_category", referencedColumnName="id")
*/
private $subCategory;
[РЕДАКТИРОВАТЬ] :

Я старался

->add('subCategory', 'sonata_type_model',array("label" => "Catégorie/Sous Catégorie","btn_add" => false), array("sortable" => "ordering"))

И я не ошибаюсь, но ничего не случилось. Я не понимаю, где я мог бы добавить опцию (orderBy => 'Affaire') или если это нужно сделать таким образом …

[EDIT2]:

Я даже попробовал:

->add('subCategory.category.affaire', null,
array("label" => "Catégorie/Sous Catégorie",
"btn_add" => false
))

2

Решение

Я не знаю, как вы можете сделать это с sonata_type_model, но вы можете изменить тип вашего поля на null или entity (null установить тип по умолчанию) и добавить опцию query_builder для адаптации используемого запроса:

->add('subcategory', null, array(
'query_builder' => function(EntityRepository $er) {
return $er->createQueryBuilder('sc')
->leftjoin('sc.category', 'c')
->orderBy('c.affaire', 'ASC');
}
))

Если вместо null вы выбираете сущность, вы должны также добавить класс:

->add('subcategory', 'entity', array(
'class' => 'MyCustomFooBundle:Subcategory',
'query_builder' => function(EntityRepository $er) {
return $er->createQueryBuilder('sc')
->leftjoin('sc.category', 'c')
->orderBy('c.affaire', 'ASC');
}
))
2

Другие решения

Кажется, что «Сортируемый» должен был быть в третьем параметре.

->add('subCategory', 'sonata_type_model',
array("label" => "Sub Category",
"btn_add" => false
'sortable'      => 'ordering',
))

И после этого у вас есть два варианта: Попытка показать Affaire

->add('subCategory.categorie.affaire', 'sonata_type_model',
array("label" => "Affaire",
"btn_add" => false
'sortable'      => 'ordering',
))

Или наша организация может реализовать «Коллекции Сортируемые». Попробуйте взглянуть на: https://github.com/Atlantic18/DoctrineExtensions/blob/master/doc/sortable.md

(Извините, я не владею английским языком)

1

По вопросам рекламы [email protected]