<?xml version="1.0" encoding="UTF-8"?> <rss version="2.0" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" ><channel><title>bbxdesign &#187; Astuces</title> <atom:link href="http://bbxdesign.com/cat/astuces/feed/" rel="self" type="application/rss+xml" /><link>http://bbxdesign.com</link> <description>Vestiges d&#039;un CSS Guru</description> <lastBuildDate>Thu, 05 Apr 2012 12:00:32 +0000</lastBuildDate> <language>fr</language> <sy:updatePeriod>hourly</sy:updatePeriod> <sy:updateFrequency>1</sy:updateFrequency> <generator>http://wordpress.org/?v=3.3.1</generator> <item><title>Regex backreference dans Notepad++</title><link>http://bbxdesign.com/2012/04/04/regex-backreference-dans-notepad/</link> <comments>http://bbxdesign.com/2012/04/04/regex-backreference-dans-notepad/#comments</comments> <pubDate>Tue, 03 Apr 2012 23:22:52 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[notepad]]></category> <category><![CDATA[regex]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=2222</guid> <description><![CDATA[Si vous aimez le Find &#38; Replace&#8220;de Notepad++, et notamment son option regex, voici comment créer un backreference dans le Find et le réutiliser comme replacement text dans le Replace : Find : ([a-z])&#60;em&#62; Replace : \1&#60;/em&#62; Là, ça matche tous les &#60;em&#62; précédés d&#8217;une lettre (et non d&#8217;un espace). Le résultat est ensuite remplacé [...]]]></description> <content:encoded><![CDATA[<p>Si vous aimez le <em>Find &amp; Replace</em>&#8220;de Notepad++, et notamment son option regex, voici comment créer un <a href="http://www.regular-expressions.info/brackets.html">backreference</a> dans le <em>Find</em> et le réutiliser comme replacement text dans le <em>Replace</em> :</p><pre>Find : ([a-z])&lt;em&gt;
Replace : \1&lt;/em&gt;</pre><p>Là, ça matche tous les &lt;em&gt; précédés d&#8217;une lettre (et non d&#8217;un espace). Le résultat est ensuite remplacé <em>par la lettre trouvée</em> (sauvegardée entretemps dans une variable) puis par la balise fermante &lt;/em&gt;.</p> ]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/04/04/regex-backreference-dans-notepad/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Archives WordPress hiérarchisées par date</title><link>http://bbxdesign.com/2012/02/20/archives-wordpress-hierarchisees-par-date/</link> <comments>http://bbxdesign.com/2012/02/20/archives-wordpress-hierarchisees-par-date/#comments</comments> <pubDate>Mon, 20 Feb 2012 15:09:39 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[wordpress]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1863</guid> <description><![CDATA[Beaucoup plus pratique, non ?]]></description> <content:encoded><![CDATA[<p><img width="500" height="200" src="http://bbxdesign.com/wp-content/uploads/archives-wordpress-hierarchie-par-date.png" class="attachment-medium wp-post-image" alt="archives-wordpress-hierarchie-par-date" title="archives-wordpress-hierarchie-par-date" /></p><p>Beaucoup plus <a href="http://bbxdesign.com/archives/">pratique</a>, non ?</p> ]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/02/20/archives-wordpress-hierarchisees-par-date/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>&#8594; Free mobile : activer les données cellulaires pour la 3G et les MMS</title><link>http://video.telephonie.commentkonfait.com/video/activer-mms-donnees-cellulaires-free-mobile-configuration-apn/3742</link> <comments>http://bbxdesign.com/2012/02/03/free-mobile-activer-les-donnees-cellulaires-pour-la-3g-et-les-mms/#comments</comments> <pubDate>Fri, 03 Feb 2012 17:22:05 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[free]]></category> <category><![CDATA[iphone]]></category> <category><![CDATA[mobile]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1758</guid> <description><![CDATA[Si vous êtes passés chez Free mais que vos données cellulaires ne sont pas activées, vous ne pourrez pas aller sur internet (mais vous pourrez quand même téléphoner et envoyer des SMS). En fait, il faut activer manuellement les données cellulaires, et cette vidéo d&#8217;1 min vous explique comment.]]></description> <content:encoded><![CDATA[<p>Si vous êtes passés chez Free mais que vos données cellulaires ne sont pas activées, vous ne pourrez pas aller sur internet (mais vous pourrez quand même téléphoner et envoyer des SMS). En fait, il faut <strong>activer manuellement les données cellulaires</strong>, et cette vidéo d&#8217;1 min vous explique comment.</p><p><a href="http://bbxdesign.com/2012/02/03/free-mobile-activer-les-donnees-cellulaires-pour-la-3g-et-les-mms/">&#8734;	Permalien</a></p>]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/02/03/free-mobile-activer-les-donnees-cellulaires-pour-la-3g-et-les-mms/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>&#8594; Un bookmarklet pour tester un responsive web design</title><link>http://www.benjaminkeen.com/misc/bricss/</link> <comments>http://bbxdesign.com/2012/02/02/un-bookmarklet-pour-tester-un-responsive-web-design/#comments</comments> <pubDate>Thu, 02 Feb 2012 13:05:14 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[Bien développer]]></category> <category><![CDATA[responsive]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1744</guid> <description><![CDATA[Un autre outil très rapide pour tester si un site web est responsive ou pas.]]></description> <content:encoded><![CDATA[<p>Un autre outil très rapide pour tester si un site web est <strong>responsive</strong> ou pas.</p><p><a href="http://bbxdesign.com/2012/02/02/un-bookmarklet-pour-tester-un-responsive-web-design/">&#8734;	Permalien</a></p>]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/02/02/un-bookmarklet-pour-tester-un-responsive-web-design/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>&#8594; Responsive Design Testing</title><link>http://mattkersley.com/responsive/</link> <comments>http://bbxdesign.com/2012/01/30/responsive-design-testing/#comments</comments> <pubDate>Mon, 30 Jan 2012 13:33:40 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[Bien développer]]></category> <category><![CDATA[responsive]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1706</guid> <description><![CDATA[Outil tout simple mais extrêmement pratique pour tester votre web design sous plusieurs largeurs d&#8217;écrans. D&#8217;ailleurs, si vous voulez avoir la même chose mais en local, voici le simple responsive design test page.]]></description> <content:encoded><![CDATA[<p>Outil tout simple mais extrêmement pratique pour <strong>tester</strong> votre web design sous plusieurs largeurs d&#8217;écrans.</p><p>D&#8217;ailleurs, si vous voulez avoir la même chose mais en local, voici le <a href="http://bricss.net/post/16538278376/simple-responsive-design-test-page">simple responsive design test page</a>.</p><p><a href="http://bbxdesign.com/2012/01/30/responsive-design-testing/">&#8734;	Permalien</a></p>]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/01/30/responsive-design-testing/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Colonnes, marges et nth-child en CSS 3</title><link>http://bbxdesign.com/2012/01/24/colonnes-marges-et-nth-child-en-css-3/</link> <comments>http://bbxdesign.com/2012/01/24/colonnes-marges-et-nth-child-en-css-3/#comments</comments> <pubDate>Tue, 24 Jan 2012 12:59:42 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[Tutoriaux]]></category> <category><![CDATA[XHTML / CSS]]></category> <category><![CDATA[css]]></category> <category><![CDATA[css3]]></category> <category><![CDATA[math]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1649</guid> <description><![CDATA[Mail d&#8217;une amie : J&#8217;ai une colle pour toi : 1 &#8211; 4 colonnes de 240px =&#62; largeur totale 960px 2 &#8211; je rajoute un margin-right de 5px et soustrais 5px de la largeur de la colonne =&#62; largeur totale 960px Et pourtant dans le 2ème cas, visuellement la largeur totale est inférieure à 960px. [...]]]></description> <content:encoded><![CDATA[<p><img class="alignnone size-full wp-image-1673" title="colonnes-marges-nth-child-css3" src="http://bbxdesign.com/wp-content/uploads/colonnes-marges-nth-child-css3.png" alt="" width="500" height="200" /></p><p>Mail d&#8217;une amie :</p><blockquote><p>J&#8217;ai une colle pour toi :</p><div>1 &#8211; 4 colonnes de 240px =&gt; largeur totale 960px</div><div>2 &#8211; je rajoute un margin-right de 5px et soustrais 5px de la largeur de la colonne =&gt; largeur totale 960px</div><div></div><div>Et pourtant dans le 2ème cas, visuellement la largeur totale est inférieure à 960px.</div><div></div><div>How is it possible ?</div></blockquote><p>Elle n&#8217;était vraisemblablement pas bien réveillée parce qu&#8217;elle connaissait la réponse, mais je vais développer la méthode ici pour ceux qui auraient des soucis.</p><p><span id="more-1649"></span></p><h3>Largeur totale ≠ largeur utilisée</h3><p>Si vous avez un espace total de 480 pixels de large et que vous y mettez, <strong>côte à côte</strong>, 4 colonnes de <strong>120px</strong> de large, alors tout l&#8217;espace <em>horizontal</em> est rempli.</p><div id="attachment_1664" class="wp-caption alignnone" style="width: 490px"><img class="size-full wp-image-1664" title="colonnes-marges-css-total" src="http://bbxdesign.com/wp-content/uploads/colonnes-sans-marge.png" alt="" width="480" height="160" /><p class="wp-caption-text">120 * 4 = 480</p></div><p>Maintenant, si l&#8217;on diminue la largeur des colonnes jusqu&#8217;à <strong>90px</strong> mais qu&#8217;on rajoute à leur droite <strong>30px</strong> de marge, le compte total ne va pas changer.</p><div id="attachment_1665" class="wp-caption alignnone" style="width: 490px"><img class="size-full wp-image-1665" title="colonnes-avec-marges" src="http://bbxdesign.com/wp-content/uploads/colonnes-avec-marges.png" alt="" width="480" height="180" /><p class="wp-caption-text">(90 + 30) * 4 = 480</p></div><p>Le souci, c&#8217;est la <span style="color: #ff0000;"><strong>dernière marge à droite</strong></span>. Elle rentre dans le calcul des 480px de large, mais <em>visuellement</em>, c&#8217;est du <strong>vide</strong>.</p><h3>n colonnes, n-1 marges</h3><p>Quel que soit le nombre de colonnes, le nombre de marges sera toujours inférieur de 1.<br /> Pour <strong>n</strong> colonnes on a bien <strong>n-1</strong> marges.</p><p>Ce que l&#8217;on veut : <strong>supprimer la dernière marge à droite</strong>. <sup class='footnote'><a href='http://bbxdesign.com/2012/01/24/colonnes-marges-et-nth-child-en-css-3/#fn-1649-1' id='fnref-1649-1' onclick='return fdfootnote_show(1649)'>1</a></sup></p><h4>nth child : le sélecteur providentiel</h4><p>Au lieu d&#8217;appliquer une classe à la dernière colonne de chaque ligne, on va utiliser la fabuleuse pseudo-classe CSS 3 <strong><a href="http://www.w3.org/TR/css3-selectors/#nth-child-pseudo">:nth-child</a></strong>.</p><p>Dans mon exemple, on veut virer la marge de chaque colonne <strong>multiple de 4</strong>.<br /> Il faut faire :</p><pre>.column:nth-child(4n){ margin-right:0;}</pre><p>En fait, le nombre <em>n</em> correspond à un nombre qui va <strong>incrémenter</strong> indéfiniment, en commençant par 1. Donc on a :</p><ul><li>4*1 = 4 (la 4e colonne)</li><li>4*2 = 8 (la 8e colonne)</li><li>4*3&#8230;</li></ul><p>Il permet donc de sélectionner toutes les colonnes multiples de 4.</p><p>Etant donné que nth-child <a href="http://www.caniuse.com/#search=nth">n&#8217;est pas supporté</a> par IE6, IE7 et IE8, il vous sera sans doute nécessaire d&#8217;utiliser plutôt une classe &#8220;last&#8221; sur la dernière colonne de chaque ligne.</p><h3>Calcul des largeurs optimales</h3><p>Comment être sûr d&#8217;occuper <em>totalement</em> l&#8217;espace horizontal disponible ? En d&#8217;autres termes, comment faire en sorte que :</p><blockquote><p>largeur totale des colonnes<br /> + largeur totale des marges<br /> = largeur totale du conteneur</p></blockquote><p>Ici, je veux que que mes <strong>4</strong> colonnes fassent 90px de large.<br /> Largeur totale des colonnes = 90*4 = 360px.<br /> Il reste donc 480-360 = 120px pour <strong>3</strong> marges.<br /> <em>Chaque</em> marge fera donc 120/3 = <strong>40px</strong> de large.</p><p><img class="alignnone size-full wp-image-1675" title="colonnes-marges-optimales" src="http://bbxdesign.com/wp-content/uploads/colonnes-marges-optimales.png" alt="" width="480" height="180" /></p><p>Ici, le compte est bon, j&#8217;ai envie de dire.<br /> Toutes les colonnes ont la même largeur, et les marges aussi, et la largeur utilisée est égale à la largeur totale.<br /> L&#8217;utilisation de l&#8217;espace est donc <strong>optimale</strong>.</p><h4>Trouver facilement les valeurs optimales</h4><p>Imaginons des colonnes qui font <strong>85</strong>px de large.</p><ul><li>Largeur totale des colonnes = 85*4 = <strong>340</strong>px</li><li>Largeur restante pour les marges = 480 &#8211; 340 = <strong>140</strong>px</li><li>Largeur de chaque marge = 140/3 = <strong>46,6666666666666666666667</strong></li></ul><p>Le drame ! Bien sûr, on pourrait essayer de trouver la solution en <span style="color: #ff0000;"><strong>tâtonnant</strong></span>, en testant 86, puis 84, puis 87&#8230; Quelle perte de temps !</p><p>Pour calculer la largeur optimale, voici la <span style="color: #339966;"><strong>règle</strong></span> :</p><blockquote><p>La marge gagnée sur chaque colonne doit être un multiple du nombre de marges.</p></blockquote><p>Ok. Alors, repartons au début. On avait 4 colonnes à <strong>120px de large</strong><em> et</em> <strong>0px de marge</strong>.<br /> On a <strong>3</strong> marges, donc faut procéder par <em>palier</em> de <strong>3</strong>px :</p><ul><li>120 &#8211; 0 = 120px</li><li>120 &#8211; 3 = 117px (de large pour une colonne)</li><li>120 &#8211; 6 = 114px</li><li>&#8230;</li><li>120 &#8211; 30 = 90px (notre exemple)</li><li>120 &#8211; 33  = 87px</li><li>120 &#8211; 36 = 84px</li></ul><p>Du coup, on voit bien que <span style="color: #ff0000;"><strong>85</strong></span>px de large pour une colonne, c&#8217;est pas bon. Il faut choisir soit <span style="color: #339966;"><strong>87</strong></span>px ou bien <span style="color: #339966;"><strong>84</strong></span>px.</p><p>Prenons <strong>84</strong>px qui est le plus proche :</p><ul><li>colonnes = 84*4 = <strong>336</strong>px</li><li>marge totale = 480-336 = 144px</li><li>chaque marge = 144/3 = <strong>48</strong>px</li></ul><p>Avec des colonnes à 84px de large et des marges à 48px de large, l&#8217;espace horizontal de 480px est utilisé en <strong>entier</strong>.</p> ]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/01/24/colonnes-marges-et-nth-child-en-css-3/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Gestion d&#8217;inbox GMail</title><link>http://bbxdesign.com/2012/01/17/gestion-dinbox-gmail/</link> <comments>http://bbxdesign.com/2012/01/17/gestion-dinbox-gmail/#comments</comments> <pubDate>Tue, 17 Jan 2012 09:08:16 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[gmail]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1564</guid> <description><![CDATA[La feature &#8220;Multiple inboxes&#8221; couplée à un label &#8220;2do&#8221; est l&#8217;outil parfait pour gérer son Inbox : ma 2nde Inbox (paramétrée pour afficher uniquement les &#8220;Label: 2do&#8221;)  me montre : les mails auxquels je dois répondre les livraisons en cours les processus administratifs en cours les voyages prévus l&#8217;orthographe du label &#8220;2do&#8221; et pas &#8220;ToDo&#8221; [...]]]></description> <content:encoded><![CDATA[<p><img width="190" height="180" src="http://bbxdesign.com/wp-content/uploads/Screen-shot-2012-01-16-at-7.50.19-PM.png" class="attachment-medium wp-post-image" alt="Screen shot 2012-01-16 at 7.50.19 PM" title="Screen shot 2012-01-16 at 7.50.19 PM" /></p><p>La feature &#8220;<strong>Multiple inboxes</strong>&#8221; couplée à un <strong>label &#8220;2do&#8221;</strong> est l&#8217;outil parfait pour gérer son Inbox :</p><ul><li>ma 2nde Inbox (paramétrée pour afficher uniquement les &#8220;Label: 2do&#8221;)  me montre :</li><ul><li>les mails auxquels je dois répondre</li><li>les livraisons en cours</li><li>les processus administratifs en cours</li><li>les voyages prévus</li></ul><li>l&#8217;orthographe du label &#8220;2do&#8221; et pas &#8220;ToDo&#8221; ou &#8220;A faire&#8221; fait qu&#8217;il est le premier de ma liste de labels.</li></ul><p>Et avec les raccourcis claviers, ajouter un mail à cette Inbox nécessite uniquement de taper &#8220;L&#8221; puis &#8220;2&#8243; et &#8220;Entrée&#8221;.</p> ]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/01/17/gestion-dinbox-gmail/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>&#8594; Script Photoshop : calques vers JPG Web</title><link>http://www.scriptsrus.talktalk.net/Layer%20Saver.htm</link> <comments>http://bbxdesign.com/2012/01/07/script-photoshop-calques-vers-jpg-web/#comments</comments> <pubDate>Sat, 07 Jan 2012 16:08:42 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[Logiciels]]></category> <category><![CDATA[photoshop]]></category> <category><![CDATA[script]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1487</guid> <description><![CDATA[Vous connaissez sans doute l&#8217;excellent outil Photoshop pour &#8220;Exporter les calques dans les fichiers&#8221; : chaque calque est exporté individuellement et son nom est celui du fichier exporté. Le seul souci : ce sont des JPG &#8220;normaux&#8221;, c&#8217;est à dire non optimisés pour le Web (Fichier -&#62; Enregistrer pour le Web). Ce script, en utilisant [...]]]></description> <content:encoded><![CDATA[<p>Vous connaissez sans doute l&#8217;excellent outil Photoshop pour &#8220;<span style="color: #999999;"><em>Exporter les calques dans les fichiers</em></span>&#8221; : chaque calque est exporté individuellement et son nom est celui du fichier exporté.</p><p>Le seul <span style="color: #ff0000;">souci</span> : ce sont des JPG &#8220;normaux&#8221;, c&#8217;est à dire non optimisés pour le Web (<span style="color: #999999;"><em>Fichier -&gt; Enregistrer pour le Web</em></span>).</p><p>Ce script, en utilisant l&#8217;option &#8220;JPG SFW&#8221;, regroupe les deux qualités : <strong>l&#8217;automatisation</strong> du processus d&#8217;exportation et <strong>la qualité optimale</strong> pour le Web. Vous économisez ainsi <span style="color: #008000;">90%</span> d&#8217;espace : je suis moi-même passé de 3Mo d&#8217;images à 320Ko.</p><p><a href="http://bbxdesign.com/2012/01/07/script-photoshop-calques-vers-jpg-web/">&#8734;	Permalien</a></p>]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2012/01/07/script-photoshop-calques-vers-jpg-web/feed/</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Introduction à WordPress 3 : custom post type et custom taxonomy</title><link>http://bbxdesign.com/2010/05/31/introduction-a-wordpress-3-custom-post-type-et-custom-taxonomy/</link> <comments>http://bbxdesign.com/2010/05/31/introduction-a-wordpress-3-custom-post-type-et-custom-taxonomy/#comments</comments> <pubDate>Mon, 31 May 2010 08:00:01 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[Best Of]]></category> <category><![CDATA[Bien développer]]></category> <category><![CDATA[Logiciels]]></category> <category><![CDATA[Tutoriaux]]></category> <category><![CDATA[taxonomy]]></category> <category><![CDATA[tutoriel]]></category> <category><![CDATA[wordpress]]></category> <category><![CDATA[wp3]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1248</guid> <description><![CDATA[J&#8217;ai écrit un tutoriel complet pour réaliser un thème WordPress de A à Z.Il est plus récent et parle aussi des Custom Post Type et Custom Taxonomy. Du coup, je vous invite à aller le lire. WordPress vient d&#8217;annoncer une Release Candidate pour la version 3. J&#8217;ai pour ma part installé et mis en prod [...]]]></description> <content:encoded><![CDATA[<p class="focus">J&#8217;ai écrit un <strong>tutoriel complet</strong> pour <a href="http://wordpress.bbxdesign.com/">réaliser un thème WordPress de A à Z</a>.<br />Il est plus récent et parle aussi des Custom Post Type et Custom Taxonomy. Du coup, je vous invite à aller le lire.</p><p><strong>WordPress </strong>vient d&#8217;annoncer une <a href="http://wordpress.org/development/2010/05/wordpress-3-0-release-candidate/">Release Candidate pour la version 3</a>. J&#8217;ai pour ma part installé et mis en prod la <a href="http://wordpress.org/development/2010/05/wordpress-3-0-beta-2/">version Beta 2</a> qui, ma foi, est très stable. Si vous comptez l&#8217;installer, allez-y! Les mises à jour se font comme les WP actuellement, c&#8217;est à dire automatiquement. Et le système de template pour les thèmes est identique donc vos thèmes marcheront sans souci! Le seul souci est qu&#8217;il n&#8217;y a pas de version française encore mais bon, c&#8217;est uniquement pour l&#8217;admin qui est vraiment très simple en anglais.</p><h3>Nouveautés WordPress 3</h3><p>Dans les nouveautés, il y a :</p><ul><li>choisir son <strong>login </strong>et son <strong>mot de passe </strong>: au lieu d&#8217;avoir &#8220;admin&#8221; et un mot de passe généré automatiquement, on peut les choisir soi-même.</li><li>un nouveau thème par défaut, bourré de nouvelles fonctions et qu&#8217;on va customiser dans ce tutoriel</li><li>custom background : un outil dans l&#8217;admin pour pouvoir choisir un fond pour le site. Si vous développez des thèmes vous même, ça vous est inutile.</li><li><strong>Multi-sites</strong>! En fait, WordPress et WordPress µ ont fusionné : il est donc possible avec 1 seule installation WP de mettre en place autant de blogs différents que l&#8217;on veut. Par exemple : <strong>css</strong>.bbxdesign.com pour un blog de CSS, <strong>inspiration</strong>.bbxdesign.com pour un blog d&#8217;inspiration etc.</li><li>Custom Post Types</li><li>Custom Taxonomies</li></ul><p>Je vais développer ces 2 derniers points car ils sont les plus intéressants.<br /> <span id="more-1248"></span></p><h3>Custom Post Types : vos propres Posts et Pages</h3><p>Si vous utilisez WP, vous savez qu&#8217;il y a 2 grand types d&#8217;éléments pour poster :</p><ul><li><strong>Posts </strong>: ce sont les billets du blogs rangés chronologiquement. Ils peuvent être dans des Catégories et avoir des Tags.</li><li><strong>Pages </strong>: ce sont des pages contenant du contenu fixe et intemporel. Il n&#8217;y a pas de notion de chronologie, ni de catégorie, ni de tags. Il y a uniquement une notion de hiérarchie (relation page parent/page enfant).</li></ul><p>Si vous avez un blog, ces 2 types d&#8217;éléments sont parfaitement suffisants. Vous créez des billets avec les Posts et vous ajoutez une page &#8220;A propos&#8221; et &#8220;Contact&#8221; avec les Pages.</p><p>Mais imaginons qu&#8217;en plus de ça, vous voulez une catégorie <strong>Portfolio </strong>qui regroupe vos plus beaux travaux, avec un screenshot, une description et quelques infos sur le client. Comment faire ? Vous pouvez créer des Posts que vous classerez dans une catégorie &#8220;Portfolio&#8221;. Mais c&#8217;est non seulement fastidieux à mettre en place dans votre thème mais c&#8217;est aussi fastidieux à gérer dans l&#8217;admin.</p><p>On va donc créer un autre type de post : les &#8220;<strong>Projets</strong>&#8220;. Pour ça, on va utiliser le fichier functions.php.</p><h4>Une fonction pour customiser l&#8217;admin</h4><p>On va regrouper tout notre code dans une fonction qui sera appelée à l&#8217;initialisation de l&#8217;admin. Comme ça, lorsqu&#8217;on lance l&#8217;admin, on activera toutes les fonctions décrites dans my_custom_init :</p><pre>add_action('init', 'my_custom_init');
function my_custom_init()
{
/* notre code PHP pour rajouter les custom post type */
}</pre><p><strong><span style="color: #ff0000;">Tout le code que je vais écrire maintenant devra être inclus dans la fonction my_custom_init</span></strong>.</p><h4>Déclarer le Custom Post Type</h4><p>Maintenant nous allons rajouter l&#8217;élément &#8220;Projet&#8221; dans notre admin :</p><pre>register_post_type('projet', array(
 'label' =&gt; __('Projets'),
 'singular_label' =&gt; __('Projet'),
 'public' =&gt; true,
 'show_ui' =&gt; true,
 'capability_type' =&gt; 'post',
 'hierarchical' =&gt; false,
 'supports' =&gt; array('title', 'author', 'thumbnail')
));</pre><p>Il faut utiliser la <a href="http://codex.wordpress.org/Function_Reference/register_post_type">fonction register_post_type</a> qui porte bien son nom : elle enregistre un nouvel élément, un nouveau type de Post. Il y a ensuite plusieurs paramètres. Ils n&#8217;y sont pas tous parce que beaucoup sont optionnels. J&#8217;ai mis les plus importants :</p><ul><li>&#8216;projet&#8217; correspond au nom du nouvel élément. Il sera utilisé dans les fichiers de template.</li><li>&#8216;label&#8217; est le nom qu&#8217;on retrouvera dans la colonne de gauche de l&#8217;admin. Il est préférable de mettre un pluriel.</li><li>&#8216;singular_label&#8217; est l&#8217;équivalent au singulier</li><li>&#8216;public&#8217; définit si les posts seront publics ou non.</li><li>&#8216;show_ui&#8217; définit si ce nouvel élément apparaît dans l&#8217;admin</li><li>&#8216;capability_type&#8217; définit si le nouvel élément est identique à un Post classique ou à une Page classique. Ici on veut un titre et une image miniature donc Post. En général, les Posts sont beaucoup plus intéressants car ils ont davantage de fonctions que les Pages.</li><li>&#8216;hierarchical&#8217; définit si il peut y avoir une hiérarchie (comme pour les Pages). Ici, c&#8217;est non car chaque élément est au même niveau.</li><li>&#8216;supports&#8217; est un array qui définit quels éléments d&#8217;un Post normal on veut avoir. Ici je veux juste le titre, l&#8217;auteur du Post et une miniature. Il y a pleins d&#8217;autres éléments :<ul><li> &#8216;title&#8217;</li><li> &#8216;editor&#8217; (la fenêtre principale de contenu)</li><li> &#8216;author&#8217;</li><li> &#8216;thumbnail&#8217;</li><li> &#8216;excerpt&#8217;</li><li> &#8216;trackbacks&#8217;</li><li> &#8216;custom-fields&#8217;</li><li> &#8216;comments&#8217;</li><li> &#8216;revisions&#8217; (la sauvegarde automatique de versions passées)</li><li> &#8216;page-attributes&#8217; (choix de template pour les pages et gestion de la hiérarchie)</li></ul></li></ul><p>Pour avoir les <strong>thumbnails </strong>dans votre thème, il faut ajouter dans functions.php :</p><pre>add_theme_support( 'post-thumbnails' );</pre><p>Merci à <a href="http://bbxdesign.com/2010/05/31/introduction-a-wordpress-3-custom-post-type-et-custom-taxonomy/comment-page-1/#comment-1554">benoit</a> pour m&#8217;avoir rappelé de mettre cette astuce.</p><p>Si vous avez tout bien fait vous devriez voir :</p><p><img class="alignnone size-full wp-image-1249" title="wordpress-custom-post-type" src="http://bbxdesign.com/wp-content/uploads/wordpress-custom-post-type.png" alt="" width="166" height="129" /></p><p>Vous pouvez maintenant créer un nouveau projet en cliquant sur &#8220;Add New&#8221;</p><p><a href="http://bbxdesign.com/wp-content/uploads/wordpress-3-custom-post-type-new.png"><img class="alignnone size-medium wp-image-1253" title="wordpress-3-custom-post-type-new" src="http://bbxdesign.com/wp-content/uploads/wordpress-3-custom-post-type-new-500x222.png" alt="" width="500" height="222" /></a></p><p>Whaaa, c&#8217;est vide! Eh oui : on a juste mis &#8220;title&#8221;, &#8220;author&#8221; et &#8220;thumbnail&#8221;. Et c&#8217;est tout ce dont on a besoin! Hop je rajoute un Projet &#8220;bbxdesign&#8221; avec un screenshot :</p><p><a href="http://bbxdesign.com/wp-content/uploads/bbxdesign-wordpress-3-nouveau-projet.png"><img class="alignnone size-medium wp-image-1254" title="bbxdesign-wordpress-3-nouveau-projet" src="http://bbxdesign.com/wp-content/uploads/bbxdesign-wordpress-3-nouveau-projet-499x267.png" alt="" width="499" height="267" /></a></p><p>Ok c&#8217;est cool, j&#8217;ai réussi à rajouter un nouveau projet! Ca marche nickel dans l&#8217;admin. Sauf que pour l&#8217;instant, j&#8217;ai rien qui s&#8217;affiche dans le blog!</p><h4>Afficher les Custom Post Type</h4><p>Sur votre blog (sur la home par exemple), dans la boucle des posts, il y a actuellement les <strong>Posts </strong>normaux. Mais nous on veut afficher les <strong>Projets</strong>! Pour ça, il faut faire un query_posts avec comme post_type le mot &#8220;projet&#8221;. Sur index.php par exemple, mettez :</p><pre>&lt;?php
$home_paged = (get_query_var('paged'));
$arguments = array(
 'post_type' =&gt; 'projet',
 'post_status' =&gt; 'publish',
 'paged' =&gt; $home_paged
);
query_posts($arguments);
get_template_part( 'loop', 'index' );
?&gt;</pre><p>Le $home_paged est une astuce qui permet de récupérer la valeur de la page courante et ainsi éviter de casser la pagination! Ensuite vient un array d&#8217;arguments : post_type en projet, post_status en publish (pour éviter d&#8217;afficher les brouillons) et page avec la variable.<br /> Ensuite on fait le query_posts avec ces options puis on appelle la boucle avec get_template_part. Il faut savoir que get_template_part est une nouvelle fonction de WordPress 3 qui permet d&#8217;inclure d&#8217;autres fichiers php. Ici on appelle le fichier loop.php. C&#8217;est d&#8217;ailleurs très pratique pour éviter de copier-coller la boucle WP dans plusieurs fichiers.</p><p>Si vous ouvrez le fichier <strong>loop.php</strong> du thème &#8220;twentyten&#8221;, vous verrez qu&#8217;il est vraiment très long. On va tout virer et mettre juste un peu de code pour la home, histoire de vous montrer facilement comment afficher les éléments pour un projet. Nous, tout ce qu&#8217;on veut, c&#8217;est afficher le titre (c&#8217;est à dire le nom du projet), ainsi que la miniature.</p><pre>&lt;?php while ( have_posts() ) : the_post(); ?&gt;
 &lt;div id="post-&lt;?php the_ID(); ?&gt;" &lt;?php post_class(); ?&gt;&gt;
 &lt;h2&gt;&lt;?php the_title(); ?&gt;&lt;/h2&gt;
 &lt;?php the_post_thumbnail(); ?&gt;
 &lt;/div&gt;
&lt;?php endwhile; ?&gt;</pre><p>Donc là, c&#8217;est très simple. On met la div avec le bon id et la bonne classe, on met le nom du projet (the_title) et l&#8217;image (the_post_thumbnail) et ça donne :</p><p><a href="http://bbxdesign.com/wp-content/uploads/wordpress-3-custom-portfolio.png"><img class="alignnone size-medium wp-image-1256" title="wordpress-3-custom-portfolio" src="http://bbxdesign.com/wp-content/uploads/wordpress-3-custom-portfolio-500x240.png" alt="" width="500" height="240" /></a></p><p>J&#8217;ai pris le thème de base &#8220;twentyten&#8221; et j&#8217;ai donc customisé les fichiers index.php et loop.php. La home contient donc des Projets et non pas des Posts. Mais vu que j&#8217;ai les 2, je peux faire une page /blog où j&#8217;aurais tous mes Posts!</p><p>Maintenant vous pouvez ajouter des projets à la volée, virer la sidebar, le header et gérer <strong>une partie Blog avec les Posts et une partie Portfolio avec les Projets.</strong></p><h3>Custom Taxonomy : de nouvelles catégories et de nouveaux tags</h3><p>Derrière ce nom barbare de &#8220;Taxonomy&#8221; se cache tout simplement les Catégories et les Tags. Avec WordPress 3, vous pouvez créer d&#8217;autres taxonomies. Imaginons qu&#8217;avec ce Portfolio vous voulez ajouter 2 choses :</p><ul><li>le <strong>type </strong>de projet : un logo, un site vitrine, une animation flash&#8230;.</li><li>les <strong>couleurs </strong>utilisées</li></ul><p>On pourrait utiliser les Catégories et les Tags, mais elles sont déjà utilisées par les Posts pour le Blog! On va donc créer d&#8217;autres catégories et d&#8217;autres tags, exclusivement pour le Portfolio.</p><pre>register_taxonomy( 'type', 'projet', array( 'hierarchical' =&gt; true, 'label' =&gt; 'Type', 'query_var' =&gt; true, 'rewrite' =&gt; true ) );
register_taxonomy( 'couleur', 'projet', array( 'hierarchical' =&gt; false, 'label' =&gt; 'Couleur', 'query_var' =&gt; true, 'rewrite' =&gt; true ) );</pre><p>On utilise la <a href="http://codex.wordpress.org/Function_Reference/register_taxonomy">fonction register_taxonomy</a>. Dans l&#8217;ordre on choisit</p><ul><li>le nom de la taxonomie</li><li>l&#8217;élément auquel il s&#8217;applique (ça peut être &#8216;post&#8217;, &#8216;page&#8217; ou un post type qu&#8217;on a créé, en l&#8217;occurence &#8216;projet&#8217;)</li><li>&#8216;hierarchical&#8217; definit si il y a une relation parent/enfant. Si oui, c&#8217;est comme les Catégories. Si non, c&#8217;est comme les Tags.</li><li>&#8216;label&#8217; c&#8217;est le nom plus descriptif qui s&#8217;affichera dans l&#8217;admin</li><li>&#8216;query_var&#8217; à mettre sur true pour qu&#8217;on puisse appeler cette taxonomie dans nos templates</li><li>&#8216;rewrite&#8217; c&#8217;est la chaîne de caractères présente dans les permaliens. Si on met &#8220;true&#8221;, ça prend la valeur par défaut, c&#8217;est à dire le nom de la taxonomie.</li></ul><p>(Bien sûr, tout ceci est toujours à mettre dans la fonction my_custom_init commencée tout à l&#8217;heure.)</p><p>Si vous rechargez l&#8217;admin, vous voyez par magie :</p><p><img class="alignnone size-full wp-image-1259" title="custom-taxonomy-type-couleur" src="http://bbxdesign.com/wp-content/uploads/custom-taxonomy-type-couleur.png" alt="" width="153" height="124" /></p><p><a href="http://bbxdesign.com/wp-content/uploads/custom-taxonomy-nouveau-projet.png"><img class="alignnone size-medium wp-image-1260" title="custom-taxonomy-nouveau-projet" src="http://bbxdesign.com/wp-content/uploads/custom-taxonomy-nouveau-projet-500x302.png" alt="" width="500" height="302" /></a></p><p>J&#8217;ai déplacé les blocs &#8220;Type&#8221; et &#8220;Couleur&#8221; à gauche pour que ce soit plus lisible. Maintenant vous pouvez ajouter le type &#8220;animation flash&#8221;, &#8220;logo&#8221;, &#8220;direction artistique&#8221;&#8230; et les couleurs &#8220;vert&#8221;, &#8220;orange&#8221;, &#8220;bleu&#8221;&#8230; Ca ressemble à peu près à ce qui ai fait sur <a href="http://www.steaw-webdesign.com/en">Steaw Web Design</a> (sauf qu&#8217;on utilise des sous-catégories).</p><h4>Afficher les Custom Taxonomies dans le thème</h4><p>Ok c&#8217;est cool, vous avez vos Custom Taxonomies dans l&#8217;admin. Maintenant faut les afficher dans le thème! On va reprendre le fichier loop.php de tout à l&#8217;heure et rajouter ça :</p><pre>&lt;?php while ( have_posts() ) : the_post(); ?&gt;
 &lt;div id="post-&lt;?php the_ID(); ?&gt;" &lt;?php post_class(); ?&gt;&gt;
 &lt;h2&gt;&lt;?php the_title(); ?&gt;&lt;/h2&gt;
 &lt;?php echo get_the_term_list( $post-&gt;ID, 'type', '&lt;p&gt;Type de projet : ', ', ', '&lt;/p&gt;' ) ?&gt;
 &lt;?php the_post_thumbnail(); ?&gt;
 &lt;?php echo get_the_term_list( $post-&gt;ID, 'couleur', '&lt;p&gt;Couleurs : ', ', ', '&lt;/p&gt;' ) ?&gt;
 &lt;/div&gt;
&lt;?php endwhile; ?&gt;</pre><p>On utilise la fonction get_the_term_list pour afficher les taxonomies du post courant ($post-&gt;ID). C&#8217;est dans un paragraphe, et les éléments sont séparés par des virgules. En fait, la <strong>taxonomie </strong>c&#8217;est l&#8217;ensemble de la liste (ex: &#8220;Couleurs&#8221;) et <strong>terme </strong>c&#8217;est chaque élément de la liste (ex: &#8220;orange&#8221;, &#8220;vert&#8221;).</p><p>Visuellement, ça donne ça :</p><p><a href="http://bbxdesign.com/wp-content/uploads/custom-taxonomies-portfolio.png"><img class="alignnone size-medium wp-image-1261" title="custom-taxonomies-portfolio" src="http://bbxdesign.com/wp-content/uploads/custom-taxonomies-portfolio-500x262.png" alt="" width="500" height="262" /></a></p><p>Vous remarquerez que ça crée des liens pour chaque terme. En cliquant dessus, on arrive à une archive. En local, j&#8217;arrive pas à le faire marcher mais ça fonctionne sur mon <a href="http://www.jukepod.fr/annee/2004">JukePod pour l&#8217;année 2004 </a>par exemple.</p><h3>Conclusion</h3><p>Avec les custom post type et les custom taxonomy, vous pouvez créer plusieurs &#8220;flux&#8221; sur votre site, comme par exemple un blog et un portfolio, sans avoir à mélanger les deux ou à s&#8217;embêter avec des sous-catégories.</p><p>Par exemple, pour le blog Steaw et le portfolio Steaw, on a du créer 2 WordPress différents avec d&#8217;un côté des Posts, des Catégories, des Tags et de l&#8217;autre&#8230; ben pareil : des Posts, des Catégories, des Tags! On le ferait aujourd&#8217;hui, on utiliserait le custom post type Projet pour le Portfolio. Il y a même un gars qui a fait un <a href="http://justintadlock.com/archives/2009/06/04/using-custom-taxonomies-to-create-a-movie-database">IMDB avec WordPress 3</a>&#8230;</p><p>Sources : <a href="http://net.tutsplus.com/tutorials/wordpress/10-features-to-look-forward-to-in-wordpress-3-0">Nettuts</a> et <a href="http://kovshenin.com/archives/custom-post-types-in-wordpress-3-0/">kovshenin</a></p> ]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2010/05/31/introduction-a-wordpress-3-custom-post-type-et-custom-taxonomy/feed/</wfw:commentRss> <slash:comments>76</slash:comments> </item> <item><title>L&#8217;URL Shortener de Google génère des codes QR</title><link>http://bbxdesign.com/2010/04/08/url-shortener-google-genere-codes-qr/</link> <comments>http://bbxdesign.com/2010/04/08/url-shortener-google-genere-codes-qr/#comments</comments> <pubDate>Thu, 08 Apr 2010 07:35:02 +0000</pubDate> <dc:creator>Jeremy</dc:creator> <category><![CDATA[Astuces]]></category> <category><![CDATA[Web World]]></category> <category><![CDATA[code]]></category> <category><![CDATA[google]]></category> <category><![CDATA[qr]]></category> <category><![CDATA[url]]></category><guid isPermaLink="false">http://bbxdesign.com/?p=1214</guid> <description><![CDATA[Vous connaissez les codes QR ? Ces code-barres en 2D très utilisés dans le domaine du mobile. Et vous savez que Google a son propre URL shortener ? Par exemple, pour mon article sur le formulaire CSS3, Google a généré l&#8217;URL http://goo.gl/fb/HioT Si vous ajoutez .qr à la fin, vous obtenez son code QR! Via Matt [...]]]></description> <content:encoded><![CDATA[<p>Vous connaissez les <a href="http://en.wikipedia.org/wiki/QR_Code"><strong>codes QR</strong></a> ? Ces <strong>code-barres en 2D</strong> très utilisés dans le domaine du <strong>mobile</strong>.<br /> Et vous savez que Google a son propre <strong>URL shortener</strong> ? Par exemple, pour mon article sur le formulaire CSS3, Google a généré l&#8217;URL http://goo.gl/fb/HioT<br /> Si vous ajoutez .qr à la fin, vous obtenez son code QR!</p><p><a href="http://chart.apis.google.com/chart?cht=qr&amp;chs=150x150&amp;choe=UTF-8&amp;chld=H&amp;chl=http://goo.gl/fb/HioT"><img class="alignnone" title="Code QR Google URL Shortener" src="http://chart.apis.google.com/chart?cht=qr&amp;chs=150x150&amp;choe=UTF-8&amp;chld=H&amp;chl=http%3A%2F%2Fgoo.gl%2Ffb%2FHioT" alt="" width="150" height="150" /></a></p><p>Via <a href="http://www.google.com/buzz/109412257237874861202/bSSWKdJcZf7/Heres-a-new-trick-that-hasnt-been-blogged-yet">Matt Cutts</a></p> ]]></content:encoded> <wfw:commentRss>http://bbxdesign.com/2010/04/08/url-shortener-google-genere-codes-qr/feed/</wfw:commentRss> <slash:comments>1</slash:comments> </item> </channel> </rss>
<!-- Performance optimized by W3 Total Cache. Learn more: http://www.w3-edge.com/wordpress-plugins/

Minified using disk: basic
Page Caching using disk: basic (User agent is rejected)
Database Caching 17/20 queries in 0.010 seconds using disk: basic

Served from: bbxdesign.com @ 2012-05-22 23:20:48 -->
