135 Zeilen
		
	
	
		
			Kein EOL
		
	
	
		
			4,6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			135 Zeilen
		
	
	
		
			Kein EOL
		
	
	
		
			4,6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Zend Framework
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.txt.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://framework.zend.com/license/new-bsd
 | |
|  * If you did not receive a copy of the license and are unable to
 | |
|  * obtain it through the world-wide-web, please send an email
 | |
|  * to license@zend.com so we can send you a copy immediately.
 | |
|  *
 | |
|  * @category    ZendX
 | |
|  * @package     ZendX_JQuery
 | |
|  * @subpackage  View
 | |
|  * @copyright  Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license     http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  * @version     $Id$
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @see Zend_Registry
 | |
|  */
 | |
| require_once "Zend/Registry.php";
 | |
| 
 | |
| /**
 | |
|  * @see ZendX_JQuery_View_Helper_UiWidget
 | |
|  */
 | |
| require_once "ZendX/JQuery/View/Helper/UiWidget.php";
 | |
| 
 | |
| /**
 | |
|  * jQuery Date Picker View Helper
 | |
|  *
 | |
|  * @uses 	   Zend_View_Helper_FormText
 | |
|  * @package    ZendX_JQuery
 | |
|  * @subpackage View
 | |
|  * @copyright  Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  */
 | |
| class ZendX_JQuery_View_Helper_DatePicker extends ZendX_JQuery_View_Helper_UiWidget
 | |
| {
 | |
|     /**
 | |
|      * Create a jQuery UI Widget Date Picker
 | |
|      *
 | |
|      * @link   http://docs.jquery.com/UI/Datepicker
 | |
|      * @param  string $id
 | |
|      * @param  string $value
 | |
|      * @param  array  $params jQuery Widget Parameters
 | |
|      * @param  array  $attribs HTML Element Attributes
 | |
|      * @return string
 | |
|      */
 | |
|     public function datePicker($id, $value = null, array $params = array(), array $attribs = array())
 | |
|     {
 | |
|         $attribs = $this->_prepareAttributes($id, $value, $attribs);
 | |
| 
 | |
|         if(!isset($params['dateFormat']) && Zend_Registry::isRegistered('Zend_Locale')) {
 | |
|             $params['dateFormat'] = self::resolveZendLocaleToDatePickerFormat();
 | |
|         }
 | |
| 
 | |
|         // TODO: Allow translation of DatePicker Text Values to get this action from client to server
 | |
|         $params = ZendX_JQuery::encodeJson($params);
 | |
| 
 | |
|         $js = sprintf('%s("#%s").datepicker(%s);',
 | |
|                 ZendX_JQuery_View_Helper_JQuery::getJQueryHandler(),
 | |
|                 $attribs['id'],
 | |
|                 $params
 | |
|         );
 | |
| 
 | |
|         $this->jquery->addOnLoad($js);
 | |
| 
 | |
|         return $this->view->formText($id, $value, $attribs);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * A Check for Zend_Locale existance has already been done in {@link datePicker()}
 | |
|      * this function only resolves the default format from Zend Locale to
 | |
|      * a jQuery Date Picker readable format. This function can be potentially buggy
 | |
|      * because of its easy nature and is therefore stripped from the core functionality
 | |
|      * to be easily overriden.
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public static function resolveZendLocaleToDatePickerFormat($format=null)
 | |
|     {
 | |
|         if($format == null) {
 | |
|             $locale = Zend_Registry::get('Zend_Locale');
 | |
|             if( !($locale instanceof Zend_Locale) ) {
 | |
|                 require_once "ZendX/JQuery/Exception.php";
 | |
|                 throw new ZendX_JQuery_Exception("Cannot resolve Zend Locale format by default, no application wide locale is set.");
 | |
|             }
 | |
|             /**
 | |
|              * @see Zend_Locale_Format
 | |
|              */
 | |
|             require_once "Zend/Locale/Format.php";
 | |
|             $format = Zend_Locale_Format::getDateFormat($locale);
 | |
|         }
 | |
| 
 | |
|         $dateFormat = array(
 | |
|             'EEEEE' => 'D', 'EEEE' => 'DD', 'EEE' => 'D', 'EE' => 'D', 'E' => 'D',
 | |
|             'MMMM' => 'MM', 'MMM' => 'M', 'MM' => 'mm', 'M' => 'm',
 | |
|             'YYYYY' => 'yy', 'YYYY' => 'yy', 'YYY' => 'yy', 'YY' => 'y', 'Y' => 'yy',
 | |
|             'yyyyy' => 'yy', 'yyyy' => 'yy', 'yyy' => 'yy', 'yy' => 'y', 'y' => 'yy',
 | |
|             'G' => '', 'e' => '', 'a' => '', 'h' => '', 'H' => '', 'm' => '',
 | |
|             's' => '', 'S' => '', 'z' => '', 'Z' => '', 'A' => '',
 | |
|         );
 | |
| 
 | |
|         $newFormat = "";
 | |
|         $isText = false;
 | |
|         $i = 0;
 | |
|         while($i < strlen($format)) {
 | |
|             $chr = $format[$i];
 | |
|             if($chr == '"' || $chr == "'") {
 | |
|                 $isText = !$isText;
 | |
|             }
 | |
|             $replaced = false;
 | |
|             if($isText == false) {
 | |
|                 foreach($dateFormat AS $zl => $jql) {
 | |
|                     if(substr($format, $i, strlen($zl)) == $zl) {
 | |
|                         $chr = $jql;
 | |
|                         $i += strlen($zl);
 | |
|                         $replaced = true;
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|             if($replaced == false) {
 | |
|                 $i++;
 | |
|             }
 | |
|             $newFormat .= $chr;
 | |
|         }
 | |
| 
 | |
|         return $newFormat;
 | |
|     }
 | |
| } |