getLocale(); } if (null === $currencyCode) { $currencyCode = $this->getCurrencyCode(); } if (null === $showDecimals) { $showDecimals = $this->shouldShowDecimals(); } if (null === $pattern) { $pattern = $this->getCurrencyPattern(); } return $this->formatCurrency($number, $currencyCode, $showDecimals, $locale, $pattern); } /** * Format a number * * @param float $number * @param string $currencyCode * @param bool $showDecimals * @param string $locale * @param string $pattern * @return string */ protected function formatCurrency( $number, $currencyCode, $showDecimals, $locale, $pattern ) { $formatterId = md5($locale); if (!isset($this->formatters[$formatterId])) { $this->formatters[$formatterId] = new NumberFormatter( $locale, NumberFormatter::CURRENCY ); } if ($pattern !== null) { $this->formatters[$formatterId]->setPattern($pattern); } if ($showDecimals) { $this->formatters[$formatterId]->setAttribute(NumberFormatter::FRACTION_DIGITS, 2); } else { $this->formatters[$formatterId]->setAttribute(NumberFormatter::FRACTION_DIGITS, 0); } return $this->formatters[$formatterId]->formatCurrency($number, $currencyCode); } /** * The 3-letter ISO 4217 currency code indicating the currency to use * * @param string $currencyCode * @return CurrencyFormat */ public function setCurrencyCode($currencyCode) { $this->currencyCode = $currencyCode; return $this; } /** * Get the 3-letter ISO 4217 currency code indicating the currency to use * * @return string */ public function getCurrencyCode() { return $this->currencyCode; } /** * Set the currency pattern * * @param string $currencyPattern * @return CurrencyFormat */ public function setCurrencyPattern($currencyPattern) { $this->currencyPattern = $currencyPattern; return $this; } /** * Get the currency pattern * * @return string */ public function getCurrencyPattern() { return $this->currencyPattern; } /** * Set locale to use instead of the default * * @param string $locale * @return CurrencyFormat */ public function setLocale($locale) { $this->locale = (string) $locale; return $this; } /** * Get the locale to use * * @return string|null */ public function getLocale() { if ($this->locale === null) { $this->locale = Locale::getDefault(); } return $this->locale; } /** * Set if the view helper should show two decimals * * @param bool $showDecimals * @return CurrencyFormat */ public function setShouldShowDecimals($showDecimals) { $this->showDecimals = (bool) $showDecimals; return $this; } /** * Get if the view helper should show two decimals * * @return bool */ public function shouldShowDecimals() { return $this->showDecimals; } }