Bug 21467: Add subscription's info when ordering
[koha.git] / acqui / acqui-home.pl
index 4ebf874..9c70773 100755 (executable)
@@ -3,20 +3,18 @@
 # Copyright 2008 - 2009 BibLibre SARL
 # This file is part of Koha.
 #
-# Koha is free software; you can redistribute it and/or modify it under the
-# terms of the GNU General Public License as published by the Free Software
-# Foundation; either version 2 of the License, or (at your option) any later
-# version.
+# Koha is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
 #
-# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
-# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
-# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
+# Koha is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
 #
-# You should have received a copy of the GNU General Public License along with
-# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
-# Suite 330, Boston, MA  02111-1307 USA
-
-
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
 
 =head1 NAME
 
@@ -24,244 +22,106 @@ acqui-home.pl
 
 =head1 DESCRIPTION
 
-this script is the main page for acqui/
-It presents the budget's dashboard, another table about differents currency with
-their rates and the pending suggestions.
-
-=head1 CGI PARAMETERS
-
-=over 4
-
-=item $status
-C<$status> is the status a suggestion could has. Default value is 'ASKED'.
-thus, it can be REJECTED, ACCEPTED, ORDERED, ASKED, AVAIBLE
-
-=back
+this script is the main page for acqui
 
 =cut
 
-use strict;
-use Number::Format;
+use Modern::Perl;
 
-use CGI;
+use CGI qw ( -utf8 );
 use C4::Auth;
 use C4::Output;
-use C4::Suggestions;
 use C4::Acquisition;
 use C4::Budgets;
 use C4::Members;
-use C4::Branch;
 use C4::Debug;
+use C4::Suggestions;
+use Koha::Acquisition::Currencies;
+use Koha::Patrons;
 
-my $query = new CGI;
-my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
-    {
-        template_name   => "acqui/acqui-home.tmpl",
+my $query = CGI->new;
+my ( $template, $loggedinuser, $cookie, $userflags ) = get_template_and_user(
+    {   template_name   => 'acqui/acqui-home.tt',
         query           => $query,
-        type            => "intranet",
+        type            => 'intranet',
         authnotrequired => 0,
-        flagsrequired   => { acquisition => "*" },
+        flagsrequired   => { acquisition => '*' },
         debug           => 1,
     }
 );
 
-# budget
-my $borrower= GetMember('borrowernumber' => $loggedinuser);
-my ( $flags, $homebranch )= ($borrower->{'flags'},$borrower->{'branchcode'});
-
-my @results = GetBookFunds($homebranch);
-my $count = scalar @results;
-my $branchname = GetBranchName($homebranch);
-
-#my $count = scalar @results;
-my $count;
-my $classlist   = '';
-my $total       = 0;
-my $totspent    = 0;
-my $totcomtd    = 0;
-my $totavail    = 0;
-my @loop_budget = ();
-
-# ---------------------------------------------------
-# currencies
-my $cur;
-my @rates = GetCurrencies();
-$count = scalar @rates;
-
-my $active_currency = GetCurrency;
-my $num = new Number::Format(-int_curr_symbol => '',
-                             -decimal_digits => "2" );
-my @loop_currency = ();
-for ( my $i = 0 ; $i < $count ; $i++ ) {
-    my %line;
-    $line{currency}        = $rates[$i]->{'currency'} ;
-    $line{currency_symbol} = $rates[$i]->{'symbol'};
-    $line{rate}            = sprintf ( '%.2f',  $rates[$i]->{'rate'} );
-    push @loop_currency, \%line;
-}
-
-# suggestions
 my $status           = $query->param('status') || "ASKED";
-my $suggestion       = CountSuggestion($status);
-my $suggestions_loop = &SearchSuggestion( {STATUS=> $status} );
-# ---------------------------------------------------
-# number format
-my $cur_format = C4::Context->preference("CurrencyFormat");
-my $num;
-
-if ( $cur_format eq 'FR' ) {
-    $num = new Number::Format(
-        'decimal_fill'      => '2',
-        'decimal_point'     => ',',
-        'int_curr_symbol'   => '',
-        'mon_thousands_sep' => ' ',
-        'thousands_sep'     => ' ',
-        'mon_decimal_point' => ','
-    );
-} else {  # US by default..
-    $num = new Number::Format(
-        'int_curr_symbol'   => '',
-        'mon_thousands_sep' => ',',
-        'mon_decimal_point' => '.'
-    );
-}
-
-my $period            = GetBudgetPeriod;
-my $budget_period_id  = $period->{budget_period_id};
-my $budget_branchcode = $period->{budget_branchcode};
-my $moo               = GetBudgetHierarchy('',$homebranch, $template->{param_map}->{'USER_INFO'}[0]->{'borrowernumber'} );
-my @results           = @$moo;
-my $period_total      = 0;
-my $toggle            = 0;
-my @loop;
-my ( $total, $totspent, $totcomtd, $totavail );
-
-foreach my $result (@results) {
-    # only get top-level budgets for display
-    #         warn  $result->{'budget_branchcode'};
-
-    $period_total += $result->{'budget_amount'};
-
-    my $a = $result->{'budget_code_indent'};
-    $a =~ s/\ /\&nbsp\;/g;
-    $result->{'budget_code_indent'} = $a;
-
-    my $r = GetBranchName( $result->{'budget_owner_id'} );
-    $result->{'budget_branchname'} = GetBranchName( $result->{'budget_branchcode'} );
-
-    my $member      = GetMember( $result->{'budget_owner_id'} );
-    my $member_full = $member->{'firstname'} . ' ' . $member->{'surname'};
-
-    $result->{'budget_owner'} = $member_full;
-    $result->{'budget_avail'} = $result->{'budget_amount'} - $result->{'budget_spent'};
-    $result->{'budget_spent'} = GetBudgetSpent( $result->{'budget_id'} );
-
-    $total    += $result->{'budget_amount'};
-    $totspent += $result->{'budget_spent'};
-    $totavail += $result->{'budget_avail'};
-
-    $result->{'budget_amount'} = $num->format_price( $result->{'budget_amount'} );
-    $result->{'budget_spent'}  = $num->format_price( $result->{'budget_spent'} );
-    $result->{'budget_avail'}  = $num->format_price( $result->{'budget_avail'} );
-
-    #        my $spent_percent = ( $result->{'budget_spent'} / $result->{'budget_amount'} ) * 100;
-    #        $result->{'budget_spent_percent'} = sprintf( "%00d", $spent_percent );
-
-    my $borrower = &GetMember( $result->{budget_owner_id} );
-    $result->{budget_owner_name} = $borrower->{'firstname'} . ' ' . $borrower->{'surname'};
-
-    push( @loop_budget, { %{$result}, toggle => $toggle++ % 2, } );
-}
-
+my $suggestions_count       = CountSuggestion($status);
 
-# ---------------------------------------------------
+my $budget_arr = GetBudgetHierarchy;
 
-=c FIXME
+my $total      = 0;
+my $totspent   = 0;
+my $totordered = 0;
+my $totcomtd   = 0;
+my $totavail   = 0;
 
+my $total_active        = 0;
+my $totspent_active     = 0;
+my $totordered_active   = 0;
+my $totavail_active     = 0;
 
-### $cur
+my @budget_loop;
+foreach my $budget ( @{$budget_arr} ) {
+    next unless (CanUserUseBudget($loggedinuser, $budget, $userflags));
 
-## suggestions
-
-my $dbh = C4::Context->dbh;
-
-
-## liste des domaines
-
-my $sth=$dbh->prepare("
-SELECT bookfundgroupnumber,bookfundgroupname
-FROM `aq2bookfundgroups`
-ORDER BY Bookfundgroupname
-");
-$sth->execute;
-
-my @bookfundgroup_loop;  ## liste des domaines
-
-while (my $row=$sth->fetchrow_hashref) {
-        push @bookfundgroup_loop,$row;
-}
-$sth->finish;
-
-
-## liste des BFG ayant des suggestions à traiter
-
-
-## nowsuggestions = Number Of Waiting Suggestions
-
-my $dbh = C4::Context->dbh;
-
-my $sth=$dbh->prepare("
-SELECT bookfundgroupnumber, count(*) AS nowsuggestions
-FROM `aq2orders`
-WHERE step=2
-AND STATUS='ASKED'
-GROUP BY bookfundgroupnumber
-");
-$sth->execute;
-
-my @nowsuggestionsneq0_loop;  ## liste des BFG ayant des suggestions à traiter
-
-while (my $row=$sth->fetchrow_hashref) {
-        push @nowsuggestionsneq0_loop,$row;
-}
-$sth->finish;
-
-
-## liste des BFG avec l'effectif des suggestions à traiter (effectif éventuellement nul)
-
-my @nowsuggestions_loop;
-
-foreach my $data1 (@bookfundgroup_loop) {
-    $data1->{'nowsuggestions'}=0;
-    foreach my $data2 (@nowsuggestionsneq0_loop) {
-        if ($data1->{'bookfundgroupnumber'}==$data2->{'bookfundgroupnumber'}) {
-            $data1->{'nowsuggestions'}=$data2->{'nowsuggestions'};
-        }
+    my $patron = Koha::Patrons->find( $budget->{budget_owner_id} );
+    if ( $patron ) {
+        $budget->{budget_owner} = $patron;
     }
-}
 
-=cut
+    if ( !defined $budget->{budget_amount} ) {
+        $budget->{budget_amount} = 0;
+    }
+    if ( !defined $budget->{budget_spent} ) {
+        $budget->{budget_spent} = 0;
+    }
+    if ( !defined $budget->{budget_ordered} ) {
+        $budget->{budget_ordered} = 0;
+    }
+    $budget->{'budget_avail'} =
+      $budget->{'budget_amount'} - ( $budget->{'budget_spent'} + $budget->{'budget_ordered'} );
+
+    $total      += $budget->{'budget_amount'};
+    $totspent   += $budget->{'budget_spent'};
+    $totordered += $budget->{'budget_ordered'};
+    $totavail   += $budget->{'budget_avail'};
+
+    if ($budget->{budget_period_active}){
+       $total_active      += $budget->{'budget_amount'};
+       $totspent_active   += $budget->{'budget_spent'};
+       $totordered_active += $budget->{'budget_ordered'};
+       $totavail_active   += $budget->{'budget_avail'};    
+    }
 
+    push @budget_loop, $budget;
+}
 
 $template->param(
-    classlist     => $classlist,
     type          => 'intranet',
-    loop_budget   => \@loop_budget,
-    loop_currency => \@loop_currency,
-    active_symbol => $active_currency->{'symbol'},
-    branchname    => $branchname,
-    budget        => $period->{budget_name},
-    total         => $num->format_price(  $total ),
-    totspent      => $num->format_price($totspent ),
-    totcomtd      => $num->format_price( $totcomtd ),
-    totavail      => $num->format_price( $totavail ),
-
-    #      nowsuggestions_loop           => \@nowsuggestions_loop,
-    #      bookfundgroup_loop            => \@bookfundgroup_loop,
-    #      numberofwaitingsuggestionsgpd => $numberofwaitingsuggestionsgpd,
-    #      numberofwaitingsuggestionspd  => $numberofwaitingsuggestionspd,
-    #      suggestions_loop              => $suggestions_loop,
-
+    loop_budget   => \@budget_loop,
+    total         => $total,
+    totspent      => $totspent,
+    totordered    => $totordered,
+    totcomtd      => $totcomtd,
+    totavail      => $totavail,
+    total_active  => $total_active,
+    totspent_active     => $totspent_active,
+    totordered_active   => $totordered_active,
+    totavail_active     => $totavail_active,
+    suggestions_count   => $suggestions_count,
 );
 
+my $cur = Koha::Acquisition::Currencies->get_active;
+if ( $cur ) {
+    $template->param(
+        currency => $cur->currency,
+    );
+}
+
 output_html_with_http_headers $query, $cookie, $template->output;