class EntityTypeInfo in Accelerated Mobile Pages (AMP) 8.3
Same name and namespace in other branches
- 8 src/EntityTypeInfo.php \Drupal\amp\EntityTypeInfo
- 8.2 src/EntityTypeInfo.php \Drupal\amp\EntityTypeInfo
Service class for retrieving and manipulating entity type information.
Hierarchy
- class \Drupal\Core\DependencyInjection\ServiceProviderBase implements ServiceModifierInterface, ServiceProviderInterface
- class \Drupal\amp\EntityTypeInfo
Expanded class hierarchy of EntityTypeInfo
2 files declare their use of EntityTypeInfo
- AmpContext.php in src/
Routing/ AmpContext.php - AmpSettingsForm.php in src/
Form/ AmpSettingsForm.php
1 string reference to 'EntityTypeInfo'
1 service uses EntityTypeInfo
File
- src/
EntityTypeInfo.php, line 13
Namespace
Drupal\ampView source
class EntityTypeInfo extends ServiceProviderBase {
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The cache backend to use for the complete theme registry data.
*
* @var \Drupal\Core\Cache\CacheBackendInterface
*/
protected $cache;
/**
* Constructs a new EntityTypeRepository.
*
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\Core\Cache\CacheBackendInterface $cache
* The cache backend interface to use for the complete theme registry data.
*/
public function __construct(EntityTypeManagerInterface $entity_type_manager, CacheBackendInterface $cache) {
$this->entityTypeManager = $entity_type_manager;
$this->cache = $cache;
}
/**
* Checks if AMP is enabled for this bundle.
*
* @param string $node_type
* The node type to check whether AMP is enabled or not.
*
* @return bool
* TRUE if AMP is enabled for this bundle. FALSE otherwise.
*/
public function isAmpEnabledType($node_type) {
$amp_display = $this->entityTypeManager
->getStorage('entity_view_display')
->load('node.' . $node_type . '.amp');
if ($amp_display && $amp_display
->status()) {
return TRUE;
}
return FALSE;
}
/**
* Returns a list of AMP-enabled content types.
*
* @return array
* An array of bundles that have AMP view modes enabled.
*/
public function getAmpEnabledTypes() {
$enabled_types = [];
if ($cache = $this->cache
->get('amp_enabled_types')) {
$enabled_types = $cache->data;
}
else {
// Get the list of node entities with AMP view mode enabled and store
// their bundles.
$ids = $this->entityTypeManager
->getStorage('entity_view_display')
->getQuery()
->condition('id', 'node.', 'STARTS_WITH')
->condition('mode', 'amp')
->condition('status', TRUE)
->execute();
if ($ids) {
foreach ($ids as $id) {
$parts = explode('.', $id);
$enabled_types[$parts[1]] = $parts[1];
}
}
$this->cache
->set('amp_enabled_types', $enabled_types);
}
return $enabled_types;
}
/**
* Returns a formatted list of AMP-enabled content types.
*
* @return array
* A list of content types that provides the following:
* - Each content type enabled on the site.
* - The enabled/disabled status for each content type.
* - A link to enable/disable view modes for each content type.
* - A link to configure the AMP view mode, if enabled.
*/
public function getFormattedAmpEnabledTypes() {
$enabled_types = !empty($this
->getAmpEnabledTypes()) ? $this
->getAmpEnabledTypes() : [];
$node_types = node_type_get_names();
$destination = Url::fromRoute("amp.settings")
->toString();
$rows = [];
foreach ($node_types as $bundle => $label) {
$configure = Url::fromRoute("entity.entity_view_display.node.view_mode", [
'node_type' => $bundle,
'view_mode_name' => 'amp',
], [
'query' => [
'destination' => $destination,
],
])
->toString();
$enable_disable = Url::fromRoute("entity.entity_view_display.node.default", [
'node_type' => $bundle,
], [
'query' => [
'destination' => $destination,
],
])
->toString();
$configure_link = t('<a href=":configure">configure</a>', [
':configure' => $configure,
]);
$enable_link = t('<a href=":enable_disable">enable</a>', [
':enable_disable' => $enable_disable,
]);
$disable_link = t('<a href=":enable_disable">disable</a>', [
':enable_disable' => $enable_disable,
]);
if (in_array($bundle, $enabled_types)) {
$rows[] = [
$label,
'X',
$configure_link,
$disable_link,
];
}
else {
$rows[] = [
$label,
'',
'',
$enable_link,
];
}
}
return $rows;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
EntityTypeInfo:: |
protected | property | The cache backend to use for the complete theme registry data. | |
EntityTypeInfo:: |
protected | property | The entity type manager. | |
EntityTypeInfo:: |
public | function | Returns a list of AMP-enabled content types. | |
EntityTypeInfo:: |
public | function | Returns a formatted list of AMP-enabled content types. | |
EntityTypeInfo:: |
public | function | Checks if AMP is enabled for this bundle. | |
EntityTypeInfo:: |
public | function | Constructs a new EntityTypeRepository. | |
ServiceProviderBase:: |
public | function |
Modifies existing service definitions. Overrides ServiceModifierInterface:: |
5 |
ServiceProviderBase:: |
public | function |
Registers services to the container. Overrides ServiceProviderInterface:: |
1 |