X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=C4%2FCategory.pm;h=255db2b02495c06168ab9db468b9692e5df66ca7;hb=5d6c092921919526ade501facb1220f8a108a08f;hp=b81e88f4a8b4ff3d58e0844461224591b23954f8;hpb=aa9b4d92cdfc9147f4da4033f4cbc0245f0ac9d1;p=koha_fer diff --git a/C4/Category.pm b/C4/Category.pm index b81e88f4a8..255db2b024 100644 --- a/C4/Category.pm +++ b/C4/Category.pm @@ -1,5 +1,8 @@ package C4::Category; +# Copyright 2009 Liblime +# Parts Copyright 2011 Tamil +# # This file is part of Koha. # # Koha is free software; you can redistribute it and/or modify it under the @@ -11,9 +14,9 @@ package C4::Category; # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR # A PARTICULAR PURPOSE. See the GNU General Public License for more details. # -# You should have received a copy of the GNU General Public License along with -# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place, -# Suite 330, Boston, MA 02111-1307 USA +# You should have received a copy of the GNU General Public License along +# with Koha; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. use strict; use warnings; @@ -71,14 +74,24 @@ C. =cut sub all { - my ($class) = @_; + my ( $class ) = @_; + my $branch_limit = C4::Context->userenv ? C4::Context->userenv->{"branch"} : ""; my $dbh = C4::Context->dbh; - return map { $class->new($_) } @{$dbh->selectall_arrayref( - # The categories table is small enough for - # `SELECT *` to be harmless. - "SELECT * FROM categories ORDER BY description", - { Slice => {} }, - )}; + # The categories table is small enough for + # `SELECT *` to be harmless. + my $query = "SELECT categories.* FROM categories"; + $query .= qq{ + LEFT JOIN categories_branches ON categories_branches.categorycode = categories.categorycode + WHERE categories_branches.branchcode = ? OR categories_branches.branchcode IS NULL + } if $branch_limit; + $query .= " ORDER BY description"; + return map { $class->new($_) } @{ + $dbh->selectall_arrayref( + $query, + { Slice => {} }, + $branch_limit ? $branch_limit : () + ) + }; }