X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FPresenter%2FProject.pm;h=8aecdfe492d9692b1fd405c7e9c273088ba4faec;hb=a0b82b1e7a9fab32f162ebee5031913b2f44ed5a;hp=650995c7f9782a6011f775f78f6c3b6332964dc3;hpb=5b5dbec0272c91697acf33c4842ee9d63f041f22;p=kivitendo-erp.git diff --git a/SL/Presenter/Project.pm b/SL/Presenter/Project.pm index 650995c7f..8aecdfe49 100644 --- a/SL/Presenter/Project.pm +++ b/SL/Presenter/Project.pm @@ -2,15 +2,16 @@ package SL::Presenter::Project; use strict; -use parent qw(Exporter); +use SL::Presenter::EscapedText qw(escape is_escaped); +use SL::Presenter::Tag qw(input_tag html_tag name_to_id select_tag); use Exporter qw(import); -our @EXPORT = qw(project); +our @EXPORT_OK = qw(project project_picker); use Carp; sub project { - my ($self, $project, %params) = @_; + my ($project, %params) = @_; return '' unless $project; @@ -18,30 +19,42 @@ sub project { croak "Unknown display type '$params{display}'" unless $params{display} =~ m/^(?:inline|table-cell)$/; - $params{style} ||= 'both'; - my $description; - - if ($params{style} =~ m/number/) { - $description = $project->projectnumber; - - } elsif ($params{style} =~ m/description/) { - $description = $project->description; - - } else { - $description = $project->projectnumber; - if ($project->description && do { my $desc = quotemeta $project->description; $project->projectnumber !~ m/$desc/ }) { - $description .= ' (' . $project->description . ')'; - } - } + my $description = $project->full_description(style => $params{style}); + my $callback = $params{callback} ? '&callback=' . $::form->escape($params{callback}) : ''; my $text = join '', ( - $params{no_link} ? '' : '', - $self->escape($description), + $params{no_link} ? '' : '', + escape($description), $params{no_link} ? '' : '', ); - return $self->escaped_text($text); + is_escaped($text); +} + +sub project_picker { + my ($name, $value, %params) = @_; + + $value = SL::DB::Manager::Project->find_by(id => $value) if $value && !ref $value; + my $id = delete($params{id}) || name_to_id($name); + my @classes = $params{class} ? ($params{class}) : (); + push @classes, 'project_autocomplete'; + + + my %data_params = map { $_ => delete $params{$_} } grep { defined $params{$_} } qw(customer_id active valid description_style); + + my $ret = + input_tag($name, (ref $value && $value->can('id') ? $value->id : ''), class => "@classes", type => 'hidden', id => $id, + 'data-project-picker-data' => JSON::to_json(\%data_params), + ) . + input_tag("", ref $value ? $value->displayable_name : '', id => "${id}_name", %params); + + $::request->layout->add_javascripts('autocomplete_project.js'); + $::request->presenter->need_reinit_widgets($id); + + html_tag('span', $ret, class => 'project_picker'); } +sub picker { goto &project_picker }; + 1; __END__ @@ -57,7 +70,7 @@ SL::Presenter::Project - Presenter module for project Rose::DB objects =head1 SYNOPSIS my $project = SL::DB::Manager::Project->get_first; - my $html = SL::Presenter->get->project($project, display => 'inline'); + my $html = SL::Presenter::Project->project($project, display => 'inline'); =head1 FUNCTIONS