X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FController%2FClientConfig.pm;h=ded1a33fb9d3d5ca231a180528bf52562a8dbfef;hb=eb07117b26f569d689835471cab6665e510e123e;hp=2279ef1dab0e01fc3a7ad94ab25c1849ca00787b;hpb=b58bafbbefa6513abb2cfb171a5fe12306826ff5;p=kivitendo-erp.git diff --git a/SL/Controller/ClientConfig.pm b/SL/Controller/ClientConfig.pm index 2279ef1da..ded1a33fb 100644 --- a/SL/Controller/ClientConfig.pm +++ b/SL/Controller/ClientConfig.pm @@ -14,13 +14,14 @@ use SL::DB::Part; use SL::DB::Unit; use SL::Helper::Flash; use SL::Locale::String qw(t8); +use SL::PriceSource::ALL; use SL::Template; __PACKAGE__->run_before('check_auth'); use Rose::Object::MakeMethods::Generic ( - 'scalar --get_set_init' => [ qw(defaults all_warehouses all_weightunits all_languages all_currencies all_templates h_unit_name - posting_options payment_options accounting_options inventory_options profit_options accounts balance_startdate_method_options) ], + 'scalar --get_set_init' => [ qw(defaults all_warehouses all_weightunits all_languages all_currencies all_templates all_price_sources h_unit_name + posting_options payment_options accounting_options inventory_options profit_options balance_startdate_method_options) ], ); sub action_edit { @@ -36,6 +37,7 @@ sub action_save { my $defaults = delete($::form->{defaults}) || {}; my $entered_currencies = delete($::form->{currencies}) || []; my $original_currency_id = $self->defaults->currency_id; + $defaults->{disabled_price_sources} ||= []; # undef several fields if an empty value has been selected. foreach (qw(warehouse_id bin_id warehouse_id_ignore_onhand bin_id_ignore_onhand)) { @@ -180,27 +182,10 @@ sub init_balance_startdate_method_options { { title => t8("Last opening balance or start of year"), value => "last_ob_or_start_of_year" }, ] } -sub init_accounts { - my %accounts; +sub init_all_price_sources { + my @classes = SL::PriceSource::ALL->all_price_sources; - foreach my $chart (@{ SL::DB::Manager::Chart->get_all(where => [ link => { like => '%IC%' } ], sort_by => 'accno ASC') }) { - my %added; - - foreach my $link (split m/:/, $chart->link) { - my $key = lc($link =~ /cogs/ ? 'IC_expense' : $link =~ /sale/ ? 'IC_income' : $link); - next if $added{$key}; - - $added{$key} = 1; - $accounts{$key} ||= []; - push @{ $accounts{$key} }, $chart; - } - } - - $accounts{fx_gain} = SL::DB::Manager::Chart->get_all(where => [ category => 'I', charttype => 'A' ], sort_by => 'accno ASC'); - $accounts{fx_loss} = SL::DB::Manager::Chart->get_all(where => [ category => 'E', charttype => 'A' ], sort_by => 'accno ASC'); - $accounts{ar_paid} = SL::DB::Manager::Chart->get_all(where => [ link => { like => '%AR_paid%' } ], sort_by => 'accno ASC'); - - return \%accounts; + [ map { [ $_->name, $_->description ] } @classes ]; } # @@ -218,6 +203,8 @@ sub check_auth { sub edit_form { my ($self) = @_; + $::request->layout->use_javascript("${_}.js") for qw(jquery.selectboxes jquery.multiselect2side); + $self->render('client_config/form', title => t8('Client Configuration'), make_chart_title => sub { $_[0]->accno . '--' . $_[0]->description }, make_templates_value => sub { 'templates/' . $_[0] },