hcalendar-authoring-fr: Difference between revisions
m (Replace <entry-title> with {{DISPLAYTITLE:}}) |
|||
(7 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
{{DISPLAYTITLE:publication hCalendar}} | |||
Cette page contient quelques trucs et instructions utiles pour savoir comment publier des événements [[hcalendar-fr|hCalendar]] soit à partir de rien, ou en ajoutant du balisage à un contenu existant. | Cette page contient quelques trucs et instructions utiles pour savoir comment publier des événements [[hcalendar-fr|hCalendar]] soit à partir de rien, ou en ajoutant du balisage à un contenu existant. | ||
Line 5: | Line 5: | ||
'''But :''' Le but de ce document est de fournir quelques instructions intuitives qui devraient faire qu'il soit aussi facile et aussi rapide que possible pour n'importe quel auteur web de créer des événements hCalendar ou d'ajouter du balisage hCalendar à un contenu existant. | '''But :''' Le but de ce document est de fournir quelques instructions intuitives qui devraient faire qu'il soit aussi facile et aussi rapide que possible pour n'importe quel auteur web de créer des événements hCalendar ou d'ajouter du balisage hCalendar à un contenu existant. | ||
'''Audience :''' auteurs web et designers. Ce document est écrit pour une consommation et une compréhension facile par n'importe quel designer web qui connaît au moins assez (X)HTML et CSS pour utiliser les noms de classe HTML sur les éléments et | '''Audience :''' auteurs web et designers. Ce document est écrit pour une consommation et une compréhension facile par n'importe quel designer web qui connaît au moins assez (X)HTML et CSS pour utiliser les noms de classe HTML sur les éléments et écrire des sélecteurs CSS qui appliquent des styles à ces noms de classes. SVP aidez à clarifier / simplifier ce document. | ||
'''Auteur(s) :''' Tantek Çelik | '''Auteur(s) :''' Tantek Çelik | ||
(traduction | (traduction [[Christophe Ducamp]]) | ||
== Créer des nouveaux événements hCalendar == | |||
Commencez avec le [http://microformats.org/code/hcalendar/creator hCalendar creator], et pour les champs additionnels (par ex. contact, participants, etc.), voir la page [[hcalendar-examples-fr|exemples hCalendar]] tout comme le reste de cette page. | Commencez avec le [http://microformats.org/code/hcalendar/creator hCalendar creator], et pour les champs additionnels (par ex. contact, participants, etc.), voir la page [[hcalendar-examples-fr|exemples hCalendar]] tout comme le reste de cette page. | ||
== Ajouter du balisage hCalendar à du contenu existant == | == Ajouter du balisage hCalendar à du contenu existant == | ||
=== Changements minimaux de syntaxe === | === Changements minimaux de syntaxe === | ||
La chose importante à garder en tête au moment d'ajouter des microformats à du contenu existant, est le fait que les microformats sont conçus de telle manière qu'ils peuvent être ajoutés avec des changements minimaux (presque toujours aucun) à la présentation existante de la page. De ce fait, gardez ça en tête : changez aussi peu de balisage que possible. Si vous voulez aussi préparer différentes pages pour qu'elles soient valides XHTML, c'est un très joli but et hautement encouragé. | |||
=== Trouver les Événements === | |||
Commencez par regarder toutes les mentions des événements sur une page, telle qu'une liste d'"Evénements à Venir" ou d'"Évènements Récents". Ce sont tous des 'events' potentiels hCalendar. Même plus s'ils sont liés vers leurs URLs respectives (par ex. les pages d'un événement unique avec plus de détails). | |||
Si un évènement est mentionné plusieurs fois sur une page, considérez de baliser la mention qui est la plus pertinente, détaillée, définitive, ou autrement complète comme un évènement hCalendar. Idéalement, vous pourriez vouloir baliser ''toutes'' les instances d'un événement avec hCalendar, mais à ce stade, faites simple et balisez l'instance la plus représentative. (Peut-être que l'instance la plus "définitive", qui pourrait être ensuite balisée avec un élément <code><nowiki><dfn></nowiki></code> autour du 'summary/title' de l'évènement pour le bien d'un XHTML sémantique additionnel.) | |||
=== Déterminer l'Élément enveloppant pour Chacun === | |||
Pour chaque évènement que vous voulez ajouter à hCalendar, trouvez le plus petit élément qui contient toute l'information à propos de cet événement, sans chevauchement avec tout autre événement sur la page. | |||
=== Déterminer l' | |||
Pour chaque | |||
Ajoutez le nom de classe "<code>vevent</code>" à cet élément. | Ajoutez le nom de classe "<code>vevent</code>" à cet élément. | ||
Si un tel élément n'existe pas (peut-être que l'élément enveloppant le plus proche contient plus d'un évènement), alors ajoutez un <code><nowiki><span class="vevent">...</span></nowiki></code> ou <code><nowiki><div class="vevent">...</div></nowiki></code> qui enveloppe l'information à propos de cet évènement et rien que cet évènement. | |||
Le reste de la syntaxe pour cet 'event' hCalendar DOIT aller ''dans'' cet élément-là avec le nom de classe "vevent". | Le reste de la syntaxe pour cet 'event' hCalendar DOIT aller ''dans'' cet élément-là avec le nom de classe "vevent". | ||
Dans tous le cas, où ça dit d'ajouter un élément avec le nom de classe de "xyz", si vous pouvez trouver un élément existant qui entoure le contenu nécessaire, alors ré- | Dans tous le cas, où ça dit d'ajouter un élément avec le nom de classe de "xyz", si vous pouvez trouver un élément existant qui entoure le contenu nécessaire, alors ré-utilisez cet-élément là et ajoutez-lui simplement le nom de classe "xyz" (en l'ajoutant à l'attribut de classe sur l'élément existant, ou en ajoutant un nouvel attribut de classe <code>class="xyz"</code> aux éléments sans attribut de classe). | ||
Par exemple, en imaginant que vous ayez la syntaxe suivante : | Par exemple, en imaginant que vous ayez la syntaxe suivante : | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class="someFoo"> | <div class="someFoo"> | ||
<p> Ceci est mon merveilleux balisage, il contient quelque information d'événement nichée à l'intérieur</p> | <p> Ceci est mon merveilleux balisage, il contient quelque information d'événement nichée à l'intérieur</p> | ||
<h6>Un | <h6>Un Evènement Merveilleux</h6> | ||
<p> De la part des personnes qui vont apporté des Moments Géniaux et de l'Amusement, | <p> De la part des personnes qui vont apporté des Moments Géniaux et de l'Amusement, | ||
voilà Quelque | voilà Quelque Evènement Merveilleux au Stade de Sport Local. | ||
Venez à <b>Une Heure Spécifiée</b>, et amusez-vous ! </p> | Venez à <b>Une Heure Spécifiée</b>, et amusez-vous ! </p> | ||
</div> | </div> | ||
</nowiki></pre> | </nowiki></pre> | ||
Si vous avez besoin d'ajouter un élément avec la classe de "vevent" autour du contenu de votre | Si vous avez besoin d'ajouter un élément avec la classe de "vevent" autour du contenu de votre évènement, vous pourriez réutiliser l'élément div existant et y ajouter la classe "vevent" comme suit : | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class=" | <div class="quelqueFoo vevent"> | ||
</nowiki></pre> | </nowiki></pre> | ||
De la même manière, si vous décidez de ne pas réutiliser un conteneur existant, vous pouvez juste emballer le contenu autour d'un nouveau bloc : | De la même manière, si vous décidez de ne pas réutiliser un conteneur existant, vous pouvez juste emballer le contenu autour d'un nouveau bloc : | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class=" | <div class="quelqueFoo"> | ||
<div class="vevent"> | <div class="vevent"> | ||
<p> Ceci est mon merveilleux... | <p> Ceci est mon merveilleux... | ||
Line 72: | Line 64: | ||
=== L'Importance du Temps et du Sujet === | === L'Importance du Temps et du Sujet === | ||
Plusieurs propriétés sont requises dans hCalendar. Au minimum, un événement à besoin d'un "summary" (comme un titre) et "dtstart" (date et heure de démarrage), tout comme soit un "dtend" (date et heure de fin) ou une "duration" (durée). De ce fait, soyez sûr de baliser le nom/résumé/titre de l'événement avec le nom de classe "summary". Par ex. : | Plusieurs propriétés sont requises dans hCalendar. Au minimum, un événement à besoin d'un "summary" (comme un titre) et "dtstart" (date et heure de démarrage), tout comme soit un "dtend" (date et heure de fin) ou une "duration" (durée). De ce fait, soyez sûr de baliser le nom/résumé/titre de l'événement avec le nom de classe "summary". Par ex. : | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class="vevent"> | <div class="vevent"> | ||
<span class="summary">Un | <span class="summary">Un Evènement A Part, New York City, NY</span>, | ||
<abbr class="dtstart" title=" | <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> | ||
</div></nowiki></pre> | </div></nowiki></pre> | ||
Cet | Cet évènement pourrait être présenté comme : | ||
Un | Un Évènement A Part, New York City, NY, <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> | ||
Note : l'utilisation de l'attribut du titre de l'élément abbr pour baliser un "datetime" absolu lisible par une machine en plus du texte | Note : l'utilisation de l'attribut du titre de l'élément abbr pour baliser un "datetime" absolu lisible par une machine en plus du texte lisible par l'humain. | ||
=== | ==== Separate dates and times ==== | ||
Souvent les pages affichent la date d'un événement et ses horaires séparément, peut-être pour des raisons de style ou mise en forme, par exemple le [http://sphcm.washington.edu/cal/cal.asp Calendrier des événement SPHCM] place la date dans un titre stylisé (devrait probablement être un <code>h3</code>), et les horaires comme suit : | |||
<pre><nowiki> | |||
<div class="eventdate">October 2</div> | |||
<div class="eventtime">3:30 pm - 4:50 pm</div> | |||
</nowiki></pre> | |||
Dans de tels cas, plutôt que d'avoir à refaire le marquage (qui peut être servi à d'autre fins) pour combiner la date et l'heure dans un seul élément unique, utilisez une div enveloppante pour marquer la date et l'heure de démarrage avec <code>dtstart</code> et un span juste pour l'horaire de fin avec <code>dtend</code>, par ex.: (espace blanc ajouté pour la lisibilité) | |||
<pre><nowiki> | <pre><nowiki> | ||
abbr | <div class="dtstart"> | ||
<div class="eventdate"><abbr class="value" title="2007-10-02">2 octobre</abbr></div> | |||
<div class="eventtime"> | |||
<span class="value">15h30</span> - | |||
<span class="dtend">16h50</span> | |||
</div> | |||
</div> | |||
</nowiki></pre> | </nowiki></pre> | ||
Cet exemple utilise la technique du [[value-class-pattern-fr|modèle de classe value]], spécifiquement à la fois les techniques de [[value-class-pattern-fr#Valeurs_Date_et_heure|séparation de date et de l'horaire]] et de la [[http://microformats.org/wiki/index.php?title=value-class-pattern-fr#hCalendar_date_dtend_implicite|date dtend implicite]]. | |||
=== Éliminer le Souligné Pointillé par Défaut === | |||
Quelques navigateurs (Camino, Firefox, Mozilla) placent un <span style="border-bottom:dotted 1px">souligné pointillé ou une bordure</span> sur chaque <abbr title="abbreviation">abbr</abbr>. Vous pouvez utiliser la règle suivante dans votre feuille de style pour éliminer cette présentation par défaut. | |||
<pre><nowiki> | |||
.vevent abbr{border:0} | |||
</nowiki></pre> | |||
Un | Dans l'exemple ci-dessus "Un Événement A Part", ceci devrait avoir l'effet suivant (qui peut ne pas quelque différence pour quelques lecteurs) : | ||
Un Évènement A Part, New York City, NY, <abbr style="border:0" class="dtstart" title="2006-07-10">10</abbr>-<abbr style="border:0" class="dtend" title="2006-07-11">11 juillet 2006</abbr> | |||
=== URLs représentatives === | === URLs représentatives === | ||
L'un des modèles les plus communs pour les évènements sur le web est de les lier vers leurs sites web préférés/qui font autorité. | |||
L'un des modèles les plus communs pour les | |||
Les "Event Rolls" sont un bon exemple de cela (voir aussi [[xoxo-fr|XOXO]] pour une liste sémantique propre et un balisage de structure.) | Les "Event Rolls" sont un bon exemple de cela (voir aussi [[xoxo-fr|XOXO]] pour une liste sémantique propre et un balisage de structure.) | ||
Line 110: | Line 122: | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class="vevent"> | <div class="vevent"> | ||
<a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un | <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènément A Part, New York City, NY</a>, | ||
<abbr class="dtstart" title="20060710">10</abbr>-<abbr class="dtend" title=" | <abbr class="dtstart" title="20060710">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> | ||
</div></nowiki></pre> | </div></nowiki></pre> | ||
Cet | Cet évènement pourrait être présenté comme : | ||
[http://aneventapart.com/events/2006/nyc/ Un | [http://aneventapart.com/events/2006/nyc/ Un Evènement A Part, New York City, NY], <abbr style="border:0" class="dtstart" title="2006-07-10">10</abbr>-<abbr style="border:0" class="dtend" title="2006-07-11">11 juillet 2006</abbr> | ||
=== Location Location Location === | === Location Location Location === | ||
Comme dans l'immobilier, l'emplacement d'un évènement est tout à fait pertinent, et important pour un balisage propre. Au minimum, identifiez l'information apparentée au lieu dans l'"event" et balisez-la avec le nom de classe "location", par ex. en continuant avec les exemples suivants : | |||
Comme | |||
<pre><nowiki> | <pre><nowiki> | ||
<div class="vevent"> | <div class="vevent"> | ||
<a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un | <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènement A Part, | ||
<span class="location">New York City, NY</span></a>, | <span class="location">New York City, NY</span></a>, | ||
<abbr class="dtstart" title=" | <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> | ||
</div></nowiki></pre> | </div></nowiki></pre> | ||
Ceci est bien, mais peut même être produit encore mieux avec l' | Ceci est bien, mais peut même être produit encore mieux avec l'ajout du microformat [[adr-fr|adr]] pour identifier explicitement la ville et l'état : | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class="vevent"> | <div class="vevent"> | ||
<a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un | <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènement A Part, | ||
<span class="location adr"><span class="locality">New York City</span>, <span class="region">NY</span></span></a>, | <span class="location adr"><span class="locality">New York City</span>, <span class="region">NY</span></span></a>, | ||
<abbr class="dtstart" title=" | <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="20060711">11 juillet 2006</abbr> | ||
</div></nowiki></pre> | </div></nowiki></pre> | ||
Line 143: | Line 153: | ||
<pre><nowiki> | <pre><nowiki> | ||
<div class="vevent"> | <div class="vevent"> | ||
<a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un | <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènement A Part, | ||
<span class="location vcard"> | <span class="location vcard"> | ||
<span class="fn org">Scandinavia House</span>, | <span class="fn org">Scandinavia House</span>, | ||
<span class="adr"><span class="locality">New York City</span>, <span class="region">NY</span></span> | <span class="adr"><span class="locality">New York City</span>, <span class="region">NY</span></span> | ||
</span></a>, | </span></a>, | ||
<abbr class="dtstart" title=" | <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> | ||
</div></nowiki></pre> | </div></nowiki></pre> | ||
=== Plus de trucs et d'instructions === | === Plus de trucs et d'instructions === | ||
Sentez-vous libre d'ajouter plus de trucs que l'expérience vous a enseignée au moment de baliser les évènements avec hCalendar, même si tout ce que vous ajoutez n'est qu'une brève "catch phrase" qui vous revient en tête. | |||
Sentez-vous libre d'ajouter plus de trucs que l'expérience vous a enseignée au moment de baliser les | |||
* Comment baliser le contact et l'organisateur | * Comment baliser le contact et l'organisateur | ||
Line 159: | Line 168: | ||
* ... | * ... | ||
== Ajouter un lien d'abonnement à des événements == | |||
Quand vous mettez à jour vos événements pour y inclure un marquage hCalendar, vous pouvez aussi y inclure des liens comme "Ajouter les Événéments à votre Agenda" et/ou "Abonnez-vous aux Événements" pour faciliter le travail de vos utilisateurs. | |||
Voici quelques exemples de tels liens : | |||
<pre><nowiki> | |||
<a href="http://h2vx.com/ics/http://microformats.org/wiki/events"> | |||
Ajouter les Événéments à votre Agenda | |||
</a> | |||
</nowiki></pre> | |||
<pre><nowiki> | |||
<a href="webcal://h2vx.com/ics/http://microformats.org/wiki/events"> | |||
Abonnez-vous aux Événements | |||
</a> | |||
</nowiki></pre> | |||
Substituez simplement le lien vers vos événements hCalendar pour l'URL http://microformats.org/wiki/events URL ci-dessus. | |||
Si vous voulez, vous pouvez aussi utiliser le service X2V hébergé de Brian Suda ou même télécharger et installer vous-même le XSLT X2V et le faire fonctionner sur votre propre serveur au lieu d'utiliser un service de conversion en ligne hCalendar vers iCalendar (.ics). | |||
== Pages en rapport == | |||
{{hcalendar-related-pages-fr}} |
Latest revision as of 16:24, 18 July 2020
Cette page contient quelques trucs et instructions utiles pour savoir comment publier des événements hCalendar soit à partir de rien, ou en ajoutant du balisage à un contenu existant.
But : Le but de ce document est de fournir quelques instructions intuitives qui devraient faire qu'il soit aussi facile et aussi rapide que possible pour n'importe quel auteur web de créer des événements hCalendar ou d'ajouter du balisage hCalendar à un contenu existant.
Audience : auteurs web et designers. Ce document est écrit pour une consommation et une compréhension facile par n'importe quel designer web qui connaît au moins assez (X)HTML et CSS pour utiliser les noms de classe HTML sur les éléments et écrire des sélecteurs CSS qui appliquent des styles à ces noms de classes. SVP aidez à clarifier / simplifier ce document.
Auteur(s) : Tantek Çelik
(traduction Christophe Ducamp)
Créer des nouveaux événements hCalendar
Commencez avec le hCalendar creator, et pour les champs additionnels (par ex. contact, participants, etc.), voir la page exemples hCalendar tout comme le reste de cette page.
Ajouter du balisage hCalendar à du contenu existant
Changements minimaux de syntaxe
La chose importante à garder en tête au moment d'ajouter des microformats à du contenu existant, est le fait que les microformats sont conçus de telle manière qu'ils peuvent être ajoutés avec des changements minimaux (presque toujours aucun) à la présentation existante de la page. De ce fait, gardez ça en tête : changez aussi peu de balisage que possible. Si vous voulez aussi préparer différentes pages pour qu'elles soient valides XHTML, c'est un très joli but et hautement encouragé.
Trouver les Événements
Commencez par regarder toutes les mentions des événements sur une page, telle qu'une liste d'"Evénements à Venir" ou d'"Évènements Récents". Ce sont tous des 'events' potentiels hCalendar. Même plus s'ils sont liés vers leurs URLs respectives (par ex. les pages d'un événement unique avec plus de détails).
Si un évènement est mentionné plusieurs fois sur une page, considérez de baliser la mention qui est la plus pertinente, détaillée, définitive, ou autrement complète comme un évènement hCalendar. Idéalement, vous pourriez vouloir baliser toutes les instances d'un événement avec hCalendar, mais à ce stade, faites simple et balisez l'instance la plus représentative. (Peut-être que l'instance la plus "définitive", qui pourrait être ensuite balisée avec un élément <dfn>
autour du 'summary/title' de l'évènement pour le bien d'un XHTML sémantique additionnel.)
Déterminer l'Élément enveloppant pour Chacun
Pour chaque évènement que vous voulez ajouter à hCalendar, trouvez le plus petit élément qui contient toute l'information à propos de cet événement, sans chevauchement avec tout autre événement sur la page.
Ajoutez le nom de classe "vevent
" à cet élément.
Si un tel élément n'existe pas (peut-être que l'élément enveloppant le plus proche contient plus d'un évènement), alors ajoutez un <span class="vevent">...</span>
ou <div class="vevent">...</div>
qui enveloppe l'information à propos de cet évènement et rien que cet évènement.
Le reste de la syntaxe pour cet 'event' hCalendar DOIT aller dans cet élément-là avec le nom de classe "vevent".
Dans tous le cas, où ça dit d'ajouter un élément avec le nom de classe de "xyz", si vous pouvez trouver un élément existant qui entoure le contenu nécessaire, alors ré-utilisez cet-élément là et ajoutez-lui simplement le nom de classe "xyz" (en l'ajoutant à l'attribut de classe sur l'élément existant, ou en ajoutant un nouvel attribut de classe class="xyz"
aux éléments sans attribut de classe).
Par exemple, en imaginant que vous ayez la syntaxe suivante :
<div class="someFoo"> <p> Ceci est mon merveilleux balisage, il contient quelque information d'événement nichée à l'intérieur</p> <h6>Un Evènement Merveilleux</h6> <p> De la part des personnes qui vont apporté des Moments Géniaux et de l'Amusement, voilà Quelque Evènement Merveilleux au Stade de Sport Local. Venez à <b>Une Heure Spécifiée</b>, et amusez-vous ! </p> </div>
Si vous avez besoin d'ajouter un élément avec la classe de "vevent" autour du contenu de votre évènement, vous pourriez réutiliser l'élément div existant et y ajouter la classe "vevent" comme suit :
<div class="quelqueFoo vevent">
De la même manière, si vous décidez de ne pas réutiliser un conteneur existant, vous pouvez juste emballer le contenu autour d'un nouveau bloc :
<div class="quelqueFoo"> <div class="vevent"> <p> Ceci est mon merveilleux... ... ... et amusez-vous ! </p> </div> </div>
L'Importance du Temps et du Sujet
Plusieurs propriétés sont requises dans hCalendar. Au minimum, un événement à besoin d'un "summary" (comme un titre) et "dtstart" (date et heure de démarrage), tout comme soit un "dtend" (date et heure de fin) ou une "duration" (durée). De ce fait, soyez sûr de baliser le nom/résumé/titre de l'événement avec le nom de classe "summary". Par ex. :
<div class="vevent"> <span class="summary">Un Evènement A Part, New York City, NY</span>, <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> </div>
Cet évènement pourrait être présenté comme :
Un Évènement A Part, New York City, NY, 10-11 juillet 2006
Note : l'utilisation de l'attribut du titre de l'élément abbr pour baliser un "datetime" absolu lisible par une machine en plus du texte lisible par l'humain.
Separate dates and times
Souvent les pages affichent la date d'un événement et ses horaires séparément, peut-être pour des raisons de style ou mise en forme, par exemple le Calendrier des événement SPHCM place la date dans un titre stylisé (devrait probablement être un h3
), et les horaires comme suit :
<div class="eventdate">October 2</div> <div class="eventtime">3:30 pm - 4:50 pm</div>
Dans de tels cas, plutôt que d'avoir à refaire le marquage (qui peut être servi à d'autre fins) pour combiner la date et l'heure dans un seul élément unique, utilisez une div enveloppante pour marquer la date et l'heure de démarrage avec dtstart
et un span juste pour l'horaire de fin avec dtend
, par ex.: (espace blanc ajouté pour la lisibilité)
<div class="dtstart"> <div class="eventdate"><abbr class="value" title="2007-10-02">2 octobre</abbr></div> <div class="eventtime"> <span class="value">15h30</span> - <span class="dtend">16h50</span> </div> </div>
Cet exemple utilise la technique du modèle de classe value, spécifiquement à la fois les techniques de séparation de date et de l'horaire et de la [dtend implicite].
Éliminer le Souligné Pointillé par Défaut
Quelques navigateurs (Camino, Firefox, Mozilla) placent un souligné pointillé ou une bordure sur chaque abbr. Vous pouvez utiliser la règle suivante dans votre feuille de style pour éliminer cette présentation par défaut.
.vevent abbr{border:0}
Dans l'exemple ci-dessus "Un Événement A Part", ceci devrait avoir l'effet suivant (qui peut ne pas quelque différence pour quelques lecteurs) :
Un Évènement A Part, New York City, NY, 10-11 juillet 2006
URLs représentatives
L'un des modèles les plus communs pour les évènements sur le web est de les lier vers leurs sites web préférés/qui font autorité.
Les "Event Rolls" sont un bon exemple de cela (voir aussi XOXO pour une liste sémantique propre et un balisage de structure.)
Parce l'attribut de classe prend un ensemble séparé de noms de classe, on peut souvent baliser l'URL sur le même élément, par ex. en remplaçant le premier <span>
dans l'exemple au-dessus avec un hyperlien <a href>
:
<div class="vevent"> <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènément A Part, New York City, NY</a>, <abbr class="dtstart" title="20060710">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> </div>
Cet évènement pourrait être présenté comme :
Un Evènement A Part, New York City, NY, 10-11 juillet 2006
Location Location Location
Comme dans l'immobilier, l'emplacement d'un évènement est tout à fait pertinent, et important pour un balisage propre. Au minimum, identifiez l'information apparentée au lieu dans l'"event" et balisez-la avec le nom de classe "location", par ex. en continuant avec les exemples suivants :
<div class="vevent"> <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènement A Part, <span class="location">New York City, NY</span></a>, <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> </div>
Ceci est bien, mais peut même être produit encore mieux avec l'ajout du microformat adr pour identifier explicitement la ville et l'état :
<div class="vevent"> <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènement A Part, <span class="location adr"><span class="locality">New York City</span>, <span class="region">NY</span></span></a>, <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="20060711">11 juillet 2006</abbr> </div>
Même encore mieux, si l'endroit a un nom, tel qu'un commerce ou une société, transformer le lieu en une hCard complète plutôt qu'un simple adr :
<div class="vevent"> <a href="http://aneventapart.com/events/2006/nyc/" class="summary url">Un Évènement A Part, <span class="location vcard"> <span class="fn org">Scandinavia House</span>, <span class="adr"><span class="locality">New York City</span>, <span class="region">NY</span></span> </span></a>, <abbr class="dtstart" title="2006-07-10">10</abbr>-<abbr class="dtend" title="2006-07-11">11 juillet 2006</abbr> </div>
Plus de trucs et d'instructions
Sentez-vous libre d'ajouter plus de trucs que l'expérience vous a enseignée au moment de baliser les évènements avec hCalendar, même si tout ce que vous ajoutez n'est qu'une brève "catch phrase" qui vous revient en tête.
- Comment baliser le contact et l'organisateur
- Comment baliser les participants (y compris les conférenciers)
- ...
Ajouter un lien d'abonnement à des événements
Quand vous mettez à jour vos événements pour y inclure un marquage hCalendar, vous pouvez aussi y inclure des liens comme "Ajouter les Événéments à votre Agenda" et/ou "Abonnez-vous aux Événements" pour faciliter le travail de vos utilisateurs.
Voici quelques exemples de tels liens :
<a href="http://h2vx.com/ics/http://microformats.org/wiki/events"> Ajouter les Événéments à votre Agenda </a>
<a href="webcal://h2vx.com/ics/http://microformats.org/wiki/events"> Abonnez-vous aux Événements </a>
Substituez simplement le lien vers vos événements hCalendar pour l'URL http://microformats.org/wiki/events URL ci-dessus.
Si vous voulez, vous pouvez aussi utiliser le service X2V hébergé de Brian Suda ou même télécharger et installer vous-même le XSLT X2V et le faire fonctionner sur votre propre serveur au lieu d'utiliser un service de conversion en ligne hCalendar vers iCalendar (.ics).
Pages en rapport
- hCalendar - spécification
- hCalendar intro - présentation en langage clair
- hCalendar publication - apprendre comment ajouter le balisage hCalendar à vos événements existants.
- hCalendar creator (hCalendar feedback) - créer vos propres événements hCalendar.
- hCalendar antisèche - propriétés hCalendar
- hCalendar exemples dans la jungle - une liste continuellement mise à jour de sites web qui utilisent hCalendar.
- hCalendar implementations - les sites web ou outils qui soit génèrent ou parsent les hCalendars.
- hCalendar FAQ - Si vous avez quelque question à propos de hCalendar, jetez un coup d'oeil ici.
- hCalendar parsage - détails normatifs sur la manière de parser hCalendar.
- hCalendar profil - le profil XMDP pour hCalendar
- hCalendar tests - une page wiki avec de véritables événements hCalendar embarqués pour essayer le parsage.
- hCalendar "to do" - tâches à faire
- hCalendar soutien - encourager les autres à utiliser hCalendar.
Cette spécification est un chantier en cours. Au fur et à mesure que les aspects additionnels sont discutés, compris et écrits, ils seront ajoutés. Ces idées et questions sont maintenues sur des pages séparées.
- hCalendar Brainstorming - brainstormings et autres explorations en rapport avec hCalendar
- hCalendar problématiques - problématiques avec la spécification