PortableInfobox/PortableInfoboxHooks.class.php

150 lines
4.2 KiB
PHP
Raw Normal View History

<?php
class PortableInfoboxHooks {
2015-06-19 12:16:07 +00:00
const PARSER_TAG_GALLERY = 'gallery';
public static function onBeforePageDisplay( OutputPage $out, Skin $skin ) {
global $wgEnablePortableInfoboxEuropaTheme;
Wikia::addAssetsToOutput( 'portable_infobox_js' );
if ( F::app()->checkSkin( 'monobook', $skin ) ) {
Wikia::addAssetsToOutput( 'portable_infobox_monobook_scss' );
Wikia::addAssetsToOutput( 'portable_infobox_monobook_js' );
} else {
Wikia::addAssetsToOutput( 'portable_infobox_scss' );
if ( !empty( $wgEnablePortableInfoboxEuropaTheme ) ) {
Wikia::addAssetsToOutput( 'portable_infobox_europa_theme_scss' );
}
}
return true;
}
public static function onImageServingCollectImages( &$imageNamesArray, $articleTitle ) {
if ( $articleTitle ) {
$infoboxImages = PortableInfoboxDataService::newFromTitle( $articleTitle )->getImages();
if ( !empty( $infoboxImages ) ) {
$imageNamesArray = array_merge( $infoboxImages, (array)$imageNamesArray );
}
}
return true;
}
/**
* Store information about raw content of all galleries in article to handle images in infoboxes
*
* @param $name Parser tag name
* @param $marker substitution marker
* @param $content raw tag contents
* @param $attributes
* @param $parser
* @param $frame
*
* @return bool
*/
public static function onParserTagHooksBeforeInvoke( $name, $marker, $content, $attributes, $parser, $frame ) {
2015-06-19 12:16:07 +00:00
if ( $name === self::PARSER_TAG_GALLERY ) {
\Wikia\PortableInfobox\Helpers\PortableInfoboxDataBag::getInstance()->setGallery( $marker, $content );
}
return true;
}
public static function onWgQueryPages( &$queryPages = [ ] ) {
$queryPages[] = [ 'AllinfoboxesQueryPage', 'AllInfoboxes' ];
return true;
}
public static function onAllInfoboxesQueryRecached() {
F::app()->wg->Memc->delete( wfMemcKey( ApiQueryAllinfoboxes::MCACHE_KEY ) );
return true;
}
/**
* Purge memcache before edit
*
* @param $article Page|WikiPage
* @param $user
* @param $text
* @param $summary
* @param $minor
* @param $watchthis
* @param $sectionanchor
* @param $flags
* @param $status
*
* @return bool
*/
public static function onArticleSave( Page &$article, &$user, &$text, &$summary, $minor, $watchthis, $sectionanchor,
&$flags, &$status ) {
PortableInfoboxDataService::newFromTitle( $article->getTitle() )->delete();
return true;
}
/**
* Purge memcache, this will not rebuild infobox data
*
* @param Page|WikiPage $article
*
* @return bool
*/
public static function onArticlePurge( Page &$article ) {
PortableInfoboxDataService::newFromTitle( $article->getTitle() )->purge();
return true;
}
2015-09-23 13:56:08 +00:00
/**
* Purge articles memcache when template is edited
*
* @param $articles Array of Titles
2015-09-23 13:56:08 +00:00
*
* @return bool
*/
public static function onBacklinksPurge( Array $articles ) {
foreach ( $articles as $title ) {
2016-12-21 08:09:25 +00:00
PortableInfoboxDataService::newFromTitle( $title )->delete();
}
return true;
}
/**
* Insert a newly created infobox into querycache, and purge the list of
* infoboxes.
*
* @param Page $page The created page object
* @param User $user The user who created the page
* @param string $text Text of the new article
* @param string $summary Edit summary
* @param int $minoredit Minor edit flag
* @param boolean $watchThis Whether or not the user should watch the page
* @param null $sectionAnchor Not used, set to null
* @param int $flags Flags for this page
* @param Revision $revision The newly inserted revision object
* @return boolean
*/
public static function onArticleInsertComplete( Page $page, User $user, $text, $summary, $minoredit,
$watchThis, $sectionAnchor, &$flags, Revision $revision ) {
$title = $page->getTitle();
if ( $title->inNamespace( NS_TEMPLATE ) ) {
( new AllinfoboxesQueryPage() )->addTitleToCache( $title );
}
return true;
}
public static function onArticleAsJsonBeforeEncode( &$text ) {
$tagController = PortableInfoboxParserTagController::getInstance();
$tagController->moveFirstMarkerToTop( $text );
$text = $tagController->replaceMarkers( $text );
return true;
}
}