mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/MultimediaViewer
synced 2024-11-17 12:53:24 +00:00
Merge "Shuffle things around so original file sizes are easier to access"
This commit is contained in:
commit
141580d9a7
|
@ -130,11 +130,15 @@
|
||||||
* @returns {mw.mmv.LightboxImage}
|
* @returns {mw.mmv.LightboxImage}
|
||||||
*/
|
*/
|
||||||
MMVP.createNewImage = function ( fileLink, filePageLink, fileTitle, index, thumb, caption ) {
|
MMVP.createNewImage = function ( fileLink, filePageLink, fileTitle, index, thumb, caption ) {
|
||||||
var thisImage = new mw.mmv.LightboxImage( fileLink, filePageLink, fileTitle, index, thumb, caption );
|
var thisImage = new mw.mmv.LightboxImage( fileLink, filePageLink, fileTitle, index, thumb, caption ),
|
||||||
|
$thumb = $( thumb );
|
||||||
|
|
||||||
thisImage.filePageLink = filePageLink;
|
thisImage.filePageLink = filePageLink;
|
||||||
thisImage.filePageTitle = fileTitle;
|
thisImage.filePageTitle = fileTitle;
|
||||||
thisImage.index = index;
|
thisImage.index = index;
|
||||||
thisImage.thumbnail = thumb;
|
thisImage.thumbnail = thumb;
|
||||||
|
thisImage.originalWidth = parseInt( $thumb.data( 'file-width' ), 10 );
|
||||||
|
thisImage.originalHeight = parseInt( $thumb.data( 'file-height' ), 10 );
|
||||||
|
|
||||||
return thisImage;
|
return thisImage;
|
||||||
};
|
};
|
||||||
|
@ -146,15 +150,15 @@
|
||||||
*/
|
*/
|
||||||
MMVP.resize = function ( ui ) {
|
MMVP.resize = function ( ui ) {
|
||||||
var viewer = this,
|
var viewer = this,
|
||||||
fileTitle = this.currentImageFileTitle,
|
image = this.thumbs[ this.currentIndex].image,
|
||||||
imageWidths;
|
imageWidths;
|
||||||
|
|
||||||
this.preloadThumbnails();
|
this.preloadThumbnails();
|
||||||
|
|
||||||
if ( fileTitle ) {
|
if ( image ) {
|
||||||
imageWidths = ui.canvas.getCurrentImageWidths();
|
imageWidths = ui.canvas.getCurrentImageWidths();
|
||||||
this.fetchThumbnail(
|
this.fetchThumbnailForLightboxImage(
|
||||||
fileTitle, imageWidths.real
|
image, imageWidths.real
|
||||||
).then( function( thumbnail, image ) {
|
).then( function( thumbnail, image ) {
|
||||||
viewer.setImage( ui, thumbnail, image, imageWidths );
|
viewer.setImage( ui, thumbnail, image, imageWidths );
|
||||||
}, function ( error ) {
|
}, function ( error ) {
|
||||||
|
@ -200,8 +204,8 @@
|
||||||
start,
|
start,
|
||||||
viewer = this,
|
viewer = this,
|
||||||
$initialImage = $( initialImage ),
|
$initialImage = $( initialImage ),
|
||||||
fileWidth = parseInt( $initialImage.data( 'file-width' ), 10 ),
|
fileWidth = image.originalWidth,
|
||||||
fileHeight = parseInt( $initialImage.data( 'file-height' ), 10 );
|
fileHeight = image.originalHeight;
|
||||||
|
|
||||||
this.currentIndex = image.index;
|
this.currentIndex = image.index;
|
||||||
|
|
||||||
|
@ -237,7 +241,7 @@
|
||||||
// while another image is already loading
|
// while another image is already loading
|
||||||
viewer.ui.panel.percent( 0 );
|
viewer.ui.panel.percent( 0 );
|
||||||
|
|
||||||
imagePromise = this.fetchThumbnail( image.filePageTitle, imageWidths.real );
|
imagePromise = this.fetchThumbnailForLightboxImage( image, imageWidths.real );
|
||||||
|
|
||||||
// Check that the image hasn't already been loaded
|
// Check that the image hasn't already been loaded
|
||||||
if ( imagePromise.state() === 'pending' ) {
|
if ( imagePromise.state() === 'pending' ) {
|
||||||
|
@ -489,8 +493,8 @@
|
||||||
|
|
||||||
this.thumbnailPreloadQueue = this.pushLightboxImagesIntoQueue( function( lightboxImage ) {
|
this.thumbnailPreloadQueue = this.pushLightboxImagesIntoQueue( function( lightboxImage ) {
|
||||||
return function() {
|
return function() {
|
||||||
return viewer.fetchThumbnail(
|
return viewer.fetchThumbnailForLightboxImage(
|
||||||
lightboxImage.filePageTitle,
|
lightboxImage,
|
||||||
viewer.ui.canvas.getLightboxImageWidths( lightboxImage ).real
|
viewer.ui.canvas.getLightboxImageWidths( lightboxImage ).real
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@ -503,8 +507,8 @@
|
||||||
* Preload the fullscreen size of the current image.
|
* Preload the fullscreen size of the current image.
|
||||||
*/
|
*/
|
||||||
MMVP.preloadFullscreenThumbnail = function( image ) {
|
MMVP.preloadFullscreenThumbnail = function( image ) {
|
||||||
this.fetchThumbnail(
|
this.fetchThumbnailForLightboxImage(
|
||||||
image.filePageTitle,
|
image,
|
||||||
this.ui.canvas.getLightboxImageWidthsForFullscreen( image ).real
|
this.ui.canvas.getLightboxImageWidthsForFullscreen( image ).real
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@ -541,13 +545,30 @@
|
||||||
} );
|
} );
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads size-dependent components of a lightbox - the thumbnail model and the image itself.
|
||||||
|
* @param {mw.mmv.LightboxImage} image
|
||||||
|
* @param {number} width the width of the requested thumbnail
|
||||||
|
*/
|
||||||
|
MMVP.fetchThumbnailForLightboxImage = function ( image, width ) {
|
||||||
|
return this.fetchThumbnail(
|
||||||
|
image.filePageTitle,
|
||||||
|
width,
|
||||||
|
image.originalWidth,
|
||||||
|
image.originalHeight
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Loads size-dependent components of a lightbox - the thumbnail model and the image itself.
|
* Loads size-dependent components of a lightbox - the thumbnail model and the image itself.
|
||||||
* @param {mw.Title} fileTitle
|
* @param {mw.Title} fileTitle
|
||||||
* @param {number} width
|
* @param {number} width the width of the requested thumbnail
|
||||||
|
* @param {number} [originalWidth] the width of the original, full-sized file (might be missing)
|
||||||
|
* @param {number} [originalHeight] the height of the original, full-sized file (might be missing)
|
||||||
* @returns {jQuery.Promise.<mw.mmv.model.Thumbnail, HTMLImageElement>}
|
* @returns {jQuery.Promise.<mw.mmv.model.Thumbnail, HTMLImageElement>}
|
||||||
*/
|
*/
|
||||||
MMVP.fetchThumbnail = function ( fileTitle, width ) {
|
MMVP.fetchThumbnail = function ( fileTitle, width, originalWidth, originalHeight ) {
|
||||||
|
$.noop( originalWidth, originalHeight ); // keep JSHint happy... will be removed later
|
||||||
var viewer = this,
|
var viewer = this,
|
||||||
thumbnailPromise,
|
thumbnailPromise,
|
||||||
imagePromise;
|
imagePromise;
|
||||||
|
|
|
@ -46,6 +46,12 @@
|
||||||
|
|
||||||
/** @property {string} caption The caption of the image, if any */
|
/** @property {string} caption The caption of the image, if any */
|
||||||
this.caption = caption;
|
this.caption = caption;
|
||||||
|
|
||||||
|
/** @property {number|undefined} originalWidth Width of the full-sized file (read from HTML data attribute, might be missing) */
|
||||||
|
this.originalWidth = undefined;
|
||||||
|
|
||||||
|
/** @property {number|undefined} originalHeight Height of the full-sized file (read from HTML data attribute, might be missing) */
|
||||||
|
this.originalHeight = undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
var LIP = LightboxImage.prototype;
|
var LIP = LightboxImage.prototype;
|
||||||
|
|
Loading…
Reference in a new issue