mirror of
https://github.com/StarCitizenTools/mediawiki-extensions-TabberNeue.git
synced 2024-11-23 16:06:45 +00:00
refactor: switch TabberTransclude to the new method
This commit is contained in:
parent
c67ac50f46
commit
a98f2f7791
|
@ -48,6 +48,10 @@ class Tabber {
|
||||||
* @return string HTML
|
* @return string HTML
|
||||||
*/
|
*/
|
||||||
public static function parserHook( ?string $input, array $args, Parser $parser, PPFrame $frame ) {
|
public static function parserHook( ?string $input, array $args, Parser $parser, PPFrame $frame ) {
|
||||||
|
if ( $input === null ) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
$config = MediaWikiServices::getInstance()->getMainConfig();
|
$config = MediaWikiServices::getInstance()->getMainConfig();
|
||||||
$parserOutput = $parser->getOutput();
|
$parserOutput = $parser->getOutput();
|
||||||
|
|
||||||
|
@ -57,11 +61,7 @@ class Tabber {
|
||||||
|
|
||||||
$count = count( $parserOutput->getExtensionData( 'tabber-count' ) ?? [] );
|
$count = count( $parserOutput->getExtensionData( 'tabber-count' ) ?? [] );
|
||||||
|
|
||||||
$html = self::render( $input ?? '', $count, $parser, $frame );
|
$html = self::render( $input, $count, $parser, $frame );
|
||||||
|
|
||||||
if ( $input === null ) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
$parserOutput->appendExtensionData( 'tabber-count', $count++ );
|
$parserOutput->appendExtensionData( 'tabber-count', $count++ );
|
||||||
|
|
||||||
|
|
|
@ -15,9 +15,12 @@ declare( strict_types=1 );
|
||||||
namespace MediaWiki\Extension\TabberNeue;
|
namespace MediaWiki\Extension\TabberNeue;
|
||||||
|
|
||||||
use Exception;
|
use Exception;
|
||||||
|
use Html;
|
||||||
use MediaWiki\MediaWikiServices;
|
use MediaWiki\MediaWikiServices;
|
||||||
use Parser;
|
use Parser;
|
||||||
use PPFrame;
|
use PPFrame;
|
||||||
|
use Sanitizer;
|
||||||
|
use TemplateParser;
|
||||||
use Title;
|
use Title;
|
||||||
|
|
||||||
class TabberTransclude {
|
class TabberTransclude {
|
||||||
|
@ -32,14 +35,18 @@ class TabberTransclude {
|
||||||
* @return string HTML
|
* @return string HTML
|
||||||
*/
|
*/
|
||||||
public static function parserHook( ?string $input, array $args, Parser $parser, PPFrame $frame ) {
|
public static function parserHook( ?string $input, array $args, Parser $parser, PPFrame $frame ) {
|
||||||
$html = self::render( $input, $parser, $frame );
|
|
||||||
|
|
||||||
if ( $input === null ) {
|
if ( $input === null ) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$parserOutput = $parser->getOutput();
|
||||||
|
|
||||||
|
$count = count( $parserOutput->getExtensionData( 'tabber-count' ) ?? [] );
|
||||||
|
|
||||||
|
$html = self::render( $input, $count, $parser, $frame );
|
||||||
|
|
||||||
$parser->getOutput()->addModuleStyles( [ 'ext.tabberNeue.init.styles' ] );
|
$parser->getOutput()->addModuleStyles( [ 'ext.tabberNeue.init.styles' ] );
|
||||||
// $parser->getOutput()->addModules( [ 'ext.tabberNeue' ] );
|
$parser->getOutput()->addModules( [ 'ext.tabberNeue' ] );
|
||||||
|
|
||||||
$parser->addTrackingCategory( 'tabberneue-tabbertransclude-category' );
|
$parser->addTrackingCategory( 'tabberneue-tabbertransclude-category' );
|
||||||
return $html;
|
return $html;
|
||||||
|
@ -49,31 +56,39 @@ class TabberTransclude {
|
||||||
* Renders the necessary HTML for a <tabbertransclude> tag.
|
* Renders the necessary HTML for a <tabbertransclude> tag.
|
||||||
*
|
*
|
||||||
* @param string $input The input URL between the beginning and ending tags.
|
* @param string $input The input URL between the beginning and ending tags.
|
||||||
|
* @param int $count Current Tabber count
|
||||||
* @param Parser $parser Mediawiki Parser Object
|
* @param Parser $parser Mediawiki Parser Object
|
||||||
* @param PPFrame $frame Mediawiki PPFrame Object
|
* @param PPFrame $frame Mediawiki PPFrame Object
|
||||||
*
|
*
|
||||||
* @return string HTML
|
* @return string HTML
|
||||||
*/
|
*/
|
||||||
public static function render( string $input, Parser $parser, PPFrame $frame ): string {
|
public static function render( string $input, int $count, Parser $parser, PPFrame $frame ): string {
|
||||||
$selected = true;
|
$selected = true;
|
||||||
$arr = explode( "\n", $input );
|
$arr = explode( "\n", $input );
|
||||||
$htmlTabs = '';
|
$tabs = '';
|
||||||
|
$tabpanels = '';
|
||||||
|
|
||||||
foreach ( $arr as $tab ) {
|
foreach ( $arr as $tab ) {
|
||||||
$tabData = self::getTabData( $tab );
|
$tabData = self::getTabData( $tab );
|
||||||
if ( $tabData === [] ) {
|
if ( $tabData === [] ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
$tabs .= self::getTabHTML( $tabData );
|
||||||
try {
|
try {
|
||||||
$htmlTabs .= self::buildTabTransclude( $tabData, $parser, $frame, $selected );
|
$tabpanels .= self::buildTabTransclude( $tabData, $parser, $frame, $selected );
|
||||||
} catch ( Exception $e ) {
|
} catch ( Exception $e ) {
|
||||||
// This can happen if a $currentTitle is null
|
// This can happen if a $currentTitle is null
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return '<div class="tabber">' .
|
$templateParser = new TemplateParser( __DIR__ . '/templates' );
|
||||||
'<header class="tabber__header"></header>' .
|
$data = [
|
||||||
'<section class="tabber__section">' . $htmlTabs . '</section></div>';
|
'count' => $count,
|
||||||
|
'html-tabs' => $tabs,
|
||||||
|
'html-tabpanels' => $tabpanels
|
||||||
|
];
|
||||||
|
return $templateParser->processTemplate( 'Tabber', $data );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -91,11 +106,35 @@ class TabberTransclude {
|
||||||
// Transclude uses a different syntax: Page name|Tab label
|
// Transclude uses a different syntax: Page name|Tab label
|
||||||
// Use array_pad to make sure at least 2 array values are always returned
|
// Use array_pad to make sure at least 2 array values are always returned
|
||||||
[ $content, $label ] = array_pad( explode( '|', $tab, 2 ), 2, '' );
|
[ $content, $label ] = array_pad( explode( '|', $tab, 2 ), 2, '' );
|
||||||
|
|
||||||
$data['label'] = trim( $label );
|
$data['label'] = trim( $label );
|
||||||
|
// Label is empty, we cannot generate tabber
|
||||||
|
if ( $data['label'] === '' ) {
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
$data['content'] = trim( $content );
|
$data['content'] = trim( $content );
|
||||||
|
$data['id'] = Sanitizer::escapeIdForAttribute( htmlspecialchars( $data['label'] ) );
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the HTML for a tab.
|
||||||
|
*
|
||||||
|
* @param array $tabData Tab data
|
||||||
|
*
|
||||||
|
* @return string HTML
|
||||||
|
*/
|
||||||
|
private static function getTabHTML( array $tabData ): string {
|
||||||
|
$tabpanelId = "tabber-tabpanel-{$tabData['id']}";
|
||||||
|
return Html::rawElement( 'a', [
|
||||||
|
'class' => 'tabber__tab',
|
||||||
|
'id' => "tabber-tab-{$tabData['id']}",
|
||||||
|
'href' => "#$tabpanelId",
|
||||||
|
'role' => 'tab',
|
||||||
|
'aria-controls' => $tabpanelId
|
||||||
|
], $tabData['label'] );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Build individual tab.
|
* Build individual tab.
|
||||||
*
|
*
|
||||||
|
@ -166,7 +205,7 @@ class TabberTransclude {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$tab = '<article class="tabber__panel" data-mw-tabber-title="' . htmlspecialchars( $tabName ) . '"';
|
$tab = '<article id="tabber-tabpanel-' . $tabData['id'] . '" class="tabber__panel" data-mw-tabber-title="' . htmlspecialchars( $tabName ) . '"';
|
||||||
$tab .= implode( array_map( static function ( $prop, $value ) {
|
$tab .= implode( array_map( static function ( $prop, $value ) {
|
||||||
return sprintf( ' data-mw-tabber-%s="%s"', $prop, htmlspecialchars( $value ) );
|
return sprintf( ' data-mw-tabber-%s="%s"', $prop, htmlspecialchars( $value ) );
|
||||||
}, array_keys( $dataProps ), $dataProps ) );
|
}, array_keys( $dataProps ), $dataProps ) );
|
||||||
|
|
Loading…
Reference in a new issue