0) { // Read menu structure // @TODO Cant this be rewritten? while ($content = SQL_FETCHARRAY($result)) { // Menu actions $menus[] = $content['action']; // Menu titles $titles[] = $content['title']; // Below this menu point should the new be added so we simply increase the sort value by 1 :-) $below[] = $content['sort'] + 1; } // END - while // Free memory SQL_FREERESULT($result); // Remove double eintries // @TODO This can be somehow rewritten to a function $prev = ''; $dmy = $menus; $dmy2 = $titles; $dmy3 = $below; foreach ($menus as $key => $value) { if ($value == $prev) { unset($dmy[$key]); unset($dmy2[$key]); unset($dmy3[$key]); } else { $prev = $value; } } // Init variables $menus = $dmy; $titles = $dmy2; $below = $dmy3; // Load sub menus :) foreach ($menus as $key_main => $value_main) { $result = SQL_QUERY_ESC("SELECT what, title, sort FROM `{!_MYSQL_PREFIX!}_guest_menu` WHERE `action`='%s' AND `what` != '' AND `what` IS NOT NULL ORDER BY `sort`", array($value_main), __FILE__, __LINE__); if (SQL_NUMROWS($result) > 0) { // Initialize arrays $menus[$value_main] = array(); $titles[$value_main] = array(); $below[$value_main] = array(); // Read menu structure while ($content = SQL_FETCHARRAY($result)) { // Menu actions $menus[$value_main][] = $content['action']; // Menu titles $titles[$value_main][] = $content['title']; // Below this menu point should the new be added so we simply increase the sort value by 1 :-) $below[$value_main][] = $content['sort'] + 1; } // Free memory SQL_FREERESULT($result); // Remove double eintries // @TODO This can be somehow rewritten to a function $prev = ''; $dmy = $menus[$value_main]; $dmy2 = $titles[$value_main]; $dmy3 = $below[$value_main]; foreach ($menus[$value_main] as $key => $value) { if ($value == $prev) { unset($dmy[$key]); unset($dmy2[$key]); unset($dmy3[$key]); } else { $prev = $value; } } // Transfer dummy array $menus[$value_main] = $dmy; $titles[$value_main] = $dmy2; $below[$value_main] = $dmy3; } } } $OUT = " "; define('__BELOW_SELECTION' , $OUT); define('__WHAT_SELECTION' , ADMIN_MAKE_MENU_SELECTION('guest', "what", "name")); define('__ACTION_SELECTION', ADMIN_MAKE_MENU_SELECTION('guest', "action", "menu")); // Display form LOAD_TEMPLATE("admin_guest_add"); } elseif (!IS_DEMO()) { // Insert new menu entry if (REQUEST_ISSET_POST(('menu'))) { SQL_QUERY_ESC("INSERT INTO `{!_MYSQL_PREFIX!}_guest_menu` (`action`,`what`,`title`,`sort`,`visible`,`locked`) VALUES ('%s','%s','%s','%s','%s','%s')", array( REQUEST_POST('menu'), REQUEST_POST('name'), REQUEST_POST('title'), bigintval(REQUEST_POST('sort')), REQUEST_POST('visible'), REQUEST_POST('active'), ), __FILE__, __LINE__); } else { SQL_QUERY_ESC("INSERT INTO `{!_MYSQL_PREFIX!}_guest_menu` (action, title, sort, visible, locked) VALUES ('%s','%s','%s','%s','%s')", array( REQUEST_POST('name'), REQUEST_POST('title'), bigintval(REQUEST_POST('sort')), REQUEST_POST('visible'), REQUEST_POST('active'), ), __FILE__, __LINE__); } LOAD_TEMPLATE('admin_settings_saved', false, getMessage('SETTINGS_SAVED')); } else { // Demo mode! LOAD_TEMPLATE('admin_settings_saved', false, getMessage('SETTINGS_NOT_SAVED')); } // ?>