From c1f9b1f7b1b77776192048005dcc66dcf3df2bfb Mon Sep 17 00:00:00 2001 From: Pierre Schmitz Date: Sat, 27 Dec 2014 15:41:37 +0100 Subject: Update to MediaWiki 1.24.1 --- includes/specialpage/ImageQueryPage.php | 79 +++++++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 includes/specialpage/ImageQueryPage.php (limited to 'includes/specialpage/ImageQueryPage.php') diff --git a/includes/specialpage/ImageQueryPage.php b/includes/specialpage/ImageQueryPage.php new file mode 100644 index 00000000..272d5337 --- /dev/null +++ b/includes/specialpage/ImageQueryPage.php @@ -0,0 +1,79 @@ + + */ +abstract class ImageQueryPage extends QueryPage { + /** + * Format and output report results using the given information plus + * OutputPage + * + * @param OutputPage $out OutputPage to print to + * @param Skin $skin User skin to use [unused] + * @param DatabaseBase $dbr (read) connection to use + * @param ResultWrapper $res Result pointer + * @param int $num Number of available result rows + * @param int $offset Paging offset + */ + protected function outputResults( $out, $skin, $dbr, $res, $num, $offset ) { + if ( $num > 0 ) { + $gallery = ImageGalleryBase::factory( false, $this->getContext() ); + + # $res might contain the whole 1,000 rows, so we read up to + # $num [should update this to use a Pager] + $i = 0; + foreach ( $res as $row ) { + $i++; + $namespace = isset( $row->namespace ) ? $row->namespace : NS_FILE; + $title = Title::makeTitleSafe( $namespace, $row->title ); + if ( $title instanceof Title && $title->getNamespace() == NS_FILE ) { + $gallery->add( $title, $this->getCellHtml( $row ) ); + } + if ( $i === $num ) { + break; + } + } + + $out->addHTML( $gallery->toHtml() ); + } + } + + // Gotta override this since it's abstract + function formatResult( $skin, $result ) { + } + + /** + * Get additional HTML to be shown in a results' cell + * + * @param object $row Result row + * @return string + */ + protected function getCellHtml( $row ) { + return ''; + } +} -- cgit v1.2.3-54-g00ecf