diff options
Diffstat (limited to 'wiki/inc/Menu/AbstractMenu.php')
-rw-r--r-- | wiki/inc/Menu/AbstractMenu.php | 95 |
1 files changed, 0 insertions, 95 deletions
diff --git a/wiki/inc/Menu/AbstractMenu.php b/wiki/inc/Menu/AbstractMenu.php deleted file mode 100644 index ce021ab..0000000 --- a/wiki/inc/Menu/AbstractMenu.php +++ /dev/null @@ -1,95 +0,0 @@ -<?php - -namespace dokuwiki\Menu; - -use dokuwiki\Menu\Item\AbstractItem; - -/** - * Class AbstractMenu - * - * Basic menu functionality. A menu defines a list of AbstractItem that shall be shown. - * It contains convenience functions to display the menu in HTML, but template authors can also - * just accesst the items via getItems() and create the HTML as however they see fit. - */ -abstract class AbstractMenu implements MenuInterface { - - /** @var string[] list of Item classes to load */ - protected $types = array(); - - /** @var int the context this menu is used in */ - protected $context = AbstractItem::CTX_DESKTOP; - - /** @var string view identifier to be set in the event */ - protected $view = ''; - - /** - * AbstractMenu constructor. - * - * @param int $context the context this menu is used in - */ - public function __construct($context = AbstractItem::CTX_DESKTOP) { - $this->context = $context; - } - - /** - * Get the list of action items in this menu - * - * @return AbstractItem[] - * @triggers MENU_ITEMS_ASSEMBLY - */ - public function getItems() { - $data = array( - 'view' => $this->view, - 'items' => array(), - ); - trigger_event('MENU_ITEMS_ASSEMBLY', $data, array($this, 'loadItems')); - return $data['items']; - } - - /** - * Default action for the MENU_ITEMS_ASSEMBLY event - * - * @see getItems() - * @param array $data The plugin data - */ - public function loadItems(&$data) { - foreach($this->types as $class) { - try { - $class = "\\dokuwiki\\Menu\\Item\\$class"; - /** @var AbstractItem $item */ - $item = new $class(); - if(!$item->visibleInContext($this->context)) continue; - $data['items'][] = $item; - } catch(\RuntimeException $ignored) { - // item not available - } - } - } - - /** - * Generate HTML list items for this menu - * - * This is a convenience method for template authors. If you need more fine control over the - * output, use getItems() and build the HTML yourself - * - * @param string|false $classprefix create a class from type with this prefix, false for no class - * @param bool $svg add the SVG link - * @return string - */ - public function getListItems($classprefix = '', $svg = true) { - $html = ''; - foreach($this->getItems() as $item) { - if($classprefix !== false) { - $class = ' class="' . $classprefix . $item->getType() . '"'; - } else { - $class = ''; - } - - $html .= "<li$class>"; - $html .= $item->asHtmlLink(false, $svg); - $html .= '</li>'; - } - return $html; - } - -} |