Diff for /loncom/interface/coursecatalog.pm between versions 1.107 and 1.108

version 1.107, 2025/02/24 13:40:33 version 1.108, 2025/02/24 23:20:17
Line 37  use Apache::lonnet; Line 37  use Apache::lonnet;
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::courseclassifier;  use Apache::courseclassifier;
 use Apache::lonacc;  use Apache::lonacc;
   use HTML::Entities();
 use LONCAPA;  use LONCAPA;
 use LONCAPA::lonauthcgi;  use LONCAPA::lonauthcgi;
   
Line 87  sub handler { Line 88  sub handler {
             ({href=>"/adm/coursecatalog",              ({href=>"/adm/coursecatalog",
               text=>"Course/Community Catalog"});                text=>"Course/Community Catalog"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));          $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));
         $r->print('<div>'.&mt('Access to catalog LON-CAPA courses/communities unavailable for: "[_1]" on servers run by: "[_2]".',          $r->print('<div role="main">'.&mt('Access to catalog LON-CAPA courses/communities unavailable for: "[_1]" on servers run by: "[_2]".',
                   $domdesc,$serverdomdesc).'</div>');                    $domdesc,$serverdomdesc).'</div>');
         $r->print(&Apache::loncommon::end_page());          $r->print(&Apache::loncommon::end_page());
         return OK;          return OK;
Line 118  sub handler { Line 119  sub handler {
           text=>"Course/Community Catalog"});            text=>"Course/Community Catalog"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));          $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));
         if ($knownuser || $canviewall) {          if ($knownuser || $canviewall) {
             $r->print('<div>'.&mt('No catalog of LON-CAPA courses/communities is provided for: [_1]',$domdesc).'</div>');              $r->print('<div role="main">'.&mt('No catalog of LON-CAPA courses/communities is provided for: [_1]',$domdesc).'</div>');
         } else {          } else {
             if ($domdefaults{'catauth'} eq 'none') {              if ($domdefaults{'catauth'} eq 'none') {
                 $r->print('<div>'.&mt('No catalog of LON-CAPA courses/communities is provided for: [_1]',$domdesc).'</div>');                  $r->print('<div role="main">'.&mt('No catalog of LON-CAPA courses/communities is provided for: [_1]',$domdesc).'</div>');
             } else {              } else {
                 $r->print('<div>'.&mt('The catalog of LON-CAPA courses/communities provided for: "[_1]" is only available to users who are logged in.',$domdesc).'</div>');                  $r->print('<div role="main">'.&mt('The catalog of LON-CAPA courses/communities provided for: "[_1]" is only available to users who are logged in.',$domdesc).'</div>');
             }              }
         }                }      
         $r->print(&Apache::loncommon::end_page());          $r->print(&Apache::loncommon::end_page());
         return OK;          return OK;
     }      }
   
       for (my $i=0; $i<=$env{'form.catalog_maxdepth'}; $i++) {
           if ($env{'form.currcat_'.$i} eq '-1') {
               $env{'form.currcat_'.$i} = '';
           }
           if (exists($env{'form.initialcurrcat_'.$i})) {
               if ($env{'form.currcat_'.$i} ne $env{'form.initialcurrcat_'.$i}) {
                   $env{'form.catalog_maxdepth'} = $i;
                   last;
               }
           }
       }
   
     my $cnum;      my $cnum;
     if ($cattype eq 'codesrch') {      if ($cattype eq 'codesrch') {
         my ($uniquecode,$codemsg,$brtext);          my ($uniquecode,$codemsg,$brtext);
Line 260  sub handler { Line 273  sub handler {
     } else {      } else {
         my ($catlinks,$has_subcats,$selitem) = &category_breadcrumbs($codedom,@cats);          my ($catlinks,$has_subcats,$selitem) = &category_breadcrumbs($codedom,@cats);
         my $wasacctext = &get_wasactive_text();          my $wasacctext = &get_wasactive_text();
           my %js_lt = &Apache::lonlocal::texthash(
                                                    'noch' => 'No changes made in drop-down lists',
                                                    'chsu' => 'Choose a subcategory to display',
                                                    'chca' => 'Choose a category to display',
           );
           &js_escape(\%js_lt);
         my $catjs = <<"ENDSCRIPT";          my $catjs = <<"ENDSCRIPT";
   
 function setCatDepth(depth) {  
     var depth = parseInt(depth);  
     if (depth !== NaN) {  
         if (depth > 0) {  
             var possmaxd = 0;  
             var toplevel = new Array($toplevelstr);  
             var maxdepths = new Array($maxdepthstr);  
             if (toplevel.length) {  
                 for (var i=0; i<toplevel.length; i++) {  
                     var item = unescape(toplevel[i]);  
                     if (item == document.coursecats.currcat_0.value) {  
                         possmaxd = maxdepths[i];  
                         break;  
                     }  
                 }  
             }  
             if (depth > possmaxd) {  
                 depth = possmaxd;  
             }  
         }  
         document.coursecats.catalog_maxdepth.value = depth;  
     } else {  
         document.coursecats.currcat_0.value = '';  
         document.coursecats.catalog_maxdepth.value = '';  
     }  
     document.coursecats.submit();  
     return;  
 }  
   
 function changeSort(caller) {  function changeSort(caller) {
     document.$formname.sortby.value = caller;      document.$formname.sortby.value = caller;
     document.$formname.submit();      document.$formname.submit();
Line 342  ENDTOGGJS Line 332  ENDTOGGJS
         } else {          } else {
             my (%add_entries);              my (%add_entries);
             my ($currdepth,$deeper) = &get_depth_values();              my ($currdepth,$deeper) = &get_depth_values();
             if ($selitem) {              my $alert = $js_lt{'chsu'};
                 my $alert = &mt('Choose a subcategory to display');              if (!$deeper) {
                 if (!$deeper) {                  $alert = $js_lt{'chca'};
                     $alert = &mt('Choose a category to display');              }
                 }              $catjs .= <<"ENDJS";
                 &js_escape(\$alert);  
                 $catjs .= <<ENDJS;  
 function check_selected() {  function check_selected() {
     if (document.coursecats.$selitem.options[document.coursecats.$selitem.selectedIndex].value == "") {      var currdepth = parseInt('$currdepth');
         alert('$alert');      var countchanged = 0;
       for (var i=0; i<=currdepth; i++) {
           var selidx = document.coursecats.elements['currcat_'+i].selectedIndex;
           var selvalue = document.coursecats.elements['currcat_'+i].options[selidx].value;
           if (i<currdepth) {
               var initialvalue = document.coursecats.elements['initialcurrcat_'+i].value;
               if (selvalue != initialvalue) {
                   countchanged ++;
               }
           } else {
               if (countchanged == 0) {
                   if (selvalue == "") {
                       alert('$alert');
                       return false;
                   } else {
                       countchanged ++;
                   }
               }
           }
       }
       if (countchanged == 0) {
           alert("$js_lt{'noch'}");
         return false;          return false;
     }      }
 }  }
 ENDJS  ENDJS
             }  
             my $js = '<script type="text/javascript">'."\n".              my $js = '<script type="text/javascript">'."\n".
                      '// <![CDATA['."\n".                       '// <![CDATA['."\n".
                      "$catjs\n".                       "$catjs\n".
Line 393  ENDJS Line 401  ENDJS
                                                 $canviewall,$hostname));                                                  $canviewall,$hostname));
             }              }
         }          }
           $r->print('</div>');
     }      }
     $r->print('<br />'.&Apache::loncommon::end_page());      $r->print(&Apache::loncommon::end_page());
     return OK;      return OK;
 }  }
   
Line 492  sub validate_input { Line 501  sub validate_input {
     }      }
   
     foreach my $key (sort(keys(%env))) {      foreach my $key (sort(keys(%env))) {
         if ($key =~ /^form\.(.+)$/) {          if ($key =~ /^form\.currcat_(.+)$/) {
             unless ($possibles{$1}) {              unless ($possibles{'currcat_'.$1}) {
                 delete($env{$key});                  delete($env{$key});
             }              }
         }          }
Line 702  sub course_details { Line 711  sub course_details {
              {text=>$brtexttwo});               {text=>$brtexttwo});
     $r->print(      $r->print(
         &Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog').          &Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog').
           '<div role="main">'.
         '<h2>'.$textthree.'</h2>'.          '<h2>'.$textthree.'</h2>'.
         &print_course_listing($codedom,undef,$trails,$allitems,undef,$codetitles,undef,$hostname).          &print_course_listing($codedom,undef,$trails,$allitems,undef,$codetitles,undef,$hostname).
         '<br />'.          '<br />'.
Line 710  sub course_details { Line 720  sub course_details {
             '<a href = "javascript:document.coursecatalog.submit()">'.$textfour.'</a>']).              '<a href = "javascript:document.coursecatalog.submit()">'.$textfour.'</a>']).
         &Apache::lonhtmlcommon::echo_form_input(['coursenum','catalogfilter',          &Apache::lonhtmlcommon::echo_form_input(['coursenum','catalogfilter',
                                                  'showdetails','courseid']).                                                   'showdetails','courseid']).
         '</form>');          '</form></div>');
     return;      return;
 }  }
   
Line 853  sub cat_header { Line 863  sub cat_header {
         ({href=>"/adm/coursecatalog",          ({href=>"/adm/coursecatalog",
           text=>"Course/Community Catalog"});            text=>"Course/Community Catalog"});
     }      }
     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));      $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog').
                 '<div role="main">');
     if ($cattype eq 'std') {      if ($cattype eq 'std') {
         my $onchange = 'this.form.submit()';  
         $r->print('<form name="coursecatdom" method="post" action="/adm/coursecatalog">'.          $r->print('<form name="coursecatdom" method="post" action="/adm/coursecatalog">'.
                   '<table border="0"><tr><td><b>'.&mt('Domain:').'</b></td><td>'.                    '<table border="0"><tr><th align="left"><label for="showdom">'.&mt('Domain:').'</label></th><td>'.
                   &Apache::loncommon::select_dom_form($codedom,'showdom','',1,$onchange));                    &Apache::loncommon::select_dom_form($codedom,'showdom','',1,'','','','','showdom').
         if (!$onchange) {                    '&nbsp;<input type="submit" name="godom" value="'.&mt('Change').'" />'."\n".
    $r->print('&nbsp;<input type="submit" name="godom" value="'.&mt('Change').'" />');                    '<input type="hidden" name="initialshowdom" value="'.$codedom.'" />'."\n".
         }                    '</td></tr></table></form>');
         $r->print('</td></tr></table></form>');      }
       my $onsubmit;
       unless ($env{'form.currcat_0'} eq 'instcode::0') {
           $onsubmit = ' onsubmit="return check_selected();"';
     }      }
     $r->print('<form name="coursecats" method="post" action="/adm/coursecatalog"'.      $r->print('<form name="coursecats" method="post" action="/adm/coursecatalog"'.$onsubmit.'>'.
               ' onsubmit="return check_selected();">'.  
               '<table border="0"><tr>'.$catlinks.'</tr></table></form>');                '<table border="0"><tr>'.$catlinks.'</tr></table></form>');
     return;      return;
 }  }
Line 877  sub category_breadcrumbs { Line 889  sub category_breadcrumbs {
     my $currcat_str =       my $currcat_str = 
         '<input type="hidden" name="catalog_maxdepth" value="'.$deeper.'" />'.          '<input type="hidden" name="catalog_maxdepth" value="'.$deeper.'" />'.
         '<input type="hidden" name="showdom" value="'.$dom.'" />';          '<input type="hidden" name="showdom" value="'.$dom.'" />';
     my $catlinks = '<td valign="top"><b>'.&mt('Catalog:').'</b></td><td><table><tr><td>';      my $catlinks = '<th class="LC_middle LC_left">'.&mt('Catalog:').'</th><td><div class="LC_leftfloat">';
     my $has_subcats;      my $has_subcats;
     my $selitem;      my $selitem;
       my $update_button;
     if (ref($cats[0]) eq 'ARRAY') {      if (ref($cats[0]) eq 'ARRAY') {
         if (@{$cats[0]} == 0) {          if (@{$cats[0]} == 0) {
             $catlinks .= &mt('No categories defined in this domain');               $catlinks .= &mt('No categories defined in this domain'); 
Line 901  sub category_breadcrumbs { Line 914  sub category_breadcrumbs {
             }              }
             $currcat_str .= '<input type="hidden" name="currcat_0" value="'.$env{'form.currcat_0'}.'" />';              $currcat_str .= '<input type="hidden" name="currcat_0" value="'.$env{'form.currcat_0'}.'" />';
         } else {          } else {
               $update_button = 1;
             $catlinks .= &main_category_selector(@cats);              $catlinks .= &main_category_selector(@cats);
             if (($env{'form.currcat_0'} ne '') &&               if (($env{'form.currcat_0'} ne '') && 
                 ($env{'form.currcat_0'} ne 'instcode::0')) {                  ($env{'form.currcat_0'} ne 'instcode::0')) {
Line 910  sub category_breadcrumbs { Line 924  sub category_breadcrumbs {
     } else {      } else {
         $catlinks .= &mt('Official courses (with institutional codes)');          $catlinks .= &mt('Official courses (with institutional codes)');
                      $env{'form.currcat_0'} = 'instcode::0';                       $env{'form.currcat_0'} = 'instcode::0';
          $currcat_str .= '<input type="hidden" name="currcat_0" value="'.$env{'form.currcat_0'}.'" />';          $currcat_str .= '<input type="hidden" name="currcat_0" value="'.$env{'form.currcat_0'}.'" />';
     }      }
     if ($deeper) {      if ($deeper) {
         for (my $i=1; $i<=$deeper; $i++) {          for (my $i=1; $i<=$deeper; $i++) {
Line 918  sub category_breadcrumbs { Line 932  sub category_breadcrumbs {
             next if ($shallower == 0);              next if ($shallower == 0);
             my ($cat,$container,$depth) = map { &unescape($_); } split(/:/,$env{'form.currcat_'.$shallower});              my ($cat,$container,$depth) = map { &unescape($_); } split(/:/,$env{'form.currcat_'.$shallower});
             if ($cat ne '') {              if ($cat ne '') {
                 $catlinks .= '<td valign="top">'.                  my $labeltext = &HTML::Entities::encode(&mt('Level [_1] category',$shallower),'<>&"');
                              '<select name="currcat_'.$shallower.'" onchange="'.                  $catlinks .= '<select name="currcat_'.$shallower.'" aria-label="'.$labeltext.'">';
                              'setCatDepth('."'$shallower'".');this.form.submit();">';  
                 if (ref($cats[$shallower]{$container}) eq 'ARRAY') {                  if (ref($cats[$shallower]{$container}) eq 'ARRAY') {
                     $catlinks .= '<option value="">'.&mt('De-select').'</option>';                      $catlinks .= '<option value="-1">'.&mt('De-select').'</option>';
                     for (my $j=0; $j<@{$cats[$shallower]{$container}}; $j++) {                      for (my $j=0; $j<@{$cats[$shallower]{$container}}; $j++) {
                         my $name = $cats[$shallower]{$container}[$j];                          my $name = $cats[$shallower]{$container}[$j];
                         my $item = &escape($name).':'.&escape($container).':'.$shallower;                          my $item = &escape($name).':'.&escape($container).':'.$shallower;
Line 934  sub category_breadcrumbs { Line 947  sub category_breadcrumbs {
                            '<option value="'.$item.'"'.$selected.'>'.$name.'</option>';                             '<option value="'.$item.'"'.$selected.'>'.$name.'</option>';
                     }                      }
                 }                  }
                 $catlinks .= '</select>';                  $catlinks .= '</select>'.
                                '<input type="hidden" name="initialcurrcat_'.$shallower.'" value="'.$env{'form.currcat_'.$shallower}.'" />';
             }              }
             unless ($i == $deeper) {              unless ($i == $deeper) {
                 $catlinks .= $crumbsymbol;                  $catlinks .= $crumbsymbol;
Line 952  sub category_breadcrumbs { Line 966  sub category_breadcrumbs {
             $has_subcats = 1;              $has_subcats = 1;
             my $buttontext = &mt('Show subcategories');              my $buttontext = &mt('Show subcategories');
             my $selitem = 'currcat_'.$deeperlevel;              my $selitem = 'currcat_'.$deeperlevel;
             $catlinks .= '&nbsp;<select name="'.$selitem.'" onchange="this.form.submit()">';              my $labeltext = &HTML::Entities::encode(&mt('Level [_1] category',$deeperlevel),'<>&"');
               $catlinks .= '&nbsp;<select name="'.$selitem.'" aria-label="'.$labeltext.'">';
             if (@{$cats[$deeperlevel]{$cat}}) {              if (@{$cats[$deeperlevel]{$cat}}) {
                 $catlinks .= '<option value="" selected="selected">'.                  $catlinks .= '<option value="" selected="selected">'.
                              &mt('Subcategory ...').'</option>';                               &mt('Subcategory ...').'</option>';
Line 969  sub category_breadcrumbs { Line 984  sub category_breadcrumbs {
     } else {      } else {
         $selitem = 'currcat_0';          $selitem = 'currcat_0';
     }      }
     $catlinks .= $currcat_str.'</td></tr></table></td>';      $catlinks .= $currcat_str;
       if ($update_button) {
           $catlinks .= '&nbsp;<input type="submit" name="gocat" value="'.&mt('Update').'" />'."\n";
       }
       $catlinks .= '</div></td>';
     return ($catlinks,$has_subcats,$selitem);      return ($catlinks,$has_subcats,$selitem);
 }  }
   
 sub main_category_selector {  sub main_category_selector {
     my (@cats) = @_;      my (@cats) = @_;
     my $maincatlinks = '<select name="currcat_0" onchange="setCatDepth('."'0'".');this.form.submit();">'."\n";      my $labeltext = &HTML::Entities::encode(&mt('Top level category'),'<>&"');
       my $maincatlinks = '<select name="currcat_0" aria-label="'.$labeltext.'">'."\n";
     if (ref($cats[0]) eq 'ARRAY') {      if (ref($cats[0]) eq 'ARRAY') {
         if (@{$cats[0]} > 1) {          if (@{$cats[0]} > 1) {
             my $selected = '';              my $selected = '';
Line 1004  sub main_category_selector { Line 1024  sub main_category_selector {
             }              }
             $maincatlinks .= '</option>'."\n";              $maincatlinks .= '</option>'."\n";
         }          }
         $maincatlinks .= '</select>'."\n";          $maincatlinks .= '</select>'."\n".
                            '<input type="hidden" name="initialcurrcat_0" value="'.$env{'form.currcat_0'}.'" />'."\n";
     }      }
     return $maincatlinks;      return $maincatlinks;
 }  }
Line 1030  sub additional_filters { Line 1051  sub additional_filters {
     if ($is_dc || $canviewall) {      if ($is_dc || $canviewall) {
         $output .= '<fieldset><legend>'.&mt('Options').'</legend>';          $output .= '<fieldset><legend>'.&mt('Options').'</legend>';
     }      }
     $output .= '<table><tr><td valign="top">';      $output .= '<div class="LC_floatleft" style="text-align: top">';
     if (($env{'form.currcat_0'} ne 'instcode::0') &&      if (($env{'form.currcat_0'} ne 'instcode::0') &&
         ($env{'form.currcat_0'} ne '') && ($has_subcats)) {          ($env{'form.currcat_0'} ne '') && ($has_subcats)) {
         my $include_subcat_status;          my $include_subcat_status;
Line 1091  sub additional_filters { Line 1112  sub additional_filters {
             }              }
         } else {          } else {
             $statusdisplay = 'none';              $statusdisplay = 'none';
             $cellborder = 'border-left: 0px';              $cellborder = 'border-left: 0px;';
         }          }
           $cellborder .= ' vertical-align: top;';
         if ($env{'form.currcat_0'} eq 'communities::0') {          if ($env{'form.currcat_0'} eq 'communities::0') {
             $details_text = &mt('Show full details for each community (domain staff only)');              $details_text = &mt('Show full details for each community (domain staff only)');
             $hidden_text = &mt('Include communities set to be hidden from catalog (domain staff only)');              $hidden_text = &mt('Include communities set to be hidden from catalog (domain staff only)');
Line 1112  sub additional_filters { Line 1134  sub additional_filters {
         $output .= '<span class="LC_nobreak">'.          $output .= '<span class="LC_nobreak">'.
                    '<label><input type="checkbox" name="showdetails" value="1" '.                     '<label><input type="checkbox" name="showdetails" value="1" '.
                    $showdetails_status.'onclick="toggleStatuses();" />'.                     $showdetails_status.'onclick="toggleStatuses();" />'.
                    $details_text.'</label></span></td>'."\n".                     $details_text.'</label></span></div>'."\n".
                    '<td id="statuscell" valign="top" style="'.$cellborder.'">'.                     '<div class="LC_floatleft" id="statuscell" style="'.$cellborder.'">'.
                    '<div id="statuschoice" style="display:'.$statusdisplay.'">';                     '<div class="LC_floatleft" id="statuschoice" style="display:'.$statusdisplay.'; margin-left: 10px">';
         if (ref($orderref) eq 'ARRAY') {          if (ref($orderref) eq 'ARRAY') {
             if (@{$orderref} > 0) {              if (@{$orderref} > 0) {
                 foreach my $type (@{$orderref}) {                  foreach my $type (@{$orderref}) {
Line 1144  sub additional_filters { Line 1166  sub additional_filters {
                             date      => 'immediately prior to specific date:',                              date      => 'immediately prior to specific date:',
                         );                          );
                         my @statuses = &Apache::loncommon::get_env_multiple('form.showcounts');                          my @statuses = &Apache::loncommon::get_env_multiple('form.showcounts');
                         $output .= '<span id="choosewasacctext" class="LC_nobreak">';                          my $wasactivetext;
                         if ($checked) {                          if ($checked) {
                             $output .= &get_wasactive_text();                              $wasactivetext = &get_wasactive_text();
                         }                          }
                         $output .= '</span>'.                          $output .= '<div id="choosewasactive" style="display:'.$wasactivedisplay.'">'."\n".
                                    '<div id="choosewasactive" style="display:'.$wasactivedisplay.'">'.                                     '<fieldset style="margin-left: 4px">'."\n".
                                    '<table>';                                     '<legend id="choosewasacctext" style="font-weight: normal">'."\n".
                                      $wasactivetext.'</legend>'."\n";
                         my @milestones = ('accessend');                          my @milestones = ('accessend');
                         if (&Apache::lonnet::auto_run(undef,$codedom)) {                          if (&Apache::lonnet::auto_run(undef,$codedom)) {
                             push(@milestones,'enrollend');                              push(@milestones,'enrollend');
Line 1166  sub additional_filters { Line 1189  sub additional_filters {
                                 $checked = ' checked="checked"';                                  $checked = ' checked="checked"';
                             }                              }
                             $output .=                              $output .=
                                 '<tr><td width="10">&nbsp;</td><td>'.                                  '<span class="LC_nobreak" style="padding-left:10px;"><label>'.
                                 '<span class="LC_nobreak"><label>'.  
                                 '<input type="radio" value="'.$item.'" name="wasactive"'.$checked.' />'.                                  '<input type="radio" value="'.$item.'" name="wasactive"'.$checked.' />'.
                                 $milestonetext{$item}.'</label></span>';                                  $milestonetext{$item}.'</label></span>';
                             if ($item eq 'date') {                              if ($item eq 'date') {
Line 1185  sub additional_filters { Line 1207  sub additional_filters {
                                                                         '','','',1,'',                                                                          '','','',1,'',
                                                                         '','',1);                                                                          '','',1);
                             }                              }
                             $output .= '</td></tr>';                              $output .= '<br />';
                         }                          }
                         $output .= '</table></div>';                          $output .= '</fieldset></div>';
                     }                      }
                     $output .= '<br />';                      $output .= '<br />';
                 }                  }
             }              }
         }          }
         $output .= '</div></td>';          $output .= '</div></div>';
     } else {      } else {
         $output .= '</td>';            $output .= '</div>';  
     }      }
     $output .= '</tr></table></fieldset></div>'.      $output .= '</fieldset></div>'.
                '<div style="clear:both;margin:0;"></div>';                   '<div style="clear:both;margin:0;"></div>';  
     return $output;      return $output;
 }  }
Line 1256  sub get_statustitles { Line 1278  sub get_statustitles {
 }  }
   
 sub get_wasactive_text {  sub get_wasactive_text {
     my $wasacctext = ' -- ';      my $wasacctext;
     if ($env{'form.currcat_0'} eq 'communities::0') {      if ($env{'form.currcat_0'} eq 'communities::0') {
         $wasacctext .= &mt('where member access status was current ...');          $wasacctext .= &mt('count where member access status was current ...');
     } else {      } else {
         $wasacctext .= &mt('where student access status was current ...');          $wasacctext .= &mt('count where student access status was current ...');
     }      }
     return $wasacctext;      return $wasacctext;
 }  }
Line 1414  sub construct_data_table { Line 1436  sub construct_data_table {
         if (defined($sortname{$item})) {          if (defined($sortname{$item})) {
             $output .= '<a href="javascript:changeSort('."'$sortname{$item}'".')">'.&mt($item).'</a>';              $output .= '<a href="javascript:changeSort('."'$sortname{$item}'".')">'.&mt($item).'</a>';
         } elsif ($item eq 'Count') {          } elsif ($item eq 'Count') {
             $output .= '&nbsp;&nbsp;';              $output .= '#';
         } else {          } else {
             $output .= &mt($item);              $output .= &mt($item);
         }          }

Removed from v.1.107  
changed lines
  Added in v.1.108


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