https://wiki.dolibarr.org/api.php?action=feedcontributions&user=Esprit-libre&feedformat=atomDolibarr ERP CRM Wiki - User contributions [en]2024-03-29T14:45:15ZUser contributionsMediaWiki 1.35.0https://wiki.dolibarr.org/index.php?title=Cr%C3%A9er_un_mod%C3%A8le_de_document_ODT&diff=37114Créer un modèle de document ODT2017-04-25T13:07:11Z<p>Esprit-libre: /* Créer votre document */</p>
<hr />
<div>{{TemplateDocUtil}}<br />
Cette page décrit comment construire un modèle de document ODT pour utiliser la génération de document ODT.<br />
<br />
Pour savoir comment générer un modèle de document PDF, voir la page [[Créer un modèle de document PDF]].<br />
Créer un modèle PDF requiert des connaissances en programmation PHP mais pas la création de modèles ODT. <br />
<br />
== Prérequis ==<br />
* Dolibarr: 3.1+<br />
* OpenOffice: 3.2+, LibreOffice, ...<br />
<br />
== Créer votre document ==<br />
* Créer un document OpenOffice ou LibreOffice en partant de rien ou en prenant un example fournis. Si vous partez d'un exemple, vous les trouverez installés dans les sous-répertoires du répertoire '''documents/doctemplates'''<br />
* Éditer le document en utilisant toutes les fonctions de votre suite bureautique.<br />
Inclure dans votre documents les tags des informations que vous voulez voir. Les tags seront remplacés automatiquement au moment de la génération du document par Dolibarr. La liste des tags disponibles est décrite dans le chapitre suivant.<br />
<br />
[[File:warning.png]] Attention, les tags sont entourés de {} ou [] pour les tableaux ou conditions (voir plus loin) et doivent être tapés d'une traite sous la suite Office (sans retour arrière ou effacement, ni par copié-collé). Dans le cas contraire, la suite Office ajoutera des informations invisibles qui empêche le remplacement. Il est également possible d'utiliser les copier-coller en faisant un collage spécial sans formatage (CTRL+MAJ+V).<br />
<br />
== Tags ==<br />
Voici la liste des tags qui seront remplacés par les informations appropriées:<br />
<br />
===Company/foundation information===<br />
{{TagsOdtMyCompany}}<br />
<br />
===Customers, prospects or suppliers information===<br />
{{TagsOdtThirdParty}}<br />
<br />
=== Information utilisateur ===<br />
{{TagsOdtUser}}<br />
<br />
=== Autres informations ===<br />
{{TagsOdtOther}}<br />
<br />
===Informations sur l'objet (facture, proposition commerciale, commande, ...)===<br />
{{TagsOdtObjects}}<br />
<br />
===Lignes des objets===<br />
Voici comment utiliser les tableaux de lignes des objets (lignes de factures, commandes, etc...). Vous devez créer un tableau dans le document et utiliser une balise "begin" et "end" pour définir la ligne du tableau. Cette ligne sera répétée autant de fois que requis au moment de la génération.<br />
<pre><br />
[!-- BEGIN row.lines --]<br />
...<br />
[!-- END row.lines --]<br />
</pre><br />
<br />
Ensuite, ajouter les tags de votre choix dans les lignes parmi ceux-ci:<br />
{{TagsOdtLines}}<br />
<br />
Voici un exemple de ce que vous pourriez avoir dans votre traitement de texte:<br />
[[File:Line for document generation.png|500px]]<br />
<br />
=== Substitution conditionnelle ===<br />
<br />
Vous pouvez utiliser des '''remplacements conditionnels''', ce qui en termes simples signifie que vous pouvez décider d'imprimer quelque chose si une variable est vrai, ou imprimer autre chose si elle est fausse (ou rien du tout) - et cela marche non seulement avec du texte, mais aussi toute structure plus complexe comme les tableaux et les images.<br />
<br />
Exemple:<br />
<pre><br />
[!-- IF {my_var} --]<br />
Print this text if {my_var} is true (can be any value but null/0/empty string)<br />
[!-- ELSE {my_var} --]<br />
Or print this if it's false (null/0/empty string)<br />
[!-- ENDIF {my_var} --]<br />
</pre><br />
<br />
Note: le tag ELSE est bien sûr optionnel, vous pouvez sans problème juste utiliser un IF/ENDIF si vous préférez.<br />
<br />
ATTENTION: le format de cette balise spéciale est très précis et pointilleux, faire attention à '''mettre un seul espace''' entre:<br />
* [!--<br />
* IF/ELSE/ENDIF<br />
* {my var}<br />
* --]<br />
<br />
=== Autres tags personnalisés ===<br />
Si vous voulez ajouter un champ de substitution non prédéfini, il y a une solution:<br />
* Ajouter un fichier nommé <br />
'''htdocs/monmodule/core/substitutions/functions_mymodule.lib.php'''<br />
* Dans ce fichier , écrivez juste une fonction du genre:<br />
<source lang="php"><br />
/** Function called to complete substitution array (before generating on ODT, or a personalized email)<br />
* functions xxx_completesubstitutionarray are called by make_substitutions() if file<br />
* is inside directory htdocs/core/substitutions<br />
* <br />
* @param array $substitutionarray Array with substitution key=>val<br />
* @param Translate $langs Output langs<br />
* @param Object $object Object to use to get values<br />
* @return void The entry parameter $substitutionarray is modified<br />
*/<br />
function mymodule_completesubstitutionarray(&$substitutionarray,$langs,$object)<br />
{<br />
global $conf,$db;<br />
<br />
$myvalue='Put here calculated value to insert';<br />
$substitutionarray['myowntag']=$myvalue;<br />
}<br />
</source><br />
<br />
La fonction sera appelée avant la génération du document afin de compléter le tableau des substitutions afin que le tag '''myowntag''' soit remplacé par la valeur définie dans '''$myvalue'''.<br />
Vous pouvez ajouter autant de tag que désiré, et mettre le code que vous voulez pour définir les valeurs (recherche en base, en fichier, calcul, partir des variables reçues ou globales...).<br />
<br />
Attention: Le premier paramètre dans la déclaration de la fonction doit commencer par & car il est modifié par le code et doit être retourné modifié. <br />
<br />
Pour que vote votre fonction de substitution soit bien appelée, il vous faut:<br />
* Vérifier que votre fichier de substitution est bien stocké dans le répertoire '''htdocs/mymodule/core/substitutions'''<br />
* Créer un module (Voir la page [[Développement module]]) avec son fichier descripteur de module.<br />
* Vérifier que le fichier descripteur de module contient une entrée pour déclarer qu'il y a un fichier de substitution à appeler. Cette doit être <br />
<source lang="php"><br />
$this->module_parts = array('substitutions' => 1)<br />
</source><br />
* Activer le module (un module doit être activé et désactivé pour prendre en compte les changement dans son fichier descripteur)<br />
<br />
=== Autres tags personnalisées pour les lignes ===<br />
<br />
Cette fonctionnalité est disponible depuis Dolibarr v3.3 (version de développement futur).<br />
<br />
De manière similaire au chapitre précédent, vous devez définir une fonction de la même façon mais avec quelques différences:<br />
<br />
* Créez ou modifiez le même fichier que précédemment (voir le chapitre précédent).<br />
* Voici les différences: dans le fichier, écrire une autre fonction avec presque le même nom mais avec '_lines' en suffixe, et également ajouter une nouvelle variable $lines:<br />
<br />
<source lang="php"><br />
/** Function called to complete substitution array for lines (before generating on ODT, or a personalized email)<br />
* functions xxx_completesubstitutionarray_lines are called by make_substitutions() if file<br />
* is inside directory htdocs/core/substitutions<br />
* <br />
* @param array $substitutionarray Array with substitution key=>val<br />
* @param Translate $langs Output langs<br />
* @param Object $object Object to use to get values<br />
* @param Object $line Current line being processed, use this object to get values<br />
* @return void The entry parameter $substitutionarray is modified<br />
*/<br />
function mymodule_completesubstitutionarray_lines(&$substitutionarray,$langs,$object,$line) {<br />
{<br />
global $conf,$db;<br />
<br />
$myvalue='Put here calculated value to insert';<br />
$substitutionarray['myowntag']=$myvalue;<br />
}<br />
</source><br />
<br />
Contrairement à la fonction précédente qui n'est jamais appelée qu'une seule fois, cette fonction sera appelée à chaque fois qu'une ligne de produit sera traitée, en vous donnant chaque fois un objet $line différent que vous pouvez traiter. Cela vous permet de faire des substitutions de tags différentes pour chaque produit.<br />
<br />
== Enregistrer votre document ==<br />
Pour voir apparaitre votre modèle de document dans la liste des modèles disponibles, placer le dans le sous-répertoire adéquat qui se trouve dans le répertoire '''documents/doctemplates'''</div>Esprit-librehttps://wiki.dolibarr.org/index.php?title=Cr%C3%A9er_un_mod%C3%A8le_de_document_ODT&diff=37113Créer un modèle de document ODT2017-04-25T13:03:34Z<p>Esprit-libre: </p>
<hr />
<div>{{TemplateDocUtil}}<br />
Cette page décrit comment construire un modèle de document ODT pour utiliser la génération de document ODT.<br />
<br />
Pour savoir comment générer un modèle de document PDF, voir la page [[Créer un modèle de document PDF]].<br />
Créer un modèle PDF requiert des connaissances en programmation PHP mais pas la création de modèles ODT. <br />
<br />
== Prérequis ==<br />
* Dolibarr: 3.1+<br />
* OpenOffice: 3.2+, LibreOffice, ...<br />
<br />
== Créer votre document ==<br />
* Créer un document OpenOffice ou LibreOffice en partant de rien ou en prenant un example fournis. Si vous partez d'un exemple, vous les trouverez installés dans les sous-répertoires du répertoire '''documents/doctemplates'''<br />
* Editer le document en utilisant toutes les fonctions de votre suite bureautique.<br />
Incluer dans votre documents les tags des informations que vous voulez voir. Les tags seront remplacés automatiquement au moment de la génération du document par Dolibarr. La liste des tags disponibles est décrite dans le chapitre suivant.<br />
<br />
[[File:warning.png]] Attention, les tags sont entourés de {} ou [] pour les tableaux ou conditions (voir plus loin) et doivent être tapés d'une traite sous la suite Office (sans retour arrière ou effacement, ni par copié-collé). Dans le cas contraire, la suite Office ajoutera des informations invisibles qui empêche le remplacement.<br />
<br />
== Tags ==<br />
Voici la liste des tags qui seront remplacés par les informations appropriées:<br />
<br />
===Company/foundation information===<br />
{{TagsOdtMyCompany}}<br />
<br />
===Customers, prospects or suppliers information===<br />
{{TagsOdtThirdParty}}<br />
<br />
=== Information utilisateur ===<br />
{{TagsOdtUser}}<br />
<br />
=== Autres informations ===<br />
{{TagsOdtOther}}<br />
<br />
===Informations sur l'objet (facture, proposition commerciale, commande, ...)===<br />
{{TagsOdtObjects}}<br />
<br />
===Lignes des objets===<br />
Voici comment utiliser les tableaux de lignes des objets (lignes de factures, commandes, etc...). Vous devez créer un tableau dans le document et utiliser une balise "begin" et "end" pour définir la ligne du tableau. Cette ligne sera répétée autant de fois que requis au moment de la génération.<br />
<pre><br />
[!-- BEGIN row.lines --]<br />
...<br />
[!-- END row.lines --]<br />
</pre><br />
<br />
Ensuite, ajouter les tags de votre choix dans les lignes parmi ceux-ci:<br />
{{TagsOdtLines}}<br />
<br />
Voici un exemple de ce que vous pourriez avoir dans votre traitement de texte:<br />
[[File:Line for document generation.png|500px]]<br />
<br />
=== Substitution conditionnelle ===<br />
<br />
Vous pouvez utiliser des '''remplacements conditionnels''', ce qui en termes simples signifie que vous pouvez décider d'imprimer quelque chose si une variable est vrai, ou imprimer autre chose si elle est fausse (ou rien du tout) - et cela marche non seulement avec du texte, mais aussi toute structure plus complexe comme les tableaux et les images.<br />
<br />
Exemple:<br />
<pre><br />
[!-- IF {my_var} --]<br />
Print this text if {my_var} is true (can be any value but null/0/empty string)<br />
[!-- ELSE {my_var} --]<br />
Or print this if it's false (null/0/empty string)<br />
[!-- ENDIF {my_var} --]<br />
</pre><br />
<br />
Note: le tag ELSE est bien sûr optionnel, vous pouvez sans problème juste utiliser un IF/ENDIF si vous préférez.<br />
<br />
ATTENTION: le format de cette balise spéciale est très précis et pointilleux, faire attention à '''mettre un seul espace''' entre:<br />
* [!--<br />
* IF/ELSE/ENDIF<br />
* {my var}<br />
* --]<br />
<br />
=== Autres tags personnalisés ===<br />
Si vous voulez ajouter un champ de substitution non prédéfini, il y a une solution:<br />
* Ajouter un fichier nommé <br />
'''htdocs/monmodule/core/substitutions/functions_mymodule.lib.php'''<br />
* Dans ce fichier , écrivez juste une fonction du genre:<br />
<source lang="php"><br />
/** Function called to complete substitution array (before generating on ODT, or a personalized email)<br />
* functions xxx_completesubstitutionarray are called by make_substitutions() if file<br />
* is inside directory htdocs/core/substitutions<br />
* <br />
* @param array $substitutionarray Array with substitution key=>val<br />
* @param Translate $langs Output langs<br />
* @param Object $object Object to use to get values<br />
* @return void The entry parameter $substitutionarray is modified<br />
*/<br />
function mymodule_completesubstitutionarray(&$substitutionarray,$langs,$object)<br />
{<br />
global $conf,$db;<br />
<br />
$myvalue='Put here calculated value to insert';<br />
$substitutionarray['myowntag']=$myvalue;<br />
}<br />
</source><br />
<br />
La fonction sera appelée avant la génération du document afin de compléter le tableau des substitutions afin que le tag '''myowntag''' soit remplacé par la valeur définie dans '''$myvalue'''.<br />
Vous pouvez ajouter autant de tag que désiré, et mettre le code que vous voulez pour définir les valeurs (recherche en base, en fichier, calcul, partir des variables reçues ou globales...).<br />
<br />
Attention: Le premier paramètre dans la déclaration de la fonction doit commencer par & car il est modifié par le code et doit être retourné modifié. <br />
<br />
Pour que vote votre fonction de substitution soit bien appelée, il vous faut:<br />
* Vérifier que votre fichier de substitution est bien stocké dans le répertoire '''htdocs/mymodule/core/substitutions'''<br />
* Créer un module (Voir la page [[Développement module]]) avec son fichier descripteur de module.<br />
* Vérifier que le fichier descripteur de module contient une entrée pour déclarer qu'il y a un fichier de substitution à appeler. Cette doit être <br />
<source lang="php"><br />
$this->module_parts = array('substitutions' => 1)<br />
</source><br />
* Activer le module (un module doit être activé et désactivé pour prendre en compte les changement dans son fichier descripteur)<br />
<br />
=== Autres tags personnalisées pour les lignes ===<br />
<br />
Cette fonctionnalité est disponible depuis Dolibarr v3.3 (version de développement futur).<br />
<br />
De manière similaire au chapitre précédent, vous devez définir une fonction de la même façon mais avec quelques différences:<br />
<br />
* Créez ou modifiez le même fichier que précédemment (voir le chapitre précédent).<br />
* Voici les différences: dans le fichier, écrire une autre fonction avec presque le même nom mais avec '_lines' en suffixe, et également ajouter une nouvelle variable $lines:<br />
<br />
<source lang="php"><br />
/** Function called to complete substitution array for lines (before generating on ODT, or a personalized email)<br />
* functions xxx_completesubstitutionarray_lines are called by make_substitutions() if file<br />
* is inside directory htdocs/core/substitutions<br />
* <br />
* @param array $substitutionarray Array with substitution key=>val<br />
* @param Translate $langs Output langs<br />
* @param Object $object Object to use to get values<br />
* @param Object $line Current line being processed, use this object to get values<br />
* @return void The entry parameter $substitutionarray is modified<br />
*/<br />
function mymodule_completesubstitutionarray_lines(&$substitutionarray,$langs,$object,$line) {<br />
{<br />
global $conf,$db;<br />
<br />
$myvalue='Put here calculated value to insert';<br />
$substitutionarray['myowntag']=$myvalue;<br />
}<br />
</source><br />
<br />
Contrairement à la fonction précédente qui n'est jamais appelée qu'une seule fois, cette fonction sera appelée à chaque fois qu'une ligne de produit sera traitée, en vous donnant chaque fois un objet $line différent que vous pouvez traiter. Cela vous permet de faire des substitutions de tags différentes pour chaque produit.<br />
<br />
== Enregistrer votre document ==<br />
Pour voir apparaitre votre modèle de document dans la liste des modèles disponibles, placer le dans le sous-répertoire adéquat qui se trouve dans le répertoire '''documents/doctemplates'''</div>Esprit-librehttps://wiki.dolibarr.org/index.php?title=Template:TagsOdtLines&diff=37112Template:TagsOdtLines2017-04-25T12:05:50Z<p>Esprit-libre: </p>
<hr />
<div><pre><br />
{line_fulldesc}<br />
{line_product_ref}<br />
{line_product_label}<br />
{line_desc}<br />
{line_vatrate}<br />
{line_up}<br />
{line_up_locale}<br />
{line_qty}<br />
{line_discount_percent}<br />
{line_price_ht}<br />
{line_price_ht_locale}<br />
{line_price_vat}<br />
{line_price_vat_locale}<br />
{line_price_ttc}<br />
{line_price_ttc_locale}<br />
{line_date_start}<br />
{line_date_start_rfc}<br />
{line_date_end}<br />
{line_date_end_rfc}<br />
<br />
Extra fields:<br />
{line_options_xxx} : Value of extra field (where xxx is code of extra field)<br />
</pre></div>Esprit-librehttps://wiki.dolibarr.org/index.php?title=Cr%C3%A9er_un_mod%C3%A8le_de_document_ODT&diff=37111Créer un modèle de document ODT2017-04-25T12:05:22Z<p>Esprit-libre: </p>
<hr />
<div>{{TemplateDocUtil}}<br />
Cette page décrit comment construire un modèle de document ODT pour utiliser la génération de document ODT.<br />
<br />
Pour savoir comment générer un modèle de document PDF, voir la page [[Créer un modèle de document PDF]].<br />
Créer un modèle PDF requiert des connaissances en programmation PHP mais pas la création de modèles ODT. <br />
<br />
== Prérequis ==<br />
* Dolibarr: 3.1+<br />
* OpenOffice: 3.2+, LibreOffice, ...<br />
<br />
== Créer votre document ==<br />
* Créer un document OpenOffice ou LibreOffice en partant de rien ou en prenant un example fournis. Si vous partez d'un exemple, vous les trouverez installés dans les sous-répertoires du répertoire '''documents/doctemplates'''<br />
* Editer le document en utilisant toutes les fonctions de votre suite bureautique.<br />
Incluer dans votre documents les tags des informations que vous voulez voir. Les tags seront remplacés automatiquement au moment de la génération du document par Dolibarr. La liste des tags disponibles est décrite dans le chapitre suivant.<br />
<br />
[[File:warning.png]] Attention, les tags sont entourés de {} ou [] pour les tableaux ou conditions (voir plus loin) et doivent être tapés d'une traite sous la suite Office (sans retour arrière ou effacement, ni par copié-collé). Dans le cas contraire, la suite Office ajoutera des informations invisibles qui empêche le remplacement.<br />
<br />
== Tags ==<br />
Voici la liste des tags qui seront remplacés par les informations appropriées:<br />
<br />
===Company/foundation information===<br />
{{TagsOdtMyCompany}}<br />
<br />
===Customers, prospects or suppliers information===<br />
{{TagsOdtThirdParty}}<br />
<br />
=== Information utilisateur ===<br />
{{TagsOdtUser}}<br />
<br />
=== Autres informations ===<br />
{{TagsOdtOther}}<br />
<br />
===Informations sur l'objet (facture, proposition commerciale, commande, ...)===<br />
{{TagsOdtObjects}}<br />
<br />
===Lignes des objets===<br />
Voici comment utiliser les tableaux de lignes des objets (lignes de factures, commandes, etc...). Vous devez créer un tableau dans le document et utiliser une balise "begin" et "end" pour définir la ligne du tableau. Cette ligne sera répétée autant de fois que requis au moment de la génération.<br />
<pre><br />
[!-- BEGIN row.lines --]<br />
...<br />
[!-- END row.lines --]<br />
</pre><br />
<br />
Ensuite, ajouter les tags de votre choix dans les lignes parmi ceux-ci:<br />
{{TagsOdtLines}}<br />
<br />
Voici un exemple de ce que vous pourriez avoir dans votre traitement de texte:<br />
[[File:Line for document generation.png|500px]]<br />
<br />
=== Substitution conditionnelle ===<br />
<br />
Vous pouvez utiliser des '''remplacements conditionnels''', ce qui en termes simples signifie que vous pouvez décider d'imprimer quelque chose si une variable est vrai, ou imprimer autre chose si elle est fausse (ou rien du tout) - et cela marche non seulement avec du texte, mais aussi toute structure plus complexe comme les tableaux et les images.<br />
<br />
Exemple:<br />
<pre><br />
[!-- IF {my_var} --]<br />
Print this text if {my_var} is true (can be any value but null/0/empty string)<br />
[!-- ELSE {my_var} --]<br />
Or print this if it's false (null/0/empty string)<br />
[!-- ENDIF {my_var} --]<br />
</pre><br />
<br />
Note: le tag ELSE est biensûr optionnel, vous pouvez sans problème juste utiliser un IF/ENDIF si vous préférez.<br />
<br />
ATTENTION: le format de cette balise spéciale est très précis et pointilleux, faire attention à '''mettre un seul espace''' entre:<br />
* [!--<br />
* IF/ELSE/ENDIF<br />
* {my var}<br />
* --]<br />
<br />
=== Autres tags personnalisés ===<br />
Si vous voulez ajouter un champ de substitution non prédéfini, il y a une solution:<br />
* Ajouter un fichier nommé <br />
'''htdocs/monmodule/core/substitutions/functions_mymodule.lib.php'''<br />
* Dans ce fichier , écrivez juste une fonction du genre:<br />
<source lang="php"><br />
/** Function called to complete substitution array (before generating on ODT, or a personalized email)<br />
* functions xxx_completesubstitutionarray are called by make_substitutions() if file<br />
* is inside directory htdocs/core/substitutions<br />
* <br />
* @param array $substitutionarray Array with substitution key=>val<br />
* @param Translate $langs Output langs<br />
* @param Object $object Object to use to get values<br />
* @return void The entry parameter $substitutionarray is modified<br />
*/<br />
function mymodule_completesubstitutionarray(&$substitutionarray,$langs,$object)<br />
{<br />
global $conf,$db;<br />
<br />
$myvalue='Put here calculated value to insert';<br />
$substitutionarray['myowntag']=$myvalue;<br />
}<br />
</source><br />
<br />
La fonction sera appelée avant la génération du document afin de compléter le tableau des substitutions afin que le tag '''myowntag''' soit remplacé par la valeur définie dans '''$myvalue'''.<br />
Vous pouvez ajouter autant de tag que désiré, et mettre le code que vous voulez pour définir les valeurs (recherche en base, en fichier, calcul, partir des variables reçues ou globales...).<br />
<br />
Attention: Le premier paramètre dans la déclaration de la fonction doit commencer par & car il est modifié par le code et doit être retourné modifié. <br />
<br />
Pour que vote votre fonction de substitution soit bien appelée, il vous faut:<br />
* Vérifier que votre fichier de substitution est bien stocké dans le répertoire '''htdocs/mymodule/core/substitutions'''<br />
* Créer un module (Voir la page [[Développement module]]) avec son fichier descripteur de module.<br />
* Vérifier que le fichier descripteur de module contient une entrée pour déclarer qu'il y a un fichier de substitution à appeler. Cette doit être <br />
<source lang="php"><br />
$this->module_parts = array('substitutions' => 1)<br />
</source><br />
* Activer le module (un module doit être activé et désactivé pour prendre en compte les changement dans son fichier descripteur)<br />
<br />
=== Autres tags personnalisées pour les lignes ===<br />
<br />
Cette fonctionnalité est disponible depuis Dolibarr v3.3 (version de développement futur).<br />
<br />
De manière similaire au chapitre précédent, vous devez définir une fonction de la même façon mais avec quelques différences:<br />
<br />
* Créez ou modifiez le même fichier que précédemment (voir le chapitre précédent).<br />
* Voici les différences: dans le fichier, écrire une autre fonction avec presque le même nom mais avec '_lines' en suffixe, et également ajouter une nouvelle variable $lines:<br />
<br />
<source lang="php"><br />
/** Function called to complete substitution array for lines (before generating on ODT, or a personalized email)<br />
* functions xxx_completesubstitutionarray_lines are called by make_substitutions() if file<br />
* is inside directory htdocs/core/substitutions<br />
* <br />
* @param array $substitutionarray Array with substitution key=>val<br />
* @param Translate $langs Output langs<br />
* @param Object $object Object to use to get values<br />
* @param Object $line Current line being processed, use this object to get values<br />
* @return void The entry parameter $substitutionarray is modified<br />
*/<br />
function mymodule_completesubstitutionarray_lines(&$substitutionarray,$langs,$object,$line) {<br />
{<br />
global $conf,$db;<br />
<br />
$myvalue='Put here calculated value to insert';<br />
$substitutionarray['myowntag']=$myvalue;<br />
}<br />
</source><br />
<br />
Contrairement à la fonction précédente qui n'est jamais appelée qu'une seule fois, cette fonction sera appelée à chaque fois qu'une ligne de produit sera traitée, en vous donnant chaque fois un objet $line différent que vous pouvez traiter. Cela vous permet de faire des substitutions de tags différentes pour chaque produit.<br />
<br />
== Enregistrer votre document ==<br />
Pour voir apparaitre votre modèle de document dans la liste des modèles disponibles, placer le dans le sous-répertoire adéquat qui se trouve dans le répertoire '''documents/doctemplates'''</div>Esprit-librehttps://wiki.dolibarr.org/index.php?title=Template:TagsOdtObjects&diff=37050Template:TagsOdtObjects2017-04-10T06:50:05Z<p>Esprit-libre: </p>
<hr />
<div><pre><br />
{object_id}<br />
{object_ref}<br />
{object_ref_customer}<br />
{object_ref_supplier}<br />
{object_date}<br />
{object_date_creation}<br />
{object_date_modification}<br />
{object_date_validation}<br />
{object_note_private}<br />
{object_note_public}<br />
or<br />
{object_note}<br />
<br />
Amounts (numeric data):<br />
{object_total_ht}<br />
{object_total_vat}<br />
{object_total_localtax1} (Dolibarr >= 3.5.0)<br />
{object_total_localtax2} (Dolibarr >= 3.5.0)<br />
{object_total_ttc}<br />
{object_total_discount_ht}<br />
{object_total_vat_x} (Dolibarr >= 3.5.0, is vat total for rate x. x can be for example 20, 8.5, 5.99 ...}<br />
<br />
Amounts (in output language format):<br />
{object_total_ht_locale} (Dolibarr >= 3.5.0)<br />
{object_total_vat_locale} (Dolibarr >= 3.5.0)<br />
{object_total_localtax1_locale} (Dolibarr >= 3.5.0)<br />
{object_total_localtax2_locale} (Dolibarr >= 3.5.0)<br />
{object_total_ttc_locale} (Dolibarr >= 3.5.0)<br />
{object_total_discount_ht_locale} (Dolibarr >= 3.5.0)<br />
{object_total_vat_locale_x.x} (Dolibarr >= 3.6.0, is vat total for rate x. x can be for example 20.000, 8.500, 5.990 ...}<br />
<br />
Specific to proposals:<br />
{object_date_end} : End date of validity of proposal<br />
<br />
Specific to order:<br />
{object_date_delivery_planed} (Dolibarr >= 3.4.0)<br />
<br />
Specific to invoices:<br />
{object_date_limit}<br />
{object_payment_mode}<br />
{object_payment_term}<br />
{object_source_invoice_ref}<br />
{object_already_payed} : Amount already payed (numeric)<br />
{object_remain_to_pay} : Remaining to pay amount (numeric)<br />
{object_already_payed_locale} : Amount already payed (output language format)<br />
{object_remain_to_pay_locale} : Remaining to pay amount (output language format)<br />
<br />
Extra fields:<br />
{object_options_xxx} : Value of extra field (where xxx is code of extra field)<br />
</pre></div>Esprit-libre