if ($issue) {
$self->{due_date} = dt_from_string( $issue->date_due, 'sql' )->truncate( to => 'minute' );
my $patron = Koha::Patrons->find( $issue->borrowernumber );
- $self->{patron} = $patron->cardnumber;
+ $self->{borrowernumber} = $patron->borrowernumber;
}
my $biblio = Koha::Biblios->find( $self->{biblionumber} );
my $holds = $biblio->current_holds->unblessed;
sub sip_circulation_status {
my $self = shift;
- if ( $self->{patron} ) {
+ if ( $self->{borrowernumber} ) {
return '04'; # charged
}
elsif ( grep { $_->{itemnumber} == $self->{itemnumber} } @{ $self->{hold_shelf} } ) {
my $count = (defined $self->{pending_queue}) ? scalar @{$self->{pending_queue}} : 0;
my $count2 = (defined $self->{hold_shelf} ) ? scalar @{$self->{hold_shelf} } : 0;
$debug and print STDERR "availability check: pending_queue size $count, hold_shelf size $count2\n";
- if (defined($self->{patron_id})) {
- ($self->{patron_id} eq $for_patron) or return 0;
+ if (defined($self->{borrowernumber})) {
+ ($self->{borrowernumber} eq $for_patron) or return 0;
return ($count ? 0 : 1);
} else { # not checked out
($count2) and return $self->barcode_is_borrowernumber($for_patron, $self->{hold_shelf}[0]->{borrowernumber});
syslog('LOG_DEBUG', "ILS::Transaction::Checkout performing checkout...");
my $shelf = $self->{item}->hold_shelf;
my $barcode = $self->{item}->id;
- my $patron_barcode = $self->{patron}->id;
- my $overridden_duedate; # usually passed as undef to AddIssue
- $debug and warn "do_checkout: patron (" . $patron_barcode . ")";
- my $patron = Koha::Patrons->find( { cardnumber => $patron_barcode } );
- my $borrower = $patron->unblessed;
- $debug and warn "do_checkout borrower: . " . Dumper $borrower;
+ my $patron = Koha::Patrons->find($self->{patron}->{borrowernumber});
+ my $overridden_duedate; # usually passed as undef to AddIssue
+ $debug and warn "do_checkout borrower: . " . $patron->borrowernumber;
my ($issuingimpossible, $needsconfirmation) = _can_we_issue($patron, $barcode,
C4::Context->preference("AllowItemsOnHoldCheckoutSIP")
);
if ($confirmation eq 'RENEW_ISSUE'){
$self->screen_msg("Item already checked out to you: renewing item.");
} elsif ($confirmation eq 'RESERVED' or $confirmation eq 'RESERVE_WAITING') {
- my $x = $self->{item}->available($patron_barcode);
+ my $x = $self->{item}->available($patron->borrowernumber);
if ($x) {
$self->screen_msg("Item was reserved for you.");
} else {
}
my $itemnumber = $self->{item}->{itemnumber};
foreach (@$shelf) {
- $debug and warn "shelf has ($_->{itemnumber} for $_->{borrowernumber}). this is ($itemnumber, $self->{patron}->{borrowernumber})";
+ $debug and warn sprintf( "shelf has (%s for %s). this is (%is, %s)", $_->{itemnumber}, $_->{borrowernumber}, $itemnumber, $patron->borrowernumber );
($_->{itemnumber} eq $itemnumber) or next; # skip it if not this item
- ($_->{borrowernumber} == $self->{patron}->{borrowernumber}) and last;
+ ($_->{borrowernumber} == $patron->borrowernumber) and last;
# if item was waiting for this patron, we're done. AddIssue takes care of the "W" hold.
$debug and warn "Item is on hold shelf for another patron.";
$self->screen_msg("Item is on hold shelf for another patron.");
$noerror = 0;
}
- my ($fee, undef) = GetIssuingCharges($itemnumber, $self->{patron}->{borrowernumber});
+ my ($fee, undef) = GetIssuingCharges($itemnumber, $patron->borrowernumber);
if ( $fee > 0 ) {
$self->{sip_fee_type} = '06';
$self->{fee_amount} = sprintf '%.2f', $fee;
return $self;
}
# can issue
- $debug and warn "do_checkout: calling AddIssue(\$borrower,$barcode, $overridden_duedate, 0)\n"
- # . "w/ \$borrower: " . Dumper($borrower)
+ $debug and warn sprintf("do_checkout: calling AddIssue(%s, %s, %s, 0)\n", $patron->borrowernumber, $barcode, $overridden_duedate)
. "w/ C4::Context->userenv: " . Dumper(C4::Context->userenv);
- my $issue = AddIssue( $borrower, $barcode, $overridden_duedate, 0 );
+ my $issue = AddIssue( $patron->unblessed, $barcode, $overridden_duedate, 0 );
$self->{due} = $self->duedatefromissue($issue, $itemnumber);
$self->ok(1);
sub do_hold {
my $self = shift;
- unless ( $self->{patron} ) {
+ my $patron = Koha::Patrons->find( $self->{patron}->borrowernumber );
+ unless ( $patron ) {
$self->screen_msg('do_hold called with undefined patron');
$self->ok(0);
return $self;
}
- my $patron = Koha::Patrons->find( { cardnumber => $self->{patron}->id } );
- unless ($patron) {
- $self->screen_msg( 'No borrower matches cardnumber "' . $self->{patron}->id . '".' );
- $self->ok(0);
- return $self;
- }
my $item = Koha::Items->find({ barcode => $self->{item}->id });
unless ($item) {
$self->screen_msg( 'No biblio record matches barcode "' . $self->{item}->id . '".' );
sub drop_hold {
my $self = shift;
- unless ($self->{patron}) {
- $self->screen_msg('drop_hold called with undefined patron');
- $self->ok(0);
- return $self;
- }
- my $patron = Koha::Patrons->find( { cardnumber => $self->{patron}->id } );
+ my $patron = Koha::Patrons->find( $self->{patron}->borrowernumber );
unless ($patron) {
- $self->screen_msg('No borrower matches cardnumber "' . $self->{patron}->id . '".');
+ $self->screen_msg('drop_hold called with undefined patron');
$self->ok(0);
return $self;
}
sub change_hold {
my $self = shift;
- unless ($self->{patron}) {
- $self->screen_msg('change_hold called with undefined patron');
- $self->ok(0);
- return $self;
- }
- my $patron = Koha::Patrons->find( { cardnumber => $self->{patron}->id } );
+ my $patron = Koha::Patrons->find( $self->{patron}->borrowernumber );
unless ($patron) {
- $self->screen_msg('No borrower matches cardnumber "' . $self->{patron}->id . '".');
+ $self->screen_msg('change_hold called with undefined patron');
$self->ok(0);
return $self;
}