Hi
here is the code i am using:
$link = mysql_connect('localhost','root','');
mysql_select_db('globalbiz',$link);
echo $sql = "SELECT id, cat_name, page_url, parent_id FROM test_cat ORDER BY parent_id, id ASC";
$items = mysql_query($sql);
while ($obj = mysql_fetch_object($items)) {
if ($obj->parent_id == 0) {
$parent_menu[$obj->id]['label'] = $obj->cat_name;
$parent_menu[$obj->id]['link'] = $obj->page_url;
} else {
$sub_menu[$obj->id]['parent'] = $obj->parent_id;
$sub_menu[$obj->id]['label'] = $obj->cat_name;
$sub_menu[$obj->id]['link'] = $obj->page_url;
$parent_menu[$obj->parent_id]['count']++;
}
}
mysql_free_result($items);
/////end first block
//echo"
"; print_r($sub_menu);exit;
///second block
function dyn_menu($parent_array, $sub_array, $qs_val = "menu", $main_id = "nav", $sub_id = "subnav", $extra_style = "foldout") {
$menu = "<ul id=\"".$main_id."\">\n";
foreach ($parent_array as $pkey => $pval) {
if (!empty($pval['count'])) {
$menu .= "
".$pval['label']."
\n";
} else {
$menu .= "
".$pval['label']."
\n";
}
if (!empty($_REQUEST[$qs_val])) {
$menu .= "<ul id=\"".$sub_id."\">\n";
foreach ($sub_array as $sval) {
if ($pkey == $_REQUEST[$qs_val] && $pkey == $sval['parent']) {
$menu .= "
".$sval['label']."
\n";
}
}
$menu .= "\n";
}
}
$menu .= "\n";
return $menu;
}
////end second block
if (!empty($_REQUEST[$qs_val])) {
$menu .= "<ul id=\"".$sub_id."\">\n";
foreach ($sub_array as $sval) {
if ($pkey == $_REQUEST[$qs_val] && $pkey == $sval['parent']) {
$menu .= "
".$sval['label']."
\n";
}
}
$menu .= "\n";
}
function rebuild_link($link, $parent_var, $parent_val) {
$link_parts = explode("?", $link);
$base_var = "?".$parent_var."=".$parent_val;
if (!empty($link_parts[1])) {
$link_parts[1] = str_replace("&", "##", $link_parts[1]);
$parts = explode("##", $link_parts[1]);
$newParts = array();
foreach ($parts as $val) {
$val_parts = explode("=", $val);
if ($val_parts[0] != $parent_var) {
array_push($newParts, $val);
}
}
if (count($newParts) != 0) {
$qs = "&".implode("&", $newParts);
}
return $link_parts[0].$base_var.$qs;
} else {
return $link_parts[0].$base_var;
}
}
//// third block
echo dyn_menu($parent_menu, $sub_menu, "menu", "nav", "subnav");