var Phenix = function () {
Troll du Web depuis 1996

Tutoriel

Ajouter une balise #CHERCHER_LOGO à #SPIP

Lorsque l’on veut récupérer le logo d’un objet SPIP, on est obligé de faire quelques choses qui ressemble à :

  1. <BOUCLE_logo(ARTICLES){id_article=1}>
  2. #LOGO_ARTICLE
  3. </BOUCLE_logo>

C’est assez ennuyant, d’autant que cela risque fort de faire une requête SQL alors que la récupération de logo n’en a absolument pas besoin, les fichiers sont stocker sous la forme objetId_objet.xx dans le dossier IMG.

On pourrait espérer que mettre simplement l’identifiant dans la balise récupère le logo, comme le font les balises URL. Malheureusement cela ne fonctionne pas.

Du coup, je me suis inspiré de la balise #INFO_ pour créer une balise #CHERCHER_LOGO :

  1. <?php
  2. /**
  3.  * #CHERCHER_LOGO{objet, id_objet}
  4.  * Retrouver le logo d'un objet sans avoir à lancer tout le système de boucle.
  5.  *
  6.  * @param mixed $p
  7.  * @access public
  8.  * @return mixed
  9.  */
  10. function balise_CHERCHER_LOGO_dist($p) {
  11.     $objet = interprete_argument_balise(1, $p);
  12.     $id_objet = interprete_argument_balise(2, $p);
  13.  
  14.     // Faire la conversion pour la fonction chercher_logo
  15.     $objet = "id_table_objet($objet)";
  16.  
  17.     include_spip('inc/filtres');
  18.     include_spip('public/quete');
  19.     $p->code = "http_img_pack(_DIR_IMG.quete_logo($objet, 'on', $id_objet, '', true), '', 'class=\"spip_logos\"')";
  20.     $p->interdire_scripts = false;
  21.  
  22.     return $p;
  23. }

Voir mon gist : https://gist.github.com/phenix-factory/57cb993512d13fdfee88


Ajouter l’icône des blocs AJAX dans l’espace publics d’un site #SPIP

Parce que c’est mieux !

Petite astuce que j’ai trouvée il y a peu.

Lorsque l’ont AJAX des blocs SPIP, le comportement par défaut est de passer le bloc en opacité 50%.
Ce n’est pas forcément le plus explicite pour les visiteurs, plus habitués à avoir un signe de « pseudo-progression ».

Ce n’est le comportement de la partie admin, qui affiche une icône « Loading » dans le coin supérieur droit.

On peut facilement reproduire ce comportement dans l’espace publique avec une petite ligne de css :

  1. .loading {
  2. background: url(../../prive/themes/spip/images/searching.gif) no-repeat top right;
  3. }

Ici je suppose que le fichier css se trouve dans un sous-dossier du dossier squelettes de SPIP. Si ce n’est pas le cas, il faut adapter le chemin.

Bien entendu on peut mettre ce que l’on veut sur la class loading, ici je n’ai fais que reproduire le comportement de SPIP.


Modifier la carte d’identité d’un site #SPIP

Voici le premier tutoriel sur SPIP, et certainement pas le dernier vu comment, ce CMS est absolument magique.

Intro

Tous les sites SPIP sont livrés, par défaut, avec une carte d’identité : le titre du site, le slogan, l’email du webmaster, etc.
En gros par défaut, cela ressemble à cela :

Dans la plupart des cas, cela suffit largement au site. Toute fois dans certains cas, on voudrait étendre les possibilités de cette carte d’identité.

Éditer le formulaire

La première chose que l’on va faire, c’est éditer le formulaire pour ajouter les champs dont on à besoin. Le fichier se trouve dans prive/formulaires.

On copie donc configurer_identite.html et configurer_identite.php dans un dossier squelettes/formulaires. Cela a pour effet de les surcharger (voir la notion de chemin dans SPIP).

Ouvrez le fichier configurer_identite.html, vous y trouverez toute une série de li contenant des champs de formulaire.

Ajoutez-y votre champ, ici je vais ajouter un champ « téléphone de la billetterie » :

  1. #SET{name,billetterie_telephone}#SET{erreurs,#ENV**{erreurs}|table_valeur{#GET{name}}}#SET{obli,''}
  2. <li class="editer editer_[(#GET{name})][ (#GET{obli})][ (#GET{erreurs}|oui)erreur]">
  3.         <label for="#GET{name}">Téléphone billeterie</label>
  4.         [<span class='erreur_message'>(#GET{erreurs})</span>]
  5.         <input type='text' class='text' name='#GET{name}' id='#GET{name}' value="#ENV{#GET{name}}" />
  6. </li>

Si vous retournez sur votre page, vous constaterez qu’un nouveau champ est disponible. En revanche, il ne fonctionne pas.

En effet, SPIP n’est pas au courant qu’il doit créer ce champ dans la base de données, il faut lui dire. Pour cela, ouvrez le fichier configurer_identite.php

Dans ce fichier vous trouverez 2 foreach de ce type (ligne 21 et 49) :

  1. foreach(array('nom_site', 'adresse_site', 'slogan_site', 'descriptif_site', 'email_webmaster') as $k)

Ajoutez dans le tableau votre nouveau champ :

  1. foreach(array('nom_site', 'adresse_site', 'slogan_site', 'descriptif_site', 'email_webmaster', 'billetterie_telephone') as $k)

Rien de plus à faire, votre champ est maintenant fonctionnel !

Créer la balise

Maintenant, on va créer la balise qui va avec ce champ, dans un fichier mes_fonctions.php (a mettre à la racine de votre dossier squelettes) :

  1. /*
  2. *   Balise #BILLETERIE_TELEPHONE
  3. */
  4. function balise_BILLETTERIE_TELEPHONE_dist($p) {
  5.     $p->code = "\$GLOBALS['meta']['billetterie_telephone']";
  6.     return $p;
  7. }

Voilà, il ne reste plus qu’à utiliser #BILLETERIE_TELEPHONE où bon vous semble dans vos squelettes SPIP. Bien sûr tous les filtres fonctionneront également !


Mettre à jour PhpMyAdmin sous MAMP

Si vous êtes sur Mac et que vous utilisé MAMP comme serveur web, vous avez peut-être envie de mettre à jour le PhMyAdmin qui est fournit avec, histoire de.

mamp_home.gif

La manipulation n’a rien de complexe, mais elle mérite d’être détaillée.

  1. La première étape c’est de télécharger la dernière version sur le site de PhpMyAdmin
  2. Ensuite, rendez-vous dans votre dossier application, chercher le dossier MAMP.
  3. PhpMyAdmin se trouve dans le dossier MAMP/bin/PhpMyAdmin . NE LE SUPPRIMEZ PAS ! Renommé le.
  4. Placer le nouveau PhpMyAdmin dans le dossier MAMP/bin .
  5. Aller dans votre ancien PhpMyAdmin et copier-coller le fichier config.inc.php dans le nouveau PhpMyAdmin.

À ce niveau, lorsque vous lancez PhpMyadmin, c’est le nouveau qui est pris en compte, par contre il y a un joli message d’erreur pas beau !

PhpMyAdmin error blowfish_secret

Pas de panique, normalement vu que c’est un serveur local, on pourrait simplement ignorer ce message. Mais je n’aime pas les messages d’erreur, ça fait tache. Et puis on ne sait jamais qu’un vilain pirate chinois n’essaie de prendre le contrôle de ma machine.

D’autant plus que l’erreur est simple a corrigé, ouvrir le fichier config.inc.php que vous avez copié juste avant et remplissé la ligne 61 : $cfg[’blowfish_secret’] = ’’ ;

Avec ce que vous voulez, par exemple : $cfg[’blowfish_secret’] = ’prout’ ;

Et le message d’erreur disparaitra.