X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=frontaccounting.php;h=d3662cd7f293619bb2a591189cea94b9b4f1fad9;hb=5723ad849a1de48c2d914772106ddf903a70877d;hp=267780b191b40593fbf4880aea4d5c480ccf5415;hpb=c70823611ef71079c28542f4810cc50c183a8cd5;p=fa-stable.git diff --git a/frontaccounting.php b/frontaccounting.php index 267780b1..d3662cd7 100644 --- a/frontaccounting.php +++ b/frontaccounting.php @@ -20,14 +20,14 @@ if (!isset($path_to_root) || isset($_GET['path_to_root']) || isset($_POST['path_ include_once($path_to_root . '/applications/generalledger.php'); include_once($path_to_root . '/applications/setup.php'); include_once($path_to_root . '/installed_extensions.php'); - if (count($installed_extensions) > 0) + + foreach ($installed_extensions as $ext) { - foreach ($installed_extensions as $ext) - { - if ($ext['type'] == 'module') - @include_once($path_to_root."/".$ext['path']."/".$ext['filename']); - } - } + if (@($ext['active'] && isset($ext['tabs']))) // supressed warnings before 2.2 upgrade + foreach($ext['tabs'] as $tab) { + include_once($path_to_root.'/'.$ext['path'].'/'.$tab['url']); + } + } class front_accounting { @@ -38,6 +38,7 @@ if (!isset($path_to_root) || isset($_GET['path_to_root']) || isset($_POST['path_ // GUI var $menu; //var $renderer; + function front_accounting() { //$this->renderer =& new renderer(); @@ -64,7 +65,9 @@ if (!isset($path_to_root) || isset($_GET['path_to_root']) || isset($_POST['path_ function display() { global $path_to_root; - include($path_to_root . "/themes/".user_theme()."/renderer.php"); + + include_once($path_to_root . "/themes/".user_theme()."/renderer.php"); + $this->init(); $rend = new renderer(); $rend->wa_header(); @@ -72,10 +75,12 @@ if (!isset($path_to_root) || isset($_GET['path_to_root']) || isset($_POST['path_ $rend->display_applications($this); //$rend->menu_footer($this->menu); $rend->wa_footer(); + $this->renderer =& $rend; } function init() { global $installed_extensions, $path_to_root; + $this->menu = new menu(_("Main Menu")); $this->menu->add_item(_("Main Menu"), "index.php"); $this->menu->add_item(_("Logout"), "/account/access/logout.php"); @@ -86,23 +91,24 @@ if (!isset($path_to_root) || isset($_GET['path_to_root']) || isset($_POST['path_ $this->add_application(new manufacturing_app()); $this->add_application(new dimensions_app()); $this->add_application(new general_ledger_app()); - if (count($installed_extensions) > 0) + + // Do not use global array directly here, or you suffer + // from buggy php behaviour (unexpected loop break + // because of same var usage in class constructor). + $extensions = $installed_extensions; + foreach ($extensions as $ext) { - foreach ($installed_extensions as $ext) - { - if (@($ext['active'] && $ext['type'] == 'module')) { // supressed warnings before 2.2 upgrade - $_SESSION['get_text']->add_domain($_SESSION['language']->code, - $ext['path']."/lang"); - $class = $ext['tab']."_app"; + if (@($ext['active'] && isset($ext['tabs']))) { // supressed warnings before 2.2 upgrade + set_ext_domain($ext['path']); + foreach($ext['tabs'] as $tab) { + $class = $tab['tab_id']."_app"; if (class_exists($class)) $this->add_application(new $class()); - $_SESSION['get_text']->add_domain($_SESSION['language']->code, - $path_to_root."/lang"); } } - } - - $this->add_application(new setup_app()); } + set_ext_domain(); + $this->add_application(new setup_app()); + } } ?> \ No newline at end of file