1 package Koha::Libraries;
3 # Copyright 2015 Koha Development team
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 3 of the License, or (at your option) any later
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License along
17 # with Koha; if not, write to the Free Software Foundation, Inc.,
18 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
28 use Koha::Item::Transfer::Limits;
33 use base qw(Koha::Objects);
37 Koha::Libraries - Koha Library Object set class
45 =head3 pickup_locations
47 Returns available pickup locations (Koha::Library objects) for
50 C. none of the above, simply all libraries with pickup_location => 1
52 This method determines the pickup location by two factors:
53 1. is the library configured as pickup location
54 2. can a specific item / at least one of the items of a biblio be transferred
58 item # Koha::Item object / itemnumber, find pickup locations for item
59 biblio # Koha::Biblio object / biblionumber, find pickup locations for biblio
61 If no parameters are given, all libraries with pickup_location => 1 are returned.
65 sub pickup_locations {
66 my ($self, $params) = @_;
68 my $item = $params->{'item'};
69 my $biblio = $params->{'biblio'};
70 my $patron = $params->{'patron'};
72 if ($biblio && $item) {
73 Koha::Exceptions::BadParameter->throw(
74 error => "Koha::Libraries->pickup_locations takes either 'biblio' or "
75 ." 'item' as parameter, but not both."
78 unless (! defined $patron || ref($patron) eq 'Koha::Patron') {
79 $patron = Koha::Patrons->find($patron);
82 # Select libraries that are configured as pickup locations
83 my $libraries = $self->search({
86 order_by => ['branchname']
89 return $libraries unless $item or $biblio;
91 unless (ref($item) eq 'Koha::Item') {
92 $item = Koha::Items->find($item);
93 return $libraries unless $item;
95 return $item->pickup_locations( {patron => $patron} );
97 unless (ref($biblio) eq 'Koha::Biblio') {
98 $biblio = Koha::Biblios->find($biblio);
99 return $libraries unless $biblio;
101 return $biblio->pickup_locations( {patron => $patron} );
105 =head3 search_filtered
109 sub search_filtered {
110 my ( $self, $params, $attributes ) = @_;
113 my $userenv = C4::Context->userenv;
114 if ( $userenv and $userenv->{number} ) {
115 my $only_from_group = $params->{only_from_group};
116 if ( $only_from_group ) {
117 my $logged_in_user = Koha::Patrons->find( $userenv->{number} );
118 my @branchcodes = $logged_in_user->libraries_where_can_see_patrons;
119 $params->{branchcode} = { -in => \@branchcodes } if @branchcodes;
121 if ( C4::Context::only_my_library ) {
122 $params->{branchcode} = C4::Context->userenv->{branch};
126 delete $params->{only_from_group};
127 return $self->SUPER::search( $params, $attributes );
139 return 'Koha::Library';