MediaWiki REL1_31
ImageGalleryBase.php
Go to the documentation of this file.
1<?php
30abstract class ImageGalleryBase extends ContextSource {
34 protected $mImages;
35
39 protected $mShowBytes;
40
45
49 protected $mShowFilename;
50
54 protected $mMode;
55
59 protected $mCaption = false;
60
68 protected $mCaptionLength = true;
69
73 protected $mHideBadImages;
74
78 public $mParser;
79
84 protected $contextTitle = false;
85
87 protected $mAttribs = [];
88
90 static private $modeMapping = false;
91
101 static function factory( $mode = false, IContextSource $context = null ) {
102 global $wgContLang;
104 if ( !$context ) {
106 }
107 if ( !$mode ) {
108 $galleryOptions = $context->getConfig()->get( 'GalleryOptions' );
109 $mode = $galleryOptions['mode'];
110 }
111
112 $mode = $wgContLang->lc( $mode );
113
114 if ( isset( self::$modeMapping[$mode] ) ) {
115 $class = self::$modeMapping[$mode];
116 return new $class( $mode, $context );
117 } else {
118 throw new MWException( "No gallery class registered for mode $mode" );
119 }
120 }
121
122 private static function loadModes() {
123 if ( self::$modeMapping === false ) {
124 self::$modeMapping = [
125 'traditional' => TraditionalImageGallery::class,
126 'nolines' => NolinesImageGallery::class,
127 'packed' => PackedImageGallery::class,
128 'packed-hover' => PackedHoverImageGallery::class,
129 'packed-overlay' => PackedOverlayImageGallery::class,
130 'slideshow' => SlideshowImageGallery::class,
131 ];
132 // Allow extensions to make a new gallery format.
133 Hooks::run( 'GalleryGetModes', [ &self::$modeMapping ] );
134 }
135 }
136
145 function __construct( $mode = 'traditional', IContextSource $context = null ) {
146 if ( $context ) {
147 $this->setContext( $context );
148 }
149
150 $galleryOptions = $this->getConfig()->get( 'GalleryOptions' );
151 $this->mImages = [];
152 $this->mShowBytes = $galleryOptions['showBytes'];
153 $this->mShowDimensions = $galleryOptions['showDimensions'];
154 $this->mShowFilename = true;
155 $this->mParser = false;
156 $this->mHideBadImages = false;
157 $this->mPerRow = $galleryOptions['imagesPerRow'];
158 $this->mWidths = $galleryOptions['imageWidth'];
159 $this->mHeights = $galleryOptions['imageHeight'];
160 $this->mCaptionLength = $galleryOptions['captionLength'];
161 $this->mMode = $mode;
162 }
163
174 function setParser( $parser ) {
175 $this->mParser = $parser;
176 }
177
182 function setHideBadImages( $flag = true ) {
183 $this->mHideBadImages = $flag;
184 }
185
191 function setCaption( $caption ) {
192 $this->mCaption = htmlspecialchars( $caption );
193 }
194
200 public function setCaptionHtml( $caption ) {
201 $this->mCaption = $caption;
202 }
203
210 public function setPerRow( $num ) {
211 if ( $num >= 0 ) {
212 $this->mPerRow = (int)$num;
213 }
214 }
215
222 public function setWidths( $num ) {
223 $parsed = Parser::parseWidthParam( $num, false );
224 if ( isset( $parsed['width'] ) && $parsed['width'] > 0 ) {
225 $this->mWidths = $parsed['width'];
226 }
227 }
228
235 public function setHeights( $num ) {
236 $parsed = Parser::parseWidthParam( $num, false );
237 if ( isset( $parsed['width'] ) && $parsed['width'] > 0 ) {
238 $this->mHeights = $parsed['width'];
239 }
240 }
241
249 public function setAdditionalOptions( $options ) {
250 }
251
262 function add( $title, $html = '', $alt = '', $link = '', $handlerOpts = [] ) {
263 if ( $title instanceof File ) {
264 // Old calling convention
265 $title = $title->getTitle();
266 }
267 $this->mImages[] = [ $title, $html, $alt, $link, $handlerOpts ];
268 wfDebug( 'ImageGallery::add ' . $title->getText() . "\n" );
269 }
270
281 function insert( $title, $html = '', $alt = '', $link = '', $handlerOpts = [] ) {
282 if ( $title instanceof File ) {
283 // Old calling convention
284 $title = $title->getTitle();
285 }
286 array_unshift( $this->mImages, [ &$title, $html, $alt, $link, $handlerOpts ] );
287 }
288
293 public function getImages() {
294 return $this->mImages;
295 }
296
301 function isEmpty() {
302 return empty( $this->mImages );
303 }
304
311 function setShowDimensions( $f ) {
312 $this->mShowDimensions = (bool)$f;
313 }
314
321 function setShowBytes( $f ) {
322 $this->mShowBytes = (bool)$f;
323 }
324
331 function setShowFilename( $f ) {
332 $this->mShowFilename = (bool)$f;
333 }
334
345 $this->mAttribs = $attribs;
346 }
347
353 abstract public function toHTML();
354
358 public function count() {
359 return count( $this->mImages );
360 }
361
367 public function setContextTitle( $title ) {
368 $this->contextTitle = $title;
369 }
370
376 public function getContextTitle() {
377 return is_object( $this->contextTitle ) && $this->contextTitle instanceof Title
378 ? $this->contextTitle
379 : false;
380 }
381
386 protected function getRenderLang() {
387 return $this->mParser
388 ? $this->mParser->getTargetLanguage()
389 : $this->getLanguage();
390 }
391}
wfDebug( $text, $dest='all', array $context=[])
Sends a line to the debug log if enabled or, optionally, to a comment in output.
The simplest way of implementing IContextSource is to hold a RequestContext as a member variable and ...
IContextSource $context
setContext(IContextSource $context)
Implements some public methods and some protected utility functions which are required by multiple ch...
Definition File.php:51
setShowDimensions( $f)
Enable/Disable showing of the dimensions of an image in the gallery.
bool string $mCaption
Gallery caption.
setHeights( $num)
Set how high each image will be, in pixels.
bool $mShowDimensions
Whether to show the dimensions in categories.
__construct( $mode='traditional', IContextSource $context=null)
Create a new image gallery object.
isEmpty()
isEmpty() returns true if the gallery contains no images
setAttributes( $attribs)
Set arbitrary attributes to go on the HTML gallery output element.
bool $mHideBadImages
Hide blacklisted images?
setCaption( $caption)
Set the caption (as plain text)
setHideBadImages( $flag=true)
Set bad image flag.
Parser $mParser
Registered parser object for output callbacks.
setCaptionHtml( $caption)
Set the caption (as HTML)
bool int $mCaptionLength
Length to truncate filename to in caption when using "showfilename".
getContextTitle()
Get the contextual title, if applicable.
string $mMode
Gallery mode.
setAdditionalOptions( $options)
Allow setting additional options.
setPerRow( $num)
Set how many images will be displayed per row.
insert( $title, $html='', $alt='', $link='', $handlerOpts=[])
Add an image at the beginning of the gallery.
setContextTitle( $title)
Set the contextual title.
Title $contextTitle
Contextual title, used when images are being screened against the bad image list.
bool $mShowFilename
Whether to show the filename.
setParser( $parser)
Register a parser object.
static bool $modeMapping
static factory( $mode=false, IContextSource $context=null)
Get a new image gallery.
bool $mShowBytes
Whether to show the filesize in bytes in categories.
toHTML()
Display an html representation of the gallery.
setShowBytes( $f)
Enable/Disable showing of the file size of an image in the gallery.
getRenderLang()
Determines the correct language to be used for this image gallery.
setWidths( $num)
Set how wide each image will be, in pixels.
getImages()
Returns the list of images this gallery contains.
setShowFilename( $f)
Enable/Disable showing of the filename of an image in the gallery.
array $mImages
Gallery images.
add( $title, $html='', $alt='', $link='', $handlerOpts=[])
Add an image to the gallery.
MediaWiki exception.
PHP Parser - Processes wiki markup (which uses a more user-friendly syntax, such as "[[link]]" for ma...
Definition Parser.php:70
static getMainAndWarn( $func=__METHOD__)
Get the RequestContext object associated with the main request and gives a warning to the log,...
Represents a title within MediaWiki.
Definition Title.php:39
this class mediates it Skin Encapsulates a look and feel for the wiki All of the functions that render HTML and make choices about how to render it are here and are called from various other places when and is meant to be subclassed with other skins that may override some of its functions The User object contains a reference to a and so rather than having a global skin object we just rely on the global User and get the skin with $wgUser and also has some character encoding functions and other locale stuff The current user interface language is instantiated as and the local content language as $wgContLang
Definition design.txt:57
do that in ParserLimitReportFormat instead $parser
Definition hooks.txt:2603
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped & $options
Definition hooks.txt:2001
namespace and then decline to actually register it file or subcat img or subcat $title
Definition hooks.txt:964
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return an< a > element with HTML attributes $attribs and contents $html will be returned If you return $ret will be returned and may include noclasses & $html
Definition hooks.txt:2013
usually copyright or history_copyright This message must be in HTML not wikitext & $link
Definition hooks.txt:3021
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return an< a > element with HTML attributes $attribs and contents $html will be returned If you return $ret will be returned and may include noclasses after processing & $attribs
Definition hooks.txt:2014
Interface for objects which can provide a MediaWiki context on request.
getConfig()
Get the site configuration.