Un filtre pour calculer la TVA et formater son affichage

Ce petit filtre a été écrit pour transformer un champ numérique contenant un prix hors taxes, en un champ contenant les prix hors taxes et TTC, bien formatés, avec les séparateurs de milliers et le signe €...

A ajouter dans mes_fonctions :

@define('tvaNormale', 1.196);
@define('tvaReduite', 1.055);

function ttc($ht, $taux='tvaNormale') {
        setlocale(LC_MONETARY, 'fr_FR');
        $taux = constant($taux);
        $ttc = $ht * $taux;
        $ttc = money_format('%i', $ttc);
        $ht  = money_format('%i', $ht);
        $tva = $ht . " HT" . " (" . $ttc . " TTC)";
        $tva = ereg_replace("EUR", "€", $tva);
        return $tva;
}

Utilisation

Dans un champ d’un article SPIP, par exemple #PS, on peut stocker un nombre qui correspond à un prix hors taxes. Ensuite, si on veut l’afficher avec le format défini par le filtre “ttc” il suffit d’appeler la balise #PS avec le filtre : [(#PS|ttc)].

Par défaut ce filtre utilise un taux de TVA à 19,6%, mais grâce à l’astuce de Patrice, il peut accepter le taux de TVA réduite à 5,5%. Pour cela, il suffit d’appeler la balise comme ceci : [(#PRIX_HT|ttc{tvaReduite})].

Explications

-  la 1ère ligne modifie la manière dont le serveur va afficher les données au format monétaire (voir lien)
-  la 3ème ligne calcule le montant TTC avec une TVA à 19,6% (par défaut) ou le taux envoyé en paramètre avec le filte.
-  les 4ème et 5ème lignes appliquent le format aux montants HT et TTC (voir lien)
-  la 6ème ligne génère la chaine qui sera affichée (ici “999,00 € HT (1234.56 € TTC)”
-  la 7ème ligne s’assure que c’est bien le signe “€” qui s’affiche et non pas le code ISO “EUR” (c’est moins joli...).

un exemple en ligne : sur une fiche “formation” du catalogue des formations FinHarmony, en bas, dans la partie “prix”.

updated on 2 October 2019

Discussion

3 discussions

  • Coucou,
    Super utile cette petite fonction.
    Pour moi, il y avait un bug dès qu’on passait au delà de 999 €. J’ai lu que money_format n’est pas définie pour Windows (http://php.net/manual/fr/function.money-format.php).
    J’ai dû remplacer mon code par :

    function ttc($ht, $taux='tvaNormale') {
            $taux = constant($taux);
                    $ht = number_format($ht, 2, '.', '');
            $ttc = $ht * $taux;
                    $ttc = number_format($ttc, 2, '.', '');
            $tva = $ttc;
            return $tva;
    }

    Plusieurs variantes ici.

    Reply to this message

  • 1

    Et hop

    $prix = money_format('%!n €', $prix); // 1 234,57 €

    • Bonjour,

      Merci, mais comment ne pas afficher les décimales ==> 1 234€ ?

      Je sèche lamentablement

    Reply to this message

  • 3

    On pourrait agrémenter ce filtre pour que la tva à 5.5% puisse également être appelée...

    peut-être comme ceci (non testé) :

    @define('tva1', 1.196);
    @define('tva2', 1.055);
    
    function ttc($ht, $taux='tva1') {
            setlocale(LC_MONETARY, 'fr_FR');
            $taux = constant($taux);
            $ttc = $ht * $taux;
            $ttc = money_format('%i', $ttc);
            $ht  = money_format('%i', $ht);
            $tva = $ht . " HT" . " (" . $ttc . " TTC)";
            $tva = ereg_replace("EUR", "€", $tva);
            return $tva;
    }

    Utilisation : [(#PS|ttc)] ou [(#PS|ttc{tva2})]

    • un spipeur

      Salut Pat, une petite question:
      Au fait pourquoi le @ ?
      Je le vois parfois, mais j’aimerais comprendre à quoi cela sert ?

    • Le @ sert à éviter les erreurs ou les warnings (cf : http://fr3.php.net/manual/fr/langua...).

      La fonction define() ne peut être appelée qu’une seule fois. Cette syntaxe permet donc aux utilisateurs qui le souhaitent, de définir (à l’avance) dans leurs squelettes leurs propres constantes (avec leurs propres taux de tva), sans toucher aux sources de ce filtre. Mais j’avoue que c’est un cas d’école ici.

    • Salut Patrice,

      Tes améliorations ont été testées avec succès, ça marche super bien !

      Du coup je les intègre au filtre, comme ça, ça profitera à tout le monde.

      A+

      Cyril

    Reply to this message

Comment on this article

Who are you?
  • [Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom