+sub get_taxkey {
+ my ($self, %params) = @_;
+
+ my $date = $params{date} || DateTime->today_local;
+ my $is_sales = !!$params{is_sales};
+ my $taxzone = $params{ defined($params{taxzone}) ? 'taxzone' : 'taxzone_id' } * 1;
+
+ $self->{__partpriv_taxkey_information} ||= { };
+ my $tk_info = $self->{__partpriv_taxkey_information};
+
+ $tk_info->{$taxzone} ||= { };
+ $tk_info->{$taxzone}->{$is_sales} ||= { };
+
+ return $tk_info->{$taxzone}->{$is_sales}->{$date} if exists $tk_info->{$taxzone}->{$is_sales}->{$date};
+
+ my $bugru = $self->buchungsgruppe;
+ my %charts = ( inventory => { id => $self->inventory_accno_id ? $bugru->inventory_accno_id : undef },
+ income => { id => $bugru->call_sub("income_accno_id_${taxzone}") },
+ expense => { id => $bugru->call_sub("expense_accno_id_${taxzone}") },
+ );
+
+ foreach my $type(qw(inventory income expense)) {
+ $charts{$type}->{chart} ||= $charts{$type}->{id} ? SL::DB::Manager::Chart->find_by(id => $charts{$type}->{id}) : undef if $charts{$type}->{id};
+ }
+
+ my $chart = $charts{ $is_sales ? 'income' : 'expense' }->{chart};
+
+ return $tk_info->{$taxzone}->{$is_sales}->{$date} = $chart->get_active_taxkey($date);
+}
+