Options des monnaies

Qu'est ce qui définit une monnaie?

Une monnaie consiste en plusieurs informations. Un nom, une abbréviation et un signe. Chacune de ces informations n'est pertinente à l'affichage que si elle est seule, par exemple il est un peu idiot d'écrire "USD 1.000 $" ou "EUR 1.000 €"

De ce fait,Zend_Currency garde en mémoire l'information pertinente pour la monnaie en cours à l'affichage. Les constantes suivantes sont utilisées:

Informations rendues pour une monnaie
Constante Description
NO_SYMBOL Aucun symbole de représentation de la monnaie
USE_SYMBOL Le symbole de la monnaie sera rendu. Pour l'Euro : '€'
USE_SHORTNAME L'abbréviation sera utilisée pour le rendu visuel. L'Euro aura 'EUR' comme abbréviation par exemple. La plupart des abbréviations tiennent sur 3 caractères.
USE_NAME Le nom complet de la monnaie sera utilisé. Pour le dollar américain : "US Dollar".

Example #1 Sélectionner la description de la monnaie

Imaginons que le client utilise la locale "en_US". Sans autre option, la valeur de monnaie retournée ressemblerait à ceci:

  1. $currency = new Zend_Currency(
  2.     array(
  3.         'value' => 100,
  4.     )
  5. );
  6.  
  7. print $currency; // Pourrait afficher '$ 100'

En donnant des options vous précisez quelle information afficher.

  1. $currency = new Zend_Currency(
  2.     array(
  3.         'value'   => 100,
  4.         'display' => Zend_Currency::USE_SHORTNAME,
  5.     )
  6. );
  7.  
  8. print $currency; // Pourrait retourner 'USD 100'

Sans le paramètre display, le signe de la monnaie sera utilisé lors du rendu visuel. Si la monnaie n'a pas de signe, son abbréviation sera utilisée à la place.

Note: Toutes les monnaies n'ont pas de signe
Toutes les monnaies ne possèdent pas forcément un signe. Ceci signifie que s'il n'y a pas de signe par défaut pour la monnaie, et que vous spécifiez manuellement de rendre un signe, alors le rendu de la monnaie sera nul car le signe serait alors une chaine vide.

Pour changer des options concernant les monnaies, voyez le paragraphe ci-après.

Example #2 Changer la description de la monnaie

Imaginons que le client utilise la locale "en_US". Nous ne voulons pas des paramètres par défaut, mais nous voulons préciser manuellement notre propre description. Ceci s'applique au moyen d'une option simple:

  1. $currency = new Zend_Currency(
  2.     array(
  3.         'value' => 100,
  4.         'name'  => 'Dollar',
  5.     )
  6. );
  7.  
  8. print $currency; // Retournerait 'Dollar 100'

Vous pourriez aussi passer un signe et une abbréviation spécifiques.

  1. $currency = new Zend_Currency(
  2.     array(
  3.         'value'    => 100,
  4.         'symbol' => '$$$',
  5.     )
  6. );
  7.  
  8. print $currency; // Retournerait '$$$ 100'

Note: Paramètres de rendu automatiques
Lorsque vous précisez un nom, une abbréviation ou un signe, alors ces informations seront rendues automatiquement. Cette supposition simplifie les traitements car vous n'avez de ce fait pas à toucher à l'option display.
Ainsi, utiliser l'option sign peut se faire en évitant de toucher à display, nul besoin de passer cette dernière à 'USE_SYMBOL'.


Options des monnaies