*/ use Wikimedia\Rdbms\IResultWrapper; use Wikimedia\Rdbms\IDatabase; /** * A special page that list pages that have highest category count * * @ingroup SpecialPage */ class MostcategoriesPage extends QueryPage { function __construct( $name = 'Mostcategories' ) { parent::__construct( $name ); } public function isExpensive() { return true; } function isSyndicated() { return false; } public function getQueryInfo() { return [ 'tables' => [ 'categorylinks', 'page' ], 'fields' => [ 'namespace' => 'page_namespace', 'title' => 'page_title', 'value' => 'COUNT(*)' ], 'conds' => [ 'page_namespace' => MWNamespace::getContentNamespaces() ], 'options' => [ 'HAVING' => 'COUNT(*) > 1', 'GROUP BY' => [ 'page_namespace', 'page_title' ] ], 'join_conds' => [ 'page' => [ 'LEFT JOIN', 'page_id = cl_from' ] ] ]; } /** * @param IDatabase $db * @param IResultWrapper $res */ function preprocessResults( $db, $res ) { $this->executeLBFromResultWrapper( $res ); } /** * @param Skin $skin * @param object $result Result row * @return string */ function formatResult( $skin, $result ) { $title = Title::makeTitleSafe( $result->namespace, $result->title ); if ( !$title ) { return Html::element( 'span', [ 'class' => 'mw-invalidtitle' ], Linker::getInvalidTitleDescription( $this->getContext(), $result->namespace, $result->title ) ); } $linkRenderer = $this->getLinkRenderer(); if ( $this->isCached() ) { $link = $linkRenderer->makeLink( $title ); } else { $link = $linkRenderer->makeKnownLink( $title ); } $count = $this->msg( 'ncategories' )->numParams( $result->value )->escaped(); return $this->getLanguage()->specialList( $link, $count ); } protected function getGroupName() { return 'highuse'; } }