3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
7 * This program is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU Affero General Public License version 3 as published by the
9 * Free Software Foundation with the addition of the following permission added
10 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
14 * This program is distributed in the hope that it will be useful, but WITHOUT
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
19 * You should have received a copy of the GNU Affero General Public License along with
20 * this program; if not, see http://www.gnu.org/licenses or write to the Free
21 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
27 * The interactive user interfaces in modified source and object code versions
28 * of this program must display Appropriate Legal Notices, as required under
29 * Section 5 of the GNU Affero General Public License version 3.
31 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32 * these Appropriate Legal Notices must retain the display of the "Powered by
33 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34 * technical reasons, the Appropriate Legal Notices must display the words
35 * "Powered by SugarCRM".
36 ********************************************************************************/
39 require_once('include/SugarFields/Fields/Float/SugarFieldFloat.php');
41 class SugarFieldCurrency extends SugarFieldFloat
44 public function getListViewSmarty($parentFieldArray, $vardef, $displayParams, $col)
46 global $locale, $current_user;
48 $this->setup($parentFieldArray, $vardef, $displayParams, $tabindex, false);
52 $amount = $parentFieldArray[strtoupper($vardef['name'])];
53 $currencyId = isset($parentFieldArray['CURRENCY_ID']) ? $parentFieldArray['CURRENCY_ID'] : "";
54 $currencySymbol = isset($parentFieldArray['CURRENCY_SYMBOL']) ? $parentFieldArray['CURRENCY_SYMBOL'] : "";
56 if (empty($currencyId)) {
57 $currencyId = $locale->getPrecedentPreference('currency');
60 if (empty($currencySymbol)) {
61 $currencySymbol = $locale->getPrecedentPreference('default_currency_symbol');
64 if (stripos($vardef['name'], '_USD')) {
65 $userCurrencyId = $current_user->getPreference('currency');
66 if (!empty($userCurrencyId) && $currencyUSD !== $userCurrencyId) {
67 $userCurrency = BeanFactory::getBean('Currencies', $userCurrencyId);
68 $currencyId = $userCurrency->id;
69 $currencySymbol = $userCurrency->symbol;
70 $amount = $userCurrency->convertFromDollar($amount, 6);
72 $currencyId = $currencyUSD;
73 $currencySymbol = $locale->getPrecedentPreference('default_currency_symbol');
77 $this->ss->assign('currency_id', $currencyId);
78 $this->ss->assign('currency_symbol', $currencySymbol);
79 $this->ss->assign('amount', $amount);
81 return $this->fetch($this->findTemplate('ListView'));
85 * @see SugarFieldBase::importSanitize()
87 public function importSanitize(
91 ImportFieldSanitize $settings
94 $value = str_replace($settings->currency_symbol,"",$value);
96 return $settings->float($value,$vardef,$focus);
100 * format the currency field based on system locale values for currency
101 * Note that this may be different from the precision specified in the vardefs.
102 * @param string $rawfield value of the field
103 * @param string $somewhere vardef for the field being processed
104 * @return number formatted according to currency settings
106 public function formatField($rawField, $vardef)
108 // for currency fields, use the user or system precision, not the precision in the vardef
109 //this is achived by passing in $precision as null
111 if ( $rawField === '' || $rawField === NULL ) {
114 return format_number($rawField, $precision, $precision);