MenuPositionRule.php in Menu Position 8
Namespace
Drupal\menu_position\EntityFile
src/Entity/MenuPositionRule.phpView source
<?php
namespace Drupal\menu_position\Entity;
use Drupal\Core\Condition\ConditionPluginCollection;
use Drupal\Core\Config\Entity\ConfigEntityBase;
use Drupal\Core\Entity\EntityStorageInterface;
use Drupal\Core\Entity\EntityWithPluginCollectionInterface;
use Drupal\Core\Plugin\ContextAwarePluginInterface;
use Drupal\menu_position\MenuPositionRuleInterface;
/**
* Defines the MenuPositionRule entity.
*
* @ConfigEntityType(
* id = "menu_position_rule",
* label = @Translation("Menu Position Rule"),
* handlers = {
* "list_builder" = "Drupal\menu_position\Controller\MenuPositionRuleListBuilder",
* "form" = {
* "default" = "Drupal\menu_position\Form\MenuPositionRuleForm",
* "delete" = "Drupal\menu_position\Form\MenuPositionRuleDeleteForm"
* }
* },
* config_prefix = "menu_position_rule",
* admin_permission = "administer menu positions",
* entity_keys = {
* "id" = "id"
* },
* links = {
* "add-form" = "/admin/structure/menu-position/add",
* "edit-form" = "/admin/structure/menu-position/{menu_position_rule}/edit",
* "delete-form" = "/admin/structure/menu-position/{menu_position_rule}/delete",
* "collection" = "/admin/structure/menu-position"
* }
* )
*/
class MenuPositionRule extends ConfigEntityBase implements MenuPositionRuleInterface, EntityWithPluginCollectionInterface {
/**
* The MenuPositionRule ID.
*
* @var string
*/
protected $id;
/**
* The MenuPositionRule label.
*
* @var string
*/
protected $label;
/**
* Whether the rule is enabled or not.
*
* @var bool
*/
protected $enabled;
/**
* The serialized conditions for this rule.
*
* @var sequence
*/
protected $conditions = [];
/**
* The menu of the menu link for this rule.
*
* @var string
*/
protected $menu_name;
/**
* The parent menu link id for this rule.
*
* @var string
*/
protected $parent;
/**
* The menu link id for this rule.
*
* @var string
*/
protected $menu_link;
/**
* The weight of this rule.
*
* @var int
*/
protected $weight;
/**
* The condition plugin manager.
*
* @var \Drupal\Core\Executable\ExecutableManagerInterface
*/
protected $conditionPluginManager;
/**
* The menu link plugin manager.
*
* @var \Drupal\Core\Menu\MenuLinkManagerInterface
*/
protected $menuLinkManager;
/**
* The context manager service.
*
* @var \Drupal\Core\Plugin\Context\ContextRepositoryInterface
*/
protected $contextRepository;
/**
* The collection of condition plugins.
*
* @var \Drupal\Core\Condition\ConditionPluginCollection
*/
protected $conditionCollection;
/**
* {@inheritdoc}
*/
public function getId() {
return $this->id;
}
/**
* {@inheritdoc}
*/
public function getLabel() {
return $this->label;
}
/**
* {@inheritdoc}
*/
public function label() {
return $this->label;
}
/**
* {@inheritdoc}
*/
public function getEnabled() {
return $this->enabled;
}
/**
* {@inheritdoc}
*/
public function getConditions() {
if (!isset($this->conditionCollection)) {
$this->conditionCollection = new ConditionPluginCollection($this
->conditionPluginManager(), $this
->get('conditions'));
}
return $this->conditionCollection;
}
/**
* {@inheritdoc}
*/
public function getMenuLink() {
return $this->menu_link;
}
/**
* {@inheritdoc}
*/
public function getMenuName() {
return $this->menu_name;
}
/**
* {@inheritdoc}
*/
public function getParent() {
return $this->parent;
}
/**
* {@inheritdoc}
*/
public function getWeight() {
return $this->weight;
}
/**
* {@inheritdoc}
*/
public function setLabel($label) {
$this->label = $label;
}
/**
* {@inheritdoc}
*/
public function setEnabled($enabled) {
$this->enabled = $enabled;
}
/**
* {@inheritdoc}
*/
public function setConditions(array $conditions, $plugin) {
$this->conditions = $conditions;
}
/**
* {@inheritdoc}
*/
public function setMenuLink($menu_link) {
$this->menu_link = $menu_link;
}
/**
* {@inheritdoc}
*/
public function setMenuName($menu_name) {
$this->menu_name = $menu_name;
}
/**
* {@inheritdoc}
*/
public function setParent($parent) {
$this->parent = $parent;
}
/**
* {@inheritdoc}
*/
public function setWeight($weight) {
$this->weight = $weight;
}
/**
* {@inheritdoc}
*/
public function getPluginCollections() {
return [
'conditions' => $this
->getConditions(),
];
}
/**
* Get the menu link plugin.
*/
public function getMenuLinkPlugin() {
$menu_link = $this
->getMenuLink();
if (!$menu_link || !$this
->menuLinkManager()
->hasDefinition($menu_link)) {
return NULL;
}
return $this
->menuLinkManager()
->createInstance($menu_link);
}
/**
* Evaluates all conditions attached to this rule and determines if this rule
* is "active" or not.
*
* @return bool
* Whether or not this rule is active.
*/
public function isActive() {
// Must be enabled.
if (!$this
->getEnabled()) {
return FALSE;
}
// Rules are good unless told otherwise by the conditions.
foreach ($this
->getConditions() as $condition) {
// Need to get context for this condition.
if ($condition instanceof ContextAwarePluginInterface) {
// Get runtime contexts and set them for this condition.
$runtime_contexts = $this
->contextRepository()
->getRuntimeContexts($condition
->getContextMapping());
$condition_contexts = $condition
->getContextDefinitions();
foreach ($condition
->getContextMapping() as $name => $context) {
// Attach appropriate context.
if (isset($runtime_contexts[$context]) && $runtime_contexts[$context]
->hasContextValue()) {
$condition
->setContext($name, $runtime_contexts[$context]);
}
elseif ($condition_contexts[$name]
->isRequired()) {
return FALSE;
}
}
}
// If this condition evaluates to false, rule is inactive.
if (!$condition
->execute()) {
return FALSE;
}
}
// No objections, rule is active.
return TRUE;
}
/**
* Gets the condition plugin manager.
*
* @return \Drupal\Core\Executable\ExecutableManagerInterface
* The condition plugin manager.
*/
protected function conditionPluginManager() {
if (!isset($this->conditionPluginManager)) {
$this->conditionPluginManager = \Drupal::service('plugin.manager.condition');
}
return $this->conditionPluginManager;
}
/**
* Gets the condition plugin manager.
*
* @return \Drupal\Core\Plugin\Context\ContextRepositoryInterface
* The condition plugin manager.
*/
protected function contextRepository() {
if (!isset($this->contextRepository)) {
$this->contextRepository = \Drupal::service('context.repository');
}
return $this->contextRepository;
}
/**
* Gets the condition plugin manager.
*
* @return \Drupal\Core\Plugin\Context\ContextRepositoryInterface
* The condition plugin manager.
*/
protected function menuLinkManager() {
if (!isset($this->menuLinkManager)) {
$this->menuLinkManager = \Drupal::service('plugin.manager.menu.link');
}
return $this->menuLinkManager;
}
/**
* {@inheritdoc}
*/
public static function preDelete(EntityStorageInterface $storage, array $entities) {
// Iterate over entities being deleted and remove associated menu links.
foreach ($entities as $entity) {
if ($entity
->getMenuLink() !== NULL) {
$entity
->menuLinkManager()
->removeDefinition($entity
->getMenuLink());
$entity
->setMenuLink(NULL);
}
}
parent::preDelete($storage, $entities);
}
/**
* Rebuild routes to create menu links.
*/
public function postSave(EntityStorageInterface $storage, $update = TRUE) {
parent::postSave($storage, $update);
if ($this
->isSyncing()) {
// Rebuild menu position links when new rule is created.
\Drupal::service('router.builder')
->setRebuildNeeded();
}
}
}
Classes
Name | Description |
---|---|
MenuPositionRule | Defines the MenuPositionRule entity. |