データベースにエンティティ データを挿入する必要があるときに問題が発生します。
エンティティは Symfony2 のエンティティ フィールドで表示され、クエリ ビルダーを使用して「アクティブ」なデータのみを表示しています。(下記参照)
Ajax を介して Symfony によって生成された「select」にデータを追加できます (アクティブではない新しい「profs」(is_active = 0))。しかし、Ajax を介して追加され、アクティブでないデータを選択すると、「この値は無効です」というエラーが表示されます。=> これは、Symfony2 がクエリビルダーの "where" ステートメントによる自動検証を追加するためです。
デフォルトの Symfony2 の動作をオーバーライドして、アクティブでない (is_active = 0 (ブール値)) -Ajax を介して追加された要素も検証できるようにすることは可能ですか?
$builder->add('professionA', 'genemu_jquerychosen_entity', array(
'class' => 'SportUserBundle:Profession',
'query_builder' => function(EntityRepository $er) {
return $er->createQueryBuilder('prof')
->where('prof.is_active = :active')
->setParameters(array('active' => '1'))
->orderBy('prof.name', 'ASC');
},
));
ありがとう!