X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;ds=sidebyside;f=SL%2FPresenter%2FCustomerVendor.pm;h=4a563e46c8d089855ebee3bc6671f324255d5ad3;hb=a3d195e845a4547ff5ae88049796290b0e6078ef;hp=6d24409d2745e77c69ab358b65880dd2cf7f1e23;hpb=e03993be556024f24e5a4940fa08078ee8cd3840;p=kivitendo-erp.git
diff --git a/SL/Presenter/CustomerVendor.pm b/SL/Presenter/CustomerVendor.pm
index 6d24409d2..4a563e46c 100644
--- a/SL/Presenter/CustomerVendor.pm
+++ b/SL/Presenter/CustomerVendor.pm
@@ -2,38 +2,82 @@ 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);
+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, $type, %params) = @_;
- return _customer_vendor($self, $customer, 'customer', %params);
+ my ($customer, %params) = @_;
+ return _customer_vendor($customer, 'customer', %params);
}
sub vendor {
- my ($self, $vendor, $type, %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';
croak "Unknown display type '$params{display}'" unless $params{display} =~ m/^(?:inline|table-cell)$/;
+ 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 ($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)$});
+
+ 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}) || name_to_id($name);
+
+ my @classes = $params{class} ? ($params{class}) : ();
+ push @classes, 'customer_vendor_autocomplete';
+
+ my $ret =
+ 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('kivi.CustomerVendor.js');
+ $::request->presenter->need_reinit_widgets($id);
+
+ 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__
@@ -51,11 +95,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
@@ -105,6 +149,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