function AssetResolver::getLibrariesToLoad
Same name in other branches
- 9 core/lib/Drupal/Core/Asset/AssetResolver.php \Drupal\Core\Asset\AssetResolver::getLibrariesToLoad()
- 8.9.x core/lib/Drupal/Core/Asset/AssetResolver.php \Drupal\Core\Asset\AssetResolver::getLibrariesToLoad()
- 10 core/lib/Drupal/Core/Asset/AssetResolver.php \Drupal\Core\Asset\AssetResolver::getLibrariesToLoad()
Returns the libraries that need to be loaded.
For example, with core/a depending on core/c and core/b on core/d:
$assets = new AttachedAssets();
$assets->setLibraries([
'core/a',
'core/b',
'core/c',
]);
$assets->setAlreadyLoadedLibraries([
'core/c',
]);
$resolver->getLibrariesToLoad($assets, 'js') === [
'core/a',
'core/b',
'core/d',
];
The attached assets tend to be in the order that libraries were attached during a request. To minimize the number of unique aggregated asset URLs and files, we normalize the list by filtering out libraries that don't include the asset type being built as well as ensuring a reliable order of the libraries based on their dependencies.
Parameters
\Drupal\Core\Asset\AttachedAssetsInterface $assets: The assets attached to the current response.
string|null $asset_type: The asset type to load.
Return value
string[] A list of libraries and their dependencies, in the order they should be loaded, excluding any libraries that have already been loaded.
3 calls to AssetResolver::getLibrariesToLoad()
- AssetResolver::getCssAssets in core/
lib/ Drupal/ Core/ Asset/ AssetResolver.php - Returns the CSS assets for the current response's libraries.
- AssetResolver::getJsAssets in core/
lib/ Drupal/ Core/ Asset/ AssetResolver.php - Returns the JavaScript assets for the current response's libraries.
- AssetResolver::getJsSettingsAssets in core/
lib/ Drupal/ Core/ Asset/ AssetResolver.php - Returns the JavaScript settings assets for this response's libraries.
File
-
core/
lib/ Drupal/ Core/ Asset/ AssetResolver.php, line 128
Class
- AssetResolver
- The default asset resolver.
Namespace
Drupal\Core\AssetCode
protected function getLibrariesToLoad(AttachedAssetsInterface $assets, ?string $asset_type = NULL) {
// @see Drupal\FunctionalTests\Core\Asset\AssetOptimizationTestUmami
// @todo https://www.drupal.org/project/drupal/issues/1945262
$libraries_to_load = array_diff($this->libraryDependencyResolver
->getLibrariesWithDependencies($assets->getLibraries()), $this->libraryDependencyResolver
->getLibrariesWithDependencies($assets->getAlreadyLoadedLibraries()));
if ($asset_type) {
$libraries_to_load = $this->filterLibrariesByType($libraries_to_load, $asset_type);
}
// We now have a complete list of libraries requested. However, this list
// could be in any order depending on when libraries were attached during
// the page request, which can result in different file contents and URLs
// even for an otherwise identical set of libraries. To ensure that any
// particular set of libraries results in the same aggregate URL, sort the
// libraries, then generate the minimum representative set again.
sort($libraries_to_load);
$minimum_libraries = $this->libraryDependencyResolver
->getMinimalRepresentativeSubset($libraries_to_load);
$libraries_to_load = array_diff($this->libraryDependencyResolver
->getLibrariesWithDependencies($minimum_libraries), $this->libraryDependencyResolver
->getLibrariesWithDependencies($assets->getAlreadyLoadedLibraries()));
// Now remove any libraries without the relevant asset type again, since
// they have been brought back in via dependencies.
if ($asset_type) {
$libraries_to_load = $this->filterLibrariesByType($libraries_to_load, $asset_type);
}
return $libraries_to_load;
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.