Files
yii2/framework/i18n/Locale.php
Pavel Dovlatov bdb7c64910 Update to https protocol for php.net links (#17168) [skip ci]
* Updated php.net link for some MemCache properties [skip ci]

* Changed protocol to https for links to php.net in comments

* Changed protocol to https for links to php.net in code

* Changed www.php.net (http) to secure.php.net (https) in comments

* Changed www.php.net (http) to secure.php.net (https) in code

* Changed protocol to https for links to php.net in UPGRADE.md

* Changed protocol to https for links to pecl.php.net in comments

* Changed us.php.net to secure.php.net (https) in comments

* Changed protocol to https for links to php.net in docs

* Changed www.php.net (http) to secure.php.net (https) in docs

* Changed protocol to https for links to pecl.php.net in docs

* Changed ru/jp.php.net to secure.php.net (https) in docs

Don't sure about russian guide: is this links meant to be for guide on russian, or not?
2019-02-28 13:09:27 +03:00

65 lines
1.6 KiB
PHP

<?php
/**
* @link http://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license http://www.yiiframework.com/license/
*/
namespace yii\i18n;
use Yii;
use yii\base\Component;
use yii\base\InvalidConfigException;
/**
* Locale provides various locale information via convenient methods.
*
* The class requires [PHP intl extension](https://secure.php.net/manual/en/book.intl.php) to be installed.
*
* @property string $currencySymbol This property is read-only.
*
* @since 2.0.14
*/
class Locale extends Component
{
/**
* @var string the locale ID.
* If not set, [[\yii\base\Application::language]] will be used.
*/
public $locale;
/**
* {@inheritdoc}
*/
public function init()
{
if (!extension_loaded('intl')) {
throw new InvalidConfigException('Locale component requires PHP intl extension to be installed.');
}
if ($this->locale === null) {
$this->locale = Yii::$app->language;
}
}
/**
* Returns a currency symbol
*
* @param string $currencyCode the 3-letter ISO 4217 currency code to get symbol for. If null,
* method will attempt using currency code from [[locale]].
* @return string
*/
public function getCurrencySymbol($currencyCode = null)
{
$locale = $this->locale;
if ($currencyCode !== null) {
$locale .= '@currency=' . $currencyCode;
}
$formatter = new \NumberFormatter($locale, \NumberFormatter::CURRENCY);
return $formatter->getSymbol(\NumberFormatter::CURRENCY_SYMBOL);
}
}