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

Plugins PHP Discussion :

[ahDoctrineEasyEmbeddedRelationsPlugin] Ajout obligatoire


Sujet :

Plugins PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2008
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2008
    Messages : 76
    Par défaut [ahDoctrineEasyEmbeddedRelationsPlugin] Ajout obligatoire
    Bonjour,

    j'ai implenté ce plugin dans mon appli mais lors de la création d'un objet, l'ajout d'un nouvel élément dans ma relation est obligatoire et il me met des "Required" sur tous les champs du formulaire embed.

    Alors que dans l'absolu, l'option 'considerNewFormEmptyFields' est sensée empêcher ce soucis.

    Quelqu'un aurait une idée de pourquoi cette option ne marche pas ?


    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
    class FormelleForm extends BaseFormelleForm
    {
      public function configure()
      {
        $this->embedRelations(array(
          'FinancementFormal' => array(
          'considerNewFormEmptyFields' => array("datedebut", "datefin", "montant", "institution_id"),
          'multipleNewForms'              => true,
          'newFormsInitialCount'          => 1,
          'newRelationButtonLabel'        => 'Add a new financing',
          'formClassArgs'                 => array(array('ah_add_delete_checkbox' => true)),
          'newFormAfterExistingRelations' => true,
     )
     ));
      }
     
    public function listenToFormPostConfigureEvent(sfEvent $event)
    {
        if ($form = parent::listenToFormPostConfigureEvent($event))
       {
         $form->widgetSchema['delete_object']->setOption('label', 'Delete financing');
       }
     }
     
    }

  2. #2
    Expert confirmé
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Par défaut
    Je ne vois pas trop, tes paramètres sont bon (a priori).

    Je n'ai pas installé en prod, mais testé à plusieurs reprises et je n'ai jamais vu de tels résultats.

    Vérifie les paramètres pour : newFormAfterExistingRelations

    Vérifie ton schéma de base de donnée, il y a peut-être quelque chose par là. (Envoie le si tu as des doutes).

  3. #3
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2008
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2008
    Messages : 76
    Par défaut
    Après avoir tourné le problème dans tous les sens, je dois bien avouer que je ne trouve pas...

    mon schema.yml au cas où :

    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
    Formelle:
      tableName: Formelle
      columns:
        programme_accord_id:
          type: integer(8)
          notnull: true
        projet_id:
          type: integer(8)
          notnull: true
        appelaprojet_id:
          type: integer(8)
          notnull: true
        coordinator_id:
          type: integer(8)
      relations:
        Projet:
          local: projet_id
          onDelete: cascade
          foreignAlias: Formelles
        ProgrammeAccord:
          local: programme_accord_id
          foreignAlias: Formelles
        AppelAProjet:
          local: AppelAProjet_id
          onDelete: cascade
          foreignAlias: Formelles
        Institutions:
          class:        Institution
          refClass:     InstitutionFormelle
          foreignAlias: Formelles
        Personne:
          local: coordinator_id
          foreignAlias: Formelles
        Porteuriu:
          class: Personne
          refClass: PorteuriusF
          foreignAlias: Formellesiu
        Porteurinter:
          class: Personne
          refClass: PorteurintersF
          foreignAlias: FormellesInter
     
    Financement:
      tableName: Financement
      columns:
        datedebut:
          type: date(25)
          notnull: true
        datefin:
          type: date(25)
          notnull: true
        montant:
          type: float(8)
          unsigned: true
          notnull: true
        institution_id:
          type: integer(8)
          notnull: true
        formelle_id:
          type: integer(8)
          notnull: true
      relations:
        Institution:
          foreignType: many
          foreignAlias: Financements
          onDelete: CASCADE
        Formelle:
          foreignType: many
          foreignAlias: FinancementFormal
          onDelete: CASCADE

  4. #4
    Expert confirmé
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Par défaut
    J'ai vu ton shema.yml, il est relativement correcte, même si j'ai du mal à valider certaines liaisons n-n vu que je n'ai pas toutes les tables.

    Il n'y a, à priori, rien de particulier qui permettrait de justifier les required impromptus.

    Essaye de monter cela dans une application vide, de test, avec uniquement deux tables (en général, cela marche). Pour voir les paramétrages a utiliser.

Discussions similaires

  1. Ajout d'une colonne obligatoire sur des doublons
    Par bernidupont dans le forum Requêtes
    Réponses: 2
    Dernier message: 18/12/2013, 14h21
  2. Réponses: 1
    Dernier message: 25/01/2012, 12h11
  3. Réponses: 1
    Dernier message: 28/12/2011, 16h29
  4. Obligatoire : lisez les règles du forum : MAJ 06/08/2010
    Par Anomaly dans le forum Mode d'emploi & aide aux nouveaux
    Réponses: 0
    Dernier message: 03/07/2008, 13h46
  5. Réponses: 4
    Dernier message: 08/08/2007, 15h27

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