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 :

Comment Filtrer avec query builder with Entity


Sujet :

Symfony PHP

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2011
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2011
    Messages : 19
    Points : 14
    Points
    14
    Par défaut Comment Filtrer avec query builder with Entity
    Bonjour,

    Sous Symfony 2.3 avec JordiLlonchCrudGeneratorBundle :

    J'ai une entité Activité qui contient une relation ManyToOne avec une entité Client (JoinColumn(nullable=false))

    J'ai généré mon CRUD avec JordiLlonchCrudGeneratorBundle et ça marche très bien.

    Seulement, quand j'affiche la liste des activités, j'aimerai pouvoir filtrer par client.

    J'ai donc créé une fonction dans ClientRepository.php :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    public function findActifClients()
      {
        $qb = $this->createQueryBuilder('a');
     
        $qb->where('a.actif = :actif')
          ->setParameter('actif', true)
          ->orderBy('a.nom', 'ASC');
     
        return $qb;
      }
    Ensuite j'ai édité mon ActiviteFilterType.php de la manière suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    class ActiviteFilterType extends AbstractType
    {
        public function buildForm(FormBuilderInterface $builder, array $options)
        {
            $builder
                ->add('nom', 'filter_text')
     
                ->add('client', 'entity', array(
                     'class' => 'Too\ClientBundle\Entity\Client',
                     'property' => 'nom',
                     'required' => false,
                     'query_builder' => function(EntityRepository $er) {
                     return $er->findActifClients();
                    }
                ))
        ...
    Maintenant quand j'affiche la liste des activités je trouve bien la possibilité de filtrer par client mais le problème arrive quand je veux effectivement filtrer sur un client donné :

    ça n'a aucun effet - la liste des activité reste la même comme si je n'avais pas de filtre.

    Il y a quelque chose qui m'echappe là

    Pouvez vous m'aider ?

  2. #2
    Membre à l'essai
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2011
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2011
    Messages : 19
    Points : 14
    Points
    14
    Par défaut
    Je continue à chercher sans succès.

    Ce qui m'étonne c'est la chose suivante :

    Voici une autre version qui marche mais étant donné que je renseigne statiquement le tableau des clients c'est pas valable comme solution :

    ActiviteFilterType.php :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    class ActiviteFilterType extends AbstractType
    {
        public function buildForm(FormBuilderInterface $builder, array $options)
        {
            $myclients = array(
                            "1" => "Client01",
                            "4" => "Client02",
                    );
     
            $builder
                ->add('nom', 'filter_text')
     
                ->add('client', 'filter_choice', array(
                    'choices' => $myclients,
                ))
        ...
    Comme je disait cette version fonctionne : je peux choisir dans la liste des clients actifs et en clquant sur Filtrer j'obtiens la liste avec exclusivement des activités lié à ce client.

    Ce qui m'étonne : cette version générer strictement le même code HTML dans le form que la première version (dynamique) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <div>
        <label for="too_clientbundle_activitefiltertype_client">Client</label>
        <select id="too_clientbundle_activitefiltertype_client" name="too_clientbundle_activitefiltertype[client]">
            <option value=""></option>
            <option value="1">Client01</option>
            <option value="4">Client02</option>
        </select>
    </div>
    N'hésitez pas à me donner même juste des petites indications ...

Discussions similaires

  1. Réponses: 0
    Dernier message: 13/01/2011, 08h09
  2. INSERT avec query builder
    Par gg2vig dans le forum Toad
    Réponses: 1
    Dernier message: 12/07/2010, 16h45
  3. Comment filtrer avec une case insensitive ?
    Par savoir dans le forum Débuter
    Réponses: 2
    Dernier message: 06/09/2007, 11h09
  4. Comment configurer active query builder
    Par davos56 dans le forum Bases de données
    Réponses: 4
    Dernier message: 21/04/2007, 07h38
  5. Comment filtrer avec une liste déroulante
    Par nicou50 dans le forum Access
    Réponses: 16
    Dernier message: 02/09/2006, 02h04

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