X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FController%2FBackgroundJobHistory.pm;h=fae870643892750afd716d3dbee33a36f4833795;hb=e83604f2c7d6d499d9db8d066cc7f637e6f609de;hp=5992dc00aa2020f7809ed8fd9aacf2bd570f9f6d;hpb=07d65516a53475a8f40714da7b4d2f906cb62804;p=kivitendo-erp.git diff --git a/SL/Controller/BackgroundJobHistory.pm b/SL/Controller/BackgroundJobHistory.pm index 5992dc00a..fae870643 100644 --- a/SL/Controller/BackgroundJobHistory.pm +++ b/SL/Controller/BackgroundJobHistory.pm @@ -5,34 +5,21 @@ use strict; use parent qw(SL::Controller::Base); use SL::Controller::Helper::GetModels; -use SL::Controller::Helper::Paginated; -use SL::Controller::Helper::Sorted; use SL::DB::BackgroundJobHistory; use SL::Helper::Flash; +use SL::Locale::String; use SL::System::TaskServer; use Rose::Object::MakeMethods::Generic ( - scalar => [ qw(history) ], - 'scalar --get_set_init' => [ qw(task_server) ], + scalar => [ qw(history filter_summary) ], + 'scalar --get_set_init' => [ qw(task_server models) ], ); __PACKAGE__->run_before('check_auth'); __PACKAGE__->run_before('add_stylesheet'); __PACKAGE__->run_before('check_task_server'); -__PACKAGE__->make_paginated(ONLY => [ qw(list) ]); - -__PACKAGE__->make_sorted( - ONLY => [ qw(list) ], - - package_name => $::locale->text('Package name'), - run_at => $::locale->text('Run at'), - status => $::locale->text('Execution status'), - result => $::locale->text('Result'), - error => $::locale->text('Error'), -); - # # actions # @@ -40,9 +27,12 @@ __PACKAGE__->make_sorted( sub action_list { my ($self) = @_; + $self->make_filter_summary; + $self->render('background_job_history/list', title => $::locale->text('Background job history'), - ENTRIES => $self->get_models); + ENTRIES => $self->models->get, + MODELS => $self->models); } sub action_show { @@ -78,7 +68,47 @@ sub check_task_server { } sub add_stylesheet { - $::form->use_stylesheet('lx-office-erp/background_jobs.css'); + $::request->{layout}->use_stylesheet('background_jobs.css'); +} + +sub make_filter_summary { + my ($self) = @_; + + my $filter = $::form->{filter} || {}; + my @filters = ( + [ "package_name:substr::ilike", $::locale->text('Package name') ], + [ "result:substr::ilike", $::locale->text('Result') ], + [ "error:substr::ilike", $::locale->text('Error') ], + [ "run_at:date::ge", $::locale->text('Run at') . " " . $::locale->text('From Date') ], + [ "run_at:date::le", $::locale->text('Run at') . " " . $::locale->text('To Date') ], + ); + + my @filter_strings = grep { $_ } + map { $filter->{ $_->[0] } ? $_->[1] . ' ' . $filter->{ $_->[0] } : undef } + @filters; + + my %status = ( + failure => $::locale->text('failed'), + success => $::locale->text('succeeded'), + ); + push @filter_strings, $status{ $filter->{'status:eq_ignore_empty'} } if $filter->{'status:eq_ignore_empty'}; + + $self->filter_summary(join(', ', @filter_strings)); +} + +sub init_models { + my ($self) = @_; + + SL::Controller::Helper::GetModels->new( + controller => $self, + sorted => { + package_name => t8('Package name'), + run_at => t8('Run at'), + status => t8('Execution status'), + result => t8('Result'), + error => t8('Error'), + }, + ); } 1;