3 function wfSpecialContributions( $par = "" )
5 global $wgUser, $wgOut, $wgLang, $target, $hideminor;
6 $fname = "wfSpecialContributions";
7 $sysop = $wgUser->isSysop();
12 $target = wfCleanQueryVar( $target );
14 if ( "" == $target ) {
15 $wgOut->errorpage( "notargettitle", "notargettext" );
18 list( $limit, $offset ) = wfCheckLimits( 50, "" );
19 $offlimit = $limit +
$offset;
21 $nt = Title
::newFromURL( $target );
22 $nt->setNamespace( Namespace::getUser() );
24 $sk = $wgUser->getSkin();
25 $id = User
::idFromName( $nt->getText() );
30 $ul = $sk->makeKnownLink( $nt->getPrefixedText(), $nt->getText() );
32 $talk = $nt->getTalkPage();
34 $ul .= " (" . $sk->makeLinkObj( $talk, $wgLang->getNsText(Namespace::getTalk(0)) ) . ")";
37 $wgOut->setSubtitle( wfMsg( "contribsub", $ul ) );
39 if ( ! isset( $hideminor ) ) {
40 $hideminor = $wgUser->getOption( "hideminor" );
43 $cmq = "AND cur_minor_edit=0";
44 $omq = "AND old_minor_edit=0";
45 } else { $cmq = $omq = ""; }
47 $top = wfShowingResults( $offset, $limit );
48 $wgOut->addHTML( "<p>{$top}\n" );
50 $sl = wfViewPrevNext( $offset, $limit,
51 $wgLang->specialpage( "Contributions" ), "target=" . wfUrlEncode( $target ) );
52 $wgOut->addHTML( "<br>{$sl}\n" );
55 $sql = "SELECT cur_namespace,cur_title,cur_timestamp,cur_comment FROM cur " .
56 "WHERE cur_user_text='" . wfStrencode( $nt->getText() ) . "' {$cmq} " .
57 "ORDER BY inverse_timestamp LIMIT {$offlimit}";
58 $res1 = wfQuery( $sql, DB_READ
, $fname );
60 $sql = "SELECT old_namespace,old_title,old_timestamp,old_comment FROM old " .
61 "WHERE old_user_text='" . wfStrencode( $nt->getText() ) . "' {$omq} " .
62 "ORDER BY inverse_timestamp LIMIT {$offlimit}";
63 $res2 = wfQuery( $sql, DB_READ
, $fname );
65 $sql = "SELECT cur_namespace,cur_title,cur_timestamp,cur_comment FROM cur " .
66 "WHERE cur_user={$id} {$cmq} ORDER BY inverse_timestamp LIMIT {$offlimit}";
67 $res1 = wfQuery( $sql, DB_READ
, $fname );
69 $sql = "SELECT old_namespace,old_title,old_timestamp,old_comment FROM old " .
70 "WHERE old_user={$id} {$omq} ORDER BY inverse_timestamp LIMIT {$offlimit}";
71 $res2 = wfQuery( $sql, DB_READ
, $fname );
73 $nCur = wfNumRows( $res1 );
74 $nOld = wfNumRows( $res2 );
77 if ( 0 == $nCur && 0 == $nOld ) {
78 $wgOut->addHTML( "\n<p>" . wfMsg( "nocontribs" ) . "</p>\n" );
81 if ( 0 != $nCur ) { $obj1 = wfFetchObject( $res1 ); }
82 if ( 0 != $nOld ) { $obj2 = wfFetchObject( $res2 ); }
84 $wgOut->addHTML( "<ul>\n" );
85 for( $n = 0; $n < $offlimit; $n++
) {
86 if ( 0 == $nCur && 0 == $nOld ) { break; }
88 if ( ( 0 == $nOld ) ||
90 ( $obj1->cur_timestamp
>= $obj2->old_timestamp
) ) ) {
91 $ns = $obj1->cur_namespace
;
92 $t = $obj1->cur_title
;
93 $ts = $obj1->cur_timestamp
;
94 $comment =$obj1->cur_comment
;
96 $obj1 = wfFetchObject( $res1 );
100 $ns = $obj2->old_namespace
;
101 $t = $obj2->old_title
;
102 $ts = $obj2->old_timestamp
;
103 $comment =$obj2->old_comment
;
105 $obj2 = wfFetchObject( $res2 );
110 ucListEdit( $sk, $ns, $t, $ts, $topmark, $comment );
112 $wgOut->addHTML( "</ul>\n" );
115 function ucListEdit( $sk, $ns, $t, $ts, $topmark, $comment )
117 global $wgLang, $wgOut, $wgUser, $target;
118 $page = Title
::makeName( $ns, $t );
119 $link = $sk->makeKnownLink( $page, "" );
120 $topmarktext = $topmark ?
wfMsg ( "uctop" ) : "";
121 $sysop = $wgUser->isSysop();
122 if($sysop && $topmark ) {
123 $topmarktext .= " [". $sk->makeKnownLink( $page,
124 wfMsg( "rollbacklink" ), "action=rollback&from=" . urlencode( $target ) ) ."]";
128 $comment="<em>(". htmlspecialchars( $comment ) .")</em> ";
131 $d = $wgLang->timeanddate( $ts, true );
133 $wgOut->addHTML( "<li>{$d} {$link} {$comment}{$topmarktext}</li>\n" );
136 function ucCountLink( $lim, $d )
138 global $wgUser, $wgLang, $target;
140 $sk = $wgUser->getSkin();
141 $s = $sk->makeKnownLink( $wgLang->specialPage( "Contributions" ),
142 "{$lim}", "target={$target}&days={$d}&limit={$lim}" );
146 function ucDaysLink( $lim, $d )
148 global $wgUser, $wgLang, $target;
150 $sk = $wgUser->getSkin();
151 $s = $sk->makeKnownLink( $wgLang->specialPage( "Contributions" ),
152 "{$d}", "target={$target}&days={$d}&limit={$lim}" );