Envie de rajouter un block sur la home Magento ? Suivez ce tutoriel magento et vous verrez l’ensemble du code concernant les zones de type block, templates, layout et modules. Eh oui un affichage sous magento ne se passe pas comme un simple hello world dans n’importe qu’elle autre standard de programmation … Nous allons aujourd’hui รฉtablir un block sur la home de magento. Imaginons que votre affichage soit intemporelle et surtout global. Comme une landing page en javascript par exemple ร l’aide d’une lightbox. (Nous ne verrons pas cette partie lightbox ici). Comme toujours pour รฉtablir ce tutoriel j’ai analysรฉ le code source de magento. Je vous ai prรฉparรฉ un ensemble de code rempli de truc, tata, plop plopiplop j’en passe et des meilleurs! Pourquoi ? Comme toujours, pour vous permettre de rรฉellement faire un lien entre les diffรฉrents points du code. Plusieurs รฉtapes ici:
- Affichage des chemins des blocks et templates
- Crรฉation du module support
- Modification des layouts de base
Affichage des indications d’emplacement des blocks et templates hints
Tout d’abord affichons les templates hints et les blocks hints sur le frontend. Pour ce faire direction le back office: System-> configuration -> advanced ->developper ->Puis changer le scope ร (main website), et enfin passer dans Debug ร yes:
- Template Path Hints
- Add Block Names to Hints
Une petite sauvegarde et purge des caches et le tour est jouรฉ !
Crรฉons le Module support du block
Nous allons crรฉer un module qui va nous servir ร utiliser un block au sens MVC du terme. Pour ce faire, il faut d’abord activer le module: Dans le fichier ร crรฉer:
Crรฉons ensuite le fichier block dans app/code/local/Valibus/Plopiplop/Block/Flip.php Comme vous le voyez on se contente d’รฉtendre mage_core_block_template et de mettre en place une mรฉthode d’affichage dans le cadre de tutoriel.
Plaรงons ensuite app/code/local/Valibus/Plopiplop/etc/config.xml pour dรฉclarer notre block et la version du module. Comme vous le constatez nous n’avons pas besoin dans ce cas prรฉcis de dรฉclarer de layout propre ร ce module.
Notre module crรฉรฉ, nous n’avons plus qu’ร crรฉer son template app/design/frontend/base/default/template/tata/truc.phtml Oui je sais pour l’instant tout รงa est un peu dรฉcousu mais je vous retranscrit ca pelle melle aussi … (citรฉ de la peur quand tu nous tiens)
Modification des layouts et template de base
C’est en principe ici que tout s’articule pour votre comprรฉhensions. (Ou alors que vous รชtes perdu …) Bref comme vous avez pu le remarquer il y a en gรฉnรฉral selon les pages 2 templates qui selon les cas englobent les autres, j’ai nommรฉ:
- frontend/base/default/template/page/2columns-right.phtml
- frontend/base/default/template/page/3columns.phtml
Nous allons donc dans chacun d’entre eux, ajouter une ligne en dessous de l’appel de global notice
Et le meilleur pour la fin : รฉditons le fichier app/design/frontend/base/default/layout/page.xml et aprรจs la ligne (environ 67) sur les global_notices, rajoutons ceci qui fait tout s’articuler:
La ligne qui fait donc le lien entre le nom de notre block flip l’appel rรฉfรฉrence plop et le template truc. Elle est pas belle la vie? Allรฉ demain je vous fait la mรชme pour l’affcihage sur une page produit en plus propre, parce que lร oui, c’est un peu bourrin quand mรชme ! Mais faut pas le dire…Votre rendu devrait donc ressembler ร un patchwork multicolor, mais au moins vous arriverez ร savoir ce qui est quoi et qui va oรน !