X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FMenu.pm;h=7d07153bc1125c927c9c0adce71745f1260aa4e6;hb=9198a41442e997dc37eb80d3a30eab7136d58208;hp=b3ffd0f94e0eb82b216610b206cc6ff101975281;hpb=e98e20941b580769e3f4e6e2bcac60a679b7e06b;p=kivitendo-erp.git diff --git a/SL/Menu.pm b/SL/Menu.pm index b3ffd0f94..7d07153bc 100644 --- a/SL/Menu.pm +++ b/SL/Menu.pm @@ -34,13 +34,17 @@ package Menu; +use SL::Inifile; + sub new { $main::lxdebug->enter_sub(); - my ($type, $menufile, $level) = @_; + my ($type, $menufile) = @_; + + my $self = {}; + my $inifile = Inifile->new($menufile); - use SL::Inifile; - my $self = Inifile->new($menufile, $level); + map { $self->{$_} = $inifile->{$_} } keys %{ $inifile }; $main::lxdebug->leave_sub(); @@ -69,7 +73,7 @@ sub menuitem { my $level = $form->escape($item); my $str = - qq|{path}&action=$action&level=$level&login=$form->{login}&password=$form->{password}|; + qq|{login}&password=$form->{password}|; my @vars = qw(module action target href); @@ -122,7 +126,7 @@ sub menuitem_v3 { my $str = qq|{$item}{module}) { + $module = $self->{$item}{module}; + } + if ($self->{$item}{action}) { + $action = $self->{$item}{action}; + } + if ($self->{$item}{target}) { + $target = $self->{$item}{target}; + } + + my $level = $form->escape($item); + + my $str = qq| link="$module?action=| . $form->escape($action) . + qq|&level=| . $form->escape($level); + map({ $str .= "&${_}=" . $form->escape($form->{$_}); } qw(login password)); + + my @vars = qw(module action target href); + + if ($self->{$item}{href}) { + $str = qq| link=$self->{$item}{href}|; + @vars = qw(module target href); + } + + map { delete $self->{$item}{$_} } @vars; + + # add other params + foreach my $key (keys %{ $self->{$item} }) { + $str .= "&" . $form->escape($key, 1) . "="; + ($value, $conf) = split(/=/, $self->{$item}{$key}, 2); + $value = $myconfig->{$value} . "/$conf" if ($conf); + $str .= $form->escape($value, 1); + } + + $str .= '"'; + + + + if ($other) { + foreach my $key (keys(%{$other})) { + $str .= qq| ${key}="| . $form->quote($other->{$key}) . qq|"|; + } + } + + + $main::lxdebug->leave_sub(); + + return $str; +} + sub menuitemNew { my ($self, $myconfig, $form, $item) = @_; @@ -176,7 +238,7 @@ sub menuitemNew { my $level = $form->escape($item); my $str = - qq|$module?path=$form->{path}&action=$action&level=$level&login=$form->{login}&password=$form->{password}|; + qq|$module?action=$action&level=$level&login=$form->{login}&password=$form->{password}|; my @vars = qw(module action target href); if ($self->{$item}{href}) { @@ -215,7 +277,7 @@ sub access_control { my $excl = (); # remove --AR, --AP from array - grep { ($a, $b) = split /--/; s/--$a$//; } @a; + grep { ($a, $b) = split(/--/); s/--$a$//; } @a; map { $excl{$_} = 1 } @a;