X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FPresenter%2FProject.pm;h=5f397715601d397936d982ccccc18da03dfe3129;hb=14d71a6d1215e4fc67136c060fd21cd6c59602af;hp=b8d20a0b354f82fc538f9eefedd6f788d752c807;hpb=766f5705ecb9cd56adfbffd94c871959bb64c6fd;p=kivitendo-erp.git diff --git a/SL/Presenter/Project.pm b/SL/Presenter/Project.pm index b8d20a0b3..5f3977156 100644 --- a/SL/Presenter/Project.pm +++ b/SL/Presenter/Project.pm @@ -5,7 +5,7 @@ use strict; use parent qw(Exporter); use Exporter qw(import); -our @EXPORT = qw(project); +our @EXPORT = qw(project project_picker); use Carp; @@ -29,6 +29,25 @@ sub project { return $self->escaped_text($text); } +sub project_picker { + my ($self, $name, $value, %params) = @_; + + $value = SL::DB::Manager::Project->find_by(id => $value) if $value && !ref $value; + my $id = delete($params{id}) || $self->name_to_id($name); + my @classes = $params{class} ? ($params{class}) : (); + push @classes, 'project_autocomplete'; + + my $ret = + $self->input_tag($name, (ref $value && $value->can('id') ? $value->id : ''), class => "@classes", type => 'hidden', id => $id) . + join('', map { $params{$_} ? $self->input_tag("", delete $params{$_}, id => "${id}_${_}", type => 'hidden') : '' } qw(customer_id)) . + $self->input_tag("", ref $value ? $value->displayable_name : '', id => "${id}_name", %params); + + $::request->layout->add_javascripts('autocomplete_project.js'); + $::request->presenter->need_reinit_widgets($id); + + $self->html_tag('span', $ret, class => 'project_picker'); +} + 1; __END__