Jhtml jgrid

Réduire
X
 
  • Filtrer
  • Heure
  • Afficher
Tout effacer
nouveaux messages

  • Jhtml jgrid

    Bonjour,

    Débutant en développement Joomla, et après lecture attentive de divers tutos et bouquin, je me heurte à la mise en oeuvre d'un des exemples du livre (Dév. des extensions en PHP pour Joomla - ENI).

    Le fichier defaut_items.php pose pb.
    Il y a la ligne :
    Code HTML:
    <td><?php echo JHtml::_('jgrid.published', $item->published, $i, 'tick.', true); ?></td>
    qui n'affiche rien dans la colonne.
    C'est sensé affiché une image de case à cocher qui permet de dépublier l'élément suite à un click.
    Qq pourrait-il m'éclairer un peu ?

    Cdt, NC

  • #2
    Re : Jhtml jgrid

    Bonjour,

    Difficile de vous aider juste avec ce bout de code.

    En cherchant un peu, j'ai trouvé une discussion https://forum.joomla.fr/showthread.p...as-fonctionner à propos de jgrid.

    Essayez de mettre echo $item->published pour vérifier si votre zone $item est bien renseignée.

    Petite remarque: le livre que vous citez est noté Joomla 3.3. Avez-vous eu une mise à jour ?

    Si vous devez développer des extensions, je vous conseille d'utiliser en local Eclipse php https://projects.eclipse.org/projects/tools.pdt qui permet de bien tracer tout et rien...

    Pascal
    If anything can go wrong, it will...If I can help, I will ..https://conseilgouz.com

    Commentaire


    • #3
      Re : Jhtml jgrid

      Bonjour,

      Normalement, ce code est toujours fonctionnel dans Joomla 3.6+

      Pouvez vous verifier 4 points pour commencer :
      1- ce code est-il bien dans une boucle "foreach" ?
      2- la variable du foreach est-elle bien "$item" ?
      3- votre table SQL possede-t-elle bien un champ nommé "published" ?
      4- votre requete SQL (dans le model) charge-t-elle bien le champ "published" ?

      Je vous conseille de changer les parametres de la configuration de votre Joomla :
      - Configuration generale > onglet "Serveur" > Rapport d'erreurrs > "Développement"
      Cela devrait permettre d'afficher le message d'erreur PHP si besoin.
      Garstud Workshop - Concepteur, Développeur et Formateur Joomla - http://www.garstud.com
      « Ce n’est pas parce que les choses sont difficiles que nous n’osons pas,
      c’est parce que nous n’osons pas qu’elles sont difficiles. »
      - Sénèque

      Commentaire


      • #4
        Re : Jhtml jgrid

        Bonjour,

        1 Le code est dans une boucle foreach :
        <?php foreach($this->evenements as $i => $item) : ?>
        <tr>
        <td>
        <a href="<?php echo $uriCompoDetail.$item->id ?>"><?php echo $item->title ?></a>
        </td>
        <td><?php echo $item->priority ?></td>
        <td><?php echo JHtml::_('jgrid.published', $item->published, $i, 'tick.', true); ?></td>
        <td><?php echo $item->theme ?></td>
        <td><?php echo $item->state ?></td>
        <td><?php echo JHtml::_('date', $item->created, 'j F Y'); ?></td>
        </tr>
        <?php endforeach; ?>
        2 - idem oui (cf code ci-dessus)
        3 - La table a bien un champ nommé published déclaré en tinyint(1) qui a pour valeur 1 quand publié et 0 sinon
        4 - oui car j'ai remplacé la ligne incriminée par
        <td><?php echo $item->published ?></td>
        et ça affiche 1 ou 0 selon le cas.

        J'ai déjà changé le paramètre de rapport d'erreurs mais je ne vois rien de particulier sur la page.
        En regardant avec l'inspecteur de firefox, je trouve comme code généré :
        <td><a class="btn btn-micro active hasTooltip" href="javascript:void(0);" onclick="return listItemTask('cb4','tick.unpublish')" title="" data-original-title="Dépublier lʼélément"><span class="icon-publish"></span></a></td>
        avec cb4 pour la 4° ligne du tableau. Je ne sais pas à quoi correspond listItemTask.
        Pour la 3° ligne aui correspond dans l'exemple à un élément non publié, le code est différent :
        <td><a class="btn btn-micro hasTooltip" href="javascript:void(0);" onclick="return listItemTask('cb3','tick.publish')" title="" data-original-title="Publier cet élément"><span class="icon-unpublish"></span></a></td>
        Je précise que je n'ai installé que l'exemple du bouquin !! et que je débute en MVC et développement Joomla.
        Je me débrouille en HTML, CSS et PHP. Ce n'est déjà pas évident au début mais si en plus le code exemple bugg ça se complique sérieusement.
        Il n'y a pas de css particulier fourni avec les fichiers d'exemple alors que dans les copies d'écran on voit des icônes de type coché ou décoché selon le cas.
        C'est pour le moment un sacré jeu de piste :-(

        Merci pour l'aide
        Cdt, NC
        Dernière édition par canard338 à 04/01/2017, 23h44

        Commentaire


        • #5
          Re : Jhtml jgrid

          Bonjour,

          J'ai le même problème que cité plus haut.
          J'ai suivi le même tutoriel, du même livre, et je sèche sur "jgrid".

          La même utilisation du même morceau de code fonctionne en backend, alors qu'elle ne fonctionne pas en frontend. Les fichiers exemples reçus avec le livre pour le composant "Support" ne fonctionnent pas non plus.

          Quelqu'un peut-il nous éclairer en expliquant à quelles fonctions ces bouts de code font-elles appel ?

          Merci

          Code:
          onclick="return listItemTask('cb4','tick.unpublish')"
          et

          Code:
          onclick="return listItemTask('cb3','tick.publish')"

          Commentaire


          • #6
            Re : Jhtml jgrid

            bonjour,
            Une recherche du terme listItemTask dans les fichiers d'un joomla local m'as ressorti une liste de fichiers avec les lignes correspondantes dans chaque fichier, dont ceux ci dessous.
            /libraries/cms/html/grid.php
            /libraries/cms/html/jgrid.php
            /media/system/js/core-uncompressed.js
            ligne 492 il y a la fonction ci dessous :
            Code:
             
            /**
            	 * USED IN: all over :)
            	 *
            	 * @param id
            	 * @param task
            	 * @return
            	 */
            	window.listItemTask = function ( id, task ) {
            		var f = document.adminForm,
            			i = 0, cbx,
            			cb = f[ id ];
            
            		if ( !cb ) return false;
            
            		while ( true ) {
            			cbx = f[ 'cb' + i ];
            
            			if ( !cbx ) break;
            
            			cbx.checked = false;
            
            			i++;
            		}
            
            		cb.checked = true;
            		f.boxchecked.value = 1;
            		window.submitform( task );
            
            		return false;
            	};
            Dans le code ci dessus, regardes la seconde ligne.

            autres lectures :




            Cette classe est utilisée uniquement sur la partie admin du site.

            Possibilités de resolution du soucis en frontend:
            1 utiliser jimport : valable si tu travailles dans une vue.

            2 créer un plugin systeme qui te la charges automatiquement ou tu en a besoin.

            3 aller voir dans les helpers de ton composant, en cas de dev d'un composant.
            Ca te fourniras des exemples d'utilisation
            /administrator/components/com_contact/helpers/html/contact.php
            /administrator/components/com_content/helpers/html/contentadministrator.php
            /administrator/components/com_contenthistory/views/history/tmpl/modal.php
            /administrator/components/com_messages/helpers/html/messages.php

            Il faut aussi charger la fonction javascript. A toi de voir si ce n est pas déja fait automatiquement, vu son emplacement.
            Ne doit etre utiliser que pour afficher des données sous forme de tableau.

            Commentaire


            • #7
              Re : Jhtml jgrid

              Code:
              // needed for Table Column ordering
              	/**
              	 * USED IN: libraries/joomla/html/html/grid.php
              	 * There's a better way to do this now, can we try to kill it?
              	 */
              	window.saveorder = function ( n, task ) {
              		window.checkAll_button( n, task );
              	};
              lire le commentaire.....

              Voir aussi du coté du composant modules com_modules pour l'edition des parametres en frontend.
              Ces classes ou des classes équivalentes sont peut etre disponible via ce biais.

              Commentaire

              Annonce

              Réduire
              Aucune annonce pour le moment.

              Partenaire de l'association

              Réduire

              Hébergeur Web PlanetHoster
              Travaille ...
              X