Add class NavigationItemContainer

refs #5600
This commit is contained in:
Johannes Meyer 2015-09-04 15:04:29 +02:00
parent 2af06e9415
commit 5c2619dcb5
3 changed files with 125 additions and 114 deletions

View File

@ -4,24 +4,10 @@
namespace Icinga\Application\Modules; namespace Icinga\Application\Modules;
/** /**
* Container for module menus * Container for module menu items
*/ */
class MenuItemContainer class MenuItemContainer extends NavigationItemContainer
{ {
/**
* This menu item's name
*
* @var string
*/
protected $name;
/**
* This menu item's properties
*
* @var array
*/
protected $properties;
/** /**
* This menu item's children * This menu item's children
* *
@ -29,65 +15,6 @@ class MenuItemContainer
*/ */
protected $children; protected $children;
/**
* Create a new MenuItemContainer
*
* @param string $name
* @param array $properties
*/
public function __construct($name, array $properties = null)
{
$this->name = $name;
$this->children = array();
$this->properties = $properties;
}
/**
* Set this menu item's name
*
* @param string $name
*
* @return $this
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Return this menu item's name
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Set this menu item's properties
*
* @param array $properties
*
* @return $this
*/
public function setProperties(array $properties)
{
$this->properties = $properties;
return $this;
}
/**
* Return this menu item's properties
*
* @return array
*/
public function getProperties()
{
return $this->properties ?: array();
}
/** /**
* Set this menu item's children * Set this menu item's children
* *
@ -108,54 +35,21 @@ class MenuItemContainer
*/ */
public function getChildren() public function getChildren()
{ {
return $this->children; return $this->children ?: array();
} }
/** /**
* Add a new child * Add a new sub menu
* *
* @param string $name * @param string $name
* @param array $properties * @param array $properties
* *
* @return MenuItemContainer The newly added menu item * @return MenuItemContainer The newly added sub menu
*/ */
public function add($name, array $properties = null) public function add($name, array $properties = array())
{ {
$child = new static($name, $properties); $child = new MenuItemContainer($name, $properties);
$this->children[] = $child; $this->children[] = $child;
return $child; return $child;
} }
/**
* Allow dynamic setters and getters for properties
*
* @param string $name
* @param array $arguments
*
* @return mixed
*
* @throws ProgrammingError In case the called method is not supported
*/
public function __call($name, $arguments)
{
if (method_exists($this, $name)) {
return call_user_method_array($name, $this, $arguments);
}
$type = substr($name, 0, 3);
if ($type !== 'set' && $type !== 'get') {
throw new ProgrammingError(
'Dynamic method %s is not supported. Only getters (get*) and setters (set*) are.',
$name
);
}
$propertyName = strtolower(join('_', preg_split('~(?=[A-Z])~', lcfirst(substr($name, 3)))));
if ($type === 'set') {
$this->properties[$propertyName] = $arguments[0];
return $this;
} else { // $type === 'get'
return array_key_exists($propertyName, $this->properties) ? $this->properties[$propertyName] : null;
}
}
} }

View File

@ -339,7 +339,7 @@ class Module
* *
* @return MenuItemContainer * @return MenuItemContainer
*/ */
protected function menuSection($name, array $properties = null) protected function menuSection($name, array $properties = array())
{ {
if (array_key_exists($name, $this->menuItems)) { if (array_key_exists($name, $this->menuItems)) {
$this->menuItems[$name]->setProperties($properties); $this->menuItems[$name]->setProperties($properties);

View File

@ -0,0 +1,117 @@
<?php
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
namespace Icinga\Application\Modules;
use Icinga\Exception\ProgrammingError;
/**
* Container for module navigation items
*/
abstract class NavigationItemContainer
{
/**
* This navigation item's name
*
* @var string
*/
protected $name;
/**
* This navigation item's properties
*
* @var array
*/
protected $properties;
/**
* Create a new NavigationItemContainer
*
* @param string $name
* @param array $properties
*/
public function __construct($name, array $properties = array())
{
$this->name = $name;
$this->properties = $properties;
}
/**
* Set this menu item's name
*
* @param string $name
*
* @return $this
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Return this menu item's name
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Set this menu item's properties
*
* @param array $properties
*
* @return $this
*/
public function setProperties(array $properties)
{
$this->properties = $properties;
return $this;
}
/**
* Return this menu item's properties
*
* @return array
*/
public function getProperties()
{
return $this->properties ?: array();
}
/**
* Allow dynamic setters and getters for properties
*
* @param string $name
* @param array $arguments
*
* @return mixed
*
* @throws ProgrammingError In case the called method is not supported
*/
public function __call($name, $arguments)
{
if (method_exists($this, $name)) {
return call_user_method_array($name, $this, $arguments);
}
$type = substr($name, 0, 3);
if ($type !== 'set' && $type !== 'get') {
throw new ProgrammingError(
'Dynamic method %s is not supported. Only getters (get*) and setters (set*) are.',
$name
);
}
$propertyName = strtolower(join('_', preg_split('~(?=[A-Z])~', lcfirst(substr($name, 3)))));
if ($type === 'set') {
$this->properties[$propertyName] = $arguments[0];
return $this;
} else { // $type === 'get'
return array_key_exists($propertyName, $this->properties) ? $this->properties[$propertyName] : null;
}
}
}