20 $value = $request->getText( $this->mName, $this->
getDefault() );
22 $tagsArray = explode(
"\n", $value );
24 $tagsArray = array_values( array_filter( $tagsArray,
static function ( $tag ) {
25 return trim( $tag ) !==
'';
28 $uniqueTags = array_unique( $tagsArray );
31 return implode(
"\n", $uniqueTags );
35 if ( $value ===
null ) {
40 $tagsArray = explode(
"\n", $value );
42 if ( isset( $this->mParams[
'max'] ) && ( count( $tagsArray ) > $this->mParams[
'max'] ) ) {
43 return $this->
msg(
'htmlform-multiselect-toomany', $this->mParams[
'max'] );
46 foreach ( $tagsArray as $tag ) {
47 $result = parent::validate( $tag, $alldata );
48 if ( $result !==
true ) {
52 if ( !$this->mParams[
'allowArbitrary'] && $tag ) {
53 $allowedValues = $this->mParams[
'allowedValues'] ?? [];
54 if ( !in_array( $tag, $allowedValues ) ) {
55 return $this->
msg(
'htmlform-tag-not-allowed', $tag )->escaped();
64 $this->mParent->getOutput()->enableOOUI();
71 if ( isset( $this->mParams[
'id'] ) ) {
72 $params[
'id'] = $this->mParams[
'id'];
75 if ( isset( $this->mParams[
'disabled'] ) ) {
76 $params[
'disabled'] = $this->mParams[
'disabled'];
79 if ( isset( $this->mParams[
'default'] ) ) {
80 $params[
'default'] = $this->mParams[
'default'];
83 if ( isset( $this->mParams[
'placeholder'] ) ) {
84 $params[
'placeholder'] = $this->mParams[
'placeholder'];
86 $params[
'placeholder'] = $this->
msg(
'mw-widgets-tagmultiselect-placeholder' )->plain();
89 if ( isset( $this->mParams[
'max'] ) ) {
90 $params[
'tagLimit'] = $this->mParams[
'max'];
93 if ( isset( $this->mParams[
'allowArbitrary'] ) ) {
94 $params[
'allowArbitrary'] = $this->mParams[
'allowArbitrary'];
97 if ( isset( $this->mParams[
'allowedValues'] ) ) {
98 $params[
'allowedValues'] = $this->mParams[
'allowedValues'];
101 if ( isset( $this->mParams[
'input'] ) ) {
102 $params[
'input'] = $this->mParams[
'input'];
105 if ( $value !==
null ) {
107 $params[
'default'] = $value ===
'' ? [] : explode(
"\n", $value );
111 $params[
'infusable'] =
true;
112 $params[
'classes'] = [
'mw-htmlform-autoinfuse' ];
114 $widget->setAttributes( [
'data-mw-modules' => implode(
',', $this->
getOOUIModules() ) ] );
124 return [
'mediawiki.widgets.TagMultiselectWidget' ];
Implements a tag multiselect input field for arbitrary values.
getInputHTML( $value)
This function must be implemented to return the HTML to generate the input object itself....
getOOUIModules()
Get the list of extra ResourceLoader modules which must be loaded client-side before it's possible to...
loadDataFromRequest( $request)
Get the value that this input has been set to from a posted form, or the input's default value if it ...
validate( $value, $alldata)
Override this function to add specific validation checks on the field input.
getInputOOUI( $value)
Same as getInputHTML, but returns an OOUI object.Defaults to false, which getOOUI will interpret as "...
shouldInfuseOOUI()
Whether the field should be automatically infused.