diff options
| author | Maarten Vanraes <alien@mageia.org> | 2016-05-10 20:07:15 +0200 |
|---|---|---|
| committer | Maarten Vanraes <alien@mageia.org> | 2016-05-14 09:25:25 +0200 |
| commit | 4c780314dace2294af648228a544fdf50c5b6afb (patch) | |
| tree | 1acbe8ed96c5be34d27c5f1ccff928d3e4175e29 /lib/ManaTools/Shared/ActionsRole.pm | |
| parent | aec9c7f4bd4f3e4b6e54ab34ced613f5becfa674 (diff) | |
| download | manatools-4c780314dace2294af648228a544fdf50c5b6afb.tar manatools-4c780314dace2294af648228a544fdf50c5b6afb.tar.gz manatools-4c780314dace2294af648228a544fdf50c5b6afb.tar.bz2 manatools-4c780314dace2294af648228a544fdf50c5b6afb.tar.xz manatools-4c780314dace2294af648228a544fdf50c5b6afb.zip | |
actions also have a level
Diffstat (limited to 'lib/ManaTools/Shared/ActionsRole.pm')
| -rw-r--r-- | lib/ManaTools/Shared/ActionsRole.pm | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/lib/ManaTools/Shared/ActionsRole.pm b/lib/ManaTools/Shared/ActionsRole.pm index ba4ed8f1..30f3789d 100644 --- a/lib/ManaTools/Shared/ActionsRole.pm +++ b/lib/ManaTools/Shared/ActionsRole.pm @@ -72,6 +72,14 @@ class_has 'acts' => ( default => sub {return [];} ); +has 'level' => ( + is => 'rw', + init_arg => undef, + lazy => 1, + isa => 'LevelType', + default => sub {return ManaTools::Shared::Action->beginnerLevel;} +); + #============================================================= =head2 get_actions @@ -89,8 +97,9 @@ class_has 'acts' => ( #============================================================= sub get_actions { my $self = shift; + my $level = $self->level(); - return map { return $_->name()} @{$self->acts()}; + return map { return $_->name()} grep { $_->is_valid($_) && ($_->is_level($_) <= $level) } @{$self->acts()}; } #============================================================= @@ -151,8 +160,10 @@ sub add_action { my $item = shift; my $action = shift; my $valid = shift; + my $level = shift; my $options = {name => $name, label => $label, item => $item, action => $action}; $options->{valid} = $valid if defined $valid; + $options->{level} = $level if defined $level; push @{$self->acts()}, ManaTools::Shared::Action->new($options); } |
