Bug 17600: Standardize our EXPORT_OK
[srvgit] / tools / exceptionHolidays.pl
index 0a36a20..a96b1d0 100755 (executable)
@@ -1,36 +1,35 @@
 #!/usr/bin/perl
 
-use strict;
-use warnings;
+use Modern::Perl;
 
-use CGI;
+use CGI qw ( -utf8 );
 
-use C4::Auth;
+use C4::Auth qw( checkauth );
 use C4::Output;
 use DateTime;
 
 use C4::Calendar;
+use Koha::DateUtils qw( dt_from_string );
 
-my $input = new CGI;
+my $input = CGI->new;
 my $dbh = C4::Context->dbh();
 
-my $branchcode = $input->param('showBranchName');
-my $weekday = $input->param('showWeekday');
-my $day = $input->param('showDay');
-my $month = $input->param('showMonth');
-my $year = $input->param('showYear');
-my $day1;
-my $month1;
-my $year1;
-my $title = $input->param('showTitle');
-my $description = $input->param('showDescription');
-my $holidaytype = $input->param('showHolidayType');
-my $datecancelrange = $input->param('datecancelrange');
-my $calendardate = sprintf("%04d-%02d-%02d", $year, $month, $day);
-my $isodate = C4::Dates->new($calendardate, 'iso');
-$calendardate = $isodate->output('syspref');
+checkauth($input, 0, {tools=> 'edit_calendar'}, 'intranet');
+
 
-my $calendar = C4::Calendar->new(branchcode => $branchcode);
+our $branchcode = $input->param('showBranchName');
+my $originalbranchcode  = $branchcode;
+our $weekday = $input->param('showWeekday');
+our $day = $input->param('showDay');
+our $month = $input->param('showMonth');
+our $year = $input->param('showYear');
+our $title = $input->param('showTitle');
+our $description = $input->param('showDescription');
+our $holidaytype = $input->param('showHolidayType');
+my $datecancelrange_dt = eval { dt_from_string( scalar $input->param('datecancelrange') ) };
+my $calendardate = sprintf("%04d-%02d-%02d", $year, $month, $day);
+our $showoperation = $input->param('showOperation');
+my $allbranches = $input->param('allBranches');
 
 $title || ($title = '');
 if ($description) {
@@ -40,106 +39,105 @@ if ($description) {
     $description = '';
 }   
 
-# We format the date
-my @dateend = split(/[\/-]/, $datecancelrange);
-if (C4::Context->preference("dateformat") eq "metric") {
-    $day1 = $dateend[0];
-    $month1 = $dateend[1];
-    $year1 = $dateend[2];
-}elsif (C4::Context->preference("dateformat") eq "us") {
-    $month1 = $dateend[0];
-    $day1 = $dateend[1];
-    $year1 = $dateend[2];
-} else {
-    $year1 = $dateend[0];
-    $month1 = $dateend[1];
-    $day1 = $dateend[2];
-}
-
 # We make an array with holiday's days
-my @holiday_list;
-if ($year1 && $month1 && $day1){
+our @holiday_list;
+if ($datecancelrange_dt){
             my $first_dt = DateTime->new(year => $year, month  => $month,  day => $day);
-            my $end_dt   = DateTime->new(year => $year1, month  => $month1,  day => $day1);
 
             for (my $dt = $first_dt->clone();
-                $dt <= $end_dt;
+                $dt <= $datecancelrange_dt;
                 $dt->add(days => 1) )
                 {
                 push @holiday_list, $dt->clone();
                 }
 }
-if ($input->param('showOperation') eq 'exception') {
-       $calendar->insert_exception_holiday(day => $day,
-                                                                               month => $month,
-                                                                           year => $year,
-                                                               title => $title,
-                                                               description => $description);
-} elsif ($input->param('showOperation') eq 'exceptionrange' ) {
-        if (@holiday_list){
-            foreach my $date (@holiday_list){
-                $calendar->insert_exception_holiday(
-                    day         => $date->{local_c}->{day},
-                    month       => $date->{local_c}->{month},
-                    year       => $date->{local_c}->{year},
-                    title       => $title,
-                    description => $description
-                    );
+
+if($allbranches) {
+    my $libraries = Koha::Libraries->search;
+    while ( my $library = $libraries->next ) {
+        edit_holiday($showoperation, $library->branchcode, $weekday, $day, $month, $year, $title, $description, $holidaytype, @holiday_list);
+    }
+} else {
+    edit_holiday($showoperation, $branchcode, $weekday, $day, $month, $year, $title, $description, $holidaytype, @holiday_list);
+}
+
+print $input->redirect("/cgi-bin/koha/tools/holidays.pl?branch=$originalbranchcode&calendardate=$calendardate");
+
+sub edit_holiday {
+    ($showoperation, $branchcode, $weekday, $day, $month, $year, $title, $description, $holidaytype, @holiday_list) = @_;
+    my $calendar = C4::Calendar->new(branchcode => $branchcode);
+
+    if ($showoperation eq 'exception') {
+        $calendar->insert_exception_holiday(day => $day,
+                                            month => $month,
+                                            year => $year,
+                                            title => $title,
+                                            description => $description);
+    } elsif ($showoperation eq 'exceptionrange' ) {
+            if (@holiday_list){
+                foreach my $date (@holiday_list){
+                    $calendar->insert_exception_holiday(
+                        day         => $date->{local_c}->{day},
+                        month       => $date->{local_c}->{month},
+                        year       => $date->{local_c}->{year},
+                        title       => $title,
+                        description => $description
+                        );
+                }
             }
-        }
-} elsif ($input->param('showOperation') eq 'edit') {
-    if($holidaytype eq 'weekday') {
-      $calendar->ModWeekdayholiday(weekday => $weekday,
-                                   title => $title,
-                                   description => $description);
-    } elsif ($holidaytype eq 'daymonth') {
-      $calendar->ModDaymonthholiday(day => $day,
+    } elsif ($showoperation eq 'edit') {
+        if($holidaytype eq 'weekday') {
+        $calendar->ModWeekdayholiday(weekday => $weekday,
+                                    title => $title,
+                                    description => $description);
+        } elsif ($holidaytype eq 'daymonth') {
+        $calendar->ModDaymonthholiday(day => $day,
+                                        month => $month,
+                                        title => $title,
+                                        description => $description);
+        } elsif ($holidaytype eq 'ymd') {
+        $calendar->ModSingleholiday(day => $day,
                                     month => $month,
+                                    year => $year,
                                     title => $title,
                                     description => $description);
-    } elsif ($holidaytype eq 'ymd') {
-      $calendar->ModSingleholiday(day => $day,
-                                  month => $month,
-                                  year => $year,
-                                  title => $title,
-                                  description => $description);
-    } elsif ($holidaytype eq 'exception') {
-      $calendar->ModExceptionholiday(day => $day,
-                                  month => $month,
-                                  year => $year,
-                                  title => $title,
-                                  description => $description);
-    }
-} elsif ($input->param('showOperation') eq 'delete') {
-       $calendar->delete_holiday(weekday => $weekday,
-                                 day => $day,
-                                 month => $month,
-                                             year => $year);
-}elsif ($input->param('showOperation') eq 'deleterange') {
-    if (@holiday_list){
-        foreach my $date (@holiday_list){
-            $calendar->delete_holiday_range(weekday => $weekday,
+        } elsif ($holidaytype eq 'exception') {
+        $calendar->ModExceptionholiday(day => $day,
+                                    month => $month,
+                                    year => $year,
+                                    title => $title,
+                                    description => $description);
+        }
+    } elsif ($showoperation eq 'delete') {
+        $calendar->delete_holiday(weekday => $weekday,
+                                day => $day,
+                                month => $month,
+                                year => $year);
+    }elsif ($showoperation eq 'deleterange') {
+        if (@holiday_list){
+            foreach my $date (@holiday_list){
+                $calendar->delete_holiday_range(weekday => $weekday,
+                                                day => $date->{local_c}->{day},
+                                                month => $date->{local_c}->{month},
+                                                year => $date->{local_c}->{year});
+                }
+        }
+    }elsif ($showoperation eq 'deleterangerepeat') {
+        if (@holiday_list){
+            foreach my $date (@holiday_list){
+            $calendar->delete_holiday_range_repeatable(weekday => $weekday,
+                                            day => $date->{local_c}->{day},
+                                            month => $date->{local_c}->{month});
+            }
+        }
+    }elsif ($showoperation eq 'deleterangerepeatexcept') {
+        if (@holiday_list){
+            foreach my $date (@holiday_list){
+            $calendar->delete_exception_holiday_range(weekday => $weekday,
                                             day => $date->{local_c}->{day},
                                             month => $date->{local_c}->{month},
                                             year => $date->{local_c}->{year});
             }
-    }
-}elsif ($input->param('showOperation') eq 'deleterangerepeat') {
-    if (@holiday_list){
-        foreach my $date (@holiday_list){
-           $calendar->delete_holiday_range_repeatable(weekday => $weekday,
-                                         day => $date->{local_c}->{day},
-                                         month => $date->{local_c}->{month});
-        }
-    }
-}elsif ($input->param('showOperation') eq 'deleterangerepeatexcept') {
-    if (@holiday_list){
-        foreach my $date (@holiday_list){
-           $calendar->delete_exception_holiday_range(weekday => $weekday,
-                                         day => $date->{local_c}->{day},
-                                         month => $date->{local_c}->{month},
-                                         year => $date->{local_c}->{year});
         }
     }
 }
-print $input->redirect("/cgi-bin/koha/tools/holidays.pl?branch=$branchcode&calendardate=$calendardate");