koha-cvs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Koha-cvs] koha/serials alt_subscription-add.pl


From: Robert Lyon
Subject: [Koha-cvs] koha/serials alt_subscription-add.pl
Date: Thu, 20 Jul 2006 03:17:16 +0000

CVSROOT:        /sources/koha
Module name:    koha
Changes by:     Robert Lyon <bob_lyon>  06/07/20 03:17:16

Added files:
        serials        : alt_subscription-add.pl 

Log message:
        Merging in katipo changes for serials

CVSWeb URLs:
http://cvs.savannah.gnu.org/viewcvs/koha/serials/alt_subscription-add.pl?cvsroot=koha&rev=1.1

Patches:
Index: alt_subscription-add.pl
===================================================================
RCS file: alt_subscription-add.pl
diff -N alt_subscription-add.pl
--- /dev/null   1 Jan 1970 00:00:00 -0000
+++ alt_subscription-add.pl     20 Jul 2006 03:17:15 -0000      1.1
@@ -0,0 +1,274 @@
+#!/usr/bin/perl
+
+
+use strict;
+use CGI;
+use C4::Koha;
+use C4::Auth;
+use C4::Date;
+use C4::Output;
+use C4::Acquisition;
+use C4::Interface::CGI::Output;
+use C4::Context;
+use HTML::Template;
+use C4::Serials;
+use Date::Manip;
+
+my $query = new CGI;
+my $op = $query->param('op');
+my $dbh = C4::Context->dbh;
+my ($subscriptionid,$auser,$librarian,$cost,$aqbooksellerid, 
$aqbooksellername,$aqbudgetid, $bookfundid, $startdate, $periodicity,
+       $firstacquidate, $dow, $irregularity, $numberpattern, $numberlength, 
$weeklength, $monthlength, $sublength,
+       $add1,$every1,$whenmorethan1,$setto1,$lastvalue1,$innerloop1,
+       $add2,$every2,$whenmorethan2,$setto2,$lastvalue2,$innerloop2,
+       $add3,$every3,$whenmorethan3,$setto3,$lastvalue3,$innerloop3,
+       $numberingmethod, $status, $biblionumber, 
+       $bibliotitle, $callnumber, $notes, $hemisphere);
+
+       my @budgets;
+my ($template, $loggedinuser, $cookie)
+= get_template_and_user({template_name => "serials/alt_subscription-add.tmpl",
+                               query => $query,
+                               type => "intranet",
+                               authnotrequired => 0,
+                               flagsrequired => {catalogue => 1},
+                               debug => 1,
+                               });
+
+
+my $weekarrayjs='';
+my $count = 0;
+my ($year, $month, $day) = UnixDate("today", "%Y", "%m", "%d");
+my $firstday = Date_DayOfYear($month,$day,$year);
+my $wkno = Date_WeekOfYear($month,$day,$year,1); # week starting monday
+my $weekno = $wkno;
+for(my $i=$firstday;$i<($firstday+365);$i=$i+7){
+        $count = $i;
+        if($wkno > 52){$year++; $wkno=1;}
+        if($count>365){$count=$i-365;}    
+        my ($y,$m,$d) = Date_NthDayOfYear($year,$count);
+        my $output = "$y-$m-$d";
+        $weekarrayjs .= "'Wk $wkno: ".format_date($output)."',";
+        $wkno++;    
+}
+chop($weekarrayjs);
+# warn $weekarrayjs;
+
+my $sub_on;
+my @subscription_types = (
+            'issues', 'weeks', 'months'
+        ); 
+my @sub_type_data;
+if ($op eq 'mod') {
+       my $subscriptionid = $query->param('subscriptionid');
+       my $subs = &GetSubscription($subscriptionid);
+       $auser = $subs->{'user'};
+       $librarian => $subs->{'librarian'},
+       $cost = $subs->{'cost'};
+       $aqbooksellerid = $subs->{'aqbooksellerid'};
+       $aqbooksellername = $subs->{'aqbooksellername'};
+       $bookfundid = $subs->{'bookfundid'};
+       $aqbudgetid = $subs->{'aqbudgetid'};
+       $startdate = $subs->{'startdate'};
+       $firstacquidate = $subs->{'firstacquidate'};    
+       $periodicity = $subs->{'periodicity'};
+       $dow = $subs->{'dow'};
+        $irregularity = $subs->{'irregularity'};
+        $numberpattern = $subs->{'numberpattern'};
+       $numberlength = $subs->{'numberlength'};
+       $weeklength = $subs->{'weeklength'};
+       $monthlength = $subs->{'monthlength'};
+
+        if($monthlength > 0){
+           $sublength = $monthlength;
+           $sub_on = $subscription_types[2];
+       } elsif ($weeklength>0){
+           $sublength = $weeklength;
+           $sub_on = $subscription_types[1];
+       } else {
+           $sublength = $numberlength;
+           $sub_on = $subscription_types[0];
+       }
+        
+
+        while (@subscription_types) {
+           my $sub_type = shift @subscription_types;
+           my %row = ( 'name' => $sub_type );
+           if ( $sub_on eq $sub_type ) {
+            $row{'selected'} = ' selected';
+           } else {
+            $row{'selected'} = '';
+           }
+           push( @sub_type_data, \%row );
+        }
+    
+       $add1 = $subs->{'add1'};
+       $every1 = $subs->{'every1'};
+       $whenmorethan1 = $subs->{'whenmorethan1'};
+       $setto1 = $subs->{'setto1'};
+       $lastvalue1 = $subs->{'lastvalue1'};
+       $innerloop1 = $subs->{'innerloop1'};
+       $add2 = $subs->{'add2'};
+       $every2 = $subs->{'every2'};
+       $whenmorethan2 = $subs->{'whenmorethan2'};
+       $setto2 = $subs->{'setto2'};
+       $lastvalue2 = $subs->{'lastvalue2'};
+       $innerloop2 = $subs->{'innerloop2'};
+       $add3 = $subs->{'add3'};
+       $every3 = $subs->{'every3'};
+       $whenmorethan3 = $subs->{'whenmorethan3'};
+       $setto3 = $subs->{'setto3'};
+       $lastvalue3 = $subs->{'lastvalue3'};
+       $innerloop3 = $subs->{'innerloop3'};
+       $numberingmethod = $subs->{'numberingmethod'};
+       $status = $subs->{status};
+       $biblionumber = $subs->{'biblionumber'};
+       $bibliotitle = $subs->{'bibliotitle'};
+        $callnumber = $subs->{'callnumber'};
+       $notes = $subs->{'notes'};
+        $hemisphere = $subs->{'hemisphere'};
+       $template->param(
+               $op => 1,
+               user => $auser,
+               librarian => $librarian,
+               aqbooksellerid => $aqbooksellerid,
+               aqbooksellername => $aqbooksellername,
+               cost => $cost,
+               aqbudgetid => $aqbudgetid,
+               bookfundid => $bookfundid,
+               startdate => format_date($startdate),
+               firstacquidate => format_date($firstacquidate),     
+               periodicity => $periodicity,
+               dow => $dow,
+               irregularity => $irregularity,
+               numberpattern => $numberpattern,
+               sublength => $sublength,
+               subtype => address@hidden,
+               add1 => $add1,
+               every1 => $every1,
+               whenmorethan1 => $whenmorethan1,
+               setto1 => $setto1,
+               lastvalue1 => $lastvalue1,
+               innerloop1 => $innerloop1,
+               add2 => $add2,
+               every2 => $every2,
+               whenmorethan2 => $whenmorethan2,
+               setto2 => $setto2,
+               lastvalue2 => $lastvalue2,
+               innerloop2 => $innerloop2,
+               add3 => $add3,
+               every3 => $every3,
+               whenmorethan3 => $whenmorethan3,
+               setto3 => $setto3,
+               lastvalue3 => $lastvalue3,
+               innerloop3 => $innerloop3,
+               numberingmethod => $numberingmethod,
+               status => $status,
+               biblionumber => $biblionumber,
+               bibliotitle => $bibliotitle,
+               callnumber => $callnumber,
+               notes => $notes,
+               subscriptionid => $subscriptionid,
+               weekarrayjs => $weekarrayjs,
+               weekno => $weekno,
+               hemisphere => $hemisphere,
+               );
+
+       $template->param(
+                               "periodicity$periodicity" => 1,
+                               "dow$dow" => 1,
+                               "numberpattern$numberpattern" => 1,
+                               );
+}
+(my $temp,@budgets) = bookfunds();
+# find default value & set it for the template
+for (my $i=0;$i<=$#budgets;$i++) {
+       if ($budgets[$i]->{'aqbudgetid'} eq $aqbudgetid) {
+               $budgets[$i]->{'selected'}=1;
+       }
+}
+$template->param(budgets => address@hidden,
+               intranetcolorstylesheet => 
C4::Context->preference("intranetcolorstylesheet"),
+               intranetstylesheet => 
C4::Context->preference("intranetstylesheet"),
+               IntranetNav => C4::Context->preference("IntranetNav"),
+               );
+
+if ($op eq 'addsubscription') {
+        my @irregular = $query->param('irregular');
+        my $irregular_count = @irregular;
+        for(my $i =0;$i<$irregular_count;$i++){
+            $irregularity .=$irregular[$i]."|";
+        }
+        $irregularity =~ s/\|$//;
+
+       my $auser = $query->param('user');
+       my $aqbooksellerid = $query->param('aqbooksellerid');
+       my $cost = $query->param('cost');
+       my $aqbudgetid = $query->param('aqbudgetid'); 
+       my $startdate = $query->param('startdate');
+       my $firstacquidate = $query->param('firstacquidate');    
+       my $periodicity = $query->param('periodicity');
+       my $dow = $query->param('dow');
+        # my $irregularity = $query->param('irregularity');
+       my $numberlength = 0;
+       my $weeklength = 0;
+       my $monthlength = 0;
+        my $numberpattern = $query->param('numbering_pattern');
+        my $sublength = $query->param('sublength');
+        my $subtype = $query->param('subtype');
+        if ($subtype eq 'months'){
+           $monthlength = $sublength;
+       } elsif ($subtype eq 'weeks'){
+           $weeklength = $sublength;
+       } else {
+           $numberlength = $sublength;
+       }
+
+       my $add1 = $query->param('add1');
+       my $every1 = $query->param('every1');
+       my $whenmorethan1 = $query->param('whenmorethan1');
+       my $setto1 = $query->param('setto1');
+       my $lastvalue1 = $query->param('lastvalue1');
+       my $add2 = $query->param('add2');
+       my $every2 = $query->param('every2');
+       my $whenmorethan2 = $query->param('whenmorethan2');
+       my $setto2 = $query->param('setto2');
+       my $lastvalue2 = $query->param('lastvalue2');
+       my $add3 = $query->param('add3');
+       my $every3 = $query->param('every3');
+       my $whenmorethan3 = $query->param('whenmorethan3');
+       my $setto3 = $query->param('setto3');
+       my $lastvalue3 = $query->param('lastvalue3');
+       my $numberingmethod = $query->param('numberingmethod');
+       my $status = 1;
+       my $biblionumber = $query->param('biblionumber');
+        my $callnumber = $query->param('callnumber');
+       my $notes = $query->param('notes');
+        my $hemisphere = $query->param('hemisphere') || 1;
+
+       my $subscriptionid = 
old_newsubscription($auser,$aqbooksellerid,$cost,$aqbudgetid,$biblionumber,
+                                       
$startdate,$periodicity,$firstacquidate,$dow,$irregularity,$numberpattern,$numberlength,$weeklength,$monthlength,
+                                       
$add1,$every1,$whenmorethan1,$setto1,$lastvalue1,
+                                       
$add2,$every2,$whenmorethan2,$setto2,$lastvalue2,
+                                       
$add3,$every3,$whenmorethan3,$setto3,$lastvalue3,
+                                       $numberingmethod, $status, $callnumber, 
$notes, $hemisphere
+                               );
+       print 
$query->redirect("/cgi-bin/koha/serials/subscription-detail.pl?subscriptionid=$subscriptionid");
+} else {
+
+        while (@subscription_types) {
+           my $sub_type = shift @subscription_types;
+           my %row = ( 'name' => $sub_type );
+           if ( $sub_on eq $sub_type ) {
+            $row{'selected'} = ' selected';
+           } else {
+            $row{'selected'} = '';
+           }
+           push( @sub_type_data, \%row );
+        }    
+    $template->param(subtype => address@hidden,
+                weekarrayjs => $weekarrayjs,
+                weekno => $weekno,
+       );
+       output_html_with_http_headers $query, $cookie, $template->output;
+}




reply via email to

[Prev in Thread] Current Thread [Next in Thread]