1 対多の関係を表現して、発注書の詳細で発注書を保持したいので、詳細ごとにテーブル行をインクリメントして発注書の詳細リストを追加しようとしました。そのために、次のように PurchaseOrderDetailType フォーム タイプを開発しました。
class PurchaseOrderDetailType extends AbstractType{
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder->add('item',EntityType::class, array(
'class' => 'AppBundle:InvtItem',
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('item')
->orderBy('item.description', 'ASC');
},
'choice_label' => 'description',
))
->add('unit_price')
->add('qty')
->add('price');
}
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'AppBundle\Entity\PurchaseOrderDetails'
));
}
}
次に、このように PurchaseOrderType クラスで使用します
class PurchaseOrderType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('supplier',EntityType::class, array(
'class' => 'AppBundle:Supplier',
'label'=>'Supplier',
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('supplier')
->orderBy('supplier.name', 'ASC');
},
'choice_label' => 'name',
))
->add('purchaseOrderDetails',CollectionType::class,array(
'entry_type' => PurchaseOrderDetailType::class,
'allow_add' => true
))
->add('status');
}
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'AppBundle\Entity\PurchaseOrder'
));
}
}
次に、このエラーが発生しました => タイプ "PurchaseOrderDetailType" を読み込めませんでした 500 Internal Server Error - InvalidArgumentException