X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Fclasses%2Fmain%2Fmenu%2Fclass_BaseMenu.php;h=38d7157e029f5a760884c9346459e07c8f6f2787;hb=b35a2f9a19e41355f6826d7c9842dce3268c4d84;hp=4c7c18c025a8d68e48c946cbb120a784a3f3c354;hpb=5e89637b5069092a60b8a6c38b670bf0cf7aa4fd;p=core.git diff --git a/inc/classes/main/menu/class_BaseMenu.php b/inc/classes/main/menu/class_BaseMenu.php index 4c7c18c0..38d7157e 100644 --- a/inc/classes/main/menu/class_BaseMenu.php +++ b/inc/classes/main/menu/class_BaseMenu.php @@ -2,11 +2,11 @@ /** * A general menu system class * - * @author Roland Haeder + * @author Roland Haeder * @version 0.0.0 * @copyright Copyright (c) 2007 - 2009 Roland Haeder, this is free software * @license GNU GPL 3.0 or any newer version - * @link http://www.ship-simu.org + * @link http://www.shipsimu.org * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -31,10 +31,51 @@ class BaseMenu extends BaseFrameworkSystem { protected function __construct ($className) { // Call parent constructor parent::__construct($className); + } + + /** + * Renders the menu by loading the base template and a menu-specific + * template. + * + * @return void + */ + public function renderMenu () { + // Initialize the menu system by preparing it's template instance + $templateInstance = ObjectFactory::createObjectByConfiguredName('menu_template_class', array($this)); + + // Set it for later use + $this->setTemplateInstance($templateInstance); + + // Load the menu template for all + $templateInstance->loadMenuTemplate('generic_menu_entries'); + + // Get the 'page' from request instance + $page = $this->getApplicationInstance()->getRequestInstance()->getRequestElement('page'); - // Clean up a little - $this->removeNumberFormaters(); - $this->removeSystemArray(); + // Load the menu template for this page + try { + $templateInstance->loadMenuTemplate($page . '_menu_entries'); + } catch (FileIoException $e) { + // @TODO Should we log it here? We should, because it will be silently ignored. + } + + // Get the prepared content + $menuContent = $templateInstance->getRawTemplateData(); + + // Render it here + $templateInstance->renderXmlContent($menuContent); + //exit(__METHOD__ . ':!OK'); + } + + /** + * Transfers the rendered menu to a given templatex engine by assigning + * the rendered content with a template variable. + * + * @param $templateInstance An instance of a CompileableTemplate class + * @return void + */ + public function transferContentToTemplateEngine (CompileableTemplate $templateInstance) { + $this->partialStub('templateInstance=' . $templateInstance->__toString()); } }