Si, sur votre serveur, vous avez des fichiers dont le nom est composé d’accents vous aurez peut être du mal à les transférer sur votre PC, voici comment faire.
Continuer la lecture de « Transfert des fichiers avec accent sur Filezilla »
Redirection 301 après migration d’une boutique Oscommerce vers Prestashop
Je travaille actuellement sur la migration vers Prestashop d’une boutique réalisée avec Oscommerce. Pour la migration aucun problème le module oscommerce to prestashop réalisé par Presto Changeo s’occupe de tout, en quelques minutes c’est fait. Par contre si vous désirez conserver le référencement de votre site c’est une autre histoire.
Modifier le hook d’un module sous Prestashop
Déplacer des modules est particulièrement simple dans le back-office de Prestashop. Toute fois, il est possible que vous obtenniez le message d’erreur suivant: « Ce module ne peut être accroché à ce hook ».
Cela signifie que le module n’est pas prévu pour être positionné là où vous le demandez. Ce qui ne veux pas dire que c’est impossible. Voici comment faire.
Continuer la lecture de « Modifier le hook d’un module sous Prestashop »
Hook Prestashop
J’expliquais dans mon article précédent comment greffer un module sur un hook supplémentaire. Ici je vais vous expliquer comment créer un nouveau hook que vous pourrez utiliser dans vos templates.
Supprimer complètement l’emballage cadeau dans Prestashop
Vous avez désactivé l’option permettant de proposer des emballages cadeaux dans les préférences de Prestashop et pourtant dans les emails de confirmation la ligne apparaît toujours. Rassurez-vous vous n’y êtes pour rien c’est un manquement dans le code de Prestashop. Continuer la lecture de « Supprimer complètement l’emballage cadeau dans Prestashop »
Ajouter des champs personnalisés aux adresses sous Prestashop
Prestashop propose un certain nombre de champs par défaut pour l’enregistrement des adresses, mais dans certains cas il peut être utile d’en ajouter de nouveaux. Je vais vous expliquer ici comment créer vos propres champs personnalisés.
Continuer la lecture de « Ajouter des champs personnalisés aux adresses sous Prestashop »
Désactiver les accents dans les url sous prestashop 1.5
Vous avez sûrement constaté comme beaucoup d’autres que l’équipe de développeurs de Prestashop avait jugé bon d’inclure les accents dans les urls. Cette idée plutôt étrange génère bien des problèmes (essayez de faire un copié collé de vos liens avec chrome par exemple). Voici la solution pour rendre les accents désactivable.
Continuer la lecture de « Désactiver les accents dans les url sous prestashop 1.5 »
Mes images ne s’affichent plus sous IE avec Prestashop 1.5.3
Vous avez fait la mise à jour de votre boutique Prestashop pour passer en 1.5.3 et depuis vos images n’apparaissent plus lorsque vous consultez votre site avec internet explorer ? Voici la solution.
Continuer la lecture de « Mes images ne s’affichent plus sous IE avec Prestashop 1.5.3 »
Recevoir un email lorsqu’un commentaire est déposé sur la boutique
Si comme moi vous utilisez le module productComment livré par défaut avec prestashop vous avez sans doute constaté que rien n’était prévu pour être averti lorsqu’un commentaire était déposé sur la boutique. Je trouve cela particulièrement dommage car cela implique de venir régulièrement ouvrir le module pour vérifier si un nouveau commentaire a été posté.
Voici donc une solution pour faire en sorte qu’un email vous soit automatiquement envoyé lorsque l’un de vos clients dépose un commentaire.
Dans le fichier « modules/productcomments/controllers/front/defaut.php » repérez le code suivant (ligne 120 environ):
if (count(Tools::getValue('criterion')) >= 1) { $comment->grade = $grade_sum / count(Tools::getValue('criterion')); // Update Grade average of comment $comment->save(); }
Et ajoutez ceci à la suite:
//send mail $donnees = array('{texte}' => "nouveau commentaire sur la boutique"); Mail::Send((int)Context::getContext()->language->id, 'newcomment', 'nouveau commentaire', $donnees, Configuration::get('PS_SHOP_EMAIL'), null, null, null, null, null, dirname(__FILE__).'/../../mails/');
Créez ensuite un dossier « modules/productcomments/mails/ » et ajoutez y un sous dossier par langue de votre boutique. Chaque dossier doit utiliser le code ISO de la langue c’est à dire « fr » pour « français », « en » pour « english », etc.
Créez ensuite les fichiers « newcomment.html » et « newcomment.txt », placez-les dans les dossier de langue que vous venez de créer et ajoutez y le code suivant (dans les deux fichiers html et txt):
{texte}
Voila désormais lorsqu’un utilisateur déposera un commentaire sur votre boutique vous en serez averti.
Ps: cette modification touche directement au fichier du module, cela signifie qu’éventuellement lors d’une mise à jour vos modifications seront écrasées.
Ps2: J’ai fait cette modification sur une version 1.5.4.1 de Prestashop.
La solution est alors de faire un override des fichiers php du module. Ceci n’est pour l’instant pas prévu par Prestashop il faut utiliser cette solution
/*** edit 09/07/13 ***/
Devnet m’a suggéré une petite amélioration via le forum de Prestashop.
Je vous la met donc ci-dessous:
Dans le fichier « defaut.php » remplacez le code suivant:
$donnees = array('{texte}' => "nouveau commentaire sur la boutique");
par :
$donnees = array( '{texte}' => $module_instance->l('New comment available'), '{content}' => $comment->content, '{id_product}' => $comment->id_product, '{id_customer}' => $comment->id_customer, '{customer_name}' => $comment->customer_name, '{title}' => $comment->title, '{grade}' => $comment->grade );
et dans les fichiers newcomment.html et newcomment.txt remplacez:
{texte}
par
{texte} {content} {id_product} {id_customer} {customer_name} {title} {grade}
Vous récupérerez ainsi le contenu du commentaire et des infos sur le client, merci Devnet !
*** EDIT 09/08/13 ***
Apparemment plsuieurs personnes n’arrivent pas à ajouter le code où il faut donc voici ce que cela donne une fois modifié:
if (count(Tools::getValue('criterion')) >= 1) { $comment->grade = $grade_sum / count(Tools::getValue('criterion')); // Update Grade average of comment $comment->save(); } //send mail $donnees = array( '{texte}' => $module_instance->l('New comment available'), '{content}' => $comment->content, '{id_product}' => $comment->id_product, '{id_customer}' => $comment->id_customer, '{customer_name}' => $comment->customer_name, '{title}' => $comment->title, '{grade}' => $comment->grade ); Mail::Send((int)Context::getContext()->language->id, 'newcomment', 'nouveau commentaire', $donnees, Configuration::get('PS_SHOP_EMAIL'), null, null, null, null, null, dirname(__FILE__).'/../../mails/'); $result = true;
Retrouvez deux autres améliorations pour ce module ci-dessous:
Alerte email lorsqu’un commentaire est déposé
5 Etoiles par défaut sur vos commentaires
Ne pas ajouter de cadre blanc autour de vos images sous Prestashop
Lorsqu’on upload une image produit (ou autre) dans prestashop, ce dernier la redimensionne selon les différents formats spécifiés dans « préférences/images ». C’est très pratique mais malheureusement prestashop ajoute systématiquement un fond blanc autour de l’image si cette dernière n’est pas exactement proportionnelle aux différents formats (ce qui arrive la plupart du temps).
Voici une solution pour que le fond soit transparent plutôt que blanc, vous pourrez ainsi le gérer plus facilement vos règles CSS.
Il suffit pour cela de faire un override de la méthode « resize » de la classe « ImageManager ».
Créez un fichier nommé « imageManager.php » dans le dossier « override/classes » et ajoutez-y le code suivant:
<?php class ImageManager extends ImageManagerCore { /** * Resize, cut and optimize image * * @param string $src_file Image object from $_FILE * @param string $dst_file Destination filename * @param integer $dst_width Desired width (optional) * @param integer $dst_height Desired height (optional) * @param string $file_type * @return boolean Operation result */ public static function resize($src_file, $dst_file, $dst_width = null, $dst_height = null, $file_type = 'jpg', $force_type = false) { if (PHP_VERSION_ID < 50300) clearstatcache(); else clearstatcache(true, $src_file); if (!file_exists($src_file) || !filesize($src_file)) return false; list($src_width, $src_height, $type) = getimagesize($src_file); // If PS_IMAGE_QUALITY is activated, the generated image will be a PNG with .jpg as a file extension. // This allow for higher quality and for transparency. JPG source files will also benefit from a higher quality // because JPG reencoding by GD, even with max quality setting, degrades the image. if (Configuration::get('PS_IMAGE_QUALITY') == 'png_all' || (Configuration::get('PS_IMAGE_QUALITY') == 'png' && $type == IMAGETYPE_PNG) && !$force_type) $file_type = 'png'; if (!$src_width) return false; if (!$dst_width) $dst_width = $src_width; if (!$dst_height) $dst_height = $src_height; $src_image = ImageManager::create($type, $src_file); $width_diff = $dst_width / $src_width; $height_diff = $dst_height / $src_height; if ($width_diff > 1 && $height_diff > 1) { $next_width = $src_width; $next_height = $src_height; } else { if (Configuration::get('PS_IMAGE_GENERATION_METHOD') == 2 || (!Configuration::get('PS_IMAGE_GENERATION_METHOD') && $width_diff > $height_diff)) { $next_height = $dst_height; $next_width = round(($src_width * $next_height) / $src_height); $dst_width = (int)(!Configuration::get('PS_IMAGE_GENERATION_METHOD') ? $dst_width : $next_width); } else { $next_width = $dst_width; $next_height = round($src_height * $dst_width / $src_width); $dst_height = (int)(!Configuration::get('PS_IMAGE_GENERATION_METHOD') ? $dst_height : $next_height); } } if (!ImageManager::checkImageMemoryLimit($src_file)) return false; $dest_image = imagecreatetruecolor($dst_width, $dst_height); //ici on applique un fond transparent quelque soit le type de fichier. imagealphablending($dest_image, false); imagesavealpha($dest_image, true); $transparent = imagecolorallocatealpha($dest_image, 255, 255, 255, 127); imagefilledrectangle($dest_image, 0, 0, $dst_width, $dst_height, $transparent); imagecopyresampled($dest_image, $src_image, (int)(($dst_width - $next_width) / 2), (int)(($dst_height - $next_height) / 2), 0, 0, $next_width, $next_height, $src_width, $src_height); return (ImageManager::write($file_type, $dest_image, $dst_file)); } }
Si jamais votre override ne s’applique pas pensez à supprimer le fichier « class_index.php » qui se trouve dans le dossier « cache » à la racine de votre boutique.