X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/73d810a4ac3395dc6d8012a52b6c787dedf932b1..af039f53d1b4d8e8456f88fcf3b2bfdc22f8889a:/SL/DB/Helper/TransNumberGenerator.pm diff --git a/SL/DB/Helper/TransNumberGenerator.pm b/SL/DB/Helper/TransNumberGenerator.pm index aa0265411..cc5fc327c 100644 --- a/SL/DB/Helper/TransNumberGenerator.pm +++ b/SL/DB/Helper/TransNumberGenerator.pm @@ -50,22 +50,43 @@ sub get_next_trans_number { return $number if $self->id && $number; - my %conditions = $scoping_conditions ? ( query => [ $scoping_conditions->($spec_type) ] ) : (); - my @numbers = map { $_->$number_column } @{ $self->_get_manager_class->get_all(%conditions) }; - my %numbers_in_use = map { ( $_ => 1 ) } @numbers; - require SL::DB::Default; - my $defaults = SL::DB::Default->get; - $number_range_column = 'articlenumber' if $number_range_column eq 'assemblynumber' and length($defaults->$number_range_column) < 1; - my $sequence = SL::PrefixedNumber->new(number => $defaults->$number_range_column); + require SL::DB::Business; + + my %conditions = ( query => [ $scoping_conditions ? $scoping_conditions->($spec_type) : () ] ); + my %conditions_for_in_use = ( query => [ $scoping_conditions ? $scoping_conditions->($spec_type) : () ] ); + + my $business; + if ($spec_type =~ m{^(?:customer|vendor)$}) { + $business = $self->business_id ? SL::DB::Business->new(id => $self->business_id)->load : $self->business; + if ($business && (($business->customernumberinit // '') ne '')) { + $number_range_column = 'customernumberinit'; + push @{ $conditions{query} }, ( business_id => $business->id ); + + } else { + undef $business; + push @{ $conditions{query} }, ( business_id => undef ); + + } + } + + my %numbers_in_use = map { ( $_->$number_column => 1 ) } @{ $self->_get_manager_class->get_all(%conditions_for_in_use) }; + + my $range_table = $business ? $business : SL::DB::Default->get; + my $start_number = $range_table->$number_range_column; + $start_number = $range_table->articlenumber if ($number_range_column eq 'assemblynumber') && (length($start_number) < 1); + my $sequence = SL::PrefixedNumber->new(number => $start_number); - $sequence->set_to_max(@numbers) if !$fill_holes_in_range; + if (!$fill_holes_in_range) { + my @numbers = map { $_->$number_column } @{ $self->_get_manager_class->get_all(%conditions) }; + $sequence->set_to_max(@numbers) ; + } my $new_number = $sequence->get_next; $new_number = $sequence->get_next while $numbers_in_use{$new_number}; - $defaults->update_attributes($number_range_column => $new_number) if $params{update_defaults}; - $self->$number_column($new_number) if $params{update_record}; + $range_table->update_attributes($number_range_column => $new_number) if $params{update_defaults}; + $self->$number_column($new_number) if $params{update_record}; return $new_number; }