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

Bibliothèques et frameworks PHP Discussion :

Changer les valeurs pour un select depuis un find [CakePHP]


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    août 2012
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : août 2012
    Messages : 25
    Points : 46
    Points
    46
    Par défaut Changer les valeurs pour un select depuis un find
    Bonjour à vous,
    j'ai utilisé bake pour générer mes différents controllers et vue.
    Donc j'ai mes tables Users(id, first_name, last_name, id_role, email) et Roles(id, designation), donc id_role possède une clef étrangère pointant sur id de Roles
    alors cake m'a généré une vue Users/add et y'a bien le champ Role, mais il affiche que les ids de la table Roles dans un select.
    et je voudrais qu'il affiche la désignation, et mette l'id de role en value pour le select.
    j'ai essayé de mettre 'all' à la place de 'list' dans le find, mais à la place d'afficher les ids j'ai un tableau {"id":2, "designation":"toast"}
    et je ne sais pas comment créer un select avec comme values les ids de role et affiche les désignation pour l'utilisateur.

    j'ai essayé de faire un debug() sur $roles mais ça affiche un tableau avec la requête SQL

    fonction add de UsersController:
    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    public function add()
        {
            $user = $this->Users->newEntity();
            if ($this->request->is('post')) {
    			debug($this->request->data);
                $user = $this->Users->patchEntity($user, $this->request->data);
                if ($this->Users->save($user)) {
                    $this->Flash->success('The user has been saved.');
                    return $this->redirect(['action' => 'index']);
                } else {
                    $this->Flash->error('The user could not be saved. Please, try again.');
                }
            }
     
    		$session = $this->request->session();
    		$currentUser = $session->read('Auth.User');
    		$role = $currentUser['role_id'];
    		$rolePossible = '';
    		 // on définie le rôle que peut attribuer l'utilisateur en cours.
    		if($role == 2){
    			$rolePossible .= '3';
    		}else if($role == 3){
    			$rolePossible .= '4';
    		}else if($role == 1){
    			$rolePossible .= '2';
    		}
    		$condition = array("Roles.id >=" => $rolePossible);
            $roles = $this->Users->Roles->find('all', array('conditions' => $condition)); // donc ici j'ai changé j'ai mit all à la place de liste
            $groups = $this->Users->Groups->find('all', ['limit' => 200]);
            $this->set(compact('user', 'roles', 'groups'));
            $this->set('_serialize', ['user']);
        }
    vue de Users/add:
    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
    17
    18
    19
    20
    21
     
    <div class="actions columns large-2 medium-3">
        <h3><?= __('Actions') ?></h3>
    </div>
    <div class="users form large-10 medium-9 columns">
    	<?= $this->Flash->render('error') ?>
        <?= $this->Form->create($user); ?>
        <fieldset>
            <legend><?= __('Add User') ?></legend>
            <?php
                echo $this->Form->input('role_id', ['options' => $roles]);
                echo $this->Form->input('email');
                echo $this->Form->input('first_name');
                echo $this->Form->input('last_name');
                echo $this->Form->input('password');
                echo $this->Form->input('groups._ids', ['options' => $groups]);
            ?>
        </fieldset>
        <?= $this->Form->button(__('Submit')) ?>
        <?= $this->Form->end() ?>
    </div>
    merci d'avance de vos réponses.

  2. #2
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    Il faut que tu choisisses explicitement les champs à afficher (par défaut, Cake prend la clef primaire et le "displayField") : http://book.cakephp.org/2.0/fr/model...html#find-list
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    août 2012
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : août 2012
    Messages : 25
    Points : 46
    Points
    46
    Par défaut
    Impeccable merci.
    Je suis en 3.0, donc j'ai suivi la nouvelle norme.
    http://book.cakephp.org/3.0/fr/orm/r...-de-cle-valeur

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 24/06/2014, 18h27
  2. Réponses: 6
    Dernier message: 23/03/2009, 15h40
  3. [JSP] Récupérer les valeurs d'un SELECT multiple
    Par ran_hery dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 15/05/2006, 15h56
  4. Récupérer les valeurs d'un <select> multiple
    Par vg33 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 25/10/2005, 11h38
  5. Requete SELECT : prendre toutes les valeurs pour 1 champ
    Par fab22montpellier dans le forum Requêtes
    Réponses: 1
    Dernier message: 02/09/2005, 09h12

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