From 0749c4f3154afb8f7ab4bf858fbb6082e35cc0f2 Mon Sep 17 00:00:00 2001 From: Brion Vibber Date: Fri, 19 Nov 2004 04:14:59 +0000 Subject: [PATCH] Convert MonoBook to pure PHP, not requiring PHPTAL. Right now the code is ugly, pretty much a straight convert. Will pretty up later. --- includes/SkinPHPTal.php | 703 +-------------------------------- includes/SkinTemplate.php | 789 ++++++++++++++++++++++++++++++++++++++ includes/User.php | 2 +- skins/MonoBook.php | 163 +++++++- skins/MonoBookTal.php | 37 ++ 5 files changed, 988 insertions(+), 706 deletions(-) create mode 100644 includes/SkinTemplate.php create mode 100644 skins/MonoBookTal.php diff --git a/includes/SkinPHPTal.php b/includes/SkinPHPTal.php index 110707c392..944612ef0e 100644 --- a/includes/SkinPHPTal.php +++ b/includes/SkinPHPTal.php @@ -38,6 +38,7 @@ if( defined( 'MEDIAWIKI' ) ) { require_once 'GlobalFunctions.php'; +require_once 'SkinTemplate.php'; if( version_compare( phpversion(), "5.0", "lt" ) ) { define( 'OLD_PHPTAL', true ); @@ -50,64 +51,11 @@ if( version_compare( phpversion(), "5.0", "lt" ) ) { require_once 'PHPTAL.php'; } -/** - * @todo document - * @package MediaWiki - */ -// PHPTAL 1.0 no longer has the PHPTAL_I18N stub class. -//class MediaWiki_I18N extends PHPTAL_I18N { -class MediaWiki_I18N { - var $_context = array(); - - function set($varName, $value) { - $this->_context[$varName] = $value; - } - - function translate($value) { - // Hack for i18n:attributes in PHPTAL 1.0.0 dev version as of 2004-10-23 - $value = preg_replace( '/^string:/', '', $value ); - - $value = wfMsg( $value ); - // interpolate variables - while (preg_match('/\$([0-9]*?)/sm', $value, $m)) { - list($src, $var) = $m; - wfSuppressWarnings(); - $varValue = $this->_context[$var]; - wfRestoreWarnings(); - $value = str_replace($src, $varValue, $value); - } - return $value; - } -} /** * * @package MediaWiki */ -class SkinPHPTal extends Skin { - /**#@+ - * @access private - */ - - /** - * Name of our skin, set in initPage() - * It probably need to be all lower case. - */ - var $skinname; - - /** - * Stylesheets set to use - * Sub directory in ./skins/ where various stylesheets are located - */ - var $stylename; - - /** - * PHPTal template to be used. - * '.pt' will be automaticly added to it on PHPTAL object creation - */ - var $template; - - /**#@-*/ - +class SkinPHPTal extends SkinTemplate { /** */ function initPage( &$out ) { parent::initPage( $out ); @@ -124,653 +72,10 @@ class SkinPHPTal extends Skin { */ function &setupTemplate( $file, $repository=false, $cache_dir=false ) { if( defined( 'NEW_PHPTAL' ) ) { - return new PHPTAL_version_bridge( $file, $repository, $cache_dir ); - } else { - return new PHPTAL( $file, $repository, $cache_dir ); - } - } - - /** - * initialize various variables and generate the template - */ - function outputPage( &$out ) { - global $wgTitle, $wgArticle, $wgUser, $wgLang, $wgContLang, $wgOut; - global $wgScript, $wgStylePath, $wgLanguageCode, $wgContLanguageCode, $wgUseNewInterlanguage; - global $wgMimeType, $wgOutputEncoding, $wgUseDatabaseMessages, $wgRequest; - global $wgDisableCounters, $wgLogo, $action, $wgFeedClasses, $wgSiteNotice; - global $wgMaxCredits, $wgShowCreditsIfMax; - - extract( $wgRequest->getValues( 'oldid', 'diff' ) ); - - $this->initPage( $out ); - $tpl =& $this->setupTemplate( $this->template . '.pt', 'skins' ); - - #if ( $wgUseDatabaseMessages ) { // uncomment this to fall back to GetText - $tpl->setTranslator(new MediaWiki_I18N()); - #} - - $this->thispage = $wgTitle->getPrefixedDbKey(); - $this->thisurl = $wgTitle->getPrefixedURL(); - $this->loggedin = $wgUser->getID() != 0; - $this->iscontent = ($wgTitle->getNamespace() != Namespace::getSpecial() ); - $this->iseditable = ($this->iscontent and !($action == 'edit' or $action == 'submit')); - $this->username = $wgUser->getName(); - $this->userpage = $wgContLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); - $this->userpageUrlDetails = $this->makeUrlDetails($this->userpage); - - $this->usercss = $this->userjs = $this->userjsprev = false; - $this->setupUserCss(); - $this->setupUserJs(); - $this->titletxt = $wgTitle->getPrefixedText(); - - $tpl->set( 'title', $wgOut->getPageTitle() ); - $tpl->set( 'pagetitle', $wgOut->getHTMLTitle() ); - - $tpl->setRef( "thispage", $this->thispage ); - $subpagestr = $this->subPageSubtitle(); - $tpl->set( - 'subtitle', !empty($subpagestr)? - ''.$subpagestr.''.$out->getSubtitle(): - $out->getSubtitle() - ); - $undelete = $this->getUndeleteLink(); - $tpl->set( - "undelete", !empty($undelete)? - ''.$undelete.'': - '' - ); - - $tpl->set( 'catlinks', $this->getCategories()); - if( $wgOut->isSyndicated() ) { - $feeds = array(); - foreach( $wgFeedClasses as $format => $class ) { - $feeds[$format] = array( - 'text' => $format, - 'href' => $wgRequest->appendQuery( "feed=$format" ), - 'ttip' => wfMsg('tooltip-'.$format) - ); - } - $tpl->setRef( 'feeds', $feeds ); - } else { - $tpl->set( 'feeds', false ); - } - $tpl->setRef( 'mimetype', $wgMimeType ); - $tpl->setRef( 'charset', $wgOutputEncoding ); - $tpl->set( 'headlinks', $out->getHeadLinks() ); - $tpl->setRef( 'wgScript', $wgScript ); - $tpl->setRef( 'skinname', $this->skinname ); - $tpl->setRef( 'stylename', $this->stylename ); - $tpl->setRef( 'loggedin', $this->loggedin ); - $tpl->set('nsclass', 'ns-'.$wgTitle->getNamespace()); - $tpl->set('notspecialpage', $wgTitle->getNamespace() != NS_SPECIAL); - /* XXX currently unused, might get useful later - $tpl->set( "editable", ($wgTitle->getNamespace() != NS_SPECIAL ) ); - $tpl->set( "exists", $wgTitle->getArticleID() != 0 ); - $tpl->set( "watch", $wgTitle->userIsWatching() ? "unwatch" : "watch" ); - $tpl->set( "protect", count($wgTitle->getRestrictions()) ? "unprotect" : "protect" ); - $tpl->set( "helppage", wfMsg('helppage')); - */ - $tpl->set( 'searchaction', $this->escapeSearchLink() ); - $tpl->setRef( 'stylepath', $wgStylePath ); - $tpl->setRef( 'logopath', $wgLogo ); - $tpl->setRef( "lang", $wgContLanguageCode ); - $tpl->set( 'dir', $wgContLang->isRTL() ? "rtl" : "ltr" ); - $tpl->set( 'rtl', $wgContLang->isRTL() ); - $tpl->set( 'langname', $wgContLang->getLanguageName( $wgContLanguageCode ) ); - $tpl->setRef( 'username', $this->username ); - $tpl->setRef( 'userpage', $this->userpage); - $tpl->setRef( 'userpageurl', $this->userpageUrlDetails['href']); - $tpl->setRef( 'usercss', $this->usercss); - $tpl->setRef( 'userjs', $this->userjs); - $tpl->setRef( 'userjsprev', $this->userjsprev); - global $wgUseSiteJs; - if ($wgUseSiteJs) { - if($this->loggedin) { - $tpl->set( 'jsvarurl', $this->makeUrl('-','action=raw&smaxage=0&gen=js') ); - } else { - $tpl->set( 'jsvarurl', $this->makeUrl('-','action=raw&gen=js') ); - } - } else { - $tpl->set('jsvarurl', false); - } - if( $wgUser->getNewtalk() ) { - $usertitle = Title::newFromText( $this->userpage ); - $usertalktitle = $usertitle->getTalkPage(); - if($usertalktitle->getPrefixedDbKey() != $this->thispage){ - - $ntl = wfMsg( 'newmessages', - $this->makeKnownLink( - $wgContLang->getNsText( Namespace::getTalk( Namespace::getUser() ) ) - . ':' . $this->username, - wfMsg('newmessageslink') ) - ); - # Disable Cache - $wgOut->setSquidMaxage(0); - } - } else { - $ntl = ''; - } - - $tpl->setRef( 'newtalk', $ntl ); - $tpl->setRef( 'skin', $this); - $tpl->set( 'logo', $this->logoText() ); - if ( $wgOut->isArticle() and (!isset( $oldid ) or isset( $diff )) and 0 != $wgArticle->getID() ) { - if ( !$wgDisableCounters ) { - $viewcount = $wgLang->formatNum( $wgArticle->getCount() ); - if ( $viewcount ) { - $tpl->set('viewcount', wfMsg( "viewcount", $viewcount )); - } else { - $tpl->set('viewcount', false); - } - } - $tpl->set('lastmod', $this->lastModified()); - $tpl->set('copyright',$this->getCopyright()); - - $this->credits = false; - - if (isset($wgMaxCredits) && $wgMaxCredits != 0) { - require_once("Credits.php"); - $this->credits = getCredits($wgArticle, $wgMaxCredits, $wgShowCreditsIfMax); - } - - $tpl->setRef( 'credits', $this->credits ); - - } elseif ( isset( $oldid ) && !isset( $diff ) ) { - $tpl->set('copyright', $this->getCopyright()); - $tpl->set('viewcount', false); - $tpl->set('lastmod', false); - $tpl->set('credits', false); - } else { - $tpl->set('copyright', false); - $tpl->set('viewcount', false); - $tpl->set('lastmod', false); - $tpl->set('credits', false); - } - - $tpl->set( 'copyrightico', $this->getCopyrightIcon() ); - $tpl->set( 'poweredbyico', $this->getPoweredBy() ); - $tpl->set( 'disclaimer', $this->disclaimerLink() ); - $tpl->set( 'about', $this->aboutLink() ); - - $tpl->setRef( 'debug', $out->mDebugtext ); - $tpl->set( 'reporttime', $out->reportTime() ); - $tpl->set( 'sitenotice', $wgSiteNotice ); - - $printfooter = "
\n" . $this->printSource() . "
\n"; - $out->mBodytext .= $printfooter ; - $tpl->setRef( 'bodytext', $out->mBodytext ); - - # Language links - $language_urls = array(); - foreach( $wgOut->getLanguageLinks() as $l ) { - $nt = Title::newFromText( $l ); - $language_urls[] = array('href' => $nt->getFullURL(), - 'text' => ($wgContLang->getLanguageName( $nt->getInterwiki()) != ''?$wgContLang->getLanguageName( $nt->getInterwiki()) : $l), - 'class' => $wgContLang->isRTL() ? 'rtl' : 'ltr'); - } - if(count($language_urls)) { - $tpl->setRef( 'language_urls', $language_urls); + return new PHPTAL_version_bridge( $file . '.pt', $repository, $cache_dir ); } else { - $tpl->set('language_urls', false); + return new PHPTAL( $file . '.pt', $repository, $cache_dir ); } - - # Personal toolbar - $tpl->set('personal_urls', $this->buildPersonalUrls()); - $content_actions = $this->buildContentActionUrls(); - $tpl->setRef('content_actions', $content_actions); - // XXX: attach this from javascript, same with section editing - if($this->iseditable && $wgUser->getOption("editondblclick") ) - { - $tpl->set('body_ondblclick', 'document.location = "' .$content_actions['edit']['href'] .'";'); - } else { - $tpl->set('body_ondblclick', false); - } - $tpl->set( 'navigation_urls', $this->buildNavigationUrls() ); - $tpl->set( 'nav_urls', $this->buildNavUrls() ); - - // execute template - $res = $tpl->execute(); - // result may be an error - if (PEAR::isError($res)) { - echo $res->toString(), "\n"; - } else { - echo $res; - } - - } - - /** - * build array of urls for personal toolbar - */ - function buildPersonalUrls() { - /* set up the default links for the personal toolbar */ - global $wgShowIPinHeader; - $personal_urls = array(); - if ($this->loggedin) { - $personal_urls['userpage'] = array( - 'text' => $this->username, - 'href' => &$this->userpageUrlDetails['href'], - 'class' => $this->userpageUrlDetails['exists']?false:'new' - ); - $usertalkUrlDetails = $this->makeTalkUrlDetails($this->userpage); - $personal_urls['mytalk'] = array( - 'text' => wfMsg('mytalk'), - 'href' => &$usertalkUrlDetails['href'], - 'class' => $usertalkUrlDetails['exists']?false:'new' - ); - $personal_urls['preferences'] = array( - 'text' => wfMsg('preferences'), - 'href' => $this->makeSpecialUrl('Preferences') - ); - $personal_urls['watchlist'] = array( - 'text' => wfMsg('watchlist'), - 'href' => $this->makeSpecialUrl('Watchlist') - ); - $personal_urls['mycontris'] = array( - 'text' => wfMsg('mycontris'), - 'href' => $this->makeSpecialUrl('Contributions','target=' . urlencode( $this->username ) ) - ); - $personal_urls['logout'] = array( - 'text' => wfMsg('userlogout'), - 'href' => $this->makeSpecialUrl('Userlogout','returnto=' . $this->thisurl ) - ); - } else { - if( $wgShowIPinHeader && isset( $_COOKIE[ini_get("session.name")] ) ) { - $personal_urls['anonuserpage'] = array( - 'text' => $this->username, - 'href' => &$this->userpageUrlDetails['href'], - 'class' => $this->userpageUrlDetails['exists']?false:'new' - ); - $usertalkUrlDetails = $this->makeTalkUrlDetails($this->userpage); - $personal_urls['anontalk'] = array( - 'text' => wfMsg('anontalk'), - 'href' => &$usertalkUrlDetails['href'], - 'class' => $usertalkUrlDetails['exists']?false:'new' - ); - $personal_urls['anonlogin'] = array( - 'text' => wfMsg('userlogin'), - 'href' => $this->makeSpecialUrl('Userlogin', 'returnto=' . $this->thisurl ) - ); - } else { - - $personal_urls['login'] = array( - 'text' => wfMsg('userlogin'), - 'href' => $this->makeSpecialUrl('Userlogin', 'returnto=' . $this->thisurl ) - ); - } - } - - return $personal_urls; - } - - /** - * an array of edit links by default used for the tabs - */ - function buildContentActionUrls () { - global $wgTitle, $wgUser, $wgOut, $wgRequest, $wgUseValidation; - $action = $wgRequest->getText( 'action' ); - $section = $wgRequest->getText( 'section' ); - $oldid = $wgRequest->getVal( 'oldid' ); - $diff = $wgRequest->getVal( 'diff' ); - $content_actions = array(); - - if( $this->iscontent and !$wgOut->isQuickbarSuppressed() ) { - - $nskey = $this->getNameSpaceKey(); - $is_active = !Namespace::isTalk( $wgTitle->getNamespace()) ; - if ( $action == 'validate' ) $is_active = false ; # Show article tab deselected when validating - $content_actions[$nskey] = array('class' => ($is_active) ? 'selected' : false, - 'text' => wfMsg($nskey), - 'href' => $this->makeArticleUrl($this->thispage)); - - /* set up the classes for the talk link */ - $talk_class = (Namespace::isTalk( $wgTitle->getNamespace()) ? 'selected' : false); - $talktitle = Title::newFromText( $this->titletxt ); - $talktitle = $talktitle->getTalkPage(); - $this->checkTitle($talktitle, $this->titletxt); - if($talktitle->getArticleId() != 0) { - $content_actions['talk'] = array( - 'class' => $talk_class, - 'text' => wfMsg('talk'), - 'href' => $this->makeTalkUrl($this->titletxt) - ); - } else { - $content_actions['talk'] = array( - 'class' => $talk_class?$talk_class.' new':'new', - 'text' => wfMsg('talk'), - 'href' => $this->makeTalkUrl($this->titletxt,'action=edit') - ); - } - - if ( $wgTitle->userCanEdit() ) { - $oid = ( $oldid && ! isset( $diff ) ) ? '&oldid='.IntVal( $oldid ) : false; - $istalk = ( Namespace::isTalk( $wgTitle->getNamespace()) ); - $istalkclass = $istalk?' istalk':''; - $content_actions['edit'] = array( - 'class' => ((($action == 'edit' or $action == 'submit') and $section != 'new') ? 'selected' : '').$istalkclass, - 'text' => wfMsg('edit'), - 'href' => $this->makeUrl($this->thispage, 'action=edit'.$oid) - ); - if ( $istalk ) { - $content_actions['addsection'] = array( - 'class' => $section == 'new'?'selected':false, - 'text' => wfMsg('addsection'), - 'href' => $this->makeUrl($this->thispage, 'action=edit§ion=new') - ); - } - } else { - $oid = ( $oldid && ! isset( $diff ) ) ? '&oldid='.IntVal( $oldid ) : ''; - $content_actions['viewsource'] = array('class' => ($action == 'edit') ? 'selected' : false, - 'text' => wfMsg('viewsource'), - 'href' => $this->makeUrl($this->thispage, 'action=edit'.$oid)); - } - - if ( $wgTitle->getArticleId() ) { - - $content_actions['history'] = array('class' => ($action == 'history') ? 'selected' : false, - 'text' => wfMsg('history_short'), - 'href' => $this->makeUrl($this->thispage, 'action=history')); - - # XXX: is there a rollback action anywhere or is it planned? - # Don't recall where i got this from... - /*if( $wgUser->getNewtalk() ) { - $content_actions['rollback'] = array('class' => ($action == 'rollback') ? 'selected' : false, - 'text' => wfMsg('rollback_short'), - 'href' => $this->makeUrl($this->thispage, 'action=rollback'), - 'ttip' => wfMsg('tooltip-rollback'), - 'akey' => wfMsg('accesskey-rollback')); - } - */ - - if($wgUser->isAllowed('protect')){ - if(!$wgTitle->isProtected()){ - $content_actions['protect'] = array( - 'class' => ($action == 'protect') ? 'selected' : false, - 'text' => wfMsg('protect'), - 'href' => $this->makeUrl($this->thispage, 'action=protect') - ); - - } else { - $content_actions['unprotect'] = array( - 'class' => ($action == 'unprotect') ? 'selected' : false, - 'text' => wfMsg('unprotect'), - 'href' => $this->makeUrl($this->thispage, 'action=unprotect') - ); - } - } - if($wgUser->isAllowed('delete')){ - $content_actions['delete'] = array( - 'class' => ($action == 'delete') ? 'selected' : false, - 'text' => wfMsg('delete'), - 'href' => $this->makeUrl($this->thispage, 'action=delete') - ); - } - if ( $wgUser->getID() != 0 ) { - if ( $wgTitle->userCanEdit()) { - $content_actions['move'] = array('class' => ($wgTitle->getDbKey() == 'Movepage' and $wgTitle->getNamespace == Namespace::getSpecial()) ? 'selected' : false, - 'text' => wfMsg('move'), - 'href' => $this->makeSpecialUrl('Movepage', 'target='. urlencode( $this->thispage )) - ); - } - } - } else { - //article doesn't exist or is deleted - if($wgUser->isAllowed('delete')){ - if( $n = $wgTitle->isDeleted() ) { - $content_actions['undelete'] = array( - 'class' => false, - 'text' => wfMsg( "undelete_short", $n ), - 'href' => $this->makeSpecialUrl('Undelete/'.$this->thispage) - ); - } - } - } - - if ( $wgUser->getID() != 0 and $action != 'submit' ) { - if( !$wgTitle->userIsWatching()) { - $content_actions['watch'] = array('class' => ($action == 'watch' or $action == 'unwatch') ? 'selected' : false, - 'text' => wfMsg('watch'), - 'href' => $this->makeUrl($this->thispage, 'action=watch')); - } else { - $content_actions['unwatch'] = array('class' => ($action == 'unwatch' or $action == 'watch') ? 'selected' : false, - 'text' => wfMsg('unwatch'), - 'href' => $this->makeUrl($this->thispage, 'action=unwatch')); - } - } - - # Show validate tab - if ( $wgUseValidation && $wgTitle->getArticleId() && $wgTitle->getNamespace() == 0 ) { - global $wgArticle ; - $article_time = "×tamp=" . $wgArticle->mTimestamp ; - $content_actions['validate'] = array('class' => ($action == 'validate') ? 'selected' : false , - 'text' => wfMsg('val_tab'), - 'href' => $this->makeUrl($this->thispage, 'action=validate'.$article_time)); - } - - } else { - /* show special page tab */ - - $content_actions['article'] = array('class' => 'selected', - 'text' => wfMsg('specialpage'), - 'href' => false); - } - - return $content_actions; - } - - /** - * build array of global navigation links - */ - function buildNavigationUrls () { - global $wgNavigationLinks; - $result = array(); - foreach ( $wgNavigationLinks as $link ) { - if (wfMsg( $link['text'] ) != '-') { - $result[] = array( - 'text' => wfMsg( $link['text'] ), - 'href' => $this->makeInternalOrExternalUrl( wfMsgForContent( $link['href'] ) ), - 'id' => 'n-'.$link['text'] - ); - } - } - return $result; - } - - /** - * build array of common navigation links - */ - function buildNavUrls () { - global $wgTitle, $wgUser, $wgRequest; - global $wgSiteSupportPage, $wgDisableUploads; - - $action = $wgRequest->getText( 'action' ); - $oldid = $wgRequest->getVal( 'oldid' ); - $diff = $wgRequest->getVal( 'diff' ); - // XXX: remove htmlspecialchars when tal:attributes works with i18n:attributes - $nav_urls = array(); - $nav_urls['mainpage'] = array('href' => $this->makeI18nUrl('mainpage')); - $nav_urls['randompage'] = array('href' => $this->makeSpecialUrl('Randompage')); - $nav_urls['recentchanges'] = array('href' => $this->makeSpecialUrl('Recentchanges')); - $nav_urls['currentevents'] = (wfMsg('currentevents') != '-') ? array('href' => $this->makeI18nUrl('currentevents')) : false; - $nav_urls['portal'] = (wfMsg('portal') != '-') ? array('href' => $this->makeI18nUrl('portal-url')) : false; - $nav_urls['bugreports'] = array('href' => $this->makeI18nUrl('bugreportspage')); - // $nav_urls['sitesupport'] = array('href' => $this->makeI18nUrl('sitesupportpage')); - $nav_urls['sitesupport'] = array('href' => $wgSiteSupportPage); - $nav_urls['help'] = array('href' => $this->makeI18nUrl('helppage')); - if( $this->loggedin && !$wgDisableUploads ) { - $nav_urls['upload'] = array('href' => $this->makeSpecialUrl('Upload')); - } else { - $nav_urls['upload'] = false; - } - $nav_urls['specialpages'] = array('href' => $this->makeSpecialUrl('Specialpages')); - - if( $wgTitle->getNamespace() != NS_SPECIAL) { - $nav_urls['whatlinkshere'] = array('href' => $this->makeSpecialUrl('Whatlinkshere', 'target='.urlencode( $this->thispage))); - $nav_urls['recentchangeslinked'] = array('href' => $this->makeSpecialUrl('Recentchangeslinked', 'target='.urlencode( $this->thispage))); - } - - if( $wgTitle->getNamespace() == NS_USER || $wgTitle->getNamespace() == NS_USER_TALK ) { - $id = User::idFromName($wgTitle->getText()); - $ip = User::isIP($wgTitle->getText()); - } else { - $id = 0; - $ip = false; - } - - if($id || $ip) { # both anons and non-anons have contri list - $nav_urls['contributions'] = array( - 'href' => $this->makeSpecialUrl('Contributions', "target=" . $wgTitle->getPartialURL() ) - ); - } else { - $nav_urls['contributions'] = false; - } - $nav_urls['emailuser'] = false; - if ( 0 != $wgUser->getID() ) { # show only to signed in users - if($id) { # can only email non-anons - $nav_urls['emailuser'] = array( - 'href' => $this->makeSpecialUrl('Emailuser', "target=" . $wgTitle->getPartialURL() ) - ); - } - } - - return $nav_urls; - } - - /** - * Generate strings used for xml 'id' names - */ - function getNameSpaceKey () { - global $wgTitle; - switch ($wgTitle->getNamespace()) { - case NS_MAIN: - case NS_TALK: - return 'nstab-main'; - case NS_USER: - case NS_USER_TALK: - return 'nstab-user'; - case NS_MEDIA: - return 'nstab-media'; - case NS_SPECIAL: - return 'nstab-special'; - case NS_PROJECT: - case NS_PROJECT_TALK: - return 'nstab-wp'; - case NS_IMAGE: - case NS_IMAGE_TALK: - return 'nstab-image'; - case NS_MEDIAWIKI: - case NS_MEDIAWIKI_TALK: - return 'nstab-mediawiki'; - case NS_TEMPLATE: - case NS_TEMPLATE_TALK: - return 'nstab-template'; - case NS_HELP: - case NS_HELP_TALK: - return 'nstab-help'; - case NS_CATEGORY: - case NS_CATEGORY_TALK: - return 'nstab-category'; - default: - return 'nstab-main'; - } - } - - /** - * @access private - */ - - function setupUserCss () { - - global $wgRequest, $wgTitle, $wgAllowUserCss, $wgUseSiteCss; - - $sitecss = ""; - $usercss = ""; - $siteargs = ""; - - # Add user-specific code if this is a user and we allow that kind of thing - - if ( $wgAllowUserCss && $this->loggedin ) { - $action = $wgRequest->getText('action'); - - # if we're previewing the CSS page, use it - if($wgTitle->isCssSubpage() and $action == 'submit' and $wgTitle->userCanEditCssJsSubpage()) { - $siteargs .= "&smaxage=0&maxage=0"; - $usercss = $wgRequest->getText('wpTextbox1'); - } else { - $siteargs .= "&maxage=0"; - $usercss = '@import "' . - $this->makeUrl($this->userpage . '/'.$this->skinname.'.css', - 'action=raw&ctype=text/css') . '";' ."\n"; - } - } - - # If we use the site's dynamic CSS, throw that in, too - - if ( $wgUseSiteCss ) { - $sitecss = '@import "'.$this->makeUrl('-','action=raw&gen=css' . $siteargs).'";'."\n"; - } - - # If we use any dynamic CSS, make a little CDATA block out of it. - - if ( !empty($sitecss) || !empty($usercss) ) { - $this->usercss = '/**/'; - } - } - - /** - * @access private - */ - function setupUserJs () { - global $wgRequest, $wgTitle, $wgAllowUserJs; - $action = $wgRequest->getText('action'); - - if( $wgAllowUserJs && $this->loggedin ) { - if($wgTitle->isJsSubpage() and $action == 'submit' and $wgTitle->userCanEditCssJsSubpage()) { - # XXX: additional security check/prompt? - $this->userjsprev = '/*getText('wpTextbox1') . ' /*]]>*/'; - } else { - $this->userjs = $this->makeUrl($this->userpage.'/'.$this->skinname.'.js', 'action=raw&ctype=text/javascript&dontcountme=s'); - } - } - } - - /** - * returns css with user-specific options - */ - function getUserStylesheet() { - global $wgUser, $wgRequest, $wgTitle, $wgContLang, $wgSquidMaxage, $wgStylePath; - $action = $wgRequest->getText('action'); - $maxage = $wgRequest->getText('maxage'); - $s = "/* generated user stylesheet */\n"; - if($wgContLang->isRTL()) $s .= '@import "'.$wgStylePath.'/'.$this->stylename.'/rtl.css";'."\n"; - $s .= '@import "'. - $this->makeNSUrl(ucfirst($this->skinname).'.css', 'action=raw&ctype=text/css&smaxage='.$wgSquidMaxage, NS_MEDIAWIKI)."\";\n"; - if($wgUser->getID() != 0) { - if ( 1 == $wgUser->getOption( "underline" ) ) { - $s .= "a { text-decoration: underline; }\n"; - } else { - $s .= "a { text-decoration: none; }\n"; - } - } - if ( 1 != $wgUser->getOption( "highlightbroken" ) ) { - $s .= "a.new, #quickbar a.new { color: #CC2200; }\n"; - } - if ( 1 == $wgUser->getOption( "justify" ) ) { - $s .= "#bodyContent { text-align: justify; }\n"; - } - return $s; - } - - /** - * - */ - function getUserJs() { - global $wgUser, $wgStylePath; - $s = '/* generated javascript */'; - $s .= "var skin = '{$this->skinname}';\nvar stylepath = '{$wgStylePath}';"; - $s .= '/* MediaWiki:'.ucfirst($this->skinname)." */\n"; - $s .= wfMsg(ucfirst($this->skinname).'.js'); - return $s; } } diff --git a/includes/SkinTemplate.php b/includes/SkinTemplate.php new file mode 100644 index 0000000000..ae5c304c65 --- /dev/null +++ b/includes/SkinTemplate.php @@ -0,0 +1,789 @@ +_context[$varName] = $value; + } + + function translate($value) { + // Hack for i18n:attributes in PHPTAL 1.0.0 dev version as of 2004-10-23 + $value = preg_replace( '/^string:/', '', $value ); + + $value = wfMsg( $value ); + // interpolate variables + while (preg_match('/\$([0-9]*?)/sm', $value, $m)) { + list($src, $var) = $m; + wfSuppressWarnings(); + $varValue = $this->_context[$var]; + wfRestoreWarnings(); + $value = str_replace($src, $varValue, $value); + } + return $value; + } +} +/** + * + * @package MediaWiki + */ +class SkinTemplate extends Skin { + /**#@+ + * @access private + */ + + /** + * Name of our skin, set in initPage() + * It probably need to be all lower case. + */ + var $skinname; + + /** + * Stylesheets set to use + * Sub directory in ./skins/ where various stylesheets are located + */ + var $stylename; + + /** + * PHPTal template to be used. + * '.pt' will be automaticly added to it on PHPTAL object creation + */ + var $template; + + /**#@-*/ + + /** */ + function initPage( &$out ) { + parent::initPage( $out ); + $this->skinname = 'monobook'; + $this->stylename = 'monobook'; + $this->template = 'MonoBookTemplate'; + } + + /** + * If using PHPTAL 0.7 on PHP 4.x, return a PHPTAL template object. + * If using PHPTAL 1.0 on PHP 5.x, return a bridge object. + * @return object + * @access private + */ + function &setupTemplate( $file, $repository=false, $cache_dir=false ) { + return new QuickTemplate( $file ); + } + + /** + * initialize various variables and generate the template + */ + function outputPage( &$out ) { + global $wgTitle, $wgArticle, $wgUser, $wgLang, $wgContLang, $wgOut; + global $wgScript, $wgStylePath, $wgLanguageCode, $wgContLanguageCode, $wgUseNewInterlanguage; + global $wgMimeType, $wgOutputEncoding, $wgUseDatabaseMessages, $wgRequest; + global $wgDisableCounters, $wgLogo, $action, $wgFeedClasses, $wgSiteNotice; + global $wgMaxCredits, $wgShowCreditsIfMax; + + extract( $wgRequest->getValues( 'oldid', 'diff' ) ); + + $this->initPage( $out ); + $tpl =& $this->setupTemplate( $this->template, 'skins' ); + + #if ( $wgUseDatabaseMessages ) { // uncomment this to fall back to GetText + $tpl->setTranslator(new MediaWiki_I18N()); + #} + + $this->thispage = $wgTitle->getPrefixedDbKey(); + $this->thisurl = $wgTitle->getPrefixedURL(); + $this->loggedin = $wgUser->getID() != 0; + $this->iscontent = ($wgTitle->getNamespace() != Namespace::getSpecial() ); + $this->iseditable = ($this->iscontent and !($action == 'edit' or $action == 'submit')); + $this->username = $wgUser->getName(); + $this->userpage = $wgContLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); + $this->userpageUrlDetails = $this->makeUrlDetails($this->userpage); + + $this->usercss = $this->userjs = $this->userjsprev = false; + $this->setupUserCss(); + $this->setupUserJs(); + $this->titletxt = $wgTitle->getPrefixedText(); + + $tpl->set( 'title', $wgOut->getPageTitle() ); + $tpl->set( 'pagetitle', $wgOut->getHTMLTitle() ); + + $tpl->setRef( "thispage", $this->thispage ); + $subpagestr = $this->subPageSubtitle(); + $tpl->set( + 'subtitle', !empty($subpagestr)? + ''.$subpagestr.''.$out->getSubtitle(): + $out->getSubtitle() + ); + $undelete = $this->getUndeleteLink(); + $tpl->set( + "undelete", !empty($undelete)? + ''.$undelete.'': + '' + ); + + $tpl->set( 'catlinks', $this->getCategories()); + if( $wgOut->isSyndicated() ) { + $feeds = array(); + foreach( $wgFeedClasses as $format => $class ) { + $feeds[$format] = array( + 'text' => $format, + 'href' => $wgRequest->appendQuery( "feed=$format" ), + 'ttip' => wfMsg('tooltip-'.$format) + ); + } + $tpl->setRef( 'feeds', $feeds ); + } else { + $tpl->set( 'feeds', false ); + } + $tpl->setRef( 'mimetype', $wgMimeType ); + $tpl->setRef( 'charset', $wgOutputEncoding ); + $tpl->set( 'headlinks', $out->getHeadLinks() ); + $tpl->setRef( 'wgScript', $wgScript ); + $tpl->setRef( 'skinname', $this->skinname ); + $tpl->setRef( 'stylename', $this->stylename ); + $tpl->setRef( 'loggedin', $this->loggedin ); + $tpl->set('nsclass', 'ns-'.$wgTitle->getNamespace()); + $tpl->set('notspecialpage', $wgTitle->getNamespace() != NS_SPECIAL); + /* XXX currently unused, might get useful later + $tpl->set( "editable", ($wgTitle->getNamespace() != NS_SPECIAL ) ); + $tpl->set( "exists", $wgTitle->getArticleID() != 0 ); + $tpl->set( "watch", $wgTitle->userIsWatching() ? "unwatch" : "watch" ); + $tpl->set( "protect", count($wgTitle->getRestrictions()) ? "unprotect" : "protect" ); + $tpl->set( "helppage", wfMsg('helppage')); + */ + $tpl->set( 'searchaction', $this->escapeSearchLink() ); + $tpl->setRef( 'stylepath', $wgStylePath ); + $tpl->setRef( 'logopath', $wgLogo ); + $tpl->setRef( "lang", $wgContLanguageCode ); + $tpl->set( 'dir', $wgContLang->isRTL() ? "rtl" : "ltr" ); + $tpl->set( 'rtl', $wgContLang->isRTL() ); + $tpl->set( 'langname', $wgContLang->getLanguageName( $wgContLanguageCode ) ); + $tpl->setRef( 'username', $this->username ); + $tpl->setRef( 'userpage', $this->userpage); + $tpl->setRef( 'userpageurl', $this->userpageUrlDetails['href']); + $tpl->setRef( 'usercss', $this->usercss); + $tpl->setRef( 'userjs', $this->userjs); + $tpl->setRef( 'userjsprev', $this->userjsprev); + global $wgUseSiteJs; + if ($wgUseSiteJs) { + if($this->loggedin) { + $tpl->set( 'jsvarurl', $this->makeUrl('-','action=raw&smaxage=0&gen=js') ); + } else { + $tpl->set( 'jsvarurl', $this->makeUrl('-','action=raw&gen=js') ); + } + } else { + $tpl->set('jsvarurl', false); + } + if( $wgUser->getNewtalk() ) { + $usertitle = Title::newFromText( $this->userpage ); + $usertalktitle = $usertitle->getTalkPage(); + if($usertalktitle->getPrefixedDbKey() != $this->thispage){ + + $ntl = wfMsg( 'newmessages', + $this->makeKnownLink( + $wgContLang->getNsText( Namespace::getTalk( Namespace::getUser() ) ) + . ':' . $this->username, + wfMsg('newmessageslink') ) + ); + # Disable Cache + $wgOut->setSquidMaxage(0); + } + } else { + $ntl = ''; + } + + $tpl->setRef( 'newtalk', $ntl ); + $tpl->setRef( 'skin', $this); + $tpl->set( 'logo', $this->logoText() ); + if ( $wgOut->isArticle() and (!isset( $oldid ) or isset( $diff )) and 0 != $wgArticle->getID() ) { + if ( !$wgDisableCounters ) { + $viewcount = $wgLang->formatNum( $wgArticle->getCount() ); + if ( $viewcount ) { + $tpl->set('viewcount', wfMsg( "viewcount", $viewcount )); + } else { + $tpl->set('viewcount', false); + } + } + $tpl->set('lastmod', $this->lastModified()); + $tpl->set('copyright',$this->getCopyright()); + + $this->credits = false; + + if (isset($wgMaxCredits) && $wgMaxCredits != 0) { + require_once("Credits.php"); + $this->credits = getCredits($wgArticle, $wgMaxCredits, $wgShowCreditsIfMax); + } + + $tpl->setRef( 'credits', $this->credits ); + + } elseif ( isset( $oldid ) && !isset( $diff ) ) { + $tpl->set('copyright', $this->getCopyright()); + $tpl->set('viewcount', false); + $tpl->set('lastmod', false); + $tpl->set('credits', false); + } else { + $tpl->set('copyright', false); + $tpl->set('viewcount', false); + $tpl->set('lastmod', false); + $tpl->set('credits', false); + } + + $tpl->set( 'copyrightico', $this->getCopyrightIcon() ); + $tpl->set( 'poweredbyico', $this->getPoweredBy() ); + $tpl->set( 'disclaimer', $this->disclaimerLink() ); + $tpl->set( 'about', $this->aboutLink() ); + + $tpl->setRef( 'debug', $out->mDebugtext ); + $tpl->set( 'reporttime', $out->reportTime() ); + $tpl->set( 'sitenotice', $wgSiteNotice ); + + $printfooter = "
\n" . $this->printSource() . "
\n"; + $out->mBodytext .= $printfooter ; + $tpl->setRef( 'bodytext', $out->mBodytext ); + + # Language links + $language_urls = array(); + foreach( $wgOut->getLanguageLinks() as $l ) { + $nt = Title::newFromText( $l ); + $language_urls[] = array('href' => $nt->getFullURL(), + 'text' => ($wgContLang->getLanguageName( $nt->getInterwiki()) != ''?$wgContLang->getLanguageName( $nt->getInterwiki()) : $l), + 'class' => $wgContLang->isRTL() ? 'rtl' : 'ltr'); + } + if(count($language_urls)) { + $tpl->setRef( 'language_urls', $language_urls); + } else { + $tpl->set('language_urls', false); + } + + # Personal toolbar + $tpl->set('personal_urls', $this->buildPersonalUrls()); + $content_actions = $this->buildContentActionUrls(); + $tpl->setRef('content_actions', $content_actions); + // XXX: attach this from javascript, same with section editing + if($this->iseditable && $wgUser->getOption("editondblclick") ) + { + $tpl->set('body_ondblclick', 'document.location = "' .$content_actions['edit']['href'] .'";'); + } else { + $tpl->set('body_ondblclick', false); + } + $tpl->set( 'navigation_urls', $this->buildNavigationUrls() ); + $tpl->set( 'nav_urls', $this->buildNavUrls() ); + + // execute template + $res = $tpl->execute(); + + // result may be an error + #if (PEAR::isError($res)) { + # echo $res->toString(), "\n"; + #} else { + echo $res; + #} + + } + + /** + * build array of urls for personal toolbar + */ + function buildPersonalUrls() { + /* set up the default links for the personal toolbar */ + global $wgShowIPinHeader; + $personal_urls = array(); + if ($this->loggedin) { + $personal_urls['userpage'] = array( + 'text' => $this->username, + 'href' => &$this->userpageUrlDetails['href'], + 'class' => $this->userpageUrlDetails['exists']?false:'new' + ); + $usertalkUrlDetails = $this->makeTalkUrlDetails($this->userpage); + $personal_urls['mytalk'] = array( + 'text' => wfMsg('mytalk'), + 'href' => &$usertalkUrlDetails['href'], + 'class' => $usertalkUrlDetails['exists']?false:'new' + ); + $personal_urls['preferences'] = array( + 'text' => wfMsg('preferences'), + 'href' => $this->makeSpecialUrl('Preferences') + ); + $personal_urls['watchlist'] = array( + 'text' => wfMsg('watchlist'), + 'href' => $this->makeSpecialUrl('Watchlist') + ); + $personal_urls['mycontris'] = array( + 'text' => wfMsg('mycontris'), + 'href' => $this->makeSpecialUrl('Contributions','target=' . urlencode( $this->username ) ) + ); + $personal_urls['logout'] = array( + 'text' => wfMsg('userlogout'), + 'href' => $this->makeSpecialUrl('Userlogout','returnto=' . $this->thisurl ) + ); + } else { + if( $wgShowIPinHeader && isset( $_COOKIE[ini_get("session.name")] ) ) { + $personal_urls['anonuserpage'] = array( + 'text' => $this->username, + 'href' => &$this->userpageUrlDetails['href'], + 'class' => $this->userpageUrlDetails['exists']?false:'new' + ); + $usertalkUrlDetails = $this->makeTalkUrlDetails($this->userpage); + $personal_urls['anontalk'] = array( + 'text' => wfMsg('anontalk'), + 'href' => &$usertalkUrlDetails['href'], + 'class' => $usertalkUrlDetails['exists']?false:'new' + ); + $personal_urls['anonlogin'] = array( + 'text' => wfMsg('userlogin'), + 'href' => $this->makeSpecialUrl('Userlogin', 'returnto=' . $this->thisurl ) + ); + } else { + + $personal_urls['login'] = array( + 'text' => wfMsg('userlogin'), + 'href' => $this->makeSpecialUrl('Userlogin', 'returnto=' . $this->thisurl ) + ); + } + } + + return $personal_urls; + } + + /** + * an array of edit links by default used for the tabs + */ + function buildContentActionUrls () { + global $wgTitle, $wgUser, $wgOut, $wgRequest, $wgUseValidation; + $action = $wgRequest->getText( 'action' ); + $section = $wgRequest->getText( 'section' ); + $oldid = $wgRequest->getVal( 'oldid' ); + $diff = $wgRequest->getVal( 'diff' ); + $content_actions = array(); + + if( $this->iscontent and !$wgOut->isQuickbarSuppressed() ) { + + $nskey = $this->getNameSpaceKey(); + $is_active = !Namespace::isTalk( $wgTitle->getNamespace()) ; + if ( $action == 'validate' ) $is_active = false ; # Show article tab deselected when validating + $content_actions[$nskey] = array('class' => ($is_active) ? 'selected' : false, + 'text' => wfMsg($nskey), + 'href' => $this->makeArticleUrl($this->thispage)); + + /* set up the classes for the talk link */ + $talk_class = (Namespace::isTalk( $wgTitle->getNamespace()) ? 'selected' : false); + $talktitle = Title::newFromText( $this->titletxt ); + $talktitle = $talktitle->getTalkPage(); + $this->checkTitle($talktitle, $this->titletxt); + if($talktitle->getArticleId() != 0) { + $content_actions['talk'] = array( + 'class' => $talk_class, + 'text' => wfMsg('talk'), + 'href' => $this->makeTalkUrl($this->titletxt) + ); + } else { + $content_actions['talk'] = array( + 'class' => $talk_class?$talk_class.' new':'new', + 'text' => wfMsg('talk'), + 'href' => $this->makeTalkUrl($this->titletxt,'action=edit') + ); + } + + if ( $wgTitle->userCanEdit() ) { + $oid = ( $oldid && ! isset( $diff ) ) ? '&oldid='.IntVal( $oldid ) : false; + $istalk = ( Namespace::isTalk( $wgTitle->getNamespace()) ); + $istalkclass = $istalk?' istalk':''; + $content_actions['edit'] = array( + 'class' => ((($action == 'edit' or $action == 'submit') and $section != 'new') ? 'selected' : '').$istalkclass, + 'text' => wfMsg('edit'), + 'href' => $this->makeUrl($this->thispage, 'action=edit'.$oid) + ); + if ( $istalk ) { + $content_actions['addsection'] = array( + 'class' => $section == 'new'?'selected':false, + 'text' => wfMsg('addsection'), + 'href' => $this->makeUrl($this->thispage, 'action=edit§ion=new') + ); + } + } else { + $oid = ( $oldid && ! isset( $diff ) ) ? '&oldid='.IntVal( $oldid ) : ''; + $content_actions['viewsource'] = array('class' => ($action == 'edit') ? 'selected' : false, + 'text' => wfMsg('viewsource'), + 'href' => $this->makeUrl($this->thispage, 'action=edit'.$oid)); + } + + if ( $wgTitle->getArticleId() ) { + + $content_actions['history'] = array('class' => ($action == 'history') ? 'selected' : false, + 'text' => wfMsg('history_short'), + 'href' => $this->makeUrl($this->thispage, 'action=history')); + + # XXX: is there a rollback action anywhere or is it planned? + # Don't recall where i got this from... + /*if( $wgUser->getNewtalk() ) { + $content_actions['rollback'] = array('class' => ($action == 'rollback') ? 'selected' : false, + 'text' => wfMsg('rollback_short'), + 'href' => $this->makeUrl($this->thispage, 'action=rollback'), + 'ttip' => wfMsg('tooltip-rollback'), + 'akey' => wfMsg('accesskey-rollback')); + } + */ + + if($wgUser->isAllowed('protect')){ + if(!$wgTitle->isProtected()){ + $content_actions['protect'] = array( + 'class' => ($action == 'protect') ? 'selected' : false, + 'text' => wfMsg('protect'), + 'href' => $this->makeUrl($this->thispage, 'action=protect') + ); + + } else { + $content_actions['unprotect'] = array( + 'class' => ($action == 'unprotect') ? 'selected' : false, + 'text' => wfMsg('unprotect'), + 'href' => $this->makeUrl($this->thispage, 'action=unprotect') + ); + } + } + if($wgUser->isAllowed('delete')){ + $content_actions['delete'] = array( + 'class' => ($action == 'delete') ? 'selected' : false, + 'text' => wfMsg('delete'), + 'href' => $this->makeUrl($this->thispage, 'action=delete') + ); + } + if ( $wgUser->getID() != 0 ) { + if ( $wgTitle->userCanEdit()) { + $content_actions['move'] = array('class' => ($wgTitle->getDbKey() == 'Movepage' and $wgTitle->getNamespace == Namespace::getSpecial()) ? 'selected' : false, + 'text' => wfMsg('move'), + 'href' => $this->makeSpecialUrl('Movepage', 'target='. urlencode( $this->thispage )) + ); + } + } + } else { + //article doesn't exist or is deleted + if($wgUser->isAllowed('delete')){ + if( $n = $wgTitle->isDeleted() ) { + $content_actions['undelete'] = array( + 'class' => false, + 'text' => wfMsg( "undelete_short", $n ), + 'href' => $this->makeSpecialUrl('Undelete/'.$this->thispage) + ); + } + } + } + + if ( $wgUser->getID() != 0 and $action != 'submit' ) { + if( !$wgTitle->userIsWatching()) { + $content_actions['watch'] = array('class' => ($action == 'watch' or $action == 'unwatch') ? 'selected' : false, + 'text' => wfMsg('watch'), + 'href' => $this->makeUrl($this->thispage, 'action=watch')); + } else { + $content_actions['unwatch'] = array('class' => ($action == 'unwatch' or $action == 'watch') ? 'selected' : false, + 'text' => wfMsg('unwatch'), + 'href' => $this->makeUrl($this->thispage, 'action=unwatch')); + } + } + + # Show validate tab + if ( $wgUseValidation && $wgTitle->getArticleId() && $wgTitle->getNamespace() == 0 ) { + global $wgArticle ; + $article_time = "×tamp=" . $wgArticle->mTimestamp ; + $content_actions['validate'] = array('class' => ($action == 'validate') ? 'selected' : false , + 'text' => wfMsg('val_tab'), + 'href' => $this->makeUrl($this->thispage, 'action=validate'.$article_time)); + } + + } else { + /* show special page tab */ + + $content_actions['article'] = array('class' => 'selected', + 'text' => wfMsg('specialpage'), + 'href' => false); + } + + return $content_actions; + } + + /** + * build array of global navigation links + */ + function buildNavigationUrls () { + global $wgNavigationLinks; + $result = array(); + foreach ( $wgNavigationLinks as $link ) { + if (wfMsg( $link['text'] ) != '-') { + $result[] = array( + 'text' => wfMsg( $link['text'] ), + 'href' => $this->makeInternalOrExternalUrl( wfMsgForContent( $link['href'] ) ), + 'id' => 'n-'.$link['text'] + ); + } + } + return $result; + } + + /** + * build array of common navigation links + */ + function buildNavUrls () { + global $wgTitle, $wgUser, $wgRequest; + global $wgSiteSupportPage, $wgDisableUploads; + + $action = $wgRequest->getText( 'action' ); + $oldid = $wgRequest->getVal( 'oldid' ); + $diff = $wgRequest->getVal( 'diff' ); + // XXX: remove htmlspecialchars when tal:attributes works with i18n:attributes + $nav_urls = array(); + $nav_urls['mainpage'] = array('href' => $this->makeI18nUrl('mainpage')); + $nav_urls['randompage'] = array('href' => $this->makeSpecialUrl('Randompage')); + $nav_urls['recentchanges'] = array('href' => $this->makeSpecialUrl('Recentchanges')); + $nav_urls['currentevents'] = (wfMsg('currentevents') != '-') ? array('href' => $this->makeI18nUrl('currentevents')) : false; + $nav_urls['portal'] = (wfMsg('portal') != '-') ? array('href' => $this->makeI18nUrl('portal-url')) : false; + $nav_urls['bugreports'] = array('href' => $this->makeI18nUrl('bugreportspage')); + // $nav_urls['sitesupport'] = array('href' => $this->makeI18nUrl('sitesupportpage')); + $nav_urls['sitesupport'] = array('href' => $wgSiteSupportPage); + $nav_urls['help'] = array('href' => $this->makeI18nUrl('helppage')); + if( $this->loggedin && !$wgDisableUploads ) { + $nav_urls['upload'] = array('href' => $this->makeSpecialUrl('Upload')); + } else { + $nav_urls['upload'] = false; + } + $nav_urls['specialpages'] = array('href' => $this->makeSpecialUrl('Specialpages')); + + if( $wgTitle->getNamespace() != NS_SPECIAL) { + $nav_urls['whatlinkshere'] = array('href' => $this->makeSpecialUrl('Whatlinkshere', 'target='.urlencode( $this->thispage))); + $nav_urls['recentchangeslinked'] = array('href' => $this->makeSpecialUrl('Recentchangeslinked', 'target='.urlencode( $this->thispage))); + } + + if( $wgTitle->getNamespace() == NS_USER || $wgTitle->getNamespace() == NS_USER_TALK ) { + $id = User::idFromName($wgTitle->getText()); + $ip = User::isIP($wgTitle->getText()); + } else { + $id = 0; + $ip = false; + } + + if($id || $ip) { # both anons and non-anons have contri list + $nav_urls['contributions'] = array( + 'href' => $this->makeSpecialUrl('Contributions', "target=" . $wgTitle->getPartialURL() ) + ); + } else { + $nav_urls['contributions'] = false; + } + $nav_urls['emailuser'] = false; + if ( 0 != $wgUser->getID() ) { # show only to signed in users + if($id) { # can only email non-anons + $nav_urls['emailuser'] = array( + 'href' => $this->makeSpecialUrl('Emailuser', "target=" . $wgTitle->getPartialURL() ) + ); + } + } + + return $nav_urls; + } + + /** + * Generate strings used for xml 'id' names + */ + function getNameSpaceKey () { + global $wgTitle; + switch ($wgTitle->getNamespace()) { + case NS_MAIN: + case NS_TALK: + return 'nstab-main'; + case NS_USER: + case NS_USER_TALK: + return 'nstab-user'; + case NS_MEDIA: + return 'nstab-media'; + case NS_SPECIAL: + return 'nstab-special'; + case NS_PROJECT: + case NS_PROJECT_TALK: + return 'nstab-wp'; + case NS_IMAGE: + case NS_IMAGE_TALK: + return 'nstab-image'; + case NS_MEDIAWIKI: + case NS_MEDIAWIKI_TALK: + return 'nstab-mediawiki'; + case NS_TEMPLATE: + case NS_TEMPLATE_TALK: + return 'nstab-template'; + case NS_HELP: + case NS_HELP_TALK: + return 'nstab-help'; + case NS_CATEGORY: + case NS_CATEGORY_TALK: + return 'nstab-category'; + default: + return 'nstab-main'; + } + } + + /** + * @access private + */ + + function setupUserCss () { + + global $wgRequest, $wgTitle, $wgAllowUserCss, $wgUseSiteCss; + + $sitecss = ""; + $usercss = ""; + $siteargs = ""; + + # Add user-specific code if this is a user and we allow that kind of thing + + if ( $wgAllowUserCss && $this->loggedin ) { + $action = $wgRequest->getText('action'); + + # if we're previewing the CSS page, use it + if($wgTitle->isCssSubpage() and $action == 'submit' and $wgTitle->userCanEditCssJsSubpage()) { + $siteargs .= "&smaxage=0&maxage=0"; + $usercss = $wgRequest->getText('wpTextbox1'); + } else { + $siteargs .= "&maxage=0"; + $usercss = '@import "' . + $this->makeUrl($this->userpage . '/'.$this->skinname.'.css', + 'action=raw&ctype=text/css') . '";' ."\n"; + } + } + + # If we use the site's dynamic CSS, throw that in, too + + if ( $wgUseSiteCss ) { + $sitecss = '@import "'.$this->makeUrl('-','action=raw&gen=css' . $siteargs).'";'."\n"; + } + + # If we use any dynamic CSS, make a little CDATA block out of it. + + if ( !empty($sitecss) || !empty($usercss) ) { + $this->usercss = '/**/'; + } + } + + /** + * @access private + */ + function setupUserJs () { + global $wgRequest, $wgTitle, $wgAllowUserJs; + $action = $wgRequest->getText('action'); + + if( $wgAllowUserJs && $this->loggedin ) { + if($wgTitle->isJsSubpage() and $action == 'submit' and $wgTitle->userCanEditCssJsSubpage()) { + # XXX: additional security check/prompt? + $this->userjsprev = '/*getText('wpTextbox1') . ' /*]]>*/'; + } else { + $this->userjs = $this->makeUrl($this->userpage.'/'.$this->skinname.'.js', 'action=raw&ctype=text/javascript&dontcountme=s'); + } + } + } + + /** + * returns css with user-specific options + */ + function getUserStylesheet() { + global $wgUser, $wgRequest, $wgTitle, $wgContLang, $wgSquidMaxage, $wgStylePath; + $action = $wgRequest->getText('action'); + $maxage = $wgRequest->getText('maxage'); + $s = "/* generated user stylesheet */\n"; + if($wgContLang->isRTL()) $s .= '@import "'.$wgStylePath.'/'.$this->stylename.'/rtl.css";'."\n"; + $s .= '@import "'. + $this->makeNSUrl(ucfirst($this->skinname).'.css', 'action=raw&ctype=text/css&smaxage='.$wgSquidMaxage, NS_MEDIAWIKI)."\";\n"; + if($wgUser->getID() != 0) { + if ( 1 == $wgUser->getOption( "underline" ) ) { + $s .= "a { text-decoration: underline; }\n"; + } else { + $s .= "a { text-decoration: none; }\n"; + } + } + if ( 1 != $wgUser->getOption( "highlightbroken" ) ) { + $s .= "a.new, #quickbar a.new { color: #CC2200; }\n"; + } + if ( 1 == $wgUser->getOption( "justify" ) ) { + $s .= "#bodyContent { text-align: justify; }\n"; + } + return $s; + } + + /** + * + */ + function getUserJs() { + global $wgUser, $wgStylePath; + $s = '/* generated javascript */'; + $s .= "var skin = '{$this->skinname}';\nvar stylepath = '{$wgStylePath}';"; + $s .= '/* MediaWiki:'.ucfirst($this->skinname)." */\n"; + $s .= wfMsg(ucfirst($this->skinname).'.js'); + return $s; + } +} + +class QuickTemplate { + function QuickTemplate( $file, $repository=false, $cache_dir=false ) { + $this->outputCallback = $file; + $this->data = array(); + $this->translator = null; + } + + function set( $name, $value ) { + $this->data[$name] = $value; + } + + function setRef($name, &$value) { + $this->data[$name] =& $value; + } + + function setTranslator( &$t ) { + $this->translator = &$t; + } + + function execute() { + return call_user_func_array( $this->outputCallback, + array( &$this->data, &$this->translator ) ); + } +} + +} // end of if( defined( 'MEDIAWIKI' ) ) +?> diff --git a/includes/User.php b/includes/User.php index ac2bceb388..b6f4238f1a 100644 --- a/includes/User.php +++ b/includes/User.php @@ -644,7 +644,7 @@ class User { * @todo FIXME : need to check the old failback system [AV] */ function &getSkin() { - global $IP, $wgUsePHPTal; + global $IP; if ( ! isset( $this->mSkin ) ) { # get all skin names available $skinNames = Skin::getSkinNames(); diff --git a/skins/MonoBook.php b/skins/MonoBook.php index 62dea25b2a..51093bfaff 100644 --- a/skins/MonoBook.php +++ b/skins/MonoBook.php @@ -8,8 +8,7 @@ */ /** */ -if ($wgUsePHPTal) { -require_once('includes/SkinPHPTal.php'); +require_once('includes/SkinTemplate.php'); /** * Inherit everything from SkinPHPTal @@ -18,15 +17,167 @@ require_once('includes/SkinPHPTal.php'); * @package MediaWiki * @subpackage Skins */ -class SkinMonoBook extends SkinPHPTal { +class SkinMonoBook extends SkinTemplate { /** Using monobook. */ function initPage( &$out ) { - SkinPHPTal::initPage( $out ); + SkinTemplate::initPage( $out ); $this->skinname = 'monobook'; $this->stylename = 'monobook'; - $this->template = 'MonoBook'; + $this->template = 'MonoBookTemplate'; } } +function MonoBookTemplate( &$data, &$translator ) { +?> + + + + + <?php echo htmlspecialchars( $data['pagetitle'] ) ?> + + + + + + + + + + ondblclick="" + class=""> +
+
+
+ +
+

+
+

translate('tagline')) ?>

+
+
+
+ + + + +
+
+
+
+
+
+
Views
+
    + $action) { ?> +
  • class="" + >
  • + +
+
+
+
translate('personaltools')) ?>
+
+
    + $item) { ?> +
  • class="" + >
  • + +
+
+
+ +
+
translate('navigation')) ?>
+
+
    + +
  • + +
  • + +
+
+
+ +
+
translate('toolbox')) ?>
+ +
+
+
translate('otherlanguages')) ?>
+
+
    + +
  • + +
  • + +
+
+ +
+
+
+ +
+ + + + + +?> \ No newline at end of file diff --git a/skins/MonoBookTal.php b/skins/MonoBookTal.php new file mode 100644 index 0000000000..7fe1eace20 --- /dev/null +++ b/skins/MonoBookTal.php @@ -0,0 +1,37 @@ +skinname = 'monobooktal'; + $this->stylename = 'monobook'; + $this->template = 'MonoBook'; + } +} + +} + +} +?> -- 2.20.1