</div>
<div id="bibliodetails" class="toptabs">
-<ul>
-<li><a href="#holdings">Holdings</a></li>
+<ul>
+ [% IF (SeparateHoldings) %]
+ <li><a href="#holdings">[% LoginBranchname %] holdings</a></li>
+ <li><a href="#otherholdings">Other holdings</a></li>
+ [% ELSE %]
+ <li><a href="#holdings">Holdings</a></li>
+ [% END %]
<li><a href="#description">Descriptions</a></li>
[% IF ( subscriptionsnumber ) %]<li><a href="#subscriptions">Subscriptions</a></li>[% END %]
[% IF ( FRBRizeEditions ) %][% IF ( XISBNS ) %]<li><a href="#editions">Editions</a></li>[% END %][% END %]
[% IF ( LocalCoverImages ) %][% IF ( localimages || CAN_user_tools_upload_local_cover_images ) %]<li><a href="#images">Images</a></li>[% END %][% END %]
</ul>
-<div id="holdings">
-[% IF ( count ) %]
- [% IF ( showncount ) %]
- <table>
+[% BLOCK items_table %]
+ <table>
+ <thead>
<tr>
[% IF ( item_level_itypes ) %]<th>Item type</th>[% END %]
<th>Current location</th>
[% IF ( itemdata_copynumber ) %]<th>Copy no.</th>[% END %]
[% IF materials %]<th>Materials specified</th>[% END %]
[% IF ( itemdata_itemnotes ) %]<th>Public notes</th>[% END %]
- [% IF ( SpineLabelShowPrintOnBibDetails ) %]<th>Spine label</th>[% END %]
- [% IF ( hostrecords ) %]<th>Host records</th>[% END %]
- [% IF ( analyze ) %]<th>Used in</th><th></th>[% END %]
+ [% IF ( SpineLabelShowPrintOnBibDetails ) %]<th>Spine label</th>[% END %]
+ [% IF ( hostrecords ) %]<th>Host records</th>[% END %]
+ [% IF ( analyze ) %]<th>Used in</th><th></th>[% END %]
</tr>
- [% FOREACH itemloo IN itemloop %]
+ </thead>
+ <tbody>
+ [% FOREACH item IN items %]
<tr>
[% IF ( item_level_itypes ) %]
- <td class="itype">
- [% IF !noItemTypeImages && itemloo.imageurl %]
- <img src="[% itemloo.imageurl %]" alt="[% itemloo.description %]" title="[% itemloo.description %]" />
- [% END %]
- [% itemloo.description %]
- </td>
+ <td class="itype">
+ [% IF !noItemTypeImages && item.imageurl %]
+ <img src="[% item.imageurl %]" alt="[% item.description %]" title="[% item.description %]" />
+ [% END %]
+ [% item.description %]
+ </td>
[% END %]
- <td class="location">[% UNLESS ( singlebranchmode ) %][% itemloo.branchname %] [% END %]</td>
- <td class="homebranch">[% itemloo.homebranch %]<span class="shelvingloc">[% itemloo.location %]</span> </td>
- [% IF ( itemdata_ccode ) %]<td>[% itemloo.ccode %]</td>[% END %]
- <td class="itemcallnumber">[% IF ( itemloo.itemcallnumber ) %] [% itemloo.itemcallnumber %][% END %]</td>
+ <td class="location">[% UNLESS ( singlebranchmode ) %][% item.branchname %] [% END %]</td>
+ <td class="homebranch">[% item.homebranch %]<span class="shelvingloc">[% item.location %]</span> </td>
+ [% IF ( itemdata_ccode ) %]<td>[% item.ccode %]</td>[% END %]
+ <td class="itemcallnumber">[% IF ( item.itemcallnumber ) %] [% item.itemcallnumber %][% END %]</td>
<td class="status">
- [% IF ( itemloo.datedue ) %]
- <span class="datedue">Checked out
- [% UNLESS ( itemloo.NOTSAMEBRANCH ) %]
- to <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% itemloo.borrowernumber %]">
- [% IF ( itemloo.hidepatronname ) %]
- [% itemloo.cardnumber %]
- [% ELSE %]
- [% itemloo.firstname %] [% itemloo.surname %]
- [% END %]
- </a>
- [% END %]
- : due [% itemloo.datedue %]
- </span>
- [% ELSIF ( itemloo.transfertwhen ) %]
- In transit from [% itemloo.transfertfrom %],
- to [% itemloo.transfertto %], since [% itemloo.transfertwhen %]
- <!-- FIXME: the "since" clause is redundant w/ lastseen field -->
- [% END %]
+ [% IF ( item.datedue ) %]
+ <span class="datedue">Checked out
+ [% UNLESS ( item.NOTSAMEBRANCH ) %]
+ to <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% item.borrowernumber %]">
+ [% IF ( item.hidepatronname ) %]
+ [% item.cardnumber %]
+ [% ELSE %]
+ [% item.firstname %] [% item.surname %]
+ [% END %]
+ </a>
+ [% END %]
+ : due [% item.datedue %]
+ </span>
+ [% ELSIF ( item.transfertwhen ) %]
+ In transit from [% item.transfertfrom %],
+ to [% item.transfertto %], since [% item.transfertwhen %]
+ <!-- FIXME: the "since" clause is redundant w/ lastseen field -->
+ [% END %]
- [% IF ( itemloo.itemlost ) %]
- [% IF ( itemloo.itemlostloop ) %]
- [% FOREACH itemlostloo IN itemloo.itemlostloop %]
- [% IF ( itemlostloo.selected ) %]
+ [% IF ( item.itemlost ) %]
+ [% IF ( item.itemlostloop ) %]
+ [% FOREACH itemlostloo IN item.itemlostloop %]
+ [% IF ( itemlostloo.selected ) %]
<span class="lost">[% itemlostloo.lib %]</span>
+ [% END %]
+ [% END %]
+ [% ELSE %]
+ <span class="lost">Unavailable (lost or missing)</span>
+ [% END %]
[% END %]
- [% END %]
- [% ELSE %]
- <span class="lost">Unavailable (lost or missing)</span>
- [% END %]
- [% END %]
- [% IF ( itemloo.wthdrawn ) %]
- <span class="wdn">Withdrawn</span>
- [% END %]
+ [% IF ( item.wthdrawn ) %]
+ <span class="wdn">Withdrawn</span>
+ [% END %]
- [% IF ( itemloo.damaged ) %]
- [% IF ( itemloo.itemdamagedloop ) %]
- [% FOREACH itemdamagedloo IN itemloo.itemdamagedloop %]
- [% IF ( itemdamagedloo.selected ) %]
+ [% IF ( item.damaged ) %]
+ [% IF ( item.itemdamagedloop ) %]
+ [% FOREACH itemdamagedloo IN item.itemdamagedloop %]
+ [% IF ( itemdamagedloo.selected ) %]
<span class="dmg">[% itemdamagedloo.lib %]</span>
+ [% END %]
+ [% END %]
+ [% ELSE %]
+ <span class="dmg">Damaged</span>
+ [% END %]
[% END %]
+
+ [% IF ( item.itemnotforloan ) %]
+ Not for loan
+ [% IF ( item.notforloanvalue ) %]
+ ([% item.notforloanvalue %])
+ [% END %]
[% END %]
- [% ELSE %]
- <span class="dmg">Damaged</span>
- [% END %]
- [% END %]
- [% IF ( itemloo.itemnotforloan ) %]
- Not for loan
- [% IF ( itemloo.notforloanvalue ) %]
- ([% itemloo.notforloanvalue %])
- [% END %]
- [% END %]
+ [% IF ( item.reservedate ) %]
+ [% IF ( item.waitingdate ) %]
+ Waiting
+ [% ELSE %]
+ Item-level hold
+ [% END %]
+ [% IF ( canreservefromotherbranches ) %]
+ for <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% item.ReservedForBorrowernumber %]">
+ [% IF ( item.hidepatronname ) %]
+ [% item.Reservedcardnumber %]
+ [% ELSE %]
+ [% item.ReservedForFirstname %] [% item.ReservedForSurname %]
+ [% END %]
+ </a>
+ [% END %]
+ [% IF ( item.waitingdate ) %]
+ at[% ELSE %]for delivery at
+ [% END %]
+ [% item.ExpectedAtLibrary %]
+ [% IF ( item.waitingdate ) %]
+ since [% item.waitingdate %]
+ [% ELSE %]
+ [% IF ( item.reservedate ) %]
+ (placed [% item.reservedate %])
+ [% END %]
+ [% END %]
+ [% END %]
+ [% UNLESS ( item.itemnotforloan or item.onloan or item.itemlost or item.wthdrawn or item.damaged or item.transfertwhen or item.reservedate ) %]
+ Available
+ [% END %]
-
- [% IF ( itemloo.reservedate ) %]
- [% IF ( itemloo.waitingdate ) %]
- Waiting
- [% ELSE %]
- Item-level hold
- [% END %]
- [% IF ( canreservefromotherbranches ) %]for <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% itemloo.ReservedForBorrowernumber %]">
- [% IF ( itemloo.hidepatronname ) %]
- [% itemloo.Reservedcardnumber %]
- [% ELSE %]
- [% itemloo.ReservedForFirstname %] [% itemloo.ReservedForSurname %]
- [% END %]
- </a>[% END %]
- [% IF ( itemloo.waitingdate ) %]
- at[% ELSE %]for delivery at
- [% END %] [% itemloo.ExpectedAtLibrary %]
- [% IF ( itemloo.waitingdate ) %]
- since [% itemloo.waitingdate %]
- [% ELSE %]
- [% IF ( itemloo.reservedate ) %](placed [% itemloo.reservedate %])[% END %]
- [% END %]
- [% END %]
- [% UNLESS ( itemloo.itemnotforloan ) %][% UNLESS ( itemloo.onloan ) %][% UNLESS ( itemloo.itemlost ) %][% UNLESS ( itemloo.wthdrawn ) %][% UNLESS ( itemloo.damaged ) %][% UNLESS ( itemloo.transfertwhen ) %][% UNLESS ( itemloo.reservedate ) %]
- Available
- [% END %][% END %][% END %][% END %][% END %][% END %][% END %]
+ [% IF ( item.restricted ) %]
+ <span class="restricted">([% item.restricted %])</span>
+ [% END %]
- [% IF ( itemloo.restricted ) %]<span class="restricted">([% itemloo.restricted %])</span>[% END %]
-
</td>
- <td class="datelastseen">[% itemloo.datelastseen %]</td>
- <td><a href="/cgi-bin/koha/catalogue/moredetail.pl?type=[% itemloo.type %]&itemnumber=[% itemloo.itemnumber %]&biblionumber=[% itemloo.biblionumber %]&bi=[% itemloo.biblioitemnumber %]#item[% itemloo.itemnumber %]">[% itemloo.barcode %]</a></td>
- [% IF ( volinfo ) %] <td class="enumchron">
- [% IF ( itemdata_enumchron ) %]
- [% IF ( itemloo.enumchron ) %]
- [% itemloo.enumchron %][% IF ( itemloo.serialseq ) %] -- [% END %]
- [% END %]
- [% itemloo.serialseq %][% IF ( itemloo.publisheddate ) %] ([% itemloo.publisheddate %])[% END %]
- [% END %]
- </td>[% END %]
- [% IF ( itemdata_uri ) %]
- <td class="uri"><a href="[% itemloo.uri %]">[% itemloo.uri %]</a></td>
- [% END %]
- [% IF ( itemdata_copynumber ) %]
- <td class="copynumber">[% itemloo.copynumber %]</td>
- [% END %]
- [% IF materials %]
- <td class="materials"> [% itemloo.materials %] </td>
- [% END %]
- [% IF ( itemdata_itemnotes ) %]<td><div class="itemnotes">[% itemloo.itemnotes %]</div></td>[% END %]
- [% IF ( SpineLabelShowPrintOnBibDetails ) %]
- <td><a href="/cgi-bin/koha/labels/spinelabel-print.pl?barcode=[% itemloo.barcode %]" >Print label</a></td>
- [% END %]
- [% IF ( hostrecords ) %]
- <td>[% IF ( itemloo.hostbiblionumber) %]<a href="/cgi-bin/koha/catalogue/detail.pl?biblionumber=[% itemloo.hostbiblionumber %]" >[% itemloo.hosttitle %]</a>[% END %]</td>
- [% END %]
- [% IF ( analyze ) %]<td>
- [% IF ( itemloo.countanalytics ) %]
- <a href="/cgi-bin/koha/catalogue/search.pl?idx=hi&q=[% itemloo.itemnumber %]">[% itemloo.countanalytics %] analytics</a>
- [% END %]</td>
- [% END %]
- [% IF ( analyze ) %]
- <td><a href="/cgi-bin/koha/cataloguing/addbiblio.pl?hostbiblionumber=[% itemloo.biblionumber %]&hostitemnumber=[% itemloo.itemnumber %]">Create analytics</a></td>
- [% END %]
+ <td class="datelastseen">[% item.datelastseen %]</td>
+ <td><a href="/cgi-bin/koha/catalogue/moredetail.pl?type=[% item.type %]&itemnumber=[% item.itemnumber %]&biblionumber=[% item.biblionumber %]&bi=[% item.biblioitemnumber %]#item[% item.itemnumber %]">[% item.barcode %]</a></td>
+ [% IF ( volinfo ) %]
+ <td class="enumchron">
+ [% IF ( itemdata_enumchron ) %]
+ [% IF ( item.enumchron ) %]
+ [% item.enumchron %]
+ [% IF ( item.serialseq ) %] -- [% END %]
+ [% END %]
+ [% item.serialseq %]
+ [% IF ( item.publisheddate ) %] ([% item.publisheddate %])[% END %]
+ [% END %]
+ </td>
+ [% END %]
+ [% IF ( itemdata_uri ) %]
+ <td class="uri"><a href="[% item.uri %]">[% item.uri %]</a></td>
+ [% END %]
+ [% IF ( itemdata_copynumber ) %]
+ <td class="copynumber">[% item.copynumber %]</td>
+ [% END %]
+ [% IF materials %]
+ <td class="materials"> [% item.materials %] </td>
+ [% END %]
+ [% IF ( itemdata_itemnotes ) %]
+ <td><div class="itemnotes">[% item.itemnotes %]</div></td>
+ [% END %]
+ [% IF ( SpineLabelShowPrintOnBibDetails ) %]
+ <td><a href="/cgi-bin/koha/labels/spinelabel-print.pl?barcode=[% item.barcode %]" >Print label</a></td>
+ [% END %]
+ [% IF ( hostrecords ) %]
+ <td>[% IF ( item.hostbiblionumber) %]<a href="/cgi-bin/koha/catalogue/detail.pl?biblionumber=[% item.hostbiblionumber %]" >[% item.hosttitle %]</a>[% END %]</td>
+ [% END %]
+ [% IF ( analyze ) %]
+ <td>
+ [% IF ( item.countanalytics ) %]
+ <a href="/cgi-bin/koha/catalogue/search.pl?idx=hi&q=[% item.itemnumber %]">[% item.countanalytics %] analytics</a>
+ [% END %]
+ </td>
+ [% END %]
+ [% IF ( analyze ) %]
+ <td><a href="/cgi-bin/koha/cataloguing/addbiblio.pl?hostbiblionumber=[% item.biblionumber %]&hostitemnumber=[% item.itemnumber %]">Create analytics</a></td>
+ [% END %]
</tr>
[% END %]
- </table>
+ </tbody>
+ </table>
+[% END %][%# end of block items_table %]
+
+<div id="holdings">
+[% IF ( count ) %]
+ [% IF ( showncount ) %]
+ [% PROCESS items_table items=itemloop %]
[% END %]
[% IF ( hiddencount ) %]
<p><a href="/cgi-bin/koha/catalogue/detail.pl?biblionumber=[% biblionumber %]&showallitems=1">Show all items ([% hiddencount %] hidden)</a>
[% END %]
[% END %]
</div>
+
+[% IF (SeparateHoldings) %]
+ <div id="otherholdings">
+ [% IF (otheritemloop.size) %]
+ [% PROCESS items_table items=otheritemloop %]
+ [% ELSE %]
+ No other items.
+ [% END %]
+ </div>
+[% END %]
<div id="description">
<div class="content_set">
$dat->{'count'} = scalar(@items);
-# If there is a lot of items, and the user has not decided
-# to view them all yet, we first warn him
-# TODO: The limit of 50 could be a syspref
-my $viewallitems = $query->param('viewallitems');
-if ($dat->{'count'} >= 50 && !$viewallitems) {
- $template->param('lotsofitems' => 1);
-}
my $biblio_authorised_value_images = C4::Items::get_authorised_value_images( C4::Biblio::get_biblio_authorised_values( $biblionumber, $record ) );
my $norequests = 1;
my $branches = GetBranches();
my %itemfields;
+my (@itemloop, @otheritemloop);
+my $currentbranch = C4::Context->userenv ? C4::Context->userenv->{branch} : undef;
+if ($currentbranch and C4::Context->preference('OpacSeparateHoldings')) {
+ $template->param(SeparateHoldings => 1);
+}
for my $itm (@items) {
$itm->{holds_count} = $item_reserves{ $itm->{itemnumber} };
$itm->{priority} = $priority{ $itm->{itemnumber} };
$itm->{transfertfrom} = $branches->{$transfertfrom}{branchname};
$itm->{transfertto} = $branches->{$transfertto}{branchname};
}
+ my $homebranch = $itm->{homebranch};
+ if ($currentbranch and C4::Context->preference('OpacSeparateHoldings')) {
+ if ($homebranch and $homebranch eq $currentbranch) {
+ push @itemloop, $itm;
+ } else {
+ push @otheritemloop, $itm;
+ }
+ } else {
+ push @itemloop, $itm;
+ }
+}
+
+# If there is a lot of items, and the user has not decided
+# to view them all yet, we first warn him
+# TODO: The limit of 50 could be a syspref
+my $viewallitems = $query->param('viewallitems');
+if (scalar(@itemloop) >= 50 && !$viewallitems) {
+ $template->param('lotsofitems' => 1);
}
## get notes and subjects from MARC record
}
$template->param(
- ITEM_RESULTS => \@items,
+ itemloop => \@itemloop,
+ otheritemloop => \@otheritemloop,
subscriptionsnumber => $subscriptionsnumber,
biblionumber => $biblionumber,
subscriptions => \@subs,
? 'subscriptions' :
$opac_serial_default eq 'serialcollection' && @serialcollections > 0
? 'serialcollection' :
- $opac_serial_default eq 'holdings' && $dat->{'count'} > 0
+ $opac_serial_default eq 'holdings' && scalar (@itemloop) > 0
? 'holdings' :
$subscriptionsnumber
? 'subscriptions' :