Namespaces

  • Latte
    • Loaders
    • Macros
    • Runtime
  • Nette
    • Application
      • Responses
      • Routers
      • UI
    • Bridges
      • ApplicationDI
      • ApplicationLatte
      • ApplicationTracy
      • CacheDI
      • CacheLatte
      • DatabaseDI
      • DatabaseTracy
      • DITracy
      • FormsDI
      • FormsLatte
      • Framework
      • HttpDI
      • HttpTracy
      • MailDI
      • ReflectionDI
      • SecurityDI
      • SecurityTracy
    • Caching
      • Storages
    • ComponentModel
    • Database
      • Conventions
      • Drivers
      • Table
    • DI
      • Config
        • Adapters
      • Extensions
    • Forms
      • Controls
      • Rendering
    • Http
    • Iterators
    • Loaders
    • Localization
    • Mail
    • Neon
    • PhpGenerator
    • Reflection
    • Security
    • Utils
  • none
  • Tracy
    • Bridges
      • Nette

Classes

  • BaseControl
  • Button
  • Checkbox
  • CheckboxList
  • ChoiceControl
  • CsrfProtection
  • HiddenField
  • ImageButton
  • MultiChoiceControl
  • MultiSelectBox
  • RadioList
  • SelectBox
  • SubmitButton
  • TextArea
  • TextBase
  • TextInput
  • UploadControl
  • Overview
  • Namespace
  • Class
  • Tree
  • Deprecated
  1: <?php
  2: 
  3: /**
  4:  * This file is part of the Nette Framework (https://nette.org)
  5:  * Copyright (c) 2004 David Grudl (https://davidgrudl.com)
  6:  */
  7: 
  8: namespace Nette\Forms\Controls;
  9: 
 10: use Nette;
 11: use Nette\Utils\Html;
 12: 
 13: 
 14: /**
 15:  * Set of radio button controls.
 16:  *
 17:  * @property-read Html $separatorPrototype
 18:  * @property-read Html $containerPrototype
 19:  * @property-read Html $itemLabelPrototype
 20:  */
 21: class RadioList extends ChoiceControl
 22: {
 23:     /** @var bool */
 24:     public $generateId = FALSE;
 25: 
 26:     /** @var Html  separator element template */
 27:     protected $separator;
 28: 
 29:     /** @var Html  container element template */
 30:     protected $container;
 31: 
 32:     /** @var Html  item label template */
 33:     protected $itemLabel;
 34: 
 35: 
 36:     /**
 37:      * @param  string  label
 38:      * @param  array   options from which to choose
 39:      */
 40:     public function __construct($label = NULL, array $items = NULL)
 41:     {
 42:         parent::__construct($label, $items);
 43:         $this->control->type = 'radio';
 44:         $this->container = Html::el();
 45:         $this->separator = Html::el('br');
 46:         $this->itemLabel = Html::el();
 47:         $this->setOption('type', 'radio');
 48:     }
 49: 
 50: 
 51:     /**
 52:      * Generates control's HTML element.
 53:      * @return Html
 54:      */
 55:     public function getControl()
 56:     {
 57:         $input = parent::getControl();
 58:         $items = $this->getItems();
 59:         $ids = [];
 60:         if ($this->generateId) {
 61:             foreach ($items as $value => $label) {
 62:                 $ids[$value] = $input->id . '-' . $value;
 63:             }
 64:         }
 65: 
 66:         return $this->container->setHtml(
 67:             Nette\Forms\Helpers::createInputList(
 68:                 $this->translate($items),
 69:                 array_merge($input->attrs, [
 70:                     'id:' => $ids,
 71:                     'checked?' => $this->value,
 72:                     'disabled:' => $this->disabled,
 73:                     'data-nette-rules:' => [key($items) => $input->attrs['data-nette-rules']],
 74:                 ]),
 75:                 ['for:' => $ids] + $this->itemLabel->attrs,
 76:                 $this->separator
 77:             )
 78:         );
 79:     }
 80: 
 81: 
 82:     /**
 83:      * Generates label's HTML element.
 84:      * @param  string
 85:      * @return Html
 86:      */
 87:     public function getLabel($caption = NULL)
 88:     {
 89:         return parent::getLabel($caption)->for(NULL);
 90:     }
 91: 
 92: 
 93:     /**
 94:      * @return Html
 95:      */
 96:     public function getControlPart($key = NULL)
 97:     {
 98:         $key = key([(string) $key => NULL]);
 99:         return parent::getControl()->addAttributes([
100:             'id' => $this->getHtmlId() . '-' . $key,
101:             'checked' => in_array($key, (array) $this->value, TRUE),
102:             'disabled' => is_array($this->disabled) ? isset($this->disabled[$key]) : $this->disabled,
103:             'value' => $key,
104:         ]);
105:     }
106: 
107: 
108:     /**
109:      * @return Html
110:      */
111:     public function getLabelPart($key = NULL)
112:     {
113:         return func_num_args()
114:             ? parent::getLabel($this->items[$key])->for($this->getHtmlId() . '-' . $key)
115:             : $this->getLabel();
116:     }
117: 
118: 
119:     /**
120:      * Returns separator HTML element template.
121:      * @return Html
122:      */
123:     public function getSeparatorPrototype()
124:     {
125:         return $this->separator;
126:     }
127: 
128: 
129:     /**
130:      * Returns container HTML element template.
131:      * @return Html
132:      */
133:     public function getContainerPrototype()
134:     {
135:         return $this->container;
136:     }
137: 
138: 
139:     /**
140:      * Returns item label HTML element template.
141:      * @return Html
142:      */
143:     public function getItemLabelPrototype()
144:     {
145:         return $this->itemLabel;
146:     }
147: 
148: }
149: 
Nette 2.4-20161109 API API documentation generated by ApiGen 2.8.0