Bug 18887: (QA follow-up) Remove last occurences of old max_holds
[koha.git] / admin / branch_transfer_limits.pl
index 8c5c064..681f85b 100755 (executable)
@@ -1,49 +1,68 @@
 #!/usr/bin/perl
 
 # Copyright 2000-2002 Katipo Communications
+# copyright 2010 BibLibre
 #
 # 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>.
 
-use strict;
-use CGI;
+use Modern::Perl;
+
+use CGI qw ( -utf8 );
 use C4::Auth;
 use C4::Context;
 use C4::Output;
 use C4::Koha;
-use C4::Branch; 
+use C4::Circulation qw{ IsBranchTransferAllowed DeleteBranchTransferLimits CreateBranchTransferLimit };
 
 my $input = new CGI;
 
 my ($template, $loggedinuser, $cookie)
-    = get_template_and_user({template_name => "admin/branch_transfer_limits.tmpl",
+    = get_template_and_user({template_name => "admin/branch_transfer_limits.tt",
                             query => $input,
                             type => "intranet",
-                            flagsrequired => {borrowers => 1},
+                 flagsrequired => {parameters => 'parameters_remaining_permissions'},
                             debug => 1,
                             });
 
 my $dbh = C4::Context->dbh;
+my $branchcode;
+if((!defined($input->param('branchcode'))) & C4::Context::mybranch() ne '')
+{
+    $branchcode = C4::Context::mybranch();
+}
+else
+{
+       $branchcode = $input->param('branchcode');
+}
+
+# Set the template language for the correct limit type using $limitType
+my $limitType = C4::Context->preference("BranchTransferLimitsType") || "ccode";
 
-my @itemtypes;
+my @codes;
 my @branchcodes;
 
-my $sth = $dbh->prepare("SELECT itemtype FROM itemtypes");
+my $sth;
+if ( $limitType eq 'ccode' ) {
+       $sth = $dbh->prepare('SELECT authorised_value AS ccode FROM authorised_values WHERE category = "CCODE"');
+} elsif ( $limitType eq 'itemtype' ) {
+       $sth = $dbh->prepare('SELECT itemtype FROM itemtypes');
+}
 $sth->execute();
 while ( my $row = $sth->fetchrow_hashref ) {
-       push( @itemtypes, $row->{'itemtype'} );
+       push( @codes, $row->{ $limitType } );
 }
 
 $sth = $dbh->prepare("SELECT branchcode FROM branches");
@@ -54,15 +73,14 @@ while ( my $row = $sth->fetchrow_hashref ) {
 
 ## If Form Data Passed, Update the Database
 if ( $input->param('updateLimits') ) {
-    DeleteBranchTransferLimits();
+    DeleteBranchTransferLimits($branchcode);
+
 
-       foreach my $itemtype ( @itemtypes ) {
+       foreach my $code ( @codes ) {
                foreach my $toBranch ( @branchcodes ) {
-                       foreach my $fromBranch ( @branchcodes ) {
-                               my $isSet = $input->param( $itemtype . "_" . $toBranch . "_" . $fromBranch );
-                               if ( $isSet ) {
-                                    CreateBranchTransferLimit( $toBranch, $fromBranch, $itemtype );
-                               }
+                       my $isSet = not $input->param( $code . "_" . $toBranch);
+                       if ( $isSet ) {
+                           CreateBranchTransferLimit( $toBranch, $branchcode, $code );
                        }
                }
        }
@@ -75,45 +93,34 @@ foreach my $branchcode ( @branchcodes ) {
        $row_data{ branchcode } = $branchcode;
        push ( @branchcode_loop, \%row_data );
 }
+my $branchcount = scalar(@branchcode_loop);
 
 ## Build the default data
-my @loop0;
-foreach my $itemtype ( @itemtypes ) {
-       my @loop1;
+my @codes_loop;
+foreach my $code ( @codes ) {
+       my @to_branch_loop;
        my %row_data;
-       $row_data{ itemtype } = $itemtype;
-       $row_data{ loop1 } = \@loop1;
+       $row_data{ code } = $code;
+       $row_data{ to_branch_loop } = \@to_branch_loop;
        foreach my $toBranch ( @branchcodes ) {
-               my @loop2;
                my %row_data;
-               $row_data{ itemtype } = $itemtype;
-               $row_data{ toBranch } = $toBranch;
-               $row_data{ loop2 } = \@loop2;
-               
-               foreach my $fromBranch ( @branchcodes ) {
-                       my %row_data;
-                        my $isChecked = ! IsBranchTransferAllowed( $toBranch, $fromBranch, $itemtype );
-                       $row_data{ itemtype } = $itemtype;
-                       $row_data{ toBranch } = $toBranch;
-                       $row_data{ fromBranch } = $fromBranch;
-                        $row_data{ isChecked } = $isChecked;
-                       
-                       push( @loop2, \%row_data );
-               }
-               
-               push( @loop1, \%row_data );
+                my $isChecked = IsBranchTransferAllowed( $toBranch, $branchcode, $code );
+               $row_data{ code }         = $code;
+               $row_data{ toBranch }     = $toBranch;
+               $row_data{ isChecked }    = $isChecked; 
+               push( @to_branch_loop, \%row_data );
        }
 
-       push( @loop0, \%row_data );     
+       push( @codes_loop, \%row_data );
 }
 
 
 $template->param(
-               loop0 => \@loop0,
+               branchcount => $branchcount,
+               codes_loop => \@codes_loop,
                branchcode_loop => \@branchcode_loop,
-               intranetcolorstylesheet => C4::Context->preference("intranetcolorstylesheet"),
-               intranetstylesheet => C4::Context->preference("intranetstylesheet"),
-               IntranetNav => C4::Context->preference("IntranetNav"),
+               branchcode => $branchcode,
+        limitType => $limitType,
                );
 
 output_html_with_http_headers $input, $cookie, $template->output;