MediaWiki REL1_33
HTMLTitleTextField.php
Go to the documentation of this file.
1<?php
2
4
22 public function __construct( $params ) {
23 $params += [
24 'namespace' => false,
25 'relative' => false,
26 'creatable' => false,
27 'exists' => false,
28 // This overrides the default from HTMLFormField
29 'required' => true,
30 ];
31
32 parent::__construct( $params );
33 }
34
35 public function validate( $value, $alldata ) {
36 if ( $this->mParent->getMethod() === 'get' && $value === '' ) {
37 // If the form is a GET form and has no value, assume it hasn't been
38 // submitted yet, and skip validation
39 // TODO This doesn't look right, we should be able to tell the difference
40 // between "not submitted" (null) and "submitted but empty" (empty string).
41 return parent::validate( $value, $alldata );
42 }
43
44 // Default value (from getDefault()) is null, which breaks Title::newFromTextThrow() below
45 if ( $value === null ) {
46 $value = '';
47 }
48
49 if ( !$this->mParams['required'] && $value === '' ) {
50 // If this field is not required and the value is empty, that's okay, skip validation
51 return parent::validate( $value, $alldata );
52 }
53
54 try {
55 if ( !$this->mParams['relative'] ) {
56 $title = Title::newFromTextThrow( $value );
57 } else {
58 // Can't use Title::makeTitleSafe(), because it doesn't throw useful exceptions
59 $title = Title::newFromTextThrow( Title::makeName( $this->mParams['namespace'], $value ) );
60 }
61 } catch ( MalformedTitleException $e ) {
62 return $this->msg( $e->getErrorMessage(), $e->getErrorMessageParameters() );
63 }
64
65 $text = $title->getPrefixedText();
66 if ( $this->mParams['namespace'] !== false &&
67 !$title->inNamespace( $this->mParams['namespace'] )
68 ) {
69 return $this->msg( 'htmlform-title-badnamespace', $text, $this->mParams['namespace'] );
70 }
71
72 if ( $this->mParams['creatable'] && !$title->canExist() ) {
73 return $this->msg( 'htmlform-title-not-creatable', $text );
74 }
75
76 if ( $this->mParams['exists'] && !$title->exists() ) {
77 return $this->msg( 'htmlform-title-not-exists', $text );
78 }
79
80 return parent::validate( $value, $alldata );
81 }
82
83 protected function getInputWidget( $params ) {
84 if ( $this->mParams['namespace'] !== false ) {
85 $params['namespace'] = $this->mParams['namespace'];
86 }
87 $params['relative'] = $this->mParams['relative'];
88 return new TitleInputWidget( $params );
89 }
90
91 protected function shouldInfuseOOUI() {
92 return true;
93 }
94
95 protected function getOOUIModules() {
96 // FIXME: TitleInputWidget should be in its own module
97 return [ 'mediawiki.widgets' ];
98 }
99
100 public function getInputHtml( $value ) {
101 // add mw-searchInput class to enable search suggestions for non-OOUI, too
102 $this->mClass .= 'mw-searchInput';
103
104 // return the HTMLTextField html
105 return parent::getInputHTML( $value );
106 }
107
108 protected function getDataAttribs() {
109 return [
110 'data-mw-searchsuggest' => FormatJson::encode( [
111 'wrapAsLink' => false,
112 ] ),
113 ];
114 }
115}
msg()
Get a translated interface message.
<input> field.
Implements a text input field for page titles.
getOOUIModules()
Get the list of extra ResourceLoader modules which must be loaded client-side before it's possible to...
getDataAttribs()
Returns an array of data-* attributes to add to the field.
validate( $value, $alldata)
Override this function to add specific validation checks on the field input.
shouldInfuseOOUI()
Whether the field should be automatically infused.
MalformedTitleException is thrown when a TitleParser is unable to parse a title string.
returning false will NOT prevent logging $e
Definition hooks.txt:2175
$params