MediaWiki REL1_28
ImageGalleryBase.php
Go to the documentation of this file.
1<?php
30abstract class ImageGalleryBase extends ContextSource {
34 protected $mImages;
35
39 protected $mShowBytes;
40
44 protected $mShowFilename;
45
49 protected $mMode;
50
54 protected $mCaption = false;
55
59 protected $mHideBadImages;
60
64 public $mParser;
65
70 protected $contextTitle = false;
71
73 protected $mAttribs = [];
74
76 static private $modeMapping = false;
77
87 static function factory( $mode = false, IContextSource $context = null ) {
90 if ( !$context ) {
92 }
93 if ( !$mode ) {
94 $galleryOptions = $context->getConfig()->get( 'GalleryOptions' );
95 $mode = $galleryOptions['mode'];
96 }
97
98 $mode = $wgContLang->lc( $mode );
99
100 if ( isset( self::$modeMapping[$mode] ) ) {
101 $class = self::$modeMapping[$mode];
102 return new $class( $mode, $context );
103 } else {
104 throw new MWException( "No gallery class registered for mode $mode" );
105 }
106 }
107
108 private static function loadModes() {
109 if ( self::$modeMapping === false ) {
110 self::$modeMapping = [
111 'traditional' => 'TraditionalImageGallery',
112 'nolines' => 'NolinesImageGallery',
113 'packed' => 'PackedImageGallery',
114 'packed-hover' => 'PackedHoverImageGallery',
115 'packed-overlay' => 'PackedOverlayImageGallery',
116 'slideshow' => 'SlideshowImageGallery',
117 ];
118 // Allow extensions to make a new gallery format.
119 Hooks::run( 'GalleryGetModes', [ &self::$modeMapping ] );
120 }
121 }
122
131 function __construct( $mode = 'traditional', IContextSource $context = null ) {
132 if ( $context ) {
133 $this->setContext( $context );
134 }
135
136 $galleryOptions = $this->getConfig()->get( 'GalleryOptions' );
137 $this->mImages = [];
138 $this->mShowBytes = $galleryOptions['showBytes'];
139 $this->mShowFilename = true;
140 $this->mParser = false;
141 $this->mHideBadImages = false;
142 $this->mPerRow = $galleryOptions['imagesPerRow'];
143 $this->mWidths = $galleryOptions['imageWidth'];
144 $this->mHeights = $galleryOptions['imageHeight'];
145 $this->mCaptionLength = $galleryOptions['captionLength'];
146 $this->mMode = $mode;
147 }
148
159 function setParser( $parser ) {
160 $this->mParser = $parser;
161 }
162
167 function setHideBadImages( $flag = true ) {
168 $this->mHideBadImages = $flag;
169 }
170
176 function setCaption( $caption ) {
177 $this->mCaption = htmlspecialchars( $caption );
178 }
179
185 public function setCaptionHtml( $caption ) {
186 $this->mCaption = $caption;
187 }
188
195 public function setPerRow( $num ) {
196 if ( $num >= 0 ) {
197 $this->mPerRow = (int)$num;
198 }
199 }
200
206 public function setWidths( $num ) {
207 if ( $num > 0 ) {
208 $this->mWidths = (int)$num;
209 }
210 }
211
217 public function setHeights( $num ) {
218 if ( $num > 0 ) {
219 $this->mHeights = (int)$num;
220 }
221 }
222
230 public function setAdditionalOptions( $options ) {
231 }
232
243 function add( $title, $html = '', $alt = '', $link = '', $handlerOpts = [] ) {
244 if ( $title instanceof File ) {
245 // Old calling convention
246 $title = $title->getTitle();
247 }
248 $this->mImages[] = [ $title, $html, $alt, $link, $handlerOpts ];
249 wfDebug( 'ImageGallery::add ' . $title->getText() . "\n" );
250 }
251
262 function insert( $title, $html = '', $alt = '', $link = '', $handlerOpts = [] ) {
263 if ( $title instanceof File ) {
264 // Old calling convention
265 $title = $title->getTitle();
266 }
267 array_unshift( $this->mImages, [ &$title, $html, $alt, $link, $handlerOpts ] );
268 }
269
274 public function getImages() {
275 return $this->mImages;
276 }
277
282 function isEmpty() {
283 return empty( $this->mImages );
284 }
285
292 function setShowBytes( $f ) {
293 $this->mShowBytes = (bool)$f;
294 }
295
302 function setShowFilename( $f ) {
303 $this->mShowFilename = (bool)$f;
304 }
305
316 $this->mAttribs = $attribs;
317 }
318
324 abstract public function toHTML();
325
329 public function count() {
330 return count( $this->mImages );
331 }
332
338 public function setContextTitle( $title ) {
339 $this->contextTitle = $title;
340 }
341
347 public function getContextTitle() {
348 return is_object( $this->contextTitle ) && $this->contextTitle instanceof Title
349 ? $this->contextTitle
350 : false;
351 }
352
357 protected function getRenderLang() {
358 return $this->mParser
359 ? $this->mParser->getTargetLanguage()
360 : $this->getLanguage();
361 }
362}
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 ...
getConfig()
Get the Config object.
IContextSource $context
getLanguage()
Get the Language object.
setContext(IContextSource $context)
Set the IContextSource object.
Implements some public methods and some protected utility functions which are required by multiple ch...
Definition File.php:50
bool string $mCaption
Gallery caption.
setHeights( $num)
Set how high each image will be, in pixels.
__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)
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:36
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
when a variable name is used in a it is silently declared as a new local masking the global
Definition design.txt:95
the array() calling protocol came about after MediaWiki 1.4rc1.
namespace are movable Hooks may change this value to override the return value of MWNamespace::isMovable(). 'NewDifferenceEngine' do that in ParserLimitReportFormat instead $parser
Definition hooks.txt:2259
namespace and then decline to actually register it file or subcat img or subcat $title
Definition hooks.txt:986
this hook is for auditing only RecentChangesLinked and Watchlist RecentChangesLinked and Watchlist e g Watchlist removed from all revisions and log entries to which it was applied This gives extensions a chance to take it off their books as the deletion has already been partly carried out by this point or something similar the user will be unable to create the tag set and then return false from the hook function Ensure you consume the ChangeTagAfterDelete hook to carry out custom deletion actions as context called by AbstractContent::getParserOutput May be used to override the normal model specific rendering of page content as context as context $options
Definition hooks.txt:1096
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:1957
usually copyright or history_copyright This message must be in HTML not wikitext & $link
Definition hooks.txt:2900
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:1958
injection txt This is an overview of how MediaWiki makes use of dependency injection The design described here grew from the discussion of RFC T384 The term dependency this means that anything an object needs to operate should be injected from the the object itself should only know narrow no concrete implementation of the logic it relies on The requirement to inject everything typically results in an architecture that based on two main types of and essentially stateless service objects that use other service objects to operate on the value objects As of the beginning MediaWiki is only starting to use the DI approach Much of the code still relies on global state or direct resulting in a highly cyclical dependency which acts as the top level factory for services in MediaWiki which can be used to gain access to default instances of various services MediaWikiServices however also allows new services to be defined and default services to be redefined Services are defined or redefined by providing a callback the instantiator that will return a new instance of the service When it will create an instance of MediaWikiServices and populate it with the services defined in the files listed by thereby bootstrapping the DI framework Per $wgServiceWiringFiles lists includes ServiceWiring php
Definition injection.txt:37
Interface for objects which can provide a MediaWiki context on request.
getConfig()
Get the site configuration.