2013-08-07 08:59:08 +00:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
* This file is part of the MediaWiki extension MultimediaViewer.
|
|
|
|
*
|
|
|
|
* MultimediaViewer is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* MultimediaViewer is distributed in the hope that it will be useful,
|
2013-11-23 01:18:25 +00:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2013-08-07 08:59:08 +00:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with MultimediaViewer. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @ingroup extensions
|
|
|
|
* @author Mark Holmquist <mtraceur@member.fsf.org>
|
|
|
|
* @copyright Copyright © 2013, Mark Holmquist
|
|
|
|
*/
|
|
|
|
|
|
|
|
class MultimediaViewerHooks {
|
2013-10-29 20:26:07 +00:00
|
|
|
/** Link to more information about this module */
|
2014-10-22 15:44:23 +00:00
|
|
|
protected static $infoLink = '//mediawiki.org/wiki/Special:MyLanguage/Extension:Media_Viewer/About';
|
2013-10-29 20:26:07 +00:00
|
|
|
|
|
|
|
/** Link to a page where this module can be discussed */
|
2014-10-22 15:44:23 +00:00
|
|
|
protected static $discussionLink = '//mediawiki.org/wiki/Special:MyLanguage/Extension_talk:Media_Viewer/About';
|
2013-08-07 08:59:08 +00:00
|
|
|
|
2014-03-24 13:35:34 +00:00
|
|
|
/** Link to help about this module */
|
2014-10-22 15:44:23 +00:00
|
|
|
protected static $helpLink = '//mediawiki.org/wiki/Special:MyLanguage/Help:Extension:Media_Viewer';
|
2014-03-24 13:35:34 +00:00
|
|
|
|
2014-03-07 01:56:56 +00:00
|
|
|
/**
|
|
|
|
* Checks the context for whether to load the viewer.
|
|
|
|
* @param User $user
|
|
|
|
* @return bool
|
|
|
|
*/
|
2014-03-25 00:09:07 +00:00
|
|
|
protected static function shouldHandleClicks( $user ) {
|
2014-08-10 11:16:01 +00:00
|
|
|
global $wgMediaViewerIsInBeta, $wgMediaViewerEnableByDefaultForAnonymous;
|
2014-03-07 01:56:56 +00:00
|
|
|
|
|
|
|
if ( $wgMediaViewerIsInBeta && class_exists( 'BetaFeatures' ) ) {
|
|
|
|
return BetaFeatures::isFeatureEnabled( $user, 'multimedia-viewer' );
|
|
|
|
}
|
2014-03-14 00:25:33 +00:00
|
|
|
|
2014-08-10 11:16:01 +00:00
|
|
|
if ( !$user->isLoggedIn() && isset( $wgMediaViewerEnableByDefaultForAnonymous ) ) {
|
|
|
|
return (bool)$wgMediaViewerEnableByDefaultForAnonymous;
|
|
|
|
} else {
|
|
|
|
return (bool)$user->getOption( 'multimediaviewer-enable' );
|
2014-03-14 00:25:33 +00:00
|
|
|
}
|
2014-03-07 01:56:56 +00:00
|
|
|
}
|
|
|
|
|
2013-11-04 21:40:31 +00:00
|
|
|
/**
|
|
|
|
* Handler for all places where we add the modules
|
|
|
|
* Could be on article pages or on Category pages
|
2013-10-25 23:27:01 +00:00
|
|
|
* @param OutputPage $out
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-11-04 21:40:31 +00:00
|
|
|
protected static function getModules( &$out ) {
|
2014-03-28 22:39:36 +00:00
|
|
|
$out->addModules( array( 'mmv.head', 'mmv.bootstrap.autostart' ) );
|
2013-11-04 21:40:31 +00:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handler for BeforePageDisplay hook
|
|
|
|
* Add JavaScript to the page when an image is on it
|
|
|
|
* and the user has enabled the feature if BetaFeatures is installed
|
|
|
|
* @param OutputPage $out
|
|
|
|
* @param Skin $skin
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function getModulesForArticle( &$out, &$skin ) {
|
2014-05-16 23:09:14 +00:00
|
|
|
if ( count( $out->getFileSearchOptions() ) > 0 || $out->getTitle()->inNamespace( NS_FILE ) ) {
|
2013-11-04 21:40:31 +00:00
|
|
|
return self::getModules( $out );
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handler for CategoryPageView hook
|
|
|
|
* Add JavaScript to the page if there are images in the category
|
|
|
|
* @param CategoryPage $catPage
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function getModulesForCategory( &$catPage ) {
|
|
|
|
$title = $catPage->getTitle();
|
|
|
|
$cat = Category::newFromTitle( $title );
|
|
|
|
if ( $cat->getFileCount() > 0 ) {
|
|
|
|
$out = $catPage->getContext()->getOutput();
|
|
|
|
return self::getModules( $out );
|
2013-08-07 08:59:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add a beta preference to gate the feature
|
2013-10-29 20:26:07 +00:00
|
|
|
public static function getBetaPreferences( $user, &$prefs ) {
|
2014-03-27 21:01:56 +00:00
|
|
|
global $wgExtensionAssetsPath, $wgMediaViewerIsInBeta;
|
|
|
|
|
|
|
|
if ( !$wgMediaViewerIsInBeta ) {
|
|
|
|
return true;
|
|
|
|
}
|
2013-08-07 08:59:08 +00:00
|
|
|
|
|
|
|
$prefs['multimedia-viewer'] = array(
|
|
|
|
'label-message' => 'multimediaviewer-pref',
|
|
|
|
'desc-message' => 'multimediaviewer-pref-desc',
|
2013-10-29 20:26:07 +00:00
|
|
|
'info-link' => self::$infoLink,
|
|
|
|
'discussion-link' => self::$discussionLink,
|
2014-03-24 13:35:34 +00:00
|
|
|
'help-link' => self::$helpLink,
|
2014-03-27 09:48:59 +00:00
|
|
|
'screenshot' => array(
|
|
|
|
'ltr' => "$wgExtensionAssetsPath/MultimediaViewer/viewer-ltr.svg",
|
|
|
|
'rtl' => "$wgExtensionAssetsPath/MultimediaViewer/viewer-rtl.svg",
|
|
|
|
),
|
2013-08-07 08:59:08 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2013-10-29 20:26:07 +00:00
|
|
|
|
2014-03-14 00:25:33 +00:00
|
|
|
// Adds a default-enabled preference to gate the feature on non-beta sites
|
|
|
|
public static function getPreferences( $user, &$prefs ) {
|
2014-03-27 21:42:22 +00:00
|
|
|
global $wgMediaViewerIsInBeta;
|
|
|
|
|
|
|
|
if ( !$wgMediaViewerIsInBeta ) {
|
|
|
|
$prefs['multimediaviewer-enable'] = array(
|
|
|
|
'type' => 'toggle',
|
|
|
|
'label-message' => 'multimediaviewer-optin-pref',
|
|
|
|
'section' => 'rendering/files',
|
|
|
|
);
|
|
|
|
}
|
2014-03-14 00:25:33 +00:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-10-29 20:26:07 +00:00
|
|
|
/**
|
|
|
|
* Export variables used in both PHP and JS to keep DRY
|
|
|
|
* @param array $vars
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function resourceLoaderGetConfigVars( &$vars ) {
|
2014-09-26 18:37:53 +00:00
|
|
|
global $wgMediaViewerActionLoggingSamplingFactorMap, $wgNetworkPerformanceSamplingFactor,
|
2014-11-06 17:51:08 +00:00
|
|
|
$wgMediaViewerDurationLoggingSamplingFactor, $wgMediaViewerDurationLoggingLoggedinSamplingFactor,
|
|
|
|
$wgMediaViewerAttributionLoggingSamplingFactor, $wgMediaViewerDimensionLoggingSamplingFactor,
|
2014-11-20 23:39:29 +00:00
|
|
|
$wgMediaViewerIsInBeta, $wgMediaViewerUseThumbnailGuessing, $wgMediaViewerImageQueryParameter,
|
|
|
|
$wgMediaViewerRecordViewDuration;
|
|
|
|
|
2013-10-29 20:26:07 +00:00
|
|
|
$vars['wgMultimediaViewer'] = array(
|
|
|
|
'infoLink' => self::$infoLink,
|
|
|
|
'discussionLink' => self::$discussionLink,
|
2014-03-24 13:35:34 +00:00
|
|
|
'helpLink' => self::$helpLink,
|
2014-04-10 01:08:36 +00:00
|
|
|
'useThumbnailGuessing' => (bool)$wgMediaViewerUseThumbnailGuessing,
|
2014-05-19 09:24:54 +00:00
|
|
|
'durationSamplingFactor' => $wgMediaViewerDurationLoggingSamplingFactor,
|
2014-11-06 17:51:08 +00:00
|
|
|
'durationSamplingFactorLoggedin' => $wgMediaViewerDurationLoggingLoggedinSamplingFactor,
|
2014-05-19 09:24:54 +00:00
|
|
|
'networkPerformanceSamplingFactor' => $wgNetworkPerformanceSamplingFactor,
|
|
|
|
'actionLoggingSamplingFactorMap' => $wgMediaViewerActionLoggingSamplingFactorMap,
|
2014-09-05 00:45:36 +00:00
|
|
|
'attributionSamplingFactor' => $wgMediaViewerAttributionLoggingSamplingFactor,
|
2014-09-26 18:37:53 +00:00
|
|
|
'dimensionSamplingFactor' => $wgMediaViewerDimensionLoggingSamplingFactor,
|
2014-11-16 11:31:47 +00:00
|
|
|
'imageQueryParameter' => $wgMediaViewerImageQueryParameter,
|
2014-11-20 23:39:29 +00:00
|
|
|
'recordViewDuration' => $wgMediaViewerRecordViewDuration,
|
2014-05-31 00:18:12 +00:00
|
|
|
'tooltipDelay' => 1000,
|
2013-10-29 20:26:07 +00:00
|
|
|
);
|
2014-03-14 22:19:26 +00:00
|
|
|
$vars['wgMediaViewer'] = true;
|
2014-04-23 20:31:43 +00:00
|
|
|
$vars['wgMediaViewerIsInBeta'] = $wgMediaViewerIsInBeta;
|
2014-03-14 22:19:26 +00:00
|
|
|
|
2013-10-29 20:26:07 +00:00
|
|
|
return true;
|
|
|
|
}
|
2013-11-27 21:57:45 +00:00
|
|
|
|
2014-03-27 22:46:51 +00:00
|
|
|
/**
|
|
|
|
* Export variables which depend on the current user
|
|
|
|
* @param $vars
|
|
|
|
* @param OutputPage $out
|
|
|
|
*/
|
|
|
|
public static function makeGlobalVariablesScript( &$vars, OutputPage $out ) {
|
2014-08-23 17:14:37 +00:00
|
|
|
global $wgDefaultUserOptions;
|
|
|
|
|
2014-03-27 22:46:51 +00:00
|
|
|
$user = $out->getUser();
|
|
|
|
$vars['wgMediaViewerOnClick'] = self::shouldHandleClicks( $user );
|
2014-08-23 17:14:37 +00:00
|
|
|
// needed because of bug 69942; could be different for anon and logged-in
|
|
|
|
$vars['wgMediaViewerEnabledByDefault'] = !empty( $wgDefaultUserOptions['multimediaviewer-enable'] );
|
2014-03-27 22:46:51 +00:00
|
|
|
}
|
|
|
|
|
2013-11-27 21:57:45 +00:00
|
|
|
/**
|
|
|
|
* Get modules for testing our JavaScript
|
|
|
|
* @param array $testModules
|
|
|
|
* @param ResourceLoader resourceLoader
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function getTestModules( array &$testModules, ResourceLoader &$resourceLoader ) {
|
2014-01-23 21:44:26 +00:00
|
|
|
$testModules['qunit']['mmv.tests'] = array(
|
2013-11-27 21:57:45 +00:00
|
|
|
'scripts' => array(
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/mmv.bootstrap.test.js',
|
|
|
|
'tests/qunit/mmv/mmv.test.js',
|
|
|
|
'tests/qunit/mmv/mmv.lightboxinterface.test.js',
|
|
|
|
'tests/qunit/mmv/mmv.lightboximage.test.js',
|
|
|
|
'tests/qunit/mmv/mmv.ThumbnailWidthCalculator.test.js',
|
2014-03-19 02:00:26 +00:00
|
|
|
'tests/qunit/mmv/mmv.EmbedFileFormatter.test.js',
|
2014-06-10 23:29:50 +00:00
|
|
|
'tests/qunit/mmv/mmv.Config.test.js',
|
2014-03-26 23:59:04 +00:00
|
|
|
'tests/qunit/mmv/mmv.HtmlUtils.test.js',
|
2014-09-04 23:00:55 +00:00
|
|
|
'tests/qunit/mmv/logging/mmv.logging.DurationLogger.test.js',
|
|
|
|
'tests/qunit/mmv/logging/mmv.logging.Performance.test.js',
|
|
|
|
'tests/qunit/mmv/logging/mmv.logging.ActionLogger.test.js',
|
2014-09-26 18:37:53 +00:00
|
|
|
'tests/qunit/mmv/logging/mmv.logging.AttributionLogger.test.js',
|
|
|
|
'tests/qunit/mmv/logging/mmv.logging.DimensionLogger.test.js',
|
2014-11-20 23:39:29 +00:00
|
|
|
'tests/qunit/mmv/logging/mmv.logging.ViewLogger.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.test.js',
|
2014-06-11 21:36:54 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.IwTitle.test.js',
|
2014-02-10 21:24:19 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.TaskQueue.test.js',
|
2014-03-20 01:19:54 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.License.test.js',
|
2014-03-21 20:29:55 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.Image.test.js',
|
2014-03-21 01:17:45 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.Repo.test.js',
|
2014-03-21 20:29:55 +00:00
|
|
|
'tests/qunit/mmv/model/mmv.model.EmbedFileInfo.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/provider/mmv.provider.Api.test.js',
|
|
|
|
'tests/qunit/mmv/provider/mmv.provider.ImageInfo.test.js',
|
|
|
|
'tests/qunit/mmv/provider/mmv.provider.FileRepoInfo.test.js',
|
|
|
|
'tests/qunit/mmv/provider/mmv.provider.ThumbnailInfo.test.js',
|
2014-04-09 08:10:21 +00:00
|
|
|
'tests/qunit/mmv/provider/mmv.provider.GuessedThumbnailInfo.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/provider/mmv.provider.UserInfo.test.js',
|
|
|
|
'tests/qunit/mmv/provider/mmv.provider.Image.test.js',
|
2014-04-14 18:32:30 +00:00
|
|
|
'tests/qunit/mmv/routing/mmv.routing.MainFileRoute.test.js',
|
|
|
|
'tests/qunit/mmv/routing/mmv.routing.ThumbnailRoute.test.js',
|
|
|
|
'tests/qunit/mmv/routing/mmv.routing.Router.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.test.js',
|
2014-02-26 20:09:37 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.canvas.test.js',
|
2014-03-28 00:10:04 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.canvasButtons.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.description.test.js',
|
2014-09-16 20:33:05 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.download.pane.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.metadataPanel.test.js',
|
2014-05-05 21:44:27 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.metadataPanelScroller.test.js',
|
2014-04-21 21:48:40 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.progressBar.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.permission.test.js',
|
2014-04-01 01:41:57 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.stripeButtons.test.js',
|
2014-03-17 08:07:53 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.reuse.dialog.test.js',
|
2014-03-19 02:00:26 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.reuse.embed.test.js',
|
2014-03-17 08:07:53 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.reuse.share.test.js',
|
|
|
|
'tests/qunit/mmv/ui/mmv.ui.reuse.tab.test.js',
|
2014-03-31 16:08:02 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.reuse.utils.test.js',
|
2014-10-03 09:15:28 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.tipsyDialog.test.js',
|
2014-03-27 06:05:47 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.truncatableTextField.test.js',
|
2014-10-15 18:06:41 +00:00
|
|
|
'tests/qunit/mmv/ui/mmv.ui.viewingOptions.test.js',
|
2014-02-25 01:54:05 +00:00
|
|
|
'tests/qunit/mmv/mmv.testhelpers.js',
|
2013-11-27 21:57:45 +00:00
|
|
|
),
|
|
|
|
'dependencies' => array(
|
2014-01-23 21:44:26 +00:00
|
|
|
'mmv',
|
2014-02-17 15:09:23 +00:00
|
|
|
'mmv.bootstrap',
|
2014-04-11 14:05:58 +00:00
|
|
|
'mmv.ui.reuse.share',
|
|
|
|
'mmv.ui.reuse.embed',
|
2014-09-16 20:33:05 +00:00
|
|
|
'mmv.ui.download.pane',
|
2014-10-03 09:15:28 +00:00
|
|
|
'mmv.ui.tipsyDialog',
|
2014-04-11 14:58:37 +00:00
|
|
|
'moment',
|
2013-11-27 21:57:45 +00:00
|
|
|
),
|
|
|
|
'localBasePath' => __DIR__,
|
|
|
|
'remoteExtPath' => 'MultimediaViewer',
|
|
|
|
);
|
|
|
|
|
|
|
|
return true;
|
2014-01-31 00:06:33 +00:00
|
|
|
}
|
2014-03-28 10:06:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Modify thumbnail DOM
|
|
|
|
* @param ThumbnailImage $thumbnail
|
|
|
|
* @param array $attribs Attributes of the <img> element
|
2014-04-01 09:56:14 +00:00
|
|
|
* @param array|boolean $linkAttribs Attributes of the wrapping <a> element
|
2014-03-28 10:06:17 +00:00
|
|
|
*/
|
2014-04-01 09:56:14 +00:00
|
|
|
public static function thumbnailBeforeProduceHTML( ThumbnailImage $thumbnail, array &$attribs, &$linkAttribs ) {
|
2014-03-28 10:06:17 +00:00
|
|
|
$file = $thumbnail->getFile();
|
|
|
|
|
|
|
|
if ( $file ) {
|
|
|
|
// At the moment all classes that extend File have getWidth() and getHeight()
|
|
|
|
// but since the File class doesn't have these methods defined, this check
|
|
|
|
// is more future-proof
|
|
|
|
|
|
|
|
if ( method_exists( $file, 'getWidth' ) ) {
|
|
|
|
$attribs['data-file-width'] = $file->getWidth();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( method_exists( $file, 'getHeight' ) ) {
|
|
|
|
$attribs['data-file-height'] = $file->getHeight();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2013-08-07 08:59:08 +00:00
|
|
|
}
|