Bug 18887: (QA follow-up) Remove last occurences of old max_holds
[koha.git] / admin / branch_transfer_limits.pl
index 2cee238..681f85b 100755 (executable)
@@ -1,52 +1,56 @@
 #!/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 warnings;
+use Modern::Perl;
 
-use CGI;
+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;
-
-# Set the template language for the correct limit type
-my $limit_phrase = 'Collection Code';
-my $limitType = C4::Context->preference("BranchTransferLimitsType");
-if ( $limitType eq 'itemtype' ) {
-       $limit_phrase = 'Item Type';
+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 @codes;
 my @branchcodes;
 
@@ -69,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 $code ( @codes ) {
                foreach my $toBranch ( @branchcodes ) {
-                       foreach my $fromBranch ( @branchcodes ) {
-                               my $isSet = $input->param( $code . "_" . $toBranch . "_" . $fromBranch );
-                               if ( $isSet ) {
-                                    CreateBranchTransferLimit( $toBranch, $fromBranch, $code );
-                               }
+                       my $isSet = not $input->param( $code . "_" . $toBranch);
+                       if ( $isSet ) {
+                           CreateBranchTransferLimit( $toBranch, $branchcode, $code );
                        }
                }
        }
@@ -90,6 +93,7 @@ foreach my $branchcode ( @branchcodes ) {
        $row_data{ branchcode } = $branchcode;
        push ( @branchcode_loop, \%row_data );
 }
+my $branchcount = scalar(@branchcode_loop);
 
 ## Build the default data
 my @codes_loop;
@@ -99,23 +103,11 @@ foreach my $code ( @codes ) {
        $row_data{ code } = $code;
        $row_data{ to_branch_loop } = \@to_branch_loop;
        foreach my $toBranch ( @branchcodes ) {
-               my @from_branch_loop;
                my %row_data;
-               $row_data{ code } = $code;
-               $row_data{ toBranch } = $toBranch;
-               $row_data{ from_branch_loop } = \@from_branch_loop;
-               
-               foreach my $fromBranch ( @branchcodes ) {
-                       my %row_data;
-                        my $isChecked = ! IsBranchTransferAllowed( $toBranch, $fromBranch, $code );
-                       $row_data{ code } = $code;
-                       $row_data{ toBranch } = $toBranch;
-                       $row_data{ fromBranch } = $fromBranch;
-                        $row_data{ isChecked } = $isChecked;
-                       
-                       push( @from_branch_loop, \%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 );
        }
 
@@ -124,9 +116,11 @@ foreach my $code ( @codes ) {
 
 
 $template->param(
+               branchcount => $branchcount,
                codes_loop => \@codes_loop,
                branchcode_loop => \@branchcode_loop,
-               limit_phrase => $limit_phrase,
+               branchcode => $branchcode,
+        limitType => $limitType,
                );
 
 output_html_with_http_headers $input, $cookie, $template->output;