我已经扩展Zend_Currency
并覆盖了getName()
andgetSymbol()
方法,以便它们(就像Zend_Currency
我们不想要的语言环境更改时一样......)Zend_Locale_Data
每次我发出请求时都返回“新鲜”数据。
在下面的示例类中,您可以创建一个实例Default_Model_Currency()
并将“货币”选项设置为任何有效货币(例如欧元、美元等),同时保持相同的语言环境。
<?php
/*
* Currency class extends Zend_Currency with exchange
* functionality using the Exchange_Service
*
* @author HF Bonnet
*/
class Default_Model_Currency extends Zend_Currency
{
/*
* Precision to round currency values with, the
* default precision is 0
*/
private $_precision = 0;
/*
* Set the currency's precision
*
* @attribute int $precision
* @return Default_Model_Currency
*/
public function setPrecision($precision)
{
$validator = new Zend_Validator_Digits();
if ($validator->isValid($precision))
$this->_precision = $precision;
return $this;
}
/*
* Becouse of problems with zend_currency I've choosen
* to override __toString
*/
public function __toString()
{
return sprintf(
'%s %s',
$this->getShortName(),
$this->getValue()
);
}
/*
* Get the full name from a currency, this method is overwitten
* to support the changing of currency without changing the locale
*
* @param string $currency (Optional) Currency name
* @param string|Zend_Locale $locale
* @return string $name
*/
public function getName($currency = null, $locale = null)
{
return Zend_Locale_Data::getContent(
null,
'nametocurrency',
$this->getShortName()
);
}
/*
* Get the full name from a currency, this method is overwitten
* to support the changing of a locale
*
* @param string $currency (Optional) Currency name
* @param string|Zend_Locale $locale
* @return string $name
*/
public function getSymbol($currency = null, $locale = null)
{
return Zend_Locale_Data::getContent(
null,
'currencysymbol',
$this->getShortName()
);
}
/*
* Get the localized value from the currency
*
* @return string $value
*/
public function getLocalizedValue()
{
return Zend_Locale_Format::toNumber(
parent::getValue(),
array(
'precision' => $this->_precision,
'locale' => $this->getLocale()
)
);
}
/*
* Get the default valuta. First checks in the Zend_Registry
* for the default valuta, if not found it is fetched from the
* database.
*
* @return string $defaultCurrency
*/
public function getDefaultValuta()
{
$currency = Zend_Registry::get('currency');
if (!isset($currency['default'])):
$className = Zend_Registry::get('prefix')->services . 'Registry';
$currency['default'] = $className::getInstance()
->getDb('currencyValuta')
->getDefaultValuta()
->getIso();
Zend_Registry::set(
'currency', $currency
);
endif;
return $currency['default'];
}
/*
* Exchanges the currency using the rates found in the
* exchange service.
*
* @attribute string $to
* @return Default_Model_Currency
*/
public function exchange($to)
{
if ($to === $this->getShortName())
return $this;
$currencyTo = new Default_Model_Currency(
array(
'value' => 0,
'currency' => $to,
'precision' => $this->_precision
)
);
// Set the exchange service
$currencyTo->setService(
$this->getExchangeService()
);
return $currencyTo->add($this);
}
/*
* Get an Default_Model_Settings instance
*
* @return Default_Model_Settings
*/
public function getExchangeService()
{
$className = Zend_Registry::get('prefix')->services . 'Exchange';
return $className::getInstance();
}
}