6 class HTMLCheckField
extends HTMLFormField
{
7 public function getInputHTML( $value ) {
8 global $wgUseMediaWikiUIEverywhere;
10 if ( !empty( $this->mParams
['invert'] ) ) {
14 $attr = $this->getTooltipAndAccessKey();
15 $attr['id'] = $this->mID
;
17 $attr +
= $this->getAttributes( [ 'disabled', 'tabindex' ] );
19 if ( $this->mClass
!== '' ) {
20 $attr['class'] = $this->mClass
;
23 $attrLabel = [ 'for' => $this->mID
];
24 if ( isset( $attr['title'] ) ) {
25 // propagate tooltip to label
26 $attrLabel['title'] = $attr['title'];
29 $chkLabel = Xml
::check( $this->mName
, $value, $attr ) .
31 Html
::rawElement( 'label', $attrLabel, $this->mLabel
);
33 if ( $wgUseMediaWikiUIEverywhere ||
$this->mParent
instanceof VFormHTMLForm
) {
34 $chkLabel = Html
::rawElement(
36 [ 'class' => 'mw-ui-checkbox' ],
45 * Get the OOUI version of this field.
47 * @param string $value
48 * @return OOUI\CheckboxInputWidget The checkbox widget.
50 public function getInputOOUI( $value ) {
51 if ( !empty( $this->mParams
['invert'] ) ) {
55 $attr = $this->getTooltipAndAccessKey();
56 $attr['id'] = $this->mID
;
57 $attr['name'] = $this->mName
;
59 $attr +
= OOUI\Element
::configFromHtmlAttributes(
60 $this->getAttributes( [ 'disabled', 'tabindex' ] )
63 if ( $this->mClass
!== '' ) {
64 $attr['classes'] = [ $this->mClass
];
67 $attr['selected'] = $value;
68 $attr['value'] = '1'; // Nasty hack, but needed to make this work
70 return new OOUI\
CheckboxInputWidget( $attr );
74 * For a checkbox, the label goes on the right hand side, and is
75 * added in getInputHTML(), rather than HTMLFormField::getRow()
77 * ...unless OOUI is being used, in which case we actually return
82 public function getLabel() {
83 if ( $this->mParent
instanceof OOUIHTMLForm
) {
86 $this->mParent
instanceof HTMLForm
&&
87 $this->mParent
->getDisplayFormat() === 'div'
96 * Get label alignment when generating field for OOUI.
97 * @return string 'left', 'right', 'top' or 'inline'
99 protected function getLabelAlignOOUI() {
104 * checkboxes don't need a label.
107 protected function needsLabel() {
112 * @param WebRequest $request
116 public function loadDataFromRequest( $request ) {
117 $invert = isset( $this->mParams
['invert'] ) && $this->mParams
['invert'];
119 // GetCheck won't work like we want for checks.
120 // Fetch the value in either one of the two following case:
121 // - we have a valid submit attempt (form was just submitted, or a GET URL forged by the user)
122 // - checkbox name has a value (false or true), ie is not null
123 if ( $this->isSubmitAttempt( $request ) ||
$request->getVal( $this->mName
) !== null ) {
125 ?
!$request->getBool( $this->mName
)
126 : $request->getBool( $this->mName
);
128 return (bool)$this->getDefault();