MediaWiki REL1_34
ResourceLoaderClientHtml Class Reference

Load and configure a ResourceLoader client on an HTML page. More...

Collaboration diagram for ResourceLoaderClientHtml:

Public Member Functions

 __construct (ResourceLoaderContext $context, array $options=[])
 
 getBodyHtml ()
 
 getDocumentAttributes ()
 
 getHeadHtml ( $nojsClass=null)
 The order of elements in the head is as follows:
 
 setConfig (array $vars)
 Set mw.config variables.
 
 setExemptStates (array $states)
 Set state of special modules that are handled by the caller manually.
 
 setModules (array $modules)
 Ensure one or more modules are loaded.
 
 setModuleStyles (array $modules)
 Ensure the styles of one or more modules are loaded.
 

Static Public Member Functions

static makeLoad (ResourceLoaderContext $mainContext, array $modules, $only, array $extraQuery=[], $nonce=null)
 Explicily load or embed modules on a page.
 

Private Member Functions

 getContext ( $group, $type)
 
 getData ()
 
 getLoad ( $modules, $only, $nonce, array $extraQuery=[])
 

Static Private Member Functions

static makeContext (ResourceLoaderContext $mainContext, $group, $type, array $extraQuery=[])
 

Private Attributes

array $config = []
 
ResourceLoaderContext $context
 
array $data
 
array $exemptStates = []
 
array $modules = []
 
array $moduleStyles = []
 
array $options
 
ResourceLoader $resourceLoader
 

Detailed Description

Load and configure a ResourceLoader client on an HTML page.

Since
1.28

Definition at line 30 of file ResourceLoaderClientHtml.php.

Constructor & Destructor Documentation

◆ __construct()

ResourceLoaderClientHtml::__construct ( ResourceLoaderContext  $context,
array  $options = [] 
)
Parameters
ResourceLoaderContext$context
array$options[optional] Array of options

Definition at line 63 of file ResourceLoaderClientHtml.php.

References $context, $options, and ResourceLoaderContext\getResourceLoader().

Member Function Documentation

◆ getBodyHtml()

ResourceLoaderClientHtml::getBodyHtml ( )
Returns
string|WrappedStringList HTML

Definition at line 341 of file ResourceLoaderClientHtml.php.

References $data, and getData().

◆ getContext()

ResourceLoaderClientHtml::getContext (   $group,
  $type 
)
private

Definition at line 356 of file ResourceLoaderClientHtml.php.

References $type, and makeContext().

◆ getData()

ResourceLoaderClientHtml::getData ( )
private
Returns
array

Definition at line 116 of file ResourceLoaderClientHtml.php.

References $context, $data, $resourceLoader, getContext(), and ResourceLoader\getModule().

Referenced by getBodyHtml(), and getHeadHtml().

◆ getDocumentAttributes()

ResourceLoaderClientHtml::getDocumentAttributes ( )
Returns
array Attribute key-value pairs for the HTML document element

Definition at line 228 of file ResourceLoaderClientHtml.php.

Referenced by getHeadHtml().

◆ getHeadHtml()

ResourceLoaderClientHtml::getHeadHtml (   $nojsClass = null)

The order of elements in the head is as follows:

  • Inline scripts.
  • Stylesheets.
  • Async external script-src.

Reasons:

  • Script execution may be blocked on preceeding stylesheets.
  • Async scripts are not blocked on stylesheets.
  • Inline scripts can't be asynchronous.
  • For styles, earlier is better.
Parameters
string | null$nojsClassClass name that caller uses on HTML document element
Returns
string|WrappedStringList HTML

Definition at line 247 of file ResourceLoaderClientHtml.php.

References $data, getData(), getDocumentAttributes(), and getLoad().

◆ getLoad()

ResourceLoaderClientHtml::getLoad (   $modules,
  $only,
  $nonce,
array  $extraQuery = [] 
)
private

Definition at line 360 of file ResourceLoaderClientHtml.php.

References $modules, and makeLoad().

Referenced by getHeadHtml().

◆ makeContext()

static ResourceLoaderClientHtml::makeContext ( ResourceLoaderContext  $mainContext,
  $group,
  $type,
array  $extraQuery = [] 
)
staticprivate

◆ makeLoad()

static ResourceLoaderClientHtml::makeLoad ( ResourceLoaderContext  $mainContext,
array  $modules,
  $only,
array  $extraQuery = [],
  $nonce = null 
)
static

Explicily load or embed modules on a page.

Parameters
ResourceLoaderContext$mainContext
array$modulesOne or more module names
string$onlyResourceLoaderModule TYPE_ class constant
array$extraQuery[optional] Array with extra query parameters for the request
string | null$nonce[optional] Content-Security-Policy nonce (from OutputPage::getCSPNonce)
Returns
string|WrappedStringList HTML

Definition at line 393 of file ResourceLoaderClientHtml.php.

References $context, $modules, $source, ResourceLoaderContext\encodeJson(), ResourceLoaderContext\getDebug(), ResourceLoaderContext\getRaw(), ResourceLoaderContext\getResourceLoader(), makeContext(), and makeLoad().

Referenced by getLoad(), makeLoad(), and OutputPage\makeResourceLoaderLink().

◆ setConfig()

ResourceLoaderClientHtml::setConfig ( array  $vars)

Set mw.config variables.

Parameters
array$varsArray of key/value pairs

Definition at line 78 of file ResourceLoaderClientHtml.php.

Referenced by OutputPage\getRlClient().

◆ setExemptStates()

ResourceLoaderClientHtml::setExemptStates ( array  $states)

Set state of special modules that are handled by the caller manually.

See OutputPage::buildExemptModules() for use cases.

Parameters
array$statesModule state keyed by module name

Definition at line 109 of file ResourceLoaderClientHtml.php.

Referenced by OutputPage\getRlClient().

◆ setModules()

ResourceLoaderClientHtml::setModules ( array  $modules)

Ensure one or more modules are loaded.

Parameters
array$modulesArray of module names

Definition at line 89 of file ResourceLoaderClientHtml.php.

References $modules.

Referenced by OutputPage\getRlClient().

◆ setModuleStyles()

ResourceLoaderClientHtml::setModuleStyles ( array  $modules)

Ensure the styles of one or more modules are loaded.

Parameters
array$modulesArray of module names

Definition at line 98 of file ResourceLoaderClientHtml.php.

References $modules.

Referenced by OutputPage\getRlClient().

Member Data Documentation

◆ $config

array ResourceLoaderClientHtml::$config = []
private

Definition at line 42 of file ResourceLoaderClientHtml.php.

◆ $context

ResourceLoaderContext ResourceLoaderClientHtml::$context
private

Definition at line 33 of file ResourceLoaderClientHtml.php.

Referenced by __construct(), getData(), makeContext(), and makeLoad().

◆ $data

array ResourceLoaderClientHtml::$data
private

Definition at line 54 of file ResourceLoaderClientHtml.php.

Referenced by getBodyHtml(), getData(), and getHeadHtml().

◆ $exemptStates

array ResourceLoaderClientHtml::$exemptStates = []
private

Definition at line 51 of file ResourceLoaderClientHtml.php.

◆ $modules

array ResourceLoaderClientHtml::$modules = []
private

Definition at line 45 of file ResourceLoaderClientHtml.php.

Referenced by getLoad(), makeLoad(), setModules(), and setModuleStyles().

◆ $moduleStyles

array ResourceLoaderClientHtml::$moduleStyles = []
private

Definition at line 48 of file ResourceLoaderClientHtml.php.

◆ $options

array ResourceLoaderClientHtml::$options
private

Definition at line 39 of file ResourceLoaderClientHtml.php.

Referenced by __construct().

◆ $resourceLoader

ResourceLoader ResourceLoaderClientHtml::$resourceLoader
private

Definition at line 36 of file ResourceLoaderClientHtml.php.

Referenced by getData().


The documentation for this class was generated from the following file: