TYPO3 API  SVNRelease
NumberViewHelper.php
Go to the documentation of this file.
00001 <?php
00002 
00003 /*                                                                        *
00004  * This script belongs to the FLOW3 package "Fluid".                      *
00005  *                                                                        *
00006  * It is free software; you can redistribute it and/or modify it under    *
00007  * the terms of the GNU Lesser General Public License as published by the *
00008  * Free Software Foundation, either version 3 of the License, or (at your *
00009  * option) any later version.                                             *
00010  *                                                                        *
00011  * This script is distributed in the hope that it will be useful, but     *
00012  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHAN-    *
00013  * TABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser       *
00014  * General Public License for more details.                               *
00015  *                                                                        *
00016  * You should have received a copy of the GNU Lesser General Public       *
00017  * License along with the script.                                         *
00018  * If not, see http://www.gnu.org/licenses/lgpl.html                      *
00019  *                                                                        *
00020  * The TYPO3 project - inspiring people to share!                         *
00021  *                                                                        */
00022 
00023 /**
00024  * Formats a number with custom precision, decimal point and grouped thousands.
00025  * @see http://www.php.net/manual/en/function.number-format.php
00026  *
00027  * = Examples =
00028  *
00029  * <code title="Defaults">
00030  * <f:format.number>423423.234</f:format.number>
00031  * </code>
00032  * <output>
00033  * 423,423.20
00034  * </output>
00035  *
00036  * <code title="With all parameters">
00037  * <f:format.number decimals="1" decimalSeparator="," thousandsSeparator=".">423423.234</f:format.number>
00038  * </code>
00039  * <output>
00040  * 423.423,2
00041  * </output>
00042  *
00043  * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
00044  * @api
00045  */
00046 class Tx_Fluid_ViewHelpers_Format_NumberViewHelper extends Tx_Fluid_Core_ViewHelper_AbstractViewHelper {
00047 
00048     /**
00049      * Format the numeric value as a number with grouped thousands, decimal point and
00050      * precision.
00051      *
00052      * @param int $decimals The number of digits after the decimal point
00053      * @param string $decimalSeparator The decimal point character
00054      * @param string $thousandsSeparator The character for grouping the thousand digits
00055      * @return string The formatted number
00056      * @author Christopher Hlubek <hlubek@networkteam.com>
00057      * @author Bastian Waidelich <bastian@typo3.org>
00058      * @api
00059      */
00060     public function render($decimals = 2, $decimalSeparator = '.', $thousandsSeparator = ',') {
00061         $stringToFormat = $this->renderChildren();
00062         return number_format($stringToFormat, $decimals, $decimalSeparator, $thousandsSeparator);
00063     }
00064 }
00065 ?>