| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- <?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;
- }
- }
|