HTML_QuickForm
[ class tree: HTML_QuickForm ] [ index: HTML_QuickForm ] [ all elements ]

Source for file hiddenselect.php

Documentation is available at hiddenselect.php

  1. <?php
  2. /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
  3.  
  4. /**
  5.  * Hidden select pseudo-element
  6.  * 
  7.  * PHP versions 4 and 5
  8.  *
  9.  * LICENSE: This source file is subject to version 3.01 of the PHP license
  10.  * that is available through the world-wide-web at the following URI:
  11.  * http://www.php.net/license/3_01.txt If you did not receive a copy of
  12.  * the PHP License and are unable to obtain it through the web, please
  13.  * send a note to license@php.net so we can mail you a copy immediately.
  14.  *
  15.  * @category    HTML
  16.  * @package     HTML_QuickForm
  17.  * @author      Isaac Shepard <ishepard@bsiweb.com>
  18.  * @copyright   2001-2011 The PHP Group
  19.  * @license     http://www.php.net/license/3_01.txt PHP License 3.01
  20.  * @version     CVS: $Id: hiddenselect.php 317587 2011-10-01 07:55:53Z avb $
  21.  * @link        http://pear.php.net/package/HTML_QuickForm
  22.  */
  23.  
  24. /**
  25.  * Class for <select></select> elements
  26.  */
  27. require_once 'HTML/QuickForm/select.php';
  28.  
  29. /**
  30.  * Hidden select pseudo-element
  31.  *
  32.  * This class takes the same arguments as a select element, but instead
  33.  * of creating a select ring it creates hidden elements for all values
  34.  * already selected with setDefault or setConstant.  This is useful if
  35.  * you have a select ring that you don't want visible, but you need all
  36.  * selected values to be passed.
  37.  *
  38.  * @category    HTML
  39.  * @package     HTML_QuickForm
  40.  * @author      Isaac Shepard <ishepard@bsiweb.com>
  41.  * @version     Release: 3.2.13
  42.  * @since       2.1
  43.  */
  44. {
  45.     // {{{ constructor
  46.         
  47.     /**
  48.      * Class constructor
  49.      * 
  50.      * @param     string    Select name attribute
  51.      * @param     mixed     Label(s) for the select (not used)
  52.      * @param     mixed     Data to be used to populate options
  53.      * @param     mixed     Either a typical HTML attribute string or an associative array (not used)
  54.      * @since     1.0
  55.      * @access    public
  56.      * @return    void 
  57.      */
  58.     function HTML_QuickForm_hiddenselect($elementName=null$elementLabel=null$options=null$attributes=null)
  59.     {
  60.         HTML_QuickForm_element::HTML_QuickForm_element($elementName$elementLabel$attributes);
  61.         $this->_persistantFreeze = true;
  62.         $this->_type 'hiddenselect';
  63.         if (isset($options)) {
  64.             $this->load($options);
  65.         }
  66.     //end constructor
  67.     
  68.     // }}}
  69.     // {{{ toHtml()
  70.  
  71.     /**
  72.      * Returns the SELECT in HTML
  73.      *
  74.      * @since     1.0
  75.      * @access    public
  76.      * @return    string 
  77.      * @throws
  78.      */
  79.     function toHtml()
  80.     {
  81.         if (empty($this->_values)) {
  82.             return '';
  83.         }
  84.  
  85.         $tabs    $this->_getTabs();
  86.         $name    $this->getPrivateName();
  87.         $strHtml '';
  88.  
  89.         foreach ($this->_values as $key => $val{
  90.             for ($i = 0$optCount count($this->_options)$i $optCount$i++{
  91.                 if ($val == $this->_options[$i]['attr']['value']{
  92.                     $strHtml .= $tabs '<input' $this->_getAttrString(array(
  93.                         'type'  => 'hidden',
  94.                         'name'  => $name,
  95.                         'value' => $val
  96.                     )) " />\n" ;
  97.                 }
  98.             }
  99.         }
  100.  
  101.         return $strHtml;
  102.     //end func toHtml
  103.     
  104.     // }}}
  105.     // {{{ accept()
  106.  
  107.    /**
  108.     * This is essentially a hidden element and should be rendered as one
  109.     */
  110.     function accept(&$renderer)
  111.     {
  112.         $renderer->renderHidden($this);
  113.     }
  114.  
  115.     // }}}
  116. //end class HTML_QuickForm_hiddenselect
  117. ?>

Documentation generated on Sat, 01 Oct 2011 09:00:11 +0000 by phpDocumentor 1.4.3. PEAR Logo Copyright © PHP Group 2004.