Diff for /loncom/interface/slotrequest.pm between versions 1.136 and 1.137

version 1.136, 2017/12/22 02:00:46 version 1.137, 2018/01/31 15:28:47
Line 465  sub get_consumed_uniqueperiods { Line 465  sub get_consumed_uniqueperiods {
         return 'error: Unable to determine current status';          return 'error: Unable to determine current status';
     }      }
     my @problems = $navmap->retrieveResources(undef,      my @problems = $navmap->retrieveResources(undef,
       sub { $_[0]->is_gradable() },1,0);        sub { $_[0]->is_problem() || $_[0]->is_tool() },1,0);
     my %used_slots;      my %used_slots;
     foreach my $problem (@problems) {      foreach my $problem (@problems) {
  my $symb = $problem->symb();   my $symb = $problem->symb();
Line 805  sub release_reservation { Line 805  sub release_reservation {
         if ($passed_resource->is_map()) {          if ($passed_resource->is_map()) {
     my ($a_resource) =       my ($a_resource) = 
                 $navmap->retrieveResources($passed_resource,                   $navmap->retrieveResources($passed_resource, 
                                            sub {$_[0]->is_gradable()},0,1);                                             sub {$_[0]->is_problem() || $_[0]->is_tool() },0,1);
             $symb = $a_resource->symb();              $symb = $a_resource->symb();
         }          }
     } else {      } else {
Line 1890  STUFF Line 1890  STUFF
   
 sub manage_reservations {  sub manage_reservations {
     my ($r,$crstype,$slots,$consumed_uniqueperiods,$allavailable) = @_;      my ($r,$crstype,$slots,$consumed_uniqueperiods,$allavailable) = @_;
       my ($cnum,$cdom)=&get_course();
     my $navmap = Apache::lonnavmaps::navmap->new();      my $navmap = Apache::lonnavmaps::navmap->new();
     $r->print('<p>'      $r->print('<p>'
              .&mt('Instructors may use a reservation system to place restrictions on when and where assignments can be worked on.')               .&mt('Instructors may use a reservation system to place restrictions on when and where assignments can be worked on.')
Line 1921  sub manage_reservations { Line 1922  sub manage_reservations {
                   '</span>');                    '</span>');
         return;          return;
     }      }
     my (%parent,%shownparent,%container,%container_title,%contents);      my (%output,%slotinfo,%statusbymap,%repsymbs,%shownmaps);
     my ($depth,$count,$reservable,$lastcontainer,$rownum,$shown) = (0,0,0,0,0,0);      my @possibles = $navmap->retrieveResources(undef,
     my @backgrounds = ("LC_odd_row","LC_even_row");                                                sub { $_[0]->is_problem() || $_[0]->is_tool() },1,0);
   
       foreach my $resource (@possibles) {
           my ($useslots) = $resource->slot_control();
           next if (($useslots eq '') || ($useslots =~ /^\s*no\s*$/i));
           my $symb = $resource->symb();
           my ($slot_status,$date,$slot_name) = $resource->check_for_slot('0');
           my ($msg,$get_choices,$slotdescription);
           my $status = $resource->simpleStatus('0');
           my ($msg,$get_choices,$slotdescription);
           if ($slot_name ne '') {
               my %slot=&Apache::lonnet::get_slot($slot_name);
               $slotdescription=&get_description($slot_name,\%slot);
           }
           if ($slot_status == $resource->NOT_IN_A_SLOT) {
               $msg=&mt('No current reservation.');
               $get_choices = 1;
           } elsif ($slot_status == $resource->NEEDS_CHECKIN) {
               $msg='<span class="LC_nobreak">'.&mt('Reserved:').
                    '&nbsp;'.$slotdescription.'</span><br />'.
                    &mt('Access requires proctor validation.');
           } elsif ($slot_status == $resource->WAITING_FOR_GRADE) {
               $msg=&mt('Submitted and currently in grading queue.');
           } elsif ($slot_status == $resource->CORRECT) {
               $msg=&mt('Problem is unavailable.');
           } elsif ($slot_status == $resource->RESERVED) {
               $msg='<span class="LC_nobreak">'.&mt('Reserved:').
                    '&nbsp;'.$slotdescription.'</span><br />'.
                    &mt('Problem is currently available.');
           } elsif ($slot_status == $resource->RESERVED_LOCATION) {
               $msg='<span class="LC_nobreak">'.&mt('Reserved:').
                    '&nbsp;'.$slotdescription.'</span><br />'.
                    &mt('Problem is available at a different location.');
               $get_choices = 1;
           } elsif ($slot_status == $resource->RESERVED_LATER) {
               $msg='<span class="LC_nobreak">'.&mt('Reserved:').
                    '&nbsp;'.$slotdescription.'</span><br />'.
                    &mt('Problem will be available later.');
               $get_choices = 1;
           } elsif ($slot_status == $resource->RESERVABLE) {
               $msg=&mt('Reservation needed');
               $get_choices = 1;
           } elsif ($slot_status == $resource->RESERVABLE_LATER) {
               $msg=&mt('Reservation needed: will be reservable later.');
           } elsif ($slot_status == $resource->NOTRESERVABLE) {
               $msg=&mt('Reservation needed: none available.');
           } elsif ($slot_status == $resource->UNKNOWN) {
               $msg=&mt('Unable to determine status due to network problems.');
           } else {
               if ($status != $resource->OPEN) {
                   $msg = &Apache::lonnavmaps::getDescription($resource,'0');
               }
           }
           $output{$symb}{'msg'} = $msg;
           if (($status == $resource->OPEN) && ($get_choices)) {
               $output{$symb}{'hasaction'} = 1;
           }
           my ($mapurl,$id,$resurl) = &Apache::lonnet::decode_symb($symb);
           $mapurl = &Apache::lonnet::clutter($mapurl);
           unless ($mapurl =~ /default\.sequence$/) {
               $shownmaps{$mapurl} = 1;
               my $map = $navmap->getResourceByUrl($mapurl);
               if (ref($map)) {
                   my @pcs = split(/,/,$map->map_hierarchy());
                   shift(@pcs);
                   shift(@pcs);
                   if (@pcs) {
                       map { $shownmaps{$navmap->getByMapPc($_)->src()} = 1; } reverse(@pcs);
                   }
               }
           }
           if (($useslots eq 'map_map') || ($useslots eq 'map')) {
               if ($slot_status ne '') {
                   if (ref($statusbymap{$mapurl}{$slot_status}) eq 'ARRAY') {
                       push(@{$statusbymap{$mapurl}{$slot_status}},$symb);
                   } else {
                       $statusbymap{$mapurl}{$slot_status} = [$symb];
                   }
               }
           }
       }
   
       foreach my $mapurl (keys(%statusbymap)) {
           if (ref($statusbymap{$mapurl}) eq 'HASH') {
               if (keys(%{$statusbymap{$mapurl}}) == 1) {
                   my @values = values(%{$statusbymap{$mapurl}});
                   my $repsymb = $values[0][0];
                   if (ref($output{$repsymb}) eq 'HASH') {
                       $output{$mapurl}{'msg'} = $output{$repsymb}{'msg'};
                       $output{$mapurl}{'hasaction'} = $output{$repsymb}{'hasaction'};
                   }
                   $repsymbs{$mapurl} = $repsymb;
               }
           }
       }
   
       my (%parent,%container,%container_title);
       my ($depth,$count,$reservable,$currcontainer,$rownum,$mapnum,$shown) = (0,0,0,0,0,0,0);
       my @backgrounds = ("LC_even_row","LC_odd_row");
     my $numcolors = scalar(@backgrounds);      my $numcolors = scalar(@backgrounds);
     my $location=&Apache::loncommon::lonhttpdurl("/adm/lonIcons/whitespace_21.gif");      my $location=&Apache::loncommon::lonhttpdurl("/adm/lonIcons/whitespace_21.gif");
     my $slotheader = '<p>'.      my $slotheader = '<p>'.
Line 1931  sub manage_reservations { Line 2030  sub manage_reservations {
                  '</p>'.                   '</p>'.
                  '<table class="LC_data_table LC_tableOfContent" id="LC_slot_reservations">'."\n";                   '<table class="LC_data_table LC_tableOfContent" id="LC_slot_reservations">'."\n";
     my $shownheader = 0;      my $shownheader = 0;
       my $currmap;
     my $it=$navmap->getIterator(undef,undef,undef,1,undef,undef);      my $it=$navmap->getIterator(undef,undef,undef,1,undef,undef);
     my (@ordered,%output,$mapitem,$got_map_slot,$currmapoutput,$mapnum);  
     $mapnum = 0;  
     $shown = 0;  
     while (my $resource = $it->next()) {      while (my $resource = $it->next()) {
         if ($resource == $it->BEGIN_MAP()) {          if ($resource == $it->BEGIN_MAP()) {
             $depth++;              $depth++;
             $parent{$depth} = $lastcontainer;              $parent{$depth} = $currcontainer;
         }              if (ref($container{$currcontainer})) {
         if ($resource == $it->END_MAP()) {                  my $currmapres = $container{$currcontainer};
             $depth--;                  my $currmaptitle = $container_title{$currcontainer};
             $lastcontainer = $parent{$depth};                  $currmap = $currmapres->src();
             my %allstatuses;                  my $currmaptype = 'sequence';
             foreach my $symb (@ordered) {                  if ($currmapres->is_page()) {
                 if (ref($output{$symb}) eq 'HASH') {                      $currmaptype = 'page';
                     if (($output{$symb}{'type'} eq 'map_map') || ($output{$symb}{'type'} eq 'map')) {                  }
                         if ($output{$symb}{'slotstatus'} ne '') {                  if ($shownmaps{$currmap}) {
                             if (ref($allstatuses{$output{$symb}{'slotstatus'}}) eq 'ARRAY') {                      $mapnum ++;
                                 push(@{$allstatuses{$output{$symb}{'slotstatus'}}},$symb);                      $rownum ++;
                       $shown ++;
                       if (!$shownheader) {
                           $r->print($slotheader);
                           $shownheader = 1;
                       }
                       my $bgcolor = $backgrounds[$shown % $numcolors];
                       my ($spacers,$icon);
                       my $row = '<tr class="'.$bgcolor.'" id="LC_slotmaprow_'.$rownum.'">';
                       if (ref($statusbymap{$currmap}) eq 'HASH') {
                           my ($spacers,$icon) = &show_map_row($depth-1,$location,$currmaptype,$currmaptitle);
                           my $arrowstate = 'open';
                           if (keys(%{$statusbymap{$currmap}}) == 1) {
                               $arrowstate = 'closed';
                           }
                           $row .= '<td>'.$spacers.'<img src="/adm/lonIcons/arrow.'.$arrowstate.'.gif" '.
                                   'id="arrow'.$mapnum.'" '.'alt="arrow" onmouseover="this.style.cursor=\'pointer\'" '.
                                   'onclick="'."toggleSlotMap('$mapnum','$rownum');".'" />'.
                                   $icon.('&nbsp;' x6).'</td>'."\n";
                           if (ref($output{$currmap}) eq 'HASH') {
                               my $formnum = $mapnum.'_'.$reservable+1;
                               my $class = 'LC_slotmaptext_'.$mapnum;
                               if ($output{$currmap}{'hasaction'}) {
                                   $row .= '<td valign="top"><span class="'.$class.'">'.
                                             $output{$currmap}{'msg'}.
                                             '</span></td><td valign="top">'.
                                             &slot_chooser($repsymbs{$currmap},$class,$formnum,
                                                           $allavailable,$slots,$consumed_uniqueperiods).
                                             '</td>';
                             } else {                              } else {
                                 $allstatuses{$output{$symb}{'slotstatus'}} = [$symb];                                  $row .= '<td colspan="2" valign="middle"><span class="'.$class.'">'.
                                             $output{$currmap}{'msg'}.
                                             '</span></td>';
                             }                              }
                               $row .= '</tr>'."\n";
                           } else {
                               $row .= '<td colspan="2">&nbsp;</td></tr>'."\n";
                         }                          }
                     }  
                 }  
             }  
             if (keys(%allstatuses) == 1) {  
                 $got_map_slot = 1;  
                 my $repsymb;  
                 my @values = values(%allstatuses);  
                 if (ref($values[0]) eq 'ARRAY') {  
                     if (ref($output{$values[0][0]}) eq 'HASH') {  
                         $repsymb = $values[0][0];  
                     }  
                 }  
                 if (($mapitem) && ($repsymb)) {  
                     my $formnum = $mapnum.'_'.$output{$repsymb}{'reservable'};  
                     my $class = 'LC_slotmaptext_'.$mapnum;  
                     if ($output{$repsymb}{'hasaction'}) {  
                         $mapitem .= '<td valign="top"><span class="'.$class.'">'.  
                                     $output{$repsymb}{'msg'}.  
                                     '</span></td><td valign="top">'.  
                                     &slot_chooser($repsymb,$class,$formnum,$allavailable,$slots,  
                                                   $consumed_uniqueperiods).  
                                    '</td>';  
   
                     } else {                      } else {
                         $mapitem .= '<td colspan="2" valign="middle"><span class="'.$class.'">'.                          my ($spacers,$icon) = &show_map_row($depth,$location,$currmaptype,$currmaptitle);
                                     $output{$repsymb}{'msg'}.                          $row .= '<td>'.$spacers.$icon.('&nbsp;' x6).'</td><td colspan="2">&nbsp;</td></tr>'."\n";
                                     '</span></td>';  
                     }  
                 }  
                 my $counter = 0;  
                 foreach my $symb (@ordered) {  
                     if (ref($output{$symb}) eq 'HASH') {  
                         $counter ++;  
                         my $bgcolor = $backgrounds[($output{$symb}{'shown'} + $counter) % $numcolors];  
                         $currmapoutput .= $output{$symb}{'header'}.  
                                           '<tr class="'.$bgcolor.' LC_slotresrow_'.$output{$symb}{'mapnum'}.'"'.  
                                           ' style="display:none" id="LC_slotresrow_'.$output{$symb}{'rownum'}.'">'.  
                                           $output{$symb}{'info'}.  
                                           $output{$symb}{'data'}.'</tr>'."\n";  
                     }  
                 }  
             } else {  
                 my $counter = 0;  
                 foreach my $symb (@ordered) {  
                     if (ref($output{$symb}) eq 'HASH') {  
                         $counter ++;  
                         my $bgcolor = $backgrounds[($output{$symb}{'shown'} + $counter) % $numcolors];  
                         $currmapoutput .= $output{$symb}{'header'}.  
                                           '<tr class="'.$bgcolor.' LC_slotresrow_'.$output{$symb}{'mapnum'}.'"'.  
                                           ' style="display:table-row" id="LC_slotresrow_'.$output{$symb}{'rownum'}.'">'.  
                                           $output{$symb}{'info'}.  
                                           $output{$symb}{'data'}.'</tr>'."\n";  
                         $shown ++;  
                     }                      }
                       $r->print($row);
                 }                  }
             }              }
             if ($mapitem) {          } elsif ($resource == $it->END_MAP()) {
                 if ($got_map_slot) {              $depth--;
                     $mapitem =~ s{(<img src=\"/adm/lonIcons/arrow\.)open(\.gif\")}{$1closed$2};              $currcontainer = $parent{$depth};
                     $mapitem .= '</tr>'."\n";          } elsif (ref($resource)) {
                 } else {  
                     $mapitem .= '<td colspan="2">&nbsp;</td></tr>'."\n";  
                 }  
             }  
             $r->print($mapitem.$currmapoutput);  
             @ordered=();  
             undef(%output);  
             $currmapoutput = '';  
             $got_map_slot = '';  
             $mapitem = '';  
         }  
         if (ref($resource)) {  
             my $symb = $resource->symb();              my $symb = $resource->symb();
             $contents{$lastcontainer} ++;              next if (!$resource->is_problem() && !$resource->is_tool() &&
             next if (!$resource->is_gradable() && !$resource->is_sequence() &&                        !$resource->is_sequence() && !$resource->is_page());
                      !$resource->is_page());  
             $count ++;              $count ++;
             if (($resource->is_sequence()) || ($resource->is_page())) {              if (($resource->is_sequence()) || ($resource->is_page())) {
                 $lastcontainer = $count;                  $currcontainer = $count;
                 $container{$lastcontainer} = $resource;                  $container{$currcontainer} = $resource;
                 $container_title{$lastcontainer} = $resource->compTitle();                  $container_title{$currcontainer} = $resource->compTitle();
             }              }
             if ($resource->is_gradable()) {              if (($resource->is_problem() || $resource->is_tool)) {
                 my ($useslots) = $resource->slot_control();                  next unless (exists($output{$symb}));
                 next if (($useslots eq '') || ($useslots =~ /^\s*no\s*$/i));  
                 push(@ordered,$symb);   
                 $output{$symb}{type} = $useslots;    
                 my ($msg,$get_choices,$slotdescription);  
                 my $title = $resource->compTitle();  
                 my $status = $resource->simpleStatus('0');  
                 my ($slot_status,$date,$slot_name) = $resource->check_for_slot('0');  
   
                 $output{$symb}{'slotstatus'} = $slot_status;  
                 $output{$symb}{'slotname'} = $slot_name;   
                 if ($slot_name ne '') {  
                     my %slot=&Apache::lonnet::get_slot($slot_name);  
                     $slotdescription=&get_description($slot_name,\%slot);  
                 }  
                 if ($slot_status == $resource->NOT_IN_A_SLOT) {  
                     $msg=&mt('No current reservation.');  
                     $get_choices = 1;  
                 } elsif ($slot_status == $resource->NEEDS_CHECKIN) {  
                     $msg='<span class="LC_nobreak">'.&mt('Reserved:').  
                          '&nbsp;'.$slotdescription.'</span><br />'.  
                          &mt('Access requires proctor validation.');  
                 } elsif ($slot_status == $resource->WAITING_FOR_GRADE) {  
                     $msg=&mt('Submitted and currently in grading queue.');  
                 } elsif ($slot_status == $resource->CORRECT) {  
                     $msg=&mt('Problem is unavailable.');  
                 } elsif ($slot_status == $resource->RESERVED) {  
                     $msg='<span class="LC_nobreak">'.&mt('Reserved:').  
                          '&nbsp;'.$slotdescription.'</span><br />'.  
                          &mt('Problem is currently available.');  
                 } elsif ($slot_status == $resource->RESERVED_LOCATION) {  
                     $msg='<span class="LC_nobreak">'.&mt('Reserved:').  
                          '&nbsp;'.$slotdescription.'</span><br />'.  
                          &mt('Problem is available at a different location.');  
                     $get_choices = 1;  
                 } elsif ($slot_status == $resource->RESERVED_LATER) {  
                     $msg='<span class="LC_nobreak">'.&mt('Reserved:').  
                          '&nbsp;'.$slotdescription.'</span><br />'.  
                          &mt('Problem will be available later.');  
                     $get_choices = 1;  
                 } elsif ($slot_status == $resource->RESERVABLE) {  
                     $msg=&mt('Reservation needed');  
                     $get_choices = 1;  
                 } elsif ($slot_status == $resource->RESERVABLE_LATER) {  
                     $msg=&mt('Reservation needed: will be reservable later.');  
                 } elsif ($slot_status == $resource->NOTRESERVABLE) {  
                     $msg=&mt('Reservation needed: none available.');  
                 } elsif ($slot_status == $resource->UNKNOWN) {  
                     $msg=&mt('Unable to determine status due to network problems.');  
                 } else {  
                     if ($status != $resource->OPEN) {  
                         $msg = &Apache::lonnavmaps::getDescription($resource,'0');   
                     }  
                 }  
                 $output{$symb}{'msg'} = $msg;  
                 $reservable ++;                  $reservable ++;
                 $output{$symb}{'reservable'} = $reservable;  
                 my $treelevel = $depth;  
                 my $higherup = $lastcontainer;  
                 if ($depth > 1) {  
                     my @maprows;  
                     while ($treelevel > 1) {  
                         if (ref($container{$higherup})) {  
                             my $res = $container{$higherup};  
                             last if (defined($shownparent{$higherup}));  
                             my $maptitle = $res->compTitle();  
                             my $type = 'sequence';  
                             if ($res->is_page()) {  
                                 $type = 'page';  
                             }  
                             &show_map_row($treelevel,$location,$type,$maptitle,  
                                           \@maprows);  
                             $shownparent{$higherup} = 1;  
                         }  
                         $treelevel --;  
                         $higherup = $parent{$treelevel};  
                     }  
                     for (my $i=0; $i<@maprows; $i++) {  
                         $mapnum ++;  
                         $rownum ++;  
                         $shown ++;  
                         my $bgcolor = $backgrounds[$shown % $numcolors];  
                         if (!$shownheader) {  
                             $mapitem .= $slotheader;  
                             $shownheader = 1;  
                         }  
                         if (ref($maprows[$i]) eq 'ARRAY') {  
                             if ($i < scalar(@maprows)-1) {  
                                 $mapitem .= '<tr class="'.$bgcolor.'" id="LC_slotmaprow_'.$rownum.'">'.  
                                             '<td>'.join('',@{$maprows[$i]}).'</td>'.  
                                             '<td colspan="2">&nbsp;</td></tr>'."\n";  
                             } else {  
                                 $mapitem .=   
                                    '<tr class="'.$bgcolor.'" id="LC_slotmaprow_'.$rownum.'">'.  
                                    '<td>'.$maprows[$i][0].  
                                    '<img src="/adm/lonIcons/arrow.open.gif" id="arrow'.$mapnum.'" '.  
                                    'alt="arrow" onmouseover="this.style.cursor=\'pointer\'" '.  
                                    'onclick="'."toggleSlotMap('$mapnum','$rownum');".'" />'.  
                                    $maprows[$i][1].('&nbsp;' x6).'</td>'."\n";  
                             }  
                         }  
                     }  
                     $output{$symb}{'mapnum'} = $mapnum;  
                 }  
                 $rownum ++;                  $rownum ++;
                 $output{$symb}{'rownum'} = $rownum;  
                 $output{$symb}{'shown'} = $shown;  
                 if (!$shownheader) {                  if (!$shownheader) {
                     $output{$symb}{'header'} = $slotheader;                      $r->print($slotheader);
                     $shownheader = 1;                      $shownheader = 1;
                 }                  }
                 $output{$symb}{'info'} = '<td>';                  my $style;
                   if (exists($output{$currmap})) {
                       $style = 'none';
                   } else {
                       $style = 'table-row';
                       $shown ++;
                   }
                   my $title = $resource->compTitle();
                   my $bgcolor = $backgrounds[$shown % $numcolors];
                   $r->print('<tr class="'.$bgcolor.' LC_slotresrow_'.$mapnum.'"'.
                             ' style="display:'.$style.'" id="LC_slotresrow_'.$rownum.'">'.
                             '<td>');
                 for (my $i=0; $i<$depth; $i++) {                  for (my $i=0; $i<$depth; $i++) {
                     $output{$symb}{'info'} .= '<img src="'.$location.'" alt="" />';                      $r->print('<img src="'.$location.'" alt="" />');
                 }                  }
                 $output{$symb}{'info'} .= '<a href="'.$resource->src().'?symb='.$symb.'">'.                  $r->print('<a href="'.$resource->src().'?symb='.$symb.'">'.
                                          '<img class="LC_contentImage" src="/adm/lonIcons/';                            '<img class="LC_contentImage" src="/adm/lonIcons/');
                 if ($resource->is_task()) {                  if ($resource->is_task()) {
                     $output{$symb}{'info'} .= 'task.gif" alt="'.&mt('Task');                      $r->print('task.gif" alt="'.&mt('Task'));
                   } elsif ($resource->is_tool()) {
                       $r->print('unknown.gif" alt="'.&mt('External Tool'));
                 } else {                  } else {
                     $output{$symb}{'info'} .= 'problem.gif" alt="'.&mt('Problem');                      $r->print('problem.gif" alt="'.&mt('Problem'));
                 }  
                 $output{$symb}{'info'} .= '" /><b>'.$title.'</b></a>'.('&nbsp;' x6).'</td>';  
   
                 my $hasaction;  
                 if ($status == $resource->OPEN) {  
                     if ($get_choices) {  
                         $hasaction = 1;  
                         $output{$symb}{'hasaction'} = $hasaction;  
                     }  
                 }                  }
                   $r->print('" /><b>'.$title.'</b></a>'.('&nbsp;' x6).'</td>');
                 my $class = 'LC_slottext_'.$mapnum;                  my $class = 'LC_slottext_'.$mapnum;
                 if ($hasaction) {                  if ($output{$symb}{'hasaction'}) {
                     $output{$symb}{'data'} = '<td valign="top"><span class="'.$class.'">'.$msg.'</span></td>'.                      $r->print('<td valign="top"><span class="'.$class.'">'.$output{$symb}{'msg'}.'</span></td>'.
                                              '<td valign="top">'.                                '<td valign="top">'.
                                              &slot_chooser($symb,$class,$reservable,$allavailable,$slots,                                &slot_chooser($symb,$class,$reservable,$allavailable,$slots,
                                                            $consumed_uniqueperiods).'</td>';                                              $consumed_uniqueperiods).'</td>');
                 } else {                  } else {
                     $output{$symb}{'data'} = '<td colspan="2" valign="middle">'.                      $r->print('<td colspan="2" valign="middle">'.
                                              '<span class="'.$class.'">'.$msg.'</span>'.                                '<span class="'.$class.'">'.$output{$symb}{'msg'}.'</span>'.
                                              '</td>';                                '</td>');
                 }                  }
                   $r->print('</tr>'."\n");
             }              }
         }          }
     }      }
Line 2199  sub manage_reservations { Line 2169  sub manage_reservations {
 }  }
   
 sub show_map_row {  sub show_map_row {
     my ($depth,$location,$type,$title,$maprows) = @_;      my ($depth,$location,$type,$title) = @_;
     my $spacers;      my $spacers;
     for (my $i=0; $i<$depth-2; $i++) {      for (my $i=0; $i<$depth-1; $i++) {
         $spacers .= '<img src="'.$location.'" alt="" />';          $spacers .= '<img src="'.$location.'" alt="" />';
     }      }
     my $icon;      my $icon;
Line 2211  sub show_map_row { Line 2181  sub show_map_row {
         $icon = '<img src="/adm/lonIcons/navmap.folder.open.gif" alt="" />&nbsp;'."\n";          $icon = '<img src="/adm/lonIcons/navmap.folder.open.gif" alt="" />&nbsp;'."\n";
     }      }
     $icon .= $title;      $icon .= $title;
     unshift (@{$maprows},[$spacers,$icon]);      return ($spacers,$icon);
     return;  
 }  }
   
 sub slot_chooser {  sub slot_chooser {
Line 2273  sub show_reservations { Line 2242  sub show_reservations {
         $udom = $env{'user.domain'};          $udom = $env{'user.domain'};
     }      }
     my $formname = 'slotlog';      my $formname = 'slotlog';
     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};      my ($cnum,$cdom)=&get_course();
     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};  
     my $crstype = &Apache::loncommon::course_type();      my $crstype = &Apache::loncommon::course_type();
     my %log=&Apache::lonnet::dump('nohist_'.$cdom.'_'.$cnum.'_slotlog',$udom,$uname);      my %log=&Apache::lonnet::dump('nohist_'.$cdom.'_'.$cnum.'_slotlog',$udom,$uname);
     if ($env{'form.origin'} eq 'aboutme') {      if ($env{'form.origin'} eq 'aboutme') {
Line 2449  sub show_reservations_log { Line 2417  sub show_reservations_log {
         return;          return;
     }      }
     my $formname = 'reservationslog';      my $formname = 'reservationslog';
     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};      my ($cnum,$cdom)=&get_course();
     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};  
     my %slotlog=&Apache::lonnet::dump('nohist_slotreservationslog',$cdom,$cnum);      my %slotlog=&Apache::lonnet::dump('nohist_slotreservationslog',$cdom,$cnum);
     if ((keys(%slotlog))[0]=~/^error\:/) { undef(%slotlog); }      if ((keys(%slotlog))[0]=~/^error\:/) { undef(%slotlog); }
   

Removed from v.1.136  
changed lines
  Added in v.1.137


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>