Difference between revisions of "Extension:Wikiskin.php"
(0.1.5) |
(0.1.6 - login/logout problem fixed) |
||
Line 8: | Line 8: | ||
if (!defined('MEDIAWIKI')) die('Not an entry point.'); | if (!defined('MEDIAWIKI')) die('Not an entry point.'); | ||
− | define('WIKISKIN_VERSION','0.1. | + | define('WIKISKIN_VERSION','0.1.6, 2007-07-18'); |
$wgWikiSkinArticle = isset($_REQUEST['skin']) ? $_REQUEST['skin'] : 'WikiSkin'; | $wgWikiSkinArticle = isset($_REQUEST['skin']) ? $_REQUEST['skin'] : 'WikiSkin'; | ||
Line 227: | Line 227: | ||
} # end of class definition | } # end of class definition | ||
− | # Make the new skin current | + | # Make the new skin current (now and after login/logout) |
+ | wfApplyWikiSkin(); | ||
+ | global $wgHooks; | ||
+ | $wgHooks['UserLoginComplete'][] = 'wfApplyWikiSkin'; | ||
+ | $wgHooks['UserLogoutComplete'][] = 'wfApplyWikiSkin'; | ||
+ | |||
+ | |||
+ | } # end of setup function | ||
+ | |||
+ | |||
+ | function wfApplyWikiSkin() { | ||
global $wgUser; | global $wgUser; | ||
$wgUser->setOption('skin','WikiSkin'); | $wgUser->setOption('skin','WikiSkin'); | ||
$wgUser->mSkin =& new SkinWikiSkin; | $wgUser->mSkin =& new SkinWikiSkin; | ||
− | + | return true; | |
− | } | + | } |
− | |||
?> | ?> |
Revision as of 01:02, 18 July 2007
<?php
- Extension:WikiSkinTemplate:Php
- - Uses a wikitext article for the skin instead of a PHP file. Special items like search box and login link use magic words
- - See http://www.mediawiki.org/wiki/Extension:WikiSkin for installation and usage details
- - Licenced under LGPL (http://www.gnu.org/copyleft/lesser.html)
- - Author: http://www.organicdesign.co.nz/nad
if (!defined('MEDIAWIKI')) die('Not an entry point.');
define('WIKISKIN_VERSION','0.1.6, 2007-07-18');
$wgWikiSkinArticle = isset($_REQUEST['skin']) ? $_REQUEST['skin'] : 'WikiSkin'; $wgWikiSkinMagic = array( 'CURRENTUSER', 'TITLE', 'SUBTITLE', 'SITELOGO', 'TEXT', 'SEARCH', 'PERSONAL', 'LOGIN', 'ACTIONS', 'SITENOTICE', 'INFO', 'CATLINKS', 'FOOTER' );
$wgExtensionFunctions[] = 'wfSetupWikiSkin'; $wgHooks['MagicWordMagicWords'][] = 'wfWikiSkinMagicWord'; $wgHooks['MagicWordwgVariableIDs'][] = 'wfWikiSkinVariableID'; $wgHooks['LanguageGetMagic'][] = 'wfWikiSkinLangMagic'; $wgHooks['ParserGetVariableValueSwitch'][] = 'wfWikiSkinGetVariable';
$wgExtensionCredits['other'][] = array( 'name' => 'WikiSkin', 'author' => 'User:Nad', 'description' => 'Allows normal wikitext articles to define skin content and layout', 'url' => 'http://www.mediawiki.org/wiki/Extension:WikiSkin', 'version' => WIKISKIN_VERSION );
function wfWikiSkinMagicWord(&$magicWords) { global $wgWikiSkinMagic; foreach($wgWikiSkinMagic as $var) $magicWords[] = "MAG_$var"; return true; }
function wfWikiSkinVariableID(&$variables) { global $wgWikiSkinMagic; foreach($wgWikiSkinMagic as $var) $variables[] = constant("MAG_$var"); return true; }
function wfWikiSkinLangMagic(&$langMagic, $langCode = 0) { global $wgWikiSkinMagic; foreach($wgWikiSkinMagic as $var) { $magic = "MAG_$var"; $langMagic[defined($magic) ? constant($magic) : $magic] = array(0,$var); } return true; }
function wfWikiSkinGetVariable(&$parser,&$cache,&$index,&$ret) { switch ($index) {
case MAG_CURRENTUSER: $parser->disableCache(); $ret = $GLOBALS['wgUser']->mName; break;
# These ones are all replaced by a token to be filled by skin when rendering page case MAG_TITLE: case MAG_SUBTITLE: case MAG_SITELOGO: case MAG_TEXT: case MAG_SEARCH: case MAG_PERSONAL: case MAG_LOGIN: case MAG_ACTIONS: case MAG_SITENOTICE: case MAG_INFO: case MAG_CATLINKS: case MAG_FOOTER: $magic = constant($index); $ret = "((((WikiSkin:$magic))))"; break; } return true; }
- Define new skin class, create an instance and make it current
function wfSetupWikiSkin() {
# Create skin class based on monobook which parses the skin article and embeds the content class SkinWikiSkin extends SkinTemplate {
function initPage(&$out) { SkinTemplate::initPage($out); $this->skinname = 'wikiskin'; $this->stylename = 'wikiskin'; $this->template = 'WikiSkinTemplate'; }
}
class WikiSkinTemplate extends QuickTemplate { function execute() {
# Build the HTML, HEAD and BODY elements and send to output wfSuppressWarnings();
?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> text('lang') ?>" lang="text('lang') ?>" dir="text('dir') ?>"> html('headlinks') ?>
'.htmlspecialchars($this->translator->translate('tagline')).'
' . '- ';
foreach ($this->data['content_actions'] as $key => $tab)
$replace['ACTIONS'] .= '
- '.htmlspecialchars($tab['text']).' '; $replace['ACTIONS'] .= '
- ';
foreach ($this->data['personal_urls'] as $key => $item) {
$replace['PERSONAL'] .= '
- '.htmlspecialchars($item['text']).' '; if ($key == 'pt-login' || $key == 'pt-anonlogin') $replace['LOGIN'] = ''.htmlspecialchars($item['text']).''; } $replace['PERSONAL'] .= '
html('reporttime') ?> <?php
wfRestoreWarnings();
}
} # end of class definition
# Make the new skin current (now and after login/logout) wfApplyWikiSkin(); global $wgHooks; $wgHooks['UserLoginComplete'][] = 'wfApplyWikiSkin'; $wgHooks['UserLogoutComplete'][] = 'wfApplyWikiSkin';
} # end of setup function
function wfApplyWikiSkin() {
global $wgUser;
$wgUser->setOption('skin','WikiSkin');
$wgUser->mSkin =& new SkinWikiSkin;
return true;
}
?>