MediaWiki master
OldChangesList.php
Go to the documentation of this file.
1<?php
26
33
44 public function recentChangesLine( &$rc, $watched = false, $linenumber = null ) {
45 $classes = $this->getHTMLClasses( $rc, $watched );
46 // use mw-line-even/mw-line-odd class only if linenumber is given (feature from T16468)
47 if ( $linenumber ) {
48 if ( $linenumber & 1 ) {
49 $classes[] = 'mw-line-odd';
50 } else {
51 $classes[] = 'mw-line-even';
52 }
53 }
54
55 $html = $this->formatChangeLine( $rc, $classes, $watched );
56
57 if ( $this->watchlist ) {
58 $classes[] = Sanitizer::escapeClass( 'watchlist-' .
59 $rc->mAttribs['rc_namespace'] . '-' . $rc->mAttribs['rc_title'] );
60 }
61
62 $attribs = $this->getDataAttributes( $rc );
63
64 if ( !$this->getHookRunner()->onOldChangesListRecentChangesLine(
65 $this, $html, $rc, $classes, $attribs )
66 ) {
67 return false;
68 }
69 $attribs = array_filter( $attribs,
70 [ Sanitizer::class, 'isReservedDataAttribute' ],
71 ARRAY_FILTER_USE_KEY
72 );
73
74 $dateheader = ''; // $html now contains only <li>...</li>, for hooks' convenience.
75 $this->insertDateHeader( $dateheader, $rc->mAttribs['rc_timestamp'] );
76
77 $html = $this->getHighlightsContainerDiv() . $html;
78 $attribs['class'] = $classes;
79
80 return $dateheader . Html::rawElement( 'li', $attribs, $html ) . "\n";
81 }
82
90 private function formatChangeLine( RecentChange $rc, array &$classes, $watched ) {
91 $html = '';
92 $unpatrolled = $this->showAsUnpatrolled( $rc );
93
94 if ( $rc->mAttribs['rc_log_type'] ) {
95 $logtitle = SpecialPage::getTitleFor( 'Log', $rc->mAttribs['rc_log_type'] );
96 $this->insertLog( $html, $logtitle, $rc->mAttribs['rc_log_type'], false );
97 $flags = $this->recentChangesFlags( [ 'unpatrolled' => $unpatrolled,
98 'bot' => $rc->mAttribs['rc_bot'] ], '' );
99 if ( $flags !== '' ) {
100 $html .= ' ' . $flags;
101 }
102 // Log entries (old format) or log targets, and special pages
103 } elseif ( $rc->mAttribs['rc_namespace'] == NS_SPECIAL ) {
104 [ $name, $htmlubpage ] = MediaWikiServices::getInstance()->getSpecialPageFactory()->
105 resolveAlias( $rc->mAttribs['rc_title'] );
106 if ( $name == 'Log' ) {
107 $this->insertLog( $html, $rc->getTitle(), $htmlubpage, false );
108 }
109 // Regular entries
110 } else {
111 $this->insertDiffHist( $html, $rc );
112 # M, N, b and ! (minor, new, bot and unpatrolled)
113 $html .= $this->recentChangesFlags(
114 [
115 'newpage' => $rc->mAttribs['rc_type'] == RC_NEW,
116 'minor' => $rc->mAttribs['rc_minor'],
117 'unpatrolled' => $unpatrolled,
118 'bot' => $rc->mAttribs['rc_bot']
119 ],
120 ''
121 );
122 $html .= $this->getArticleLink( $rc, $unpatrolled, $watched );
123 }
124 # Edit/log timestamp
125 $this->insertTimestamp( $html, $rc );
126 # Bytes added or removed
127 if ( $this->getConfig()->get( MainConfigNames::RCShowChangedSize ) ) {
128 $cd = $this->formatCharacterDifference( $rc );
129 if ( $cd !== '' ) {
130 $html .= $cd . ' <span class="mw-changeslist-separator"></span> ';
131 }
132 }
133
134 if ( $rc->mAttribs['rc_type'] == RC_LOG ) {
135 $html .= $this->insertLogEntry( $rc );
136 } elseif ( $this->isCategorizationWithoutRevision( $rc ) ) {
137 $html .= $this->insertComment( $rc );
138 } else {
139 # User tool links
140 $this->insertUserRelatedLinks( $html, $rc );
141 $html .= $this->insertComment( $rc );
142 }
143
144 # Tags
145 $this->insertTags( $html, $rc, $classes );
146 # Rollback
147 $this->insertRollback( $html, $rc );
148 # For subclasses
149 $this->insertExtra( $html, $rc, $classes );
150
151 # How many users watch this page
152 if ( $rc->numberofWatchingusers > 0 ) {
153 $html .= ' ' . $this->numberofWatchingusers( $rc->numberofWatchingusers );
154 }
155
156 $html = Html::rawElement( 'span', [
157 'class' => 'mw-changeslist-line-inner',
158 'data-target-page' => $rc->getTitle(), // Used for reliable determination of the affiliated page
159 ], $html );
160 if ( is_callable( $this->changeLinePrefixer ) ) {
161 $prefix = call_user_func( $this->changeLinePrefixer, $rc, $this, false );
162 $html = Html::rawElement( 'span', [ 'class' => 'mw-changeslist-line-prefix' ], $prefix ) . $html;
163 }
164
165 return $html;
166 }
167}
const RC_NEW
Definition Defines.php:118
const NS_SPECIAL
Definition Defines.php:54
const RC_LOG
Definition Defines.php:119
Base class for lists of recent changes shown on special pages.
insertDateHeader(&$s, $rc_timestamp)
insertRollback(&$s, &$rc)
Insert a rollback link.
getHighlightsContainerDiv()
Get the container for highlights that are used in the new StructuredFilters system.
recentChangesFlags( $flags, $nothing="\u{00A0}")
Returns the appropriate flags for new page, minor change and patrolling.
getDataAttributes(RecentChange $rc)
Get recommended data attributes for a change line.
numberofWatchingusers( $count)
Returns the string which indicates the number of watching users.
getHTMLClasses( $rc, $watched)
Get an array of default HTML class attributes for the change.
formatCharacterDifference(RecentChange $old, ?RecentChange $new=null)
Format the character difference of one or several changes.
getArticleLink(&$rc, $unpatrolled, $watched)
Get the HTML link to the changed page, possibly with a prefix from hook handlers, and a suffix for te...
insertUserRelatedLinks(&$s, &$rc)
Insert links to user page, user talk page and eventually a blocking link.
insertLogEntry( $rc)
Insert a formatted action.
insertLog(&$s, $title, $logtype, $useParentheses=true)
insertTags(&$s, &$rc, &$classes)
insertComment( $rc)
Insert a formatted comment.
insertExtra(&$s, &$rc, &$classes)
isCategorizationWithoutRevision( $rcObj)
Determines whether a revision is linked to this change; this may not be the case when the categorizat...
insertDiffHist(&$s, &$rc, $unpatrolled=null)
insertTimestamp(&$s, $rc)
Insert time timestamp string from $rc into $s.
This class is a collection of static functions that serve two purposes:
Definition Html.php:56
A class containing constants representing the names of configuration variables.
Service locator for MediaWiki core services.
HTML sanitizer for MediaWiki.
Definition Sanitizer.php:46
Parent class for all special pages.
Generate a list of changes using the good old system (no javascript).
recentChangesLine(&$rc, $watched=false, $linenumber=null)
Format a line using the old system (aka without any javascript).
Utility class for creating and reading rows in the recentchanges table.