egroupware/phpgwapi/inc/phpgw_utilities_menutree.inc.php

295 lines
11 KiB
PHP
Raw Normal View History

2000-12-18 21:09:56 +01:00
<?php
/**************************************************************************\
* phpGroupWare *
* http://www.phpgroupware.org *
* This file based on PHP3 TreeMenu *
* (c)1999 Bjorge Dijkstra <bjorge@gmx.net> *
* -------------------------------------------- *
* 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 {
2000-12-30 05:07:14 +01:00
function showtree($treefile, $expandlevels="", $num_menus = 50, $invisible_menus = Null){
global $phpgw_info, $phpgw;
2000-12-18 21:09:56 +01:00
$script = $SCRIPT_NAME;
2000-12-30 05:07:14 +01:00
$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";
2000-12-18 21:09:56 +01:00
/*********************************************/
/* 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);
2000-12-30 05:07:14 +01:00
while ($buffer = fgets($fd, 4096)) {
2000-12-18 21:09:56 +01:00
$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<count($tree); $i++) {
$expand[$i]=0;
$visible[$i]=0;
$levels[$i]=0;
}
/*********************************************/
/* Get Node numbers to expand */
/*********************************************/
2000-12-30 05:07:14 +01:00
if ($expandlevels!="") $explevels = explode("|",$expandlevels);
2000-12-18 21:09:56 +01:00
$i=0;
2000-12-30 05:07:14 +01:00
while($i<count($explevels)) {
2000-12-18 21:09:56 +01:00
$expand[$explevels[$i]]=1;
$i++;
}
/*********************************************/
/* Find last nodes of subtrees */
/*********************************************/
$lastlevel=$maxlevel;
2000-12-30 05:07:14 +01:00
for ($i=count($tree)-1; $i>=0; $i--) {
if ( $tree[$i][0] < $lastlevel ) {
for ($j=$tree[$i][0]+1; $j <= $maxlevel; $j++) {
2000-12-18 21:09:56 +01:00
$levels[$j]=0;
}
}
2000-12-30 05:07:14 +01:00
if ( $levels[$tree[$i][0]]==0 ) {
2000-12-18 21:09:56 +01:00
$levels[$tree[$i][0]]=1;
$tree[$i][4]=1;
2000-12-30 05:07:14 +01:00
} else
2000-12-18 21:09:56 +01:00
$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
2000-12-30 05:07:14 +01:00
for ($i=0; $i<count($explevels); $i++) {
2000-12-18 21:09:56 +01:00
$n=$explevels[$i];
2000-12-30 05:07:14 +01:00
if ( ($visible[$n]==1) && ($expand[$n]==1) ) {
2000-12-18 21:09:56 +01:00
$j=$n+1;
2000-12-30 05:07:14 +01:00
while ( $tree[$j][0] > $tree[$n][0] ) {
2000-12-18 21:09:56 +01:00
if ($tree[$j][0]==$tree[$n][0]+1) $visible[$j]=1;
$j++;
}
}
}
2000-12-30 05:07:14 +01:00
for ($i=0; $i<count($explevels); $i++) {
2000-12-18 21:09:56 +01:00
$n=$explevels[$i];
2000-12-30 05:07:14 +01:00
if ( ($visible[$n]==1) && ($expand[$n]==1) ) {
2000-12-18 21:09:56 +01:00
$j=$n+1;
2000-12-30 05:07:14 +01:00
while ( $tree[$j][0] == $tree[$n][0] + 1 ) {
$visible[$j]=1;
2000-12-18 21:09:56 +01:00
$j++;
}
}
}
/*********************************************/
/* Output nicely formatted tree */
/*********************************************/
for ($i=0; $i<$maxlevel; $i++) $levels[$i]=1;
$maxlevel++;
$cnt=0;
2000-12-30 05:07:14 +01:00
while ($cnt<count($tree)) {
if ($visible[$cnt]) {
/****************************************/
/* Create expand/collapse parameters */
/****************************************/
$i=1; $params="p=";
while($i<count($expand)) {
if ( ($expand[$i]==1) && ($cnt!=$i) || ($expand[$i]==0 && $cnt==$i)) {
$params=$params.$i;
$params=$params."|";
}
$i++;
}
/****************************************/
/* Always display the extreme top level */
/****************************************/
if($cnt==0) {
$str = "<table cellspacing=0 cellpadding=0 border=0 cols=".($maxlevel+3)." width=".($maxlevel*16+100).">\n";
$str .= "<a href=\"".$phpgw->link("index.php",$params)."\" target=_parent><img src=\"templates/default/images/docs.gif\" border=\"0\"></a>\n";
$str .= "<tr>";
for ($i=0; $i<$maxlevel; $i++) $str .= "<td width=16></td>";
$str .= "<td width=100></td></tr>\n";
}
2000-12-18 21:09:56 +01:00
/****************************************/
/* start new row */
/****************************************/
2000-12-30 05:07:14 +01:00
$str .= "<tr>";
2000-12-18 21:09:56 +01:00
/****************************************/
/* vertical lines from higher levels */
/****************************************/
$i=0;
2000-12-30 05:07:14 +01:00
while ($i<$tree[$cnt][0]-1) {
2000-12-18 21:09:56 +01:00
if ($levels[$i]==1)
2000-12-30 05:07:14 +01:00
$str .= "<td><img src=\"".$img_line."\"></td>";
2000-12-18 21:09:56 +01:00
else
2000-12-30 05:07:14 +01:00
$str .= "<td><img src=\"".$img_spc."\"></td>";
2000-12-18 21:09:56 +01:00
$i++;
}
/****************************************/
/* corner at end of subtree or t-split */
/****************************************/
2000-12-30 05:07:14 +01:00
if ($tree[$cnt][4]==1) {
$str .= "<td><img src=\"".$img_end."\"></td>";
2000-12-18 21:09:56 +01:00
$levels[$tree[$cnt][0]-1]=0;
2000-12-30 05:07:14 +01:00
} else {
$str .= "<td><img src=\"".$img_split."\"></td>";
2000-12-18 21:09:56 +01:00
$levels[$tree[$cnt][0]-1]=1;
}
/********************************************/
/* Node (with subtree) or Leaf (no subtree) */
/********************************************/
2000-12-30 05:07:14 +01:00
if ($tree[$cnt+1][0]>$tree[$cnt][0]) {
2000-12-18 21:09:56 +01:00
if ($expand[$cnt]==0)
2000-12-30 05:07:14 +01:00
$str .= "<td><a href=\"".$phpgw->link($script,$params)."\"><img src=\"".$img_expand."\" border=no></a></td>";
2000-12-18 21:09:56 +01:00
else
2000-12-30 05:07:14 +01:00
$str .= "<td><a href=\"".$phpgw->link($script,$params)."\"><img src=\"".$img_collapse."\" border=no></a></td>";
} else {
2000-12-18 21:09:56 +01:00
/*************************/
/* Tree Leaf */
/*************************/
2000-12-30 05:07:14 +01:00
$str .= "<td><img src=\"".$img_leaf."\"></td>";
2000-12-18 21:09:56 +01:00
}
/****************************************/
/* output item text */
/****************************************/
if ($tree[$cnt][2]=="")
2000-12-30 05:07:14 +01:00
$str .= "<td colspan=".($maxlevel-$tree[$cnt][0]).">".$tree[$cnt][1]."<font face\=\"Arial, Helvetica, san-serif\" size=\"2\"></td>";
2000-12-18 21:09:56 +01:00
else
2000-12-30 05:07:14 +01:00
$str .= "<td colspan=".($maxlevel-$tree[$cnt][0])."><font face\=\"Arial, Helvetica, san-serif\" size=\"2\"><a href=\"".$phpgw->link($tree[$cnt][2],$params)."\" target=\"".$tree[$cnt][3]."\">".$tree[$cnt][1]."</a></td>";
2000-12-18 21:09:56 +01:00
/****************************************/
/* end row */
/****************************************/
2000-12-30 05:07:14 +01:00
$str .= "</tr>\n";
2000-12-18 21:09:56 +01:00
}
$cnt++;
}
2000-12-30 05:07:14 +01:00
$str .= "</table>\n";
return $str;
2000-12-18 21:09:56 +01:00
/***************************************************/
/* 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 */
/* */
/***************************************************/
}
}