>我想知道创建一个表单的最佳方法是什么,该表单在symfony2中处理具有额外字段的多对多关系。
例如,假设我想为用户创建一个通知功能。我有User
和Notification
实体。同样为了能够在实体之间的多对多关系中添加额外的参数,我创建了第三个实体UserNotification
。extra 参数指示用户是否已阅读通知。
* @ORMEntity() */
class Notification
{
/** @Id @Column(type="integer") */
private $id;
/** @OneToMany(targetEntity="UserNotification", mappedBy="notification") */
private $usernotifications;
/** @Column() */
private $message;
...
}
* @ORMEntity() */
class User
{
/** @Id @Column(type="integer") */
private $id;
/** @OneToMany(targetEntity="UserNotification", mappedBy="user") */
private $usernotifications;
/** @Column() */
private $name;
...
}
* @ORMEntity() */
class UserNotification
{
/** @ManyToOne(targetEntity="User", inversedBy="usernotifications")
private $user;
/** @ManyToOne(targetEntity="Message", inversedBy="usernotifications")
private $message;
/** @Column(type="boolean") */
private $isRead;
...
}
这样我就可以获得这种数据
User
+----+---------+
| id | name |
+----+---------+
| 1 | John |
| 2 | Paul |
+----+---------+
Notification
+----+----------------------+
| id | message |
+----+----------------------+
| 1 | Cool stuff |
| 2 | Lorem ipsum |
+----+----------------------+
UserNotification
+---------+-----------------+---------+
| user_id | notification_id | isRead |
+---------+-----------------+---------+
| 1 | 1 | 1 |
| 2 | 1 | 0 |
| 1 | 2 | 0 |
| 2 | 2 | 1 |
+---------+-----------------+---------+
好的,现在问题来了,如何制作一个允许向某些用户发送通知的表单?对于经典的多对多关系,这不是问题。我有以下builder
NotificationType
:
$builder->add('users', 'entity', array(
'class' => 'User',
'property' => 'name',
'multiple' => 'true',
))
->add('message', 'text');
但是由于我必须创建中间UserNotification
实体,我不知道该怎么做。感谢您的帮助;)
我做了完全相同的事情。我的InternalMessage
实体是你的Notification
。在表单中,users
字段未映射(property_path
false
),并使用订阅者进行验证:
public function buildForm(FormBuilder $builder, array $options)
{
$builder
->add('title', 'text', array(
'label' => 'Titolo *'
))
->add('content', 'textarea', array(
'label' => 'Contenuto *'
))
->add('priority', new PriorityType(), array(
'label' => 'Priorità *'
))
->add('users', 'entity', array(
'label' => 'Destinatari *',
'class' => 'AcmeHelloBundleEntityUser',
'property' => 'select_label',
'multiple' => true,
'expanded' => true,
'property_path' => false,
));
;
$builder->addEventSubscriber(new AddUsersValidationSubscriber());
}
在我的控制器中,我唯一要做的就是(假设表单有效)是在表单模型中的每个用户之前创建一个InternalMessageFeedback
实体(与您的UserNotification
相同):
$message = new InternalMessage();
$form = $this->createForm(new InternalMessageType(), $message);
// ...
// The sender
$message->setUser($this->getSecurityContext()->getToken()->getUser());
// Persist the inverse side
$em = $this->getEntityManager();
$em->persist($message);
// One feedback for each user
/** @var $user AcmeHelloBundleEntityUser */
foreach($form->get('users')->getData() as $user) {
$feedback = new InternalMessageFeedback();
// Se the message and user for current feedback
$feedback->setInternalMessage($message);
$feedback->setUser($user);
// Persist the owning side
$em->persist($feedback);
// Sync the inverse side
$message->addInternalMessageFeedback($feedback);
}
$em->flush();
希望这对:)有所帮助