47 private const MAX_INCLUDE_SIZE = 50000000;
50 parent::__construct(
'ExpandTemplates' );
62 $titleStr = $request->getText(
'wpContextTitle' );
63 $title = Title::newFromText( $titleStr );
68 $input = $request->getText(
'wpInput' );
69 $this->generateXML = $request->getBool(
'wpGenerateXml' );
70 $this->generateRawHtml = $request->getBool(
'wpGenerateRawHtml' );
72 if ( strlen( $input ) ) {
73 $this->removeComments = $request->getBool(
'wpRemoveComments',
false );
74 $this->removeNowiki = $request->getBool(
'wpRemoveNowiki',
false );
75 $options = ParserOptions::newFromContext( $this->
getContext() );
76 $options->setRemoveComments( $this->removeComments );
77 $options->setMaxIncludeSize( self::MAX_INCLUDE_SIZE );
79 $parser = MediaWikiServices::getInstance()->getParser();
80 if ( $this->generateXML ) {
81 $parser->startExternalParse(
$title, $options, Parser::OT_PREPROCESS );
82 $dom = $parser->preprocessToDom( $input );
84 if ( method_exists( $dom,
'saveXML' ) ) {
86 $xml = $dom->saveXML();
89 $xml = $dom->__toString();
93 $output = $parser->preprocess( $input,
$title, $options );
95 $this->removeComments = $request->getBool(
'wpRemoveComments',
true );
96 $this->removeNowiki = $request->getBool(
'wpRemoveNowiki',
false );
102 $this->
makeForm( $titleStr, $input );
104 if ( $output !==
false ) {
105 if ( $this->generateXML && strlen( $output ) > 0 ) {
106 $out->addHTML( $this->
makeOutput( $xml,
'expand_templates_xml_output' ) );
111 if ( $this->removeNowiki ) {
113 [
'_<nowiki>_',
'_</nowiki>_',
'_<nowiki */>_' ],
123 $out->addHTML( $tmp );
126 $rawhtml = $pout->getText();
127 if ( $this->generateRawHtml && strlen( $rawhtml ) > 0 ) {
128 $out->addHTML( $this->
makeOutput( $rawhtml,
'expand_templates_html_output' ) );
144 $status = Status::newGood();
145 if ( !strlen( $values[
'input'] ) ) {
146 $status = Status::newFatal(
'expand_templates_input_missing' );
161 'label' => $this->
msg(
'expand_templates_title' )->plain(),
162 'name' =>
'wpContextTitle',
163 'id' =>
'contexttitle',
169 'type' =>
'textarea',
171 'label' => $this->
msg(
'expand_templates_input' )->text(),
175 'useeditfont' =>
true,
177 'removecomments' => [
179 'label' => $this->
msg(
'expand_templates_remove_comments' )->text(),
180 'name' =>
'wpRemoveComments',
181 'id' =>
'removecomments',
186 'label' => $this->
msg(
'expand_templates_remove_nowiki' )->text(),
187 'name' =>
'wpRemoveNowiki',
188 'id' =>
'removenowiki',
193 'label' => $this->
msg(
'expand_templates_generate_xml' )->text(),
194 'name' =>
'wpGenerateXml',
195 'id' =>
'generate_xml',
198 'generate_rawhtml' => [
200 'label' => $this->
msg(
'expand_templates_generate_rawhtml' )->text(),
201 'name' =>
'wpGenerateRawHtml',
202 'id' =>
'generate_rawhtml',
207 $form = HTMLForm::factory(
'ooui', $fields, $this->
getContext() );
209 ->setSubmitTextMsg(
'expand_templates_ok' )
210 ->setWrapperLegendMsg(
'expandtemplates' )
211 ->setHeaderText( $this->
msg(
'expand_templates_intro' )->parse() )
212 ->setSubmitCallback( [ $this,
'onSubmitInput' ] )
223 private function makeOutput( $output, $heading =
'expand_templates_output' ) {
224 $out =
"<h2>" . $this->
msg( $heading )->escaped() .
"</h2>\n";
225 $out .= Xml::textarea(
232 'readonly' =>
'readonly',
233 'class' =>
'mw-editfont-' . $this->
getUser()->getOption(
'editfont' )
248 $popts = ParserOptions::newFromContext( $this->
getContext() );
249 $popts->setTargetLanguage(
$title->getPageLanguage() );
250 return MediaWikiServices::getInstance()->getParser()->parse( $text,
$title, $popts );
262 $out->
addHTML(
"<h2>" . $this->
msg(
'expand_templates_preview' )->escaped() .
"</h2>\n" );
264 if ( $this->
getConfig()->
get(
'RawHtml' ) ) {
272 if ( $user->isAnon() && !MediaWikiServices::getInstance()
273 ->getPermissionManager()
274 ->userHasRight( $user,
'edit' )
276 $error = [
'expand_templates_preview_fail_html_anon' ];
277 } elseif ( !$user->matchEditToken( $request->getVal(
'wpEditToken' ),
'', $request ) ) {
278 $error = [
'expand_templates_preview_fail_html' ];
284 $out->
wrapWikiMsg(
"<div class='previewnote errorbox'>\n$1\n</div>", $error );
289 $out->
addHTML( Html::openElement(
'div', [
290 'class' =>
'mw-content-' .
$lang->getDir(),
291 'dir' =>
$lang->getDir(),
292 'lang' =>
$lang->getHtmlCode(),
295 $out->
addHTML( Html::closeElement(
'div' ) );
static tidy( $text)
Interface with Remex tidy.
This is one of the Core classes and should be read at least once by any new developers.
setCategoryLinks(array $categories)
Reset the category links (but not the category list) and add $categories.
wrapWikiMsg( $wrap,... $msgSpecs)
This function takes a number of message/argument specifications, wraps them in some overall structure...
addParserOutputContent(ParserOutput $parserOutput, $poOptions=[])
Add the HTML and enhancements for it (like ResourceLoader modules) associated with a ParserOutput obj...
addHTML( $text)
Append $text to the body HTML.
A special page that expands submitted templates, parser functions, and variables, allowing easier deb...
bool $generateRawHtml
Whether or not to show the raw HTML code.
bool $removeComments
Whether or not to remove comments in the expanded wikitext.
onSubmitInput(array $values)
Callback for the HTMLForm used in self::makeForm.
bool $generateXML
Whether or not to show the XML parse tree.
makeForm( $title, $input)
Generate a form allowing users to enter information.
getGroupName()
Under which header this special page is listed in Special:SpecialPages See messages 'specialpages-gro...
showHtmlPreview(Title $title, ParserOutput $pout, OutputPage $out)
Wraps the provided html code in a div and outputs it to the page.
generateHtml(Title $title, $text)
Renders the supplied wikitext as html.
makeOutput( $output, $heading='expand_templates_output')
Generate a nice little box with a heading for output.
execute( $subpage)
Show the special page.
bool $removeNowiki
Whether or not to remove <nowiki> tags in the expanded wikitext.
Parent class for all special pages.
setHeaders()
Sets headers - this should be called from the execute() method of all derived classes!...
getOutput()
Get the OutputPage being used for this instance.
getUser()
Shortcut to get the User executing this instance.
getContext()
Gets the context this SpecialPage is executed in.
msg( $key,... $params)
Wrapper around wfMessage that sets the current context.
getConfig()
Shortcut to get main config object.
getRequest()
Get the WebRequest being used for this instance.
getPageTitle( $subpage=false)
Get a self-referential title object.
addHelpLink( $to, $overrideBaseUrl=false)
Adds help link with an icon via page indicators.
Represents a title within MediaWiki.
if(!isset( $args[0])) $lang