X-Git-Url: https://git.llucax.com/mecon/meconlib.git/blobdiff_plain/cacc1525e7102dfef7964462a50e4ff13f02dcc6..1209440ef94cb8b357936a78c56b9872d4fb5ae5:/lib/MECON/HTML/QuickForm/mdate.php?ds=sidebyside diff --git a/lib/MECON/HTML/QuickForm/mdate.php b/lib/MECON/HTML/QuickForm/mdate.php index de9c54b..a261647 100644 --- a/lib/MECON/HTML/QuickForm/mdate.php +++ b/lib/MECON/HTML/QuickForm/mdate.php @@ -1,31 +1,28 @@ - +------------------------------------------------------------------------------- +$Id$ +-----------------------------------------------------------------------------*/ require_once 'HTML/QuickForm/date.php'; require_once 'Date.php'; @@ -36,8 +33,7 @@ require_once 'Validate.php'; * Modificado para que cumpla con los requisitos de mecon * */ -class HTML_QuickForm_mdate extends HTML_QuickForm_date -{ +class MECON_HTML_QuickForm_mdate extends HTML_QuickForm_date { // {{{ constructor /** @@ -50,17 +46,22 @@ class HTML_QuickForm_mdate extends HTML_QuickForm_date * @access public * @return void */ - function HTML_QuickForm_mdate($elementName=null, $elementLabel=null, $options=array(), $attributes=null) - { + function MECON_HTML_QuickForm_mdate($elementName=null, $elementLabel=null, $options=array(), $attributes=null) { $this->_options = array ('es' => array ( - 'weekdays_short'=> array ('--' => '--', 'Dom', 'Lun', 'Mar', 'Mié', 'Jue', 'Vie', 'Sáb'), - 'weekdays_long' => array ('--' => '--', 'Domingo', 'Lunes', 'Martes', 'Miércoles', 'Jueves', 'Viernes', 'Sábado'), - 'months_short' => array ('--' => '--', 'Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'), - 'months_long' => array ('--' => '--', 'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio', 'Agosto', 'Septimbre', 'Octubre', 'Noviembre', 'Diciembre') - ) - ); - - parent::HTML_QuickForm_date($elementName, $elementLabel, $options, $attributes); + 'weekdays_short'=> array ('' => '--', 'Dom', 'Lun', 'Mar', 'Mié', 'Jue', 'Vie', 'Sáb'), + 'weekdays_long' => array ('' => '--', 'Domingo', 'Lunes', 'Martes', 'Miércoles', 'Jueves', 'Viernes', 'Sábado'), + 'months_short' => array ('' => '--', 'Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'), + 'months_long' => array ('' => '--', + 'Enero', 'Febrero', 'Marzo', + 'Abril', 'Mayo', 'Junio', + 'Julio', 'Agosto', 'Septiembre', + 'Octubre', 'Noviembre', 'Diciembre') + ) + ); + + parent::HTML_QuickForm_date($elementName, $elementLabel, + array_merge(array('language'=>'es','format'=>'d F Y'), $options), + $attributes); } //end constructor // }}} @@ -75,19 +76,18 @@ class HTML_QuickForm_mdate extends HTML_QuickForm_date * @access public * @return array An array of numeric options. */ - function _createNumericOptionList($start, $end) - { + function _createNumericOptionList($start, $end) { $options = array(); - //TODO + //TODO //Verificar que esto este funcionando bien. - $options['--'] = '--'; + $options[''] = '--'; //Hasta aca for ($i = $start; $i <= $end; $i++) { $options[$i] = sprintf('%02d', $i); } - + return $options; - + } // end func _createNumericOptionList /** @@ -97,12 +97,10 @@ class HTML_QuickForm_mdate extends HTML_QuickForm_date * @access public * @return object Date. */ - function &getValue() - { - if ($this->_selectedDate['Y'] != 00) { - return new Date (sprintf("%04d-%02d-%02d 00:00:00",$this->_selectedDate['Y'],$this->_selectedDate['F'],$this->_selectedDate['d'])); - } - else { + function &getValue() { + if ($this->_selectedDate['Y']) { + return new Date (@sprintf("%04d-%02d-%02d 00:00:00", $this->_selectedDate['Y'], $this->_selectedDate['F'], $this->_selectedDate['d'])); + } else { return null; } } // end func getValue @@ -116,12 +114,21 @@ class HTML_QuickForm_mdate extends HTML_QuickForm_date * @access public * @return bool */ - function validate($valor, $nombre, $formato = '') - { - if ($valor['Y'] != '--' && $valor['d'] != '--' && $valor['F'] != '--') { - return Validate::date($valor['Y'].'-'.$valor['d'].'-'.$valor['F'], array('format' => '%Y-%m-%d')); + function validate($valor, $nombre, $formato = '') { + // Si viene completamente lleno, se valida con el paquete Validate. + if ($valor['Y'] and $valor['d'] and $valor['F']) { + $str = sprintf('%4d-%02d-%02d', $valor['Y'], $valor['F'], $valor['d']); + return Validate::date($str, array('format' => '%Y-%m-%d')); + // Si viene completamente vacio, es valido. + } + elseif (!$valor['Y'] and !$valor['d'] and !$valor['F']) { + return true; + // Si viene a medio completar, es invalido. + } + else { + return false; } - return true; } // end func validate } + ?>