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=ba367a370d85fb72f07f7beb48b43bd63334877a;hpb=fd758aaa3c619ed1f3058117b55e61a3b59f8a63;p=lhc%2Fweb%2Fwiklou.git
diff --git a/skins/Standard.php b/skins/Standard.php
index ba367a370d..bd0c41a5c0 100644
--- a/skins/Standard.php
+++ b/skins/Standard.php
@@ -1,65 +1,279 @@
addModuleStyles( 'skins.standard' );
- function getHeadScripts()
- {
- global $wgStylePath;
+ $qb = $this->qbSetting();
+ $rules = array();
- $s = parent::getHeadScripts();
- if ( 3 == $this->qbSetting() ) { # Floating left
- $s .= "\n";
+ 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' );
}
- function getUserStyles()
- {
- global $wgStylePath;
- $s = '';
- if ( 3 == $this->qbSetting() ) { # Floating left
- $s .= "\n";
+}
+
+class StandardTemplate extends LegacyTemplate {
+
+ /**
+ * @return string
+ */
+ 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;
}
- function doGetUserStyles()
- {
- global $wgUser, $wgOut, $wgStylePath;
+ /**
+ * @return string
+ */
+ 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();
+ $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'
+ )
+ );
- if ( 3 == $this->qbSetting() ) { # Floating left
- $qb = "setup(\"quickbar\")";
- if($a["onload"]) {
- $a["onload"] .= ";$qb";
- } else {
- $a["onload"] = $qb;
+ /**
+ * 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;
}
- return $a;
+
+ $s .= Linker::specialLink( 'Specialpages' );
+
+ global $wgSiteSupportPage;
+ if( $wgSiteSupportPage ) {
+ $s .= "\n
' . wfMsg( 'sitesupport' ) . '';
+ }
+
+ $s .= "\n
\n";
+ wfProfileOut( __METHOD__ );
+ return $s;
}
-}
-?>
+}