Précédent   Forum des professionnels en informatique > PHP > Bibliothèques et frameworks > symfony
symfony Forum d'entraide sur le framework PHP symfony. Avant de poster : cours symfony et FAQ symfony
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 02/10/2011, 12h33   #1
Candidat au titre de Membre du Club
 
Homme John
Développeur informatique
Inscription : avril 2008
Messages : 18
Détails du profil
Informations personnelles :
Nom : Homme John
Localisation : France, Nord (Nord Pas de Calais)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : avril 2008
Messages : 18
Points : 10
Points : 10
Par défaut Données d'une liste déroulante

Bonjour,

Apprenti dans le frameWork symfony, je souhaite réalisé une liste déroulante dans un formulaire généré par Doctrine.

Ces données sont dans une autre table (typedemande) que celle utilisée pour réaliser le formulaire et sont reliées par une clé étrangère.

La génération de mon formulaire m'a donc crée la liste déroulante mais avec des champs vides avec des values correspondants au ID de typeDemande.

J'ai donc crée une fonction dans typeDemandeTable afin de récupérer les valeurs qui m’intéresse:
Code :
1
2
3
4
5
6
7
8
 public function getTypes()
  {
     $q = Doctrine_Query::create()
      ->select("c.nom")
      ->from("typeDemande c");
 
     return $q->fetchArray();
  }
Ensuite dans la fonction configure() de mon formulaire j'ai modifié mon widget :
Code :
$this->widgetSchema['typeDemande'] = new sfWidgetFormSelect(array('choices'  => array_keys(Doctrine_Core::getTable('typeDemande')->getTypes())));
Mais cela ne change rien. Quelqu'un a une idée? Merci.
ctek59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/10/2011, 07h42   #2
Membre éclairé
 
Avatar de firehist
 
Homme Benjamin Longearet
Intégrateur Web Freelance
Inscription : février 2008
Messages : 153
Détails du profil
Informations personnelles :
Nom : Homme Benjamin Longearet
Âge : 24
Localisation : France

Informations professionnelles :
Activité : Intégrateur Web Freelance
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : février 2008
Messages : 153
Points : 357
Points : 357
Envoyer un message via Skype™ à firehist
Si ces données sont reliées par une clé étrangère, il te suffit de mieux décrire ta base de données dans le schema.yml avec les relations.

En faisant un build de ton application, cette liste déroulante doit apparaître dans ton formulaire.
__________________
Ingénieur Web Freelance - Firehist Studio
Profil Viadeo Benjamin Longearet
Geekos.fr : Blog technique sur les technologies du Web
---
Citation:
De l'innovation nait la solution et inversement
firehist est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/10/2011, 14h13   #3
Candidat au titre de Membre du Club
 
Homme John
Développeur informatique
Inscription : avril 2008
Messages : 18
Détails du profil
Informations personnelles :
Nom : Homme John
Localisation : France, Nord (Nord Pas de Calais)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : avril 2008
Messages : 18
Points : 10
Points : 10
Ma liste déroulante s'affiche bien, mais elle affiche les ID de typedemande, moi je veux quel affiche le nom.
J'ai utilisé 'relation' dans mon schema.yml, peut être que je l'ai mal utilisé?

Citation:
typeDemande:
columns:
nom : { type: string(255) }
description : { type: LONGTEXT }

contact:
columns:
typeDemande_id: { type: integer, notnull: true }
nom : { type: string(255) }
prenom : { type: string(255) }
adresse : { type: string(255) }
ville : { type: string(255) }
codePostal : {type : integer, notnull: true}
email : { type: string(255) }
telephone : { type: string(255)}
description : { type: LONGTEXT }

relations:
typeDemande: { onDelete: CASCADE, local: typeDemande_id, foreign: id, foreignAlias: contact}
ctek59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/10/2011, 16h02   #4
Candidat au titre de Membre du Club
 
Homme John
Développeur informatique
Inscription : avril 2008
Messages : 18
Détails du profil
Informations personnelles :
Nom : Homme John
Localisation : France, Nord (Nord Pas de Calais)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : avril 2008
Messages : 18
Points : 10
Points : 10
J'ai trouvé une solution :

J'ai ajouté dans le model (fichierTable) :
Citation:
public function getFormChoiceName()
{
$types = self::getName();
foreach($types as $type)
{
$array[$type->getId()] = $type->getNom();
}
return $array;
}
Et j'ai ajouté dans la configure de mon formulaire :

Citation:
$this->widgetSchema['type_Devis_id'] = new sfWidgetFormSelect(array(
'choices' => array(Doctrine::getTable('TypeDevis')->getFormChoiceName())
ctek59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/01/2012, 01h59   #5
Membre régulier
 
Avatar de Romanops
 
Homme Romain Delecambre
Développeur Web
Inscription : octobre 2002
Messages : 215
Détails du profil
Informations personnelles :
Nom : Homme Romain Delecambre
Âge : 28
Localisation : France, Nord (Nord Pas de Calais)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2002
Messages : 215
Points : 97
Points : 97
Envoyer un message via AIM à Romanops Envoyer un message via MSN à Romanops Envoyer un message via Yahoo à Romanops Envoyer un message via Skype™ à Romanops
Bonjour,

J'ai le même problème que ctek59, mais je me demande s'il y a moyen que ça soit automatique une fois généré l'application, comme l'explique firehist.

Voici mon fichier schema.yml :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# config/doctrine/schema.yml
Race:
  actAs: { Timestampable: ~ }
  columns:
    nom: { type: string(255), notnull: true, unique: true }
    description: { type: string(4000), notnull: true }
 
Genre:
  actAs: { Timestampable: ~ }
  columns:
    nom: { type: string(255), notnull: true, unique: true }
    description: { type: string(4000), notnull: true }
 
Nature:
  actAs: { Timestampable: ~ }
  columns:
    nom: { type: string(255), notnull: true, unique: true }
    description: { type: string(4000), notnull: true }
 
Personnage:
  actAs: { Timestampable: ~ }
  columns:
    nom: { type: string(255), notnull: true, unique: true }
    forc: { type: integer, notnull: true }
    constitution: { type: integer, notnull: true }
    dexterite: { type: integer, notnull: true }
    beaute: { type: integer, notnull: true }
    intelligence: { type: integer, notnull: true }
    volonte: { type: integer, notnull: true }
    persuasion: { type: integer, notnull: true }
    charisme: { type: integer, notnull: true }
    vie: { type: integer, notnull: true }
    fatigue: { type: integer, notnull: true }
    experience: { type: integer, notnull: true }
    points: { type: integer, notnull: true }
    race_id: { type: integer, notnull: false }
    genre_id: { type: integer, notnull: false }
    age: { type: integer, notnull: true }
    alignement: { type: integer, notnull: true }
    nature_id: { type: integer, notnull: false }
    employeur_id: { type: integer, notnull: false }
  relations:
    Race: { onDelete: CASCADE, local: race_id, foreign: id, foreignAlias: Personnages }
    Genre: { onDelete: CASCADE, local: genre_id, foreign: id, foreignAlias: Personnages }
    Nature: { onDelete: CASCADE, local: nature_id, foreign: id, foreignAlias: Personnages }
    Personnage: { onDelete: CASCADE, local: employeur_id, foreign: id, foreignAlias: Personnages }
Lorsque j'affiche une liste select en html dans un formulaire pour personnage, le champ affiché est la description pour toutes les clés étrangères, et pas le nom comme je le souhaiterai !

Comment résoudre ceci ?

Merci d'avance
__________________
En vous remerciant, bonsoir.
Romanops est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/01/2012, 09h40   #6
Membre habitué
 
Inscription : juin 2006
Messages : 488
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 488
Points : 116
Points : 116
Symfony/Doctrine quand il a besoin d'afficher une "description" à la place de l'id cherche (via la fonction __toString()) le champ name dans la table.

Au vu de vos schéma respectif, vous n'avez pas de champ name mais un champ nom.

Donc 2 possibilité, soit vous renommer vos champs soit vous modifier la fonction __toString:
Code :
1
2
3
4
5
 
public function __toString()
{
  return $this->getNom();
}
erictomcat est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/01/2012, 11h57   #7
Membre régulier
 
Avatar de Romanops
 
Homme Romain Delecambre
Développeur Web
Inscription : octobre 2002
Messages : 215
Détails du profil
Informations personnelles :
Nom : Homme Romain Delecambre
Âge : 28
Localisation : France, Nord (Nord Pas de Calais)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2002
Messages : 215
Points : 97
Points : 97
Envoyer un message via AIM à Romanops Envoyer un message via MSN à Romanops Envoyer un message via Yahoo à Romanops Envoyer un message via Skype™ à Romanops
En suivant vos conseils, j'ai rajouté la fonction
Code :
1
2
3
4
5
 
  public function __toString()
  {
    return $this->getNom();
  }
Dans mes classes comme Race.class.php (dans ./lib/model/doctrine), et ça fonctionne à merveille. Merci !!
__________________
En vous remerciant, bonsoir.
Romanops est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 03h55.


 
 
 
 
Partenaires

Hébergement Web