PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Symfony 2.3 Dynamisches Formular
Beitrag
<blockquote data-quote="Greenhorn79" data-source="post: 2504271" data-attributes="member: 346865"><p>Hallo zusammen,</p><p></p><p>ich bräuchte ein dynamisches Formular in Symfony 2.3. Ich suche und probiere nun schon 14 Tage aber ich finde einfach keine Lösung.</p><p></p><p>Ich habe zwei Entities eine Projekt und eine Artikel mit einer ManytoOne-Beziehung, was in der Article.php so aussieht:</p><p></p><p>[php]/**</p><p> * @ORM\ManyToOne(targetEntity="Pso\ProjectBundle\Entity\Project", inversedBy="article")</p><p> * @ORM\JoinColumn(name="project_id", referencedColumnName="id")</p><p> */</p><p> private $projects;[/php]</p><p></p><p>Der Controller sieht wie folgt aus ( es soll hier ein mal das Projekt dargestellt werden was auch ohne Probleme funktioniert und einmal die zugehörigen Artikel was leider nicht funktioniert):</p><p></p><p>[php]public function maintainProjectAction(id $id, Request $request)</p><p> {</p><p> $em = $this->getDoctrine()->getManager(); </p><p> $project = $em->getRepository('PsoProjectBundle:Project')->find($id);</p><p> $form = $this->createForm(new MaintainProjectType(),$project);</p><p> $form->handleRequest($request);</p><p> </p><p> //$article = $em->getRepository('PsoProjectBundle:Project')->findArticle($id);</p><p> //return New Response (var_dump($article));</p><p> //$form2 = $this->createForm(new ArticleType($article));</p><p> //$form2 = $this->createForm(new ArticleType($article),$form_data);</p><p> //$form2 = $this->createForm(new ArticleType(),$article);</p><p> $form2 = $this->createForm(new ArticleType($id));</p><p> $form2->handleRequest($request);</p><p>}[/php]</p><p></p><p>An den Kommentaren sieht man, dass ich schon verschiedenes versucht habe <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" class="smilie smilie--sprite smilie--sprite1" alt=":-)" title="Smile :-)" loading="lazy" data-shortname=":-)" /></p><p></p><p>Im Repository findet man einen entsprechenden Select, der auch die richtigen Daten liefert:</p><p>[php]public function findArticle($id)</p><p> {</p><p> return $this->getEntityManager()</p><p> ->createQuery(</p><p> 'SELECT a.id,a.category,a.product_description,a.article_nr,a.color,a.carton_qty</p><p> FROM PsoProjectBundle:article a</p><p> JOIN a.projects p</p><p> WHERE p.id = :id</p><p> '</p><p> )</p><p> ->setParameter('id', $id)</p><p> ->getResult();</p><p> }[/php]</p><p></p><p>Mein ArticleType sieht momentan so aus:</p><p></p><p>[php]<?php</p><p></p><p>namespace Pso\ProjectBundle\Form;</p><p></p><p>use Symfony\Component\Form\AbstractType;</p><p>use Symfony\Component\Form\FormBuilderInterface;</p><p>use Symfony\Component\OptionsResolver\OptionsResolverInterface;</p><p></p><p></p><p>class ArticleType extends AbstractType</p><p>{</p><p></p><p>protected $id;</p><p></p><p> public function __construct(id $id) {</p><p> $this->id = $id;</p><p> }</p><p> </p><p> public function buildForm(FormBuilderInterface $builder, array $options)</p><p> { </p><p> $id = $this->id;</p><p> $builder</p><p> ->add('category','text', array('label' => 'Category'))</p><p> ->add('product_description','text', array('label' => 'Product description'))</p><p> ->add('article_nr','text', array('label' => 'Article-Nr'))</p><p> ->add('id', 'entity', array(</p><p> 'class' => 'PsoProjectBundle:Article',</p><p> 'query_builder' => function(EntityRepository $er) use ($id) {</p><p> return $er->createQuery ('SELECT a.id</p><p> FROM PsoProjectBundle:article a</p><p> JOIN a.projects p</p><p> WHERE p.id = :id')</p><p> ;</p><p> },</p><p> ))</p><p> ->add('color','text', array('label' => 'color'))</p><p> ->add('carton_qty','text', array('label' => 'carton_qty'))</p><p> ->add('qty','text', array('label' => 'qty'))</p><p> ->add('carton','text', array('label' => 'carton'))</p><p> ->add('size','text', array('label' => 'size'))</p><p> ->add('price','text', array('label' => 'price'))</p><p> ->add('price_calculation_file','text', array('label' => 'price_calculation_file'))</p><p> ->add('closed','text', array('label' => 'closed'))</p><p> ->add('dbinsert','text', array('label' => 'dbinsert'))</p><p> ->add('dbupdate','text', array('label' => 'dbupdate'))</p><p> ->add('product_packaging','text', array('label' => 'product_packaging'))</p><p> ->add('outer_packaging','text', array('label' => 'outer_packaging'))</p><p> ->add('submit', 'submit', array(</p><p> 'attr'=> array (</p><p> 'formnovalidate' => 'formnovalidate')))</p><p> ;</p><p> }</p><p> </p><p> public function setDefaultOptions(OptionsResolverInterface $resolver)</p><p> {</p><p> $resolver->setDefaults(array(</p><p> 'data_class' => 'Pso\ProjectBundle\Entity\Article',</p><p> ));</p><p> }</p><p> </p><p> </p><p> public function getName()</p><p> {</p><p> return 'Article';</p><p> }</p><p>}[/php]</p><p></p><p>Dies so wie es jetzt aussieht, bewirkt immer den Fehler </p><p></p><p>Mittlerweile habe ich soviel probiert, verschiedene Fehler erhalten, aber ich komme nicht weiter. Daher wäre ich unsagbar froh, wenn jemand einen Tipp für mich hätte.</p><p></p><p>Viele Grüße</p><p>Micha</p></blockquote><p></p>
[QUOTE="Greenhorn79, post: 2504271, member: 346865"] Hallo zusammen, ich bräuchte ein dynamisches Formular in Symfony 2.3. Ich suche und probiere nun schon 14 Tage aber ich finde einfach keine Lösung. Ich habe zwei Entities eine Projekt und eine Artikel mit einer ManytoOne-Beziehung, was in der Article.php so aussieht: [php]/** * @ORM\ManyToOne(targetEntity="Pso\ProjectBundle\Entity\Project", inversedBy="article") * @ORM\JoinColumn(name="project_id", referencedColumnName="id") */ private $projects;[/php] Der Controller sieht wie folgt aus ( es soll hier ein mal das Projekt dargestellt werden was auch ohne Probleme funktioniert und einmal die zugehörigen Artikel was leider nicht funktioniert): [php]public function maintainProjectAction(id $id, Request $request) { $em = $this->getDoctrine()->getManager(); $project = $em->getRepository('PsoProjectBundle:Project')->find($id); $form = $this->createForm(new MaintainProjectType(),$project); $form->handleRequest($request); //$article = $em->getRepository('PsoProjectBundle:Project')->findArticle($id); //return New Response (var_dump($article)); //$form2 = $this->createForm(new ArticleType($article)); //$form2 = $this->createForm(new ArticleType($article),$form_data); //$form2 = $this->createForm(new ArticleType(),$article); $form2 = $this->createForm(new ArticleType($id)); $form2->handleRequest($request); }[/php] An den Kommentaren sieht man, dass ich schon verschiedenes versucht habe :-) Im Repository findet man einen entsprechenden Select, der auch die richtigen Daten liefert: [php]public function findArticle($id) { return $this->getEntityManager() ->createQuery( 'SELECT a.id,a.category,a.product_description,a.article_nr,a.color,a.carton_qty FROM PsoProjectBundle:article a JOIN a.projects p WHERE p.id = :id ' ) ->setParameter('id', $id) ->getResult(); }[/php] Mein ArticleType sieht momentan so aus: [php]<?php namespace Pso\ProjectBundle\Form; use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\FormBuilderInterface; use Symfony\Component\OptionsResolver\OptionsResolverInterface; class ArticleType extends AbstractType { protected $id; public function __construct(id $id) { $this->id = $id; } public function buildForm(FormBuilderInterface $builder, array $options) { $id = $this->id; $builder ->add('category','text', array('label' => 'Category')) ->add('product_description','text', array('label' => 'Product description')) ->add('article_nr','text', array('label' => 'Article-Nr')) ->add('id', 'entity', array( 'class' => 'PsoProjectBundle:Article', 'query_builder' => function(EntityRepository $er) use ($id) { return $er->createQuery ('SELECT a.id FROM PsoProjectBundle:article a JOIN a.projects p WHERE p.id = :id') ; }, )) ->add('color','text', array('label' => 'color')) ->add('carton_qty','text', array('label' => 'carton_qty')) ->add('qty','text', array('label' => 'qty')) ->add('carton','text', array('label' => 'carton')) ->add('size','text', array('label' => 'size')) ->add('price','text', array('label' => 'price')) ->add('price_calculation_file','text', array('label' => 'price_calculation_file')) ->add('closed','text', array('label' => 'closed')) ->add('dbinsert','text', array('label' => 'dbinsert')) ->add('dbupdate','text', array('label' => 'dbupdate')) ->add('product_packaging','text', array('label' => 'product_packaging')) ->add('outer_packaging','text', array('label' => 'outer_packaging')) ->add('submit', 'submit', array( 'attr'=> array ( 'formnovalidate' => 'formnovalidate'))) ; } public function setDefaultOptions(OptionsResolverInterface $resolver) { $resolver->setDefaults(array( 'data_class' => 'Pso\ProjectBundle\Entity\Article', )); } public function getName() { return 'Article'; } }[/php] Dies so wie es jetzt aussieht, bewirkt immer den Fehler Mittlerweile habe ich soviel probiert, verschiedene Fehler erhalten, aber ich komme nicht weiter. Daher wäre ich unsagbar froh, wenn jemand einen Tipp für mich hätte. Viele Grüße Micha [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 5, ▼ = 2 und ■ = 7, was ist ▲ × ▼ + ■?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Symfony 2.3 Dynamisches Formular
Oben