]> git.llucax.com Git - mecon/meconlib.git/blob - lib/MECON/HTML/QuickForm/mdate.php
b1fb915a5246ea47f22324e20b7defe4eda45dba
[mecon/meconlib.git] / lib / MECON / HTML / QuickForm / mdate.php
1 <?php
2 /* vim: set expandtab tabstop=4 shiftwidth=4: */
3 // +----------------------------------------------------------------------+
4 // | PHP Version 4                                                        |
5 // +----------------------------------------------------------------------+
6 // | Copyright (c) 1997-2003 The PHP Group                                |
7 // +----------------------------------------------------------------------+
8 // | This source file is subject to version 2.0 of the PHP license,       |
9 // | that is bundled with this package in the file LICENSE, and is        |
10 // | available at through the world-wide-web at                           |
11 // | http://www.php.net/license/2_02.txt.                                 |
12 // | If you did not receive a copy of the PHP license and are unable to   |
13 // | obtain it through the world-wide-web, please send a note to          |
14 // | license@php.net so we can mail you a copy immediately.               |
15 // +----------------------------------------------------------------------+
16 // | Authors: Martin Marrese
17 // | Date: jue jun  5 17:59:44 ART 2003
18 // +----------------------------------------------------------------------+
19 //
20 // $Id$
21 //
22 // $Author$
23 // $URL$
24 // $Date$
25 // $Rev$
26 //
27
28
29
30 require_once 'HTML/QuickForm/date.php';
31 require_once 'Date.php';
32 require_once 'Validate.php';
33
34 /**
35  * Class to dynamically create HTML Select elements from a date
36  * Modificado para que cumpla con los requisitos de mecon
37  *
38  */
39 class HTML_QuickForm_mdate extends HTML_QuickForm_date
40 {   
41     // {{{ constructor
42
43     /**
44      * Class constructor
45      * 
46      * @param     string    $elementName    (optional)Input field name attribute
47      * @param     string    $value          (optional)Input field value
48      * @param     mixed     $attributes     (optional)Either a typical HTML attribute string 
49      *                                      or an associative array. Date format is passed along the attributes.
50      * @access    public
51      * @return    void
52      */
53     function HTML_QuickForm_mdate($elementName=null, $elementLabel=null, $options=array(), $attributes=null)
54     {
55         $this->_options = array ('es' => array (
56                                                'weekdays_short'=> array ('--' => '--', 'Dom', 'Lun', 'Mar', 'Mié', 'Jue', 'Vie', 'Sáb'),
57                                                'weekdays_long' => array ('--' => '--', 'Domingo', 'Lunes', 'Martes', 'Miércoles', 'Jueves', 'Viernes', 'Sábado'),
58                                                'months_short'  => array ('--' => '--', 'Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'),
59                                                'months_long'   => array ('--' => '--', 'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio', 'Agosto', 'Septimbre', 'Octubre', 'Noviembre', 'Diciembre')
60                                 )
61                         );
62                         
63         parent::HTML_QuickForm_date($elementName, $elementLabel, $options, $attributes);
64     } //end constructor
65
66     // }}}
67     // {{{ _createNumericOptionList()
68
69     /**
70      * Creates a numeric option list based on a start number and end number
71      *
72      * @param int $start The start number
73      * @param int $end The end number
74      *
75      * @access public
76      * @return array An array of numeric options.
77      */
78     function _createNumericOptionList($start, $end)
79     {
80         $options = array();
81         //TODO 
82         //Verificar que esto este funcionando bien.
83         $options['--'] = '--';
84         //Hasta aca
85         for ($i = $start; $i <= $end; $i++) {
86             $options[$i] = sprintf('%02d', $i);
87         }
88         
89         return $options;
90         
91     } // end func _createNumericOptionList
92
93     /**
94      * Devuelve un objeto date
95      *
96      *
97      * @access public
98      * @return object Date.
99      */
100     function &getValue()
101     {
102         if ($this->_selectedDate['Y'] != 00) {
103             return new Date (sprintf("%04d-%02d-%02d 00:00:00",$this->_selectedDate['Y'],$this->_selectedDate['F'],$this->_selectedDate['d']));
104         } 
105         else {
106             return null;
107         }
108     } // end func getValue
109
110     /**
111      * Verifica que una fecha sea valida.
112      *
113      * Verifica que una fecha sea valida. El formato siempre debe ser
114      * '%Y-%m-%d'
115      *
116      * @access public
117      * @return bool
118      */
119     function validate($valor, $nombre, $formato = '')
120     {
121         $str = sprintf ("%4d-%02d-%02d",$valor['Y'],$valor['F'],$valor['d']);
122    
123         if (($valor['Y'] != '--' && $valor['d'] != '--' && $valor['F'] != '--') && ($valor['Y'] != '' && $valor['d'] != '' && $valor['F'] != '')) {
124             return  Validate::date($str, array('format' => '%Y-%m-%d'));
125         }
126         return true;
127     } // end func validate
128 }
129 ?>