IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Symfony PHP Discussion :

Tableau de contacts et checkboxes


Sujet :

Symfony PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 24
    Par défaut Tableau de contacts et checkboxes
    Bonjour,
    Je suis débutant avec Symfony, et je me demande quel moyen est le plus efficace pour ajouter une checkbox par ligne dans un tableau (table) afin de récupérer les identifiants dans une autre action.
    En fait, j'ai une liste de Contacts, et je voudrai après les avoir sélectionnés, envoyer un mail groupé, ou faire un publipostage.
    Je ne sais pas par où commencer : créer le formulaire directement dans le template ? Sinon, comment inclure mon tableau dans celui-ci ?
    Merci

  2. #2
    Membre extrêmement actif
    Avatar de dukoid
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2012
    Messages
    2 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 2 100
    Par défaut
    une des méthodes est d'utiliser L'option querybuilder.
    je te conseil vivement de consulter la doc officielle.

    le repository .... Repository
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    class ArticleRepository extends EntityRepository {
      public function getSelectList()  {
        $qb = $this->createQueryBuilder('a')
               ->where('a.publication = 1'); // On filtre sur l'attribut publication
     
        // Et on retourne simplement le QueryBuilder, et non la Query, attention
        return $qb;
      }
    les formulaire ...Type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    ->add('article', 'entity', array(
      'class'        => 'SdzBlogBundle:Article',
      'property'     => 'titre',
      'querybuilder' => function(\Sdz\BlogBundle\Entity\ArticleRepository $r) {
        return $r->getSelectList();
      },
    'multiple'=>true,
    'expanded'=>false )

    il faut bien sur adapter le code.(contact au lieu d'article....)
    bon courage

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 24
    Par défaut
    Merci beaucoup pour ta réponse rapide

    Si je comprend bien ton point de vue, je devrai créer un formulaire contenant un sous-formulaire par contact ?
    J'ai vu qu'il existe une option pour désactiver l'édition des lignes.
    Je pensais créer cette page un peu façon webmail, soit un tableau avec une checkbox sur chaque ligne, et mise de l'id en session lors de l'évènement Click.
    Ensuite, j'aurai une Select, et un bouton pour être redirigé vers une autre action (mail, publipostage...).
    Je vais travailler sur ton idée, merci beaucoup

  4. #4
    Membre extrêmement actif
    Avatar de dukoid
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2012
    Messages
    2 100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 2 100
    Par défaut
    un selectBox est plus indiqué peut être.
    c'est une liste de "contact" ou tu sélectionne les éléments voulu(sans la présence de bouton check)

    sinon pour le principe tu as un seul formulaire.
    un formulaire(......Type) qui contient un champ un peu special(un selectbox)
    le selectBox est rempli avec les valeurs de la requete du repository

    /repository/ toutes les class .......Repository (requête en base)
    /form/ toutes les class .......Type (formulaire)

    en gros :
    dans le controleur tu construis le formulaire avec le ....Type que tu envois à la page.
    la page affiche le formulaire.
    une fois le submit effectué :
    le controller recupere le choix effectué sur le select et c'est là que tu traite l'action que tu veux faire en fonction de la selection

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 24
    Par défaut
    Génial !
    Merci beaucoup pour ton idée

Discussions similaires

  1. [MySQL] recuperer une ligne d'un tableau en selectionant un checkbox
    Par ala1986 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 25/03/2010, 12h28
  2. creation d'un tableau en fonction dune checkbox
    Par keithsize dans le forum Langage
    Réponses: 4
    Dernier message: 04/06/2009, 14h46
  3. [Tableaux] Tableau à double entrée de checkbox
    Par r-zo dans le forum Langage
    Réponses: 5
    Dernier message: 28/11/2006, 13h54
  4. [Conception] Supprimer une ligne d'un tableau à partir d'un CHECKBOX
    Par snakejl dans le forum PHP & Base de données
    Réponses: 71
    Dernier message: 30/05/2006, 08h43
  5. [C#] Tableau généré contenant des checkbox
    Par la_muraille dans le forum ASP.NET
    Réponses: 3
    Dernier message: 04/04/2005, 12h16

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo