# jsHtml2Ods Conversion d'un tableau HTML en fichier ODS disponible en téléchargement. Le principe de cette bibliothèque est de pouvoir écrire un lien proposant une version ODS (en fait au format .fods) d'un tableau HTML existant. L'exportation est opérationnelle sans aucune modification du tableau mais l'aspect du fichier résultant peut être substantiellement amélioré en ajoutant des attributs spéciaux (`data-od-*`) aux éléments du tableau et en proposant des styles suivant la syntaxe CSS. Cette bibliothèque est testée sous Firefox ou Chromium pour des tableaux de petite taille. ## Démonstration de la bibliothèque Une démonstration est visible ici : [jshtml2ods.exemole.fr/demo.html](https://jshtml2ods.exemole.fr/demo.html), également disponible via le site [Jsfiddle](https://jsfiddle.net/vcalame/4fxrkzgs/23/) pour faire des tests en direct. ## Utilisation de la bibliothèque La bibliothèque est contenue dans un seul fichier sans dépendance. La dernière version stable se trouve dans le répertoire *dist/*, voir aussi les versions dans la forge : [forge.chapril.org/vcalame/jsHtml2Ods/releases](https://forge.chapril.org/vcalame/jsHtml2Ods/releases). La dernière version est utilisable directement en ligne : [https://jshtml2ods.exemole.fr/latest/html2ods.js](https://jshtml2ods.exemole.fr/latest/html2ods.js). L'utilisation se fait en trois étapes : 1. Inclure la bibliothèque ```html ``` 2. Avoir dans le texte un lien et une table dotées d'identifiant HTML ```html Version ODS ...
` ou ` | ` - `data-od-style` : style de la cellule (en cas d'absence de valeur, un élément ` | ` a comme style *Header* et un élément ` | ` a comme style *Standard*) - `data-od-type` : type des données de la cellule (valeurs possibles : `number`, `date` ou `currency`) - `data-od-text` : texte de la cellule (alias : `data-text`), voir ci-dessous - `data-od-currency` : monnaie de la cellule, n'a d'intérêt que si la cellule est de type `currency` (voir ci-dessous) - `data-od-date-pattern` : formatage de la date, n'a d'intérêt que si si la cellule est de type `date` (voir ci-dessous) #### Texte d'une cellule Par défaut, le texte de la cellule dans le fichier résultant est le texte brut de l'élément ` | ` ou ` | `. Il est possible d'indiquer un texte alternatif via l'attribut `data-od-text`. Ce texte alternatif est souvent nécessaire dans le cas de cellule de type `number`, `date` ou `currency` ; en effet, la valeur de la cellule doit être un nombre valide ou une date au format ISO pour être traitée correctement lors de l'exporation. Au lieu de l'attribut `data-od-text`, la valeur peut être définie dans l'attribut `data-text`, ce qui permet la comptabilité avec l'extension JQuery TableSorter. Si les deux attributs sont présents, `data-od-text` a la préséance. Lorsque le texte de la cellule est le texte brut de l'élément, il est possible d'ignorer un élément enfant **direct** de l'élément ` | ` ou ` | ` en lui donnant l'attribut `data-od-hidden` avec la valeur 1 ou true. #### Formatage des dates Par défaut, les dates sont affichées au format ISO (année-mois-jour). Une autre format d'affichage peut être indiqué à trois endroits différents (classés par ordre de préséance) : l'attribut `data-od-date-pattern` de la celulle, l'attribut `data-od-date-pattern` de la table et la propriété *datePattern* de l'objet *options* passé en argument. Ce format doit est une chaine où les lettres suivantes sont remplacées par les valeurs de la date : - D : numéro du jour à un ou deux chiffres - DD : numéro du jour à deux chiffres - M : numéro du mois à un ou deux chiffres - MM : numéro du mois à deux chiffres - Y : année à deux chiffres - YY : année à quatre chiffres Par exemple, le code ISO correspond au format `YYYY-MM-DD` ; `DD/MM/YY` affiche le trois novembre 2021 sous la forme 03/11/21). **Point important** : ce formatage concerne l'affichage dans le fichier résultant mais pas la date telle qu'elle est représentée dans le tableau HTML ; dans ce dernier cas, la date doit impérativement être fournie au format ISO. #### Code des monnaies Les valeurs monétaires doivent avoir l'indication de la monnaie correspondante. Cette monnaie peut être indiquée à trois endroits différents (classés par ordre de préséance) : l'attribut `data-od-currency` de la cellule, l'attribut `data-od-currency` de la table, la propriété *datePattern* de l'objet *options* passé en argument. La monnaie est indiquée par son code ISO en trois lettres : *EUR*, *USD*, etc. ## Définition des styles via une syntaxe CSS Dans le format OpenDocument, la mise en forme des éléments (colonne, ligne, cellule) sont définies par des styles attachés aux éléments. Si de nombreux noms de propriété rappellent ceux des propriétés courantes du CSS, il y a quelques différences de taille : - Un élément possède un style et un seul - La seule hiérachie possible est un parent pour un style - Il n'y a évidemment aucune possibilité de définition en « cascade » via les sélecteurs CSS. Pour définir des styles dans le fichier résultant (par exemple, mettre un fond rouge à une cellule), jsHtml2Ods propose un mécanisme de conversion d'éléments suivant la syntaxe CSS vers le format XML d'OpenDocument. **Point important** : il s'agit d'une forme de détournement du CSS, aucun sélecteur CSS ne va fonctionner de manière habituelle ; l'idée est de pouvoir définir les styles de l'exportation au même endroit que le reste du HTML, c'est à dire dans les fichiers CSS chargés pa la page (ou le CSS d'éléments ` |
---|