Difference between revisions of "Extension:Wikiskin.php"
m |
m |
||
Line 127: | Line 127: | ||
# Build list of special fields and their content | # Build list of special fields and their content | ||
$replace = array(); | $replace = array(); | ||
+ | /* | ||
$replace['SEARCH'] = '<div id="p-search" class="portlet">' | $replace['SEARCH'] = '<div id="p-search" class="portlet">' | ||
.'<h5><label for="searchInput">'.$this->msg('search').'</label></h5>' | .'<h5><label for="searchInput">'.$this->msg('search').'</label></h5>' | ||
Line 144: | Line 145: | ||
$replace['SITENOTICE'] = $this->data['sitenotice'] ? '<div id="siteNotice">'.$this->html('sitenotice').'</div>' : ''; | $replace['SITENOTICE'] = $this->data['sitenotice'] ? '<div id="siteNotice">'.$this->html('sitenotice').'</div>' : ''; | ||
− | + | */ | |
$replace['SUBTITLE'] = '<h3 id="siteSub">'.$this->msg('tagline').'</h3><div id="contentSub">'.$this->html('subtitle').'</div>'; | $replace['SUBTITLE'] = '<h3 id="siteSub">'.$this->msg('tagline').'</h3><div id="contentSub">'.$this->html('subtitle').'</div>'; | ||
Line 153: | Line 154: | ||
.', <a href="#searchInput">'.$this->msg('jumptosearch').'</a></div>' : ''); | .', <a href="#searchInput">'.$this->msg('jumptosearch').'</a></div>' : ''); | ||
− | + | $replace['TEXT'] = $this->html('bodytext'); | |
$replace['CATLINKS'] = $this->html('catlinks') ? '<div id="catlinks">'.$this->html('catlinks').'</div>' : ''; | $replace['CATLINKS'] = $this->html('catlinks') ? '<div id="catlinks">'.$this->html('catlinks').'</div>' : ''; |
Revision as of 06:59, 6 April 2007
<?
- Extension:WikiSkin
- - Uses a wikitext article for the skin instead of a PHP file. Special items like search box and login link use magic words
- - Version 0.1 (2007-04-06)
- - 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
$wgWikiSkinArticle = isset($_REQUEST['skin']) ? $_REQUEST['skin'] : 'WikiSkin'; $wgWikiSkinMagic = array('SITELOGO','TEXT','SEARCH','PERSONAL','ACTIONS','SITENOTICE','SUBTITLE','INFO','CATLINKS','FOOTER');
$wgExtensionFunctions[] = 'wfSetupWikiSkin'; $wgHooks['MagicWordMagicWords'][] = 'wfWikiSkinMagicWord'; $wgHooks['MagicWordwgVariableIDs'][] = 'wfWikiSkinVariableID'; $wgHooks['LanguageGetMagic'][] = 'wfWikiSkinLangMagic'; $wgHooks['ParserGetVariableValueSwitch'][] = 'wfWikiSkinGetVariable';
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(&$this,&$cache,&$index,&$ret) { switch ($index) {
case MAG_CURRENTUSER: $ret = $GLOBALS['wgUser']->mName; break;
# These ones are all replaced by a token to be filled by skin when rendering page case MAG_SITELOGO: case MAG_TEXT: case MAG_SEARCH: case MAG_PERSONAL: case MAG_ACTIONS: case MAG_SITENOTICE: case MAG_SUBTITLE: 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') ?>
'; $replace['SITELOGO'] = '
' .'
'; $replace['SITENOTICE'] = $this->data['sitenotice'] ? '
' : ''; */ $replace['SUBTITLE'] = '
'.$this->msg('tagline').'
'; $replace['INFO'] = ($this->data['undelete'] ? '
' : '') .($this->data['newtalk'] ? '
' : '') .($this->data['showjumplinks'] ? '
' : ''); $replace['TEXT'] = $this->html('bodytext'); $replace['CATLINKS'] = $this->html('catlinks') ? '
' : ''; $replace['ACTIONS'] = '
- ';
foreach ($this->data['content_actions'] as $key => $tab) $replace['ACTIONS'] .=
'
- '.htmlspecialchars($tab['text']).' '; $replace['ACTIONS'] .= '
'; $replace['PERSONAL'] = '
- ';
foreach ($this->data['personal_urls'] as $key => $item) $replace['PERSONAL'] .=
'
- '.htmlspecialchars($item['text']).' '; $replace['PERSONAL'] .= '
'; # Read and parse the skin article global $wgUser,$wgTitle,$wgParser,$wgWikiSkinArticle; $skin = new Article(Title::newFromText($wgWikiSkinArticle)); $opt = ParserOptions::newFromUser($wgUser); $out = $wgParser->parse($skin->fetchContent(0,false,false),$wgTitle,$opt,true,true); $content = preg_replace('/<\\/?p>/','',$out->getText()); # parser adding damn p's # Replace all the fields and send to output echo preg_replace('/\\({4}WikiSkin:MAG_(.+?)\\){4}/ie','$replace["$1"]',$content); ?>
html('reporttime') ?> <?php
wfRestoreWarnings();
}
} # end of class definition
# Make the new skin current global $wgUser; $wgUser->setOption('skin','WikiSkin'); $wgUser->mSkin =& new SkinWikiSkin;
} # end of setup function
?>