X-Git-Url: http://wagnertech.de/git?p=kivitendo-erp.git;a=blobdiff_plain;f=SL%2FPresenter%2FCustomerVendor.pm;fp=SL%2FPresenter%2FCustomerVendor.pm;h=ab951720addaa3145c0d2afe6398b1a611e15336;hp=5f41a2a509d2876eaa0c8c7834c6c2b493a12f02;hb=53593baa211863fbf66540cf1bcc36c8fb37257f;hpb=deb4d2dbb676d7d6f69dfe7815d6e0cb09bd4a44 diff --git a/SL/Presenter/CustomerVendor.pm b/SL/Presenter/CustomerVendor.pm index 5f41a2a50..ab951720a 100644 --- a/SL/Presenter/CustomerVendor.pm +++ b/SL/Presenter/CustomerVendor.pm @@ -2,25 +2,31 @@ package SL::Presenter::CustomerVendor; 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(customer vendor customer_vendor_picker); +our @EXPORT_OK = qw(customer_vendor customer vendor customer_vendor_picker customer_picker vendor_picker); use Carp; +sub customer_vendor { + my ($customer_vendor, %params) = @_; + return _customer_vendor($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); + my ($customer, %params) = @_; + return _customer_vendor($customer, 'customer', %params); } sub vendor { - my ($self, $vendor, %params) = @_; - return _customer_vendor($self, $vendor, 'vendor', %params); + my ($vendor, %params) = @_; + return _customer_vendor($vendor, 'vendor', %params); } sub _customer_vendor { - my ($self, $cv, $type, %params) = @_; + my ($cv, $type, %params) = @_; $params{display} ||= 'inline'; @@ -29,15 +35,19 @@ sub _customer_vendor { my $callback = $params{callback} ? '&callback=' . $::form->escape($params{callback}) : ''; my $text = join '', ( - $params{no_link} ? '' : '', - $self->escape($cv->name), + $params{no_link} ? '' : '', + escape($cv->name), $params{no_link} ? '' : '', ); - return $self->escaped_text($text); + + is_escaped($text); } sub customer_vendor_picker { - my ($self, $name, $value, %params) = @_; + my ($name, $value, %params) = @_; + + $params{type} //= 'customer' if 'SL::DB::Customer' eq ref $value; + $params{type} //= 'vendor' if 'SL::DB::Vendor' eq 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)$}); @@ -47,24 +57,30 @@ sub customer_vendor_picker { $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 $id = delete($params{id}) || name_to_id($name); my @classes = $params{class} ? ($params{class}) : (); push @classes, 'customer_vendor_autocomplete'; - push @classes, 'customer-vendor-picker-fat-set-item' if $fat_set_item; + + # do not use reserved html attribute 'type' for cv type + $params{cv_type} = delete $params{type}; 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->displayable_name : '', id => "${id}_name", %params); + 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), + ) . + input_tag("", ref $value ? $value->displayable_name : '', id => "${id}_name", %params); - $::request->layout->add_javascripts('autocomplete_customer.js'); + $::request->layout->add_javascripts('kivi.CustomerVendor.js'); $::request->presenter->need_reinit_widgets($id); - $self->html_tag('span', $ret, class => 'customer_vendor_picker'); + html_tag('span', $ret, class => 'customer_vendor_picker'); } +sub customer_picker { my ($name, $value, @slurp) = @_; customer_vendor_picker($name, $value, @slurp, type => 'customer') } +sub vendor_picker { my ($name, $value, @slurp) = @_; customer_vendor_picker($name, $value, @slurp, type => 'vendor') } +sub picker { goto &customer_vendor_picker } + 1; __END__ @@ -82,11 +98,11 @@ vendor Rose::DB objects # Customers: my $customer = SL::DB::Manager::Customer->get_first; - my $html = SL::Presenter->get->customer($customer, display => 'inline'); + my $html = SL::Presenter::CustomerVendor::customer($customer, display => 'inline'); # Vendors: my $vendor = SL::DB::Manager::Vendor->get_first; - my $html = SL::Presenter->get->vendor($customer, display => 'inline'); + my $html = SL::Presenter::Customer::Vendor::vendor($customer, display => 'inline'); =head1 FUNCTIONS @@ -136,6 +152,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