class MenuPositionLink in Menu Position 8
Same name in this branch
- 8 src/Plugin/Derivative/MenuPositionLink.php \Drupal\menu_position\Plugin\Derivative\MenuPositionLink
- 8 src/Plugin/Menu/MenuPositionLink.php \Drupal\menu_position\Plugin\Menu\MenuPositionLink
Defines menu links provided by menu position rules.
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\Core\Menu\MenuLinkBase implements MenuLinkInterface
- class \Drupal\menu_position\Plugin\Menu\MenuPositionLink implements ContainerFactoryPluginInterface
- class \Drupal\Core\Menu\MenuLinkBase implements MenuLinkInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of MenuPositionLink
See also
\Drupal\menu_position\Plugin\Derivative\MenuPositionLink
1 file declares its use of MenuPositionLink
- menu_position.module in ./
menu_position.module - Contains menu_position.module.
1 string reference to 'MenuPositionLink'
File
- src/
Plugin/ Menu/ MenuPositionLink.php, line 21
Namespace
Drupal\menu_position\Plugin\MenuView source
class MenuPositionLink extends MenuLinkBase implements ContainerFactoryPluginInterface {
/**
* The route admin context to determine whether a route is an admin one.
*
* @var \Drupal\Core\Routing\AdminContext
*/
protected $adminContext;
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The renderer service.
*
* @var \Drupal\Core\Render\RendererInterface
*/
protected $renderer;
/**
* The request stack.
*
* @var \Symfony\Component\HttpFoundation\RequestStack
*/
protected $requestStack;
/**
* The route match service.
*
* @var \Drupal\Core\Routing\RouteMatchInterface
*/
protected $routeMatch;
/**
* The title resolver service.
*
* @var \Drupal\Core\Controller\TitleResolverInterface
*/
protected $titleResolver;
/**
* Menu position settings.
*
* @var \Drupal\Core\Config\ImmutableConfig
*/
protected $settings;
/**
* Constructs a Drupal\Component\Plugin\PluginBase object.
*
* @param array $configuration
* A configuration array containing information about the plugin instance.
* @param string $plugin_id
* The plugin_id for the plugin instance.
* @param mixed $plugin_definition
* The plugin implementation definition.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
* The config factory service.
* @param \Drupal\Core\Routing\RouteMatchInterface $route_match
* The route match service.
* @param \Symfony\Component\HttpFoundation\RequestStack $request_stack
* The request stack.
* @param \Drupal\Core\Routing\AdminContext $admin_context
* The admin context.
* @param \Drupal\Core\Controller\TitleResolverInterface $title_resolver
* The title resolver service.
* @param \Drupal\Core\Render\RendererInterface $renderer
* The renderer service.
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, EntityTypeManagerInterface $entity_type_manager, ConfigFactoryInterface $config_factory, RouteMatchInterface $route_match, RequestStack $request_stack, AdminContext $admin_context, TitleResolverInterface $title_resolver, RendererInterface $renderer) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->entityTypeManager = $entity_type_manager;
$this->settings = $config_factory
->get('menu_position.settings');
$this->routeMatch = $route_match;
$this->requestStack = $request_stack;
$this->adminContext = $admin_context;
$this->titleResolver = $title_resolver;
$this->renderer = $renderer;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('entity_type.manager'), $container
->get('config.factory'), $container
->get('current_route_match'), $container
->get('request_stack'), $container
->get('router.admin_context'), $container
->get('title_resolver'), $container
->get('renderer'));
}
/**
* {@inheritdoc}
*/
protected $overrideAllowed = [
'parent' => 1,
'weight' => 1,
];
/**
* {@inheritdoc}
*/
public function getTitle() {
// When we're in an admin route we want to display the name of the menu
// position rule.
// @todo Ensure this translates properly when using configuration
// translation.
if ($this->adminContext
->isAdminRoute()) {
return $this->pluginDefinition['title'];
}
else {
$title = $this->titleResolver
->getTitle($this->requestStack
->getCurrentRequest(), $this->routeMatch
->getRouteObject());
if (is_array($title)) {
$title = $this->renderer
->renderPlain($title);
}
return $title;
}
}
/**
* {@inheritdoc}
*/
public function getDescription() {
return $this
->getPluginDefinition()['description'];
}
/**
* {@inheritdoc}
*/
public function updateLink(array $new_definition_values, $persist) {
// Filter the list of updates to only those that are allowed.
$overrides = array_intersect_key($new_definition_values, $this->overrideAllowed);
// Update the definition.
$this->pluginDefinition = $overrides + $this
->getPluginDefinition();
return $this->pluginDefinition;
}
/**
* {@inheritdoc}
*/
public function isDeletable() {
return TRUE;
}
/**
* {@inheritdoc}
*/
public function isEnabled() {
return (bool) ($this->settings
->get('link_display') === 'child');
}
/**
* {@inheritdoc}
*/
public function deleteLink() {
// Noop.
}
/**
* {@inheritdoc}
*/
public function getEditRoute() {
$storage = $this->entityTypeManager
->getStorage('menu_position_rule');
$entity_id = $this->pluginDefinition['metadata']['entity_id'];
$entity = $storage
->load($entity_id);
return $entity
->toUrl();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
MenuLinkBase:: |
public | function |
The cache contexts associated with this object. Overrides CacheableDependencyInterface:: |
3 |
MenuLinkBase:: |
public | function |
The maximum age for which this object may be cached. Overrides CacheableDependencyInterface:: |
2 |
MenuLinkBase:: |
public | function |
The cache tags associated with this object. Overrides CacheableDependencyInterface:: |
2 |
MenuLinkBase:: |
public | function |
Returns route information for a route to delete the menu link. Overrides MenuLinkInterface:: |
1 |
MenuLinkBase:: |
public | function |
Returns the name of a class that can build an editing form for this link. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns the menu name of the menu link. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns any metadata for this link. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns the options for this link. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns the plugin ID of the menu link's parent, or an empty string. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns the provider (module name) of the menu link. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns the route name, if available. Overrides MenuLinkInterface:: |
2 |
MenuLinkBase:: |
public | function |
Returns the route parameters, if available. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns route information for a route to translate the menu link. Overrides MenuLinkInterface:: |
1 |
MenuLinkBase:: |
public | function |
Returns a URL object containing either the external path or route. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns the weight of the menu link. Overrides MenuLinkInterface:: |
|
MenuLinkBase:: |
public | function |
Returns whether the child menu links should always been shown. Overrides MenuLinkInterface:: |
1 |
MenuLinkBase:: |
public | function |
Returns whether this link can be reset. Overrides MenuLinkInterface:: |
1 |
MenuLinkBase:: |
public | function |
Returns whether this link can be translated. Overrides MenuLinkInterface:: |
1 |
MenuPositionLink:: |
protected | property | The route admin context to determine whether a route is an admin one. | |
MenuPositionLink:: |
protected | property | The entity type manager. | |
MenuPositionLink:: |
protected | property |
The list of definition values where an override is allowed. Overrides MenuLinkBase:: |
|
MenuPositionLink:: |
protected | property | The renderer service. | |
MenuPositionLink:: |
protected | property | The request stack. | |
MenuPositionLink:: |
protected | property | The route match service. | |
MenuPositionLink:: |
protected | property | Menu position settings. | |
MenuPositionLink:: |
protected | property | The title resolver service. | |
MenuPositionLink:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
MenuPositionLink:: |
public | function |
Deletes a menu link. Overrides MenuLinkBase:: |
|
MenuPositionLink:: |
public | function |
Returns the description of the menu link. Overrides MenuLinkInterface:: |
|
MenuPositionLink:: |
public | function |
Returns route information for a custom edit form for the menu link. Overrides MenuLinkBase:: |
|
MenuPositionLink:: |
public | function |
Returns the localized title to be shown for this link. Overrides MenuLinkInterface:: |
|
MenuPositionLink:: |
public | function |
Returns whether this link can be deleted. Overrides MenuLinkBase:: |
|
MenuPositionLink:: |
public | function |
Returns whether the menu link is enabled (not hidden). Overrides MenuLinkBase:: |
|
MenuPositionLink:: |
public | function |
Updates the definition values for a menu link. Overrides MenuLinkInterface:: |
|
MenuPositionLink:: |
public | function |
Constructs a Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
|
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |