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

Source for file Element.php

Documentation is available at Element.php

  1. <?php
  2. /**
  3.  * Base class for simple HTML_QuickForm2 elements (not Containers)
  4.  *
  5.  * PHP version 5
  6.  *
  7.  * LICENSE:
  8.  * 
  9.  * Copyright (c) 2006, 2007, Alexey Borzov <avb@php.net>,
  10.  *                           Bertrand Mansion <golgote@mamasam.com>
  11.  * All rights reserved.
  12.  *
  13.  * Redistribution and use in source and binary forms, with or without
  14.  * modification, are permitted provided that the following conditions
  15.  * are met:
  16.  *
  17.  *    * Redistributions of source code must retain the above copyright
  18.  *      notice, this list of conditions and the following disclaimer.
  19.  *    * Redistributions in binary form must reproduce the above copyright
  20.  *      notice, this list of conditions and the following disclaimer in the
  21.  *      documentation and/or other materials provided with the distribution.
  22.  *    * The names of the authors may not be used to endorse or promote products
  23.  *      derived from this software without specific prior written permission.
  24.  *
  25.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
  26.  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  27.  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  28.  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  29.  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  30.  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  31.  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  32.  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  33.  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  34.  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  35.  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  36.  *
  37.  * @category   HTML
  38.  * @package    HTML_QuickForm2
  39.  * @author     Alexey Borzov <avb@php.net>
  40.  * @author     Bertrand Mansion <golgote@mamasam.com>
  41.  * @license    http://opensource.org/licenses/bsd-license.php New BSD License
  42.  * @version    CVS: $Id: Element.php,v 1.12 2007/06/30 20:36:00 avb Exp $
  43.  * @link       http://pear.php.net/package/HTML_QuickForm2
  44.  */
  45.  
  46. /**
  47.  * Base class for all HTML_QuickForm2 elements
  48.  */
  49. require_once 'HTML/QuickForm2/Node.php';
  50.  
  51. /**
  52.  * Abstract base class for simple QuickForm2 elements (not Containers)
  53.  *
  54.  * @category   HTML
  55.  * @package    HTML_QuickForm2
  56.  * @author     Alexey Borzov <avb@php.net>
  57.  * @author     Bertrand Mansion <golgote@mamasam.com>
  58.  * @version    Release: 0.2.0
  59.  */
  60. {
  61.    /**
  62.     * 'name' and 'id' attributes should be always present and their setting
  63.     * should go through setName() and setId().
  64.     * @var array 
  65.     */
  66.     protected $watchedAttributes = array('id''name');
  67.  
  68.     protected function onAttributeChange($name$value = null)
  69.     {
  70.         if ('name' == $name{
  71.             if (null === $value{
  72.                 throw new HTML_QuickForm2_InvalidArgumentException(
  73.                     "Required attribute 'name' can not be removed"
  74.                 );
  75.             else {
  76.                 $this->setName($value);
  77.             }
  78.         elseif ('id' == $name{
  79.             if (null === $value{
  80.                 throw new HTML_QuickForm2_InvalidArgumentException(
  81.                     "Required attribute 'id' can not be removed"
  82.                 );
  83.             else {
  84.                 $this->setId($value);
  85.             }
  86.         }
  87.     }
  88.  
  89.     public function getName()
  90.     {
  91.         return $this->attributes['name'];
  92.     }
  93.  
  94.     public function setName($name)
  95.     {
  96.         $this->attributes['name'= (string)$name;
  97.         $this->updateValue();
  98.         return $this;
  99.     }
  100.  
  101.     public function getId()
  102.     {
  103.         return isset($this->attributes['id'])$this->attributes['id']: null;
  104.     }
  105.  
  106.     public function setId($id = null)
  107.     {
  108.         if (is_null($id)) {
  109.             $id = self::generateId($this->getName());
  110.         else {
  111.             self::storeId($id);
  112.         }
  113.         $this->attributes['id'= (string)$id;
  114.         return $this;
  115.     }
  116.  
  117.    /**
  118.     * Generates hidden form field containing the element's value
  119.     *
  120.     * This is used to pass the frozen element's value if 'persistent freeze'
  121.     * feature is on
  122.     *
  123.     * @return string 
  124.     */
  125.     protected function getPersistentContent()
  126.     {
  127.         if (!$this->persistent || null === ($value $this->getValue())) {
  128.             return '';
  129.         }
  130.         return '<input type="hidden"' . self::getAttributesString(array(
  131.             'name'  => $this->getName(),
  132.             'value' => $value,
  133.             'id'    => $this->getId()
  134.         )) ' />';
  135.     }
  136.  
  137.    /**
  138.     * Called when the element needs to update its value from form's data sources
  139.     *
  140.     * The default behaviour is to go through the complete list of the data
  141.     * sources until the non-null value is found.
  142.     */
  143.     protected function updateValue()
  144.     {
  145.         $name $this->getName();
  146.         foreach ($this->getDataSources(as $ds{
  147.             if (null !== ($value $ds->getValue($name))) {
  148.                 $this->setValue($value);
  149.                 return;
  150.             }
  151.         }
  152.     }
  153. }
  154. ?>

Documentation generated on Mon, 22 Oct 2007 12:30:13 -0400 by phpDocumentor 1.4.0. PEAR Logo Copyright © PHP Group 2004.