diff --git a/modules/Vtiger/uitypes/Percentage.php b/modules/Vtiger/uitypes/Percentage.php index 4477d8b916559747370554932f3eb382ae0fcc04..93815bc501f969d5c404dbdcc3955c1d6a56186f 100644 --- a/modules/Vtiger/uitypes/Percentage.php +++ b/modules/Vtiger/uitypes/Percentage.php @@ -21,9 +21,29 @@ class Vtiger_Percentage_UIType extends Vtiger_Base_UIType { public function getDisplayValue($value, $record = false, $recordInstance = false) { $fldvalue = str_replace(",", ".", $value); $value = (is_numeric($fldvalue)) ? $fldvalue : null; - return CurrencyField::convertToUserFormat($value, null, true); + return Vtiger_Percentage_UIType::convertToUserFormat($value, null, true); } + public static function convertToUserFormat($value, $user = null, $skipConversion = false, $skipFormatting = false) { + + if (empty($value)) { + return $value; + } + if (empty($user)) { + $user = Users_Record_Model::getCurrentUserModel(); + } + $old_no_of_currency_decimals = $user->no_of_currency_decimals; + // If decimal separator is "," and no.of decimals is "0" then if we give 8,8 (value:8.8) + // which is becoming round of value i,e "9". + // so by default we are setting no_of_currency_decimals to max value. + $user->no_of_currency_decimals = 5; + + $currencyField = new CurrencyField($value); + $display_value = $currencyField->getDisplayValue($user, $skipConversion, $skipFormatting); + $user->no_of_currency_decimals = $old_no_of_currency_decimals; + return $display_value; + } + public function getEditViewDisplayValue($value) { return $this->getDisplayValue($value); }