use C4::Search; replace use C4::SearchMarc;
[koha_gimpoz] / opac / opac-user.pl
index 29503f9..188a3bf 100755 (executable)
@@ -3,87 +3,155 @@ use strict;
 require Exporter;
 use CGI;
 
-use C4::Search;       # borrdata
-use C4::Output;       # gettemplate
-use C4::Auth;         # checkauth, getborrowernumber.
+use C4::Auth;
 use C4::Koha;
 use C4::Circulation::Circ2;
 use C4::Reserves2;
+use C4::Members;
+use C4::Interface::CGI::Output;
+use HTML::Template;
+use C4::Date;
+use C4::Letters;
 
 my $query = new CGI;
-
-my ($loggedinuser, $cookie, $sessionID) = checkauth($query);
-
-my $template = gettemplate("opac-user.tmpl", "opac");
+my ($template, $borrowernumber, $cookie) 
+    = get_template_and_user({template_name => "opac-user.tmpl",
+                            query => $query,
+                            type => "opac",
+                            authnotrequired => 0,
+                            flagsrequired => {borrow => 1},
+                            debug => 1,
+                            });
 
 # get borrower information ....
-my $borrowernumber = getborrowernumber($loggedinuser);
 my ($borr, $flags) = getpatroninformation(undef, $borrowernumber);
 
-$borr->{'dateenrolled'} = slashifyDate($borr->{'dateenrolled'});
-$borr->{'expiry'}       = slashifyDate($borr->{'expiry'});
-$borr->{'dateofbirth'}  = slashifyDate($borr->{'dateofbirth'});
+$borr->{'dateenrolled'} = format_date($borr->{'dateenrolled'});
+$borr->{'expiry'}       = format_date($borr->{'expiry'});
+$borr->{'dateofbirth'}  = format_date($borr->{'dateofbirth'});
 $borr->{'ethnicity'}    = fixEthnicity($borr->{'ethnicity'});
 
+if($borr->{'debarred'} || $borr->{'gonenoaddress'} || $borr->{'lost'}){
+       $borr->{'flagged'} =1;
+}
+
 if ($borr->{'amountoutstanding'} > 5) {
     $borr->{'amountoverfive'} = 1;
-} else {
-    $borr->{'amountoverfive'} = 0;
+}
+if (5 >= $borr->{'amountoutstanding'} && $borr->{'amountoutstanding'} > 0 ) {
+    $borr->{'amountoverzero'} = 1;
+}
+if ($borr->{'amountoutstanding'} < 0) {
+    $borr->{'amountlessthanzero'} = 1;
+    $borr->{'amountoutstanding'} = -1*($borr->{'amountoutstanding'});
 }
 
-$borr->{'amountoutstanding'} = sprintf "\$%.02f", $borr->{'amountoutstanding'};
+$borr->{'amountoutstanding'} = sprintf "%.02f", $borr->{'amountoutstanding'};
 
 my @bordat;
 $bordat[0] = $borr;
 
 $template->param(BORROWER_INFO => \@bordat);
+$template->param(borrowernumber => $borrowernumber);
 
 #get issued items ....
 my $issues = getissues($borr);
 
-my $count=0;
+my $count = 0;
+my $overdues_count = 0;
+my @overdues;
 my @issuedat;
 foreach my $key (keys %$issues) {
     my $issue = $issues->{$key};
-    $issue->{'date_due'}  = slashifyDate($issue->{'date_due'});
-    if ($issue->{'overdue'}) {
-       $issue->{'status'} = "OVERDUE";
-    } else {
-       $issue->{'status'} = "Issued";
-    }
-# check for reserves
+    $issue->{'date_due'}  = format_date($issue->{'date_due'});
+
+    # check for reserves
     my ($restype, $res) = CheckReserves($issue->{'itemnumber'});
     if ($restype) {
-       $issue->{'status'} .= "Reserved";
+       $issue->{'reserved'} = 1;
+    }
+
+    my ($numaccts,$accts,$total) = getboracctrecord(undef,$borr);
+    my $charges = 0;
+    foreach my $ac (@$accts) {
+       if ($ac->{'itemnumber'} == $issue->{'itemnumber'}) {
+           $charges += $ac->{'amountoutstanding'} if $ac->{'accounttype'} eq 'F'; 
+           $charges += $ac->{'amountoutstanding'} if $ac->{'accounttype'} eq 'L';
+       } 
+    }
+    $issue->{'charges'} = $charges;
+
+    # get publictype for icon
+    
+    my $publictype = $issue->{'publictype'};
+    $issue->{$publictype} = 1;
+
+    # check if item is renewable
+    my %env;
+    my $status = renewstatus(\%env,$borrowernumber, $issue->{'itemnumber'});
+
+    $issue->{'status'} = $status;
+
+    if ($issue->{'overdue'}) {
+       push @overdues, $issue;
+       $overdues_count++;
+       $issue->{'overdue'} = 1;
+    } else {
+       $issue->{'issued'} = 1;
     }
-    my ($charges, $itemtype) = calc_charges(undef, undef, $issue->{'itemnumber'}, $borrowernumber);
-    $issue->{'charges'} = $charges; 
     push @issuedat, $issue;
     $count++;
-} 
+}
+
+$template->param(ISSUES => \@issuedat);
+$template->param(issues_count => $count);
+
+$template->param(OVERDUES => \@overdues);
+$template->param(overdues_count => $overdues_count);
 
-$template->param(ISSUES => \@issuedat); 
-$template->param(issues_count => $count); 
+my $branches = GetBranches();
 
 # now the reserved items....
 my ($rcount, $reserves) = FindReserves(undef, $borrowernumber);
+foreach my $res (@$reserves) {
+    $res->{'reservedate'}  = format_date($res->{'reservedate'});
+    my $publictype = $res->{'publictype'};
+    $res->{$publictype} = 1;
+    $res->{'waiting'} = 1 if $res->{'found'} eq 'W';
+    $res->{'branch'} = $branches->{$res->{'branchcode'}}->{'branchname'};
+}
 
 $template->param(RESERVES => $reserves);
 $template->param(reserves_count => $rcount);
 
-my $branches = getbranches();
 my @waiting;
 my $wcount = 0;
 foreach my $res (@$reserves) {
     if ($res->{'itemnumber'}) {
+       my $item = getiteminformation('',$res->{'itemnumber'},'');
+       $res->{'holdingbranch'} = $branches->{$item->{'holdingbranch'}}->{'branchname'};
        $res->{'branch'} = $branches->{$res->{'branchcode'}}->{'branchname'};
+       if($res->{'holdingbranch'} eq $res->{'branch'}){
+                       $res->{'atdestination'} = 1;
+               }
        push @waiting, $res;
        $wcount++;
     }
 }
-
 $template->param(WAITING => \@waiting);
-$template->param(waiting_count => $wcount);
 
-$template->param(loggedinuser => $loggedinuser);
-print "Content-Type: text/html\n\n", $template->output; 
+# current alert subscriptions
+warn " B : $borrowernumber";
+my $alerts = getalert($borrowernumber);
+foreach (@$alerts) {
+       $_->{$_->{type}}=1;
+       $_->{relatedto} = findrelatedto($_->{type},$_->{externalid});
+}
+
+$template->param(waiting_count => $wcount,
+                               textmessaging => $borr->{textmessaging},
+                               OpacPasswordChange => C4::Context->preference("OpacPasswordChange"),
+);
+
+output_html_with_http_headers $query, $cookie, $template->output;
+