]> git.llucax.com Git - mecon/meconlib.git/blob - HTML/php/QuickForm/mdate.php
d1aa84d7f986f8daf1694dbd49b7fb4b8ab3684f
[mecon/meconlib.git] / HTML / php / 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
33 /**
34  * Class to dynamically create HTML Select elements from a date
35  * Modificado para que cumpla con los requisitos de mecon
36  *
37  */
38 class HTML_QuickForm_mdate extends HTML_QuickForm_date
39 {   
40     // {{{ constructor
41
42     /**
43      * Class constructor
44      * 
45      * @param     string    $elementName    (optional)Input field name attribute
46      * @param     string    $value          (optional)Input field value
47      * @param     mixed     $attributes     (optional)Either a typical HTML attribute string 
48      *                                      or an associative array. Date format is passed along the attributes.
49      * @access    public
50      * @return    void
51      */
52     function HTML_QuickForm_mdate($elementName=null, $elementLabel=null, $options=array(), $attributes=null)
53     {
54         $this->_options = array ('es' => array (
55                                                'weekdays_short'=> array ('--' => '--', 'Dom', 'Lun', 'Mar', 'Mié', 'Jue', 'Vie', 'Sáb'),
56                                                'weekdays_long' => array ('--' => '--', 'Domingo', 'Lunes', 'Martes', 'Miércoles', 'Jueves', 'Viernes', 'Sábado'),
57                                                'months_short'  => array ('--' => '--', 'Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'),
58                                                'months_long'   => array ('--' => '--', 'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio', 'Agosto', 'Septimbre', 'Octubre', 'Noviembre', 'Diciembre')
59                                 )
60                         );
61                         
62         parent::HTML_QuickForm_date($elementName, $elementLabel, $options, $attributes);
63     } //end constructor
64
65     // }}}
66     // {{{ _createNumericOptionList()
67
68     /**
69      * Creates a numeric option list based on a start number and end number
70      *
71      * @param int $start The start number
72      * @param int $end The end number
73      *
74      * @access public
75      * @return array An array of numeric options.
76      */
77     function _createNumericOptionList($start, $end)
78     {
79         $options = array();
80         //TODO 
81         //Verificar que esto este funcionando bien.
82         $options['--'] = '--';
83         //Hasta aca
84         for ($i = $start; $i <= $end; $i++) {
85             $options[$i] = sprintf('%02d', $i);
86         }
87         
88         return $options;
89         
90     } // end func _createNumericOptionList
91
92     /**
93      * Devuelve un objeto date
94      *
95      *
96      * @access public
97      * @return object Date.
98      */
99     function &getValue()
100     {
101         return new Date (sprintf("%04d/%02d/%02d 00:00:00",$this->_selectedDate['Y'],$this->_selectedDate['F'],$this->_selectedDate['d']));
102     } // end func _createNumericOptionList
103 }
104 ?>