Merge "Add deprecated annotation to Article::doEditContent()"
[mediawiki.git] / includes / htmlform / fields / HTMLInfoField.php
blob1376d0c86b6fac916bf705cbdb0074ae27ada937
1 <?php
3 /**
4 * An information field (text blob), not a proper input.
5 */
6 class HTMLInfoField extends HTMLFormField {
7 /**
8 * @param array $info
9 * In adition to the usual HTMLFormField parameters, this can take the following fields:
10 * - default: the value (text) of the field. Unlike other form field types, HTMLInfoField can
11 * take a closure as a default value, which will be evaluated with $info as its only parameter.
12 * - raw: if true, the value won't be escaped.
13 * - rawrow: if true, the usual wrapping of form fields (e.g. into a table row + cell when
14 * display mode is table) will not happen and the value must contain it already.
16 public function __construct( $info ) {
17 $info['nodata'] = true;
19 parent::__construct( $info );
22 public function getDefault() {
23 $default = parent::getDefault();
24 if ( $default instanceof Closure ) {
25 $default = call_user_func( $default, $this->mParams );
27 return $default;
30 public function getInputHTML( $value ) {
31 return !empty( $this->mParams['raw'] ) ? $value : htmlspecialchars( $value );
34 public function getInputOOUI( $value ) {
35 if ( !empty( $this->mParams['raw'] ) ) {
36 $value = new OOUI\HtmlSnippet( $value );
39 return new OOUI\LabelWidget( [
40 'label' => $value,
41 ] );
44 public function getTableRow( $value ) {
45 if ( !empty( $this->mParams['rawrow'] ) ) {
46 return $value;
49 return parent::getTableRow( $value );
52 /**
53 * @param string $value
54 * @return string
55 * @since 1.20
57 public function getDiv( $value ) {
58 if ( !empty( $this->mParams['rawrow'] ) ) {
59 return $value;
62 return parent::getDiv( $value );
65 /**
66 * @param string $value
67 * @return string
68 * @since 1.20
70 public function getRaw( $value ) {
71 if ( !empty( $this->mParams['rawrow'] ) ) {
72 return $value;
75 return parent::getRaw( $value );
78 protected function needsLabel() {
79 return false;