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 ( empty( $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 $params[
'placeholder'] = $this->mParams[
'placeholder'] ??
84 $this->
msg(
'mw-widgets-tagmultiselect-placeholder' )->plain();
86 if ( isset( $this->mParams[
'max'] ) ) {
87 $params[
'tagLimit'] = $this->mParams[
'max'];
90 if ( isset( $this->mParams[
'allowArbitrary'] ) ) {
91 $params[
'allowArbitrary'] = $this->mParams[
'allowArbitrary'];
94 if ( isset( $this->mParams[
'allowedValues'] ) ) {
95 $params[
'allowedValues'] = $this->mParams[
'allowedValues'];
98 if ( isset( $this->mParams[
'input'] ) ) {
99 $params[
'input'] = $this->mParams[
'input'];
102 if ( $value !==
null ) {
104 $params[
'default'] = $value ===
'' ? [] : explode(
"\n", $value );
108 $params[
'infusable'] =
true;
109 $params[
'classes'] = [
'mw-htmlform-autoinfuse' ];
111 $widget->setAttributes( [
'data-mw-modules' => implode(
',', $this->
getOOUIModules() ) ] );
121 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.