X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FPresenter%2FCustomerVendor.pm;h=d00c54d7ec450ae843e46c14e3a01173d2bb3e5f;hb=808bfd679e48691da8f0b9bbb8c778ab7805cbda;hp=2bf5ebc3c368a72eb5aff36eb15bb17e4385b705;hpb=f16c552035ab973a9aed4a1dc29d0e16be7ff541;p=kivitendo-erp.git diff --git a/SL/Presenter/CustomerVendor.pm b/SL/Presenter/CustomerVendor.pm index 2bf5ebc3c..d00c54d7e 100644 --- a/SL/Presenter/CustomerVendor.pm +++ b/SL/Presenter/CustomerVendor.pm @@ -5,10 +5,15 @@ use strict; use parent qw(Exporter); use Exporter qw(import); -our @EXPORT = qw(customer vendor customer_vendor_picker); +our @EXPORT = qw(customer_vendor customer vendor customer_vendor_picker); use Carp; +sub customer_vendor { + my ($self, $customer_vendor, %params) = @_; + return _customer_vendor($self, $customer_vendor, ref($customer_vendor) eq 'SL::DB::Customer' ? 'customer' : 'vendor', %params); +} + sub customer { my ($self, $customer, %params) = @_; return _customer_vendor($self, $customer, 'customer', %params); @@ -39,19 +44,26 @@ sub _customer_vendor { sub customer_vendor_picker { my ($self, $name, $value, %params) = @_; - $value = SL::DB::Manager::Customer->find_by(id => $value) if $value && !ref $value; + croak 'Unknown "type" parameter' unless $params{type} =~ m{^(?:customer|vendor)$}; + croak 'Unknown value class' if $value && ref($value) && (ref($value) !~ m{^SL::DB::(?:Customer|Vendor)$}); + + if ($value && !ref $value) { + my $class = $params{type} eq 'customer' ? 'SL::DB::Manager::Customer' : 'SL::DB::Manager::Vendor'; + $value = $class->find_by(id => $value); + } + my $id = delete($params{id}) || $self->name_to_id($name); - my $fat_set_item = delete $params{fat_set_item}; my @classes = $params{class} ? ($params{class}) : (); push @classes, 'customer_vendor_autocomplete'; - push @classes, 'customer-vendor-picker-fat-set-item' if $fat_set_item; 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(type)) . - $self->input_tag("", (ref $value && $value->can('name')) ? $value->name : '', id => "${id}_name", %params); + $self->input_tag($name, (ref $value && $value->can('id') ? $value->id : ''), class => "@classes", type => 'hidden', id => $id, + 'data-customer-vendor-picker-data' => JSON::to_json(\%params), + ) . + $self->input_tag("", ref $value ? $value->displayable_name : '', id => "${id}_name", %params); + $::request->layout->add_javascripts('kivi.CustomerVendor.js'); $::request->presenter->need_reinit_widgets($id); $self->html_tag('span', $ret, class => 'customer_vendor_picker'); @@ -128,6 +140,14 @@ the "edit vendor" dialog from the master data menu. =back +=item C + +Returns a rendered version (actually an instance of +L) of the customer or vendor object +C<$object> by calling either L or L depending on +C<$object>'s type. See the respective functions for available +parameters. + =back =head1 BUGS