Archives du blog

Prestashop : problème de marge blanche avec JQZoom

JqZoom est une application, basée sur le framework Javascript JQuery, permettant de zoomer sur la photo d’un produit sur la fiche produit (par exemple).
Par le passé, j’ai déjà utilisé JQ Zoom et il est vraiment pas mal ! Il est assez facilement paramétrable, il fonctionne bien… et c’est très agréable !

De base, JqZoom est installé sur Prestashop (du moins, à partir de la version 1.3 de Prestashop).
Pour l’activer ou désactiver JqZoom, aller dans l’interface d’administration de Prestashop > Onglet Préférences > Sous-onglet Produits.

Comment activer ou désactiver JqZoom sur Prestaship

Comment activer ou désactiver JqZoom sur Prestashop

 Problème de marge blanche avec JqZoom sur Prestashop : Comment faire ?

 bug marge blanche Jquery JqZoom

bug marge blanche Jquery JqZoom

Quand est-ce que ce bug a lieu ?

La plupart du temps sur Prestashop.

Pourquoi y a-t’il une marge blanche en Haut et en Bas ?

Cet marge blanche peut être présente sur tous les côtés, selon la taille de l’image zoomée. Si l’image est en mode portrait, alors on aura les marges blanches à gauche et à droite. Si l’image est en mode paysage, les marges seront en haut et en bas. Pour ne pas avoir les marges, il faudrait une image aux dimansions d’un carré.

Pourquoi l’image doit-elle être de forme carrée ?

Sur Prestashop 1.4 (c’est celle que j’utilise actuellement), lorsque l’on survole l’image à zoomer, Prestashop appelle une autre déclinaison de l’image à zoomer !
Cette image est nommée de la façon suivante : http://www. mon_domaine.com/img/p/id_produitid_image-thickbox.jpg (ex : « ./img/p/10-36-thickbox.jpg »)

Or, le format de l’image Thickbox est par défaut de 600 x 600 px.

Parametrage de la taille des images produits dans prestashop

Parametrage de la taille des images produits dans prestashop

2 Solutions :

– Si toutes vos images sources ont toutes les mêmes dimensions et/ou proportions, dans ce cas il est préférable de modifier les dimensions des différentes images qui seront utilisées, et ce via l’interface d’administration (Cf. écran ci-contre).

– Si vos images sont tantôt verticales, tantôt horizontales, il sera préférable d’effectuer la modification de code ci-dessous.

Comment éviter les problèmes de marge blanche avec JqZoom et Prestashop ?

Vos images n’ont pas les mêmes proportions ? Du coup, vous aurez une marge blanche! Pour éviter celà, il faut non plus appeler l’image thickbox ayant une dimension définie, mais appeler l’image originale.
Cette image est nommée de la façon suivante : http://www. mon_domaine.com/img/p/id_produitid_image.jpg (ex : « ./img/p/10-36.jpg »)

Pour cela, ouvrez le fichier product.tpl (/www/themes/mon_theme/product.tpl).

A la ligne 150, vous êtes sensés avoir :

{if $jqZoomEnabled}class="jqzoom" alt="{$link->getImageLink($product->link_rewrite, $cover.id_image, 'thickbox')}"
{else} title="{$product->name|escape:'htmlall':'UTF-8'}" alt="{$product->name|escape:'htmlall':'UTF-8'}" 
{/if} id="bigpic" width="{$largeSize.width}" height="{$largeSize.height}" />

à modifier en :

{if $jqZoomEnabled}class="jqzoom" alt="{$link->getImageLink($product->link_rewrite, $cover.id_image, '')}"
{else} title="{$product->name|escape:'htmlall':'UTF-8'}" alt="{$product->name|escape:'htmlall':'UTF-8'}"
{/if} id="bigpic" width="{$largeSize.width}" height="{$largeSize.height}" />

On a supprimé le paramètre thickbox du lien généré dans la balise de texte alternatif.

 

ATTENTION : Pensez à supprimer les fichier de cache des templates dans le répertoire ./www/tools/smarty/compile !

Problème JqZoom avec une petite image

Bug JqZoom avec une petite image

NB : Si toutefois votre image originale est plus petite que l’image survolée, alors ça ne sera pas esthétique car d’une part il n’y aura pas de zoom, et d’autre part, le déplacement de la souris ne fera pas déplacer l’image zoomée.

Publicités

Prestashop : accès à la base de données via l’administration

Pour ma part, je suis chez OVH, avec le Prestashop v.1.4.1 qui est inclus dans l’offre PRO OVH.
Ce n’est pas la dernière version de Prestashop mais bon… (la dernière version étant Prestashop 1.4.3 à l’heure de ce post)

Concernant la base de données je n’y ai pas accès et n’ai donc pas pu choisir le préfixe du nom des tables. Cependant, via le Back-Office de Prestashop 1.4, on peut retrouver certaines informations qui peuvent s’avérer très utilses.

Pour cela, aller dans votre espace d’administration Prestashop, puis dans l’onglet Préférences puis cliquer sur l’onglet de sous-rubrique Base de Données.

Ainsi, vous avez accès :

  • au nom du serveur de base de données (en local localhost ou en production)
  • au nom de la base de données que vous utilisez pour la e-boutique
  • au préfixe des noms de tables de la base de données (souvent ps_ , mais chez OVH, de base le préfixe est pss_ )
  • au nom d’utilisateur ayant accès à la base de données
  • et un champ permettant de changer le mot de passe de l’utilisateur de la base de données (laisser vide si vous ne souhaitez pas le modifier).
  • enfin, la liste des tables présentes dans la base de données en question (leur nom commençant pas le fameux préfixe).
Le fait que le préfixe ne soit pas ps_ de base (comme chez OVH avec son hébergement PRO), peut parfois poser problème. Voir le problème de chargement du résultat de la navigation à facette sous Prestashop 1.4.