File indexing completed on 2025-01-19 05:21:08

0001 <?php
0002 /**
0003  * Zend Framework
0004  *
0005  * LICENSE
0006  *
0007  * This source file is subject to the new BSD license that is bundled
0008  * with this package in the file LICENSE.txt.
0009  * It is also available through the world-wide-web at this URL:
0010  * http://framework.zend.com/license/new-bsd
0011  * If you did not receive a copy of the license and are unable to
0012  * obtain it through the world-wide-web, please send an email
0013  * to license@zend.com so we can send you a copy immediately.
0014  *
0015  * @category   Zend
0016  * @package    Zend_Filter
0017  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
0018  * @license    http://framework.zend.com/license/new-bsd     New BSD License
0019  * @version    $Id$
0020  */
0021 
0022 /**
0023  * @see Zend_Filter_Interface
0024  */
0025 // require_once 'Zend/Filter/Interface.php';
0026 
0027 /**
0028  * @see Zend_Loader
0029  */
0030 // require_once 'Zend/Locale/Format.php';
0031 
0032 /**
0033  * Normalizes given localized input
0034  *
0035  * @category   Zend
0036  * @package    Zend_Filter
0037  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
0038  * @license    http://framework.zend.com/license/new-bsd     New BSD License
0039  */
0040 class Zend_Filter_LocalizedToNormalized implements Zend_Filter_Interface
0041 {
0042     /**
0043      * Set options
0044      * @var array
0045      */
0046     protected $_options = array(
0047         'locale'      => null,
0048         'date_format' => null,
0049         'precision'   => null
0050     );
0051 
0052     /**
0053      * Class constructor
0054      *
0055      * @param string|Zend_Locale $locale (Optional) Locale to set
0056      */
0057     public function __construct($options = null)
0058     {
0059         if ($options instanceof Zend_Config) {
0060             $options = $options->toArray();
0061         }
0062 
0063         if (null !== $options) {
0064             $this->setOptions($options);
0065         }
0066     }
0067 
0068     /**
0069      * Returns the set options
0070      *
0071      * @return array
0072      */
0073     public function getOptions()
0074     {
0075         return $this->_options;
0076     }
0077 
0078     /**
0079      * Sets options to use
0080      *
0081      * @param  array $options (Optional) Options to use
0082      * @return Zend_Filter_LocalizedToNormalized
0083      */
0084     public function setOptions(array $options = null)
0085     {
0086         $this->_options = $options + $this->_options;
0087         return $this;
0088     }
0089 
0090     /**
0091      * Defined by Zend_Filter_Interface
0092      *
0093      * Normalizes the given input
0094      *
0095      * @param  string $value Value to normalized
0096      * @return string|array The normalized value
0097      */
0098     public function filter($value)
0099     {
0100         if (Zend_Locale_Format::isNumber($value, $this->_options)) {
0101             return Zend_Locale_Format::getNumber($value, $this->_options);
0102         } else if (($this->_options['date_format'] === null) && (strpos($value, ':') !== false)) {
0103             // Special case, no date format specified, detect time input
0104             return Zend_Locale_Format::getTime($value, $this->_options);
0105         } else if (Zend_Locale_Format::checkDateFormat($value, $this->_options)) {
0106             // Detect date or time input
0107             return Zend_Locale_Format::getDate($value, $this->_options);
0108         }
0109 
0110         return $value;
0111     }
0112 }