Bug 32426: Changes for opac-registration-verify
[koha-ffzg.git] / mainpage.pl
index 183b5e0..53f6335 100755 (executable)
 
 use Modern::Perl;
 use CGI qw ( -utf8 );
-use C4::Output;
-use C4::Auth;
+use C4::Output qw( output_html_with_http_headers );
+use C4::Auth qw( get_template_and_user );
 use C4::Koha;
-use C4::NewsChannels; # GetNewsToDisplay
-use C4::Tags qw/get_count_by_tag_status/;
+use C4::Tags qw( get_count_by_tag_status );
+use Koha::AdditionalContents;
 use Koha::Patron::Modifications;
 use Koha::Patron::Discharge;
 use Koha::Reviews;
@@ -33,6 +33,9 @@ use Koha::ArticleRequests;
 use Koha::ProblemReports;
 use Koha::Quotes;
 use Koha::Suggestions;
+use Koha::BackgroundJobs;
+use Koha::CurbsidePickups;
+use Koha::Tickets;
 
 my $query = CGI->new;
 
@@ -45,17 +48,24 @@ my ( $template, $loggedinuser, $cookie, $flags ) = get_template_and_user(
     }
 );
 
+my $logged_in_user = Koha::Patrons->find($loggedinuser);
+
 my $homebranch;
 if (C4::Context->userenv) {
     $homebranch = C4::Context->userenv->{'branch'};
 }
-my $all_koha_news   = &GetNewsToDisplay("koha",$homebranch);
-my $koha_news_count = scalar @$all_koha_news;
+my $koha_news = Koha::AdditionalContents->search_for_display(
+    {
+        category   => 'news',
+        location   => [ 'staff_only', 'staff_and_opac' ],
+        lang       => $template->lang,
+        library_id => $homebranch
+    }
+);
 
 $template->param(
-    koha_news       => $all_koha_news,
-    koha_news_count => $koha_news_count,
-    daily_quote     => Koha::Quotes->get_daily_quote(),
+    koha_news   => $koha_news,
+    daily_quote => Koha::Quotes->get_daily_quote(),
 );
 
 my $branch =
@@ -88,12 +98,39 @@ my $pending_borrower_modifications = Koha::Patron::Modifications->pending_count(
 my $pending_discharge_requests = Koha::Patron::Discharge::count({ pending => 1 });
 my $pending_article_requests = Koha::ArticleRequests->search_limited(
     {
-        status => Koha::ArticleRequest::Status::Pending,
+        status => Koha::ArticleRequest::Status::Requested,
         $branch ? ( 'me.branchcode' => $branch ) : (),
     }
 )->count;
 my $pending_problem_reports = Koha::ProblemReports->search({ status => 'New' });
 
+if ( C4::Context->preference('OpacCatalogConcerns') || C4::Context->preference('CatalogConcerns') ) {
+    my $pending_biblio_tickets = Koha::Tickets->search(
+        {
+            resolved_date => undef,
+            biblio_id     => { '!=' => undef }
+        }
+    );
+    $template->param(
+        pending_biblio_tickets => $pending_biblio_tickets->count );
+}
+
+unless ( $logged_in_user->has_permission( { parameters => 'manage_background_jobs' } ) ) {
+    my $already_ran_jobs = Koha::BackgroundJobs->search(
+        { borrowernumber => $logged_in_user->borrowernumber } )->count ? 1 : 0;
+    $template->param( already_ran_jobs => $already_ran_jobs );
+}
+
+if ( C4::Context->preference('CurbsidePickup') ) {
+    $template->param(
+        new_curbside_pickups => Koha::CurbsidePickups->search(
+            {
+                branchcode                => $homebranch,
+            }
+        )->filter_by_to_be_staged->filter_by_scheduled_today,
+    );
+}
+
 $template->param(
     pendingcomments                => $pendingcomments,
     pendingtags                    => $pendingtags,