<?php /** * Single checkbox field. * * @package forms * @subpackage fields-basic */ class CheckboxField extends FormField { public function setValue($value) { $this->value = ($value) ? 1 : 0; return $this; } public function dataValue() { return ($this->value) ? 1 : NULL; } public function Value() { return ($this->value) ? 1 : 0; } public function getAttributes() { $attrs = parent::getAttributes(); $attrs['value'] = 1; return array_merge( $attrs, array( 'checked' => ($this->Value()) ? 'checked' : null, 'type' => 'checkbox', ) ); } /** * Returns a readonly version of this field */ public function performReadonlyTransformation() { $field = new CheckboxField_Readonly($this->name, $this->title, $this->value); $field->setForm($this->form); return $field; } } /** * Readonly version of a checkbox field - "Yes" or "No". * * @package forms * @subpackage fields-basic */ class CheckboxField_Readonly extends ReadonlyField { public function performReadonlyTransformation() { return clone $this; } public function Value() { return Convert::raw2xml($this->value ? _t('CheckboxField.YESANSWER', 'Yes') : _t('CheckboxField.NOANSWER', 'No')); } }