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 :

Form en plusieurs étapes


Sujet :

Symfony PHP

  1. #1
    Membre averti
    Homme Profil pro
    ISTV
    Inscrit en
    Novembre 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : ISTV

    Informations forums :
    Inscription : Novembre 2015
    Messages : 12
    Par défaut Form en plusieurs étapes
    Bonjour, je reviens vers vous pour un problème que je pourrais qualifier de colossal pour moi,


    Travaillant sur une application de prise de rendez-vous je suis sur la phase finale de mon projet mais je rencontre un problème et je ne sais pas comment m'y prendre afin de le résoudre.

    J'ai mon entité rdv :

    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    class Rdv
    {
        /**
         * @var integer
         *
         * @ORM\Column(name="idRdv", type="integer", nullable=false)
         * @ORM\Id
         * @ORM\GeneratedValue(strategy="IDENTITY")
         */
        private $id;
     
        /**
         * @var \Plages
         *
         * @ORM\ManyToOne(targetEntity="Plages")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="idPlages", referencedColumnName="id")
         * })
         */
        private $idplages;
     
        /**
         * @var string
         *
         * @ORM\Column(name="commentaire", type="text", nullable=true)
         */
        private $commentaire;
     
        /**
         * @var boolean
         *
         * @ORM\Column(name="venu", type="boolean", nullable=true)
         */
        private $venu;
     
        /**
         * @var \Patient
         *
         * @ORM\ManyToOne(targetEntity="Patient",cascade={"persist"})
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="idPatient", referencedColumnName="id")
         * })
         */
        private $idpatient;
     
        /**
         * @var \Utilisateurs
         *
         * @ORM\ManyToOne(targetEntity="Utilisateur")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="idUtilisateur", referencedColumnName="id")
         * })
         */
        private $idutilisateurs;
     
        /**
         * @var \Lieux
         *
         * @ORM\ManyToOne(targetEntity="Lieux")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="idLieux", referencedColumnName="id")
         * })
         */
        private $idlieux;
     
     
     
     
        /**
         * Get id
         *
         * @return integer 
         */
        public function getId()
        {
            return $this->id;
        }
     
        /**
         * Set date
         *
         * @param \DateTime $date
         * @return Rdv
         */
        public function setDate($date)
        {
            $this->date = $date;
     
            return $this;
        }
     
        /**
         * Get date
         *
         * @return \DateTime 
         */
        public function getDate()
        {
            return $this->date;
        }
     
        /**
         * Set commentaire
         *
         * @param string $commentaire
         * @return Rdv
         */
        public function setCommentaire($commentaire)
        {
            $this->commentaire = $commentaire;
     
            return $this;
        }
     
        /**
         * Get commentaire
         *
         * @return string 
         */
        public function getCommentaire()
        {
            return $this->commentaire;
        }
     
        /**
         * Set venu
         *
         * @param boolean $venu
         * @return Rdv
         */
        public function setVenu($venu)
        {
            $this->venu = $venu;
     
            return $this;
        }
     
        /**
         * Get venu
         *
         * @return boolean 
         */
        public function getVenu()
        {
            return $this->venu;
        }
     
        /**
         * Set idpatient
         *
         * @param \TM\AgendaBundle\Entity\Patient $idpatient
         * @return Rdv
         */
        public function setIdpatient(\TM\AgendaBundle\Entity\Patient $idpatient = null)
        {
            $this->idpatient = $idpatient;
     
            return $this;
        }
     
        /**
         * Get idpatient
         *
         * @return \TM\AgendaBundle\Entity\Patient 
         */
        public function getIdpatient()
        {
            return $this->idpatient;
        }
     
        /**
         * Set idutilisateurs
         *
         * @param \TM\AgendaBundle\Entity\Utilisateur $idutilisateurs
         * @return Rdv
         */
        public function setIdutilisateurs(\TM\AgendaBundle\Entity\Utilisateur $idutilisateurs = null)
        {
            $this->idutilisateurs = $idutilisateurs;
     
            return $this;
        }
     
        /**
         * Get idutilisateurs
         *
         * @return \TM\AgendaBundle\Entity\Utilisateur 
         */
        public function getIdutilisateurs()
        {
            return $this->idutilisateurs;
        }
     
        /**
         * Set idlieux
         *
         * @param \TM\AgendaBundle\Entity\Lieux $idlieux
         * @return Rdv
         */
        public function setIdlieux(\TM\AgendaBundle\Entity\Lieux $idlieux = null)
        {
            $this->idlieux = $idlieux;
     
            return $this;
        }
     
        /**
         * Get idlieux
         *
         * @return \TM\AgendaBundle\Entity\Lieux 
         */
        public function getIdlieux()
        {
            return $this->idlieux;
     
        }
     
         /**
         * Set idplages
         *
         * @param \TM\AgendaBundle\Entity\Plages $idplages
         * @return Rdv
         */
        public function setIdplages(\TM\AgendaBundle\Entity\Plages $idplages = null)
        {
            $this->idplages = $idplages;
     
            return $this;
        }
     
        /**
         * Get idpatient
         *
         * @return \TM\AgendaBundle\Entity\Plages 
         */
        public function getIdplages()
        {
            return $this->idplages;
        }
     
    }
    Seulement je dois récupérer idLieux et idPlages avant toute chose afin de pouvoir choisir un Utilisateur en fonction de ces deux critères ( un Utilisateur est lié à un lieu et à une vacation (= plage horraire)

    Je ne sais pas du tout comment faire ? c'est relativement complexe (j'ai pensé a un formulaire multi page ?)

    Merci d'avance

  2. #2
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 209
    Billets dans le blog
    52
    Par défaut
    Bonjour,

    Tu ne nous donne pas le contexte de ton problème. D'après ce que tu dis, tu as besoin de d'un lieu et d'un horaire pour retrouver une personne associé à un rendrez-vous. Ce qui me semble logique...
    Si on suppose que tu veux faire un formulaire de recherche. Il me semble plus logique de proposer seulement un critère le lieu ou l'horaire. Logiquement, si on réalise une recherche de ce type, c'est dans un contexte donnée. Par exemple, savoir qui a rendez-vous dans la journée dans la salle X. Ou quelle salle/lieu est occupé à un horaire donnée.

    Après, il est toujours possible d'avoir un formulaire proposant les deux champs lieu et horaire avec l'ensemble des valeurs possible. Et utiliser une requête AJAX lorsque l'utilisateur change la valeur d'un des champs pour ne proposer seulement les valeurs ayant du sans pour le second champs. IE Si l'utilisateur sélectionne la salle A, seul les horaire avec un rendez-cous pour la salle A sont disponible.

    Cordialement,
    Patrick Kolodziejczyk.
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

  3. #3
    Membre averti
    Homme Profil pro
    ISTV
    Inscrit en
    Novembre 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : ISTV

    Informations forums :
    Inscription : Novembre 2015
    Messages : 12
    Par défaut
    Et bien pour être plus précis, je dois saisir une plage horraire (qui correspond à idplages) et un lieu (qui correspond à idlieux) et en fonction de ça afficher la liste des utilisateurs (médecins) de ce lieu et de cette plage horraire pour pouvoir leur affecter un rendez vous.

  4. #4
    Membre averti
    Homme Profil pro
    ISTV
    Inscrit en
    Novembre 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : ISTV

    Informations forums :
    Inscription : Novembre 2015
    Messages : 12
    Par défaut
    Bonjour, dans le but de simplifier j'aimerai savoir si il était possible de mixer du php standard avec du symfony ?

    merci

  5. #5
    Membre expérimenté
    Avatar de vinmar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2012
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Service public

    Informations forums :
    Inscription : Août 2012
    Messages : 139
    Par défaut
    Salut,

    Comme kolodz te l'a dit :

    1. Tu commences par sélectionner le lieu via une liste déroulante par exemple
    2. En fonction du choix, tu proposes des plages horaires qui sont disponibles. Via une autre liste déroulante par exemple.
    3. Si la plage horaire est liée à un médecin, pour une plage horaire sélectionnée, si il y a plusieurs médecins disponibles, tu affiches une troisième liste déroulante pour sélectionner le médecin que la personne veut.

    Pour faire ces listes déroulantes, un peu d'Ajax sera le bienvenu pour rafraîchir les listes en fonction des choix.

    Sinon :
    1. Tu commences par une plage horaire (liste déroulante)
    2. Qui te donne les lieux dispos sur cette plage horaire (liste déroulante)
    3. Qui te donne les médecins dispos (liste déroulante).

    Est-ce que ta question porte sur la suite d'actions à faire dans le formulaire ou sur comment le mettre en place ?

    A+

Discussions similaires

  1. [ZF 1.10] Form en plusieurs étapes
    Par Firnael dans le forum Zend_Form
    Réponses: 4
    Dernier message: 20/07/2012, 10h50
  2. Réponses: 19
    Dernier message: 21/11/2006, 11h57
  3. [Visual Web] [SJSC] Form et plusieurs boutons
    Par vincent77320 dans le forum NetBeans
    Réponses: 4
    Dernier message: 14/06/2006, 09h56
  4. Struts form avec plusieurs submit
    Par micanti dans le forum Struts 1
    Réponses: 3
    Dernier message: 29/05/2006, 21h23
  5. Forms (insertion à plusieurs tables) ?
    Par bchbch dans le forum Forms
    Réponses: 1
    Dernier message: 02/04/2006, 18h50

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