109 private static $modeMapping;
126 $galleryOptions = $context->getConfig()->get( MainConfigNames::GalleryOptions );
127 $mode = $galleryOptions[
'mode'];
130 $mode = MediaWikiServices::getInstance()->getContentLanguage()->lc( $mode );
132 if ( isset( self::$modeMapping[$mode] ) ) {
133 $class = self::$modeMapping[$mode];
134 return new $class( $mode, $context );
140 private static function loadModes() {
141 if ( self::$modeMapping ===
null ) {
142 self::$modeMapping = [
143 'traditional' => TraditionalImageGallery::class,
144 'nolines' => NolinesImageGallery::class,
145 'packed' => PackedImageGallery::class,
146 'packed-hover' => PackedHoverImageGallery::class,
147 'packed-overlay' => PackedOverlayImageGallery::class,
148 'slideshow' => SlideshowImageGallery::class,
151 (
new HookRunner( MediaWikiServices::getInstance()->getHookContainer() ) )
152 ->onGalleryGetModes( self::$modeMapping );
174 $galleryOptions = $this->
getConfig()->get( MainConfigNames::GalleryOptions );
176 $this->mShowBytes = $galleryOptions[
'showBytes'];
177 $this->mShowDimensions = $galleryOptions[
'showDimensions'];
178 $this->mShowFilename =
true;
179 $this->mParser =
false;
180 $this->mHideBadImages =
false;
181 $this->mPerRow = $galleryOptions[
'imagesPerRow'];
182 $this->mWidths = $galleryOptions[
'imageWidth'];
183 $this->mHeights = $galleryOptions[
'imageHeight'];
184 $this->mCaptionLength = $galleryOptions[
'captionLength'];
185 $this->mMode = $mode;
199 $this->mParser = $parser;
206 $this->mHideBadImages = $flag;
215 $this->mCaption = htmlspecialchars( $caption );
224 $this->mCaption = $caption;
235 $this->mPerRow = (int)$num;
247 if ( isset( $parsed[
'width'] ) && $parsed[
'width'] > 0 ) {
248 $this->mWidths = $parsed[
'width'];
260 if ( isset( $parsed[
'width'] ) && $parsed[
'width'] > 0 ) {
261 $this->mHeights = $parsed[
'width'];
295 $loading = self::LOADING_DEFAULT,
296 ?array $imageOptions =
null
302 $this->mImages[] = [
$title, $html, $alt, $link, $handlerOpts, $loading, $imageOptions ];
324 $loading = self::LOADING_DEFAULT,
325 ?array $imageOptions =
null
331 array_unshift( $this->mImages, [ &
$title, $html, $alt, $link, $handlerOpts, $loading, $imageOptions ] );
348 return empty( $this->mImages );
358 $this->mShowDimensions = (bool)$f;
368 $this->mShowBytes = (bool)$f;
378 $this->mShowFilename = (bool)$f;
391 $this->mAttribs = $attribs;
405 return count( $this->mImages );
414 $this->contextTitle =
$title;
431 return $this->mParser
432 ? $this->mParser->getTargetLanguage()
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 ...
setContext(IContextSource $context)
Implements some public methods and some protected utility functions which are required by multiple ch...
setShowDimensions( $f)
Enable/Disable showing of the dimensions of an image in the gallery.
Parser false $mParser
Registered parser object for output callbacks.
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 bad images?
setCaption( $caption)
Set the caption (as plain text)
setHideBadImages( $flag=true)
string false $mCaption
Gallery caption.
Title null $contextTitle
Contextual title, used when images are being screened against the bad image list.
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.
setContextTitle( $title)
Set the contextual title.
bool $mShowFilename
Whether to show the filename.
setParser( $parser)
Register a parser object.
static factory( $mode=false, IContextSource $context=null)
Get a new image gallery.
insert( $title, $html='', $alt='', $link='', $handlerOpts=[], $loading=self::LOADING_DEFAULT, ?array $imageOptions=null)
Add an image at the beginning of the 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.
add( $title, $html='', $alt='', $link='', $handlerOpts=[], $loading=self::LOADING_DEFAULT, ?array $imageOptions=null)
Add an image to the gallery.
array[] $mImages
Gallery images.
setShowFilename( $f)
Enable/Disable showing of the filename of an image in the gallery.
Class for exceptions thrown by ImageGalleryBase::factory().
A class containing constants representing the names of configuration variables.
static parseWidthParam( $value, $parseHeight=true)
Parsed a width param of imagelink like 300px or 200x300px.
static getMainAndWarn( $func=__METHOD__)
Get the RequestContext object associated with the main request and gives a warning to the log,...
Interface for objects which can provide a MediaWiki context on request.