ee350cf0b5301c06005885d7c53913c195532706
[lhc/web/wiklou.git] / includes / resourceloader / ResourceLoaderUserGroupsModule.php
1 <?php
2 /**
3 * Resource loader module for user customizations.
4 *
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.
9 *
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.
14 *
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
19 *
20 * @file
21 */
22
23 /**
24 * Module for user customizations
25 */
26 class ResourceLoaderUserGroupsModule extends ResourceLoaderWikiModule {
27
28 /* Protected Members */
29
30 protected $origin = self::ORIGIN_USER_SITEWIDE;
31 protected $targets = array( 'desktop', 'mobile' );
32
33 /* Protected Methods */
34
35 /**
36 * @param ResourceLoaderContext $context
37 * @return array
38 */
39 protected function getPages( ResourceLoaderContext $context ) {
40 $useSiteJs = $this->getConfig()->get( 'UseSiteJs' );
41 $useSiteCss = $this->getConfig()->get( 'UseSiteCss' );
42 if ( !$useSiteJs && !$useSiteCss ) {
43 return array();
44 }
45
46 $user = $context->getUserObj();
47 if ( !$user || $user->isAnon() ) {
48 return array();
49 }
50
51 $pages = array();
52 foreach ( $user->getEffectiveGroups() as $group ) {
53 if ( $group == '*' ) {
54 continue;
55 }
56 if ( $useSiteJs ) {
57 $pages["MediaWiki:Group-$group.js"] = array( 'type' => 'script' );
58 }
59 if ( $useSiteCss ) {
60 $pages["MediaWiki:Group-$group.css"] = array( 'type' => 'style' );
61 }
62 }
63 return $pages;
64 }
65
66 /* Methods */
67
68 /**
69 * @return string
70 */
71 public function getGroup() {
72 return 'user';
73 }
74 }