mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/CategoryTree
synced 2024-11-15 20:09:58 +00:00
0726e27270
added README
187 lines
5.7 KiB
PHP
187 lines
5.7 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Setup and Hooks for the CategoryTree extension, an AJAX based gadget
|
|
* to display the category structure of a wiki
|
|
*
|
|
* @package MediaWiki
|
|
* @subpackage Extensions
|
|
* @author Daniel Kinzler <duesentrieb@brightbyte.de>
|
|
* @copyright © 2006 Daniel Kinzler
|
|
* @licence GNU General Public Licence 2.0 or later
|
|
*/
|
|
|
|
if( !defined( 'MEDIAWIKI' ) ) {
|
|
echo( "This file is an extension to the MediaWiki software and cannot be used standalone.\n" );
|
|
die( 1 );
|
|
}
|
|
|
|
/**
|
|
* Constants for use with efCategoryTreeRenderChildren,
|
|
* defining what should be shown in the tree
|
|
*/
|
|
define('CT_MODE_CATEGORIES', 0);
|
|
define('CT_MODE_PAGES', 10);
|
|
define('CT_MODE_ALL', 20);
|
|
|
|
/**
|
|
* Abort if AJAX is not enabled
|
|
**/
|
|
if ( !$wgUseAjax ) {
|
|
wfDebug( 'CategoryTree: Ajax is not enabled, aborting extension setup.' );
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Options:
|
|
*
|
|
* $wgCategoryTreeMaxChildren - maximum number of children shown in a tree node. Default is 200
|
|
* $wgCategoryTreeAllowTag - enable <categorytree> tag. Default is true.
|
|
* $wgCategoryTreeDynamicTag - loads the first level of the tree in a <categorytag> dynamically.
|
|
* This way, the cache does not need to be disabled. Default is false.
|
|
* $wgCategoryTreeDisableCache - disabled the parser cache for pages with a <categorytree> tag. Default is true.
|
|
*/
|
|
if ( !isset( $wgCategoryTreeMaxChildren ) ) $wgCategoryTreeMaxChildren = 200;
|
|
if ( !isset( $wgCategoryTreeAllowTag ) ) $wgCategoryTreeAllowTag = true;
|
|
if ( !isset( $wgCategoryTreeDisableCache ) ) $wgCategoryTreeDisableCache = true;
|
|
if ( !isset( $wgCategoryTreeDynamicTag ) ) $wgCategoryTreeDynamicTag = false;
|
|
|
|
/**
|
|
* Register extension setup hook and credits
|
|
*/
|
|
$wgExtensionFunctions[] = 'efCategoryTree';
|
|
$wgExtensionCredits['specialpage'][] = array( 'name' => 'CategoryTree', 'author' => 'Daniel Kinzler', 'url' => 'http://meta.wikimedia.org/wiki/CategoryTree_extension' );
|
|
$wgExtensionCredits['parserhook'][] = array( 'name' => 'CategoryTree', 'author' => 'Daniel Kinzler', 'url' => 'http://meta.wikimedia.org/wiki/CategoryTree_extension' );
|
|
|
|
/**
|
|
* Register the special page
|
|
*/
|
|
$wgAutoloadClasses['CategoryTree'] = dirname( __FILE__ ) . '/CategoryTreePage.php';
|
|
$wgSpecialPages['CategoryTree'] = 'CategoryTree';
|
|
$wgHooks['SkinTemplateTabs'][] = 'efCategoryTreeInstallTabs';
|
|
|
|
/**
|
|
* register Ajax function
|
|
*/
|
|
$wgAjaxExportList[] = 'efCategoryTreeAjaxWrapper';
|
|
|
|
/**
|
|
* Internal state
|
|
*/
|
|
$wgCategoryTreeHeaderDone = false; #set to true by efCategoryTreeHeader after registering the code
|
|
$wgCategoryTreeMessagesDone = false; #set to true by efInjectCategoryTreeMessages after registering the messages
|
|
|
|
/**
|
|
* Hook it up
|
|
*/
|
|
function efCategoryTree() {
|
|
global $wgParser, $wgCategoryTreeAllowTag;
|
|
|
|
if ( $wgCategoryTreeAllowTag ) $wgParser->setHook( 'categorytree' , 'efCategoryTreeParserHook' );
|
|
}
|
|
|
|
/**
|
|
* Entry point for Ajax, registered in $wgAjaxExportList.
|
|
* This loads CategoryTreeFunctions.php and calls efCategoryTreeAjax()
|
|
*/
|
|
function efCategoryTreeAjaxWrapper( $category, $mode = CT_MODE_CATEGORIES ) {
|
|
require_once( dirname( __FILE__ ) . '/CategoryTreeFunctions.php' );
|
|
|
|
return efCategoryTreeAjax( $category, $mode );
|
|
}
|
|
|
|
/**
|
|
* Entry point for the <categorytree> tag parser hook.
|
|
* This loads CategoryTreeFunctions.php and calls efCategoryTreeTag()
|
|
*/
|
|
function efCategoryTreeParserHook( $cat, $argv ) {
|
|
require_once( dirname( __FILE__ ) . '/CategoryTreeFunctions.php' );
|
|
|
|
$style= @$argv[ 'style' ];
|
|
|
|
$mode= @$argv[ 'mode' ];
|
|
if ( $mode !== NULL ) {
|
|
$mode= trim( strtolower( $mode ) );
|
|
|
|
if ( $mode == 'all' ) $mode = CT_MODE_ALL;
|
|
else if ( $mode == 'pages' ) $mode = CT_MODE_PAGES;
|
|
else if ( $mode == 'categories' ) $mode = CT_MODE_CATEGORIES;
|
|
}
|
|
else {
|
|
$mode = CT_MODE_CATEGORIES;
|
|
}
|
|
|
|
$hideroot = @$argv[ 'hideroot' ];
|
|
if ( $hideroot !== NULL ) {
|
|
$hideroot = trim( strtolower( $hideroot ) );
|
|
|
|
if ( $hideroot === '1' || $hideroot === 'yes' || $hideroot === 'on' || $hideroot === 'true' ) $hideroot = true;
|
|
else if ( $hideroot === '0' || $hideroot === 'no' || $hideroot === 'off' || $hideroot === 'false' ) $hideroot = false;
|
|
}
|
|
|
|
return efCategoryTreeTag( $cat, $mode, $hideroot, $style );
|
|
}
|
|
|
|
/**
|
|
* Hook callback that installs a tab for CategoryTree on Category pages
|
|
*/
|
|
function efCategoryTreeInstallTabs( &$skin, &$content_actions ) {
|
|
global $wgTitle;
|
|
|
|
if ( $wgTitle->getNamespace() != NS_CATEGORY ) return true;
|
|
|
|
$special = Title::makeTitle( NS_SPECIAL, 'CategoryTree' );
|
|
|
|
efInjectCategoryTreeMessages();
|
|
|
|
$content_actions['categorytree'] = array(
|
|
'class' => false,
|
|
'text' => wfMsgHTML( 'categorytree-tab' ),
|
|
'href' => $special->getLocalUrl() . '/' . $wgTitle->getPartialURL() );
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* inject messages used by CategoryTree into the message cache
|
|
*/
|
|
function efInjectCategoryTreeMessages() {
|
|
global $wgMessageCache, $wgCategoryTreeMessagesDone;
|
|
|
|
if ( $wgCategoryTreeMessagesDone ) return;
|
|
else $wgCategoryTreeMessagesDone = true;
|
|
|
|
$msg = efLoadCategoryTreeMessages();
|
|
$wgMessageCache->addMessages( $msg );
|
|
}
|
|
|
|
/**
|
|
* load the CategoryTree internationalization file
|
|
*/
|
|
function efLoadCategoryTreeMessages() {
|
|
global $wgLanguageCode, $wgContLang;
|
|
|
|
$messages= array();
|
|
|
|
$f= dirname( __FILE__ ) . '/CategoryTree.i18n.php';
|
|
include( $f );
|
|
|
|
$f= dirname( __FILE__ ) . '/CategoryTree.i18n.' . $wgContLang->getCode() . '.php';
|
|
if ( file_exists( $f ) ) include( $f );
|
|
|
|
return $messages;
|
|
}
|
|
|
|
/**
|
|
* Creates a Title object from a user provided (and thus unsafe) string
|
|
*/
|
|
function & efCategoryTreeMakeTitle( $title ) {
|
|
global $wgContLang, $wgCanonicalNamespaceNames;
|
|
|
|
#HACK to strip redundant namespace name
|
|
$title = preg_replace( '~^\s*(' . $wgCanonicalNamespaceNames[ NS_CATEGORY ] . '|' . $wgContLang->getNsText( NS_CATEGORY ) . ')\s*:\s*~i', '', $title );
|
|
|
|
$t = Title::makeTitleSafe( NS_CATEGORY, $title );
|
|
return $t;
|
|
}
|
|
|
|
?>
|