*
*/
function wfSpecialAllmessages() {
- global $wgOut, $wgAllMessagesEn, $wgRequest, $wgMessageCache, $wgTitle;
- global $wgLanguageCode, $wgContLanguageCode, $wgContLang;
+ global $wgOut, $wgRequest, $wgMessageCache, $wgTitle;
global $wgUseDatabaseMessages;
- if(!$wgUseDatabaseMessages) {
- $wgOut->addHTML(wfMsg('allmessagesnotsupportedDB'));
+ # The page isn't much use if the MediaWiki namespace is not being used
+ if( !$wgUseDatabaseMessages ) {
+ $wgOut->addWikiText( wfMsg( 'allmessagesnotsupportedDB' ) );
return;
}
$fname = "wfSpecialAllMessages";
wfProfileIn( $fname );
-
+
wfProfileIn( "$fname-setup");
$ot = $wgRequest->getText( 'ot' );
- $mwMsg =& MagicWord::get( MAG_MSG );
-
- $navText = wfMsg( 'allmessagestext', $mwMsg->getSynonym( 0 ) );
+ $navText = wfMsg( 'allmessagestext' );
+
+ # Make sure all extension messages are available
+ MessageCache::loadAllMessages();
$first = true;
- $sortedArray = $wgAllMessagesEn;
+ $sortedArray = array_merge( Language::getMessagesFor( 'en' ), $wgMessageCache->getExtensionMessagesFor( 'en' ) );
ksort( $sortedArray );
$messages = array();
$wgMessageCache->disableTransform();
- foreach ( $sortedArray as $key => $enMsg ) {
- $messages[$key]['enmsg'] = $enMsg;
+ foreach ( $sortedArray as $key => $value ) {
+ $messages[$key]['enmsg'] = $value;
$messages[$key]['statmsg'] = wfMsgNoDb( $key );
$messages[$key]['msg'] = wfMsg ( $key );
}
$wgMessageCache->enableTransform();
wfProfileOut( "$fname-setup" );
-
+
wfProfileIn( "$fname-output" );
if ($ot == 'php') {
$navText .= makePhp($messages);
$wgOut->addHTML( makeHTMLText( $messages ) );
}
wfProfileOut( "$fname-output" );
-
+
wfProfileOut( $fname );
}
*
*/
function makePhp($messages) {
- global $wgLanguageCode;
- $txt = "\n\n".'$wgAllMessages'.ucfirst($wgLanguageCode).' = array('."\n";
+ global $wgLang;
+ $txt = "\n\n\$messages = array(\n";
foreach( $messages as $key => $m ) {
- if(strtolower($wgLanguageCode) != 'en' and $m['msg'] == $m['enmsg'] ) {
- if (strstr($m['msg'],"\n")) {
- $txt.='/* ';
- $comment=' */';
- } else {
- $txt .= '#';
- $comment = '';
- }
+ if($wgLang->getCode() != 'en' and $m['msg'] == $m['enmsg'] ) {
+ //if (strstr($m['msg'],"\n")) {
+ // $txt.='/* ';
+ // $comment=' */';
+ //} else {
+ // $txt .= '#';
+ // $comment = '';
+ //}
+ continue;
} elseif ($m['msg'] == '<'.$key.'>'){
$m['msg'] = '';
$comment = ' #empty';
} else {
$comment = '';
}
- $txt .= "'".$key."' => \"".str_replace('"','\"',$m['msg'])."\",$comment\n";
+ $txt .= "'$key' => '" . preg_replace( "/(?<!\\\\)'/", "\'", $m['msg']) . "',$comment\n";
}
$txt .= ');';
return $txt;
*
*/
function makeHTMLText( $messages ) {
- global $wgLang, $wgUser, $wgLanguageCode, $wgContLanguageCode, $wgContLang;
+ global $wgLang, $wgContLang, $wgUser;
$fname = "makeHTMLText";
wfProfileIn( $fname );
-
+
$sk =& $wgUser->getSkin();
$talk = $wgLang->getNsText( NS_TALK );
$mwnspace = $wgLang->getNsText( NS_MEDIAWIKI );
$mwtalk = $wgLang->getNsText( NS_MEDIAWIKI_TALK );
- $txt = "
- <table border='1' cellspacing='0' width='100%'>
- <tr bgcolor='#b2b2ff'>
- <th>" . wfMsg('allmessagesname') . "</th>
- <th>" . wfMsg('allmessagesdefault') . "</th>
- <th>" . wfMsg('allmessagescurrent') . "</th>
+ $input = wfElement( 'input', array(
+ 'type' => 'text',
+ 'id' => 'allmessagesinput',
+ 'onkeyup' => 'allmessagesfilter()',),
+ '');
+ $checkbox = wfElement( 'input', array(
+ 'type' => 'button',
+ 'value' => wfMsgHtml( 'allmessagesmodified' ),
+ 'id' => 'allmessagescheckbox',
+ 'onclick' => 'allmessagesmodified()',),
+ '');
+
+ $txt = '<span id="allmessagesfilter" style="display:none;">' .
+ wfMsgHtml('allmessagesfilter') . " {$input}{$checkbox} " . '</span>';
+
+ $txt .= "
+<table border='1' cellspacing='0' width='100%' id='allmessagestable'>
+ <tr>
+ <th rowspan='2'>" . wfMsgHtml('allmessagesname') . "</th>
+ <th>" . wfMsgHtml('allmessagesdefault') . "</th>
+ </tr>
+ <tr>
+ <th>" . wfMsgHtml('allmessagescurrent') . "</th>
</tr>";
-
+
wfProfileIn( "$fname-check" );
# This is a nasty hack to avoid doing independent existence checks
# without sending the links and table through the slow wiki parser.
wfProfileIn( "$fname-output" );
+ $i = 0;
+
foreach( $messages as $key => $m ) {
$title = $wgLang->ucfirst( $key );
- if($wgLanguageCode != $wgContLanguageCode)
- $title.="/$wgLanguageCode";
+ if($wgLang->getCode() != $wgContLang->getCode())
+ $title.= '/' . $wgLang->getCode();
$titleObj =& Title::makeTitle( NS_MEDIAWIKI, $title );
$talkPage =& Title::makeTitle( NS_MEDIAWIKI_TALK, $title );
- $colorIt = ($m['statmsg'] == $m['msg']) ? " bgcolor=\"#f0f0ff\"" : " bgcolor=\"#ffe2e2\"";
+ $changed = ($m['statmsg'] != $m['msg']);
$message = htmlspecialchars( $m['statmsg'] );
$mw = htmlspecialchars( $m['msg'] );
-
+
#$pageLink = $sk->makeLinkObj( $titleObj, htmlspecialchars( $key ) );
#$talkLink = $sk->makeLinkObj( $talkPage, htmlspecialchars( $talk ) );
if( isset( $pageExists[NS_MEDIAWIKI][$title] ) ) {
- $pageLink = $sk->makeKnownLinkObj( $titleObj, htmlspecialchars( $key ) );
+ $pageLink = $sk->makeKnownLinkObj( $titleObj, "<span id='sp-allmessages-i-$i'>" . htmlspecialchars( $key ) . "</span>" );
} else {
- $pageLink = $sk->makeBrokenLinkObj( $titleObj, htmlspecialchars( $key ) );
+ $pageLink = $sk->makeBrokenLinkObj( $titleObj, "<span id='sp-allmessages-i-$i'>" . htmlspecialchars( $key ) . "</span>" );
}
if( isset( $pageExists[NS_MEDIAWIKI_TALK][$title] ) ) {
$talkLink = $sk->makeKnownLinkObj( $talkPage, htmlspecialchars( $talk ) );
} else {
$talkLink = $sk->makeBrokenLinkObj( $talkPage, htmlspecialchars( $talk ) );
}
+
+ $anchor = 'msg_' . htmlspecialchars( strtolower( $title ) );
+ $anchor = "<a id=\"$anchor\" name=\"$anchor\"></a>";
+
+ if($changed) {
- $txt .=
- "<tr$colorIt><td>
- $pageLink<br />
- $talkLink
+ $txt .= "
+ <tr class='orig' id='sp-allmessages-r1-$i'>
+ <td rowspan='2'>
+ $anchor$pageLink<br />$talkLink
</td><td>
- $message
+$message
+ </td>
+ </tr><tr class='new' id='sp-allmessages-r2-$i'>
+ <td>
+$mw
+ </td>
+ </tr>";
+ } else {
+
+ $txt .= "
+ <tr class='def' id='sp-allmessages-r1-$i'>
+ <td>
+ $anchor$pageLink<br />$talkLink
</td><td>
- $mw
- </td></tr>";
+$mw
+ </td>
+ </tr>";
+
+ }
+ $i++;
}
$txt .= "</table>";
wfProfileOut( "$fname-output" );