3 * Resource loader module for user customizations.
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
21 * @author Trevor Parscal
22 * @author Roan Kattouw
26 * Module for user customizations
28 class ResourceLoaderUserModule
extends ResourceLoaderWikiModule
{
30 /* Protected Members */
32 protected $origin = self
::ORIGIN_USER_INDIVIDUAL
;
34 /* Protected Methods */
37 * @param ResourceLoaderContext $context
40 protected function getPages( ResourceLoaderContext
$context ) {
41 global $wgAllowUserJs, $wgAllowUserCss;
42 $username = $context->getUser();
44 if ( $username === null ) {
47 if ( !$wgAllowUserJs && !$wgAllowUserCss ) {
51 // Get the normalized title of the user's user page
52 $userpageTitle = Title
::makeTitleSafe( NS_USER
, $username );
54 if ( !$userpageTitle instanceof Title
) {
58 $userpage = $userpageTitle->getPrefixedDBkey(); // Needed so $excludepages works
61 if ( $wgAllowUserJs ) {
62 $pages["$userpage/common.js"] = array( 'type' => 'script' );
63 $pages["$userpage/" . $context->getSkin() . '.js'] = array( 'type' => 'script' );
65 if ( $wgAllowUserCss ) {
66 $pages["$userpage/common.css"] = array( 'type' => 'style' );
67 $pages["$userpage/" . $context->getSkin() . '.css'] = array( 'type' => 'style' );
70 // Hack for bug 26283: if we're on a preview page for a CSS/JS page,
71 // we need to exclude that page from this module. In that case, the excludepage
72 // parameter will be set to the name of the page we need to exclude.
73 $excludepage = $context->getRequest()->getVal( 'excludepage' );
74 if ( isset( $pages[$excludepage] ) ) {
75 // This works because $excludepage is generated with getPrefixedDBkey(),
76 // just like the keys in $pages[] above
77 unset( $pages[$excludepage] );
87 public function getGroup() {