Projekt

Allgemein

Profil

Herunterladen (2,2 KB) Statistiken
| Zweig: | Markierung: | Revision:
eebe8e90 Sven Schöling
package SL::PriceSource::Pricegroup;

use strict;
use parent qw(SL::PriceSource::Base);

use SL::PriceSource::Price;
df1b03d5 Sven Schöling
use SL::DB::Price;
eebe8e90 Sven Schöling
use SL::Locale::String;
0409db7c Sven Schöling
use List::UtilsBy qw(min_by);
use List::Util qw(first);
eebe8e90 Sven Schöling
sub name { 'pricegroup' }

sub description { t8('Pricegroup') }

sub available_prices {
my ($self, %params) = @_;

df1b03d5 Sven Schöling
return () unless $self->record->is_sales;

eebe8e90 Sven Schöling
my $item = $self->record_item;

e48eb4dc Geoffrey Richardson
my $query = [ parts_id => $item->parts_id, price => { gt => 0 } ];

# add a pricegroup_filter for obsolete pricegroups, unless part of an
# existing pricegroup where that pricegroup was actually used.
if ( $self->record->id and $item->active_price_source =~ m/^pricegroup/ ) {
my ($pricegroup_id) = $item->active_price_source =~ m/^pricegroup\/(\d+)$/;
push(@{$query}, or => [ 'pricegroup.obsolete' => 0, 'pricegroup_id' => $pricegroup_id ]);
} else {
push(@{$query}, 'pricegroup.obsolete' => 0);
}

eebe8e90 Sven Schöling
my $prices = SL::DB::Manager::Price->get_all(
e48eb4dc Geoffrey Richardson
query => $query,
eebe8e90 Sven Schöling
with_objects => 'pricegroup',
e48eb4dc Geoffrey Richardson
sort_by => 'pricegroup.sortkey',
eebe8e90 Sven Schöling
);

return () unless @$prices;

return map {
$self->make_price($_);
} @$prices;
}

89b26688 Sven Schöling
sub available_discounts { }

eebe8e90 Sven Schöling
sub price_from_source {
my ($self, $source, $spec) = @_;

df1b03d5 Sven Schöling
my $price = SL::DB::Manager::Price->find_by(pricegroup_id => $spec, parts_id => $self->part->id);
eebe8e90 Sven Schöling
a5b2f9b4 Bernd Bleßmann
if (!$price) {
return SL::PriceSource::Price->new(
price_source => $self,
missing => t8('Could not find an entry for this part in the pricegroup.'),
);
}

eebe8e90 Sven Schöling
return $self->make_price($price);
}

e1c3b6b7 Bernd Bleßmann
sub discount_from_source { }

0409db7c Sven Schöling
sub best_price {
my ($self, %params) = @_;

df1b03d5 Sven Schöling
return () unless $self->record->is_sales;

my @prices = $self->available_prices;
0409db7c Sven Schöling
my $customer = $self->record->customer;

7349649b Geoffrey Richardson
return () if !$customer || !$customer->pricegroup_id;
0409db7c Sven Schöling
7349649b Geoffrey Richardson
my $best_price = first { $_->spec == $customer->pricegroup_id } @prices;
0409db7c Sven Schöling
df1b03d5 Sven Schöling
return $best_price || ();
0409db7c Sven Schöling
}

89b26688 Sven Schöling
sub best_discount { }

eebe8e90 Sven Schöling
sub make_price {
my ($self, $price_obj) = @_;

SL::PriceSource::Price->new(
price => $price_obj->price,
df1b03d5 Sven Schöling
spec => $price_obj->pricegroup->id,
eebe8e90 Sven Schöling
description => $price_obj->pricegroup->pricegroup,
price_source => $self,
)
}

1;