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 :

[sfWidgetFormDoctrineJQueryUISortable], je n'y arrive pas !


Sujet :

Plugins PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 12
    Par défaut [sfWidgetFormDoctrineJQueryUISortable], je n'y arrive pas !
    Bonjour,

    Je n'arrive pas à faire fonctionner le plugin sfWidgetFormDoctrineJQueryUISortable.
    Dès que je déplace un élément, j'ai une alerte javascript qui affiche :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    theres an error with AJAX
    Je pense que l'erreur vient de la requête dans l'action du plugin, il doit y avoir un problème dans mon schéma.

    shema.yml
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    TypeCarte:
      columns:
        id:
          type: integer(11)
          primary: true
          autoincrement: true
        name:
          type: string(100)
          notnull: true
          unique: true
        visuel:
          type: string(100)
        ordre:
          type: integer(11)
    TypeCarteForm.class.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
        $this->widgetSchema['ordre'] = new sfWidgetFormDoctrineJQueryUISortable(array(
    		'model'     => 'TypeCarte',
    		'parent_object' => $this->getObject(),
    		'method' => 'getTypeCarteMini', // Retourne le visuel du type de carte
    		'key_method' => 'getPrimaryKey',
    		'parent_key_method' => 'getPrimaryKey',
    //		'order_by' => 'ordre',
    		'query' => null,
    		'table_method' => null,
    		'grid' => true,
    		'rank_field' => 'ordre'
        ));
    J'ai pensé à créer une table TypeCarteOrdre car dans l'action du plugin on peut voir qu'il y a une liaison entre la table du modèle et un modèle parent que je ne pense pas avoir mais ca ne passe pas non plus, la même erreur s'affiche.

    /plugins/sfWidgetFormDoctrineJQueryUISortable/modules/sfDoctrineJQueryUISortable/actions/actions.class.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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    class sfDoctrineJQueryUISortableActions extends sfActions
    {
      public function executeSaveOrder(sfWebRequest $request)
      { 
        $model = $request->getParameter('model');
        $order = 'sfDoctrineJQueryUISortable' . $model;
        $parentModel = $request->getParameter('parent_model');
        $parentId = $request->getParameter('parent_id');
     
        if (empty($model) || empty($order) || empty($parentModel) || empty($parentId)
            || !is_array($request->getParameter($order)))
        {
          return sfView::NONE;
        }
     
        foreach ($request->getParameter($order) as $rank => $objectId)
        {
          $query = Doctrine_Query::create()
            ->from($model . ' m')
            ->innerJoin('m.' . $parentModel . ' p')
            ->where('m.id=? AND p.id=?', array($objectId, $parentId));
     
          $object = $query->fetchOne();
     
          if ($object instanceOf $model)
          {
            $object->setRank($rank);
            $object->save();
          }
        }
     
        return sfView::HEADER_ONLY;
      }
    }

    Merci pour votre aide

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 12
    Par défaut
    Bonjour,

    N'ayant toujours pas trouvé comment faire fonctionner ce plugin, j'ai écris au concepteur qui m'a répondu ceci :

    Hi there
    Unfortunately the widget relies on the object belonging to something, ie the parent object. So you would need another model and a foreign key to it in your existing model. I plan to remove this dependency from the plugin at some point. Feel free to have a go yourself!
    J'ai bien essayé de créer une seconde table qui enregistrerai les "ordres" comme je l'avais dis précédemment mais aucun succès.

    Toujours aucune idée ?

  3. #3
    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
    C'est un plugin que je n'ai jamais pratiqué.

    Et je n'ai pas le temps, hélas, pour m'y pencher sérieusement.

    Mais, si on contourne la question, tu veux faire quoi exactement ?

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 12
    Par défaut
    Concrètement je veux pouvoir appliquer un ordre sur une table qui contient des images.
    Et ce qui était magnifique avec plugin c'est que l'on pouvait afficher ces images et définir l'ordre en drag en drop avec Ajax.

  5. #5
    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
    Et il te retourne un array avec les tris ? Ou carrément il modifie la base ?

    Effectivement, cela peut être intéressant.

    Je vais peut-être abandonné là v2 quelques heures...

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 12
    Par défaut
    Il modifie directement la base.
    Et c'est sur l'exécution de la requête qu'il doit planter selon mon schéma

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

Discussions similaires

  1. [Kylix 3] Je n'arrive pas à utiliser MySQL
    Par usebob dans le forum EDI
    Réponses: 4
    Dernier message: 15/04/2005, 10h18
  2. problème que je n'arrive pas à résoudre de façon récursive
    Par miam dans le forum Algorithmes et structures de données
    Réponses: 9
    Dernier message: 31/07/2004, 11h21
  3. [Function] N'arrive pas à sortir
    Par bouboussjunior dans le forum ASP
    Réponses: 3
    Dernier message: 14/06/2004, 16h36
  4. Je n'arrive pas à détruire une fenêtre
    Par CORREGE Frédéric dans le forum MFC
    Réponses: 6
    Dernier message: 22/02/2004, 20h28
  5. j'arrive pas a arreter mon thread d'arriere-plan
    Par ms91fr dans le forum Langage
    Réponses: 6
    Dernier message: 06/06/2003, 21h36

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