X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FCredits.php;h=65a879393675b9f84bb0b40eb107b6d65ac07139;hb=819ffd2be340513bfe40be368fe4699af639977b;hp=4e30b81582c9d27975db995cf93d63c5973fd5d5;hpb=4e9e22c4b1e5b6dc147dd342376ad48820247a4d;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/Credits.php b/includes/Credits.php index 4e30b81582..65a8793936 100644 --- a/includes/Credits.php +++ b/includes/Credits.php @@ -1,172 +1,219 @@ . - * + * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * - * This program is distributed in the hope that it will be useful, + * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + * + * @author */ -/* This is largely cadged from PageHistory::history */ - -function showCreditsPage($article) -{ - global $wgOut; +class Credits { - $fname = "showCreditsPage"; - - wfProfileIn( $fname ); - - $wgOut->setPageTitle( $article->mTitle->getPrefixedText() ); - $wgOut->setSubtitle( wfMsg( "creditspage" ) ); - $wgOut->setArticleFlag( false ); - $wgOut->setArticleRelated( true ); - $wgOut->setRobotpolicy( "noindex,nofollow" ); - - if( $article->mTitle->getArticleID() == 0 ) { - $s = wfMsg( "nocredits" ); - } else { - $s = getCredits($article, -1); - } + /** + * This is largely cadged from PageHistory::history + * @param $article Article object + */ + public static function showPage( Article $article ) { + global $wgOut; + + wfProfileIn( __METHOD__ ); + + $wgOut->setPageTitle( $article->mTitle->getPrefixedText() ); + $wgOut->setSubtitle( wfMsg( 'creditspage' ) ); + $wgOut->setArticleFlag( false ); + $wgOut->setArticleRelated( true ); + $wgOut->setRobotPolicy( 'noindex,nofollow' ); + + if( $article->mTitle->getArticleID() == 0 ) { + $s = wfMsg( 'nocredits' ); + } else { + $s = self::getCredits( $article, -1 ); + } + + $wgOut->addHTML( $s ); + + wfProfileOut( __METHOD__ ); + } - $wgOut->addHTML( $s ); - - wfProfileOut( $fname ); -} + /** + * Get a list of contributors of $article + * @param $article Article object + * @param $cnt Int: maximum list of contributors to show + * @param $showIfMax Bool: whether to contributors if there more than $cnt + * @return String: html + */ + public static function getCredits( Article $article, $cnt, $showIfMax = true ) { + wfProfileIn( __METHOD__ ); + $s = ''; + + if( isset( $cnt ) && $cnt != 0 ){ + $s = self::getAuthor( $article ); + if ( $cnt > 1 || $cnt < 0 ) { + $s .= ' ' . self::getContributors( $article, $cnt - 1, $showIfMax ); + } + } + + wfProfileOut( __METHOD__ ); + return $s; + } -function getCredits($article, $cnt, $showIfMax=true) { - - $s = ''; - - if (isset($cnt) && $cnt != 0) { - $s = getAuthorCredits($article); - if ($cnt > 1 || $cnt < 0) { - $s .= ' ' . getContributorCredits($article, $cnt - 1, $showIfMax); + /** + * Get the last author with the last modification time + * @param $article Article object + */ + protected static function getAuthor( Article $article ){ + global $wgLang; + + $user = User::newFromId( $article->getUser() ); + + $timestamp = $article->getTimestamp(); + if( $timestamp ){ + $d = $wgLang->date( $article->getTimestamp(), true ); + $t = $wgLang->time( $article->getTimestamp(), true ); + } else { + $d = ''; + $t = ''; + } + return wfMsgExt( 'lastmodifiedatby', 'parsemag', $d, $t, self::userLink( $user ), $user->getName() ); } - } - - return $s; -} -function getAuthorCredits($article) { - - global $wgLang; - - $last_author = $article->getUser(); - - if ($last_author == 0) { - $author_credit = wfMsg('anonymous'); - } else { + /** + * Get a list of contributors of $article + * @param $article Article object + * @param $cnt Int: maximum list of contributors to show + * @param $showIfMax Bool: whether to contributors if there more than $cnt + * @return String: html + */ + protected static function getContributors( Article $article, $cnt, $showIfMax ) { + global $wgLang, $wgHiddenPrefs; - $real_name = User::whoIsReal($last_author); - $user_name = User::whoIs($last_author); + $contributors = $article->getContributors(); - if (!empty($real_name)) { - $author_credit = creditLink($user_name, $real_name); - } else { - $author_credit = wfMsg('siteuser', creditLink($user_name)); - } - } - - $timestamp = $article->getTimestamp(); - if ($timestamp) { - $d = $wgLang->timeanddate($article->getTimestamp(), true); - } else { - $d = ''; - } - return wfMsg('lastmodifiedby', $d, $author_credit); -} - -function getContributorCredits($article, $cnt, $showIfMax) { - - global $wgLang, $wgAllowRealName; - - $contributors = $article->getContributors(); - - $others_link = ''; - - # Hmm... too many to fit! - - if ($cnt > 0 && count($contributors) > $cnt) { - $others_link = creditOthersLink($article); - if (!$showIfMax) { - return wfMsg('othercontribs', $others_link); - } else { - $contributors = array_slice($contributors, 0, $cnt); - } - } + $others_link = false; - $real_names = array(); - $user_names = array(); - - $anon = ''; - - # Sift for real versus user names - - foreach ($contributors as $user_parts) { - if ($user_parts[0] != 0) { - if ($wgAllowRealName && !empty($user_parts[2])) { - $real_names[] = creditLink($user_parts[1], $user_parts[2]); - } else { - $user_names[] = creditLink($user_parts[1]); - } - } else { - $anon = wfMsg('anonymous'); - } - } + # Hmm... too many to fit! + if( $cnt > 0 && $contributors->count() > $cnt ){ + $others_link = self::othersLink( $article ); + if( !$showIfMax ) + return wfMsgExt( 'othercontribs', 'parsemag', $others_link, $contributors->count() ); + } + + $real_names = array(); + $user_names = array(); + $anon_ips = array(); + + # Sift for real versus user names + foreach( $contributors as $user ) { + $cnt--; + if( $user->isLoggedIn() ){ + $link = self::link( $user ); + if( !in_array( 'realname', $wgHiddenPrefs ) && $user->getRealName() ) + $real_names[] = $link; + else + $user_names[] = $link; + } else { + $anon_ips[] = self::link( $user ); + } + if( $cnt == 0 ) break; + } + + if ( count( $real_names ) ) { + $real = $wgLang->listToText( $real_names ); + } else { + $real = false; + } + + # "ThisSite user(s) A, B and C" + if( count( $user_names ) ){ + $user = wfMsgExt( 'siteusers', array( 'parsemag' ), + $wgLang->listToText( $user_names ), count( $user_names ) ); + } else { + $user = false; + } + + if( count( $anon_ips ) ){ + $anon = wfMsgExt( 'anonusers', array( 'parsemag' ), + $wgLang->listToText( $anon_ips ), count( $anon_ips ) ); + } else { + $anon = false; + } - # Two strings: real names, and user names - - $real = $wgLang->listToText($real_names); - $user = $wgLang->listToText($user_names); - - # "ThisSite user(s) A, B and C" - - if (!empty($user)) { - $user = wfMsg('siteusers', $user); - } - - # This is the big list, all mooshed together. We sift for blank strings - - $fulllist = array(); - - foreach (array($real, $user, $anon, $others_link) as $s) { - if (!empty($s)) { - array_push($fulllist, $s); + # This is the big list, all mooshed together. We sift for blank strings + $fulllist = array(); + foreach( array( $real, $user, $anon, $others_link ) as $s ){ + if( $s ){ + array_push( $fulllist, $s ); + } + } + + # Make the list into text... + $creds = $wgLang->listToText( $fulllist ); + + # "Based on work by ..." + return strlen( $creds ) + ? wfMsgExt( 'othercontribs', 'parsemag', $creds, count( $fulllist ) ) + : ''; } - } - # Make the list into text... - - $creds = $wgLang->listToText($fulllist); - - # "Based on work by ..." - - return wfMsg('othercontribs', $creds); -} + /** + * Get a link to $user's user page + * @param $user User object + * @return String: html + */ + protected static function link( User $user ) { + global $wgUser, $wgHiddenPrefs; + if( !in_array( 'realname', $wgHiddenPrefs ) && !$user->isAnon() ) + $real = $user->getRealName(); + else + $real = false; + + $skin = $wgUser->getSkin(); + $page = $user->isAnon() ? + SpecialPage::getTitleFor( 'Contributions', $user->getName() ) : + $user->getUserPage(); + + return $skin->link( $page, htmlspecialchars( $real ? $real : $user->getName() ) ); + } -function creditLink($user_name, $link_text = '') { - global $wgUser, $wgLang; - $skin = $wgUser->getSkin(); - return $skin->makeLink($wgLang->getNsText(NS_USER) . ":" . $user_name, - (empty($link_text)) ? $user_name : $link_text); -} + /** + * Get a link to $user's user page + * @param $user User object + * @return String: html + */ + protected static function userLink( User $user ) { + $link = self::link( $user ); + if( $user->isAnon() ){ + return wfMsgExt( 'anonuser', array( 'parseinline', 'replaceafter' ), $link ); + } else { + global $wgHiddenPrefs; + if( !in_array( 'realname', $wgHiddenPrefs ) && $user->getRealName() ) + return $link; + else + return wfMsgExt( 'siteuser', array( 'parseinline', 'replaceafter' ), $link ); + } + } -function creditOthersLink($article) { - global $wgUser, $wgLang; - $skin = $wgUser->getSkin(); - return $skin->makeKnownLink($article->mTitle->getPrefixedText(), wfMsg('others'), "action=credits"); + /** + * Get a link to action=credits of $article page + * @param $article Article object + * @return String: html + */ + protected static function othersLink( Article $article ) { + global $wgUser; + $skin = $wgUser->getSkin(); + return $skin->link( $article->getTitle(), wfMsgHtml( 'others' ), array(), array( 'action' => 'credits' ), array( 'known' ) ); + } } - -?>