Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 67
0.00% covered (danger)
0.00%
0 / 6
CRAP
0.00% covered (danger)
0.00%
0 / 1
VisualEditorDataModule
0.00% covered (danger)
0.00%
0 / 67
0.00% covered (danger)
0.00%
0 / 6
240
0.00% covered (danger)
0.00%
0 / 1
 getScript
0.00% covered (danger)
0.00%
0 / 13
0.00% covered (danger)
0.00%
0 / 1
12
 getDefinitionSummary
0.00% covered (danger)
0.00%
0 / 11
0.00% covered (danger)
0.00%
0 / 1
6
 getMessageInfo
0.00% covered (danger)
0.00%
0 / 28
0.00% covered (danger)
0.00%
0 / 1
6
 enableModuleContentVersion
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 getDependencies
0.00% covered (danger)
0.00%
0 / 4
0.00% covered (danger)
0.00%
0 / 1
2
 addOptional
0.00% covered (danger)
0.00%
0 / 10
0.00% covered (danger)
0.00%
0 / 1
42
1<?php
2/**
3 * Resource loader module providing extra data from the server to VisualEditor.
4 *
5 * @file
6 * @ingroup Extensions
7 * @copyright 2011-2020 VisualEditor Team and others; see AUTHORS.txt
8 * @license MIT
9 */
10
11namespace MediaWiki\Extension\VisualEditor;
12
13use MediaWiki\Registration\ExtensionRegistry;
14use MediaWiki\ResourceLoader\Context as ResourceLoaderContext;
15use MediaWiki\ResourceLoader\FileModule;
16use MediaWiki\ResourceLoader\Module as ResourceLoaderModule;
17use MediaWiki\ResourceLoader\Module;
18use MediaWiki\Title\Title;
19
20class VisualEditorDataModule extends ResourceLoaderModule {
21
22    /**
23     * @param ResourceLoaderContext $context Object containing information about the state of this
24     *   specific loader request.
25     * @return string JavaScript code
26     */
27    public function getScript( ResourceLoaderContext $context ) {
28        $msgInfo = $this->getMessageInfo( $context );
29        $parsedMessages = [];
30        $plainMessages = [];
31        foreach ( $msgInfo['parse'] as $msgKey => $msgObj ) {
32            $parsedMessages[ $msgKey ] = $msgObj->parse();
33        }
34        foreach ( $msgInfo['plain'] as $msgKey => $msgObj ) {
35            $plainMessages[ $msgKey ] = $msgObj->plain();
36        }
37
38        return 've.init.platform.addParsedMessages(' . $context->encodeJson(
39                $parsedMessages
40            ) . ');' .
41            've.init.platform.addMessages(' . $context->encodeJson(
42                $plainMessages
43            ) . ');';
44    }
45
46    /**
47     * Get the definition summary for this module.
48     *
49     * @param ResourceLoaderContext $context
50     * @return array
51     */
52    public function getDefinitionSummary( ResourceLoaderContext $context ) {
53        $summary = parent::getDefinitionSummary( $context );
54
55        $msgVersion = [];
56        $msgInfo = $this->getMessageInfo( $context );
57        $msgInfo = array_merge( $msgInfo['parse'], $msgInfo['plain'] );
58        foreach ( $msgInfo as $msgKey => $msgObj ) {
59            $msgVersion[ $msgKey ] = [
60                // Include the text of the message, in case the canonical translation changes
61                $msgObj->plain(),
62                // Include the page touched time, in case the on-wiki override is invalidated
63                Title::makeTitle( NS_MEDIAWIKI, ucfirst( $msgObj->getKey() ) )->getTouched(),
64            ];
65        }
66        $summary[] = [ 've-messages' => $msgVersion ];
67        return $summary;
68    }
69
70    /**
71     * @param ResourceLoaderContext $context Object containing information about the state of this
72     *   specific loader request.
73     * @return array[] Messages in various states of parsing
74     */
75    protected function getMessageInfo( ResourceLoaderContext $context ) {
76        $editSubmitButtonLabelPublish = $this->getConfig()
77            ->get( 'EditSubmitButtonLabelPublish' );
78        $saveButtonLabelKey = $editSubmitButtonLabelPublish ? 'publishchanges' : 'savechanges';
79        $saveButtonLabel = $context->msg( $saveButtonLabelKey )->text();
80
81        // Messages to be exported as parsed html
82        $parseMsgs = [
83            'missingsummary' => $context->msg( 'missingsummary', $saveButtonLabel ),
84            'summary' => $context->msg( 'summary' ),
85            'visualeditor-browserwarning' => $context->msg( 'visualeditor-browserwarning' ),
86            'visualeditor-wikitext-warning' => $context->msg( 'visualeditor-wikitext-warning' ),
87        ];
88
89        // Messages to be exported as plain text
90        $plainMsgs = [
91            'visualeditor-feedback-link' =>
92                $context->msg( 'visualeditor-feedback-link' )
93                ->inContentLanguage(),
94            'visualeditor-feedback-source-link' =>
95                $context->msg( 'visualeditor-feedback-source-link' )
96                ->inContentLanguage(),
97            'visualeditor-quick-access-characters.json' =>
98                $context->msg( 'visualeditor-quick-access-characters.json' )
99                ->inContentLanguage(),
100            'visualeditor-template-tools-definition.json' =>
101                $context->msg( 'visualeditor-template-tools-definition.json' )
102                ->inContentLanguage(),
103        ];
104
105        return [
106            'parse' => $parseMsgs,
107            'plain' => $plainMsgs,
108        ];
109    }
110
111    /**
112     * @inheritDoc
113     *
114     * Always true.
115     */
116    public function enableModuleContentVersion() {
117        return true;
118    }
119
120    /**
121     * @inheritDoc
122     */
123    public function getDependencies( ?ResourceLoaderContext $context = null ) {
124        return [
125            'ext.visualEditor.base',
126            'ext.visualEditor.mediawiki',
127        ];
128    }
129
130    /**
131     * Add optional array values to a ResourceLoader module definition depending on loaded extensions.
132     *
133     * "factory": "MediaWiki\\Extension\\VisualEditor\\VisualEditorDataModule::addOptional"
134     * "optional": {
135     *   "MyExtension": {
136     *     "dependencies": [ ... ],
137     *     "messages": [ ... ],
138     *     "packageFiles": [ ... ],
139     *     ...
140     *   }
141     * }
142     */
143    public static function addOptional( array $info ): Module {
144        $extensionRegistry = ExtensionRegistry::getInstance();
145
146        if ( isset( $info['optional'] ) ) {
147            foreach ( $info['optional'] as $ext => $extOptions ) {
148                if ( $extensionRegistry->isLoaded( $ext ) ) {
149                    foreach ( $extOptions as $key => $values ) {
150                        if ( !isset( $info[$key] ) ) {
151                            $info[$key] = [];
152                        }
153                        // TODO: Support non-array properties
154                        $info[$key] = array_merge( $info[$key], (array)$values );
155                    }
156                }
157            }
158        }
159
160        $class = $info['class'] ?? FileModule::class;
161        return new $class( $info );
162    }
163}