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

Source for file InputCheckable.php

Documentation is available at InputCheckable.php

  1. <?php
  2. /**
  3.  * Base class for checkboxes and radios
  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: InputCheckable.php,v 1.4 2007/06/30 20:36:00 avb Exp $
  43.  * @link       http://pear.php.net/package/HTML_QuickForm2
  44.  */
  45.  
  46. /**
  47.  * Base class for <input> elements
  48.  */
  49. require_once 'HTML/QuickForm2/Element/Input.php';
  50.  
  51. /**
  52.  * Base class for <input> elements having 'checked' attribute (checkboxes and radios)
  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.     protected $persistent = true;
  62.  
  63.    /**
  64.     * HTML to represent the element in "frozen" state
  65.     * 
  66.     * Array index "checked" contains HTML for element's "checked" state,
  67.     * "unchecked" for not checked
  68.     * @var  array 
  69.     */
  70.     protected $frozenHtml = array(
  71.         'checked'   => 'On',
  72.         'unchecked' => 'Off'
  73.     );
  74.  
  75.    /**
  76.     * Contains options and data used for the element creation
  77.     * - content: Label "glued" to a checkbox or radio
  78.     * @var  array 
  79.     */
  80.     protected $data = array('content' => '');
  81.  
  82.  
  83.    /**
  84.     * Sets the label to be rendered glued to the element
  85.     *
  86.     * This label is returned by {@link __toString()} method with the element's
  87.     * HTML. It is automatically wrapped into the <label> tag.
  88.     *
  89.     * @param    string 
  90.     * @return   HTML_QuickForm2_Element_InputCheckable 
  91.     */
  92.     public function setContent($content)
  93.     {
  94.         $this->data['content'$content;
  95.         return $this;
  96.     }
  97.  
  98.    /**
  99.     * Returns the label that will be "glued" to element's HTML
  100.     *
  101.     * @return   string 
  102.     */
  103.     public function getContent()
  104.     {
  105.         return $this->data['content'];
  106.     }
  107.  
  108.  
  109.     public function setValue($value)
  110.     {
  111.         if ((string)$value == $this->getAttribute('value')) {
  112.             return $this->setAttribute('checked');
  113.         else {
  114.             return $this->removeAttribute('checked');
  115.         }
  116.     }
  117.  
  118.     public function getValue()
  119.     {
  120.         if (!empty($this->attributes['checked']&& empty($this->attributes['disabled'])) {
  121.             return $this->getAttribute('value');
  122.         else {
  123.             return null;
  124.         }
  125.     }
  126.  
  127.     public function __toString()
  128.     {
  129.         if (0 == strlen($this->data['content'])) {
  130.             $label '';
  131.         elseif ($this->frozen{
  132.             $label $this->data['content'];
  133.         else {
  134.             $label '<label for="' htmlspecialchars(
  135.                          $this->getId()ENT_QUOTESself::getOption('charset')
  136.                      '">' $this->data['content''</label>';
  137.         }
  138.         return parent::__toString($label;
  139.     }
  140.  
  141.     public function getFrozenHtml()
  142.     {
  143.         if ($this->getAttribute('checked')) {
  144.             return $this->frozenHtml['checked'$this->getPersistentContent();
  145.         else {
  146.             return $this->frozenHtml['unchecked'];
  147.         }
  148.     }
  149. }
  150. ?>

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