X-Git-Url: http://git.cyclocoop.org/%7B%7B%20url_for%28%27admin_vote_del%27%2C%20idvote=vote.voteid%29%20%7D%7D?a=blobdiff_plain;f=skins%2FStandard.php;h=bd0c41a5c036698fee98c46beeb260bfa7acba79;hb=fd70e68a2e1eeeaf0b7d97c24fa64d0a6785a2ce;hp=d4dd53db9eee1656863620f5a75fe09cd9087a7c;hpb=a0d30b1e0365a84d407ec54b4e51d050410d1fad;p=lhc%2Fweb%2Fwiklou.git diff --git a/skins/Standard.php b/skins/Standard.php index d4dd53db9e..bd0c41a5c0 100644 --- a/skins/Standard.php +++ b/skins/Standard.php @@ -1,84 +1,279 @@ addModuleStyles( 'skins.standard' ); - $s = parent::getHeadScripts(); - if ( 3 == $this->qbSetting() ) { # Floating left - $s .= "\n"; + $qb = $this->qbSetting(); + $rules = array(); + + if ( 2 == $qb ) { # Right + $rules[] = "/* @noflip */#quickbar { position: absolute; top: 4px; right: 4px; border-left: 2px solid #000000; }"; + $rules[] = "/* @noflip */#article, #mw-data-after-content { margin-left: 4px; margin-right: 152px; }"; + $rules[] = "/* @noflip */#topbar, #footer { margin-right: 152px; }"; + } elseif ( 1 == $qb || 3 == $qb ) { + $rules[] = "/* @noflip */#quickbar { position: absolute; top: 4px; left: 4px; border-right: 1px solid gray; }"; + $rules[] = "/* @noflip */#article, #mw-data-after-content { margin-left: 152px; margin-right: 4px; }"; + $rules[] = "/* @noflip */#topbar, #footer { margin-left: 152px; }"; + if( 3 == $qb ) { + $rules[] = "/* @noflip */#quickbar { position: fixed; padding: 4px; }"; + } + } elseif ( 4 == $qb ) { + $rules[] = "/* @noflip */#quickbar { position: fixed; right: 0; top: 0; padding: 4px; }"; + $rules[] = "/* @noflip */#quickbar { border-right: 1px solid gray; }"; + $rules[] = "/* @noflip */#article, #mw-data-after-content { margin-right: 152px; margin-left: 4px; }"; + $rules[] = "/* @noflip */#topbar, #footer { margin-right: 152px; }"; } - return $s; + $style = implode( "\n", $rules ); + $out->addInlineStyle( $style, 'flip' ); } +} + +class StandardTemplate extends LegacyTemplate { + /** - * + * @return string */ - function getUserStyles() { - global $wgStylePath; - $s = ''; - if ( 3 == $this->qbSetting() ) { # Floating left - $s .= "\n"; + function doAfterContent() { + wfProfileIn( __METHOD__ ); + wfProfileIn( __METHOD__ . '-1' ); + + $s = "\n
\n"; + $s .= "\n\n\n"; + + wfProfileOut( __METHOD__ . '-2' ); + wfProfileIn( __METHOD__ . '-3' ); + if ( $this->getSkin()->qbSetting() != 0 ) { + $s .= $this->quickBar(); } - $s .= parent::getUserStyles(); + wfProfileOut( __METHOD__ . '-3' ); + wfProfileOut( __METHOD__ ); return $s; } /** - * + * @return string */ - function doGetUserStyles() { - global $wgUser, $wgOut, $wgStylePath; + function quickBar() { + global $wgContLang; - $s = parent::doGetUserStyles(); - $qb = $this->qbSetting(); + wfProfileIn( __METHOD__ ); - if ( 2 == $qb ) { # Right - $s .= "#quickbar { position: absolute; top: 4px; right: 4px; " . - "border-left: 2px solid #000000; }\n" . - "#article { margin-left: 4px; margin-right: 152px; }\n"; - } else if ( 1 == $qb || 3 == $qb ) { - $s .= "#quickbar { position: absolute; top: 4px; left: 4px; " . - "border-right: 1px solid gray; }\n" . - "#article { margin-left: 152px; margin-right: 4px; }\n"; + $action = $this->getSkin()->getRequest()->getText( 'action' ); + $wpPreview = $this->getSkin()->getRequest()->getBool( 'wpPreview' ); + $title = $this->getSkin()->getTitle(); + $tns = $title->getNamespace(); + + $s = "\n
"; + $s .= "\n" . $this->getSkin()->logoText() . "\n
"; + + $sep = "\n
"; + + # Use the first heading from the Monobook sidebar as the "browse" section + $bar = $this->getSkin()->buildSidebar(); + unset( $bar['SEARCH'] ); + unset( $bar['LANGUAGES'] ); + unset( $bar['TOOLBOX'] ); + + $barnumber = 1; + foreach ( $bar as $browseLinks ) { + if ( is_array( $browseLinks ) ) { + if ( $barnumber > 1 ) { + $s .= "\n
"; + } + foreach ( $browseLinks as $link ) { + if ( $link['text'] != '-' ) { + $s .= "" . + htmlspecialchars( $link['text'] ) . '' . $sep; + } + } + } + if ( $barnumber == 1 ) { + // only show watchlist link if logged in + if( $this->data['loggedin'] ) { + $s.= Linker::specialLink( 'Watchlist' ) ; + $s .= $sep . Linker::linkKnown( + SpecialPage::getTitleFor( 'Contributions' ), + wfMsg( 'mycontris' ), + array(), + array( 'target' => $this->data['username'] ) + ); + } + } + $barnumber = $barnumber + 1; } - return $s; - } - /** - * - */ - function getBodyOptions() { - $a = parent::getBodyOptions(); - - if ( 3 == $this->qbSetting() ) { # Floating left - $qb = "setup(\"quickbar\")"; - if($a["onload"]) { - $a["onload"] .= ";$qb"; - } else { - $a["onload"] = $qb; + $s .= "\n
"; + $articleExists = $title->getArticleId(); + if ( $this->data['isarticle'] || $action == 'edit' || $action == 'history' || $wpPreview ) { + if( $this->data['isarticle'] ) { + $s .= '' . $this->editThisPage() . ''; + } else { # backlink to the article in edit or history mode + if( $articleExists ){ # no backlink if no article + switch( $tns ) { + case NS_TALK: + case NS_USER_TALK: + case NS_PROJECT_TALK: + case NS_FILE_TALK: + case NS_MEDIAWIKI_TALK: + case NS_TEMPLATE_TALK: + case NS_HELP_TALK: + case NS_CATEGORY_TALK: + $text = wfMsg('viewtalkpage'); + break; + case NS_MAIN: + $text = wfMsg( 'articlepage' ); + break; + case NS_USER: + $text = wfMsg( 'userpage' ); + break; + case NS_PROJECT: + $text = wfMsg( 'projectpage' ); + break; + case NS_FILE: + $text = wfMsg( 'imagepage' ); + break; + case NS_MEDIAWIKI: + $text = wfMsg( 'mediawikipage' ); + break; + case NS_TEMPLATE: + $text = wfMsg( 'templatepage' ); + break; + case NS_HELP: + $text = wfMsg( 'viewhelppage' ); + break; + case NS_CATEGORY: + $text = wfMsg( 'categorypage' ); + break; + default: + $text = wfMsg( 'articlepage' ); + } + + $link = $title->getText(); + $nstext = $wgContLang->getNsText( $tns ); + if( $nstext ) { # add namespace if necessary + $link = $nstext . ':' . $link; + } + + $s .= Linker::link( Title::newFromText( $link ), $text ); + } elseif( $title->getNamespace() != NS_SPECIAL ) { + # we just throw in a "New page" text to tell the user that he's in edit mode, + # and to avoid messing with the separator that is prepended to the next item + $s .= '' . wfMsg( 'newpage' ) . ''; + } } + + # "Post a comment" link + if( ( $title->isTalkPage() || $this->getSkin()->getOutput()->showNewSectionLink() ) && $action != 'edit' && !$wpPreview ) + $s .= '
' . Linker::link( + $title, + wfMsg( 'postcomment' ), + array(), + array( + 'action' => 'edit', + 'section' => 'new' + ) + ); + + /** + * Watching could cause problems in edit mode: + * if user edits article, then loads "watch this article" in background and then saves + * article with "Watch this article" checkbox disabled, the article is transparently + * unwatched. Therefore we do not show the "Watch this page" link in edit mode. + */ + if ( $this->data['loggedin'] && $articleExists ) { + if( $action != 'edit' && $action != 'submit' ) { + $s .= $sep . $this->watchThisPage(); + } + if ( $title->userCan( 'edit' ) ) + $s .= $sep . $this->moveThisPage(); + } + if ( $this->getSkin()->getUser()->isAllowed( 'delete' ) && $articleExists ) { + $s .= $sep . $this->deleteThisPage() . + $sep . $this->protectThisPage(); + } + $s .= $sep . $this->talkLink(); + if( $articleExists && $action != 'history' ) { + $s .= $sep . $this->historyLink(); + } + $s .= $sep . $this->whatLinksHere(); + + if( $this->getSkin()->getOutput()->isArticleRelated() ) { + $s .= $sep . $this->watchPageLinksLink(); + } + + if ( + NS_USER == $title->getNamespace() || + $title->getNamespace() == NS_USER_TALK + ) { + + $id = User::idFromName( $title->getText() ); + $ip = User::isIP( $title->getText() ); + + if( $id || $ip ){ + $s .= $sep . $this->userContribsLink(); + } + if( $this->getSkin()->showEmailUser( $id ) ) { + $s .= $sep . $this->emailUserLink(); + } + } + $s .= "\n

"; + } + + if( UploadBase::isEnabled() && UploadBase::isAllowed( $this->getSkin()->getUser() ) === true ) { + $s .= $this->getUploadLink() . $sep; + } + + $s .= Linker::specialLink( 'Specialpages' ); + + global $wgSiteSupportPage; + if( $wgSiteSupportPage ) { + $s .= "\n
' . wfMsg( 'sitesupport' ) . ''; } - return $a; + + $s .= "\n
\n"; + wfProfileOut( __METHOD__ ); + return $s; } -} -?> +}