4 * An information field (text blob), not a proper input.
6 class HTMLInfoField
extends HTMLFormField
{
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 function getDefault() {
23 $default = parent
::getDefault();
24 if ( $default instanceof Closure
) {
25 $default = call_user_func( $default, $this->mParams
);
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( [
44 public function getTableRow( $value ) {
45 if ( !empty( $this->mParams
['rawrow'] ) ) {
49 return parent
::getTableRow( $value );
53 * @param string $value
57 public function getDiv( $value ) {
58 if ( !empty( $this->mParams
['rawrow'] ) ) {
62 return parent
::getDiv( $value );
66 * @param string $value
70 public function getRaw( $value ) {
71 if ( !empty( $this->mParams
['rawrow'] ) ) {
75 return parent
::getRaw( $value );
78 protected function needsLabel() {