-
Notifications
You must be signed in to change notification settings - Fork 4
/
SpecialNewPagesFeed.php
111 lines (96 loc) � 2.98 KB
/
SpecialNewPagesFeed.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<?php
namespace MediaWiki\Extension\PageTriage;
use Exception;
use MediaWiki\Config\ConfigException;
use MediaWiki\Html\Html;
use MediaWiki\Html\TemplateParser;
use MediaWiki\SpecialPage\SpecialPage;
/**
* This file defines the SpecialNewPagesFeed class which handles the functionality for the
* New Pages Feed (Special:NewPagesFeed).
*
* @file
* @ingroup Extensions
* @author Ryan Kaldari
*/
class SpecialNewPagesFeed extends SpecialPage {
/**
* Initialize the special page.
*
* @throws Exception
*/
public function __construct() {
parent::__construct( 'NewPagesFeed' );
}
/**
* Define what happens when the special page is loaded by the user.
* @param string $sub The subpage, if any
* @throws ConfigException
*/
public function execute( $sub ) {
$this->addHelpLink( 'Help:New_pages_feed' );
$config = $this->getConfig();
$request = $this->getRequest();
$showOresFilters = PageTriageUtil::oresIsAvailable() &&
( $config->get( 'PageTriageEnableOresFilters' ) || $request->getBool( 'ores' ) );
$showCopyvio = $showOresFilters &&
( $config->get( 'PageTriageEnableCopyvio' ) || $request->getBool( 'copyvio' ) );
$this->setHeaders();
$out = $this->getOutput();
// Output the title of the page
$out->setPageTitleMsg( $this->msg( 'newpagesfeed' ) );
// Load common interface css
$out->addModuleStyles( [ 'mediawiki.interface.helpers.styles' ] );
// Set the config flags in JavaScript
$globalVars = [
'pageTriageNamespaces' => PageTriageUtil::getNamespaces(),
'wgPageTriageEnableExtendedFeatures' => $config->get( 'PageTriageEnableExtendedFeatures' ),
'wgShowOresFilters' => $showOresFilters,
'wgShowCopyvio' => $showCopyvio,
];
$out->addJsConfigVars( $globalVars );
// Load the JS
$out->addModules( [
'ext.pageTriage.external',
'ext.pageTriage.util',
'ext.pageTriage.newPagesFeed'
] );
$header = '';
$header .= '<div id="mwe-pt-list-warnings" style="display: none;">';
$parsedWelcomeMessage = $this->msg(
'pagetriage-welcome',
$config->get( 'PageTriageLearnMoreUrl' ),
$config->get( 'PageTriageFeedbackUrl' )
)->parse();
$header .= Html::rawElement( 'div', [ 'class' => 'plainlinks' ], $parsedWelcomeMessage );
$header .= '</div>';
$out->addHTML( $header );
$out->addInlineStyle(
'.client-nojs #mwe-pt-list-view, .client-js #mwe-pt-list-view-no-js { display: none; }'
);
// Output the HTML for the triage interface
$out->addHTML( $this->getListViewHtml() );
}
/**
* Get the list control nav HTML.
*
* @return string
*/
private function getListViewHtml() {
$templateParser = new TemplateParser( __DIR__ . '/templates' );
// HTML for this is located in includes/templates/ListView.mustache
return $templateParser->processTemplate(
'ListView',
[
'pagetriage-please-wait' => $this->msg( 'pagetriage-please-wait' ),
'pagetriage-js-required' => $this->msg( 'pagetriage-js-required' ),
]
);
}
/**
* @inheritDoc
*/
protected function getGroupName() {
return 'changes';
}
}