Page Menu
Home
WickedGov Phorge
Search
Configure Global Search
Log In
Files
F1432228
DropdownInputWidget.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
4 KB
Referenced Files
None
Subscribers
None
DropdownInputWidget.php
View Options
<?php
namespace
OOUI
;
/**
* Dropdown input widget, wrapping a `<select>` element. Intended to be used within a
* OO.ui.FormLayout.
*/
class
DropdownInputWidget
extends
InputWidget
{
use
RequiredElement
;
/**
* HTML `<option>` tags for this widget.
* @var Tag[]
*/
protected
$options
=
[];
/**
* @param array $config Configuration options
* - array[] $config['options'] Array of menu options in the format
* described in DropdownInputWidget::setOptions().
*/
public
function
__construct
(
array
$config
=
[]
)
{
// Parent constructor
parent
::
__construct
(
$config
);
// Traits
$this
->
initializeRequiredElement
(
array_merge
(
[
'indicatorElement'
=>
null
],
$config
)
);
// Initialization
$this
->
setOptions
(
$config
[
'options'
]
??
[]
);
$this
->
addClasses
(
[
'oo-ui-dropdownInputWidget'
,
'oo-ui-dropdownInputWidget-php'
]
);
$this
->
input
->
addClasses
(
[
'oo-ui-indicator-down'
]
);
}
/** @inheritDoc */
protected
function
getInputElement
(
$config
)
{
return
new
Tag
(
'select'
);
}
/** @inheritDoc */
public
function
setValue
(
$value
)
{
$this
->
value
=
$this
->
cleanUpValue
(
$value
);
foreach
(
$this
->
options
as
$opt
)
{
if
(
$opt
->
getAttribute
(
'value'
)
===
$this
->
value
)
{
$opt
->
setAttributes
(
[
'selected'
=>
'selected'
]
);
}
else
{
$opt
->
removeAttributes
(
[
'selected'
]
);
}
}
return
$this
;
}
/**
* Set the options available for this input.
*
* Each element of the `$options` array should be an array with one of the
* following structures:
*
* -# For normal menu items (`label` and `disabled` are optional; if no
* label is provided, the 'data' value will be also used as the label):
* ~~~~~
* [ 'data' => 'optionvalue', 'label' => 'Option Label', 'disabled' => true ]
* ~~~~~
* -# For option groups ('disabled' is optional):
* ~~~~~
* [ 'optgroup' => 'Group Label', 'disabled' => true ]
* ~~~~~
*
* An `optgroup` will contain all subsequent options up until the next
* `optgroup` or the end of the array.
*
* @param array[] $options Array of options in format described above.
* @return $this
*/
public
function
setOptions
(
$options
)
{
$value
=
$this
->
getValue
();
$availableValue
=
null
;
$this
->
options
=
[];
$container
=
$this
->
input
;
// Rebuild the dropdown menu
$this
->
input
->
clearContent
();
foreach
(
$options
as
$opt
)
{
if
(
!
isset
(
$opt
[
'optgroup'
]
)
)
{
$optValue
=
$this
->
cleanUpValue
(
$opt
[
'data'
]
);
$option
=
(
new
Tag
(
'option'
)
)
->
setAttributes
(
[
'value'
=>
$optValue
]
)
->
appendContent
(
$opt
[
'label'
]
??
$optValue
);
// Prefer the previous value, if available, otherwise select the first one
if
(
$value
===
$optValue
||
$availableValue
===
null
)
{
$availableValue
=
$optValue
;
}
$container
->
appendContent
(
$option
);
}
else
{
$option
=
(
new
Tag
(
'optgroup'
)
)
->
setAttributes
(
[
'label'
=>
$opt
[
'optgroup'
]
]
);
$this
->
input
->
appendContent
(
$option
);
$container
=
$option
;
}
// Add disabled attribute if required (both the <option> and
// <optgroup> elements can be disabled).
if
(
$opt
[
'disabled'
]
??
false
)
{
$option
->
setAttributes
(
[
'disabled'
=>
'disabled'
]
);
}
$this
->
options
[]
=
$option
;
}
// Restore the previous value, or reset to something sensible
if
(
$availableValue
!==
null
)
{
$this
->
setValue
(
$availableValue
);
}
return
$this
;
}
/** @inheritDoc */
public
function
getConfig
(
&
$config
)
{
$optionsConfig
=
[];
foreach
(
$this
->
options
as
$option
)
{
if
(
$option
->
getTag
()
!==
'optgroup'
)
{
$label
=
$option
->
content
[
0
];
$data
=
$option
->
getAttribute
(
'value'
);
$optionConfig
=
[
'data'
=>
$data
,
'label'
=>
$label
];
}
else
{
$optgroup
=
$option
->
getAttribute
(
'label'
);
$optionConfig
=
[
'optgroup'
=>
$optgroup
];
}
if
(
$option
->
getAttribute
(
'disabled'
)
)
{
$optionConfig
[
'disabled'
]
=
true
;
}
$optionsConfig
[]
=
$optionConfig
;
}
$config
[
'options'
]
=
$optionsConfig
;
$config
[
'$overlay'
]
=
true
;
return
parent
::
getConfig
(
$config
);
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Sat, May 16, 21:32 (1 d, 7 h)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
37/e2/2b0eac2c292285d3c7f19cf0c574
Default Alt Text
DropdownInputWidget.php (4 KB)
Attached To
Mode
rMWPROD MediaWiki Production
Attached
Detach File
Event Timeline
Log In to Comment