163 Zeilen
		
	
	
	
		
			5,3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			163 Zeilen
		
	
	
	
		
			5,3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Zend Framework
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.txt.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://framework.zend.com/license/new-bsd
 | |
|  * If you did not receive a copy of the license and are unable to
 | |
|  * obtain it through the world-wide-web, please send an email
 | |
|  * to license@zend.com so we can send you a copy immediately.
 | |
|  *
 | |
|  * @category   Zend
 | |
|  * @package    Zend_View
 | |
|  * @subpackage Helper
 | |
|  * @copyright  Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  * @version    $Id$
 | |
|  */
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Abstract class for extension
 | |
|  */
 | |
| require_once 'Zend/View/Helper/FormElement.php';
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Helper to generate a "checkbox" element
 | |
|  *
 | |
|  * @category   Zend
 | |
|  * @package    Zend_View
 | |
|  * @subpackage Helper
 | |
|  * @copyright  Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  */
 | |
| class Zend_View_Helper_FormCheckbox extends Zend_View_Helper_FormElement
 | |
| {
 | |
|     /**
 | |
|      * Default checked/unchecked options
 | |
|      * @var array
 | |
|      */
 | |
|     protected static $_defaultCheckedOptions = array(
 | |
|         'checkedValue'   => '1',
 | |
|         'uncheckedValue' => '0'
 | |
|     );
 | |
| 
 | |
|     /**
 | |
|      * Generates a 'checkbox' element.
 | |
|      *
 | |
|      * @access public
 | |
|      *
 | |
|      * @param string|array $name If a string, the element name.  If an
 | |
|      * array, all other parameters are ignored, and the array elements
 | |
|      * are extracted in place of added parameters.
 | |
|      * @param mixed $value The element value.
 | |
|      * @param array $attribs Attributes for the element tag.
 | |
|      * @return string The element XHTML.
 | |
|      */
 | |
|     public function formCheckbox($name, $value = null, $attribs = null, array $checkedOptions = null)
 | |
|     {
 | |
|         $info = $this->_getInfo($name, $value, $attribs);
 | |
|         extract($info); // name, id, value, attribs, options, listsep, disable
 | |
| 
 | |
|         $checked = false;
 | |
|         if (isset($attribs['checked']) && $attribs['checked']) {
 | |
|             $checked = true;
 | |
|             unset($attribs['checked']);
 | |
|         } elseif (isset($attribs['checked'])) {
 | |
|             $checked = false;
 | |
|             unset($attribs['checked']);
 | |
|         }
 | |
| 
 | |
|         $checkedOptions = self::determineCheckboxInfo($value, $checked, $checkedOptions);
 | |
| 
 | |
|         // is the element disabled?
 | |
|         $disabled = '';
 | |
|         if ($disable) {
 | |
|             $disabled = ' disabled="disabled"';
 | |
|         }
 | |
| 
 | |
|         // XHTML or HTML end tag?
 | |
|         $endTag = ' />';
 | |
|         if (($this->view instanceof Zend_View_Abstract) && !$this->view->doctype()->isXhtml()) {
 | |
|             $endTag= '>';
 | |
|         }
 | |
| 
 | |
|         // build the element
 | |
|         $xhtml = '';
 | |
|         if (!$disable && !strstr($name, '[]')) {
 | |
|             $xhtml = $this->_hidden($name, $checkedOptions['uncheckedValue']);
 | |
|         }
 | |
|         $xhtml .= '<input type="checkbox"'
 | |
|                 . ' name="' . $this->view->escape($name) . '"'
 | |
|                 . ' id="' . $this->view->escape($id) . '"'
 | |
|                 . ' value="' . $this->view->escape($checkedOptions['checkedValue']) . '"'
 | |
|                 . $checkedOptions['checkedString']
 | |
|                 . $disabled
 | |
|                 . $this->_htmlAttribs($attribs)
 | |
|                 . $endTag;
 | |
| 
 | |
|         return $xhtml;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Determine checkbox information
 | |
|      *
 | |
|      * @param  string $value
 | |
|      * @param  bool $checked
 | |
|      * @param  array|null $checkedOptions
 | |
|      * @return array
 | |
|      */
 | |
|     public static function determineCheckboxInfo($value, $checked, array $checkedOptions = null)
 | |
|     {
 | |
|         // Checked/unchecked values
 | |
|         $checkedValue   = null;
 | |
|         $uncheckedValue = null;
 | |
|         if (is_array($checkedOptions)) {
 | |
|             if (array_key_exists('checkedValue', $checkedOptions)) {
 | |
|                 $checkedValue = (string) $checkedOptions['checkedValue'];
 | |
|                 unset($checkedOptions['checkedValue']);
 | |
|             }
 | |
|             if (array_key_exists('uncheckedValue', $checkedOptions)) {
 | |
|                 $uncheckedValue = (string) $checkedOptions['uncheckedValue'];
 | |
|                 unset($checkedOptions['uncheckedValue']);
 | |
|             }
 | |
|             if (null === $checkedValue) {
 | |
|                 $checkedValue = (string) array_shift($checkedOptions);
 | |
|             }
 | |
|             if (null === $uncheckedValue) {
 | |
|                 $uncheckedValue = (string) array_shift($checkedOptions);
 | |
|             }
 | |
|         } elseif ($value !== null) {
 | |
|             $uncheckedValue = self::$_defaultCheckedOptions['uncheckedValue'];
 | |
|         } else {
 | |
|             $checkedValue   = self::$_defaultCheckedOptions['checkedValue'];
 | |
|             $uncheckedValue = self::$_defaultCheckedOptions['uncheckedValue'];
 | |
|         }
 | |
| 
 | |
|         // is the element checked?
 | |
|         $checkedString = '';
 | |
|         if ($checked || ((string) $value === $checkedValue)) {
 | |
|             $checkedString = ' checked="checked"';
 | |
|             $checked = true;
 | |
|         } else {
 | |
|             $checked = false;
 | |
|         }
 | |
| 
 | |
|         // Checked value should be value if no checked options provided
 | |
|         if ($checkedValue == null) {
 | |
|             $checkedValue = $value;
 | |
|         }
 | |
| 
 | |
|         return array(
 | |
|             'checked'        => $checked,
 | |
|             'checkedString'  => $checkedString,
 | |
|             'checkedValue'   => $checkedValue,
 | |
|             'uncheckedValue' => $uncheckedValue,
 | |
|         );
 | |
|     }
 | |
| }
 |