tag in Parsoid * * @package TabberNeue * @author alistair3149, Eric Fortin, Alexia E. Smith, Ciencia Al Poder * @license GPL-3.0-or-later * @link https://www.mediawiki.org/wiki/Extension:TabberNeue */ declare( strict_types=1 ); namespace TabberNeue; use Wikimedia\Parsoid\Ext\ExtensionTagHandler; use Wikimedia\Parsoid\Ext\ParsoidExtensionAPI; class TabberParsoid extends ExtensionTagHandler { /** @inheritDoc */ public function sourceToDom( ParsoidExtensionAPI $extApi, string $src, array $extArgs ) { $extApi->addModuleStyles( [ 'ext.tabberNeue' ] ); $html = self::render( $extApi, $src ); return $extApi->htmlToDom( $html ); } /** * Renders the necessary HTML for a tag. * * @param PParsoidExtensionAPI $extApi * @param string $src The input URL between the beginning and ending tags. * * @return string HTML */ public static function render( ParsoidExtensionAPI $extApi, string $src ) { $arr = explode( "|-|", $src ); $htmlTabs = ''; foreach ( $arr as $tab ) { $htmlTabs .= self::buildTab( $extApi, $tab ); } $html = '
' . '
' . $htmlTabs . "
"; return $html; } /** * Build individual tab. * * @param PParsoidExtensionAPI $extApi * @param string $tab Tab information * * @return string HTML */ private static function buildTab( ParsoidExtensionAPI $extApi, string $tab ) { $tab = trim( $tab ); if ( empty( $tab ) ) { return $tab; } // Use array_pad to make sure at least 2 array values are always returned list( $tabName, $tabBody ) = array_pad( array_map( 'trim', explode( '=', $tab, 2 ) ), 2, '' ); // $tabBody = $extApi->wikitextToDOM( $tabBody ); $tabBody = $extApi->domToHTML( $extApi->wikitextToDOM( $tabBody, [ 'parseOpts' => [ 'extTag' => 'tabber', 'context' => 'inline', ] ], true // sol ) ); $tab = '
' . $tabBody . '
'; return $tab; } }