[Koha-patches] [PATCH] Perltidy of C4/VirtualShelves/Page.pm

Owen Leonard oleonard at myacpl.org
Thu Feb 11 20:25:20 CET 2010


---
 C4/VirtualShelves/Page.pm |  619 +++++++++++++++++++++++----------------------
 1 files changed, 316 insertions(+), 303 deletions(-)

diff --git a/C4/VirtualShelves/Page.pm b/C4/VirtualShelves/Page.pm
index 658b9ac..14f9816 100644
--- a/C4/VirtualShelves/Page.pm
+++ b/C4/VirtualShelves/Page.pm
@@ -38,328 +38,341 @@ use C4::Csv;
 use vars qw($debug @EXPORT @ISA $VERSION);
 
 BEGIN {
-	$VERSION = 1.01;
-	@ISA = qw(Exporter);
-	@EXPORT = qw(&shelfpage);
-    $debug = $ENV{DEBUG} || 0;
+    $VERSION = 1.01;
+    @ISA     = qw(Exporter);
+    @EXPORT  = qw(&shelfpage);
+    $debug   = $ENV{DEBUG} || 0;
 }
 
 our %pages = (
-	intranet => {
-		redirect=>'/cgi-bin/koha/virtualshelves/shelves.pl',
-	},
-	opac => {
-		redirect=>'/cgi-bin/koha/opac-shelves.pl',
-	},
+    intranet => { redirect => '/cgi-bin/koha/virtualshelves/shelves.pl', },
+    opac     => { redirect => '/cgi-bin/koha/opac-shelves.pl', },
 );
 
 sub shelfpage ($$$$$) {
-	my ($type, $query, $template, $loggedinuser, $cookie ) = @_;
-	($pages{$type}) or $type = 'opac';
-	$query or die "No query";
-	$template or die "No template";
-	$template->param( { loggedinuser => $loggedinuser } );
-	my @paramsloop;
-	my $totitems;
-	my $shelfoff = ($query->param('shelfoff') ? $query->param('shelfoff') : 1);
-	my $itemoff = ($query->param('itemoff') ? $query->param('itemoff') : 1);
-	my $displaymode = ($query->param('display') ? $query->param('display') : 'publicshelves');
-	my ($shelflimit, $shelfoffset, $shelveslimit, $shelvesoffset);
-	# FIXME: These limits should not be hardcoded...
-	$shelflimit = 20;	# Limits number of items returned for a given query
-	$shelfoffset = ($itemoff - 1) * 20;		# Sets the offset to begin retrieving items at
-	$shelveslimit = 20;	# Limits number of shelves returned for a given query (row_count)
-	$shelvesoffset = ($shelfoff - 1) * 20;		# Sets the offset to begin retrieving shelves at (offset)
-	# getting the Shelves list
-	my $category = (($displaymode eq 'privateshelves') ? 1 : 2);
-	my ($shelflist, $totshelves) = GetShelves( $category, $shelveslimit, $shelvesoffset, $loggedinuser );
-	#Get a list of private shelves for possible deletion. Only do this when we've defaulted to public shelves
-    my ($privshelflist, $privtotshelves); 
-    if ($category == 2) {
-        ($privshelflist, $privtotshelves) = GetShelves( 1, $shelveslimit, $shelvesoffset, $loggedinuser );
+    my ( $type, $query, $template, $loggedinuser, $cookie ) = @_;
+    ( $pages{$type} ) or $type = 'opac';
+    $query            or die "No query";
+    $template         or die "No template";
+    $template->param( { loggedinuser => $loggedinuser } );
+    my @paramsloop;
+    my $totitems;
+    my $shelfoff    = ( $query->param('shelfoff') ? $query->param('shelfoff') : 1 );
+    my $itemoff     = ( $query->param('itemoff')  ? $query->param('itemoff')  : 1 );
+    my $displaymode = ( $query->param('display')  ? $query->param('display')  : 'publicshelves' );
+    my ( $shelflimit, $shelfoffset, $shelveslimit, $shelvesoffset );
+
+    # FIXME: These limits should not be hardcoded...
+    $shelflimit    = 20;                        # Limits number of items returned for a given query
+    $shelfoffset   = ( $itemoff - 1 ) * 20;     # Sets the offset to begin retrieving items at
+    $shelveslimit  = 20;                        # Limits number of shelves returned for a given query (row_count)
+    $shelvesoffset = ( $shelfoff - 1 ) * 20;    # Sets the offset to begin retrieving shelves at (offset)
+                                                # getting the Shelves list
+    my $category = ( ( $displaymode eq 'privateshelves' ) ? 1 : 2 );
+    my ( $shelflist, $totshelves ) = GetShelves( $category, $shelveslimit, $shelvesoffset, $loggedinuser );
+
+    #Get a list of private shelves for possible deletion. Only do this when we've defaulted to public shelves
+    my ( $privshelflist, $privtotshelves );
+    if ( $category == 2 ) {
+        ( $privshelflist, $privtotshelves ) = GetShelves( 1, $shelveslimit, $shelvesoffset, $loggedinuser );
+    }
+    my $op = $query->param('op');
+
+    #    my $imgdir = getitemtypeimagesrc();
+    #    my $itemtypes = GetItemTypes();
+
+    # the format of this is unindented for ease of diff comparison to the old script
+    # Note: do not mistake the assignment statements below for comparisons!
+
+    if ( $query->param('modifyshelfcontents') ) {
+        my ( $shelfnumber, $barcode, $item, $biblio );
+        if ( $shelfnumber = $query->param('viewshelf') ) {
+            if ( ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' ) ) {
+                if ( $barcode = $query->param('addbarcode') ) {
+                    if ( $item = GetItem( 0, $barcode ) ) {
+                        $biblio = GetBiblioFromItemNumber( $item->{'itemnumber'} );
+                        AddToShelf( $biblio->{'biblionumber'}, $shelfnumber )
+                          or push @paramsloop, { duplicatebiblio => $barcode };
+                    } else {
+                        push @paramsloop, { failgetitem => $barcode };
+                    }
+                } else {
+                    ( grep { /REM-(\d+)/ } $query->param ) or push @paramsloop, { nobarcode => 1 };
+                    foreach ( $query->param ) {
+                        /REM-(\d+)/ or next;
+                        $debug and warn "SHELVES: user $loggedinuser removing item $1 from shelf $shelfnumber";
+                        DelFromShelf( $1, $shelfnumber );    # $1 is biblionumber
+                    }
+                }
+            } else {
+                push @paramsloop, { nopermission => $shelfnumber };
+            }
+        } else {
+            push @paramsloop, { noshelfnumber => 1 };
+        }
     }
-	my $op = $query->param('op');
-#    my $imgdir = getitemtypeimagesrc();
-#    my $itemtypes = GetItemTypes();
-    
-# the format of this is unindented for ease of diff comparison to the old script
-# Note: do not mistake the assignment statements below for comparisons!
-
-if ( $query->param('modifyshelfcontents') ) {
-	my ($shelfnumber,$barcode,$item,$biblio);
-    if ($shelfnumber = $query->param('viewshelf')) {
-    	if (ShelfPossibleAction($loggedinuser, $shelfnumber, 'manage')) {
-    		if ($barcode = $query->param('addbarcode')) {
-    			if ($item = GetItem( 0, $barcode )) {
-    				$biblio = GetBiblioFromItemNumber($item->{'itemnumber'});
-        			AddToShelf($biblio->{'biblionumber'}, $shelfnumber) or 
-						push @paramsloop, {duplicatebiblio=>$barcode};
-				} else { push @paramsloop, {failgetitem=>$barcode}; }
-        	} else { 
-				(grep {/REM-(\d+)/} $query->param) or push @paramsloop, {nobarcode=>1};
-        		foreach ($query->param) {
-					/REM-(\d+)/ or next;
-					$debug and warn 
-						"SHELVES: user $loggedinuser removing item $1 from shelf $shelfnumber";
-					DelFromShelf($1, $shelfnumber);	 # $1 is biblionumber
-				}
-			}
-		} else { push @paramsloop, {nopermission=>$shelfnumber}; }
-    } else { push @paramsloop, {noshelfnumber=>1}; }
-}
-
-my $showadd = 1;
-# set the default tab, etc. (for OPAC)
-my $shelf_type = ($query->param('display') ? $query->param('display') : 'publicshelves');
-if (defined $shelf_type) {
-	if ($shelf_type eq 'privateshelves')  {
-		$template->param(showprivateshelves => 1);
-	} elsif ($shelf_type eq 'publicshelves') {
-		$template->param(showpublicshelves => 1);
-		$showadd = 0;
-	} else {
-		$debug and warn "Invalid 'display' param ($shelf_type)";
-	}
-} elsif ($loggedinuser == -1) {
-	$template->param(showpublicshelves => 1);
-} else {
-	$template->param(showprivateshelves => 1);
-}
 
-my($okmanage, $okview);
-my $shelfnumber = $query->param('shelfnumber') || $query->param('viewshelf');
-if ($shelfnumber) {
-	$okmanage = ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' );
-	$okview   = ShelfPossibleAction( $loggedinuser, $shelfnumber, 'view' );
-}
+    my $showadd = 1;
+
+    # set the default tab, etc. (for OPAC)
+    my $shelf_type = ( $query->param('display') ? $query->param('display') : 'publicshelves' );
+    if ( defined $shelf_type ) {
+        if ( $shelf_type eq 'privateshelves' ) {
+            $template->param( showprivateshelves => 1 );
+        } elsif ( $shelf_type eq 'publicshelves' ) {
+            $template->param( showpublicshelves => 1 );
+            $showadd = 0;
+        } else {
+            $debug and warn "Invalid 'display' param ($shelf_type)";
+        }
+    } elsif ( $loggedinuser == -1 ) {
+        $template->param( showpublicshelves => 1 );
+    } else {
+        $template->param( showprivateshelves => 1 );
+    }
 
-my $delflag = 0;
-
-SWITCH: {
-	if ( $op ) {
-		unless ($okmanage) {
-			push @paramsloop, {nopermission=>$shelfnumber};
-			last SWITCH;
-		}
-		if ( $op eq 'modifsave' ) {
-			my $shelf = {
-    			'shelfname'		=> $query->param('shelfname'),
-				'category'		=> $query->param('category'),
-				'sortfield'		=> $query->param('sortfield'),
-			};
-
-			ModShelf( $shelfnumber, $shelf );
-
-		} elsif ( $op eq 'modif' ) {
-			my ( $shelfnumber2, $shelfname, $owner, $category, $sortfield ) =GetShelf( $shelfnumber );
-			my $member = GetMember('borrowernumber'=>$owner);
-			my $ownername = defined($member) ? $member->{firstname} . " " . $member->{surname} : '';
-			$template->param(
-				edit                => 1,
-				shelfnumber         => $shelfnumber2,
-				shelfname           => $shelfname,
-				owner               => $owner,
-				ownername			=> $ownername,
-				"category$category"	=> 1,
-				category			=> $category,
-				"sort_$sortfield"   => 1,
-			);
-		}
-		last SWITCH;
-	}
-    if ($shelfnumber = $query->param('viewshelf') ) {
-        #check that the user can view the shelf
-		if ( ShelfPossibleAction( $loggedinuser, $shelfnumber, 'view' ) ) {
-			my $items;
-			my $authorsort;
-			my $yearsort;
-	                my $sortfield = ($query->param('sortfield') ? $query->param('sortfield') : 'title');
-			if ($sortfield eq 'author') {
-				$authorsort = 'author';
-			}
-			if ($sortfield eq 'year'){
-				$yearsort = 'year';
-			}
-			($items, $totitems) = GetShelfContents($shelfnumber, $shelflimit, $shelfoffset);
-			for my $this_item (@$items) {
-				my $record = GetMarcBiblio($this_item->{'biblionumber'});
-				# the virtualshelfcontents table does not store these columns nor are they retrieved from the items
-				# and itemtypes tables, so I'm commenting them out for now to quiet the log -crn
-				#$this_item->{imageurl} = $imgdir."/".$itemtypes->{ $this_item->{itemtype}  }->{'imageurl'};
-				#$this_item->{'description'} = $itemtypes->{ $this_item->{itemtype} }->{'description'};
-				$this_item->{'dateadded'} = format_date($this_item->{'dateadded'});
-                $this_item->{'imageurl'} = getitemtypeinfo($this_item->{'itemtype'})->{'imageurl'};
-                $this_item->{'coins'} = GetCOinSBiblio($this_item->{'biblionumber'});
-				$this_item->{'subtitle'} = C4::Biblio::get_koha_field_from_marc('bibliosubtitle', 'subtitle', $record, '');
-				
-				# Getting items infos for location display
-				my @items_infos = &GetItemsInfo($this_item->{'biblionumber'}, $type);
-				$this_item->{'ITEM_RESULTS'} = \@items_infos;
-
-			}
-			push @paramsloop, {display => 'privateshelves'} if $category == 1;
-			$showadd = 1;
-			my $i = 0;
-			my $manageshelf = ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' );
-			$template->param(
-				shelfname   => $shelflist->{$shelfnumber}->{'shelfname'} || $privshelflist->{$shelfnumber}->{'shelfname'},
-				shelfnumber => $shelfnumber,
-				viewshelf   => $shelfnumber,
-				authorsort   => $authorsort,
-				yearsort => $yearsort,
-				manageshelf => $manageshelf,
-				itemsloop => $items,
-			);
-		} else { push @paramsloop, {nopermission=>$shelfnumber} };
-        last SWITCH;
+    my ( $okmanage, $okview );
+    my $shelfnumber = $query->param('shelfnumber') || $query->param('viewshelf');
+    if ($shelfnumber) {
+        $okmanage = ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' );
+        $okview   = ShelfPossibleAction( $loggedinuser, $shelfnumber, 'view' );
     }
-    if ( $query->param('shelves') ) {
-		my $stay = 1;
-        if (my $newshelf = $query->param('addshelf')) {
-			# note: a user can always add a new shelf
-            my $shelfnumber = AddShelf(
-                $newshelf,
-                $query->param('owner'),
-                $query->param('category'),
-                $query->param('sortfield')
-            );
-			$stay = 1;
-            if ( $shelfnumber == -1 ) {    #shelf already exists.
-				$showadd = 1;
-				push @paramsloop, { already => $newshelf };
-                $template->param(shelfnumber => $shelfnumber);
+
+    my $delflag = 0;
+
+  SWITCH: {
+        if ($op) {
+            unless ($okmanage) {
+                push @paramsloop, { nopermission => $shelfnumber };
+                last SWITCH;
+            }
+            if ( $op eq 'modifsave' ) {
+                my $shelf = {
+                    'shelfname' => $query->param('shelfname'),
+                    'category'  => $query->param('category'),
+                    'sortfield' => $query->param('sortfield'),
+                };
+
+                ModShelf( $shelfnumber, $shelf );
+
+            } elsif ( $op eq 'modif' ) {
+                my ( $shelfnumber2, $shelfname, $owner, $category, $sortfield ) = GetShelf($shelfnumber);
+                my $member = GetMember( 'borrowernumber' => $owner );
+                my $ownername = defined($member) ? $member->{firstname} . " " . $member->{surname} : '';
+                $template->param(
+                    edit                => 1,
+                    shelfnumber         => $shelfnumber2,
+                    shelfname           => $shelfname,
+                    owner               => $owner,
+                    ownername           => $ownername,
+                    "category$category" => 1,
+                    category            => $category,
+                    "sort_$sortfield"   => 1,
+                );
+            }
+            last SWITCH;
+        }
+        if ( $shelfnumber = $query->param('viewshelf') ) {
+
+            #check that the user can view the shelf
+            if ( ShelfPossibleAction( $loggedinuser, $shelfnumber, 'view' ) ) {
+                my $items;
+                my $authorsort;
+                my $yearsort;
+                my $sortfield = ( $query->param('sortfield') ? $query->param('sortfield') : 'title' );
+                if ( $sortfield eq 'author' ) {
+                    $authorsort = 'author';
+                }
+                if ( $sortfield eq 'year' ) {
+                    $yearsort = 'year';
+                }
+                ( $items, $totitems ) = GetShelfContents( $shelfnumber, $shelflimit, $shelfoffset );
+                for my $this_item (@$items) {
+                    my $record = GetMarcBiblio( $this_item->{'biblionumber'} );
+
+                    # the virtualshelfcontents table does not store these columns nor are they retrieved from the items
+                    # and itemtypes tables, so I'm commenting them out for now to quiet the log -crn
+                    #$this_item->{imageurl} = $imgdir."/".$itemtypes->{ $this_item->{itemtype}  }->{'imageurl'};
+                    #$this_item->{'description'} = $itemtypes->{ $this_item->{itemtype} }->{'description'};
+                    $this_item->{'dateadded'} = format_date( $this_item->{'dateadded'} );
+                    $this_item->{'imageurl'}  = getitemtypeinfo( $this_item->{'itemtype'} )->{'imageurl'};
+                    $this_item->{'coins'}     = GetCOinSBiblio( $this_item->{'biblionumber'} );
+                    $this_item->{'subtitle'}  = C4::Biblio::get_koha_field_from_marc( 'bibliosubtitle', 'subtitle', $record, '' );
+
+                    # Getting items infos for location display
+                    my @items_infos = &GetItemsInfo( $this_item->{'biblionumber'}, $type );
+                    $this_item->{'ITEM_RESULTS'} = \@items_infos;
+
+                }
+                push @paramsloop, { display => 'privateshelves' } if $category == 1;
+                $showadd = 1;
+                my $i = 0;
+                my $manageshelf = ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' );
+                $template->param(
+                    shelfname => $shelflist->{$shelfnumber}->{'shelfname'} || $privshelflist->{$shelfnumber}->{'shelfname'},
+                    shelfnumber => $shelfnumber,
+                    viewshelf   => $shelfnumber,
+                    authorsort  => $authorsort,
+                    yearsort    => $yearsort,
+                    manageshelf => $manageshelf,
+                    itemsloop   => $items,
+                );
             } else {
-            	print $query->redirect($pages{$type}->{redirect} . "?viewshelf=$shelfnumber");
-            	exit;
-			}
+                push @paramsloop, { nopermission => $shelfnumber };
+            }
+            last SWITCH;
         }
-		foreach ($query->param()) {
-			/DEL-(\d+)/ or next;
-			$delflag = 1;
-			my $number = $1;
-			unless (defined $shelflist->{$number} || defined $privshelflist->{$number}) {
-				push(@paramsloop, {unrecognized=>$number}); last;
-	  		}
-			unless (ShelfPossibleAction($loggedinuser, $number, 'manage')) {
-				push(@paramsloop, {nopermission=>$shelfnumber}); last;
-			}
-			my $contents;
-			($contents, $totshelves) = GetShelfContents($number, $shelveslimit, $shelvesoffset);
-			if (my $count = scalar @$contents){
-				unless (scalar grep {/^CONFIRM-$number$/} $query->param()) {
-					if (defined $shelflist->{$number}) {
-						push(@paramsloop, {need_confirm=>$shelflist->{$number}->{shelfname}, count=>$count});
-						$shelflist->{$number}->{confirm} = $number;
-					} else {
-						push(@paramsloop, {need_confirm=>$privshelflist->{$number}->{shelfname}, count=>$count});
-						$privshelflist->{$number}->{confirm} = $number;
-					}
-					$stay = 0;
-					next;
-				}
-			} 
-			my $name;
-			if (defined $shelflist->{$number}) {
-				$name = $shelflist->{$number}->{'shelfname'};
-				delete $shelflist->{$number};
-			} else {
-				$name = $privshelflist->{$number}->{'shelfname'};
-				delete $privshelflist->{$number};
-			}
-			unless (DelShelf($number)) {
-				push(@paramsloop, {delete_fail=>$name}); last;
-			}
-			push(@paramsloop, {delete_ok=>$name});
-			# print $query->redirect($pages{$type}->{redirect}); exit;
-			$stay = 0;
-		}
-		$showadd = 1;
-		$stay and $template->param(shelves => 1);
-		last SWITCH;
-	}
-}
+        if ( $query->param('shelves') ) {
+            my $stay = 1;
+            if ( my $newshelf = $query->param('addshelf') ) {
+
+                # note: a user can always add a new shelf
+                my $shelfnumber = AddShelf( $newshelf, $query->param('owner'), $query->param('category'), $query->param('sortfield') );
+                $stay = 1;
+                if ( $shelfnumber == -1 ) {    #shelf already exists.
+                    $showadd = 1;
+                    push @paramsloop, { already => $newshelf };
+                    $template->param( shelfnumber => $shelfnumber );
+                } else {
+                    print $query->redirect( $pages{$type}->{redirect} . "?viewshelf=$shelfnumber" );
+                    exit;
+                }
+            }
+            foreach ( $query->param() ) {
+                /DEL-(\d+)/ or next;
+                $delflag = 1;
+                my $number = $1;
+                unless ( defined $shelflist->{$number} || defined $privshelflist->{$number} ) {
+                    push( @paramsloop, { unrecognized => $number } );
+                    last;
+                }
+                unless ( ShelfPossibleAction( $loggedinuser, $number, 'manage' ) ) {
+                    push( @paramsloop, { nopermission => $shelfnumber } );
+                    last;
+                }
+                my $contents;
+                ( $contents, $totshelves ) = GetShelfContents( $number, $shelveslimit, $shelvesoffset );
+                if ( my $count = scalar @$contents ) {
+                    unless ( scalar grep { /^CONFIRM-$number$/ } $query->param() ) {
+                        if ( defined $shelflist->{$number} ) {
+                            push( @paramsloop, { need_confirm => $shelflist->{$number}->{shelfname}, count => $count } );
+                            $shelflist->{$number}->{confirm} = $number;
+                        } else {
+                            push( @paramsloop, { need_confirm => $privshelflist->{$number}->{shelfname}, count => $count } );
+                            $privshelflist->{$number}->{confirm} = $number;
+                        }
+                        $stay = 0;
+                        next;
+                    }
+                }
+                my $name;
+                if ( defined $shelflist->{$number} ) {
+                    $name = $shelflist->{$number}->{'shelfname'};
+                    delete $shelflist->{$number};
+                } else {
+                    $name = $privshelflist->{$number}->{'shelfname'};
+                    delete $privshelflist->{$number};
+                }
+                unless ( DelShelf($number) ) {
+                    push( @paramsloop, { delete_fail => $name } );
+                    last;
+                }
+                push( @paramsloop, { delete_ok => $name } );
+
+                # print $query->redirect($pages{$type}->{redirect}); exit;
+                $stay = 0;
+            }
+            $showadd = 1;
+            $stay and $template->param( shelves => 1 );
+            last SWITCH;
+        }
+    }
 
-(@paramsloop) and $template->param(paramsloop => \@paramsloop);
-$showadd and $template->param(showadd => 1);
-my @shelvesloop;
-my @shelveslooppriv;
-my $numberCanManage = 0;
-
-# rebuild shelflist in case a shelf has been added
-($shelflist, $totshelves) = GetShelves( $category, $shelveslimit, $shelvesoffset, $loggedinuser ) unless $delflag;
-foreach my $element (sort { lc($shelflist->{$a}->{'shelfname'}) cmp lc($shelflist->{$b}->{'shelfname'}) } keys %$shelflist) {
-	my %line;
-	$shelflist->{$element}->{shelf} = $element;
-	my $category = $shelflist->{$element}->{'category'};
-	my $owner    = $shelflist->{$element}->{ 'owner'  };
-	my $canmanage = ShelfPossibleAction( $loggedinuser, $element, 'manage' );
-	$shelflist->{$element}->{"viewcategory$category"} = 1;
-	$shelflist->{$element}->{manageshelf} = $canmanage;
-	if ($owner eq $loggedinuser or $canmanage) {
-		$shelflist->{$element}->{'mine'} = 1;
-	} 
-	my $member = GetMember('borrowernumber' => $owner);
-	$shelflist->{$element}->{ownername} = defined($member) ? $member->{firstname} . " " . $member->{surname} : '';
-	$numberCanManage++ if $canmanage;	# possibly outmoded
-	if ($shelflist->{$element}->{'category'} eq '1') {
-		push (@shelveslooppriv, $shelflist->{$element});
-	} else {
-		push (@shelvesloop, $shelflist->{$element});
-	}
-}
+    (@paramsloop) and $template->param( paramsloop => \@paramsloop );
+    $showadd      and $template->param( showadd    => 1 );
+    my @shelvesloop;
+    my @shelveslooppriv;
+    my $numberCanManage = 0;
+
+    # rebuild shelflist in case a shelf has been added
+    ( $shelflist, $totshelves ) = GetShelves( $category, $shelveslimit, $shelvesoffset, $loggedinuser ) unless $delflag;
+    foreach my $element ( sort { lc( $shelflist->{$a}->{'shelfname'} ) cmp lc( $shelflist->{$b}->{'shelfname'} ) } keys %$shelflist ) {
+        my %line;
+        $shelflist->{$element}->{shelf} = $element;
+        my $category  = $shelflist->{$element}->{'category'};
+        my $owner     = $shelflist->{$element}->{'owner'};
+        my $canmanage = ShelfPossibleAction( $loggedinuser, $element, 'manage' );
+        $shelflist->{$element}->{"viewcategory$category"} = 1;
+        $shelflist->{$element}->{manageshelf} = $canmanage;
+        if ( $owner eq $loggedinuser or $canmanage ) {
+            $shelflist->{$element}->{'mine'} = 1;
+        }
+        my $member = GetMember( 'borrowernumber' => $owner );
+        $shelflist->{$element}->{ownername} = defined($member) ? $member->{firstname} . " " . $member->{surname} : '';
+        $numberCanManage++ if $canmanage;    # possibly outmoded
+        if ( $shelflist->{$element}->{'category'} eq '1' ) {
+            push( @shelveslooppriv, $shelflist->{$element} );
+        } else {
+            push( @shelvesloop, $shelflist->{$element} );
+        }
+    }
 
-my $url = $type eq 'opac' ? "/cgi-bin/koha/opac-shelves.pl" : "/cgi-bin/koha/virtualshelves/shelves.pl";
-my %qhash = ();
-foreach (qw(display viewshelf sortfield)) {
-    $qhash{$_} = $query->param($_) if $query->param($_);
-}
-(scalar keys %qhash) and $url .= '?' . join '&', map {"$_=$qhash{$_}"} keys %qhash;
-if ($query->param('viewshelf')) {
-	$template->param( {pagination_bar => pagination_bar($url, (int($totitems/$shelflimit)) + (($totitems % $shelflimit) > 0 ? 1 : 0), $itemoff, "itemoff")} );
-} else {
-	$template->param( {pagination_bar => pagination_bar($url, (int($totshelves/$shelveslimit)) + (($totshelves % $shelveslimit) > 0 ? 1 : 0), $shelfoff, "shelfoff")} );
-}
-$template->param(
-    shelveslooppriv => \@shelveslooppriv,
-    shelvesloop     => \@shelvesloop,
-    shelvesloopall  => [(@shelvesloop, @shelveslooppriv)],
-    numberCanManage => $numberCanManage,
-	"BiblioDefaultView".C4::Context->preference("BiblioDefaultView") => 1,
-    csv_profiles => GetCsvProfilesLoop()
-);
-if ($template->param('viewshelf') or
-	$template->param( 'shelves' ) or
-	$template->param(  'edit'   ) ) {
-	$template->param(vseflag => 1);
-}
-if ($template->param( 'shelves' ) or    # note: this part looks duplicative, but is intentional
-	$template->param(  'edit'   ) ) {
-	$template->param( seflag => 1);
-}
+    my $url = $type eq 'opac' ? "/cgi-bin/koha/opac-shelves.pl" : "/cgi-bin/koha/virtualshelves/shelves.pl";
+    my %qhash = ();
+    foreach (qw(display viewshelf sortfield)) {
+        $qhash{$_} = $query->param($_) if $query->param($_);
+    }
+    ( scalar keys %qhash ) and $url .= '?' . join '&', map { "$_=$qhash{$_}" } keys %qhash;
+    if ( $query->param('viewshelf') ) {
+        $template->param( { pagination_bar => pagination_bar( $url, ( int( $totitems / $shelflimit ) ) + ( ( $totitems % $shelflimit ) > 0 ? 1 : 0 ), $itemoff, "itemoff" ) } );
+    } else {
+        $template->param(
+            { pagination_bar => pagination_bar( $url, ( int( $totshelves / $shelveslimit ) ) + ( ( $totshelves % $shelveslimit ) > 0 ? 1 : 0 ), $shelfoff, "shelfoff" ) } );
+    }
+    $template->param(
+        shelveslooppriv                                                    => \@shelveslooppriv,
+        shelvesloop                                                        => \@shelvesloop,
+        shelvesloopall                                                     => [ ( @shelvesloop, @shelveslooppriv ) ],
+        numberCanManage                                                    => $numberCanManage,
+        "BiblioDefaultView" . C4::Context->preference("BiblioDefaultView") => 1,
+        csv_profiles                                                       => GetCsvProfilesLoop()
+    );
+    if (   $template->param('viewshelf')
+        or $template->param('shelves')
+        or $template->param('edit') ) {
+        $template->param( vseflag => 1 );
+    }
+    if ($template->param('shelves') or    # note: this part looks duplicative, but is intentional
+        $template->param('edit')
+      ) {
+        $template->param( seflag => 1 );
+    }
 
-#FIXME:	This refresh really only needs to happen when there is a modification of some sort
-#		to the shelves, but the above code is so convoluted in its handling of the various
-#		options, it is easier to do this refresh every time C4::VirtualShelves::Page.pm is
-#		called
+    #FIXME:	This refresh really only needs to happen when there is a modification of some sort
+    #		to the shelves, but the above code is so convoluted in its handling of the various
+    #		options, it is easier to do this refresh every time C4::VirtualShelves::Page.pm is
+    #		called
 
-my ($total, $pubshelves, $barshelves) = RefreshShelvesSummary($query->cookie("CGISESSID"),$loggedinuser,($loggedinuser == -1 ? 20 : 10));
+    my ( $total, $pubshelves, $barshelves ) = RefreshShelvesSummary( $query->cookie("CGISESSID"), $loggedinuser, ( $loggedinuser == -1 ? 20 : 10 ) );
 
-if (defined $barshelves) {
-	$template->param( 	barshelves     	=> scalar (@{$barshelves->[0]}),
-						barshelvesloop 	=> $barshelves->[0],
-					);
-	$template->param(	bartotal		=> $total->{'bartotal'}, ) if ($total->{'bartotal'} > scalar (@{$barshelves->[0]}));
-}
+    if ( defined $barshelves ) {
+        $template->param(
+            barshelves     => scalar( @{ $barshelves->[0] } ),
+            barshelvesloop => $barshelves->[0],
+        );
+        $template->param( bartotal => $total->{'bartotal'}, ) if ( $total->{'bartotal'} > scalar( @{ $barshelves->[0] } ) );
+    }
 
-if (defined $pubshelves) {
-	$template->param( 	pubshelves     	=> scalar (@{$pubshelves->[0]}),
-						pubshelvesloop 	=> $pubshelves->[0],
-					);
-	$template->param(	pubtotal		=> $total->{'pubtotal'}, ) if ($total->{'pubtotal'} > scalar (@{$pubshelves->[0]}));
-}
+    if ( defined $pubshelves ) {
+        $template->param(
+            pubshelves     => scalar( @{ $pubshelves->[0] } ),
+            pubshelvesloop => $pubshelves->[0],
+        );
+        $template->param( pubtotal => $total->{'pubtotal'}, ) if ( $total->{'pubtotal'} > scalar( @{ $pubshelves->[0] } ) );
+    }
 
-output_html_with_http_headers $query, $cookie, $template->output;
-}	
+    output_html_with_http_headers $query, $cookie, $template->output;
+}
 
 1;
 __END__
-- 
1.6.3.3




More information about the Koha-patches mailing list