将具有额外字段的多对多关系呈现到表单中



>我想知道创建一个表单的最佳方法是什么,该表单在symfony2中处理具有额外字段的多对多关系。

例如,假设我想为用户创建一个通知功能。我有UserNotification实体。同样为了能够在实体之间的多对多关系中添加额外的参数,我创建了第三个实体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();

希望这对:)有所帮助

相关内容

  • 没有找到相关文章