Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [Symfony][Symfony2][SF2]Formularz w formularzu, nie wiem dokładnie jak to nazwać
skowron-line
post
Post #1





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


Więc chce zrobić coś takiego
Mam 2 tabele
users i users_email_addresses
i teraz chce na stronie mieć 2 inputy
- nazwa użytkownika
- email użytkownika

I teraz tak stworzyłem sobie Entity
  1. class Users
  2. {
  3. /**
  4.   * @var integer
  5.   *
  6.   * @ORM\Column(name="id_users", type="smallint", nullable=false)
  7.   * @ORM\Id
  8.   * @ORM\GeneratedValue(strategy="IDENTITY")
  9.   */
  10. private $id;
  11.  
  12. /**
  13.   * @var string
  14.   *
  15.   * @ORM\Column(name="name", type="string", length=100, nullable=true)
  16.   */
  17. private $name;
  18. /**
  19.   *
  20.   * @var ArrayCollection
  21.   * @ORM\OneToMany(targetEntity="UsersEmailAddresses", mappedBy="users")
  22.   */
  23. private $email;

i
  1. class UsersEmailAddresses
  2. {
  3. /**
  4.   * @var integer
  5.   *
  6.   * @ORM\Column(name="id_users_email_adresses", type="smallint", nullable=false)
  7.   * @ORM\Id
  8.   * @ORM\GeneratedValue(strategy="IDENTITY")
  9.   */
  10. private $id;
  11.  
  12. /**
  13.   * @var string
  14.   *
  15.   * @ORM\Column(name="email", type="string", length=100, nullable=true)
  16.   */
  17. private $email;
  18.  
  19. /**
  20.   * @var type
  21.   *
  22.   * @ORM\ManyToOne(targetEntity="Users", inversedBy="email")
  23.   * @ORM\JoinColumn(name="users_id", referencedColumnName="id_users")
  24.   */
  25. private $users;


I teraz w deklaracji formularza mam coś takiego
  1. public function buildForm(FormBuilderInterface $builder, array $options)
  2. {
  3. $builder
  4. ->add('name')
  5. ->add('email', 'collection', array(
  6. 'type'=> new UsersEmailAddressesType(),
  7. ))
  8. ;
  9. }
  10.  
  11. public function setDefaultOptions(OptionsResolverInterface $resolver)
  12. {
  13. $resolver->setDefaults(array(
  14. 'data_class' => 'Test\UserBundle\Entity\Users',
  15. 'cascade_validation' => true
  16. ));
  17. }

Jako że przy dodawaniu nowego usera nie ma żadnego adresu email to pole input się nie wyświetla więc na hama dodałem (tak wiem że na stronie jest opcja dodawania pola przez JS)
  1. $email = new \Test\UserBundle\Entity\UsersEmailAddresses;
  2. $formEmail = $this->createForm(new \Test\UserBundle\Form\UsersEmailAddressesType, $email);
  3.  
  4. return array(
  5. 'email_form' => $formEmail->createView(),
  6. 'entity' => $entity,
  7. 'form' => $form->createView(),
  8. );


I wszystko było by ok gdyby nie to że po wysłaniu formularza dostaje komunikat
Cytat
Catchable Fatal Error: Argument 1 passed to Test\UserBundle\Entity\Users::setEmail() must be an instance of Test\UserBundle\Entity\UsersEmailAddresses, array given..

No i teraz pytanie brzmi czy dobrze się do tego zabrałem (IMG:style_emoticons/default/questionmark.gif) Bo jak mam przekazać obiekt UsersEmailAddresses w sytuacji kiedy chce aby najpierw user wpadl do bazy a pozniej adres email z id_users wczesniej dodanego.

Chyba że to działa
insert (email)
id = insert (users)
update (email) set users_id = id
(a tak podejrzewam że to działa)

Ps Sorki za może głupie pytanie ale z ORM do tej pory miałem nie wiele wspólnego.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
skowron-line
post
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


Już nie moge gapie się w to i gapie i nie moge znaleźć błędu
  1. <?php
  2.  
  3. namespace Test\UserBundle\Entity;
  4.  
  5. use Doctrine\ORM\Mapping as ORM;
  6. use Symfony\Component\Validator\Constraints as Assert;
  7. use Doctrine\Common\Collections\ArrayCollection;
  8.  
  9. /**
  10.  * Users
  11.  *
  12.  * @ORM\Table(name="users")
  13.  * @ORM\Entity
  14.  */
  15. class Users
  16. {
  17. /**
  18.   * @var integer
  19.   *
  20.   * @ORM\Column(name="id", type="smallint", nullable=false)
  21.   * @ORM\Id
  22.   * @ORM\GeneratedValue(strategy="IDENTITY")
  23.   */
  24. private $id;
  25.  
  26. /**
  27.   * @var string
  28.   *
  29.   * @ORM\Column(name="name", type="string", length=100, nullable=true)
  30.   * @Assert\NotBlank()
  31.   */
  32. private $name;
  33. /**
  34.   *
  35.   * @var ArrayCollection
  36.   * @ORM\OneToMany(targetEntity="UsersEmailAddresses", mappedBy="users", cascade={"persist", "remove"})
  37.   */
  38. private $email;
  39.  
  40. public function __construct()
  41. {
  42. $this->email = new ArrayCollection();
  43. }
  44. /**
  45.   * Get idUsers
  46.   *
  47.   * @return integer
  48.   */
  49. public function getId()
  50. {
  51. return $this->id;
  52. }
  53.  
  54. /**
  55.   * Set name
  56.   *
  57.   * @param string $name
  58.   * @return Users
  59.   */
  60. public function setName($name)
  61. {
  62. $this->name = $name;
  63.  
  64. return $this;
  65. }
  66.  
  67. /**
  68.   * Get name
  69.   *
  70.   * @return string
  71.   */
  72. public function getName()
  73. {
  74. return $this->name;
  75. }
  76.  
  77. public function addEmail(\Test\UserBundle\Entity\UsersEmailAddresses $email)
  78. {
  79. $this->email = $email;
  80. $email->setUsers($this);
  81. return $this;
  82. }
  83.  
  84.  
  85. public function getEmail()
  86. {
  87. return $this->email;
  88. }
  89.  
  90. }

  1. <?php
  2.  
  3. namespace Test\UserBundle\Entity;
  4.  
  5. use Doctrine\ORM\Mapping as ORM;
  6. use Symfony\Component\Validator\Constraints as Assert;
  7.  
  8. /**
  9.  * UsersEmailAddresses
  10.  *
  11.  * @ORM\Table(name="users_email_addresses")
  12.  * @ORM\Entity
  13.  */
  14. class UsersEmailAddresses
  15. {
  16. /**
  17.   * @var integer
  18.   *
  19.   * @ORM\Column(name="id", type="smallint", nullable=false)
  20.   * @ORM\Id
  21.   * @ORM\GeneratedValue(strategy="IDENTITY")
  22.   */
  23. private $id;
  24.  
  25. /**
  26.   * @var string
  27.   *
  28.   * @ORM\Column(name="email", type="string", length=100, nullable=true)
  29.   * @Assert\NotBlank()
  30.   */
  31. private $email;
  32.  
  33. /**
  34.   * @var type
  35.   *
  36.   * @ORM\ManyToOne(targetEntity="Users", inversedBy="email")
  37.   * @ORM\JoinColumn(name="users_id", referencedColumnName="id")
  38.   */
  39. private $users;
  40. /**
  41.   * Get idUsersEmailAdresses
  42.   *
  43.   * @return integer
  44.   */
  45. public function getId()
  46. {
  47. return $this->id;
  48. }
  49.  
  50. /**
  51.   * Set email
  52.   *
  53.   * @param string $email
  54.   * @return UsersEmailAddresses
  55.   */
  56. public function setEmail($email)
  57. {
  58. $this->email = $email;
  59.  
  60. return $this;
  61. }
  62.  
  63. /**
  64.   * Get email
  65.   *
  66.   * @return string
  67.   */
  68. public function getEmail()
  69. {
  70. return $this->email;
  71. }
  72.  
  73. public function setUsers(\Test\UserBundle\Entity\Users $users)
  74. {
  75. $this->users = $users;
  76.  
  77. return $this;
  78. }
  79.  
  80. public function getUsers()
  81. {
  82. return $this->users;
  83. }
  84. }

i kontroler jak w poprzednim poscie.

I nadal się nie zapisuje users_id w tabeli users_email_adresses
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 15.10.2025 - 11:16