42 $out =
'<' . $element;
44 $out .= self::expandAttributes(
$attribs );
46 if ( is_null( $contents ) ) {
49 if ( $allowShortTag && $contents ===
'' ) {
52 $out .=
'>' . htmlspecialchars( $contents ) .
"</$element>";
77 throw new MWException(
'Expected attribute array, got something else in ' . __METHOD__ );
97 $contents = $wgContLang->normalize( $contents );
99 return self::element( $element,
$attribs, $contents );
110 return '<' . $element . self::expandAttributes(
$attribs ) .
'>';
119 return "</$element>";
132 return self::openElement( $element,
$attribs ) . $contents .
"</$element>";
144 public static function monthSelector( $selected =
'', $allmonths = null, $id =
'month' ) {
147 $data =
new XmlSelect(
'month', $id, $selected );
148 if ( is_null( $selected ) ) {
151 if ( !is_null( $allmonths ) ) {
154 for ( $i = 1; $i < 13; $i++ ) {
155 $options[$wgLang->getMonthName( $i )] = $i;
158 $data->setAttribute(
'class',
'mw-month-selector' );
159 return $data->getHTML();
168 # Offset overrides year/month selection
169 if ( $month && $month !== -1 ) {
170 $encMonth = intval( $month );
175 $encYear = intval( $year );
176 } elseif ( $encMonth ) {
178 $thisMonth = intval(
$timestamp->format(
'n' ) );
179 $thisYear = intval(
$timestamp->format(
'Y' ) );
180 if ( intval( $encMonth ) > $thisMonth ) {
183 $encYear = $thisYear;
187 $inputAttribs =
array(
'id' =>
'year',
'maxlength' => 4,
'size' => 7 );
189 Html::input(
'year', $encYear,
'number', $inputAttribs ) .
' ' .
191 self::monthSelector( $encMonth, -1 );
205 $inLanguage = null, $overrideAttrs =
array(),
Message $msg = null
209 $include = $customisedOnly ?
'mwfile' :
'mw';
214 if ( !array_key_exists( $wgLanguageCode, $languages ) ) {
225 $selected = isset( $languages[$selected] ) ? $selected :
$wgLanguageCode;
227 foreach ( $languages
as $code =>
$name ) {
231 $attrs =
array(
'id' =>
'wpUserLanguage',
'name' =>
'wpUserLanguage' );
232 $attrs = array_merge( $attrs, $overrideAttrs );
234 if ( $msg === null ) {
252 return self::element(
'span',
array(
'class' => $class ) +
$attribs, $text );
279 $attributes[
'size'] = $size;
283 $attributes[
'value'] =
$value;
286 return self::element(
'input',
325 return self::element(
'input', array_merge(
328 'type' =>
'checkbox',
330 self::attrib(
'checked', $checked ),
343 return self::element(
'input',
array(
346 'value' =>
$value ) + self::attrib(
'checked', $checked ) +
$attribs );
360 $a =
array(
'for' => $id );
362 foreach (
array(
'class',
'title' )
as $attr ) {
368 return self::element(
'label', $a, $label );
385 return $label .
' ' . $input;
426 if ( $wgUseMediaWikiUIEverywhere ) {
427 $chkLabel = self::openElement(
'div',
array(
'class' =>
'mw-ui-checkbox' ) ) .
428 $chkLabel . self::closeElement(
'div' );
469 if ( $wgUseMediaWikiUIEverywhere ) {
470 $baseAttrs[
'class'] =
'mw-ui-button mw-ui-constructive';
485 public static function option( $text,
$value = null, $selected =
false,
487 if ( !is_null(
$value ) ) {
509 $selected =
'', $class =
'',
$tabindex = null
513 $options = self::option( $other,
'other', $selected ===
'other' );
515 foreach ( explode(
"\n", $list )
as $option ) {
519 } elseif ( substr(
$value, 0, 1 ) ==
'*' && substr(
$value, 1, 1 ) !=
'*' ) {
523 $options .= self::closeElement(
'optgroup' );
527 } elseif ( substr(
$value, 0, 2 ) ==
'**' ) {
534 $options .= self::closeElement(
'optgroup' );
542 $options .= self::closeElement(
'optgroup' );
605 return self::element(
'textarea',
639 # To avoid any complaints about bad
entity refs
643 # Encode certain Unicode formatting chars
so affected
644 # versions
of Gecko don
't misinterpret our strings;
645 # this is a common problem with Farsi text.
646 "\xe2\x80\x8c" => "\\u200c", // ZERO WIDTH NON-JOINER
647 "\xe2\x80\x8d" => "\\u200d", // ZERO WIDTH JOINER
650 return strtr( $string, $pairs );
664 public static function encodeJsVar( $value, $pretty = false ) {
665 if ( $value instanceof XmlJsCode ) {
666 return $value->value;
668 return FormatJson::encode( $value, $pretty, FormatJson::UTF8_OK );
682 public static function encodeJsCall( $name, $args, $pretty = false ) {
683 foreach ( $args as &$arg ) {
684 $arg = Xml::encodeJsVar( $arg, $pretty );
685 if ( $arg === false ) {
690 return "$name(" . ( $pretty
691 ? ( ' ' . implode( ',
', $args ) . ' ' )
692 : implode( ',
', $args )
707 private static function isWellFormed( $text ) {
708 $parser = xml_parser_create( "UTF-8" );
710 # case folding violates XML standard, turn it off
711 xml_parser_set_option( $parser, XML_OPTION_CASE_FOLDING, false );
713 if ( !xml_parse( $parser, $text, true ) ) {
714 // $err = xml_error_string( xml_get_error_code( $parser ) );
715 // $position = xml_get_current_byte_index( $parser );
716 // $fragment = $this->extractFragment( $html, $position );
717 // $this->mXmlError = "$err at byte $position:\n$fragment";
718 xml_parser_free( $parser );
722 xml_parser_free( $parser );
735 public static function isWellFormedXmlFragment( $text ) {
737 Sanitizer::hackDocType() .
742 return Xml::isWellFormed( $html );
752 public static function escapeTagsOnly( $in ) {
754 array( '"', '>', '<' ),
755 array( '"', '>', '<' ),
770 public static function buildForm( $fields, $submitLabel = null, $submitAttribs = array() ) {
772 $form .= "<
table><tbody>
";
774 foreach ( $fields as $labelmsg => $input ) {
775 $id = "mw-$labelmsg
";
776 $form .= Xml::openElement( 'tr', array( 'id' => $id ) );
778 // TODO use a <label> here for accessibility purposes - will need
779 // to either not use a table to build the form, or find the ID of
780 // the input somehow.
782 $form .= Xml::tags( 'td', array( 'class' => 'mw-label' ), wfMessage( $labelmsg )->parse() );
783 $form .= Xml::openElement( 'td', array( 'class' => 'mw-input' ) )
784 . $input . Xml::closeElement( 'td' );
785 $form .= Xml::closeElement( 'tr' );
788 if ( $submitLabel ) {
789 $form .= Xml::openElement( 'tr' );
790 $form .= Xml::tags( 'td', array(), '' );
791 $form .= Xml::openElement( 'td', array( 'class' => 'mw-submit' ) )
792 . Xml::submitButton( wfMessage( $submitLabel )->text(), $submitAttribs )
793 . Xml::closeElement( 'td' );
794 $form .= Xml::closeElement( 'tr' );
797 $form .= "</tbody></
table>
";
809 public static function buildTable( $rows, $attribs = array(), $headers = null ) {
810 $s = Xml::openElement( 'table', $attribs );
812 if ( is_array( $headers ) ) {
813 $s .= Xml::openElement( 'thead', $attribs );
815 foreach ( $headers as $id => $header ) {
818 if ( is_string( $id ) ) {
819 $attribs['id'] = $id;
822 $s .= Xml::element( 'th', $attribs, $header );
824 $s .= Xml::closeElement( 'thead' );
827 foreach ( $rows as $id => $row ) {
830 if ( is_string( $id ) ) {
831 $attribs['id'] = $id;
834 $s .= Xml::buildTableRow( $attribs, $row );
837 $s .= Xml::closeElement( 'table' );
848 public static function buildTableRow( $attribs, $cells ) {
849 $s = Xml::openElement( 'tr', $attribs );
851 foreach ( $cells as $id => $cell ) {
854 if ( is_string( $id ) ) {
855 $attribs['id'] = $id;
858 $s .= Xml::element( 'td', $attribs, $cell );
861 $s .= Xml::closeElement( 'tr' );
887 function __construct( $value ) {
888 $this->value = $value;
static label($label, $id, $attribs=array())
Convenience function to build an HTML form label.
deferred txt A few of the database updates required by various functions here can be deferred until after the result page is displayed to the user For updating the view updating the linked to tables after a etc PHP does not yet have any way to tell the server to actually return and disconnect while still running these but it might have such a feature in the future We handle these by creating a deferred update object and putting those objects on a global list
static option($text, $value=null, $selected=false, $attribs=array())
Convenience function to build an HTML drop-down list item.
static inputLabel($label, $name, $id, $size=false, $value=false, $attribs=array())
Convenience function to build an HTML text input field with a label.
static element($element, $attribs=null, $contents= '', $allowShortTag=true)
Format an XML element with given attributes and, optionally, text content.
Allows to change the fields on the form that will be generated $name
The Message class provides methods which fulfil two basic services:
static span($text, $class, $attribs=array())
Shortcut to make a span element.
static expandAttributes($attribs)
Given an array of ('attributename' => 'value'), it generates the code to set the XML attributes : attr...
Class for generating HTML <select> elements.
static inputLabelSep($label, $name, $id, $size=false, $value=false, $attribs=array())
Same as Xml::inputLabel() but return input and label in an array.
static monthSelector($selected= '', $allmonths=null, $id= 'month')
Create a date selector.
when a variable name is used in a it is silently declared as a new local masking the global
globals txt Globals are evil The original MediaWiki code relied on globals for processing context far too often MediaWiki development since then has been a story of slowly moving context out of global variables and into objects Storing processing context in object member variables allows those objects to be reused in a much more flexible way Consider the elegance of
static fetchLanguageNames($inLanguage=null, $include= 'mw')
Get an array of language names, indexed by code.
this class mediates it Skin Encapsulates a look and feel for the wiki All of the functions that render HTML and make choices about how to render it are here and are called from various other places when and is meant to be subclassed with other skins that may override some of its functions The User object contains a reference to a and so rather than having a global skin object we just rely on the global User and get the skin with $wgUser and also has some character encoding functions and other locale stuff The current user interface language is instantiated as $wgLang
$wgLanguageCode
Site language code.
static closeElement($element)
Shortcut to close an XML element.
static getTextInputAttributes(array $attrs)
Modifies a set of attributes meant for text input elements and apply a set of default attributes...
Apache License January AND DISTRIBUTION Definitions License shall mean the terms and conditions for and distribution as defined by Sections through of this document Licensor shall mean the copyright owner or entity authorized by the copyright owner that is granting the License Legal Entity shall mean the union of the acting entity and all other entities that control are controlled by or are under common control with that entity For the purposes of this definition control direct or to cause the direction or management of such entity
static submitButton($value, $attribs=array())
Convenience function to build an HTML submit button When $wgUseMediaWikiUIEverywhere is true it will ...
static languageSelector($selected, $customisedOnly=true, $inLanguage=null, $overrideAttrs=array(), Message $msg=null)
Construct a language selector appropriate for use in a form or preferences.
namespace and then decline to actually register it file or subcat img or subcat RecentChangesLinked and Watchlist RecentChangesLinked and Watchlist e g Watchlist removed from all revisions and log entries to which it was applied This gives extensions a chance to take it off their books $tag
static password($name, $size=false, $value=false, $attribs=array())
Convenience function to build an HTML password input field.
magic word the default is to use $key to get the label
in this case you re responsible for computing and outputting the entire conflict i the difference between revisions and your text headers and sections and Diff & $tabindex
static checkLabel($label, $name, $id, $checked=false, $attribs=array())
Convenience function to build an HTML checkbox with a label.
namespace and then decline to actually register it file or subcat img or subcat RecentChangesLinked and Watchlist RecentChangesLinked and Watchlist e g Watchlist removed from all revisions and log entries to which it was applied This gives extensions a chance to take it off their books as the deletion has already been partly carried out by this point or something similar the user will be unable to create the tag set and then return false from the hook function Ensure you consume the ChangeTagAfterDelete hook to carry out custom deletion actions as context called by AbstractContent::getParserOutput May be used to override the normal model specific rendering of page content as context as context $options
static getInstance($ts=false)
Get a timestamp instance in GMT.
static radioLabel($label, $name, $value, $id, $checked=false, $attribs=array())
Convenience function to build an HTML radio button with a label.
static openElement($element, $attribs=null)
This opens an XML element.
static dateMenu($year, $month)
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return an< a > element with HTML attributes $attribs and contents $html will be returned If you return $ret will be returned and may include noclasses after processing after in associative array form externallinks including delete and has completed for all link tables whether this was an auto creation default is conds Array Extra conditions for the No matching items in log is displayed if loglist is empty msgKey Array If you want a nice box with a set this to the key of the message First element is the message additional optional elements are parameters for the key that are processed with wfMessage() -> params() ->parseAsBlock()-offset Set to overwrite offset parameter in $wgRequest set to ''to unsetoffset-wrap String Wrap the message in html(usually something like"<
$wgUseMediaWikiUIEverywhere
Temporary variable that applies MediaWiki UI wherever it can be supported.
design txt This is a brief overview of the new design More thorough and up to date information is available on the documentation wiki at etc Handles the details of getting and saving to the user table of the and dealing with sessions and cookies OutputPage Encapsulates the entire HTML page that will be sent in response to any server request It is used by calling its functions to add text
static escapeJsString($string)
Returns an escaped string suitable for inclusion in a string literal for JavaScript source code...
This document is intended to provide useful advice for parties seeking to redistribute MediaWiki to end users It s targeted particularly at maintainers for Linux since it s been observed that distribution packages of MediaWiki often break We ve consistently had to recommend that users seeking support use official tarballs instead of their distribution s and this often solves whatever problem the user is having It would be nice if this could such as
namespace and then decline to actually register it file or subcat img or subcat RecentChangesLinked and Watchlist RecentChangesLinked and Watchlist e g Watchlist removed from all revisions and log entries to which it was applied This gives extensions a chance to take it off their books as the deletion has already been partly carried out by this point or something similar the user will be unable to create the tag set and then return false from the hook function Ensure you consume the ChangeTagAfterDelete hook to carry out custom deletion actions as context called by AbstractContent::getParserOutput May be used to override the normal model specific rendering of page content $content
static check($name, $checked=false, $attribs=array())
Convenience function to build an HTML checkbox.
static textarea($name, $content, $cols=40, $rows=5, $attribs=array())
Shortcut for creating textareas.
static tags($element, $attribs=null, $contents)
Same as Xml::element(), but does not escape contents.
deferred txt A few of the database updates required by various functions here can be deferred until after the result page is displayed to the user For updating the view updating the linked to tables after a etc PHP does not yet have any way to tell the server to actually return and disconnect while still running these but it might have such a feature in the future We handle these by creating a deferred update object and putting those objects on a global then executing the whole list after the page is displayed We don t do anything smart like collating updates to the same table or such because the list is almost always going to have just one item on if so it s not worth the trouble Since there is a job queue in the jobs table
static input($name, $value= '', $type= 'text', array $attribs=array())
Convenience function to produce an "<input>" element.
static radio($name, $value, $checked=false, $attribs=array())
Convenience function to build an HTML radio button.
the array() calling protocol came about after MediaWiki 1.4rc1.
List of Api Query prop modules.
static element($element, $attribs=array(), $contents= '')
Identical to rawElement(), but HTML-escapes $contents (like Xml::element()).
this class mediates it Skin Encapsulates a look and feel for the wiki All of the functions that render HTML and make choices about how to render it are here and are called from various other places when and is meant to be subclassed with other skins that may override some of its functions The User object contains a reference to a and so rather than having a global skin object we just rely on the global User and get the skin with $wgUser and also has some character encoding functions and other locale stuff The current user interface language is instantiated as and the local content language as $wgContLang
Apache License January AND DISTRIBUTION Definitions License shall mean the terms and conditions for and distribution as defined by Sections through of this document Licensor shall mean the copyright owner or entity authorized by the copyright owner that is granting the License Legal Entity shall mean the union of the acting entity and all other entities that control are controlled by or are under common control with that entity For the purposes of this definition control direct or to cause the direction or management of such whether by contract or including but not limited to software source documentation and configuration files Object form shall mean any form resulting from mechanical transformation or translation of a Source including but not limited to compiled object generated and conversions to other media types Work shall mean the work of whether in Source or Object made available under the as indicated by a copyright notice that is included in or attached to the whether in Source or Object that is based or other modifications as a an original work of authorship For the purposes of this Derivative Works shall not include works that remain separable or merely the Work and Derivative Works thereof Contribution shall mean any work of including the original version of the Work and any modifications or additions to that Work or Derivative Works that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner For the purposes of this submitted means any form of or written communication sent to the Licensor or its including but not limited to communication on electronic mailing source code control and issue tracking systems that are managed or on behalf the Licensor for the purpose of discussing and improving the Work
design txt This is a brief overview of the new design More thorough and up to date information is available on the documentation wiki at https
static attrib($name, $present=true)
Internal function for use in checkboxes and radio buttons and such.
maintenance dev scripts can help quickly setup a local MediaWiki for development purposes Wikis setup in this way are NOT meant to be publicly available They use a development database not acceptible for use in production Place a sqlite database in an unsafe location a real wiki should never place it in And use predictable default logins for the initial administrator user Running maintenance dev install sh will download and install a local copy of php
Module of static functions for generating XML.
static listDropDown($name= '', $list= '', $other= '', $selected= '', $class= '', $tabindex=null)
Build a drop-down box from a textual list.
static fieldset($legend=false, $content=false, $attribs=array())
Shortcut for creating fieldsets.
static input($name, $size=false, $value=false, $attribs=array())
Convenience function to build an HTML text input field.
static wrapClass($text, $class, $tag= 'span', $attribs=array())
Shortcut to make a specific element with a class attribute.
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return an< a > element with HTML attributes $attribs and contents $html will be returned If you return $ret will be returned and may include noclasses after processing & $attribs
static encodeAttribute($text)
Encode an attribute value for HTML output.
in this case you re responsible for computing and outputting the entire conflict i the difference between revisions and your text headers and sections and Diff overridable Default is either copyrightwarning or copyrightwarning2 overridable Default is editpage tos summary such as anonymity and the real check
static elementClean($element, $attribs=array(), $contents= '')
Format an XML element as with self::element(), but run text through the $wgContLang->normalize() vali...