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() );
27 if ( 0 == $id ) { $ul = $nt->getText(); }
29 $ul = $sk->makeKnownLink( $nt->getPrefixedText(), $nt->getText() );
31 $wgOut->setSubtitle( wfMsg( "contribsub", $ul ) );
33 if ( ! isset( $hideminor ) ) {
34 $hideminor = $wgUser->getOption( "hideminor" );
37 $cmq = "AND cur_minor_edit=0";
38 $omq = "AND old_minor_edit=0";
39 } else { $cmq = $omq = ""; }
41 $top = wfShowingResults( $offset, $limit );
42 $wgOut->addHTML( "<p>{$top}\n" );
44 $sl = wfViewPrevNext( $offset, $limit,
45 $wgLang->specialpage( "Contributions" ), "target=" . wfUrlEncode( $target ) );
46 $wgOut->addHTML( "<br>{$sl}\n" );
49 $sql = "SELECT cur_namespace,cur_title,cur_timestamp,cur_comment FROM cur " .
50 "WHERE cur_user_text='" . wfStrencode( $nt->getText() ) . "' {$cmq} " .
51 "ORDER BY inverse_timestamp LIMIT {$offlimit}";
52 $res1 = wfQuery( $sql, DB_READ
, $fname );
54 $sql = "SELECT old_namespace,old_title,old_timestamp,old_comment FROM old " .
55 "WHERE old_user_text='" . wfStrencode( $nt->getText() ) . "' {$omq} " .
56 "ORDER BY inverse_timestamp LIMIT {$offlimit}";
57 $res2 = wfQuery( $sql, DB_READ
, $fname );
59 $sql = "SELECT cur_namespace,cur_title,cur_timestamp,cur_comment FROM cur " .
60 "WHERE cur_user={$id} {$cmq} ORDER BY inverse_timestamp LIMIT {$offlimit}";
61 $res1 = wfQuery( $sql, DB_READ
, $fname );
63 $sql = "SELECT old_namespace,old_title,old_timestamp,old_comment FROM old " .
64 "WHERE old_user={$id} {$omq} ORDER BY inverse_timestamp LIMIT {$offlimit}";
65 $res2 = wfQuery( $sql, DB_READ
, $fname );
67 $nCur = wfNumRows( $res1 );
68 $nOld = wfNumRows( $res2 );
71 if ( 0 == $nCur && 0 == $nOld ) {
72 $wgOut->addHTML( "\n<p>" . wfMsg( "nocontribs" ) . "</p>\n" );
75 if ( 0 != $nCur ) { $obj1 = wfFetchObject( $res1 ); }
76 if ( 0 != $nOld ) { $obj2 = wfFetchObject( $res2 ); }
78 $wgOut->addHTML( "<ul>\n" );
79 for( $n = 0; $n < $offlimit; $n++
) {
80 if ( 0 == $nCur && 0 == $nOld ) { break; }
82 if ( ( 0 == $nOld ) ||
84 ( $obj1->cur_timestamp
>= $obj2->old_timestamp
) ) ) {
85 $ns = $obj1->cur_namespace
;
86 $t = $obj1->cur_title
;
87 $ts = $obj1->cur_timestamp
;
88 $comment =$obj1->cur_comment
;
90 $obj1 = wfFetchObject( $res1 );
94 $ns = $obj2->old_namespace
;
95 $t = $obj2->old_title
;
96 $ts = $obj2->old_timestamp
;
97 $comment =$obj2->old_comment
;
99 $obj2 = wfFetchObject( $res2 );
104 ucListEdit( $sk, $ns, $t, $ts, $topmark, $comment );
106 $wgOut->addHTML( "</ul>\n" );
109 function ucListEdit( $sk, $ns, $t, $ts, $topmark, $comment )
111 global $wgLang, $wgOut, $wgUser, $target;
112 $page = Title
::makeName( $ns, $t );
113 $link = $sk->makeKnownLink( $page, "" );
114 $topmarktext = $topmark ?
wfMsg ( "uctop" ) : "";
115 $sysop = $wgUser->isSysop();
116 if($sysop && $topmark ) {
117 $topmarktext .= " [". $sk->makeKnownLink( $page,
118 wfMsg( "rollbacklink" ), "action=rollback&from=" . urlencode( $target ) ) ."]";
122 $comment="<em>(". htmlspecialchars( $comment ) .")</em> ";
125 $d = $wgLang->timeanddate( $ts, true );
127 $wgOut->addHTML( "<li>{$d} {$link} {$comment}{$topmarktext}</li>\n" );
130 function ucCountLink( $lim, $d )
132 global $wgUser, $wgLang, $target;
134 $sk = $wgUser->getSkin();
135 $s = $sk->makeKnownLink( $wgLang->specialPage( "Contributions" ),
136 "{$lim}", "target={$target}&days={$d}&limit={$lim}" );
140 function ucDaysLink( $lim, $d )
142 global $wgUser, $wgLang, $target;
144 $sk = $wgUser->getSkin();
145 $s = $sk->makeKnownLink( $wgLang->specialPage( "Contributions" ),
146 "{$d}", "target={$target}&days={$d}&limit={$lim}" );