output: Narrow Title type hint to LinkTarget
[lhc/web/wiklou.git] / includes / resourceloader / ResourceLoaderUserOptionsModule.php
1 <?php
2 /**
3 * ResourceLoader module for user preference 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 * @author Trevor Parscal
22 * @author Roan Kattouw
23 */
24
25 /**
26 * Module for user preference customizations
27 */
28 class ResourceLoaderUserOptionsModule extends ResourceLoaderModule {
29
30 protected $origin = self::ORIGIN_CORE_INDIVIDUAL;
31
32 protected $targets = [ 'desktop', 'mobile' ];
33
34 /**
35 * @param ResourceLoaderContext|null $context
36 * @return array List of module names as strings
37 */
38 public function getDependencies( ResourceLoaderContext $context = null ) {
39 return [ 'user.defaults' ];
40 }
41
42 /**
43 * @return bool
44 */
45 public function enableModuleContentVersion() {
46 return true;
47 }
48
49 /**
50 * @param ResourceLoaderContext $context
51 * @return string JavaScript code
52 */
53 public function getScript( ResourceLoaderContext $context ) {
54 // Use FILTER_NOMIN annotation to prevent needless minification and caching (T84960).
55 return ResourceLoader::FILTER_NOMIN . Xml::encodeJsCall(
56 'mw.user.options.set',
57 [ $context->getUserObj()->getOptions( User::GETOPTIONS_EXCLUDE_DEFAULTS ) ],
58 ResourceLoader::inDebugMode()
59 );
60 }
61
62 /**
63 * @return bool
64 */
65 public function supportsURLLoading() {
66 return false;
67 }
68
69 /**
70 * @param ResourceLoaderContext $context
71 * @return bool
72 */
73 public function isKnownEmpty( ResourceLoaderContext $context ) {
74 return !$context->getUserObj()->getOptions( User::GETOPTIONS_EXCLUDE_DEFAULTS );
75 }
76
77 /**
78 * @return string
79 */
80 public function getGroup() {
81 return 'private';
82 }
83 }