X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=sql-ledger%2FSL%2FMenu.pm;h=0df3067aa60a04a31fe7b63e5696ab71be5ea022;hp=661d35408a635f275e4afb49794cda3534820023;hb=32306b5f8ffe4ce594409aa6e89626740b225a39;hpb=52072fcd26f2faf57923f598c358e7f47c4e2643 diff --git a/sql-ledger/SL/Menu.pm b/sql-ledger/SL/Menu.pm index 661d35408..0df3067aa 100644 --- a/sql-ledger/SL/Menu.pm +++ b/sql-ledger/SL/Menu.pm @@ -1,6 +1,6 @@ #===================================================================== # SQL-Ledger Accounting -# Copyright (C) 2001 +# Copyright (C) 2002 # # Author: Dieter Simader # Email: dsimader@sql-ledger.org @@ -12,7 +12,7 @@ # 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. -# +# # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the @@ -35,13 +35,13 @@ sub new { use SL::Inifile; my $self = Inifile->new($menufile, $level); - bless $self, $type; + bless $self, $type if $self; } sub menuitem { - my ($self, $myconfig, $form, $item) = @_; + my ($self, $myconfig, $form, $item, $level) = @_; my $module = $form->{script}; my $action = "section_menu"; @@ -56,9 +56,10 @@ sub menuitem { if ($self->{$item}{target}) { $target = $self->{$item}{target}; } + + $level = $form->escape($item); + my $str = qq|{path}&action=$action&level=$level&login=$form->{login}&timeout=$form->{timeout}&sessionid=$form->{sessionid}|; - my $level = $form->escape($item); - my $str = qq|{path}&action=$action&level=$level&login=$form->{login}&password=$form->{password}|; my @vars = qw(module action target href); if ($self->{$item}{href}) { @@ -68,20 +69,23 @@ sub menuitem { map { delete $self->{$item}{$_} } @vars; - + delete $self->{$item}{submenu}; + # add other params foreach my $key (keys %{ $self->{$item} }) { - $str .= "&".$form->escape($key,1)."="; + $str .= "&".$form->escape($key)."="; ($value, $conf) = split /=/, $self->{$item}{$key}, 2; $value = $myconfig->{$value}."/$conf" if ($conf); - $str .= $form->escape($value, 1); + $str .= $form->escape($value); } + $str .= qq|#id$form->{tag}| if $target eq 'acc_menu'; + if ($target) { $str .= qq| target=$target|; } - - $str .= ">"; + + $str .= qq|>|; }