X-Git-Url: https://git.mxchange.org/?p=core.git;a=blobdiff_plain;f=inc%2Fclasses%2Fmain%2Fmenu%2Fclass_BaseMenu.php;h=23324eddab8131ff0ef9e54121b07c53a6417ada;hp=8041813b3f5151eb955eed43db010f55c585a044;hb=602a3281da3bcf4ab4da2d8571b921e61e167b5b;hpb=c27d9eeb693e0b8ee34d39ac28d771faee450b25 diff --git a/inc/classes/main/menu/class_BaseMenu.php b/inc/classes/main/menu/class_BaseMenu.php index 8041813b..23324edd 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 @@ -41,41 +41,47 @@ class BaseMenu extends BaseFrameworkSystem { */ public function renderMenu () { // Initialize the menu system by preparing it's template instance - $templateInstance = ObjectFactory::createObjectByConfiguredName('menu_template_class', array($this->getApplicationInstance(), $this)); + $templateInstance = ObjectFactory::createObjectByConfiguredName('menu_template_class', array($this)); // Set it for later use $this->setTemplateInstance($templateInstance); // Load the menu template for all - $this->getTemplateInstance()->loadMenuTemplate('generic_menu_entries'); + $templateInstance->loadMenuTemplate('generic_menu_entries'); - // Get the 'page' from request instance - $page = $this->getApplicationInstance()->getRequestInstance()->getRequestElement('page'); + // Get the 'command' from request instance + $command = $this->getApplicationInstance()->getRequestInstance()->getRequestElement('command'); + + // If page is empty, choose default + if (empty($command)) { + // Use default page as none has been specified + $command = $this->getConfigInstance()->getConfigEntry('default_' . $this->getApplicationInstance()->getAppShortName() . '_' . self::getResponseTypeFromSystem() . '_command'); + } // END - if // Load the menu template for this page try { - $this->getTemplateInstance()->loadMenuTemplate($page . '_menu_entries'); - } catch (FileNotFoundException $e) { - // @TODO Should we log it here? We should, because it will be silently ignored. + $templateInstance->loadMenuTemplate($command . '_menu_entries'); + } catch (FileIoException $e) { + // Log exception @TODO Maybe to intrusive? + self::createDebugInstance(__CLASS__)->debugOutput('[' . __METHOD__ . ':' . __LINE__ . ']: Exception caught: ' . $e->__toString() . ', with message: ' . $e->getMessage()); } - // Get the prepared content - $menuContent = $this->getTemplateInstance()->getRawTemplateData(); - - // Render it here - $this->getTemplateInstance()->renderXmlContent($menuContent); - die('!OK'); + // Render template data here + $templateInstance->renderXmlContent(); + //exit(__METHOD__ . ':!OK'); } /** - * Transfers the rendered menu to a given templatex engine by assigning + * Transfers the rendered menu to a given template 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()); + // Assign menu content to variable + $templateInstance->assignVariable('menu_content', $this->getTemplateInstance()->getMenuContent()); + //* DEBUG */ $templateInstance->debugInstance(); } }