* * -------------------------------------------- * * 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 the * * Free Software Foundation; either version 2 of the License, or (at your * * option) any later version. * \**************************************************************************/ /* $Id$ */ /*********************************************/ /* Settings */ /*********************************************/ /* */ /* $treefile variable needs to be set in */ /* main file */ /* */ /*********************************************/ class menutree { function showtree($treefile, $expandlevels="", $num_menus = 50, $invisible_menus = Null){ global $phpgw_info, $phpgw; $script = $SCRIPT_NAME; $img_expand = "templates/default/images/tree_expand.gif"; $img_collapse = "templates/default/images/tree_collapse.gif"; $img_line = "templates/default/images/tree_vertline.gif"; $img_split = "templates/default/images/tree_split.gif"; $img_end = "templates/default/images/tree_end.gif"; $img_leaf = "templates/default/images/tree_leaf.gif"; $img_spc = "templates/default/images/tree_space.gif"; /*********************************************/ /* Read text file with tree structure */ /*********************************************/ /*********************************************/ /* read file to $tree array */ /* tree[x][0] -> tree level */ /* tree[x][1] -> item text */ /* tree[x][2] -> item link */ /* tree[x][3] -> link target */ /* tree[x][4] -> last item in subtree */ /*********************************************/ $maxlevel=0; $cnt=0; $fd = fopen($treefile, "r"); if ($fd==0) die("menutree.inc : Unable to open file ".$treefile); while ($buffer = fgets($fd, 4096)) { $tree[$cnt][0]=strspn($buffer,"."); $tmp=rtrim(substr($buffer,$tree[$cnt][0])); $node=explode("|",$tmp); $tree[$cnt][1]=$node[0]; $tree[$cnt][2]=$node[1]; $tree[$cnt][3]=$node[2]; $tree[$cnt][4]=0; if ($tree[$cnt][0] > $maxlevel) $maxlevel=$tree[$cnt][0]; $cnt++; } fclose($fd); for ($i=0; $i=0; $i--) { if ( $tree[$i][0] < $lastlevel ) { for ($j=$tree[$i][0]+1; $j <= $maxlevel; $j++) { $levels[$j]=0; } } if ( $levels[$tree[$i][0]]==0 ) { $levels[$tree[$i][0]]=1; $tree[$i][4]=1; } else $tree[$i][4]=0; $lastlevel=$tree[$i][0]; } /*********************************************/ /* Determine visible nodes */ /*********************************************/ $visible[0]=1; // root is always visible $visible[1]=1; // root is always visible $visible[2]=1; // root is always visible $visible[3]=0; // root is always visible $visible[4]=0; // root is always visible $visible[5]=0; // root is always visible $visible[6]=0; // root is always visible $visible[7]=1; // root is always visible $visible[8]=0; // root is always visible $visible[9]=0; // root is always visible $visible[10]=0; // root is always visible $visible[11]=1; // root is always visible $visible[12]=0; // root is always visible $visible[13]=0; // root is always visible $visible[14]=0; // root is always visible $visible[15]=0; // root is always visible $visible[16]=1; // root is always visible $visible[17]=1; // root is always visible $visible[18]=1; // root is always visible $visible[19]=1; // root is always visible $visible[20]=1; // root is always visible $visible[21]=0; // root is always visible $visible[22]=0; // root is always visible $visible[23]=1; // root is always visible $visible[24]=0; // root is always visible $visible[25]=0; // root is always visible $visible[26]=1; // root is always visible $visible[27]=0; // root is always visible $visible[28]=0; // root is always visible for ($i=0; $i $tree[$n][0] ) { if ($tree[$j][0]==$tree[$n][0]+1) $visible[$j]=1; $j++; } } } for ($i=0; $i\n"; $str .= "link("index.php",$params)."\" target=_parent>\n"; $str .= ""; for ($i=0; $i<$maxlevel; $i++) $str .= ""; $str .= "\n"; } /****************************************/ /* start new row */ /****************************************/ $str .= ""; /****************************************/ /* vertical lines from higher levels */ /****************************************/ $i=0; while ($i<$tree[$cnt][0]-1) { if ($levels[$i]==1) $str .= ""; else $str .= ""; $i++; } /****************************************/ /* corner at end of subtree or t-split */ /****************************************/ if ($tree[$cnt][4]==1) { $str .= ""; $levels[$tree[$cnt][0]-1]=0; } else { $str .= ""; $levels[$tree[$cnt][0]-1]=1; } /********************************************/ /* Node (with subtree) or Leaf (no subtree) */ /********************************************/ if ($tree[$cnt+1][0]>$tree[$cnt][0]) { if ($expand[$cnt]==0) $str .= "link($script,$params)."\">"; else $str .= "link($script,$params)."\">"; } else { /*************************/ /* Tree Leaf */ /*************************/ $str .= ""; } /****************************************/ /* output item text */ /****************************************/ if ($tree[$cnt][2]=="") $str .= "".$tree[$cnt][1].""; else $str .= "link($tree[$cnt][2],$params)."\" target=\"".$tree[$cnt][3]."\">".$tree[$cnt][1].""; /****************************************/ /* end row */ /****************************************/ $str .= "\n"; } $cnt++; } $str .= "\n"; return $str; /***************************************************/ /* Tree file format */ /* */ /* */ /* The first line is always of format : */ /* .[rootname] */ /* */ /* each line contains one item, the line starts */ /* with a series of dots(.). Each dot is one level */ /* deeper. Only one level at a time once is allowed*/ /* Next comes the come the item name, link and */ /* link target, seperated by a |. */ /* */ /* example: */ /* */ /* .top */ /* ..category 1 */ /* ...item 1.1|item11.htm|main */ /* ...item 2.2|item12.htm|main */ /* ..category 2|cat2overview.htm|main */ /* ...item 2.1|item21.htm|main */ /* ...item 2.2|item22.htm|main */ /* ...item 2.3|item23.htm|main */ /* */ /***************************************************/ } }