kivitendo/SL/Controller/PriceSource.pm @ 61a56bb4
049e49fe | Sven Schöling | package SL::Controller::PriceSource;
|
||
use strict;
|
||||
use parent qw(SL::Controller::Base);
|
||||
use List::MoreUtils qw(any uniq apply);
|
||||
use SL::Locale::String qw(t8);
|
||||
use SL::PriceSource;
|
||||
use Rose::Object::MakeMethods::Generic
|
||||
(
|
||||
scalar => [ qw(record_item) ],
|
||||
40a0907f | Sven Schöling | 'scalar --get_set_init' => [ qw(record) ],
|
||
049e49fe | Sven Schöling | );
|
||
__PACKAGE__->run_before('check_auth');
|
||||
#
|
||||
# actions
|
||||
#
|
||||
sub action_price_popup {
|
||||
my ($self) = @_;
|
||||
my $record_item = _make_record_item($::form->{row});
|
||||
9716e08e | Sven Schöling | my $old_unit;
|
||
if (($old_unit = $record_item->{__additional_form_attributes}{unit_old}) && $old_unit ne $record_item->unit) {
|
||||
# reset unit changes. the way these interact on update breaks stuff
|
||||
$record_item->unit_obj(SL::DB::Manager::Unit->find_by(name => $old_unit));
|
||||
$self->js->val("select[name='unit_$::form->{row}']", $old_unit);
|
||||
}
|
||||
049e49fe | Sven Schöling | |||
$self->render_price_dialog($record_item);
|
||||
}
|
||||
sub render_price_dialog {
|
||||
my ($self, $record_item) = @_;
|
||||
my $price_source = SL::PriceSource->new(record_item => $record_item, record => $self->record);
|
||||
$self->js
|
||||
->run(
|
||||
'kivi.io.price_chooser_dialog',
|
||||
t8('Available Prices'),
|
||||
$self->render('oe/price_sources_dialog', { output => 0 }, price_source => $price_source)
|
||||
)
|
||||
->reinit_widgets;
|
||||
# if (@errors) {
|
||||
# $self->js->text('#dialog_flash_error_content', join ' ', @errors);
|
||||
# $self->js->show('#dialog_flash_error');
|
||||
# }
|
||||
40a0907f | Sven Schöling | $self->js->render;
|
||
049e49fe | Sven Schöling | }
|
||
#
|
||||
# internal stuff
|
||||
#
|
||||
sub check_auth {
|
||||
$::auth->assert('edit_prices');
|
||||
}
|
||||
sub init_record {
|
||||
_make_record();
|
||||
}
|
||||
sub _make_record_item {
|
||||
my ($row) = @_;
|
||||
my $class = {
|
||||
sales_order => 'OrderItem',
|
||||
3bcd9c94 | Sven Schöling | purchase_order => 'OrderItem',
|
||
049e49fe | Sven Schöling | sales_quotation => 'OrderItem',
|
||
request_quotation => 'OrderItem',
|
||||
invoice => 'InvoiceItem',
|
||||
purchase_invoice => 'InvoiceItem',
|
||||
223e6d0c | Sven Schöling | credit_note => 'InvoiceItem',
|
||
049e49fe | Sven Schöling | purchase_delivery_order => 'DeliveryOrderItem',
|
||
sales_delivery_order => 'DeliveryOrderItem',
|
||||
}->{$::form->{type}};
|
||||
return unless $class;
|
||||
$class = 'SL::DB::' . $class;
|
||||
eval "require $class";
|
||||
my $obj = $::form->{"orderitems_id_$row"}
|
||||
? $class->meta->convention_manager->auto_manager_class_name->find_by(id => $::form->{"orderitems_id_$row"})
|
||||
: $class->new;
|
||||
for my $method (apply { s/_$row$// } grep { /_$row$/ } keys %$::form) {
|
||||
b81ceec0 | Sven Schöling | if ($obj->meta->column($method)) {
|
||
if ($obj->meta->column($method)->isa('Rose::DB::Object::Metadata::Column::Date')) {
|
||||
$obj->${\"$method\_as_date"}($::form->{"$method\_$row"});
|
||||
} elsif ((ref $obj->meta->column($method)) =~ /^Rose::DB::Object::Metadata::Column::(?:Numeric|Float|DoublePrecsion)$/) {
|
||||
$obj->${\"$method\_as_number"}($::form->{"$method\_$row"});
|
||||
} elsif ((ref $obj->meta->column($method)) =~ /^Rose::DB::Object::Metadata::Column::Boolean$/) {
|
||||
$obj->$method(!!$::form->{$method});
|
||||
} else {
|
||||
$obj->$method($::form->{"$method\_$row"});
|
||||
}
|
||||
049e49fe | Sven Schöling | } else {
|
||
b81ceec0 | Sven Schöling | $obj->{__additional_form_attributes}{$method} = $::form->{"$method\_$row"};
|
||
049e49fe | Sven Schöling | }
|
||
}
|
||||
if ($::form->{"id_$row"}) {
|
||||
$obj->part(SL::DB::Part->load_cached($::form->{"id_$row"}));
|
||||
}
|
||||
return $obj;
|
||||
}
|
||||
sub _make_record {
|
||||
my ($with_items) = @_;
|
||||
my $class = {
|
||||
sales_order => 'Order',
|
||||
d47c3124 | Sven Schöling | purchase_order => 'Order',
|
||
049e49fe | Sven Schöling | sales_quotation => 'Order',
|
||
request_quotation => 'Order',
|
||||
3bcd9c94 | Sven Schöling | purchase_invoice => 'PurchaseInvoice',
|
||
049e49fe | Sven Schöling | purchase_delivery_order => 'DeliveryOrder',
|
||
sales_delivery_order => 'DeliveryOrder',
|
||||
}->{$::form->{type}};
|
||||
17384c04 | Sven Schöling | if ($::form->{type} =~ /invoice|credit_note/) {
|
||
049e49fe | Sven Schöling | $class = $::form->{vc} eq 'customer' ? 'Invoice'
|
||
: $::form->{vc} eq 'vendor' ? 'PurchaseInvoice'
|
||||
: do { die 'unknown invoice type' };
|
||||
}
|
||||
return unless $class;
|
||||
$class = 'SL::DB::' . $class;
|
||||
eval "require $class";
|
||||
my $obj = $::form->{id}
|
||||
? $class->meta->convention_manager->auto_manager_class_name->find_by(id => $::form->{id})
|
||||
: $class->new;
|
||||
for my $method (keys %$::form) {
|
||||
next unless $obj->can($method);
|
||||
next unless $obj->meta->column($method);
|
||||
if ($obj->meta->column($method)->isa('Rose::DB::Object::Metadata::Column::Date')) {
|
||||
$obj->${\"$method\_as_date"}($::form->{$method});
|
||||
} elsif ((ref $obj->meta->column($method)) =~ /^Rose::DB::Object::Metadata::Column::(?:Numeric|Float|DoublePrecsion)$/) {
|
||||
$obj->${\"$method\_as\_number"}($::form->{$method});
|
||||
a6433753 | Sven Schöling | } elsif ((ref $obj->meta->column($method)) =~ /^Rose::DB::Object::Metadata::Column::Boolean$/) {
|
||
$obj->$method(!!$::form->{$method});
|
||||
049e49fe | Sven Schöling | } else {
|
||
$obj->$method($::form->{$method});
|
||||
}
|
||||
}
|
||||
if ($with_items) {
|
||||
my @items;
|
||||
for my $i (1 .. $::form->{rowcount}) {
|
||||
next unless $::form->{"id_$i"};
|
||||
push @items, _make_record_item($i)
|
||||
}
|
||||
$obj->items(@items) if @items;
|
||||
}
|
||||
44310118 | Jan Büren | $obj->is_sales(!!$obj->customer_id) if $class eq 'SL::DB::DeliveryOrder';
|
||
049e49fe | Sven Schöling | |||
return $obj;
|
||||
}
|
||||
1;
|