From b73bf7374ceed33d217498042c240a35097f37f1 Mon Sep 17 00:00:00 2001 From: Nick Clemens Date: Wed, 1 Apr 2020 12:38:02 +0000 Subject: [PATCH] Bug 25033: Display both local and all pending suggestions counts if the numbers differ To test: 0 - Be in staff client as a superlibrarian 1 - Place some suggestions 1 for any branch 1 for signed in branch 1 for another branch 2 - Go to Koha main page, 3 suggestions pending 3 - Click 'Suggestions pending approval' - you see one suggestion 4 - Click on 'Acquisitions' in breadcrumbs , 3 suggestions pending 5 - Click manage suggestions - you see one suggestion 6 - Apply patch 7 - On mainpage and acqui-home you now see "Centerville: 1 / All libraries: 3" suggestions 8 - Confirm that the links take you to suggestions view of your branch or all libraries respectively 9 - Turn on IndependentBranches 10 - Create a user with acquisition and suggestions permissions but not superlibrarian in one of the branches used above 11 - Sign in as that user 11 - See "Centerville: 1" suggestion on mainpage and on acqui home Signed-off-by: David Nind Signed-off-by: Katrin Fischer Signed-off-by: Jonathan Druart --- acqui/acqui-home.pl | 18 +++++++++++++--- .../prog/en/modules/acqui/acqui-home.tt | 13 +++++++++++- .../prog/en/modules/intranet-main.tt | 13 ++++++++++-- mainpage.pl | 21 ++++++++++++++++--- 4 files changed, 56 insertions(+), 9 deletions(-) diff --git a/acqui/acqui-home.pl b/acqui/acqui-home.pl index 9c70773f8f..e12307438f 100755 --- a/acqui/acqui-home.pl +++ b/acqui/acqui-home.pl @@ -35,9 +35,9 @@ use C4::Acquisition; use C4::Budgets; use C4::Members; use C4::Debug; -use C4::Suggestions; use Koha::Acquisition::Currencies; use Koha::Patrons; +use Koha::Suggestions; my $query = CGI->new; my ( $template, $loggedinuser, $cookie, $userflags ) = get_template_and_user( @@ -51,7 +51,20 @@ my ( $template, $loggedinuser, $cookie, $userflags ) = get_template_and_user( ); my $status = $query->param('status') || "ASKED"; -my $suggestions_count = CountSuggestion($status); +# Get current branch count and total viewable count, if they don't match then pass +# both to template +if( C4::Context->only_my_library ){ + my $local_pendingsuggestions_count = Koha::Suggestions->search({ status => "ASKED", branchcode => C4::Context->userenv()->{'branch'} })->count(); + $template->param( suggestions_count => $local_pendingsuggestions_count ); +} else { + my $pendingsuggestions = Koha::Suggestions->search({ status => "ASKED" }); + my $local_pendingsuggestions_count = $pendingsuggestions->search({ 'me.branchcode' => C4::Context->userenv()->{'branch'} })->count(); + my $pendingsuggestions_count = $pendingsuggestions->count(); + $template->param( + all_pendingsuggestions => $pendingsuggestions_count != $local_pendingsuggestions_count ? $pendingsuggestions_count : 0, + suggestions_count => $local_pendingsuggestions_count + ); +} my $budget_arr = GetBudgetHierarchy; @@ -114,7 +127,6 @@ $template->param( totspent_active => $totspent_active, totordered_active => $totordered_active, totavail_active => $totavail_active, - suggestions_count => $suggestions_count, ); my $cur = Koha::Acquisition::Currencies->get_active; diff --git a/koha-tmpl/intranet-tmpl/prog/en/modules/acqui/acqui-home.tt b/koha-tmpl/intranet-tmpl/prog/en/modules/acqui/acqui-home.tt index b64911f96a..2546eb6b50 100644 --- a/koha-tmpl/intranet-tmpl/prog/en/modules/acqui/acqui-home.tt +++ b/koha-tmpl/intranet-tmpl/prog/en/modules/acqui/acqui-home.tt @@ -54,7 +54,18 @@
Pending suggestions -

[% suggestions_count | html %] suggestions waiting. Manage suggestions.

+

+ Manage suggestions: + + [% LoginBranchname | html %]: [% suggestions_count | html %] + + [% IF (all_pendingsuggestions > 0) %] + / + + All libraries: [% all_pendingsuggestions | html %] + + [% END %] +

diff --git a/koha-tmpl/intranet-tmpl/prog/en/modules/intranet-main.tt b/koha-tmpl/intranet-tmpl/prog/en/modules/intranet-main.tt index 882a446ff1..7e038a85cb 100644 --- a/koha-tmpl/intranet-tmpl/prog/en/modules/intranet-main.tt +++ b/koha-tmpl/intranet-tmpl/prog/en/modules/intranet-main.tt @@ -1,6 +1,7 @@ [% USE raw %] [% USE Asset %] [% USE Koha %] +[% USE Branches %] [% SET footerjs = 1 %] [% INCLUDE 'doc-head-open.inc' %] Koha staff client @@ -155,8 +156,16 @@ [% IF ( CAN_user_suggestions_suggestions_manage && pendingsuggestions ) %]
- Suggestions pending approval: - [% pendingsuggestions | html %] + Suggestions pending approval: + + [% LoginBranchname | html %]: [% pendingsuggestions | html %] + + [% IF (all_pendingsuggestions > 0) %] + / + + All libraries: [% all_pendingsuggestions | html %] + + [% END %]
[% END %] diff --git a/mainpage.pl b/mainpage.pl index c062f5d8e1..f096da62c6 100755 --- a/mainpage.pl +++ b/mainpage.pl @@ -25,7 +25,6 @@ use C4::Output; use C4::Auth; use C4::Koha; use C4::NewsChannels; # GetNewsToDisplay -use C4::Suggestions qw/CountSuggestion/; use C4::Tags qw/get_count_by_tag_status/; use Koha::Patron::Modifications; use Koha::Patron::Discharge; @@ -33,6 +32,7 @@ use Koha::Reviews; use Koha::ArticleRequests; use Koha::ProblemReports; use Koha::Quotes; +use Koha::Suggestions; my $query = new CGI; @@ -68,7 +68,23 @@ my $branch = my $pendingcomments = Koha::Reviews->search_limited({ approved => 0 })->count; my $pendingtags = get_count_by_tag_status(0); -my $pendingsuggestions = CountSuggestion("ASKED"); + +# Get current branch count and total viewable count, if they don't match then pass +# both to template + +if( C4::Context->only_my_library ){ + my $local_pendingsuggestions_count = Koha::Suggestions->search({ status => "ASKED", branchcode => C4::Context->userenv()->{'branch'} })->count(); + $template->param( pendingsuggestions => $local_pendingsuggestions_count ); +} else { + my $pendingsuggestions = Koha::Suggestions->search({ status => "ASKED" }); + my $local_pendingsuggestions_count = $pendingsuggestions->search({ 'me.branchcode' => C4::Context->userenv()->{'branch'} })->count(); + my $pendingsuggestions_count = $pendingsuggestions->count(); + $template->param( + all_pendingsuggestions => $pendingsuggestions_count != $local_pendingsuggestions_count ? $pendingsuggestions_count : 0, + pendingsuggestions => $local_pendingsuggestions_count + ); +} + my $pending_borrower_modifications = Koha::Patron::Modifications->pending_count( $branch ); my $pending_discharge_requests = Koha::Patron::Discharge::count({ pending => 1 }); my $pending_article_requests = Koha::ArticleRequests->search_limited( @@ -82,7 +98,6 @@ my $pending_problem_reports = Koha::ProblemReports->search({ status => 'New' }); $template->param( pendingcomments => $pendingcomments, pendingtags => $pendingtags, - pendingsuggestions => $pendingsuggestions, pending_borrower_modifications => $pending_borrower_modifications, pending_discharge_requests => $pending_discharge_requests, pending_article_requests => $pending_article_requests, -- 2.39.5