Diff for /loncom/interface/slotrequest.pm between versions 1.128 and 1.129

version 1.128, 2015/09/25 16:13:00 version 1.129, 2015/09/27 14:21:48
Line 261  function uncheckSlotRadio() { Line 261  function uncheckSlotRadio() {
     }      }
 }  }
   
 function toggleSlotMap(maprownum) {  function toggleSlotMap(maprownum,rownum) {
     if (document.getElementById('arrow'+maprownum)) {      if (document.getElementById('arrow'+maprownum)) {
         var img = document.getElementById('arrow'+maprownum);          var img = document.getElementById('arrow'+maprownum);
         var rowdisplay;          var rowdisplay;
Line 278  function toggleSlotMap(maprownum) { Line 278  function toggleSlotMap(maprownum) {
         var resrows;          var resrows;
         var maptext;          var maptext;
         if (document.getElementsByClassName) {          if (document.getElementsByClassName) {
             resrows = document.getElementsByClassName('LC_slotmaprow_'+maprownum);              resrows = document.getElementsByClassName('LC_slotresrow_'+maprownum);
             maptext = document.getElementsByClassName('LC_slotmaptext_'+maprownum);              maptext = document.getElementsByClassName('LC_slotmaptext_'+maprownum);
         } else {          } else {
             resrows = getElementsByClassName(document.body,'LC_slotmaprow_'+maprownum);              resrows = getElementsByClassName(document.body,'LC_slotresrow_'+maprownum);
             maptext = getElementsByClassName(document.body,'LC_slotmaptext_'+maprownum);              maptext = getElementsByClassName(document.body,'LC_slotmaptext_'+maprownum);
         }          }
           if (maptext.length) {
               for (var i=0; i<maptext.length; i++) {
                   maptext[i].style.display = celldisplay;
               }
           }
         if (resrows.length) {          if (resrows.length) {
              var mapbgidx = 0;
              var rowclasses = ['LC_even_row','LC_odd_row'];
              var mapbgClass = 'LC_even_row';
              var regExpBg = /LC_odd_row/i;
              if (rowdisplay == 'table-row') {
                   if (document.getElementById('LC_slotmaprow_'+rownum)) {
                       mapbgClass = document.getElementById('LC_slotmaprow_'+rownum).className;
                       if (regExpBg.test(mapbgClass)) {
                           mapbgidx = 1;
                       }
                   }
               }
             for (var i=0; i<resrows.length; i++) {              for (var i=0; i<resrows.length; i++) {
                 resrows[i].style.display = rowdisplay;                     resrows[i].style.display = rowdisplay;
                   if (rowdisplay == 'table-row') {
                       mapbgidx ++;        
                       var bgcolnew = mapbgidx % 2;
                       var bgcolold = (mapbgidx+1) % 2;
                       var k = i+parseInt(rownum)+1; 
                       if (document.getElementById('LC_slotresrow_'+k)) {
                           document.getElementById('LC_slotresrow_'+k).className = document.getElementById('LC_slotresrow_'+k).className.replace(rowclasses[bgcolold],rowclasses[bgcolnew]);
                       }
                   }
             }              }
         }              if (document.getElementById('LC_slot_reservations')) {
         if (maptext.length) {                   var numrowsOdd = resrows.length % 2;
             for (var i=0; i<maptext.length; i++) {                  if (numrowsOdd) {
                 maptext[i].style.display = celldisplay;                      var lastbgClass = 'LC_even_row';
                       var idx = 0;
                       var lastresnum = parseInt(rownum) + resrows.length; 
                       if (rowdisplay == 'none') {
                           lastresnum = rownum;
                           if (document.getElementById('LC_slotmaprow_'+rownum)) {
                               lastbgClass = document.getElementById('LC_slotmaprow_'+rownum).className;
                           }
                       } else {
                           lastresnum = parseInt(rownum) + resrows.length;
                           if (document.getElementById('LC_slotresrow_'+lastresnum)) {
                               lastbgClass = document.getElementById('LC_slotresrow_'+lastresnum).className;
                           }
                       }
                       if (regExpBg.test(lastbgClass)) {
                           idx = 1;
                       }
                       var table = document.getElementById('LC_slot_reservations');
                       if ((table.rows.length) && (table.rows.length >= lastresnum)) {
                           for (var i=lastresnum; i<table.rows.length; i++) {
                               if (table.rows[i].style.display != 'none') {
                                   idx ++;
                                   var bgcolnew = idx % 2;
                                   var bgcolold = (idx+1) % 2;  
                                   j = i+1;
                                   if (document.getElementById('LC_slotmaprow_'+j)) {
                                       document.getElementById('LC_slotmaprow_'+j).className = rowclasses[bgcolnew];
                                   } else {
                                       if (document.getElementById('LC_slotresrow_'+j)) {
                                           document.getElementById('LC_slotresrow_'+j).className = document.getElementById('LC_slotresrow_'+j).className.replace(rowclasses[bgcolold],rowclasses[bgcolnew]);
                                       }
                                   }
                               }
                           }
                       }
                   }
             }              }
         }          }
     }      }
Line 1816  sub manage_reservations { Line 1877  sub manage_reservations {
         return;          return;
     }      }
     my (%parent,%shownparent,%container,%container_title,%contents);      my (%parent,%shownparent,%container,%container_title,%contents);
     my ($depth,$count,$reservable,$lastcontainer,$rownum) = (0,0,0,0,0);      my ($depth,$count,$reservable,$lastcontainer,$rownum,$shown) = (0,0,0,0,0,0);
     my @backgrounds = ("LC_odd_row","LC_even_row");      my @backgrounds = ("LC_odd_row","LC_even_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>'.
                  &mt('Your reservation status for any such assignments is listed below:').                   &mt('Your reservation status for any such assignments is listed below:').
                  '</p>'.                   '</p>'.
                  '<table class="LC_data_table LC_tableOfContent">'."\n";                   '<table class="LC_data_table LC_tableOfContent" id="LC_slot_reservations">'."\n";
     my $shownheader = 0;      my $shownheader = 0;
     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);      my (@ordered,%output,$mapitem,$got_map_slot,$currmapoutput,$mapnum);
     $mapnum = 0;      $mapnum = 0;
       $shown = 0;
     while (my $resource = $it->next()) {      while (my $resource = $it->next()) {
         if ($resource == $it->BEGIN_MAP()) {          if ($resource == $it->BEGIN_MAP()) {
             @ordered=();  
             undef(%output);  
             $currmapoutput = '';  
             $got_map_slot = '';  
             $mapitem = '';  
             $depth++;              $depth++;
             $parent{$depth} = $lastcontainer;              $parent{$depth} = $lastcontainer;
         }          }
Line 1881  sub manage_reservations { Line 1938  sub manage_reservations {
                                     '</span></td>';                                      '</span></td>';
                     }                      }
                 }                  }
                   my $counter = 0;
                 foreach my $symb (@ordered) {                  foreach my $symb (@ordered) {
                     if (ref($output{$symb}) eq 'HASH') {                      if (ref($output{$symb}) eq 'HASH') {
                         my $bgcolor = $backgrounds[$output{$symb}{'rownum'} % $numcolors];                          $counter ++;
                           my $bgcolor = $backgrounds[($output{$symb}{'shown'} + $counter) % $numcolors];
                         $currmapoutput .= $output{$symb}{'header'}.                          $currmapoutput .= $output{$symb}{'header'}.
                                           '<tr class="'.$bgcolor.' LC_slotmaprow_'.$output{$symb}{'mapnum'}.'"'.                                            '<tr class="'.$bgcolor.' LC_slotresrow_'.$output{$symb}{'mapnum'}.'"'.
                                           ' style="display:none">'.$output{$symb}{'info'}.                                            ' style="display:none" id="LC_slotresrow_'.$output{$symb}{'rownum'}.'">'.
                                             $output{$symb}{'info'}.
                                           $output{$symb}{'data'}.'</tr>'."\n";                                            $output{$symb}{'data'}.'</tr>'."\n";
                     }                      }
                 }                  }
             } else {              } else {
                   my $counter = 0;
                 foreach my $symb (@ordered) {                  foreach my $symb (@ordered) {
                     if (ref($output{$symb}) eq 'HASH') {                      if (ref($output{$symb}) eq 'HASH') {
                         my $bgcolor = $backgrounds[$output{$symb}{'rownum'} % $numcolors];                          $counter ++;
                           my $bgcolor = $backgrounds[($output{$symb}{'shown'} + $counter) % $numcolors];
                         $currmapoutput .= $output{$symb}{'header'}.                          $currmapoutput .= $output{$symb}{'header'}.
                                           '<tr class="'.$bgcolor.' LC_slotmaprow_'.$output{$symb}{'mapnum'}.'"'.                                            '<tr class="'.$bgcolor.' LC_slotresrow_'.$output{$symb}{'mapnum'}.'"'.
                                           ' style="display:table-row">'.$output{$symb}{'info'}.                                            ' style="display:table-row" id="LC_slotresrow_'.$output{$symb}{'rownum'}.'">'.
                                             $output{$symb}{'info'}.
                                           $output{$symb}{'data'}.'</tr>'."\n";                                            $output{$symb}{'data'}.'</tr>'."\n";
                           $shown ++;
                     }                      }
                 }                  }
             }              }
Line 1910  sub manage_reservations { Line 1974  sub manage_reservations {
                 }                  }
             }              }
             $r->print($mapitem.$currmapoutput);              $r->print($mapitem.$currmapoutput);
               @ordered=();
               undef(%output);
               $currmapoutput = '';
               $got_map_slot = '';
               $mapitem = '';
         }          }
         if (ref($resource)) {          if (ref($resource)) {
             my $symb = $resource->symb();              my $symb = $resource->symb();
Line 2003  sub manage_reservations { Line 2072  sub manage_reservations {
                     for (my $i=0; $i<@maprows; $i++) {                      for (my $i=0; $i<@maprows; $i++) {
                         $mapnum ++;                          $mapnum ++;
                         $rownum ++;                          $rownum ++;
                         my $bgcolor = $backgrounds[$rownum % $numcolors];                          $shown ++;
                           my $bgcolor = $backgrounds[$shown % $numcolors];
                         if (!$shownheader) {                          if (!$shownheader) {
                             $mapitem .= $slotheader;                              $mapitem .= $slotheader;
                             $shownheader = 1;                              $shownheader = 1;
                         }                          }
                         if (ref($maprows[$i]) eq 'ARRAY') {                          if (ref($maprows[$i]) eq 'ARRAY') {
                             if ($i < scalar(@maprows)-1) {                              if ($i < scalar(@maprows)-1) {
                                 $mapitem .= '<tr class="'.$bgcolor.'"><td>'.join('',@{$maprows[$i]}).'</td>'.                                  $mapitem .= '<tr class="'.$bgcolor.'" id="LC_slotmaprow_'.$rownum.'">'.
                                               '<td>'.join('',@{$maprows[$i]}).'</td>'.
                                             '<td colspan="2">&nbsp;</td></tr>'."\n";                                              '<td colspan="2">&nbsp;</td></tr>'."\n";
                             } else {                              } else {
                                 $mapitem .=                                   $mapitem .= 
                                    '<tr class="'.$bgcolor.'"><td>'.$maprows[$i][0].                                     '<tr class="'.$bgcolor.'" id="LC_slotmaprow_'.$rownum.'">'.
                                      '<td>'.$maprows[$i][0].
                                    '<img src="/adm/lonIcons/arrow.open.gif" id="arrow'.$mapnum.'" '.                                     '<img src="/adm/lonIcons/arrow.open.gif" id="arrow'.$mapnum.'" '.
                                    'alt="arrow" onmouseover="this.style.cursor=\'pointer\'" '.                                     'alt="arrow" onmouseover="this.style.cursor=\'pointer\'" '.
                                    'onclick="'."toggleSlotMap('$mapnum');".'" />'.                                     'onclick="'."toggleSlotMap('$mapnum','$rownum');".'" />'.
                                    $maprows[$i][1].('&nbsp;' x6).'</td>'."\n";                                     $maprows[$i][1].('&nbsp;' x6).'</td>'."\n";
                             }                              }
                         }                          }
Line 2026  sub manage_reservations { Line 2098  sub manage_reservations {
                 }                  }
                 $rownum ++;                  $rownum ++;
                 $output{$symb}{'rownum'} = $rownum;                  $output{$symb}{'rownum'} = $rownum;
                   $output{$symb}{'shown'} = $shown;
                 if (!$shownheader) {                  if (!$shownheader) {
                     $output{$symb}{'header'} = $slotheader;                      $output{$symb}{'header'} = $slotheader;
                     $shownheader = 1;                      $shownheader = 1;

Removed from v.1.128  
changed lines
  Added in v.1.129


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